thedesk/app/js/login/manager.js

806 lines
25 KiB
JavaScript
Raw Normal View History

2018-01-28 21:22:43 +09:00
//アカウントマネージャ
//最初に読むやつ
function load() {
2020-07-21 12:44:53 +09:00
document.querySelector('#acct-list').innerHTML = ''
2019-05-19 16:39:30 +09:00
if (location.search) {
2020-07-21 12:44:53 +09:00
const m = location.search.match(/\?mode=([a-zA-Z-0-9]+)\&code=(.+)/)
const mode = m[1]
const codex = m[2]
2019-11-08 22:52:54 +09:00
if (mode == 'first' && codex == 'true') {
2020-07-21 12:44:53 +09:00
setAllClasses('body', 'first', 'add')
2019-04-11 01:52:01 +09:00
}
}
2020-08-31 00:23:55 +09:00
const obj = acctList
2020-07-21 12:44:53 +09:00
let domains = []
let template = ''
document.querySelector('#acct-list').innerHTML = ''
for (let i = 0; i < obj.length; i++) {
const acct = obj[i]
const list = (parseInt(i) + 1).toString()
let style = ''
if (acct.background != 'def' && acct.text != 'def') style = `style="background-color:#${acct.background}; color:${acct.text};"`
let name = acct.user
if (acct.name) name = acct.name
domains.push(acct.domain)
2020-07-21 12:44:53 +09:00
template = template + `
2019-11-08 22:52:54 +09:00
<div id="acct_${key}" class="card" ${style}>
<div class="card-content ">
<span class="lts">${list}.</span><img src="${acct.prof}" width="40" height="40" />
<span class="card-title">${name}</span>${escapeHTML(acct.user)}@${acct.domain}
</div>
<div class="card-action">
<button class="btn-flat waves-effect disTar pointer white-text" onclick="refresh('${key}')">
<i class="material-icons left">refresh</i>${lang.lang_manager_refresh}
</button>
<button class="btn-flat waves-effect disTar pointer red-text" onclick="multiDel('${key}')">
<i class="material-icons left">delete</i>${lang.lang_manager_delete}
</button><br />${lang.lang_manager_color}
2019-11-08 22:52:54 +09:00
<div id="colorsel_${key}" class="colorsel"></div>
</div>
</div>
`
2020-07-21 12:44:53 +09:00
colorpicker(i)
}
document.querySelector('#acct-list').innerHTML = template
//lodash dependent
domains = _.uniq(domains)
2020-07-21 12:44:53 +09:00
document.querySelector('#domain-list').innerHTML = ''
const keymap = Object.keys(domains)
let templateDomainList = ''
2020-08-31 00:23:55 +09:00
for (let j = 0; j < domains.length; j++) {
2020-07-21 12:44:53 +09:00
const key = keymap[j]
const domain = domains[key]
let maxChars = 500
const thisLtrs = localStorage.getItem(`${domain}_letters`)
2020-08-31 00:23:55 +09:00
if (thisLtrs) maxChars = thisLtrs
2020-07-21 12:44:53 +09:00
templateDomainList = templateDomainList + `
<li class="collection-item transparent">
<div>
<p class="title">${domain}</p>
${lang.lang_manager_maxChars} <input style="width: 100px" value="${maxChars}" id="maxChars${key2}">
<button class="btn-flat waves-effect" onclick="maxChars('${domain}', '${key2}')">
<i class="material-icons">send</i>
</button>
<button class="btn-flat waves-effect secondary-content" onclick="data('${domain}', '${key2}')">
<i class="material-icons left">info</i>${lang.lang_manager_info}
</button>
</div>
</li>
`
2020-07-21 12:44:53 +09:00
}
document.querySelector('#domain-list').innnerHTML = templateDomainList
2019-11-08 22:52:54 +09:00
multisel()
2020-07-21 12:44:53 +09:00
let acctN = localStorage.getItem('acct')
2018-01-28 21:22:43 +09:00
if (!acctN) {
2019-11-08 22:52:54 +09:00
localStorage.setItem('acct', 0)
2020-07-21 12:44:53 +09:00
acctN = 0
2018-01-28 21:22:43 +09:00
}
}
//最初に読む
2019-11-08 22:52:54 +09:00
load()
support()
function maxChars(domain, uid) {
2020-07-21 12:44:53 +09:00
const value = document.querySelector(`#maxChars${uid}`).value
if (parseInt(value) < 1 || !Number.isInteger(parseInt(value))) {
Swal.fire({
type: 'error',
title: 'Error'
})
return false
}
2020-07-21 12:44:53 +09:00
const multi = localStorage.getItem('multi')
2020-08-31 00:23:55 +09:00
if (!multi) return false
2020-07-21 12:44:53 +09:00
const obj = JSON.parse(multi)
2020-08-31 00:23:55 +09:00
for (let k = 0; k < obj.length; k++) {
2020-07-21 12:44:53 +09:00
if (obj[k].domain == domain) localStorage.setItem(`${domain}_letters`, value)
}
load()
}
//instances.social/instances API
async function data(domain, acct_id) {
2020-08-31 00:23:55 +09:00
document.querySelector('#ins-upd').innerText = 'Loading...'
document.querySelector('#ins-add').innerText = 'Loading...'
document.querySelector('#ins-connect').innerText = 'Loading...'
document.querySelector('#ins-toot').innerText = 'Loading...'
document.querySelector('#ins-sys').innerText = 'Loading...'
document.querySelector('#ins-per').innerText = 'Loading...'
document.querySelector('#ins-user').innerText = 'Loading...'
document.querySelector('#ins-var').innerText = 'Loading...'
document.querySelector('#ins-name').innerText = 'Loading...'
document.querySelector('#ins-prof').setAttribute('src', '../../img/loading.svg')
const start = 'https://instances.social/api/1.0/instances/show?name=' + domain
const json = await getApi(start, 'tC8F6xWGWBUwGScyNevYlx62iO6fdQ4oIK0ad68Oo7ZKB8GQdGpjW9TKxBnIh8grAhvd5rw3iyP9JPamoDpeLQdz62EToPJUW99hDx8rfuJfGdjQuimZPTbIOx0woA5M')
document.querySelector('#ins-name').innerText = json.name
document.querySelector('#ins-upd').innerText = date(json.checked_at, 'full')
document.querySelector('#ins-add').innerText = date(json.added_at, 'full')
document.querySelector('#ins-connect').innerText = json.connections
document.querySelector('#ins-toot').innerText = json.statuses
document.querySelector('#ins-sys').innerText = date(json.updated_at, 'full')
document.querySelector('#ins-per').innerText = json.uptime * 100
document.querySelector('#ins-user').innerText = json.users
document.querySelector('#ins-ver').innerText = json.version
const start2 = 'https://' + domain + '/api/v1/instance'
const json2 = await getApi(start2, null)
document.querySelector('#ins-title').innerText = json2.title
document.querySelector('#ins-desc').innerText = json2.description
document.querySelector('#ins-email').innerText = json2.email
document.querySelector('#ins-toot').innerText = json2.stats.status_count
document.querySelector('#ins-user').innerText = json2.user_count
document.querySelector('#ins-ver').innerText = json2.version
document.querySelector('#ins-prof').innerText = json2.version
document.querySelector('#ins-prof').setAttribute('src', json2.thumbnail)
document.querySelector('#ins-admin').innerText = `${escapeHTML(json2.contact_account.display_name)}(${json2.contact_account.acct})`
document.querySelector('#ins-admin').setAttribute('href', `index.html?mode=user&code=${json2.contact_account.username}@${domain}`)
if (json2['max_toot_chars']) {
localStorage.setItem('letters_' + acct_id, json['max_toot_chars'])
load()
}
2018-01-28 21:22:43 +09:00
}
//アカウントデータ 消す
function multiDel(target) {
2020-08-31 00:23:55 +09:00
const obj = acctList
2018-07-07 02:51:48 +09:00
//削除確認ダイアログ
2019-06-22 01:06:32 +09:00
Swal.fire({
title: lang.lang_manager_logout,
2019-11-08 22:52:54 +09:00
text: obj[target]['user'] + '@' + obj[target]['domain'] + lang.lang_manager_confirm,
type: 'warning',
2019-06-22 01:06:32 +09:00
showCancelButton: true,
2019-11-08 22:52:54 +09:00
confirmButtonColor: '#3085d6',
cancelButtonColor: '#d33',
2019-06-22 01:06:32 +09:00
confirmButtonText: lang.lang_yesno,
cancelButtonText: lang.lang_no
2019-10-22 14:34:23 +09:00
}).then(result => {
2019-06-22 01:06:32 +09:00
if (result.value) {
2020-08-31 00:23:55 +09:00
for (let i = 0; i < obj.length; i++) {
const nk = i - 1
2019-06-22 01:06:32 +09:00
if (key >= target) {
2020-08-31 00:23:55 +09:00
const oldvis = localStorage.getItem(`vis-memory-${i}`)
if (oldvis) localStorage.setItem(`vis-memory-${nk}`, oldvis)
2018-07-07 02:51:48 +09:00
}
2020-08-31 00:23:55 +09:00
}
2019-06-22 01:06:32 +09:00
//とりあえず消す
2019-11-08 22:52:54 +09:00
obj.splice(target, 1)
2020-08-31 00:23:55 +09:00
const json = JSON.stringify(obj)
2019-11-08 22:52:54 +09:00
localStorage.setItem('multi', json)
load()
2019-06-22 01:06:32 +09:00
//カラムデータコンフリクト
2020-08-31 00:23:55 +09:00
const col = localStorage.getItem('column')
const oldcols = JSON.parse(col)
const newcols = []
for (let i = 0; i < oldcols.length; i++) {
const nk = i - 1
const oldcol = oldcols[i]
let newdom = oldcol.domain
if (target < oldcol.domain) newdom = oldcol.domain - 1
const type = oldcol.type
let data = null
if (oldcol.data) data = oldcol.data
let background = null
if (oldcol.background) background = oldcol.background
let text = null
if (oldcol.text) text = oldcol.text
let left_fold = false
if (oldcol.left_fold) left_fold = true
2019-06-22 01:06:32 +09:00
//消した垢のコラムじゃないときコピー
if (target != oldcol.domain) {
2020-08-31 00:23:55 +09:00
const add = {
2019-06-22 01:06:32 +09:00
domain: newdom,
2020-06-10 12:09:17 +09:00
type: type,
data: data,
background: background,
text: text,
left_fold: left_fold
2019-11-08 22:52:54 +09:00
}
newcols.push(add)
2019-06-22 01:06:32 +09:00
}
2018-07-07 02:51:48 +09:00
}
2020-08-31 00:23:55 +09:00
const newjson = JSON.stringify(newcols)
localStorage.setItem('column', newjson)
location.reload()
2018-07-07 02:51:48 +09:00
}
2019-11-08 22:52:54 +09:00
})
2018-01-28 21:22:43 +09:00
}
//サポートインスタンス
function support() {
2020-08-31 00:23:55 +09:00
let i = 0
let template = ''
const keys = Object.keys(idata)
for (const instance of idata) {
2019-11-08 22:52:54 +09:00
if (instance == 'instance') {
2020-08-31 00:23:55 +09:00
template = template + `<a onclick="login('${key}') class="collection-item pointer transparent">
${idata[`${keys[i]}_name`]}
</a>`
2019-05-19 16:39:30 +09:00
}
2020-08-31 00:23:55 +09:00
i++
}
document.querySelector('#support').innerHTML = template
2018-01-28 21:22:43 +09:00
}
//URL指定してポップアップ
2020-08-31 00:23:55 +09:00
async function login(url) {
if (document.querySelector('#misskey').checked) {
2019-11-08 22:52:54 +09:00
misskeyLogin(url)
return
2018-07-28 06:25:12 +09:00
}
2020-08-31 00:23:55 +09:00
document.querySelector('#compt').style.display = 'none'
let red = 'thedesk://manager'
if (document.querySelector('#linux').checked) {
red = 'urn:ietf:wg:oauth:2.0:oob'
if (~url.indexOf('pixelfed')) red = 'https://thedesk.top/hello.html'
2018-02-26 00:32:10 +09:00
}
2019-11-08 22:52:54 +09:00
localStorage.setItem('redirect', red)
2020-08-31 00:23:55 +09:00
const start = 'https://' + url + '/api/v1/apps'
let json
const body = JSON.stringify({
scopes: 'read write follow',
client_name: 'TheDesk(PC)',
redirect_uris: red,
website: 'https://thedesk.top'
})
const json = await postApi(start, body, null, null)
const auth = `https://${url}/oauth/authorize?client_id=${json.client_id}&client_secret=${json.client_secret}&response_type=code&scope=read+write+follow&redirect_uri=${encodeURIComponent(red)}`
localStorage.setItem('domain_tmp', url)
localStorage.setItem('client_id', json['client_id'])
localStorage.setItem('client_secret', json['client_secret'])
document.querySelector('#auth').style.display = 'block'
versionChecker(url)
document.querySelector('#add').style.display = 'none'
postMessage(['openUrl', auth], '*')
if (!document.querySelector('#linux').checked) postMessage(['sendSinmpleIpc', 'quit'], '*')
2019-09-30 02:22:44 +09:00
}
2020-08-31 00:23:55 +09:00
async function versionChecker(url) {
const start = `https://${url}/api/v1/instance`
const json = await getApi(start, null)
const version = json.version
if (version) {
const reg = version.match(/^([0-9])\.[0-9]\.[0-9]/u)
if (reg) {
versionCompat(reg[1], reg, json.title, reg[0])
2019-09-30 02:22:44 +09:00
}
2020-08-31 00:23:55 +09:00
}
2019-09-30 02:22:44 +09:00
}
2020-08-31 00:23:55 +09:00
async function versionCompat(prefix, ver, title, real) {
document.querySelector('#compt-instance').innerText = title
document.querySelector('#compt-ver').innerText = real
2019-11-08 22:52:54 +09:00
if (~real.indexOf('compatible')) {
2020-08-31 00:23:55 +09:00
document.querySelector('#compt-warn').style.display = 'block'
2019-10-22 14:34:23 +09:00
} else {
2020-08-31 00:23:55 +09:00
document.querySelector('#compt-warn').style.display = 'none'
}
document.querySelector('#compt-list').innnerHTML = ''
const json = await getApi('../../source/version.json', null)
let complete = false
let ct = 0
let jl = 0
let jl2 = 0
let template = ''
for (const key in json) {
if (complete) break
const data = json[key]
if (data) {
jl++
if (key != real && !complete) {
for (let i = 0; i < data.length; i++) {
let e = ''
if (i == 0) {
e = `(${key})`
2019-09-30 02:22:44 +09:00
}
2020-08-31 00:23:55 +09:00
template = `<li>${data[i]}${e}</li>`
ct++
e = ''
2019-10-22 14:34:23 +09:00
}
2020-08-31 00:23:55 +09:00
jl2++
} else if (!complete) {
complete = true
2019-09-30 02:22:44 +09:00
}
2020-08-31 00:23:55 +09:00
}
}
document.querySelector('#compt-list').innnerHTML = template
if (lang.language == 'ja' && ct > 0) {
if (jl2 != jl && prefix != '1') {
document.querySelector('#compt').style.display = 'block'
2018-08-21 03:26:14 +09:00
}
2019-11-08 22:52:54 +09:00
}
2019-03-08 17:14:47 +09:00
}
2020-08-31 00:23:55 +09:00
async function misskeyLogin(url) {
if (!url) {
url = document.querySelector('#misskey-url').value
2019-11-08 22:52:54 +09:00
}
2020-08-31 00:23:55 +09:00
const start = `https://${url}/api/app/create`
const httpreq = new XMLHttpRequest()
const body = JSON.stringify({
name: 'TheDesk(PC)',
description: 'Mastodon and Misskey client for PC',
permission: [
'account-read',
'account-write',
'account/read',
'account/write',
'drive-read',
'drive-write',
'favorite-read',
'favorite-write',
'favorites-read',
'following-read',
'following-write',
'messaging-read',
'messaging-write',
'note-read',
'note-write',
'notification-read',
'notification-write',
'reaction-read',
'reaction-write',
'vote-read',
'vote-write',
'read:account',
'write:account',
'read:drive',
'write:drive',
'read:blocks',
'write:blocks',
'read:favorites',
'write:favorites',
'read:following',
'write:following',
'read:messaging',
'write:messaging',
'read:mutes',
'write:mutes',
'write:notes',
'read:notifications',
'write:notifications',
'read:reactions',
'write:reactions',
'write:votes'
]
})
const json = await postApi(start, body, null, null)
misskeyAuth(url, json.secret)
}
async function misskeyAuth(url, mkc) {
const start = 'https://' + url + '/api/auth/session/generate'
const body = JSON.stringify({
appSecret: mkc
})
const json = await postApi(start, body, null, null)
const token = json.token
localStorage.setItem('mkc', mkc)
document.querySelector('#auth').style.display = 'block'
document.querySelector('#code').value = token
document.querySelector('#add').style.display = 'none'
localStorage.setItem('domain_tmp', url)
postMessage(['openUrl', json.url], '*')
2018-01-28 21:22:43 +09:00
}
//テキストボックスにURL入れた
function instance() {
2020-08-31 00:23:55 +09:00
const url = document.querySelector('#url').value
2019-11-08 22:52:54 +09:00
if (url.indexOf('@') != -1 || url.indexOf('https') != -1) {
2020-08-31 00:23:55 +09:00
Swal.fire({
type: 'error',
title: '入力形式が違います。(Cutls@mstdn.jpにログインする場合、入力するのは"mstdn.jp"です。)'
})
2019-11-08 22:52:54 +09:00
return false
2018-08-21 03:26:14 +09:00
}
2019-11-08 22:52:54 +09:00
login(url)
2018-01-28 21:22:43 +09:00
}
//コード入れてAccessTokenゲット
2020-08-31 00:23:55 +09:00
async function code(code) {
2019-11-08 22:52:54 +09:00
localStorage.removeItem('redirect')
2019-05-19 16:39:30 +09:00
if (!code) {
2020-08-31 00:23:55 +09:00
code = document.querySelector('#code').value
document.querySelector('#code').value = ''
2018-02-18 14:43:11 +09:00
}
2019-11-08 22:52:54 +09:00
if (!code || code == '') {
M.toast({ html: lang.lang_fatalerroroccured + 'Error: no code', displayLength: 5000 })
return false
2019-10-22 14:34:23 +09:00
}
2020-08-31 00:23:55 +09:00
const url = localStorage.getItem('domain_tmp')
2019-11-08 22:52:54 +09:00
localStorage.removeItem('domain_tmp')
2020-08-31 00:23:55 +09:00
if (document.querySelector('#misskey').checked) {
document.querySelector('#misskey').checked = false
const mkc = localStorage.getItem('mkc')
localStorage.removeItem('mkc')
const start = `https://${url}/api/auth/session/userkey`
const body = JSON.stringify({
token: code,
appSecret: mkc
})
const json = await postApi(start, body, null, null)
const i = sha256(json.accessToken + mkc)
const { avatarUrl, name, username, id } = json.user
const add = {
at: i,
name: name,
domain: url,
user: username,
prof: avatarUrl,
id: id,
vis: 'public',
mode: 'misskey'
2019-11-08 22:52:54 +09:00
}
2020-08-31 00:23:55 +09:00
const multi = localStorage.getItem('multi')
let obj = JSON.parse(multi)
obj.push(add)
const write = JSON.stringify(obj)
localStorage.setItem('multi', write)
if (document.getElementsByTagName('body').classList.contains('first')) {
location.href = 'index.html'
2019-11-08 22:52:54 +09:00
}
2020-08-31 00:23:55 +09:00
load()
return
}
let red = 'urn:ietf:wg:oauth:2.0:oob'
if (~url.indexOf('pixelfed')) {
red = 'https://thedesk.top/hello.html'
}
const start = `https://${url}/oauth/token`
const id = localStorage.getItem('client_id')
localStorage.removeItem('client_id')
const secret = localStorage.getItem('client_secret')
localStorage.removeItem('client_secret')
const body = JSON.stringify({
grant_type: 'authorization_code',
redirect_uri: red,
client_id: id,
client_secret: secret,
code: code
})
const json = await postApi(start, body, null, null)
if (json.access_token) {
document.querySelector('#add').style.display = 'block'
document.querySelector('#auth').style.display = 'none'
getdata(url, json.access_token)
2018-04-17 02:10:35 +09:00
}
2018-01-28 21:22:43 +09:00
}
//ユーザーデータ取得
2020-08-31 00:23:55 +09:00
async function getdata(domain, at) {
const start = `https://${domain}/api/v1/accounts/verify_credentials`
const json = await getApi(start, at)
if (json.error) {
console.error('Error:' + json.error)
M.toast({ html: lang.lang_fatalerroroccured + 'Error:' + json.error, displayLength: 5000 })
return
}
const {avatar: avatarRaw, display_name: displayName, acct, id, source} = json
let avatar = avatarRaw
if (avatar == '/avatars/original/missing.png') {
avatar = '../../img/missing.svg'
}
let priv = 'public'
if(source) priv = source.privacy
const add = {
at: at,
name: displayName,
domain: domain,
user: acct,
prof: avatar,
id: id,
vis: priv,
mode: 'mastodon'
}
const multi = localStorage.getItem('multi')
let obj = JSON.parse(multi)
obj.push(add)
const json = JSON.stringify(obj)
localStorage.setItem('multi', json)
if (document.getElementsByTagName('body').classList.contains('first')) {
location.href = 'index.html'
}
load()
2019-10-22 14:34:23 +09:00
}
//アクセストークン直接入力
function atSetup(type) {
2020-08-31 00:23:55 +09:00
const url = localStorage.getItem('domain_tmp')
2019-11-08 22:52:54 +09:00
localStorage.removeItem('domain_tmp')
2020-08-31 00:23:55 +09:00
const multi = localStorage.getItem('multi')
const avatar = '../../img/missing.svg'
const priv = 'public'
let add
2019-11-08 22:52:54 +09:00
if (type == 'misskey') {
2020-08-31 00:23:55 +09:00
const i = document.querySelector('#misskey-key').value
add = {
2019-10-22 14:34:23 +09:00
at: i,
2019-11-08 22:52:54 +09:00
name: 'Pseudo Account',
2019-10-22 14:34:23 +09:00
domain: url,
2019-11-08 22:52:54 +09:00
user: 'user+pseudo',
2018-03-31 11:39:06 +09:00
prof: avatar,
2019-11-08 22:52:54 +09:00
id: 'id+pseudo',
2018-08-21 03:26:14 +09:00
vis: priv,
2019-11-08 22:52:54 +09:00
mode: 'misskey'
}
2019-10-22 14:34:23 +09:00
} else {
2020-08-31 00:23:55 +09:00
const i = document.querySelector('#code').value
add = {
2019-10-22 14:34:23 +09:00
at: i,
2019-11-08 22:52:54 +09:00
name: 'Pseudo Account',
2019-10-22 14:34:23 +09:00
domain: url,
2019-11-08 22:52:54 +09:00
user: 'user+pseudo',
2019-10-22 14:34:23 +09:00
prof: avatar,
2019-11-08 22:52:54 +09:00
id: 'id+pseudo',
2019-10-22 14:34:23 +09:00
vis: priv,
2020-08-31 00:23:55 +09:00
mode: 'mastodon'
2019-11-08 22:52:54 +09:00
}
2019-10-22 14:34:23 +09:00
}
2019-11-08 22:52:54 +09:00
if (!i || i == '') {
M.toast({ html: lang.lang_fatalerroroccured + 'Error: access token', displayLength: 5000 })
return false
2019-10-22 14:34:23 +09:00
}
2020-08-31 00:23:55 +09:00
let obj = JSON.parse(multi)
2019-11-08 22:52:54 +09:00
obj.push(add)
2020-08-31 00:23:55 +09:00
const json = JSON.stringify(obj)
2019-11-08 22:52:54 +09:00
localStorage.setItem('multi', json)
refresh(target)
2018-01-28 21:22:43 +09:00
}
//ユーザーデータ更新
2020-08-31 00:23:55 +09:00
async function refresh(i) {
const multi = localStorage.getItem('multi')
const obj = JSON.parse(multi)
const target = obj[i]
if (target.mode == 'misskey') {
misskeyRefresh(obj, target, target.domain)
2019-11-08 22:52:54 +09:00
return
2018-07-30 20:03:49 +09:00
}
2020-08-31 00:23:55 +09:00
const start = `https://${target.domain}/api/v1/accounts/verify_credentials`
const json = await getApi(start, target.at)
if (json.error) {
console.error('Error:' + json.error)
M.toast({ html: lang.lang_fatalerroroccured + 'Error:' + json.error, displayLength: 5000 })
return
}
const {avatar: avatarRaw, display_name: displayName, acct, id, source} = json
let avatar = avatarRaw
//missingがmissingなやつ
if (avatar == '/avatars/original/missing.png' || !avatar) {
avatar = './img/missing.svg'
}
let priv = 'public'
if(source) priv = source.privacy
const ref = {
at: target.at,
name: displayName,
domain: target.domain,
user: acct,
prof: avatar,
id: id,
vis: priv
}
if (target.background) {
ref.background = target.background
}
if (target.text) {
ref.text = target.text
}
if (source.sensitive) {
localStorage.setItem('nsfw_' + i, 'true')
} else {
localStorage.removeItem('nsfw_' + i)
}
obj[i] = ref
const json = JSON.stringify(obj)
localStorage.setItem('multi', json)
2018-01-28 21:22:43 +09:00
2020-08-31 00:23:55 +09:00
load()
2018-01-28 21:22:43 +09:00
}
2019-05-19 16:39:30 +09:00
function misskeyRefresh(obj, target, url) {
2019-11-08 22:52:54 +09:00
var start = 'https://' + url + '/api/users/show'
var httpreq = new XMLHttpRequest()
httpreq.open('POST', start, true)
httpreq.setRequestHeader('Content-Type', 'application/json')
httpreq.responseType = 'json'
2019-10-22 14:34:23 +09:00
httpreq.send(
JSON.stringify({
username: obj[target].user,
i: obj[target].at
})
2019-11-08 22:52:54 +09:00
)
2020-07-21 12:44:53 +09:00
httpreq.onreadystatechange = function () {
2019-05-19 16:39:30 +09:00
if (httpreq.readyState === 4) {
2019-11-08 22:52:54 +09:00
var json = httpreq.response
2019-11-04 01:10:06 +09:00
if (this.status !== 200) {
2019-11-08 22:52:54 +09:00
setLog(start, this.status, json)
2019-11-04 01:10:06 +09:00
}
2019-11-08 22:52:54 +09:00
var avatar = json['user']['avatarUrl']
var priv = 'public'
2019-05-19 16:39:30 +09:00
var add = {
at: json.accessToken,
2019-11-08 22:52:54 +09:00
name: json['user']['name'],
2019-05-19 16:39:30 +09:00
domain: url,
2019-11-08 22:52:54 +09:00
user: json['user']['username'],
2019-05-19 16:39:30 +09:00
prof: avatar,
2019-11-08 22:52:54 +09:00
id: json['user']['id'],
2019-05-19 16:39:30 +09:00
vis: priv
2019-11-08 22:52:54 +09:00
}
var multi = localStorage.getItem('multi')
var obj = JSON.parse(multi)
var target = obj.length
obj.push(add)
localStorage.setItem('name_' + target, json['user']['name'])
localStorage.setItem('user_' + target, json['user']['username'])
localStorage.setItem('user-id_' + target, json['user']['id'])
localStorage.setItem('prof_' + target, avatar)
var json = JSON.stringify(obj)
localStorage.setItem('multi', json)
load()
return
2019-05-19 16:39:30 +09:00
}
2019-11-08 22:52:54 +09:00
}
2018-07-30 20:03:49 +09:00
}
2018-05-20 15:17:10 +09:00
//アカウントを選択…を実装
function multisel() {
2019-11-08 22:52:54 +09:00
var multi = localStorage.getItem('multi')
2018-05-20 15:17:10 +09:00
if (!multi) {
2019-11-08 22:52:54 +09:00
var obj = []
var json = JSON.stringify(obj)
localStorage.setItem('multi', json)
2018-05-20 15:17:10 +09:00
} else {
2019-11-08 22:52:54 +09:00
var obj = JSON.parse(multi)
2018-05-20 15:17:10 +09:00
}
2019-11-08 22:52:54 +09:00
var templete
var last = localStorage.getItem('main')
var sel
2019-05-19 16:39:30 +09:00
if (obj.length < 1) {
2019-11-08 22:52:54 +09:00
$('#src-acct-sel').html('<option value="tootsearch">Tootsearch</option>')
$('#add-acct-sel').html('<option value="noauth">' + lang.lang_login_noauth + '</option>')
2019-05-19 16:39:30 +09:00
} else {
2020-07-21 12:44:53 +09:00
Object.keys(obj).forEach(function (key) {
2019-11-08 22:52:54 +09:00
var acct = obj[key]
var list = key * 1 + 1
2019-05-19 16:39:30 +09:00
if (key == last) {
2019-11-08 22:52:54 +09:00
sel = 'selected'
mainb = '(' + lang.lang_manager_def + ')'
var domain = localStorage.getItem('domain_' + key)
var profimg = localStorage.getItem('prof_' + key)
var domain = localStorage.getItem('domain_' + key)
2019-05-19 16:39:30 +09:00
if (!profimg) {
2019-11-08 22:52:54 +09:00
profimg = '../../img/missing.svg'
2019-05-19 16:39:30 +09:00
}
} else {
2019-11-08 22:52:54 +09:00
sel = ''
mainb = ''
2018-05-20 15:17:10 +09:00
}
2019-11-08 22:52:54 +09:00
template = `
<option value="${key}" data-icon="${acct.prof}" class="left circle" ${sel}>
${acct.user}@${acct.domain}${mainb}
</option>
`
2019-11-09 00:15:03 +09:00
$('.acct-sel').append(template)
2019-11-08 22:52:54 +09:00
})
2018-05-20 15:17:10 +09:00
}
2019-11-08 22:52:54 +09:00
$('select').formSelect()
2018-05-20 15:17:10 +09:00
}
2019-05-19 16:39:30 +09:00
function mainacct() {
2019-11-08 22:52:54 +09:00
var acct_id = $('#main-acct-sel').val()
localStorage.setItem('main', acct_id)
M.toast({ html: lang.lang_manager_mainAcct, displayLength: 3000 })
2018-06-17 23:26:45 +09:00
}
2019-05-19 16:39:30 +09:00
function colorpicker(key) {
2019-11-08 22:52:54 +09:00
temp = `<div onclick="coloradd('${key}','def','def')" class="pointer exc">${lang.lang_manager_none}</div>
<div onclick="coloradd('${key}','f44336','white')" class="red white-text pointer"></div>
<div onclick="coloradd('${key}','e91e63','white')" class="pink white-text pointer"></div>
<div onclick="coloradd('${key}','9c27b0','white')" class="purple white-text pointer"></div>
<div onclick="coloradd('${key}','673ab7','white')" class="deep-purple white-text pointer"></div>
<div onclick="coloradd('${key}','3f51b5','white')" class="indigo white-text pointer"></div>
<div onclick="coloradd('${key}','2196f3','white')" class="blue white-text pointer"></div>
<div onclick="coloradd('${key}','03a9f4','black')" class="light-blue black-text pointer"></div>
<div onclick="coloradd('${key}','00bcd4','black')" class="cyan black-text pointer"></div>
<div onclick="coloradd('${key}','009688','white')" class="teal white-text pointer"></div>
<div onclick="coloradd('${key}','4caf50','black')" class="green black-text pointer"></div>
<div onclick="coloradd('${key}','8bc34a','black')" class="light-green black-text pointer"></div>
<div onclick="coloradd('${key}','cddc39','black')" class="lime black-text pointer"></div>
<div onclick="coloradd('${key}','ffeb3b','black')" class="yellow black-text pointer"></div>
<div onclick="coloradd('${key}','ffc107','black')" class="amber black-text pointer"></div>
<div onclick="coloradd('${key}','ff9800','black')" class="orange black-text pointer"></div>
<div onclick="coloradd('${key}','ff5722','white')" class="deep-orange white-text pointer"></div>
<div onclick="coloradd('${key}','795548','white')" class="brown white-text pointer"></div>
<div onclick="coloradd('${key}','9e9e9e','white')" class="grey white-text pointer"></div>
<div onclick="coloradd('${key}','607d8b','white')" class="blue-grey white-text pointer"></div>
<div onclick="coloradd('${key}','000000','white')" class="black white-text pointer"></div>
<div onclick="coloradd('${key}','ffffff','black')" class="white black-text pointer"></div>`
$('#colorsel_' + key).html(temp)
2018-06-17 23:26:45 +09:00
}
2019-05-19 16:39:30 +09:00
function coloradd(key, bg, txt) {
2019-11-08 22:52:54 +09:00
var col = localStorage.getItem('multi')
var o = JSON.parse(col)
var obj = o[key]
obj.background = bg
obj.text = txt
o[key] = obj
var json = JSON.stringify(o)
localStorage.setItem('multi', json)
if (txt == 'def') {
$('#acct_' + key).attr('style', '')
2019-05-19 16:39:30 +09:00
} else {
2019-11-08 22:52:54 +09:00
$('#acct_' + key).css('background-color', '#' + bg)
if (txt == 'black') {
var bghex = '000000'
var ichex = '9e9e9e'
} else if (txt == 'white') {
var bghex = 'ffffff'
var ichex = 'eeeeee'
2019-05-19 16:39:30 +09:00
}
2019-11-08 22:52:54 +09:00
$('#acct_' + key + ' .nex').css('color', '#' + ichex)
$('#acct_' + key).css('color', '#' + bghex)
2018-06-17 23:26:45 +09:00
}
}
//入力時にハッシュタグと@をサジェスト
2019-11-08 22:52:54 +09:00
var timer = null
2018-06-17 23:26:45 +09:00
2019-11-08 22:52:54 +09:00
var input = document.getElementById('url')
2018-06-17 23:26:45 +09:00
2019-11-08 22:52:54 +09:00
var prev_val = input.value
var oldSuggest
var suggest
2019-10-22 14:34:23 +09:00
input.addEventListener(
2019-11-08 22:52:54 +09:00
'focus',
2020-07-21 12:44:53 +09:00
function () {
2019-11-08 22:52:54 +09:00
$('#ins-suggest').html('')
window.clearInterval(timer)
2020-07-21 12:44:53 +09:00
timer = window.setInterval(function () {
2019-11-08 22:52:54 +09:00
var new_val = input.value
2019-10-22 14:34:23 +09:00
if (prev_val != new_val) {
if (new_val.length > 3) {
2019-11-08 22:52:54 +09:00
var start = 'https://instances.social/api/1.0/instances/search?q=' + new_val
2019-10-22 14:34:23 +09:00
fetch(start, {
2019-11-08 22:52:54 +09:00
method: 'GET',
2019-10-22 14:34:23 +09:00
headers: {
2019-11-08 22:52:54 +09:00
'content-type': 'application/json',
Authorization:
'Bearer tC8F6xWGWBUwGScyNevYlx62iO6fdQ4oIK0ad68Oo7ZKB8GQdGpjW9TKxBnIh8grAhvd5rw3iyP9JPamoDpeLQdz62EToPJUW99hDx8rfuJfGdjQuimZPTbIOx0woA5M'
2019-10-22 14:34:23 +09:00
}
})
2020-07-21 12:44:53 +09:00
.then(function (response) {
2019-10-31 00:30:26 +09:00
if (!response.ok) {
2020-07-21 12:44:53 +09:00
response.text().then(function (text) {
2019-11-08 22:52:54 +09:00
setLog(response.url, response.status, text)
})
2019-11-04 01:10:06 +09:00
}
2019-11-08 22:52:54 +09:00
return response.json()
2019-10-22 14:34:23 +09:00
})
2020-07-21 12:44:53 +09:00
.catch(function (error) {
2019-11-08 22:52:54 +09:00
todo(error)
setLog(start, 'JSON', error)
console.error(error)
2019-10-22 14:34:23 +09:00
})
2020-07-21 12:44:53 +09:00
.then(function (json) {
2019-10-22 14:34:23 +09:00
if (!json.error) {
2019-11-08 22:52:54 +09:00
var urls = 'Suggest:'
2020-07-21 12:44:53 +09:00
Object.keys(json.instances).forEach(function (key) {
2019-11-08 22:52:54 +09:00
var url = json.instances[key]
urls =
urls +
` <a onclick="login('${url.name}')" class="pointer">${escapeHTML(url.name)}</a>`
})
$('#ins-suggest').html(urls)
2019-10-22 14:34:23 +09:00
} else {
2019-11-08 22:52:54 +09:00
console.error(json.error)
2019-10-22 14:34:23 +09:00
}
2019-11-08 22:52:54 +09:00
})
2019-10-22 14:34:23 +09:00
}
2019-11-08 22:52:54 +09:00
oldSuggest = suggest
prev_value = new_val
2018-06-17 23:26:45 +09:00
}
2019-11-08 22:52:54 +09:00
}, 1000)
2019-10-22 14:34:23 +09:00
},
false
2019-11-08 22:52:54 +09:00
)
2018-06-17 23:26:45 +09:00
2019-10-22 14:34:23 +09:00
input.addEventListener(
2019-11-08 22:52:54 +09:00
'blur',
2020-07-21 12:44:53 +09:00
function () {
2019-11-08 22:52:54 +09:00
window.clearInterval(timer)
2019-10-22 14:34:23 +09:00
},
false
2019-11-08 22:52:54 +09:00
)
2019-10-05 01:57:53 +09:00
//acctで未読マーカーは要らない
function asReadEnd() {
2019-11-08 22:52:54 +09:00
postMessage(['asReadComp', ''], '*')
2019-10-22 14:34:23 +09:00
}