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