blob: 3225af9a2f331f28abdfa7f720ef186aed5ea576 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
|
/*
* Jitsi, the OpenSource Java VoIP and Instant Messaging client.
*
* Copyright @ 2015 Atlassian Pty Ltd
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package net.java.sip.communicator.impl.muc;
import java.util.*;
import net.java.sip.communicator.service.contactsource.*;
import net.java.sip.communicator.service.muc.*;
import net.java.sip.communicator.service.protocol.*;
/**
* Basic source contact for the chat rooms.
*
* @author Hristo Terezov
*/
public class BaseChatRoomSourceContact
extends SortedGenericSourceContact
{
/**
* The parent contact query.
*/
protected final ContactQuery parentQuery;
/**
* The name of the chat room associated with the contact.
*/
private String chatRoomName;
/**
* The ID of the chat room associated with the contact.
*/
private String chatRoomID;
/**
* The protocol provider of the chat room associated with the contact.
*/
private ProtocolProviderService provider;
/**
* Contsructs new chat room source contact.
* @param chatRoomName the name of the chat room associated with the room.
* @param chatRoomID the id of the chat room associated with the room.
* @param query the query associated with the contact.
* @param pps the protocol provider of the contact.
*/
public BaseChatRoomSourceContact(String chatRoomName,
String chatRoomID, ContactQuery query, ProtocolProviderService pps)
{
super(query, query.getContactSource(), chatRoomName,
generateDefaultContactDetails(chatRoomName));
this.chatRoomName = chatRoomName;
this.chatRoomID = chatRoomID;
this.provider = pps;
this.parentQuery = query;
initContactProperties(ChatRoomPresenceStatus.CHAT_ROOM_OFFLINE);
setDisplayDetails(pps.getAccountID().getDisplayName());
}
/**
* Sets the given presence status and the name of the chat room associated
* with the contact.
* @param status the presence status to be set.
*/
protected void initContactProperties(PresenceStatus status)
{
setPresenceStatus(status);
setContactAddress(chatRoomName);
}
/**
* Generates the default contact details for
* <tt>BaseChatRoomSourceContact</tt> instances.
*
* @param chatRoomName the name of the chat room associated with the contact
* @return list of default <tt>ContactDetail</tt>s for the contact.
*/
private static List<ContactDetail> generateDefaultContactDetails(
String chatRoomName)
{
ContactDetail contactDetail
= new ContactDetail(chatRoomName);
List<Class<? extends OperationSet>> supportedOpSets
= new ArrayList<Class<? extends OperationSet>>();
supportedOpSets.add(OperationSetMultiUserChat.class);
contactDetail.setSupportedOpSets(supportedOpSets);
List<ContactDetail> contactDetails
= new ArrayList<ContactDetail>();
contactDetails.add(contactDetail);
return contactDetails;
}
/**
* Returns the id of the chat room associated with the contact.
*
* @return the chat room id.
*/
public String getChatRoomID()
{
return chatRoomID;
}
/**
* Returns the name of the chat room associated with the contact.
*
* @return the chat room name
*/
public String getChatRoomName()
{
return chatRoomName;
}
/**
* Returns the provider of the chat room associated with the contact.
*
* @return the provider
*/
public ProtocolProviderService getProvider()
{
return provider;
}
/**
* Returns the index of this source contact in its parent group.
*
* @return the index of this contact in its parent
*/
public int getIndex()
{
if(parentQuery instanceof ServerChatRoomQuery)
return ((ServerChatRoomQuery)parentQuery).indexOf(this);
return -1;
}
}
|