2011-12-19 14:46:40 +00:00
|
|
|
###
|
2011-12-19 14:52:00 +00:00
|
|
|
# TimWolla.WCF.Chat
|
|
|
|
#
|
|
|
|
# @author Tim Düsterhus
|
|
|
|
# @copyright 2010-2011 Tim Düsterhus
|
|
|
|
# @license Creative Commons Attribution-NonCommercial-ShareAlike <http://creativecommons.org/licenses/by-nc-sa/3.0/legalcode>
|
|
|
|
# @package timwolla.wcf.chat
|
2011-12-19 14:46:40 +00:00
|
|
|
###
|
|
|
|
|
2011-12-19 14:44:27 +00:00
|
|
|
TimWolla ?= {}
|
|
|
|
TimWolla.WCF ?= {}
|
|
|
|
|
|
|
|
(($) ->
|
|
|
|
TimWolla.WCF.Chat =
|
|
|
|
titleTemplate: null
|
|
|
|
messageTemplate: null
|
|
|
|
init: (roomID, messageID) ->
|
2011-12-24 16:47:07 +00:00
|
|
|
@bindEvents()
|
|
|
|
@refreshRoomList()
|
|
|
|
new WCF.PeriodicalExecuter $.proxy(@refreshRoomList, this), 10e3
|
2011-12-19 14:44:27 +00:00
|
|
|
|
|
|
|
$('#chatInput').focus()
|
2011-12-19 14:52:00 +00:00
|
|
|
###
|
|
|
|
# Binds all the events needed for Tims Chat.
|
|
|
|
###
|
2011-12-19 14:44:27 +00:00
|
|
|
bindEvents: () ->
|
|
|
|
$('.smiley').click $.proxy (event) ->
|
2011-12-24 16:47:07 +00:00
|
|
|
@insertText ' ' + $(event.target).attr('alt') + ' '
|
2011-12-19 14:44:27 +00:00
|
|
|
, this
|
|
|
|
|
|
|
|
$('.chatSidebarTabs li').click $.proxy (event) ->
|
|
|
|
event.preventDefault()
|
2011-12-24 16:47:07 +00:00
|
|
|
@toggleSidebarContents $ event.target
|
2011-12-19 14:44:27 +00:00
|
|
|
, this
|
|
|
|
|
|
|
|
$('.chatUser .chatUserLink').click $.proxy (event) ->
|
|
|
|
event.preventDefault()
|
2011-12-24 16:47:07 +00:00
|
|
|
@toggleUserMenu $ event.target
|
2011-12-19 14:44:27 +00:00
|
|
|
, this
|
|
|
|
|
|
|
|
$('#chatForm').submit $.proxy (event) ->
|
|
|
|
event.preventDefault()
|
2011-12-24 16:47:07 +00:00
|
|
|
@submit $ event.target
|
2011-12-19 14:44:27 +00:00
|
|
|
, this
|
|
|
|
|
|
|
|
$('#chatClear').click (event) ->
|
|
|
|
event.preventDefault()
|
|
|
|
$('.chatMessage').remove()
|
|
|
|
$('#chatInput').focus()
|
|
|
|
|
|
|
|
$('.chatToggle').click (event) ->
|
|
|
|
element = $ this
|
|
|
|
icon = element.find 'img'
|
2011-12-24 16:48:08 +00:00
|
|
|
if element.data('status') is 1
|
2011-12-19 14:44:27 +00:00
|
|
|
element.data 'status', 0
|
|
|
|
icon.attr 'src', icon.attr('src').replace /enabled(\d?).([a-z]{3})$/, 'disabled$1.$2'
|
|
|
|
element.attr 'title', element.data 'enableMessage'
|
|
|
|
else
|
|
|
|
element.data 'status', 1
|
|
|
|
icon.attr 'src', icon.attr('src').replace /disabled(\d?).([a-z]{3})$/, 'enabled$1.$2'
|
|
|
|
element.attr 'title', element.data 'disableMessage'
|
2011-12-19 14:52:00 +00:00
|
|
|
###
|
|
|
|
# Changes the chat-room.
|
|
|
|
#
|
|
|
|
# @param jQuery-object target
|
|
|
|
###
|
2011-12-19 14:44:27 +00: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 16:47:07 +00:00
|
|
|
@loading = false
|
2011-12-19 14:44:27 +00:00
|
|
|
target.parent().removeClass 'ajaxLoad'
|
|
|
|
|
|
|
|
# mark as active
|
|
|
|
$('.activeMenuItem .chatRoom').parent().removeClass 'activeMenuItem'
|
|
|
|
target.parent().addClass 'activeMenuItem'
|
|
|
|
|
|
|
|
# set new topic
|
2011-12-24 16:48:08 +00:00
|
|
|
if data.topic is ''
|
|
|
|
return if $('#topic').text().trim() is ''
|
2011-12-19 14:44:27 +00:00
|
|
|
|
|
|
|
$('#topic').wcfBlindOut 'vertical', () ->
|
|
|
|
$(this).text ''
|
|
|
|
else
|
|
|
|
$('#topic').text data.topic
|
2011-12-24 16:48:08 +00:00
|
|
|
$('#topic').wcfBlindIn() if $('#topic').text().trim() isnt ''
|
2011-12-19 14:44:27 +00:00
|
|
|
|
2011-12-24 16:47:07 +00:00
|
|
|
$('title').text @titleTemplate.fetch(data)
|
2011-12-19 14:44:27 +00:00
|
|
|
, this)
|
|
|
|
error: () ->
|
|
|
|
# reload page to change the room the old fashion-way
|
|
|
|
# inclusive the error-message :)
|
|
|
|
window.location.reload true
|
|
|
|
beforeSend: $.proxy(() ->
|
2011-12-24 16:47:07 +00:00
|
|
|
return false if @loading or target.parent().hasClass 'activeMenuItem'
|
2011-12-19 14:44:27 +00:00
|
|
|
|
2011-12-24 16:47:07 +00:00
|
|
|
@loading = true
|
2011-12-19 14:44:27 +00:00
|
|
|
target.parent().addClass 'ajaxLoad'
|
|
|
|
, this)
|
2011-12-19 14:52:00 +00:00
|
|
|
###
|
2011-12-24 16:28:36 +00:00
|
|
|
# Frees the fish
|
|
|
|
###
|
|
|
|
freeTheFish: () ->
|
|
|
|
return if $.wcfIsset('fish')
|
|
|
|
fish = $ '<div id="fish">' + WCF.String.escapeHTML('><((((°>') + '</div>'
|
|
|
|
fish.css
|
|
|
|
position: 'absolute'
|
|
|
|
top: '150px'
|
|
|
|
left: '400px'
|
|
|
|
color: 'black'
|
|
|
|
textShadow: '1px 1px white'
|
|
|
|
zIndex: 9999
|
|
|
|
|
|
|
|
fish.appendTo $ 'body'
|
|
|
|
new WCF.PeriodicalExecuter(() ->
|
|
|
|
left = (Math.random() * 100 - 50)
|
|
|
|
|
|
|
|
$('#fish').text('><((((°>') if (left > 0)
|
|
|
|
$('#fish').text('<°))))><') if (left < 0)
|
|
|
|
|
|
|
|
$('#fish').animate
|
|
|
|
top: '+=' + (Math.random() * 100 - 50)
|
|
|
|
left: '+=' + left
|
|
|
|
, 1000
|
|
|
|
, 3e3);
|
|
|
|
###
|
2011-12-19 14:52:00 +00:00
|
|
|
# Loads new messages.
|
|
|
|
###
|
2011-12-19 14:44:27 +00:00
|
|
|
getMessages: () ->
|
2011-12-19 14:52:00 +00:00
|
|
|
###
|
|
|
|
# Inserts the new messages.
|
|
|
|
#
|
|
|
|
# @param array<object> messages
|
|
|
|
###
|
2011-12-19 14:44:27 +00:00
|
|
|
handleMessages: (messages) ->
|
|
|
|
for message in messages
|
2011-12-24 16:47:07 +00:00
|
|
|
output = @messageTemplate.fetch message
|
2011-12-19 14:44:27 +00:00
|
|
|
li = $ '<li></li>'
|
|
|
|
li.addClass 'chatMessage chatMessage'+message.type
|
2011-12-24 16:48:08 +00:00
|
|
|
li.addClass 'ownMessage' if message.sender is WCF.User.userID
|
2011-12-19 14:44:27 +00:00
|
|
|
li.append output
|
|
|
|
|
|
|
|
li.appendTo $ '.chatMessageContainer ul'
|
|
|
|
$('.chatMessageContainer').animate
|
|
|
|
scrollTop: $('.chatMessageContainer ul').height()
|
|
|
|
, 1000
|
2011-12-19 14:52:00 +00:00
|
|
|
###
|
|
|
|
# Inserts text into our input.
|
|
|
|
#
|
|
|
|
# @param string text
|
|
|
|
# @param object options
|
|
|
|
###
|
2011-12-19 14:44:27 +00:00
|
|
|
insertText: (text, options) ->
|
|
|
|
options = $.extend
|
|
|
|
append: true
|
|
|
|
submit: false
|
|
|
|
, options or {}
|
|
|
|
|
|
|
|
text = $('#chatInput').val() + text if options.append
|
|
|
|
$('#chatInput').val(text)
|
|
|
|
$('#chatInput').keyup()
|
|
|
|
|
|
|
|
if (options.submit)
|
|
|
|
$('#chatForm').submit()
|
|
|
|
else
|
|
|
|
$('#chatInput').focus()
|
2011-12-19 14:52:00 +00:00
|
|
|
###
|
|
|
|
# Refreshes the room-list.
|
|
|
|
###
|
2011-12-19 14:44:27 +00:00
|
|
|
refreshRoomList: () ->
|
|
|
|
$('.chatRoom').unbind 'click'
|
|
|
|
$('#toggleRooms a').addClass 'ajaxLoad'
|
|
|
|
|
|
|
|
$.ajax $('#toggleRooms a').data('refreshUrl'),
|
|
|
|
dataType: 'json'
|
|
|
|
type: 'POST'
|
|
|
|
success: $.proxy((data, textStatus, jqXHR) ->
|
|
|
|
$('#chatRoomList li').remove()
|
|
|
|
$('#toggleRooms a').removeClass 'ajaxLoad'
|
|
|
|
for room in data
|
|
|
|
li = $ '<li></li>'
|
|
|
|
li.addClass 'activeMenuItem' if room.active
|
|
|
|
$('<a href="' + room.link + '">' + room.title + '</a>').addClass('chatRoom').appendTo li
|
|
|
|
$('#chatRoomList ul').append li
|
|
|
|
$('.chatRoom').click $.proxy (event) ->
|
2011-12-24 16:48:08 +00:00
|
|
|
return if typeof window.history.replaceState is 'undefined'
|
2011-12-19 14:44:27 +00:00
|
|
|
event.preventDefault()
|
2011-12-24 16:47:07 +00:00
|
|
|
@changeRoom $ event.target
|
2011-12-19 14:44:27 +00:00
|
|
|
, this
|
|
|
|
, this)
|
2011-12-19 14:52:00 +00:00
|
|
|
###
|
|
|
|
# Handles submitting of messages.
|
|
|
|
#
|
|
|
|
# @param jQuery-object target
|
|
|
|
###
|
2011-12-19 14:44:27 +00:00
|
|
|
submit: (target) ->
|
|
|
|
# break if input contains only whitespace
|
2011-12-24 16:48:08 +00:00
|
|
|
return false if $('#chatInput').val().trim().length is 0
|
2011-12-19 14:44:27 +00:00
|
|
|
|
2011-12-24 16:48:08 +00:00
|
|
|
@freeTheFish() if $('#chatInput').val().trim() is '/free the fish'
|
2011-12-24 16:28:36 +00:00
|
|
|
|
2011-12-19 14:44:27 +00:00
|
|
|
$.ajax $('#chatForm').attr('action'),
|
|
|
|
data:
|
2011-12-20 20:20:32 +00:00
|
|
|
text: $('#chatInput').val(),
|
|
|
|
smilies: $('#chatSmilies').data('status')
|
2011-12-19 14:44:27 +00:00
|
|
|
type: 'POST',
|
|
|
|
beforeSend: (jqXHR) ->
|
|
|
|
$('#chatInput').addClass 'ajaxLoad'
|
|
|
|
success: $.proxy((data, textStatus, jqXHR) ->
|
2011-12-24 16:47:07 +00:00
|
|
|
@getMessages()
|
2011-12-19 14:44:27 +00:00
|
|
|
$('#chatInput').val('').focus()
|
|
|
|
$('#chatInput').keyup()
|
|
|
|
, this)
|
|
|
|
complete: () ->
|
|
|
|
$('#chatInput').removeClass 'ajaxLoad'
|
2011-12-19 14:52:00 +00:00
|
|
|
###
|
|
|
|
# Toggles between user- and room-list.
|
|
|
|
#
|
|
|
|
# @param jQuery-object target
|
|
|
|
###
|
2011-12-19 14:44:27 +00:00
|
|
|
toggleSidebarContents: (target) ->
|
|
|
|
return if target.parent().hasClass 'active'
|
|
|
|
|
2011-12-24 16:48:08 +00:00
|
|
|
if target.parent().attr('id') is 'toggleUsers'
|
2011-12-19 14:44:27 +00:00
|
|
|
$('#toggleUsers').addClass 'active'
|
|
|
|
$('#toggleRooms').removeClass 'active'
|
|
|
|
|
|
|
|
$('#chatRoomList').hide()
|
|
|
|
$('#chatUserList').show()
|
2011-12-24 16:48:08 +00:00
|
|
|
else if target.parent().attr('id') is 'toggleRooms'
|
2011-12-19 14:44:27 +00:00
|
|
|
$('#toggleRooms').addClass 'active'
|
|
|
|
$('#toggleUsers').removeClass 'active'
|
|
|
|
|
|
|
|
$('#chatUserList').hide()
|
|
|
|
$('#chatRoomList').show()
|
2011-12-19 14:52:00 +00:00
|
|
|
###
|
|
|
|
# Toggles the user-menu.
|
|
|
|
#
|
|
|
|
# @param jQuery-object target
|
|
|
|
###
|
2011-12-19 14:44:27 +00:00
|
|
|
toggleUserMenu: (target) ->
|
|
|
|
liUserID = '#' + target.parent().parent().attr 'id'
|
|
|
|
|
|
|
|
if $(liUserID).hasClass 'activeMenuItem'
|
|
|
|
$(liUserID + ' .chatUserMenu').wcfBlindOut 'vertical', () ->
|
|
|
|
$(liUserID).removeClass 'activeMenuItem'
|
|
|
|
else
|
|
|
|
$(liUserID).addClass 'activeMenuItem'
|
|
|
|
$(liUserID + ' .chatUserMenu').wcfBlindIn()
|
2011-12-19 14:46:40 +00:00
|
|
|
)(jQuery)
|