1
0
mirror of https://github.com/wbbaddons/Tims-Chat.git synced 2025-01-12 00:50:09 +00:00
Tims-Chat/file/js/be.bastelstu.Chat.coffee

579 lines
17 KiB
CoffeeScript
Raw Normal View History

2011-12-19 14:46:40 +00:00
###
# be.bastelstu.WCF.Chat
2011-12-26 19:02:23 +00:00
#
# @author Tim Düsterhus
2013-01-19 19:36:40 +00:00
# @copyright 2010-2013 Tim Düsterhus
2011-12-26 19:02:23 +00:00
# @license Creative Commons Attribution-NonCommercial-ShareAlike <http://creativecommons.org/licenses/by-nc-sa/3.0/legalcode>
2013-01-19 19:36:40 +00:00
# @package be.bastelstu.chat
2011-12-19 14:46:40 +00:00
###
2012-04-27 13:42:44 +00:00
window.console ?=
log: () ->,
warn: () ->,
error: () ->
2012-06-19 14:23:18 +00:00
(($, window, _console) ->
2013-02-01 19:41:59 +00:00
"use strict";
window.be ?= {}
be.bastelstu ?= {}
2012-04-27 13:42:44 +00:00
console =
log: (message) ->
2013-01-29 20:41:02 +00:00
_console.log "[be.bastelstu.Chat] #{message}"
2012-04-27 13:42:44 +00:00
warn: (message) ->
2013-01-29 20:41:02 +00:00
_console.warn "[be.bastelstu.Chat] #{message}"
2012-04-27 13:42:44 +00:00
error: (message) ->
2013-01-29 20:41:02 +00:00
_console.error "[be.bastelstu.Chat] #{message}"
2012-04-27 13:42:44 +00:00
2013-01-19 19:36:40 +00:00
be.bastelstu.Chat = Class.extend
# Tims Chat stops loading when this reaches zero
# TODO: We need an explosion animation
shields: 3
# Are we currently loading messages?
loading: false
2012-01-28 15:09:24 +00:00
# Templates
titleTemplate: null
messageTemplate: null
2012-01-28 15:09:24 +00:00
# Notifications
2011-12-26 21:16:37 +00:00
newMessageCount: null
2012-01-28 13:08:51 +00:00
isActive: true
2012-01-28 15:09:24 +00:00
# Autocompleter
2012-01-28 13:08:51 +00:00
autocompleteOffset: 0
autocompleteValue: null
2012-10-20 11:45:05 +00:00
autocompleteCaret: 0
2012-01-28 15:09:24 +00:00
# Autoscroll
oldScrollTop: null
2012-01-28 15:09:24 +00:00
# Events
2012-01-12 19:04:28 +00:00
events:
newMessage: $.Callbacks()
userMenu: $.Callbacks()
2012-06-19 14:30:16 +00:00
submit: $.Callbacks()
2012-04-27 13:42:44 +00:00
# socket.io
socket: null
pe:
getMessages: null
refreshRoomList: null
fish: null
2013-01-09 18:59:32 +00:00
init: (@config, @titleTemplate, @messageTemplate) ->
2012-04-27 13:42:44 +00:00
console.log 'Initializing'
2013-01-14 19:52:09 +00:00
@events =
newMessage: $.Callbacks()
userMenu: $.Callbacks()
submit: $.Callbacks()
2011-12-24 16:47:07 +00:00
@bindEvents()
@events.newMessage.add $.proxy @notify, @
@pe.refreshRoomList = new WCF.PeriodicalExecuter $.proxy(@refreshRoomList, @), 60e3
@pe.getMessages = new WCF.PeriodicalExecuter $.proxy(@getMessages, @), @config.reloadTime * 1e3
@refreshRoomList()
@getMessages()
2012-04-27 13:42:44 +00:00
@initPush()
2011-12-26 19:02:23 +00:00
2012-04-27 13:42:44 +00:00
console.log 'Finished initializing - Shields at 104 percent'
2011-12-19 14:52:00 +00:00
###
2012-01-28 13:08:51 +00:00
# Autocompletes a username
###
autocomplete: (firstChars, offset = @autocompleteOffset) ->
users = []
2012-01-28 14:57:33 +00:00
# Search all matching users
2012-02-05 16:21:43 +00:00
for user in $ '.timsChatUser'
2012-03-07 22:04:19 +00:00
username = $(user).data 'username'
2012-01-28 13:08:51 +00:00
if username.indexOf(firstChars) is 0
users.push username
2012-01-28 14:57:33 +00:00
# None found -> return firstChars
# otherwise return the user at the current offset
2012-10-20 11:45:05 +00:00
return if users.length is 0 then firstChars else users[offset % users.length] + ','
2012-01-28 13:08:51 +00:00
###
2011-12-19 14:52:00 +00:00
# Binds all the events needed for Tims Chat.
###
2013-02-07 21:34:05 +00:00
bindEvents: ->
# Mark window as focused
2013-02-07 21:34:05 +00:00
$(window).focus =>
2012-02-05 16:21:43 +00:00
document.title = @titleTemplate.fetch
title: $('#timsChatRoomList .activeMenuItem a').text()
2011-12-26 21:16:37 +00:00
@newMessageCount = 0
@isActive = true
2013-02-07 21:34:05 +00:00
2011-12-26 21:16:37 +00:00
# Mark window as blurred
2013-02-07 21:34:05 +00:00
$(window).blur =>
2011-12-26 21:16:37 +00:00
@isActive = false
2013-02-07 21:34:05 +00:00
2011-12-26 21:16:37 +00:00
# Unload the chat
2013-02-07 21:34:05 +00:00
$(window).on 'beforeunload', =>
@unload()
2013-02-07 21:34:05 +00:00
undefined
2012-01-28 14:57:33 +00:00
# Insert a smiley
2013-02-07 21:34:05 +00:00
$('#smilies').on 'click', 'img', (event) =>
2011-12-24 16:47:07 +00:00
@insertText ' ' + $(event.target).attr('alt') + ' '
2013-02-07 21:34:05 +00:00
2011-12-26 19:02:23 +00:00
2012-01-28 14:57:33 +00:00
# Switch sidebar tab
2013-02-07 21:34:05 +00:00
$('.timsChatSidebarTabs li').click (event) =>
event.preventDefault()
2011-12-24 16:47:07 +00:00
@toggleSidebarContents $ event.target
2013-02-07 21:34:05 +00:00
2011-12-26 19:02:23 +00:00
2012-01-28 14:57:33 +00:00
# Submit Handler
2013-02-07 21:34:05 +00:00
$('#timsChatForm').submit (event) =>
event.preventDefault()
2011-12-24 16:47:07 +00:00
@submit $ event.target
2013-02-07 21:34:05 +00:00
2012-01-28 14:57:33 +00:00
# Autocompleter
2013-02-07 21:34:05 +00:00
$('#timsChatInput').keydown (event) =>
# tab key
2012-01-28 13:08:51 +00:00
if event.keyCode is 9
event.preventDefault()
2012-10-20 11:45:05 +00:00
@autocompleteValue = $('#timsChatInput').val() if @autocompleteValue is null
@autocompleteCaret = $('#timsChatInput').getCaret() if @autocompleteCaret is null
2012-01-28 13:08:51 +00:00
2012-10-20 11:45:05 +00:00
beforeCaret = @autocompleteValue.substring 0, @autocompleteCaret
lastSpace = beforeCaret.lastIndexOf ' '
beforeComplete = @autocompleteValue.substring 0, lastSpace + 1
toComplete = @autocompleteValue.substring lastSpace + 1
nextSpace = toComplete.indexOf ' '
if nextSpace is -1
afterComplete = '';
else
afterComplete = toComplete.substring nextSpace + 1
toComplete = toComplete.substring 0, nextSpace
2012-01-28 13:08:51 +00:00
2012-10-20 11:45:05 +00:00
return if toComplete.length is 0
2013-01-29 20:41:02 +00:00
console.log "Autocompleting '#{toComplete}'"
2012-01-28 13:08:51 +00:00
2012-01-28 14:57:33 +00:00
# Insert name and increment offset
2012-10-20 11:45:05 +00:00
name = @autocomplete toComplete
2013-01-29 20:41:02 +00:00
$('#timsChatInput').val "#{beforeComplete}#{name} #{afterComplete}"
$('#timsChatInput').setCaret (beforeComplete + name).length + 1
2012-01-28 13:08:51 +00:00
@autocompleteOffset++
else
@autocompleteOffset = 0
@autocompleteValue = null
2012-10-20 11:45:05 +00:00
@autocompleteCaret = null
2013-02-07 21:34:05 +00:00
$('#timsChatInput').click =>
2012-10-20 11:45:05 +00:00
@autocompleteOffset = 0
@autocompleteValue = null
@autocompleteCaret = null
2013-02-07 21:34:05 +00:00
2012-01-28 14:57:33 +00:00
# Refreshes the roomlist
2013-01-29 20:41:02 +00:00
$('#timsChatRoomList button').click $.proxy @refreshRoomList, @
2013-01-31 15:03:20 +00:00
# Clears the stream
$('#timsChatClear').click (event) ->
event.preventDefault()
$('.timsChatMessage').remove()
@oldScrollTop = null
$('#timsChatMessageContainer').scrollTop $('#timsChatMessageContainer ul').height()
2012-01-28 14:57:33 +00:00
# Toggle Buttons
2012-02-05 16:21:43 +00:00
$('.timsChatToggle').click (event) ->
element = $ @
icon = element.find 'span.icon'
2011-12-24 16:48:08 +00:00
if element.data('status') is 1
element.data 'status', 0
icon.removeClass('icon-circle-blank').addClass('icon-off')
element.attr 'title', element.data 'enableMessage'
else
element.data 'status', 1
icon.removeClass('icon-off').addClass('icon-circle-blank')
element.attr 'title', element.data 'disableMessage'
2012-06-29 15:05:01 +00:00
$('#timsChatInput').focus()
2012-06-13 16:13:54 +00:00
# Enable fullscreen-mode
$('#timsChatFullscreen').click (event) ->
if $(@).data 'status'
2012-07-14 12:35:58 +00:00
$('html').addClass 'fullscreen'
else
2012-07-14 12:35:58 +00:00
$('html').removeClass 'fullscreen'
2012-06-16 19:03:29 +00:00
2012-01-28 14:57:33 +00:00
# Immediatly scroll down when activating autoscroll
2012-02-05 16:21:43 +00:00
$('#timsChatAutoscroll').click (event) ->
2012-06-16 19:03:29 +00:00
$(@).removeClass 'active'
if $(@).data 'status'
2013-01-09 18:59:32 +00:00
$('#timsChatMessageContainer').scrollTop $('#timsChatMessageContainer ul').height()
2012-02-05 16:21:43 +00:00
@oldScrollTop = $('.timsChatMessageContainer').scrollTop()
2013-01-29 20:41:02 +00:00
2012-01-28 14:57:33 +00:00
# Desktop Notifications
2012-01-28 15:09:24 +00:00
unless typeof window.webkitNotifications is 'undefined'
2012-02-05 16:21:43 +00:00
$('#timsChatNotify').click (event) ->
2012-08-07 21:56:57 +00:00
if $(@).data('status') and window.webkitNotifications.checkPermission() isnt 0
window.webkitNotifications.requestPermission()
2013-01-31 15:03:20 +00:00
2011-12-19 14:52:00 +00:00
###
# Changes the chat-room.
#
# @param jQuery-object target
###
changeRoom: (target) ->
window.history.replaceState {}, '', target.attr('href')
$.ajax target.attr('href'),
dataType: 'json'
data:
ajax: 1
type: 'POST'
2013-02-07 21:34:05 +00:00
success: (data, textStatus, jqXHR) =>
2011-12-24 16:47:07 +00:00
@loading = false
target.parent().removeClass 'loading'
2012-01-28 14:57:33 +00:00
# Mark as active
2012-02-05 16:21:43 +00:00
$('.activeMenuItem .timsChatRoom').parent().removeClass 'activeMenuItem'
target.parent().addClass 'activeMenuItem'
2011-12-26 19:02:23 +00:00
2012-01-28 14:57:33 +00:00
# Set new topic
2013-01-31 15:03:20 +00:00
$('#timsChatTopic').text data.topic
2011-12-24 16:48:08 +00:00
if data.topic is ''
2013-01-31 15:03:20 +00:00
$('#timsChatTopic').addClass 'empty'
else
2013-01-31 15:03:20 +00:00
$('#timsChatTopic').removeClass 'empty'
2012-03-07 22:04:19 +00:00
$('.timsChatMessage').addClass 'unloaded', 800
2012-02-05 16:21:43 +00:00
@handleMessages data.messages
document.title = @titleTemplate.fetch data
2013-02-01 20:29:50 +00:00
# Fix smiley urls ...
$('#smilies .menu li a').each (key, value) ->
anchor = $(value)
anchor.attr 'href', anchor.attr('href').replace /.*#/, "#{target.attr('href')}#"
2013-02-07 21:34:05 +00:00
error: ->
2012-01-28 14:57:33 +00:00
# Reload the page to change the room the old fashion-way
# inclusive the error-message :)
window.location.reload true
2013-02-07 21:34:05 +00:00
beforeSend: =>
return false if target.parent().hasClass('loading') or target.parent().hasClass 'activeMenuItem'
2011-12-24 16:47:07 +00:00
@loading = true
target.parent().addClass 'loading'
2011-12-19 14:52:00 +00:00
###
2011-12-24 16:28:36 +00:00
# Frees the fish
###
2013-02-07 21:34:05 +00:00
freeTheFish: ->
return if $.wcfIsset 'fish'
2012-04-27 13:42:44 +00:00
console.warn 'Freeing the fish'
2013-02-01 19:41:59 +00:00
fish = $ """<div id="fish">#{WCF.String.escapeHTML('><((((\u00B0>')}</div>"""
2011-12-24 16:28:36 +00:00
fish.css
position: 'absolute'
top: '150px'
left: '400px'
color: 'black'
textShadow: '1px 1px white'
zIndex: 9999
fish.appendTo $ 'body'
2013-02-07 21:34:05 +00:00
@pe.fish = new WCF.PeriodicalExecuter () ->
2012-01-28 15:09:24 +00:00
left = Math.random() * 100 - 50
top = Math.random() * 100 - 50
fish = $ '#fish'
2011-12-24 16:28:36 +00:00
left *= -1 unless fish.width() < (fish.position().left + left) < ($(document).width() - fish.width())
top *= -1 unless fish.height() < (fish.position().top + top) < ($(document).height() - fish.height())
2011-12-24 16:28:36 +00:00
fish.text '><((((\u00B0>' if left > 0
fish.text '<\u00B0))))><' if left < 0
2011-12-24 16:28:36 +00:00
fish.animate
2013-02-07 21:34:05 +00:00
top: "+=#{top}"
left: "+=#{left}"
, 1e3
2013-02-07 21:34:05 +00:00
, 1.5e3
2011-12-24 16:28:36 +00:00
###
2011-12-19 14:52:00 +00:00
# Loads new messages.
###
2013-02-07 21:34:05 +00:00
getMessages: ->
2012-10-15 10:08:57 +00:00
$.ajax @config.messageURL,
2011-12-26 16:01:24 +00:00
dataType: 'json'
type: 'POST'
2013-02-07 21:34:05 +00:00
success: (data, textStatus, jqXHR) =>
2012-08-07 21:56:57 +00:00
WCF.DOMNodeInsertedHandler.enable()
@handleMessages(data.messages)
2012-01-12 19:04:28 +00:00
@handleUsers(data.users)
2012-08-07 21:56:57 +00:00
WCF.DOMNodeInsertedHandler.disable()
2013-02-07 21:34:05 +00:00
error: (jqXHR, textStatus, errorThrown) =>
2012-04-27 13:42:44 +00:00
console.error 'Battle Station hit - shields at ' + (--@shields / 3 * 104) + ' percent'
if @shields is 0
@pe.refreshRoomList.stop()
@pe.getMessages.stop()
@freeTheFish()
2012-04-27 13:42:44 +00:00
console.error 'We got destroyed, but could free our friend the fish before he was killed as well. Have a nice life in freedom!'
alert 'herp i cannot load messages'
2013-02-07 21:34:05 +00:00
complete: =>
@loading = false
2013-02-07 21:34:05 +00:00
beforeSend: =>
return false if @loading
@loading = true
2011-12-19 14:52:00 +00:00
###
# Inserts the new messages.
#
# @param array<object> messages
###
handleMessages: (messages) ->
2012-01-28 14:57:33 +00:00
# Disable scrolling automagically when user manually scrolled
unless @oldScrollTop is null
2013-01-09 18:59:32 +00:00
if $('#timsChatMessageContainer').scrollTop() < @oldScrollTop
2012-03-18 19:05:05 +00:00
if $('#timsChatAutoscroll').data('status') is 1
2012-02-05 16:21:43 +00:00
$('#timsChatAutoscroll').click()
2012-05-24 18:36:58 +00:00
$('#timsChatAutoscroll').addClass 'active'
$('#timsChatAutoscroll').parent().fadeOut('slow').fadeIn 'slow'
2012-01-28 14:57:33 +00:00
# Insert the messages
for message in messages
2012-03-07 22:04:19 +00:00
continue if $.wcfIsset 'timsChatMessage' + message.messageID # Prevent problems with race condition
2011-12-27 16:07:12 +00:00
@events.newMessage.fire message
2011-12-24 16:47:07 +00:00
output = @messageTemplate.fetch message
li = $ '<li></li>'
li.attr 'id', 'timsChatMessage'+message.messageID
2012-02-05 16:21:43 +00:00
li.addClass 'timsChatMessage timsChatMessage'+message.type
2011-12-24 16:48:08 +00:00
li.addClass 'ownMessage' if message.sender is WCF.User.userID
li.append output
2013-01-09 18:59:32 +00:00
li.appendTo $ '#timsChatMessageContainer > ul'
2012-01-28 14:57:33 +00:00
# Autoscroll down
2013-01-09 18:59:32 +00:00
$('#timsChatMessageContainer').scrollTop $('#timsChatMessageContainer ul').height() if $('#timsChatAutoscroll').data('status') is 1
@oldScrollTop = $('#timsChatMessageContainer').scrollTop()
2012-01-28 14:57:33 +00:00
###
# Builds the userlist.
#
# @param array<object> users
###
2012-01-12 19:04:28 +00:00
handleUsers: (users) ->
foundUsers = { }
2012-01-12 19:04:28 +00:00
for user in users
2012-02-05 16:21:43 +00:00
id = 'timsChatUser-'+user.userID
2012-03-07 22:04:19 +00:00
element = $ '#'+id
2012-01-28 14:57:33 +00:00
# Move the user to the correct position
2012-01-12 19:04:28 +00:00
if element[0]
2013-02-01 19:41:59 +00:00
console.log "Moving User: '#{user.username}'"
2012-01-12 19:04:28 +00:00
element = element.detach()
2012-03-22 17:45:36 +00:00
if user.awayStatus?
2012-11-20 15:08:48 +00:00
element.addClass 'away'
2012-03-22 17:45:36 +00:00
element.attr 'title', user.awayStatus
else
2013-01-31 15:03:20 +00:00
element.removeClass 'timsChatAway'
2012-03-22 17:45:36 +00:00
element.removeAttr 'title'
element.data 'tooltip', ''
if user.suspended
element.addClass 'suspended'
else
element.removeClass 'suspended'
2012-02-05 16:21:43 +00:00
$('#timsChatUserList').append element
2012-01-28 14:57:33 +00:00
# Insert the user
2012-01-12 19:04:28 +00:00
else
2013-02-01 19:41:59 +00:00
console.log "Inserting User: '#{user.username}'"
2012-01-12 19:04:28 +00:00
li = $ '<li></li>'
li.attr 'id', id
2012-02-05 16:21:43 +00:00
li.addClass 'timsChatUser'
2012-03-22 17:45:36 +00:00
li.addClass 'jsTooltip'
li.addClass 'dropdown'
2012-08-10 16:32:08 +00:00
li.addClass 'you' if user.userID is WCF.User.userID
li.addClass 'suspended' if user.suspended
2012-03-22 17:45:36 +00:00
if user.awayStatus?
li.addClass 'timsChatAway'
li.attr 'title', user.awayStatus
2012-01-28 13:08:51 +00:00
li.data 'username', user.username
2012-08-10 16:32:08 +00:00
2012-10-16 10:09:09 +00:00
a = $ '<a>' + WCF.String.escapeHTML(user.username) + '</a>'
2012-08-07 22:11:55 +00:00
a.addClass 'userLink'
a.addClass 'dropdownToggle'
2012-08-07 22:11:55 +00:00
a.data 'userID', user.userID
a.data 'toggle', id
2012-08-07 22:11:55 +00:00
2012-01-12 19:04:28 +00:00
li.append a
2012-08-10 16:32:08 +00:00
2012-01-12 19:04:28 +00:00
menu = $ '<ul></ul>'
#menu.addClass 'timsChatUserMenu'
menu.addClass 'dropdownMenu'
2013-02-07 21:34:05 +00:00
menu.append $ "<li><a>#{WCF.Language.get('chat.general.query')}</a></li>"
menu.append $ "<li><a>#{ WCF.Language.get('chat.general.kick')}</a></li>"
menu.append $ "<li><a>#{ WCF.Language.get('chat.general.ban')}</a></li>"
2013-01-19 19:36:40 +00:00
# TODO: SID and co
2013-02-07 21:34:05 +00:00
menu.append $ """<li><a href="index.php/User/#{user.userID}-#{encodeURI(user.username)}/">#{WCF.Language.get('chat.general.profile')}</a></li>"""
2012-01-12 19:04:28 +00:00
@events.userMenu.fire user, menu
li.append menu
2012-08-10 16:32:08 +00:00
2012-02-05 16:21:43 +00:00
li.appendTo $ '#timsChatUserList'
2012-01-12 19:04:28 +00:00
foundUsers[id] = true
# Remove users that were not found
2012-02-05 16:21:43 +00:00
$('.timsChatUser').each () ->
if typeof foundUsers[$(@).attr('id')] is 'undefined'
2013-02-01 19:41:59 +00:00
console.log "Removing User: '#{$(@).data('username')}'"
$(@).remove();
2012-01-12 19:04:28 +00:00
2012-07-14 12:35:58 +00:00
$('#toggleUsers .badge').text users.length
2011-12-19 14:52:00 +00:00
###
2012-04-27 13:42:44 +00:00
# Initializes Server-Push
###
initPush: () ->
2012-06-19 14:30:16 +00:00
unless typeof window.io is 'undefined'
console.log 'Initializing nodePush'
2012-04-27 13:42:44 +00:00
@socket = io.connect @config.socketIOPath
2013-02-07 21:34:05 +00:00
@socket.on 'connect', =>
2012-06-19 14:30:16 +00:00
console.log 'Connected to nodePush'
2012-04-27 13:42:44 +00:00
@pe.getMessages.stop()
2013-02-07 21:34:05 +00:00
@socket.on 'disconnect', =>
2012-06-19 14:30:16 +00:00
console.log 'Lost connection to nodePush'
2012-04-27 13:42:44 +00:00
@pe.getMessages = new WCF.PeriodicalExecuter $.proxy(@getMessages, @), @config.reloadTime * 1e3
2013-02-07 21:34:05 +00:00
@socket.on 'newMessage', =>
2012-04-27 13:42:44 +00:00
@getMessages()
###
2011-12-19 14:52:00 +00:00
# Inserts text into our input.
#
# @param string text
# @param object options
###
insertText: (text, options) ->
options = $.extend
append: true
submit: false
, options or {}
2012-02-05 16:21:43 +00:00
text = $('#timsChatInput').val() + text if options.append
2012-07-14 12:35:58 +00:00
$('#timsChatInput').val text
2012-02-05 16:21:43 +00:00
$('#timsChatInput').keyup()
if (options.submit)
2012-02-05 16:21:43 +00:00
$('#timsChatForm').submit()
else
2012-02-05 16:21:43 +00:00
$('#timsChatInput').focus()
2011-12-19 14:52:00 +00:00
###
2012-01-21 17:43:58 +00:00
# Sends a notification about a message.
#
# @param object message
###
notify: (message) ->
2012-03-25 12:56:16 +00:00
return if @isActive or $('#timsChatNotify').data('status') is 0
2012-01-21 17:43:58 +00:00
@newMessageCount++
2012-02-05 16:21:43 +00:00
document.title = '(' + @newMessageCount + ') ' + @titleTemplate.fetch
title: $('#timsChatRoomList .activeMenuItem a').text()
2012-01-21 17:43:58 +00:00
2012-01-28 14:57:33 +00:00
# Desktop Notifications
2012-01-21 17:43:58 +00:00
if typeof window.webkitNotifications isnt 'undefined'
if window.webkitNotifications.checkPermission() is 0
title = WCF.Language.get 'chat.general.notify.title'
2013-01-29 20:33:30 +00:00
icon = "%3D%3D" # empty gif
2012-05-24 18:32:43 +00:00
content = message.username + message.separator + (if message.separator is ' ' then '' else ' ') + message.message
2012-02-05 16:21:43 +00:00
notification = window.webkitNotifications.createNotification icon, title, content
2012-01-21 17:43:58 +00:00
notification.show()
# Hide notification after 10 seconds
setTimeout () ->
2012-01-21 17:43:58 +00:00
notification.cancel()
, 10e3
2012-01-21 17:43:58 +00:00
###
2011-12-19 14:52:00 +00:00
# Refreshes the room-list.
###
refreshRoomList: () ->
2012-04-27 13:42:44 +00:00
console.log 'Refreshing the roomlist'
$('#toggleRooms .ajaxLoad').show()
$.ajax $('#toggleRooms a').data('refreshUrl'),
dataType: 'json'
type: 'POST'
2013-02-07 21:34:05 +00:00
success: (data, textStatus, jqXHR) =>
2012-02-05 16:21:43 +00:00
$('#timsChatRoomList li').remove()
$('#toggleRooms .ajaxLoad').hide()
2012-04-15 11:00:16 +00:00
$('#toggleRooms .badge').text data.length
2012-01-07 15:45:14 +00:00
for room in data
li = $ '<li></li>'
li.addClass 'activeMenuItem' if room.active
2013-02-01 19:41:59 +00:00
$("""<a href="#{room.link}">#{room.title}</a>""").addClass('timsChatRoom').appendTo li
2012-02-05 16:21:43 +00:00
$('#timsChatRoomList ul').append li
2013-02-07 21:34:05 +00:00
$('.timsChatRoom').click (event) =>
2011-12-24 16:48:08 +00:00
return if typeof window.history.replaceState is 'undefined'
event.preventDefault()
2011-12-24 16:47:07 +00:00
@changeRoom $ event.target
2013-02-07 21:34:05 +00:00
2013-01-29 20:41:02 +00:00
console.log "Found #{data.length} rooms"
2011-12-19 14:52:00 +00:00
###
# Handles submitting of messages.
#
# @param jQuery-object target
###
submit: (target) ->
2012-01-28 14:57:33 +00:00
# Break if input contains only whitespace
2012-02-05 16:21:43 +00:00
return false if $('#timsChatInput').val().trim().length is 0
2012-01-28 14:57:33 +00:00
# Finally free the fish
2012-02-05 16:21:43 +00:00
@freeTheFish() if $('#timsChatInput').val().trim().toLowerCase() is '/free the fish'
2011-12-24 16:28:36 +00:00
text = $('#timsChatInput').val()
2012-06-19 14:30:16 +00:00
# call submit event
2012-06-25 18:52:02 +00:00
# TODO: Fix this
# text = @events.submit.fire text
2012-06-19 14:30:16 +00:00
$('#timsChatInput').val('').focus().keyup()
2012-02-05 16:21:43 +00:00
$.ajax $('#timsChatForm').attr('action'),
data:
text: text
2012-03-07 22:04:19 +00:00
smilies: $('#timsChatSmilies').data 'status'
type: 'POST',
beforeSend: (jqXHR) ->
2013-02-07 21:34:05 +00:00
success: =>
2011-12-24 16:47:07 +00:00
@getMessages()
complete: () ->
2011-12-19 14:52:00 +00:00
###
# Toggles between user- and room-list.
#
# @param jQuery-object target
###
toggleSidebarContents: (target) ->
return if target.parents('li').hasClass 'active'
2012-03-11 17:19:11 +00:00
if target.parents('li').attr('id') is 'toggleUsers'
$('#toggleUsers').addClass 'active'
$('#toggleRooms').removeClass 'active'
2012-02-05 16:21:43 +00:00
$('#timsChatRoomList').hide()
$('#timsChatUserList').show()
2012-03-11 17:19:11 +00:00
else if target.parents('li').attr('id') is 'toggleRooms'
$('#toggleRooms').addClass 'active'
$('#toggleUsers').removeClass 'active'
2012-02-05 16:21:43 +00:00
$('#timsChatUserList').hide()
$('#timsChatRoomList').show()
2011-12-19 14:52:00 +00:00
###
# Unloads the chat.
###
unload: () ->
$.ajax @config.unloadURL,
type: 'POST'
async: false
2012-04-27 13:42:44 +00:00
)(jQuery, @, console)