//通知 //取得+Streaming接続 function notf(acct_id, tlid, sys) { todo("Notifications Loading..."); var domain = localStorage.getItem("domain_" + acct_id); var at = localStorage.getItem(domain + "_at"); var start = "https://" + domain + "/api/v1/notifications"; fetch(start, { method: 'GET', headers: { 'content-type': 'application/json', 'Authorization': 'Bearer ' + at }, //body: JSON.stringify({}) }).then(function(response) { return response.json(); }).catch(function(error) { todo(error); console.error(error); }).then(function(json) { var templete=""; Object.keys(json).forEach(function(key) { var obj = json[key]; if(obj.type!="follow"){ templete = templete+parse([obj], 'notf', acct_id, tlid, -1); }else{ templete = templete+userparse([obj.account], 'notf', acct_id, tlid, -1); } }); if (sys == "direct") { $("#timeline_" + tlid).html(templete); } else { $("div[data-notf=" + acct_id +"]").html(templete); } jQuery("time.timeago").timeago(); $("#notf-box").addClass("fetched"); todc(); }); var start = "wss://" + domain + "/api/v1/streaming/?stream=user&access_token=" + at; console.log(start); var wsid = websocketNotf.length; websocketNotf[wsid] = new WebSocket(start); console.log(websocketNotf); websocketNotf[wsid].onopen = function(mess) { console.log("Connect Streaming API(Notf):"); console.log(mess); $("i[data-notf=" + acct_id +"]").removeClass("red-text"); } websocketNotf[wsid].onmessage = function(mess) { console.log("Receive Streaming API(Notf):"+acct_id); var obj = JSON.parse(JSON.parse(mess.data).payload); console.log(obj); var type = JSON.parse(mess.data).event; if (type == "notification") { var popup = localStorage.getItem("popup"); if (!popup) { popup = 0; } var templete=""; if(obj.type!="follow"){ templete = templete+parse([obj], 'notf', acct_id, tlid, popup); }else{ templete = templete+userparse([obj], 'notf', acct_id, tlid, popup); } $("div[data-notf=" + acct_id +"]").prepend(templete); jQuery("time.timeago").timeago(); } else if (type == "delete") { $("[toot-id=" + obj + "]").hide(); $("[toot-id=" + obj + "]").remove(); } } websocketNotf[wsid].onerror = function(error) { console.error('WebSocket Error ' + error); }; } //一定のスクロールで発火 function notfmore(tlid) { var multi = localStorage.getItem("column"); var obj = JSON.parse(multi); var acct_id = obj[tlid].domain; if (!type) { var type = obj[tlid].type; }else{ var data; } var sid = $("#timeline_" + tlid + " .cvo").last().attr("toot-id"); console.log(sid); if (localStorage.getItem("morelock") != sid) { localStorage.setItem("morelock", sid); localStorage.setItem("now", type); todo("Notfication TL MoreLoading"); var domain = localStorage.getItem("domain_" + acct_id); var at = localStorage.getItem(domain + "_at"); var start = "https://" + domain + "/api/v1/notifications"+ "max_id=" + sid; fetch(start, { method: 'GET', headers: { 'content-type': 'application/json', 'Authorization': 'Bearer ' + at }, }).then(function(response) { return response.json(); }).catch(function(error) { todo(error); console.error(error); }).then(function(json) { var templete=""; Object.keys(json).forEach(function(key) { var obj = json[key]; if(obj.type!="follow"){ templete = templete+parse([obj], '', acct_id, tlid, -1); }else{ templete = templete+userparse([obj.account], '', acct_id, tlid, -1); } }); $("#timeline_" + tlid).append(templete); additional(acct_id, tlid); jQuery("time.timeago").timeago(); localStorage.removeItem("morelock") todc(); }); } } //通知トグルボタン function notfToggle(acct, tlid) { $("#notf-box_" + tlid).toggleClass("hide"); $("#notf-box_" + tlid).toggleClass("show"); if (!$("#notf-box_" + tlid).hasClass("fetched")) { notf(acct, tlid); } $(".notf-icon_" + acct).removeClass("red-text"); }