// twister_directmsg.js // 2013 Miguel Freitas // // Handle direct messages modal var _groupMsgInviteToGroupQueue = []; function directMsgSubmit(e) { e.stopPropagation(); e.preventDefault(); var replyText = $(this).closest('.post-area-new').find('textarea'); replyText.siblings('#post-preview').hide(); newDirectMsg(replyText.val(), $('.directMessages').attr('data-screen-name')); replyText.val(''); } function newDirectMsg(msg, peerAlias) { if (typeof lastPostId !== 'undefined') { var paramsOrig = [defaultScreenName, lastPostId + 1, peerAlias, msg]; var paramsOpt = paramsOrig; var copySelf = $.Options.dmCopySelf.val === 'enable'; if (copySelf && peerAlias[0] !== '*') paramsOpt = paramsOrig.concat(true) twisterRpc('newdirectmsg', paramsOpt, function(req, ret) { incLastPostId(); if (req.copySelf) incLastPostId(); }, {copySelf: copySelf}, function(req, ret) { // fallback for older twisterd (error: no copy_self parameter) twisterRpc('newdirectmsg', req.paramsOrig, function(req, ret) {incLastPostId();}, null, function(req, ret) { var msg = (ret.message) ? ret.message : ret; alert('Ajax error: ' + msg); }, null ); }, {paramsOrig: paramsOrig} ); } else alert(polyglot.t('Internal error: lastPostId unknown (following yourself may fix!)')); } function modalDMsSummaryDraw(elem, group) { elem.empty(); for (var peerAlias in twister.DMs) if (group ? peerAlias[0] === '*' : peerAlias[0] !== '*') for (var j in twister.DMs[peerAlias].twists.cached) if (twister.DMs[peerAlias].lastId === twister.DMs[peerAlias].twists.cached[j].id) { addToCommonDMsList(elem, peerAlias, twister.DMs[peerAlias].twists.cached[j]); break; } $.MAL.commonDMsListLoaded(); } // dispara o modal de direct messages function openCommonDMsModal() { if (!defaultScreenName) { alert(polyglot.t('You have to log in to use direct messages.')); return; } if ($.isEmptyObject(twister.DMs)) { setTimeout(openCommonDMsModal, 1000); return; } var modal = openModal({ classAdd: 'directMessages', content: twister.tmpl.commonDMsList.clone(true), title: polyglot.t('Direct Messages') }); modalDMsSummaryDraw(modal.content.find('.direct-messages-list')); modal.self.find('.mark-all-as-read') .css('display', 'inline') .attr('title', polyglot.t('Mark all as read')) .on('click', function (event) { resetNewDMsCount(); var elem = $(event.target).closest('.directMessages').find('.direct-messages-list'); elem.find('.messages-qtd').hide(); elem.find('.post.new').removeClass('new'); }) ; } function openDmWithUserModal(peerAlias) { if (!defaultScreenName) { alert(polyglot.t('You have to log in to use direct messages.')); return; } if ($.isEmptyObject(twister.DMs)) { setTimeout(openDmWithUserModal, 1000, peerAlias); return; } var modal = openModal({ classAdd: 'directMessages', content: $('.messages-thread-template').children().clone(true), title: polyglot.t('direct_messages_with', {username: '' + peerAlias + ''}) }); modal.self.attr('data-screen-name', peerAlias); if (peerAlias.length && peerAlias[0] === '*') getGroupChatName(peerAlias, modal.self.find('.modal-header h3 span')); else getFullname(peerAlias, modal.self.find('.modal-header h3 span')); queryStart(modal.content.find('.direct-messages-thread'), peerAlias, 'direct', undefined, 2000, { boardAutoAppend: true, lastId: 0, lengthNew: 0, ready: function (req, peerAlias) { twister.DMs[peerAlias] = twister.res[req]; }, readyReq: peerAlias, drawFinish: function (req) { $.MAL.dmConversationLoaded(twister.res[req].board); } } ); modal.content.on('scroll', {req: peerAlias}, handleDMsModalScroll); $('.dm-form-template').children().clone(true) .addClass('open').appendTo(modal.content).fadeIn('fast') .find('textarea').trigger('focus'); } function openGroupMessagesModal(groupAlias) { if (!defaultScreenName) { alert(polyglot.t('You have to log in to use group messages.')); return; } if ($.isEmptyObject(twister.DMs)) { setTimeout(openGroupMessagesModal, 1000, groupAlias); return; } if (typeof groupAlias === 'undefined') { var modal = openModal({ classAdd: 'directMessages groupMessages', content: twister.tmpl.commonDMsList.clone(true), title: polyglot.t('Group Messages') }); modal.content.prepend($('#group-messages-profile-modal-control-template').children().clone(true)); modalDMsSummaryDraw(modal.content.find('.direct-messages-list'), true); modal.self.find('.mark-all-as-read') .css('display', 'inline') .attr('title', polyglot.t('Mark all as read')) .on('click', function (event) { resetNewDMsCountGroup(); var elem = $(event.target).closest('.groupMessages').find('.direct-messages-list'); elem.find('.messages-qtd').hide(); elem.find('.post.new').removeClass('new'); }) ; } else { var modal = openModal({ classAdd: 'directMessages groupMessages', title: polyglot.t('direct_messages_with', {username: '' + groupAlias + ''}) }); modal.self.attr('data-screen-name', groupAlias); getGroupChatName(groupAlias, modal.self.find('.modal-header h3 span')); groupMsgGetGroupInfo(groupAlias, function(req, ret) { if (ret && ret.members.indexOf(defaultScreenName) !== -1) { req.modal.content.append($('.messages-thread-template').children().clone(true)); queryStart(req.modal.content.find('.direct-messages-thread'), req.groupAlias, 'direct', undefined, 2000, { boardAutoAppend: true, lastId: 0, lengthNew: 0, ready: function (req, peerAlias) { twister.DMs[peerAlias] = twister.res[req]; }, readyReq: req.groupAlias, drawFinish: function (req) { $.MAL.dmConversationLoaded(twister.res[req].board); } } ); modal.content.on('scroll', {req: req.groupAlias}, handleDMsModalScroll); var control = $('#group-messages-messages-modal-control-template').children().clone(true) .appendTo(req.modal.content); control.find('.profile').on('click', {groupAlias: req.groupAlias}, function (event) {window.location.href = $.MAL.userUrl(event.data.groupAlias);} ); $('.dm-form-template').children().clone(true) .addClass('open').appendTo(req.modal.content).fadeIn('fast') .find('textarea').trigger('focus'); } }, {groupAlias: groupAlias, modal: modal} ); } } function openGroupMessagesNewGroupModal() { if (!defaultScreenName) { alert(polyglot.t('You have to log in to use group messages.')); return; } var modal = openModal({ classAdd: 'group-messages-new-group', content: $('#group-messages-new-group-template').children().clone(true), title: polyglot.t('Group Messages — New Group Creation') }); modal.content.find('.description').on('input', {parentSelector: '.module', enterSelector: '.create'}, inputEnterActivator); modal.content.find('.invite') .on('input', {handleRet: groupMsgInviteFormInputHandleUserSearchRet}, userSearchKeypress) .on('focus', {req: groupMsgInviteFormInputSetTextcompleteReq}, setTextcompleteOnEventTarget) .on('focusout', unsetTextcompleteOnEventTarget) ; modal.content.find('.create').on('click', function (event) { var elemEvent = $(event.target); var elemForm = elemEvent.closest('.module'); var peersToInvite = elemForm.find('.invite').val().toLowerCase().match(/@\w+/g); if (peersToInvite) peersToInvite = peersToInvite.join('').slice(1).split('@'); groupMsgCreateGroup(elemForm.find('.description').val(), peersToInvite); closeModal(event); }); } function openGroupMessagesJoinGroupModal() { if (!defaultScreenName) { alert(polyglot.t('You have to log in to use group messages.')); return; } var modal = openModal({ classAdd: 'group-messages-join-group', content: $('#group-messages-join-group-template').children().clone(true), title: polyglot.t('Group Messages — Join Group') }); var elemGroupsList = modal.content.find('.groups-list'); var elemGroupTemplate = $('#groups-list-item-template').children(); groupMsgGetGroupsForPeer(defaultScreenName, function(req, ret) { if (ret) { for (var i = 0; i < groupChatAliases.length; i++) { if (ret.indexOf(groupChatAliases[i]) === -1) { var item = req.elemGroupTemplate.clone(true).appendTo(req.elemGroupsList); item.find('input') .attr('data-screen-name', groupChatAliases[i]) .on('click', function (event) { var elemEvent = $(event.target); elemEvent.closest('.module').find('.join') .prop('disabled', !elemEvent.closest('.groups-list').find('input:checked').length); }) ; item.find('.twister-user-name') .text(groupChatAliases[i]) .attr('href', $.MAL.userUrl(groupChatAliases[i])) ; getGroupChatName(groupChatAliases[i], item.find('.description')); // FIXME } } } }, {elemGroupsList: elemGroupsList, elemGroupTemplate: elemGroupTemplate} ); modal.content.find('.join').on('click', function (event) { var elemEvent = $(event.target); var groups = elemEvent.closest('.module').find('.groups-list input:checked'); for (var i = 0; i < groups.length; i++) groupMsgInviteToGroup(groups[i].getAttribute('data-screen-name'), [defaultScreenName]); closeModal(event); }); modal.content.find('.secret-key-import').on('input', {parentSelector: '.module', enterSelector: '.import-secret-key'}, inputEnterActivator); modal.content.find('.import-secret-key').on('click', function (event) { groupMsgImportKey($(event.target).closest('.module').find('.secret-key-import').val()); closeModal(event); }); } function groupMsgCreateGroup(description, peersToInvite) { if (!peersToInvite) peersToInvite = []; twisterRpc('creategroup', [description], function(peersToInvite, ret) { groupMsgInviteToGroup(ret, peersToInvite.concat([defaultScreenName])); }, peersToInvite, function(req, ret) { alert(polyglot.t('error', {error: 'can\'t create group — ' + ret.message})); } ); } function groupMsgImportKey(key) { if (parseInt(twisterVersion) < 93800) { alertPopup({ //txtTitle: polyglot.t(''), add some title (not 'error', please) or just KISS txtMessage: polyglot.t('group_key_cant_import') + ' —\n' + polyglot.t('daemon_is_obsolete', {versionReq: '0.9.38'}) }); return; } twisterRpc('creategroup', ['whatever', key], function(req, ret) { if (!ret) { alertPopup({ //txtTitle: polyglot.t(''), add some title (not 'error', please) or just KISS txtMessage: polyglot.t('group_key_cant_import') + ' —\n' + polyglot.t('group_key_is_invalid_perhaps') }); return; } groupMsgInviteToGroup(ret, [defaultScreenName], function () { twisterRpc('rescandirectmsgs', [defaultScreenName], function () {}, undefined, function () {}); } ); alertPopup({ //txtTitle: polyglot.t(''), add some title (not 'error', please) or just KISS txtMessage: polyglot.t('group_key_was_imported', {alias: ret}) }); }, undefined, function(req, ret) { alertPopup({ //txtTitle: polyglot.t(''), add some title (not 'error', please) or just KISS txtMessage: polyglot.t('group_key_cant_import') + ' —\n' + ret.message }); } ); } function groupMsgInviteToGroup(groupAlias, peersToInvite, cbFunc, cbReq) { _groupMsgInviteToGroupQueue.push({ groupAlias: groupAlias, peersToInvite: peersToInvite, cbFunc: cbFunc, cbReq: cbReq }); if (_groupMsgInviteToGroupQueue.length === 1) doGroupMsgInviteToGroup(); } function doGroupMsgInviteToGroup() { twisterRpc('newgroupinvite', [defaultScreenName, lastPostId + 1, _groupMsgInviteToGroupQueue[0].groupAlias, _groupMsgInviteToGroupQueue[0].peersToInvite], function(req, ret) { incLastPostId(); _groupMsgInviteToGroupQueue.shift(); if (_groupMsgInviteToGroupQueue.length) setTimeout(doGroupMsgInviteToGroup, 200); if (typeof req.cbFunc === 'function') req.cbFunc(req.cbReq); }, {cbFunc: _groupMsgInviteToGroupQueue[0].cbFunc, cbReq: _groupMsgInviteToGroupQueue[0].cbReq}, function(req, ret) { alert(polyglot.t('error', {error: 'can\'t invite ' + req[1] + ' to ' + req[0] + ' group — ' + ret.message})); _groupMsgInviteToGroupQueue.shift(); if (_groupMsgInviteToGroupQueue.length) setTimeout(doGroupMsgInviteToGroup, 200); }, [_groupMsgInviteToGroupQueue[0].groupAlias, _groupMsgInviteToGroupQueue[0].peersToInvite] ); } function groupMsgSetGroupDescription(groupAlias, description, cbFunc, cbArgs) { twisterRpc('newgroupdescription', [defaultScreenName, lastPostId + 1, groupAlias, description], function (req) { incLastPostId(); req.cbFunc(req.cbArgs); }, {cbFunc: cbFunc, cbArgs: cbArgs}, function(req, ret) {alert(polyglot.t('error', {error: 'can\'t set group description — ' + ret.message}));}, null ); } function groupMsgLeaveGroup(groupAlias, cbFunc, cbArgs) { twisterRpc('leavegroup', [defaultScreenName, groupAlias], cbFunc, cbArgs, function(req, ret) {alert(polyglot.t('error', {error: 'can\'t leave group — ' + ret.message}));}, null ); } function groupMsgGetGroupsForPeer(peer, cbFunc, cbArgs) { twisterRpc('listgroups', [peer], cbFunc, cbArgs, function(req, ret) {alert(polyglot.t('error', {error: 'can\'t list groups — ' + ret.message}));}, null ); } function groupMsgGetGroupInfo(groupAlias, cbFunc, cbArgs) { twisterRpc('getgroupinfo', [groupAlias], cbFunc, cbArgs, function(req, ret) {alert(polyglot.t('error', {error: 'can\'t get group info — ' + ret.message}));}, null ); } function groupMsgInviteFormInputHandleUserSearchRet() { // working with global results because of search function in textcomplete strategy, see groupMsgInviteFormInputSetTextcompleteReq var i = _lastSearchUsersResults.indexOf(defaultScreenName); if (i !== -1) _lastSearchUsersResults.splice(i, 1); } function groupMsgInviteFormInputSetTextcompleteReq() { return [{ match: /\B@(\w*)$/, search: function (term, callback) { callback($.map(_lastSearchUsersResults, function (mention) { return mention.indexOf(term) === 0 ? mention : null; })); }, index: 1, replace: function (mention) {return '@' + mention + ' ';} }] } function initInterfaceDirectMsg() { $('.direct-messages').attr('href', '#directmessages'); $('.userMenu-messages a').attr('href', '#directmessages'); $('.groupmessages').attr('href', '#groupmessages'); $('.userMenu-groupmessages a').attr('href', '#groupmessages'); $('.dm-submit').on('click', directMsgSubmit); $('.direct-messages-with-user').on('click', function () { window.location.hash = '#directmessages?user=' + $(this).closest('[data-screen-name]').attr('data-screen-name'); }); $('.group-messages-control .invite').on('click', function (event) { $(event.target).siblings('.invite-form').toggle(); }); $('.group-messages-control .invite-form textarea') .on('input', {parentSelector: '.invite-form', enterSelector: 'button', handleRet: groupMsgInviteFormInputHandleUserSearchRet}, function (event) { inputEnterActivator(event); userSearchKeypress(event); } ) .on('focus', {req: groupMsgInviteFormInputSetTextcompleteReq}, setTextcompleteOnEventTarget) .on('focusout', unsetTextcompleteOnEventTarget) ; $('.group-messages-control .invite-form button').on('click', function (event) { var elemEvent = $(event.target); var elemInput = elemEvent.siblings('textarea'); var peersToInvite = elemInput.val().toLowerCase().match(/@\w+/g); if (peersToInvite) peersToInvite = peersToInvite.join('').slice(1).split('@'); groupMsgInviteToGroup(elemEvent.closest('[data-screen-name]').attr('data-screen-name'), peersToInvite); elemInput.val(''); elemEvent.closest('.invite-form').toggle(); // TODO reload group members list }); $('.group-messages-control .join').on('click', function () { window.location.hash = '#groupmessages+joingroup'; }); $('.group-messages-control .leave').on('click', function (event) { var elemLeave = $(event.target); var groupAlias = elemLeave.closest('[data-screen-name]').attr('data-screen-name'); event.data = { txtTitle: polyglot.t('сonfirm_group_leaving_header'), txtMessage: polyglot.t('сonfirm_group_leaving_body', {alias: groupAlias}), cbConfirm: function (req) { groupMsgLeaveGroup(req.groupAlias, closeModal, req.elem); }, cbConfirmReq: {groupAlias: groupAlias, elem: elemLeave} }; confirmPopup(event); }); $('.group-messages-control .new').on('click', function () { window.location.hash = '#groupmessages+newgroup'; }); $('.group-messages-control .secret-key').on('click', promptCopyAttrData); $('.group-messages-control .show-secret-key').on('click', function (event) { var elemEvent = $(event.target); var elemSecretKey = elemEvent.siblings('.secret-key') .toggle(); if (elemSecretKey.css('display') !== 'none') { dumpPrivkey(elemEvent.closest('[data-screen-name]').attr('data-screen-name'), function(req, ret) {req.text(ret).attr('data', ret);}, elemSecretKey ); } else elemSecretKey.text('').attr('data', ''); }); }