Today shinchoku

This commit is contained in:
cutls 2020-07-12 00:48:15 +09:00
parent 2c54e43e37
commit 78a8c2bdce
4 changed files with 133 additions and 208 deletions

View File

@ -6,11 +6,12 @@ localStorage.removeItem('quoters')
localStorage.removeItem('imas') localStorage.removeItem('imas')
//stable, 固定タグのことらしい。ふざけるな。 //stable, 固定タグのことらしい。ふざけるな。
localStorage.removeItem('stable') localStorage.removeItem('stable')
const acctList = JSON.parse(localStorage.getItem('multi'))
function ck() { function ck() {
const main = localStorage.getItem('main') const main = localStorage.getItem('main')
if (!main) { if (!main) {
localStorage.setItem('main', 0) localStorage.setItem('main', '0')
} }
//コード受信 //コード受信
@ -31,13 +32,26 @@ function ck() {
} else { } else {
const obj = JSON.parse(multi) const obj = JSON.parse(multi)
const keymap = Object.keys(obj) const keymap = Object.keys(obj)
let req = false
for (let i = 0; i < keymap.length; i++) { for (let i = 0; i < keymap.length; i++) {
const key = keymap[i] const key = keymap[i]
const acct = obj[key] const acct = obj[key]
if (acct.domain) { if (acct.domain) {
refresh(key, true) req = refresh(key, true)
} }
} }
if(req) {
Swal.fire({
title: 'Reload required',
text: lang.lang_login_changedData,
type: 'info',
showCancelButton: true,
confirmButtonText: lang.lang_no,
cancelButtonText: lang.lang_yesno
}).then(result => {
if(result) location.reload()
})
}
if (obj[0].domain) { if (obj[0].domain) {
showElm('#tl') showElm('#tl')
ticker() ticker()
@ -55,9 +69,9 @@ function ck() {
ck() ck()
//ユーザーデータ更新 //ユーザーデータ更新
async function refresh(target, loadskip) { async function refresh(target, loadskip) {
const multi = localStorage.getItem('multi') let obj = acctList
let obj = JSON.parse(multi) let requireReload = false
const {mode, domain, at, background, text} = obj[target] const { mode, domain, at, background, text, name, prof, vis } = obj[target]
if (mode == 'misskey') { if (mode == 'misskey') {
return return
} }
@ -73,31 +87,37 @@ async function refresh(target, loadskip) {
if (avatar == '/avatars/original/missing.png' || !avatar) { if (avatar == '/avatars/original/missing.png' || !avatar) {
avatar = './img/missing.svg' avatar = './img/missing.svg'
} }
let ref = { const { newName, newProf, newVis } = json
at: at, if (newName != name || newProf != prof || newVis != vis) {
name: json['display_name'], let ref = {
domain: domain, at: at,
user: json['acct'], name: json['display_name'],
prof: avatar, domain: domain,
id: json['id'], user: json['acct'],
vis: json['source']['privacy'] prof: avatar,
id: json['id'],
vis: json['source']['privacy']
}
if (background) {
ref.background = background
}
if (text) {
ref.text = text
}
if (json['source']['sensitive']) {
localStorage.setItem('nsfw_' + target, true)
} else {
localStorage.removeItem('nsfw_' + target)
}
obj[target] = ref
const save = JSON.stringify(obj)
localStorage.setItem('multi', save)
requireReload = true
} }
if (background) {
ref.background = background
}
if (text) {
ref.text = text
}
if (json['source']['sensitive']) {
localStorage.setItem('nsfw_' + target, 'true')
} else {
localStorage.removeItem('nsfw_' + target)
}
obj[target] = ref
const save = JSON.stringify(obj)
localStorage.setItem('multi', save)
if (!loadskip) { if (!loadskip) {
load() load()
} else {
return requireReload
} }
} }
//MarkdownやBBCodeの対応、文字数制限をチェック //MarkdownやBBCodeの対応、文字数制限をチェック
@ -105,195 +125,118 @@ async function refresh(target, loadskip) {
function ckdb(acct_id) { function ckdb(acct_id) {
const domain = localStorage.getItem(`domain_${acct_id}`) const domain = localStorage.getItem(`domain_${acct_id}`)
if (domain == 'kirishima.cloud') { if (domain == 'kirishima.cloud') {
localStorage.setItem('kirishima', 'true') localStorage.setItem('kirishima', true)
} else if (domain == 'imastodon.net') { } else if (domain == 'imastodon.net') {
localStorage.setItem('imas', 'true') localStorage.setItem('imas', true)
showElm('.imasonly') showElm('.imasonly')
} }
const at = localStorage.getItem(`acct_${acct_id}_at`) const at = localStorage.getItem(`acct_${acct_id}_at`)
const letters = `${domain}_letters` const letters = `${domain}_letters`
const quoteMarker = `${domain}_quote` const quoteMarker = `${domain}_quote`
if (idata) { if (idata) {
//check and replace json to idata //check and replace json to idata
var json = idata var json = idata
if (json[quoteMarker] == 'enabled') { if (json[quoteMarker] == 'enabled') {
localStorage.setItem('quoters', 'true') localStorage.setItem('quoters', true)
localStorage.setItem('quote_' + acct_id, 'true') localStorage.setItem(`quote_${acct_id}`, true)
}
if (json[bbcode]) {
if (json[bbcode] == 'enabled') {
localStorage.setItem('bb_' + acct_id, 'true')
} else {
localStorage.removeItem('bb_' + acct_id)
$("[data-activates='bbcode']").addClass('disabled')
$("[data-activates='bbcode']").prop('disabled', true)
}
} else {
localStorage.removeItem('bb_' + acct_id)
$("[data-activates='bbcode']").addClass('disabled')
$("[data-activates='bbcode']").addClass('disabled', true)
}
if (json[domain + '_markdown'] == 'enabled') {
localStorage.setItem('md_' + acct_id, 'true')
$('.markdown').show()
} else {
$('.anti-markdown').hide()
$('.markdown').hide()
localStorage.removeItem('bb_' + acct_id)
}
if (json[domain + '_home']) {
localStorage.setItem('home_' + acct_id, json[domain + '_home'])
}
if (json[domain + '_local']) {
localStorage.setItem('local_' + acct_id, json[domain + '_local'])
}
if (json[domain + '_public']) {
localStorage.setItem('public_' + acct_id, json[domain + '_public'])
}
if (json[domain + '_notification']) {
localStorage.setItem('notification_' + acct_id, json[domain + '_notification'])
}
if (json[domain + '_post']) {
localStorage.setItem('post_' + acct_id, json[domain + '_post'])
}
if (json[domain + '_fav']) {
localStorage.setItem('fav_' + acct_id, json[domain + '_fav'])
}
if (json[domain + '_bt']) {
localStorage.setItem('bt_' + acct_id, json[domain + '_bt'])
}
if (json[domain + '_follow']) {
localStorage.setItem('followlocale_' + acct_id, json[domain + '_follow'])
} }
} }
if (localStorage.getItem('mode_' + domain) != 'misskey') { if (!isMisskey(domain)) {
var start = 'https://' + domain + '/api/v1/instance' const start = `https://${domain}/api/v1/instance`
fetch(start, { const json = getApi(start, null)
method: 'GET', if (!json || json.error) {
headers: { return
'content-type': 'application/json' }
} const mtc = json['max_toot_chars']
}) if (mtc) {
.then(function (response) { localStorage.setItem(`letters_${acct_id}`, mtc)
return response.json() }
}) if (json['feature_quote']) {
.catch(function (error) { localStorage.setItem(`quote_${acct_id}`, true)
console.error(error) }
}) const str = json['urls']['streaming_api']
.then(function (json) { if (str) {
if (json.error) { localStorage.setItem(`streaming_${acct_id}`, str)
console.error(json.error) }
return
}
if (json) {
if (json['max_toot_chars']) {
localStorage.setItem('letters_' + acct_id, json['max_toot_chars'])
}
if (json['urls']['streaming_api']) {
localStorage.setItem('streaming_' + acct_id, json['urls']['streaming_api'])
} else {
localStorage.removeItem('streaming_' + acct_id)
}
}
})
} else {
} }
} }
//アカウントを選択…を実装 //アカウントを選択…を実装
function multiSelector(parseC) { function multiSelector(parseC) {
var multi = localStorage.getItem('multi') if (!acctList) return false
if (!multi) { const obj = acctList
var obj = [] let template
var json = JSON.stringify(obj) //StringなのはlocalStorageがStringしか返さないから
localStorage.setItem('multi', json) let lastUsed = '0'
} else {
var obj = JSON.parse(multi)
}
var templete
if (localStorage.getItem('mainuse') == 'main') { if (localStorage.getItem('mainuse') == 'main') {
var last = localStorage.getItem('main') lastUsed = localStorage.getItem('main')
} else if (localStorage.getItem('last-use')) { } else if (localStorage.getItem('last-use')) {
var last = localStorage.getItem('last-use') lastUsed = localStorage.getItem('last-use')
if (last == 'webview' || last == 'noauth') { if (lastUsed == 'webview' || last == 'noauth') {
last = '0' lastUsed = '0'
} }
} else { } else {
var last = '0' lastUsed = '0'
} }
last = last + '' let sel
var sel
if (obj.length < 1) { if (obj.length < 1) {
$('#src-acct-sel').html('<option value="tootsearch">Tootsearch</option>') document.querySelector('#src-acct-sel').innerHTML = '<option value="tootsearch">Tootsearch</option>'
$('#add-acct-sel').html('<option value="noauth">' + lang.lang_login_noauth + '</option>') document.querySelector('#add-acct-sel').innerHTML = `<option value="noauth">${lang.lang_login_noauth}</option>`
} else { } else {
Object.keys(obj).forEach(function (key) { for (let i = 0; i < obj.length; i++) {
var acct = obj[key] const acct = obj[i]
var list = key * 1 + 1 const strKey = i?.toString()
if (key + '' === last) { if (key == lastUsed) {
sel = 'selected' sel = 'selected'
var domain = acct.domain const domain = acct.domain
localStorage.setItem('domain_' + key, domain) const letters = idata[`${domain}_letters`]
if (idata[domain + '_letters']) { const textarea = document.querySelector('#textarea')
$('#textarea').attr('data-length', idata[domain + '_letters']) if (letters) {
textarea.setAttribute('data-length', letters)
} else { } else {
var maxletters = localStorage.getItem('letters_' + key) //手動でアカマネで変えれちゃうから
if (maxletters > 0) { const maxLetters = localStorage.getItem('letters_' + key)
$('#textarea').attr('data-length', maxletters) if (maxLetters > 0) {
textarea.setAttribute('data-length', maxLetters)
} else { } else {
$('#textarea').attr('data-length', 500) textarea.setAttribute('data-length', 500)
} }
} }
if (idata[domain + '_glitch']) { if (idata[`${domain}_glitch`]) {
$('#local-button').removeClass('hide') document.querySelector('#local-button').classList.remove('hide')
} }
var profimg = acct.prof let profimg = acct.prof
//localStorage.setItem("prof_" + key, profimg);
if (!profimg) { if (!profimg) {
profimg = '../../img/missing.svg' profimg = '../../img/missing.svg'
} }
$('#acct-sel-prof').attr('src', profimg) document.querySelector('#acct-sel-pro').setAttribute('src', profimg)
let cc = ''
if (domain) { if (domain) {
var cc = '(' + domain + ')' cc = `(${domain})`
} else {
var cc = ''
} }
$('#toot-post-btn').text(lang.lang_toot + cc) const tpb = document.querySelector('#toot-post-btn')
tpb.innerText = lang.lang_toot + cc
if (acct.background && acct.background != 'def' && acct.text && acct.text != 'def') { if (acct.background && acct.background != 'def' && acct.text && acct.text != 'def') {
$('#toot-post-btn').removeClass('indigo') tpb.classList.remove('indigo')
$('#toot-post-btn').css('background-color', '#' + acct.background) tpb.style.backgroundColor = `#${acct.background}`
$('#toot-post-btn').css('color', acct.text) tpb.style.color = `#${acct.text}`
} else {
}
if (domain == 'kirishima.cloud') {
$('#faicon-btn').show()
} else {
$('#faicon-btn').hide()
} }
if (domain == 'imastodon.net') { if (domain == 'imastodon.net') {
trendTag() trendTag()
} else { } else {
$('#trendtag').html('') document.querySelector('#trendtag').innerHTML = ''
} }
} else { } else {
sel = '' sel = ''
} }
templete = template = `
'<option value="' + <option value="${key}" data-icon="${acct.prof}" class="left circle" ${sel}>
key + @${acct.user} ${acct.domain}
'" data-icon="' + </option>
acct.prof + `
'" class="left circle" ' + appendPrepend('.acct-sel', template, 'append')
sel + }
'>' +
acct.user +
'@' +
acct.domain +
'</option>'
$('.acct-sel').append(templete)
})
$('#src-acct-sel').append('<option value="tootsearch">Tootsearch</option>') $('#src-acct-sel').append('<option value="tootsearch">Tootsearch</option>')
$('#add-acct-sel').append( $('#add-acct-sel').append(
'<option value="noauth">' + '<option value="noauth">' +
@ -307,40 +250,12 @@ function multiSelector(parseC) {
parseColumn(null, true) parseColumn(null, true)
} }
} }
//バージョンエンコ
function enc(ver) {
var ver = ver.replace(/\s/g, '')
var ver = ver.replace(/\(/g, '-')
var ver = ver.replace(/\)/g, '')
var ver = ver.replace(/\[/g, '_')
var ver = ver.replace(/\]/g, '')
return ver
}
//インスタンスティッカー //インスタンスティッカー
function ticker() { function ticker() {
var start = 'https://toot-app.thedesk.top/toot/index.php' const start = 'https://toot-app.thedesk.top/toot/index.php'
fetch(start, { const json = getApi(start, null)
method: 'GET', if(json) localStorage.setItem('ticker', JSON.stringify(json))
cors: true,
headers: {
'content-type': 'application/json'
}
})
.then(function (response) {
if (!response.ok) {
response.text().then(function (text) {
setLog(response.url, response.status, text)
})
}
return response.json()
})
.catch(function (error) {
console.error(error)
})
.then(function (json) {
if (json) {
localStorage.setItem('ticker', JSON.stringify(json))
}
})
} }
function isMisskey(domain) {
return localStorage.getItem(`mode_${domain}`) == 'misskey'
}

View File

@ -314,4 +314,12 @@ function setAllClasses(query, className, action) {
if(action == 'remove') target.classList.remove(className) if(action == 'remove') target.classList.remove(className)
} }
} }
function appendPrepend(query, elm, action) {
const allTarget = document.querySelectorAll(query)
for (let i = 0; i < allTarget.length; i++) {
const target = allTarget[i]
if(action == 'prepend') target.prependChild(elm)
if(action == 'append') target.appendChild(elm)
}
}
const sleep = msec => new Promise(resolve => setTimeout(resolve, msec)); const sleep = msec => new Promise(resolve => setTimeout(resolve, msec));

View File

@ -3,8 +3,8 @@
"lang_toot": "トゥート", "lang_toot": "トゥート",
"lang_there": "あり", "lang_there": "あり",
"lang_nothing": "なし", "lang_nothing": "なし",
"lang_yesno": "はい", "lang_yesno": "せやな",
"lang_no": "いいえ", "lang_no": "ちゃうわ",
"lang_progress": "処理中", "lang_progress": "処理中",
"lang_edit": "編集", "lang_edit": "編集",
"lang_del": "削除", "lang_del": "削除",
@ -38,6 +38,7 @@
"lang_version_platform_linux": "このソフトウェアSnapcraftからダウンロードしたんか普通はホームページからインストールするし「いいえ」でええんやけど。「はい」にしたらSnapcraftはんがアップデートするからTheDeskはアップデートせえへんとか言わへんようになる。", "lang_version_platform_linux": "このソフトウェアSnapcraftからダウンロードしたんか普通はホームページからインストールするし「いいえ」でええんやけど。「はい」にしたらSnapcraftはんがアップデートするからTheDeskはアップデートせえへんとか言わへんようになる。",
"lang_version_platform_mac": "このソフトウェアHomebrew caskからダウンロードしたんか普通はホームページからインストールするし「いいえ」でええんやけど。「はい」にしたらHomebrew caskはんがアップデートするからTheDeskはアップデートせえへんとか言わへんようになる。", "lang_version_platform_mac": "このソフトウェアHomebrew caskからダウンロードしたんか普通はホームページからインストールするし「いいえ」でええんやけど。「はい」にしたらHomebrew caskはんがアップデートするからTheDeskはアップデートせえへんとか言わへんようになる。",
"lang_login_noauth": "認証せんと見る", "lang_login_noauth": "認証せんと見る",
"lang_login_changedData": "プロフの情報が変わってしもたけど、もっかい読み込んだ方がええんちゃうか?",
"lang_manager_info": "インスタンス情報", "lang_manager_info": "インスタンス情報",
"lang_manager_refresh": "情報更新", "lang_manager_refresh": "情報更新",
"lang_manager_delete": "削除", "lang_manager_delete": "削除",

View File

@ -38,6 +38,7 @@
"lang_version_platform_linux": "このソフトウェアはSnapcraft(snapd)からインストールしましたか通常はホームページからインストールするため「いいえ」を選んでください。「はい」を選ぶとSnapcraftからアップデートが提供され、アップデートの通知を出しません。", "lang_version_platform_linux": "このソフトウェアはSnapcraft(snapd)からインストールしましたか通常はホームページからインストールするため「いいえ」を選んでください。「はい」を選ぶとSnapcraftからアップデートが提供され、アップデートの通知を出しません。",
"lang_version_platform_mac": "このソフトウェアはHomebrew Caskからインストールしましたか通常はホームページからインストールするため「いいえ」を選んでください。「はい」を選ぶとアップデートの通知を出しません。", "lang_version_platform_mac": "このソフトウェアはHomebrew Caskからインストールしましたか通常はホームページからインストールするため「いいえ」を選んでください。「はい」を選ぶとアップデートの通知を出しません。",
"lang_login_noauth": "認証せずに見る", "lang_login_noauth": "認証せずに見る",
"lang_login_changedData": "プロフィール情報が変更されました。再読み込みしますか?",
"lang_manager_info": "インスタンス情報", "lang_manager_info": "インスタンス情報",
"lang_manager_refresh": "情報更新", "lang_manager_refresh": "情報更新",
"lang_manager_delete": "削除", "lang_manager_delete": "削除",