| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341 |
- var
- /**
- * @type {number} next period to wait before next retry in case of failure, in seconds
- **/
- NEXT_RETRY = 0
- /**
- * @type {Room|null}
- **/
- ,SELECTED_ROOM = null
- /**
- * @type {SimpleChatSystem|null}
- **/
- ,SELECTED_CONTEXT = null
- /** @type {Message|null} */
- ,REPLYING_TO = null
- /** @type {Message|null} */
- ,EDITING = null
- ;
- function initHljs() {
- var xhr = new XMLHttpRequest();
- xhr.timeout = 1000 * 60 * 1; // 3 min timeout
- xhr.onreadystatechange = function(e) {
- if (xhr.readyState === 4) {
- var script = document.createElement("script");
- script.innerHTML = xhr.response;
- script.language = "text/javascript";
- document.head.innerHTML += '<link href="hljs-androidstudio.css" rel="stylesheet"/>';
- document.body.appendChild(script);
- }
- };
- xhr.open('GET', 'highlight.pack.js', true);
- xhr.send(null);
- }
- /**
- * @param {Room} room
- * @param {function(boolean)} cb
- **/
- function fetchHistory(room, cb) {
- var xhr = new XMLHttpRequest();
- xhr.open('GET', 'api/hist?room=' +room.id, true);
- xhr.send(null);
- }
- function poll(callback) {
- var xhr = new XMLHttpRequest();
- xhr.timeout = 1000 * 60 * 1; // 3 min timeout
- xhr.onreadystatechange = function(e) {
- if (xhr.readyState === 4) {
- if (xhr.status === 0) {
- if (NEXT_RETRY) {
- NEXT_RETRY = 0;
- onNetworkStateUpdated(true);
- }
- poll(callback); // retry on timeout
- return;
- }
- var resp = null
- ,success = Math.floor(xhr.status / 100) === 2;
- if (success) {
- if (NEXT_RETRY) {
- NEXT_RETRY = 0;
- onNetworkStateUpdated(true);
- }
- resp = xhr.response;
- try {
- resp = JSON.parse(/** @type {string} */ (resp));
- } catch (e) {
- resp = null;
- }
- } else {
- if (NEXT_RETRY) {
- NEXT_RETRY += Math.floor((NEXT_RETRY || 5)/2);
- NEXT_RETRY = Math.min(60, NEXT_RETRY);
- } else {
- NEXT_RETRY = 5;
- onNetworkStateUpdated(false);
- }
- }
- callback(success, resp);
- }
- };
- xhr.open('GET', 'api?v=' +DATA.lastServerVersion, true);
- xhr.send(null);
- }
- function outOfSync() {
- DATA.lastServerVersion = 0;
- }
- /**
- * @param {Room} room
- **/
- function sendTyping(room) {
- var xhr = new XMLHttpRequest()
- ,url = 'api/typing?room=' +room.id;
- xhr.open('POST', url, true);
- xhr.send(null);
- }
- /**
- * @param {boolean} success
- * @param {*} response
- **/
- function onPollResponse(success, response) {
- if (success) {
- if (response) {
- DATA.update(response);
- }
- startPolling();
- } else {
- setTimeout(startPolling, NEXT_RETRY * 1000);
- }
- }
- function startPolling() {
- poll(onPollResponse);
- }
- /**
- * @param {Room} room
- **/
- function selectRoom(room) {
- if (SELECTED_ROOM)
- unselectRoom();
- document.getElementById("room_" +room.id).classList.add(R.klass.selected);
- document.body.classList.remove(R.klass.noRoomSelected);
- SELECTED_ROOM = room;
- SELECTED_CONTEXT = /** @type {SimpleChatSystem} */ (DATA.context.getChannelContext(room.id));
- onRoomSelected();
- createContextBackground(SELECTED_CONTEXT.getChatContext().team.id, SELECTED_CONTEXT.getChatContext().users, function(imgData) {
- document.getElementById(R.id.context).style.backgroundImage = 'url(' +imgData +')';
- });
- if (SELECTED_ROOM.lastMsg !== 0 && !DATA.history[SELECTED_ROOM.id])
- fetchHistory(SELECTED_ROOM, function(success) {});
- }
- function unselectRoom() {
- document.getElementById("room_" +SELECTED_ROOM.id).classList.remove(R.klass.selected);
- }
- /**
- * @param {Room} chan
- * @param {string} filename
- * @param {File} file
- * @param {function(string?)} callback
- **/
- function uploadFile(chan, filename, file, callback) {
- var fileReader = new FileReader()
- ,formData = new FormData()
- ,xhr = new XMLHttpRequest();
- formData.append("file", file);
- formData.append("filename", filename);
- xhr.onreadystatechange = function() {
- if (xhr.readyState === 4) {
- if (xhr.status === 204) {
- callback(null);
- } else {
- callback(xhr.statusText);
- }
- }
- }
- xhr.open('POST', 'api/file?room=' +chan.id);
- xhr.send(formData);
- }
- /**
- * @param {string} payload
- * @param {string} serviceId
- * @param {(function((string|null)))=} callback
- **/
- function sendCommand(payload, serviceId, callback) {
- var formData = new FormData()
- ,xhr = new XMLHttpRequest();
- formData.append("payload", payload);
- formData.append("service_id", serviceId);
- if (callback) {
- xhr.onreadystatechange = function() {
- if (xhr.readyState === 4) {
- if (xhr.status === 204) {
- callback(null);
- } else {
- callback(xhr.statusText);
- }
- }
- }
- }
- xhr.open('POST', "api/attachmentAction");
- xhr.send(formData);
- }
- function getActionPayload(channelId, msg, attachment, action) {
- var payload = {
- "actions": [ action ]
- ,"attachment_id": attachment["id"]
- ,"callback_id": attachment["callback_id"]
- ,"channel_id": channelId
- ,"is_ephemeral": msg instanceof NoticeMessage
- ,"message_ts": msg["id"]
- };
- return JSON.stringify(payload);
- }
- /**
- * @param {Room} chan
- * @param {Command!} cmd
- * @param {string} args
- **/
- function doCommand(chan, cmd, args) {
- var xhr = new XMLHttpRequest()
- ,url = 'api/cmd?room=' +chan.id +"&cmd=" +encodeURIComponent(cmd.name.substr(1)) +"&args=" +encodeURIComponent(args);
- xhr.open('POST', url, true);
- xhr.send(null);
- }
- /**
- * @param {Room} chan
- * @param {string} msg
- * @param {Message|null=} replyTo
- **/
- function sendMsg(chan, msg, replyTo) {
- var xhr = new XMLHttpRequest();
- var url = 'api/msg?room=' +chan.id +"&text=" +encodeURIComponent(msg);
- if (replyTo) {
- var sender = DATA.context.getUser(replyTo.userId)
- ,footer = "Message";
- if (chan.isPrivate) {
- footer = "Private message";
- } else {
- footer = chan.name;
- }
- var attachment = {
- "fallback": replyTo.text
- ,"author_name": "<@" +sender.id +"|" +sender.name +">"
- ,"text": replyTo.text
- ,"footer": footer
- ,"ts": replyTo.ts
- };
- url += "&attachments=" +encodeURIComponent(JSON.stringify([attachment]));
- }
- xhr.open('POST', url, true);
- xhr.send(null);
- }
- /**
- * @param {string} input
- * @param {boolean=} skipCommand
- * @return {boolean} true on recognized input
- **/
- function onTextEntered(input, skipCommand) {
- var success = true;
- if (EDITING) {
- editMsg(SELECTED_ROOM, input, EDITING);
- return true;
- }
- if (input[0] === '/' && skipCommand !== true) {
- var endCmd = input.indexOf(' ')
- ,cmd = input.substr(0, endCmd === -1 ? undefined : endCmd)
- ,args = endCmd === -1 ? "" : input.substr(endCmd)
- ,ctx = SELECTED_CONTEXT
- ,cmdObject = ctx ? ctx.getChatContext().commands.data[cmd] : null;
- if (cmdObject) {
- doCommand(SELECTED_ROOM, cmdObject, args.trim());
- return true;
- }
- return false;
- }
- sendMsg(SELECTED_ROOM, input, REPLYING_TO);
- return true;
- }
- /**
- * @param {Room} chan
- * @param {string} text
- * @param {Message|null=} msg
- **/
- function editMsg(chan, text, msg) {
- var xhr = new XMLHttpRequest();
- var url = 'api/msg?room=' +chan.id +"&ts=" +msg.id +"&text=" +encodeURIComponent(text);
- xhr.open('PUT', url, true);
- xhr.send(null);
- }
- /**
- * @param {Room} chan
- * @param {Message|null=} msg
- **/
- function removeMsg(chan, msg) {
- var xhr = new XMLHttpRequest();
- var url = 'api/msg?room=' +chan.id +"&ts=" +msg.id;
- xhr.open('DELETE', url, true);
- xhr.send(null);
- }
- /**
- * @param {Room} chan
- * @param {number} ts
- **/
- function sendReadMArker(chan, ts) {
- var xhr = new XMLHttpRequest();
- var url = 'api/markread?room=' +chan.id +"&ts=" +ts;
- xhr.open('POST', url, true);
- xhr.send(null);
- }
- /**
- * @param {string} channelId
- * @param {string} msgId
- * @param {string} reaction
- **/
- function addReaction(channelId, msgId, reaction) {
- var xhr = new XMLHttpRequest();
- var url = 'api/reaction?room=' +channelId +"&msg=" +msgId +"&reaction=" +encodeURIComponent(reaction);
- xhr.open('POST', url, true);
- xhr.send(null);
- }
- /**
- * @param {string} channelId
- * @param {string} msgId
- * @param {string} reaction
- **/
- function removeReaction(channelId, msgId, reaction) {
- var xhr = new XMLHttpRequest();
- var url = 'api/reaction?room=' +channelId +"&msg=" +msgId +"&reaction=" +encodeURIComponent(reaction);
- xhr.open('DELETE', url, true);
- xhr.send(null);
- }
|