Namespace for chat-related functionalities.
Members
-
static chat.channels :Array.<ChannelDescription>
-
Holds channels infos.
Methods
-
inner addChannel(channelDesc)
-
Add to the channel list a new channel description
If tabs are already created, a tab is created for this channel as well
Parameters:
Name Type Description channelDesc
ChannelDescription channel description
-
inner addNickname(nick)
-
Adds a nickname to the chat input.
Parameters:
Name Type Description nick
string The nickname to add.
-
inner backgroundChannelData(instance, channel, flag)
-
Allows plugins to request and monitor COMM data streams in the background. This is useful for plugins that need to process COMM data even when the user is not actively viewing the COMM channels. It tracks the requested channels for each plugin instance and updates the global state accordingly.
Parameters:
Name Type Description instance
string A unique identifier for the plugin or instance requesting background COMM data.
channel
string The name of the COMM channel ('all', 'faction', or 'alerts').
flag
boolean Set to true to request data for the specified channel, false to stop requesting.
-
inner chooser(event)
-
Chat tab chooser handler. This function is triggered by a click event on the chat tab. It reads the tab name from the event target and activates the corresponding chat tab.
Parameters:
Name Type Description event
Event The event triggered by clicking a chat tab.
-
inner chooseTab(tab)
-
Chooses and activates a specified chat tab. Also triggers an early refresh of the chat data when switching tabs.
Parameters:
Name Type Description tab
string The name of the chat tab to activate ('all', 'faction', or 'alerts').
-
inner getActive() → {string}
-
Gets the name of the active chat tab.
Returns:
string -The name of the active chat tab.
-
inner getChannelDesc(tab) → {ChannelDescription}
-
Converts a chat tab name to its corresponding channel object.
Parameters:
Name Type Description tab
string The name of the chat tab.
Returns:
ChannelDescription -The corresponding channel name ('faction', 'alerts', or 'all').
-
inner handleTabCompletion()
-
Handles tab completion in chat input.
-
inner keepScrollPosition(box, scrollBefore, isOldMsgs)
-
Maintains the scroll position of a chat box when new messages are added. This function is designed to keep the scroll position fixed when old messages are loaded, and to automatically scroll to the bottom when new messages are added if the user is already at the bottom of the chat.
Parameters:
Name Type Description box
jQuery The jQuery object of the chat box.
scrollBefore
number The scroll position before new messages were added.
isOldMsgs
boolean Indicates if the added messages are older messages.
-
inner needMoreMessages()
-
Checks if the currently selected chat tab needs more messages. This function is triggered by scroll events and loads older messages when the user scrolls to the top.
-
inner nicknameClicked(event, nickname) → {boolean}
-
Handles click events on nicknames in the chat.
Parameters:
Name Type Description event
Event The click event.
nickname
string The clicked nickname.
Returns:
boolean -Always returns false.
-
inner postMsg()
-
Posts a chat message to the currently active chat tab.
-
inner renderAlerts(oldMsgsWereAdded)
-
Renders alerts chat in the UI.
Parameters:
Name Type Description oldMsgsWereAdded
boolean Indicates if older messages were added to the chat.
-
inner renderFaction(oldMsgsWereAdded)
-
Renders faction chat.
Parameters:
Name Type Description oldMsgsWereAdded
boolean Indicates if old messages were added in the current rendering.
-
inner renderMsg(msg, nick, time, team, msgToPlayer, systemNarrowcast) → {string}
-
Legacy function for rendering chat messages. Used for backward compatibility with plugins.
Parameters:
Name Type Description msg
string The chat message.
nick
string The nickname of the player who sent the message.
time
number The timestamp of the message.
team
string The team of the player who sent the message.
msgToPlayer
boolean Flag indicating if the message is directed to the player.
systemNarrowcast
boolean Flag indicating if the message is a system narrowcast.
Returns:
string -The HTML string representing a chat message row.
- Deprecated:
- Yes
-
inner renderPublic(oldMsgsWereAdded)
-
Renders public chat in the UI.
Parameters:
Name Type Description oldMsgsWereAdded
boolean Indicates if older messages were added to the chat.
-
inner request()
-
Requests chat messages for the currently active chat tab and background channels. It calls the appropriate request function based on the active tab or background channels.
-
inner requestAlerts(getOlderMsgs, isRetryopt)
-
Initiates a request for alerts chat data.
Parameters:
Name Type Attributes Default Description getOlderMsgs
boolean Whether to retrieve older messages.
isRetry
boolean <optional>
false Whether the request is a retry.
-
inner requestFaction(getOlderMsgs, isRetryopt)
-
Requests faction chat messages.
Parameters:
Name Type Attributes Default Description getOlderMsgs
boolean Flag to determine if older messages are being requested.
isRetry
boolean <optional>
false Flag to indicate if this is a retry attempt.
-
inner requestPublic(getOlderMsgs, isRetryopt)
-
Initiates a request for public chat data.
Parameters:
Name Type Attributes Default Description getOlderMsgs
boolean Whether to retrieve older messages.
isRetry
boolean <optional>
false Whether the request is a retry.
-
inner setup()
-
Sets up the chat interface.
-
inner setupPosting()
-
Sets up the chat message posting functionality.
-
inner setupTabs(channelDesc)
-
Sets up all channels starting from intel COMM
Parameters:
Name Type Description channelDesc
ChannelDescription channel description
-
inner setupTime()
-
Sets up the time display in the chat input box. This function updates the time displayed next to the chat input field every minute to reflect the current time.
-
inner show(name)
-
Displays the chat interface and activates a specified chat tab.
Parameters:
Name Type Description name
string The name of the chat tab to show and activate.
-
inner tabToChannel(tab) → {string}
-
Legacy function for converts a chat tab name to its corresponding COMM channel name. Used for backward compatibility with plugins.
Parameters:
Name Type Description tab
string The name of the chat tab.
Returns:
string -The corresponding channel name ('faction', 'alerts', or 'all').
- Deprecated:
- Yes
-
inner toggle()
-
Toggles the chat window between expanded and collapsed states. When expanded, the chat window covers a larger area of the screen. This function also ensures that the chat is scrolled to the bottom when collapsed.
Type Definitions
-
ChannelDescription
-
Hold channel description
See comm.js for examples
Properties:
Name Type Attributes Description id
string uniq id, matches 'tab' parameter for server requests
name
string visible name
inputPrompt
string <optional>
(optional) string for the input prompt
inputClass
string <optional>
(optional) class to apply to #chatinput
sendMessage
ChannelSendMessageFn <optional>
(optional) function to send the message
request
ChannelRequestFn <optional>
(optional) function to call to request new message
render
ChannelRenderFn <optional>
(optional) function to render channel content,, called on tab change
localBounds
boolean <optional>
(optional) if true, reset on view change
-
ChannelRenderFn(id, oldMsgsWereAdded) → {void}
-
Parameters:
Name Type Description id
string channel id
oldMsgsWereAdded
boolean true if data has been added at the top (to preserve scroll position)
Returns:
void -
ChannelRequestFn(id, getOlderMsgs, isRetry) → {void}
-
Parameters:
Name Type Description id
string channel id
getOlderMsgs
boolean true if request data from a scroll to top
isRetry
boolean Returns:
void -
ChannelSendMessageFn(id, message) → {void}
-
Parameters:
Name Type Description id
string channel id
message
string input message
Returns:
void