thedesk/app/js/tl/datails.js

355 lines
11 KiB
JavaScript
Raw Normal View History

2018-01-28 23:22:43 +11:00
//トゥートの詳細
2018-03-11 01:22:59 +11:00
function details(id, acct_id, tlid) {
2018-02-18 03:44:03 +11:00
$(".toot-reset").html("データなし");
2018-03-11 01:22:59 +11:00
var html = $("#timeline_"+tlid+" #pub_" + id).html();
2018-01-28 23:22:43 +11:00
$("#toot-this").html(html);
$('#tootmodal').modal('open');
var domain = localStorage.getItem("domain_" + acct_id);
2018-07-07 03:51:48 +10:00
var at = localStorage.getItem("acct_"+ acct_id + "_at");
2018-01-28 23:22:43 +11:00
var start = "https://" + domain + "/api/v1/statuses/" + id;
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) {
2018-03-21 16:36:02 +11:00
if(!$("#timeline_"+tlid+" #pub_" + id).length){
2018-04-10 02:22:08 +10:00
var html = parse([json], '', acct_id);
2018-03-21 16:36:02 +11:00
$("#toot-this").html(html);
jQuery("time.timeago").timeago();
}
2018-01-28 23:22:43 +11:00
$("#toot-this .fav_ct").text(json.favourites_count);
$("#toot-this .rt_ct").text(json.reblogs_count);
2018-02-18 03:44:03 +11:00
$("#tootmodal").attr("data-url",json.url);
2018-03-11 01:22:59 +11:00
$("#tootmodal").attr("data-id",json.id);
2018-03-21 16:36:02 +11:00
if(json.account.acct==json.account.username){
$("#tootmodal").attr("data-user",json.account.acct+"@"+domain);
}else{
$("#tootmodal").attr("data-user",json.account.acct);
}
2018-01-28 23:22:43 +11:00
if (json.in_reply_to_id) {
replyTL(json.in_reply_to_id, acct_id);
}
context(id, acct_id);
2018-05-20 16:17:10 +10:00
if(json.account.acct!=json.account.username){
var dom=json.account.acct.replace(/.+@/g,'');
}else{
var dom=domain;
}
beforeToot(id, acct_id, dom);
2018-05-02 14:14:03 +10:00
userToot(id, acct_id, json.account.id);
2018-01-28 23:22:43 +11:00
faved(id, acct_id);
rted(id, acct_id);
2018-02-26 00:37:04 +11:00
if(!$("#activator").hasClass("active")){
2018-05-02 14:14:03 +10:00
$('#det-col').collapsible('open', 1);
2018-02-26 00:37:04 +11:00
}
2018-01-28 23:22:43 +11:00
});
}
//返信タイムライン
function replyTL(id, acct_id) {
var domain = localStorage.getItem("domain_" + acct_id);
2018-07-07 03:51:48 +10:00
var at = localStorage.getItem("acct_"+ acct_id + "_at");
2018-01-28 23:22:43 +11:00
var start = "https://" + domain + "/api/v1/statuses/" + id;
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) {
2018-07-17 01:39:06 +10:00
if(localStorage.getItem("filter_"+ acct_id)!="undefined"){
var mute=getFilterType(JSON.parse(localStorage.getItem("filter_"+ acct_id)),"thread");
}else{
var mute=[];
}
console.log(mute);
var templete = parse([json], '', acct_id,"","",mute);
2018-01-28 23:22:43 +11:00
$("#toot-reply").prepend(templete);
2018-07-17 01:39:06 +10:00
$("#toot-reply .hide").html("フィルターされました。");
$("#toot-reply .by_filter").css("display","block");
$("#toot-reply .by_filter").removeClass("hide");
2018-01-28 23:22:43 +11:00
jQuery("time.timeago").timeago();
if (json.in_reply_to_id) {
replyTL(json.in_reply_to_id, acct_id);
}
});
}
//コンテクストってなんですか
function context(id, acct_id) {
var domain = localStorage.getItem("domain_" + acct_id);
2018-07-07 03:51:48 +10:00
var at = localStorage.getItem("acct_"+ acct_id + "_at");
2018-01-28 23:22:43 +11:00
var start = "https://" + domain + "/api/v1/statuses/" + id + "/context";
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) {
2018-07-17 01:39:06 +10:00
if(localStorage.getItem("filter_"+ acct_id)!="undefined"){
var mute=getFilterType(JSON.parse(localStorage.getItem("filter_"+ acct_id)),"thread");
}else{
var mute=[];
}
var templete = parse(json.descendants, '', acct_id,"","",mute);
2018-01-28 23:22:43 +11:00
$("#toot-after").html(templete);
2018-07-17 01:39:06 +10:00
$("#toot-after .hide").html("フィルターされました。");
$("#toot-after .by_filter").css("display","block");
$("#toot-after .by_filter").removeClass("hide");
2018-01-28 23:22:43 +11:00
jQuery("time.timeago").timeago();
});
}
//前のトゥート(Back TL)
2018-05-20 16:17:10 +10:00
function beforeToot(id, acct_id, domain) {
//var domain = localStorage.getItem("domain_" + acct_id);
2018-07-07 03:51:48 +10:00
var at = localStorage.getItem("acct_"+ acct_id + "_at");
2018-01-28 23:22:43 +11:00
var start = "https://" + domain +
"/api/v1/timelines/public?local=true&max_id=" + id;
fetch(start, {
method: 'GET',
headers: {
'content-type': 'application/json',
},
}).then(function(response) {
return response.json();
}).catch(function(error) {
todo(error);
console.error(error);
}).then(function(json) {
2018-05-20 16:17:10 +10:00
var templete = parse(json, 'noauth', acct_id);
2018-01-28 23:22:43 +11:00
$("#toot-before").html(templete);
jQuery("time.timeago").timeago();
});
}
2018-05-02 14:14:03 +10:00
//前のユーザーのトゥート
function userToot(id, acct_id, user) {
var domain = localStorage.getItem("domain_" + acct_id);
2018-07-07 03:51:48 +10:00
var at = localStorage.getItem("acct_"+ acct_id + "_at");
2018-05-02 14:14:03 +10:00
var start = "https://" + domain + "/api/v1/accounts/" + user + "/statuses?max_id=" + id;
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 = parse(json, '', acct_id);
$("#user-before").html(templete);
jQuery("time.timeago").timeago();
});
}
2018-01-28 23:22:43 +11:00
//ふぁぼ一覧
function faved(id, acct_id) {
var domain = localStorage.getItem("domain_" + acct_id);
2018-07-07 03:51:48 +10:00
var at = localStorage.getItem("acct_"+ acct_id + "_at");
2018-01-28 23:22:43 +11:00
var start = "https://" + domain + "/api/v1/statuses/" + id + "/favourited_by";
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) {
2018-04-10 02:22:08 +10:00
var templete = userparse(json, '', acct_id);
2018-01-28 23:22:43 +11:00
$("#toot-fav").html(templete);
});
}
//ブースト一覧
function rted(id, acct_id) {
var domain = localStorage.getItem("domain_" + acct_id);
2018-07-07 03:51:48 +10:00
var at = localStorage.getItem("acct_"+ acct_id + "_at");
2018-01-28 23:22:43 +11:00
var start = "https://" + domain + "/api/v1/statuses/" + id + "/reblogged_by";
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) {
2018-04-10 02:22:08 +10:00
var templete = userparse(json, '', acct_id);
2018-01-28 23:22:43 +11:00
$("#toot-rt").html(templete);
});
}
2018-02-18 03:44:03 +11:00
//URL等のコピー
function cbCopy(mode){
var url=$("#tootmodal").attr("data-url");
var urls = url.match(/https?:\/\/([-.a-zA-Z0-9]+)/);
var domain=urls[1];
if(mode=="emb"){
var emb='<iframe src="'+url+'/embed" class="mastodon-embed" style="max-width: 100%; border: 0" width="400"></iframe><script src="https://'+domain+'/embed.js" async="async"></script>';
execCopy(emb)
2018-02-18 05:44:20 +11:00
Materialize.toast("埋め込みHTMLをコピーしました", 1500);
2018-02-18 03:44:03 +11:00
}else{
2018-02-25 19:41:34 +11:00
if(execCopy(url)){
Materialize.toast("トゥートURLをコピーしました", 1500);
}
2018-02-18 03:44:03 +11:00
}
2018-03-11 01:22:59 +11:00
}
2018-03-27 13:39:35 +11:00
//本文のコピー
function staCopy(id){
var html=$("[toot-id="+id+"] .toot").html();
2018-06-18 00:26:45 +10:00
html = html.replace(/^<p>(.+)<\/p>$/,"$1");
2018-03-27 13:39:35 +11:00
html = html.replace(/<br\s?\/?>/, "\n");
html = html.replace(/<p>/, "\n");
html = html.replace(/<\/p>/, "\n");
2018-06-18 00:26:45 +10:00
console.log(html);
html = html.replace(/<img[\s\S]*alt="(.+?)"[\s\S]*?>/g, "$1");
2018-03-27 13:39:35 +11:00
html=$.strip_tags(html);
if(execCopy(html)){
Materialize.toast("トゥート本文をコピーしました", 1500);
}
}
2018-03-11 01:22:59 +11:00
//魚拓
function shot(){
2018-06-18 00:26:45 +10:00
var title=$("#tootmodal").attr("data-id");
var off = $('#toot-this').offset();
var w=$("#toot-this").width()+50;
var h=$("#toot-this").height()+50;
2018-03-11 01:22:59 +11:00
var electron = require("electron");
2018-06-18 00:26:45 +10:00
const fs = require("fs");
const os = require('os')
const shell = electron.shell;
const path = require('path')
2018-03-11 01:22:59 +11:00
var ipc = electron.ipcRenderer;
2018-06-18 00:26:45 +10:00
let options = {
types: ['screen'],
thumbnailSize: {
width: window.parent.screen.width,
height: window.parent.screen.height
}
}
const desktopCapturer = electron.desktopCapturer;
desktopCapturer.getSources(options, function(error, sources) {
if (error) return console.log(error)
sources.forEach(function(source) {
if (source.name === 'Screen 1' || source.name === 'TheDesk') {
var durl=source.thumbnail.toDataURL();
var b64 = durl.match(
/data:image\/png;base64,(.+)/
);
const screenshotPath = path.join(os.tmpdir(), 'screenshot.png');
const savePath = path.join(os.tmpdir(), 'screenshot.png');
var ipc = electron.ipcRenderer;
ipc.send('shot', ['file://' + screenshotPath,w,h,b64[1],title,off.top+50,off.left]);
if($("#toot-this .img-parsed").length>0){
for(i=0;i<$("#toot-this .img-parsed").length;i++){
var url=$("#toot-this .img-parsed").eq(i).attr("data-url");
ipc.send('shot-img-dl', [url,title+"_img"+i+".png"]);
}
}
return;
const message = `Saved screenshot to: ${screenshotPath}`
//screenshotMsg.textContent = message
}
})
})
2018-03-31 13:39:06 +11:00
}
//翻訳
function trans(tar){
var html=$("#toot-this .toot").html();
if(html.match(/^<p>(.+)<\/p>$/)){
html = html.match(/^<p>(.+)<\/p>$/)[1];
}
2018-04-01 07:00:27 +10:00
html = html.replace(/<br\s?\/?>/g, "\n");
html = html.replace(/<p>/g, "\n");
html = html.replace(/<\/p>/g, "\n");
2018-03-31 13:39:06 +11:00
html=$.strip_tags(html);
$("#toot-this .additional").text("Loading...(Powered by Google Translate)");
2018-04-01 07:00:27 +10:00
var exec='https://script.google.com/macros/s/AKfycbz0ETqcUxwNlw961GjErNb7vr_X18N2s1AS5Xu5nFTbYXcdcRM/exec?text='+encodeURIComponent(html)+'&source='+tar+'&target=ja'
console.log(exec);
2018-03-31 13:39:06 +11:00
fetch(exec, {
method: 'GET',
}).then(function(response) {
return response.text();
}).catch(function(error) {
todo(error);
console.error(error);
}).then(function(text) {
$("#toot-this .additional").html('<span class="gray">'+text+'</span>');
});
2018-04-07 14:31:09 +10:00
}
//ブラウザで開く
function brws(){
var url=$("#tootmodal").attr("data-url");
const {
shell
} = require('electron');
shell.openExternal(url);
}
//外部からトゥート開く
2018-04-09 00:17:33 +10:00
function detEx(url,acct_id){
2018-05-20 16:17:10 +10:00
if(acct_id=="main"){
acct_id=localStorage.getItem("main");
}
2018-04-09 00:17:33 +10:00
var domain = localStorage.getItem("domain_"+acct_id);
2018-07-07 03:51:48 +10:00
var at = localStorage.getItem("acct_"+ acct_id + "_at");
2018-04-07 14:31:09 +10:00
var start = "https://" + domain + "/api/v1/search?resolve=true&q="+url
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) {
if(!json.statuses){
const {
shell
} = require('electron');
shell.openExternal(url);
}else{
var id=json.statuses[0].id;
2018-04-09 00:17:33 +10:00
$(".loadp").text($(".loadp").attr("href"));
$(".loadp").removeClass("loadp");
details(id, acct_id, 0)
2018-04-07 14:31:09 +10:00
}
});
return;
2018-02-18 03:44:03 +11:00
}