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
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
|
/**
* @file llimpanel.h
* @brief LLIMPanel class definition
*
* Copyright (c) 2001-2007, Linden Research, Inc.
*
* The source code in this file ("Source Code") is provided by Linden Lab
* to you under the terms of the GNU General Public License, version 2.0
* ("GPL"), unless you have obtained a separate licensing agreement
* ("Other License"), formally executed by you and Linden Lab. Terms of
* the GPL can be found in doc/GPL-license.txt in this distribution, or
* online at http://secondlife.com/developers/opensource/gplv2
*
* There are special exceptions to the terms and conditions of the GPL as
* it is applied to this Source Code. View the full text of the exception
* in the file doc/FLOSS-exception.txt in this software distribution, or
* online at http://secondlife.com/developers/opensource/flossexception
*
* By copying, modifying or distributing this software, you acknowledge
* that you have read and understood your obligations described above,
* and agree to abide by those obligations.
*
* ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
* WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
* COMPLETENESS OR PERFORMANCE.
*/
#ifndef LL_IMPANEL_H
#define LL_IMPANEL_H
#include "llfloater.h"
#include "lluuid.h"
#include "lldarray.h"
#include "llinstantmessage.h"
class LLLineEditor;
class LLViewerTextEditor;
class LLInventoryItem;
class LLInventoryCategory;
class LLFloaterIMPanel : public LLFloater
{
public:
// The session id is the id of the session this is for. The target
// refers to the user (or group) that where this session serves as
// the default. For example, if you open a session though a
// calling card, a new session id will be generated, but the
// target_id will be the agent referenced by the calling card.
LLFloaterIMPanel(const std::string& name, const LLRect& rect,
const std::string& session_label,
const LLUUID& session_id, const LLUUID& target_id,
EInstantMessage dialog);
/*virtual*/ BOOL postBuild();
// Check typing timeout timer.
/*virtual*/ void draw();
/*virtual*/ void onClose(bool app_quitting = FALSE);
// add target ids to the session.
// Return TRUE if successful, otherwise FALSE.
BOOL addParticipants(const LLDynamicArray<LLUUID>& agent_ids);
void addHistoryLine(const std::string &utf8msg,
const LLColor4& color = LLColor4::white,
bool log_to_file = true);
void setInputFocus( BOOL b );
void selectAll();
void selectNone();
void setVisible(BOOL b);
BOOL handleKeyHere(KEY key, MASK mask, BOOL called_from_parent);
BOOL handleDragAndDrop(S32 x, S32 y, MASK mask,
BOOL drop, EDragAndDropType cargo_type,
void *cargo_data, EAcceptance *accept,
LLString& tooltip_msg);
static void onInputEditorFocusReceived( LLUICtrl* caller, void* userdata );
static void onInputEditorFocusLost(LLLineEditor* caller, void* userdata);
static void onInputEditorKeystroke(LLLineEditor* caller, void* userdata);
static void onTabClick( void* userdata );
static void onClickProfile( void* userdata ); // Profile button pressed
static void onClickClose( void* userdata );
//const LLUUID& getItemUUID() const { return mItemUUID; }
const LLUUID& getSessionID() const { return mSessionUUID; }
const LLUUID& getOtherParticipantID() const { return mOtherParticipantUUID; }
// HACK -- for enabling a teleport button for helpers
static void onTeleport(void* userdata);
void addTeleportButton(const LLUUID& lure_id);
void removeTeleportButton();
// Handle other participant in the session typing.
void processIMTyping(const LLIMInfo* im_info, BOOL typing);
static void chatFromLogFile(LLString line, void* userdata);
private:
// called by constructors
void init();
// Called by UI methods.
void sendMsg();
// for adding agents via the UI. Return TRUE if possible, do it if
BOOL dropCallingCard(LLInventoryItem* item, BOOL drop);
BOOL dropCategory(LLInventoryCategory* category, BOOL drop);
// test if local agent can add agents.
BOOL isAddAllowed() const;
// Called whenever the user starts or stops typing.
// Sends the typing state to the other user if necessary.
void setTyping(BOOL typing);
// Add the "User is typing..." indicator.
void addTypingIndicator(const LLIMInfo* im_info);
// Remove the "User is typing..." indicator.
void removeTypingIndicator();
void sendTypingState(BOOL typing);
static LLFloaterIMPanel* sInstance;
private:
LLLineEditor* mInputEditor;
LLViewerTextEditor* mHistoryEditor;
std::string mSessionLabel;
// The value of the mSessionUUID depends on how the IM session was started:
// one-on-one ==> random id
// group ==> group_id
// inventory folder ==> folder item_id
// 911 ==> Gaurdian_Angel_Group_ID ^ gAgent.getID()
LLUUID mSessionUUID;
// The value mOtherParticipantUUID depends on how the IM session was started:
// one-on-one = recipient's id
// group ==> group_id
// inventory folder ==> first target id in list
// 911 ==> sender
LLUUID mOtherParticipantUUID;
// the lure ID for help IM sessions
LLUUID mLureID;
EInstantMessage mDialog;
// Are you currently typing?
BOOL mTyping;
// Is other user currently typing?
BOOL mOtherTyping;
// Where does the "User is typing..." line start?
S32 mTypingLineStartIndex;
BOOL mSentTypingState;
// Optimization: Don't send "User is typing..." until the
// user has actually been typing for a little while. Prevents
// extra IMs for brief "lol" type utterences.
LLFrameTimer mFirstKeystrokeTimer;
// Timer to detect when user has stopped typing.
LLFrameTimer mLastKeystrokeTimer;
};
#endif // LL_IMPANEL_H
|