thedesk/app/js/login/manager.js

1153 lines
32 KiB
JavaScript
Raw Normal View History

2018-01-28 21:22:43 +09:00
//アカウントマネージャ
//最初に読むやつ
function load() {
2019-11-08 22:52:54 +09:00
$('#acct-list').html('')
2019-05-19 16:39:30 +09:00
if (location.search) {
2019-11-08 22:52:54 +09:00
var m = location.search.match(/\?mode=([a-zA-Z-0-9]+)\&code=(.+)/)
var mode = m[1]
var codex = m[2]
if (mode == 'first' && codex == 'true') {
$('body').addClass('first')
2019-05-19 16:39:30 +09:00
} else {
2019-04-11 01:52:01 +09:00
}
}
2019-11-08 22:52:54 +09:00
var prof = localStorage.getItem('prof')
$('.my-prof').attr('src', prof)
var name = localStorage.getItem('name')
$('#now-name').text(name)
var user = localStorage.getItem('user')
$('#now-user').text(user)
var domain = localStorage.getItem('domain')
$('.now-domain').text(domain)
var multi = localStorage.getItem('multi')
2018-01-28 21:22:43 +09:00
if (!multi) {
2019-11-08 22:52:54 +09:00
var obj = []
2018-01-28 21:22:43 +09:00
} else {
2019-11-08 22:52:54 +09:00
var obj = JSON.parse(multi)
2018-01-28 21:22:43 +09:00
}
2019-05-19 16:39:30 +09:00
if (obj[0]) {
if (!obj[0].at) {
2019-11-08 22:52:54 +09:00
obj = []
localStorage.removeItem('multi')
2018-08-17 02:21:40 +09:00
}
}
2019-05-19 16:39:30 +09:00
2019-11-08 22:52:54 +09:00
console.table(obj)
var domains = []
2019-11-08 22:52:54 +09:00
var templete
$('#acct-list').html('')
2021-01-19 04:06:13 +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
if (acct.background != 'def' && acct.text != 'def') {
var style = 'style="background-color:#' + acct.background + '; color:' + acct.text + ';"'
2019-05-19 16:39:30 +09:00
} else {
2019-11-08 22:52:54 +09:00
var style = ''
2018-06-17 23:26:45 +09:00
}
2019-05-19 16:39:30 +09:00
if (acct.name) {
2019-11-08 22:52:54 +09:00
var name = acct.name
2019-05-19 16:39:30 +09:00
} else {
2019-11-08 22:52:54 +09:00
var name = acct.user
2018-08-23 02:29:39 +09:00
}
domains.push(acct.domain)
2019-11-08 22:52:54 +09:00
templete = `
<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}
2021-01-19 04:06:13 +09:00
<a onclick="login('${acct.domain}')" class="pointer white-text waves-effect" title="${lang.lang_manager_refreshAt}">
<i class="material-icons text-line-icon">login</i>
</a>
2019-11-08 22:52:54 +09:00
</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>
`
$('#acct-list').append(templete)
colorpicker(key)
})
domains = _.uniq(domains)
$('#domain-list').html('')
2021-01-19 04:06:13 +09:00
Object.keys(domains).forEach(function (key2) {
var domain = domains[key2]
if (localStorage.getItem('letters_' + key2)) {
var maxChars = localStorage.getItem('letters_' + key2)
} else {
var maxChars = 500
}
var templete = `
<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>
`
$('#domain-list').append(templete)
})
2019-11-08 22:52:54 +09:00
multisel()
var 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)
var acctN = 0
2018-01-28 21:22:43 +09:00
}
2019-04-08 00:14:06 +09:00
//全部チェックアリでいいと思うの
2019-11-08 22:52:54 +09:00
$('#linux').prop('checked', true)
2018-01-28 21:22:43 +09:00
}
//最初に読む
2019-11-08 22:52:54 +09:00
load()
support()
function maxChars(domain, uid) {
var value = $('#maxChars' + uid).val()
2021-01-19 04:06:13 +09:00
if (value * 1 < 1 || !Number.isInteger(value * 1)) {
Swal.fire({
type: 'error',
title: 'Error'
})
return false
}
var multi = localStorage.getItem('multi')
if (!multi) {
var obj = []
} else {
var obj = JSON.parse(multi)
}
if (obj[0]) {
if (!obj[0].at) {
obj = []
localStorage.removeItem('multi')
}
}
2021-01-19 04:06:13 +09:00
Object.keys(obj).forEach(function (key) {
if (obj[key].domain == domain) localStorage.setItem('letters_' + key, value)
})
console.log('#maxChars' + uid, value)
load()
}
//instances.social/instances API
async function data(domain, acct_id) {
2019-11-08 22:52:54 +09:00
$('#ins-upd').text('Loading...')
$('#ins-add').text('Loading...')
$('#ins-connect').text('Loading...')
$('#ins-toot').text('Loading...')
$('#ins-sys').text('Loading...')
$('#ins-per').text('Loading...')
$('#ins-user').text('Loading...')
$('#ins-ver').text('Loading...')
$('#ins-name').text('Loading...')
$('#ins-prof').attr('src', '../../img/loading.svg')
var start = 'https://instances.social/api/1.0/instances/show?name=' + domain
let promise = await fetch(start, {
2019-11-08 22:52:54 +09:00
method: 'GET',
2018-01-28 21:22:43 +09:00
headers: {
2019-11-08 22:52:54 +09:00
'content-type': 'application/json',
Authorization:
'Bearer tC8F6xWGWBUwGScyNevYlx62iO6fdQ4oIK0ad68Oo7ZKB8GQdGpjW9TKxBnIh8grAhvd5rw3iyP9JPamoDpeLQdz62EToPJUW99hDx8rfuJfGdjQuimZPTbIOx0woA5M'
2018-01-28 21:22:43 +09:00
}
2019-10-22 14:34:23 +09:00
})
var json = await promise.json()
$('#ins-name').text(json.name)
$('#ins-upd').text(date(json.checked_at, 'full'))
$('#ins-add').text(date(json.added_at, 'full'))
$('#ins-connect').text(json.connections)
$('#ins-toot').text(json.statuses)
$('#ins-sys').text(date(json.updated_at, 'full'))
$('#ins-per').text(json.uptime * 100)
$('#ins-user').text(json.users)
$('#ins-ver').text(json.version)
2019-11-08 22:52:54 +09:00
var start = 'https://' + domain + '/api/v1/instance'
let promise2 = await fetch(start, {
2019-11-08 22:52:54 +09:00
method: 'GET',
headers: {
2019-11-08 22:52:54 +09:00
'content-type': 'application/json'
}
2019-10-22 14:34:23 +09:00
})
var json = await promise2.json()
$('#ins-title').text(json.title)
$('#ins-desc').html(json.description)
$('#ins-email').text(json.email)
$('#ins-toot').text(json.stats.status_count)
$('#ins-user').text(json.stats.user_count)
$('#ins-ver').text(json.version)
$('#ins-prof').attr('src', json.thumbnail)
$('#ins-admin').text(
escapeHTML(json.contact_account.display_name) + '(' + json.contact_account.acct + ')'
)
$('#ins-admin').attr(
'href',
'index.html?mode=user&code=' + json.contact_account.username + '@' + domain
)
if (json['max_toot_chars']) {
localStorage.setItem('letters_' + acct_id, json['max_toot_chars'])
load()
}
2018-01-28 21:22:43 +09:00
}
//アカウントデータ 消す
function multiDel(target) {
2019-11-08 22:52:54 +09:00
var multi = localStorage.getItem('multi')
var obj = JSON.parse(multi)
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,
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) {
2021-01-19 04:06:13 +09:00
Object.keys(obj).forEach(function (key) {
2019-11-08 22:52:54 +09:00
var nk = key - 1
2019-06-22 01:06:32 +09:00
//公開範囲(差分のみ)
if (key >= target) {
2019-11-08 22:52:54 +09:00
var oldvis = localStorage.getItem('vis-memory-' + key)
2019-06-22 01:06:32 +09:00
if (oldvis) {
2019-11-08 22:52:54 +09:00
localStorage.setItem('vis-memory-' + nk, oldvis)
2019-06-22 01:06:32 +09:00
}
}
//独自ロケール
2019-11-08 22:52:54 +09:00
localStorage.removeItem('home_' + key)
localStorage.removeItem('local_' + key)
localStorage.removeItem('public_' + key)
localStorage.removeItem('notification_' + key)
2019-06-22 01:06:32 +09:00
//アクセストークンとドメイン、プロフ(差分)
if (key > target) {
2019-11-08 22:52:54 +09:00
var olddom = localStorage.getItem('domain_' + key)
localStorage.setItem('domain_' + nk, olddom)
var oldat = localStorage.getItem('acct_' + key + '_at')
2021-01-19 04:06:13 +09:00
var oldrt = localStorage.getItem('acct_' + key + '_rt')
2019-11-08 22:52:54 +09:00
localStorage.setItem('acct_' + nk + '_at', oldat)
2021-01-19 04:06:13 +09:00
localStorage.setItem('acct_' + nk + '_rt', oldrt)
2019-11-08 22:52:54 +09:00
localStorage.setItem('name_' + nk, localStorage.getItem('name_' + key))
localStorage.setItem('user_' + target, localStorage.getItem('user_' + key))
localStorage.setItem('user-id_' + target, localStorage.getItem('user-id_' + key))
localStorage.setItem('prof_' + target, localStorage.getItem('prof_' + key))
2018-07-07 02:51:48 +09:00
}
2019-11-08 22:52:54 +09:00
})
2019-06-22 01:06:32 +09:00
//とりあえず消す
2019-11-08 22:52:54 +09:00
obj.splice(target, 1)
var json = JSON.stringify(obj)
localStorage.setItem('multi', json)
load()
2019-06-22 01:06:32 +09:00
//カラムデータコンフリクト
2019-11-08 22:52:54 +09:00
var col = localStorage.getItem('column')
var oldcols = JSON.parse(col)
var newcols = []
2021-01-19 04:06:13 +09:00
Object.keys(oldcols).forEach(function (key) {
2019-11-08 22:52:54 +09:00
var nk = key - 1
var oldcol = oldcols[key]
2019-06-22 01:06:32 +09:00
if (target < oldcol.domain) {
2019-11-08 22:52:54 +09:00
var newdom = oldcol.domain - 1
2019-06-22 01:06:32 +09:00
} else {
2019-11-08 22:52:54 +09:00
var newdom = oldcol.domain
2019-06-22 01:06:32 +09:00
}
2019-11-08 22:52:54 +09:00
var type = oldcol.type
2020-06-10 12:09:17 +09:00
var data = null
2021-01-19 04:06:13 +09:00
if (oldcol.data) {
2020-06-10 12:09:17 +09:00
data = oldcol.data
}
var background = null
2021-01-19 04:06:13 +09:00
if (oldcol.background) {
2020-06-10 12:09:17 +09:00
background = oldcol.background
}
var text = null
2021-01-19 04:06:13 +09:00
if (oldcol.text) {
2020-06-10 12:09:17 +09:00
text = oldcol.text
}
var left_fold = false
2021-01-19 04:06:13 +09:00
if (oldcol.left_fold) {
2020-06-10 12:09:17 +09:00
left_fold = true
}
2019-06-22 01:06:32 +09:00
//消した垢のコラムじゃないときコピー
if (target != oldcol.domain) {
var add = {
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
}
2019-11-08 22:52:54 +09:00
})
var json = JSON.stringify(newcols)
localStorage.setItem('column', json)
2019-06-22 01:06:32 +09:00
}
2019-11-08 22:52:54 +09:00
})
2018-07-07 02:51:48 +09:00
}
function multiDel2(target) {
2019-11-08 22:52:54 +09:00
var multi = localStorage.getItem('multi')
var obj = JSON.parse(multi)
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,
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) {
2019-11-08 22:52:54 +09:00
obj.splice(target, 1)
var json = JSON.stringify(obj)
localStorage.setItem('multi', json)
2021-01-19 04:06:13 +09:00
Object.keys(obj).forEach(function (key) {
2019-06-22 01:06:32 +09:00
if (key >= target) {
2019-11-08 22:52:54 +09:00
var oldvis = localStorage.getItem('vis-memory-' + key)
2019-06-22 01:06:32 +09:00
if (oldvis) {
2019-11-08 22:52:54 +09:00
var nk = key - 1
localStorage.setItem('vis-memory-' + nk, oldvis)
2019-06-22 01:06:32 +09:00
}
2019-05-19 16:39:30 +09:00
}
2019-11-08 22:52:54 +09:00
localStorage.removeItem('home_' + key)
localStorage.removeItem('local_' + key)
localStorage.removeItem('public_' + key)
localStorage.removeItem('notification_' + key)
refresh(key)
})
var col = localStorage.getItem('column')
2019-06-22 01:06:32 +09:00
if (!col) {
2019-10-22 14:34:23 +09:00
var obj = [
{
domain: 0,
2019-11-08 22:52:54 +09:00
type: 'local'
2019-10-22 14:34:23 +09:00
}
2019-11-08 22:52:54 +09:00
]
localStorage.setItem('card_0', 'true')
var json = JSON.stringify(obj)
localStorage.setItem('column', json)
2019-06-22 01:06:32 +09:00
} else {
2019-11-08 22:52:54 +09:00
var cobj = JSON.parse(col)
2018-07-07 02:51:48 +09:00
}
2021-01-19 04:06:13 +09:00
Object.keys(cobj).forEach(function (key) {
2019-11-08 22:52:54 +09:00
var column = cobj[key]
2019-06-22 01:06:32 +09:00
if (column.domain > target) {
2019-11-08 22:52:54 +09:00
var nk = key - 1
column.domain = nk
cobj[key] = column
2019-06-22 01:06:32 +09:00
} else if (column.domain == target) {
2019-11-08 22:52:54 +09:00
localStorage.removeItem('card_' + tlid)
cobj.splice(key, 1)
2019-06-22 01:06:32 +09:00
}
2019-11-08 22:52:54 +09:00
})
var json = JSON.stringify(column)
localStorage.setItem('column', json)
load()
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() {
2021-01-19 04:06:13 +09:00
Object.keys(idata).forEach(function (key) {
2019-11-08 22:52:54 +09:00
var instance = idata[key]
if (instance == 'instance') {
templete =
'<a onclick="login(\'' +
key +
'\')" class="collection-item pointer transparent">' +
idata[key + '_name'] +
'(' +
key +
')</a>'
$('#support').append(templete)
2019-05-19 16:39:30 +09:00
}
2019-11-08 22:52:54 +09:00
})
2018-01-28 21:22:43 +09:00
}
function backToInit() {
$('#auth').hide()
$('#add').show()
}
2018-01-28 21:22:43 +09:00
//URL指定してポップアップ
async function login(url) {
2019-11-08 22:52:54 +09:00
var multi = localStorage.getItem('multi')
var obj = JSON.parse(multi)
if ($('#misskey:checked').val() == 'on') {
$('#misskey').prop('checked', true)
misskeyLogin(url)
return
2018-07-28 06:25:12 +09:00
}
2019-11-08 22:52:54 +09:00
$('#compt').hide()
const start = `https://${url}/api/v1/apps`
$('#loginBtn').attr('disabled', true)
const nextSetup = await versionChecker(url)
$('#loginBtn').attr('disabled', false)
let red = 'thedesk://manager'
if (!nextSetup) {
red = 'urn:ietf:wg:oauth:2.0:oob'
2019-11-08 22:52:54 +09:00
if (~url.indexOf('pixelfed')) {
red = 'https://thedesk.top/hello.html'
2019-10-14 00:28:44 +09:00
}
2018-02-26 00:32:10 +09:00
}
2019-11-08 22:52:54 +09:00
localStorage.setItem('redirect', red)
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({
2019-11-08 22:52:54 +09:00
scopes: 'read write follow',
client_name: 'TheDesk(PC)',
2019-10-22 14:34:23 +09:00
redirect_uris: red,
2019-11-08 22:52:54 +09:00
website: 'https://thedesk.top'
2019-10-22 14:34:23 +09:00
})
2019-11-08 22:52:54 +09:00
)
2021-01-19 04:06:13 +09:00
httpreq.onreadystatechange = function () {
2019-03-08 03:19:26 +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
localStorage.setItem('msky', 'false')
var 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'])
$('#auth').show()
$('#add').hide()
postMessage(['openUrl', auth], '*')
2018-04-17 02:10:35 +09:00
}
2019-11-08 22:52:54 +09:00
}
2019-09-30 02:22:44 +09:00
}
async function versionChecker(url) {
const start = `https://${url}/api/v1/instance`
try {
const response = await fetch(start, {
method: 'GET',
headers: {
'content-type': 'application/json'
2019-11-04 01:10:06 +09:00
}
2019-10-22 14:34:23 +09:00
})
if (!response.ok) {
response.text().then(function (text) {
setLog(response.url, response.status, text)
})
}
const json = await response.json()
const version = json.version
if (version) {
const reg = version.match(/^([0-9])\.[0-9]\.[0-9]/u)
if (reg) versionCompat(json.title, version)
if (version.match('compatible')) {
$('#compt-warn').show()
return false
} else {
$('#compt-warn').hide()
if (pwa) return true
const codeSetupCheck = await Swal.fire({
title: lang.lang_manager_codesetup_title,
text: lang.lang_manager_codesetup,
icon: 'info',
showCancelButton: true
})
if (!codeSetupCheck.isConfirmed) return false
return true
2019-10-22 14:34:23 +09:00
}
}
} catch {
return false
}
2019-09-30 02:22:44 +09:00
}
async function versionCompat(title, version) {
const [sem, a, b, c] = version.match(/^([0-9]+)\.([0-9]+)\.([0-9]+)/)
2019-11-08 22:52:54 +09:00
$('#compt-instance').text(title)
$('#compt-ver').text(version)
2019-11-08 22:52:54 +09:00
$('#compt-list').html('')
var start = '../../source/version.json'
const response = await fetch(start)
const json = await response.json()
const keys = Object.keys(json)
let i = 0
let onceAdd = false
for (const targetVersion of keys) {
const data = json[targetVersion]
const [tsem, ta, tb, tc] = targetVersion.match(/^([0-9]+)\.([0-9]+)\.([0-9]+)/)
let add = false
if (ta === a) {
if (tb === b) {
if (tc > c) {
add = true
2019-09-30 02:22:44 +09:00
}
} else if (tb > b) {
add = true
2019-09-30 02:22:44 +09:00
}
} else if (ta > a) {
add = true
}
if (!add) break
if (add) onceAdd = true
for (const note of data) {
$('#compt-list').append(`<li>${note}(${targetVersion})</li>`)
}
i++
}
if (lang.language == 'ja' && onceAdd) {
$('#compt').show()
}
2018-07-28 06:25:12 +09:00
}
//これが後のMisskeyである。
2018-08-21 03:26:14 +09:00
function misskeyLogin(url) {
2019-05-19 16:39:30 +09:00
if (!url) {
2019-11-08 22:52:54 +09:00
var url = $('#misskey-url').val()
2018-08-21 03:26:14 +09:00
}
2020-04-08 15:27:47 +09:00
var start = 'https://' + url + '/api/app/create'
2019-11-08 22:52:54 +09:00
var httpreq = new XMLHttpRequest()
httpreq.open('POST', start, true)
httpreq.setRequestHeader('Content-Type', 'application/json')
httpreq.responseType = 'json'
localStorage.setItem('msky', 'true')
2019-10-22 14:34:23 +09:00
httpreq.send(
JSON.stringify({
2019-11-08 22:52:54 +09:00
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'
]
2019-10-22 14:34:23 +09:00
})
2019-11-08 22:52:54 +09:00
)
2021-01-19 04:06:13 +09:00
httpreq.onreadystatechange = function () {
2019-03-08 17:14:47 +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
misskeyAuth(url, json.secret)
2018-08-21 03:26:14 +09:00
}
2019-11-08 22:52:54 +09:00
}
2019-03-08 17:14:47 +09:00
}
2019-05-19 16:39:30 +09:00
function misskeyAuth(url, mkc) {
2019-11-08 22:52:54 +09:00
var start = 'https://' + url + '/api/auth/session/generate'
var httpreq = new XMLHttpRequest()
httpreq.open('POST', start, true)
httpreq.setRequestHeader('Content-Type', 'application/json')
httpreq.responseType = 'json'
2019-03-08 17:14:47 +09:00
2019-11-08 22:52:54 +09:00
localStorage.setItem('mkc', mkc)
localStorage.setItem('msky', 'true')
2019-10-22 14:34:23 +09:00
httpreq.send(
JSON.stringify({
appSecret: mkc
})
2019-11-08 22:52:54 +09:00
)
2021-01-19 04:06:13 +09:00
httpreq.onreadystatechange = function () {
2019-03-08 03:19:26 +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 token = json.token
$('#auth').show()
$('#code').val(token)
$('#add').hide()
$('#misskey').prop('checked', false)
localStorage.setItem('domain_tmp', url)
postMessage(['openUrl', json.url], '*')
2018-07-28 06:25:12 +09:00
}
2019-11-08 22:52:54 +09:00
}
2018-01-28 21:22:43 +09:00
}
//テキストボックスにURL入れた
function instance() {
2021-04-18 04:23:45 +09:00
var url = $('#autocomplete-input').val()
2019-11-08 22:52:54 +09:00
if (url.indexOf('@') != -1 || url.indexOf('https') != -1) {
alert('入力形式が違います。(Cutls@mstdn.jpにログインする場合、入力するのは"mstdn.jp"です。)')
return false
2018-08-21 03:26:14 +09:00
}
2021-04-18 04:23:45 +09:00
login(url)
2018-01-28 21:22:43 +09:00
}
//コード入れてAccessTokenゲット
2018-02-18 14:43:11 +09:00
function code(code) {
2021-04-18 04:23:45 +09:00
var red = localStorage.getItem('redirect')
2019-11-08 22:52:54 +09:00
localStorage.removeItem('redirect')
2019-05-19 16:39:30 +09:00
if (!code) {
2019-11-08 22:52:54 +09:00
var code = $('#code').val()
$('#code').val('')
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
}
2019-11-08 22:52:54 +09:00
var url = localStorage.getItem('domain_tmp')
localStorage.removeItem('domain_tmp')
if (localStorage.getItem('msky') == 'true') {
var start = 'https://' + url + '/api/auth/session/userkey'
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({
token: code,
2019-11-08 22:52:54 +09:00
appSecret: localStorage.getItem('mkc')
2019-10-22 14:34:23 +09:00
})
2019-11-08 22:52:54 +09:00
)
2021-01-19 04:06:13 +09:00
httpreq.onreadystatechange = function () {
2019-03-08 03:19:26 +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 i = sha256(json.accessToken + localStorage.getItem('mkc'))
var avatar = json['user']['avatarUrl']
var priv = 'public'
2018-07-30 20:03:49 +09:00
var add = {
at: i,
2019-11-08 22:52:54 +09:00
name: json['user']['name'],
2018-08-21 03:26:14 +09:00
domain: url,
2019-11-08 22:52:54 +09:00
user: json['user']['username'],
2018-07-30 20:03:49 +09:00
prof: avatar,
2019-11-08 22:52:54 +09:00
id: json['user']['id'],
2018-08-21 03:26:14 +09:00
vis: priv,
2019-11-08 22:52:54 +09:00
mode: 'misskey'
2019-04-11 01:52:01 +09:00
}
2019-11-08 22:52:54 +09:00
localStorage.setItem('mode_' + url, 'misskey')
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)
if ($('body').hasClass('first')) {
location.href = 'index.html'
}
load()
return
2018-07-30 20:03:49 +09:00
}
2019-11-08 22:52:54 +09:00
}
return
2019-05-19 16:39:30 +09:00
} else {
2021-04-18 04:23:45 +09:00
if (!red) red = 'urn:ietf:wg:oauth:2.0:oob'
2019-11-08 22:52:54 +09:00
if (~url.indexOf('pixelfed')) {
red = 'https://thedesk.top/hello.html'
2019-10-14 00:28:44 +09:00
}
2019-11-08 22:52:54 +09:00
var start = 'https://' + url + '/oauth/token'
var id = localStorage.getItem('client_id')
var secret = localStorage.getItem('client_secret')
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({
2019-11-08 22:52:54 +09:00
grant_type: 'authorization_code',
2019-10-22 14:34:23 +09:00
redirect_uri: red,
client_id: id,
client_secret: secret,
code: code
})
2019-11-08 22:52:54 +09:00
)
2021-01-19 04:06:13 +09:00
httpreq.onreadystatechange = function () {
2019-03-08 03:19:26 +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) {
2021-04-18 04:23:45 +09:00
M.toast({ html: lang.lang_fatalerroroccured + 'Error: cannot complete', displayLength: 5000 })
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
if (json['access_token']) {
$('#auth').hide()
$('#add').show()
2021-01-19 04:06:13 +09:00
getdata(url, json)
2018-08-17 02:21:40 +09:00
}
2018-04-17 02:10:35 +09:00
}
2019-11-08 22:52:54 +09:00
}
2018-04-17 02:10:35 +09:00
}
2018-01-28 21:22:43 +09:00
}
//ユーザーデータ取得
2021-01-19 04:06:13 +09:00
function getdata(domain, json) {
var at = json['access_token']
var rt = `${json['refresh_token']} ${localStorage.getItem('client_id')} ${localStorage.getItem('client_secret')}`
2019-11-08 22:52:54 +09:00
var start = 'https://' + domain + '/api/v1/accounts/verify_credentials'
2018-01-28 21:22:43 +09:00
fetch(start, {
2019-11-08 22:52:54 +09:00
method: 'GET',
2018-01-28 21:22:43 +09:00
headers: {
2019-11-08 22:52:54 +09:00
'content-type': 'application/json',
Authorization: 'Bearer ' + at
2018-07-07 02:51:48 +09:00
}
2019-10-22 14:34:23 +09:00
})
2021-01-19 04:06:13 +09:00
.then(function (response) {
2019-10-31 00:30:26 +09:00
if (!response.ok) {
2021-01-19 04:06:13 +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
})
2021-01-19 04:06:13 +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
})
2021-01-19 04:06:13 +09:00
.then(function (json) {
2019-10-22 14:34:23 +09:00
if (json.error) {
2019-11-08 22:52:54 +09:00
console.error('Error:' + json.error)
M.toast({ html: lang.lang_fatalerroroccured + 'Error:' + json.error, displayLength: 5000 })
return
2019-10-22 14:34:23 +09:00
}
2019-11-08 22:52:54 +09:00
var avatar = json['avatar']
2019-10-22 14:34:23 +09:00
//missingがmissingなやつ
2019-11-08 22:52:54 +09:00
if (avatar == '/avatars/original/missing.png') {
avatar = '../../img/missing.svg'
2019-10-22 14:34:23 +09:00
}
2019-11-08 22:52:54 +09:00
if (json['source']) {
var priv = json['source']['privacy']
2019-10-22 14:34:23 +09:00
} else {
2019-11-08 22:52:54 +09:00
var priv = 'public'
2019-10-22 14:34:23 +09:00
}
var add = {
at: at,
2021-01-19 04:06:13 +09:00
rt: rt ? rt : null,
2019-11-08 22:52:54 +09:00
name: json['display_name'],
2019-10-22 14:34:23 +09:00
domain: domain,
2019-11-08 22:52:54 +09:00
user: json['acct'],
2019-10-22 14:34:23 +09:00
prof: avatar,
2019-11-08 22:52:54 +09:00
id: json['id'],
2019-10-22 14:34:23 +09:00
vis: priv,
2019-11-08 22:52:54 +09:00
mode: 'mastodon'
}
var multi = localStorage.getItem('multi')
var obj = JSON.parse(multi)
2021-01-19 04:06:13 +09:00
let addTarget = -1
let ct = 0
for (let acct of obj) {
if (acct.domain === domain && acct.user === json['acct']) {
console.log('detected dupl addct')
addTarget = ct
break
}
ct++
}
if (addTarget == -1) {
var target = obj.length
obj.push(add)
} else {
console.log('dupl acct_' + addTarget)
obj[addTarget] = add
var target = addTarget
}
2019-11-08 22:52:54 +09:00
localStorage.setItem('name_' + target, json['display_name'])
localStorage.setItem('user_' + target, json['acct'])
localStorage.setItem('user-id_' + target, json['id'])
localStorage.setItem('prof_' + target, avatar)
var json = JSON.stringify(obj)
localStorage.setItem('multi', json)
if ($('body').hasClass('first')) {
location.href = 'index.html'
2019-10-22 14:34:23 +09:00
}
2019-11-08 22:52:54 +09:00
load()
})
2019-10-22 14:34:23 +09:00
}
//アクセストークン直接入力
function atSetup(type) {
2019-11-08 22:52:54 +09:00
var url = localStorage.getItem('domain_tmp')
localStorage.removeItem('domain_tmp')
var multi = localStorage.getItem('multi')
var avatar = '../../img/missing.svg'
var priv = 'public'
if (type == 'misskey') {
var i = $('#misskey-key').val()
2018-01-28 21:22:43 +09:00
var add = {
2019-10-22 14:34:23 +09:00
at: i,
2021-01-19 04:06:13 +09:00
rt: null,
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'
}
localStorage.setItem('mode_' + url, 'misskey')
2019-10-22 14:34:23 +09:00
} else {
2019-11-08 22:52:54 +09:00
var i = $('#code').val()
2019-10-22 14:34:23 +09:00
var add = {
at: i,
2021-01-19 04:06:13 +09:00
rt: null,
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,
2019-11-08 22:52:54 +09:00
mode: ''
}
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
}
2019-11-08 22:52:54 +09:00
var obj = JSON.parse(multi)
var target = obj.length
obj.push(add)
localStorage.setItem('name_' + target, add['name'])
localStorage.setItem('user_' + target, add['username'])
localStorage.setItem('user-id_' + target, add['id'])
localStorage.setItem('prof_' + target, avatar)
var json = JSON.stringify(obj)
localStorage.setItem('multi', json)
refresh(target)
2018-01-28 21:22:43 +09:00
}
//ユーザーデータ更新
function refresh(target) {
2019-11-08 22:52:54 +09:00
var multi = localStorage.getItem('multi')
var obj = JSON.parse(multi)
console.log(obj)
if (obj[target].mode == 'misskey') {
misskeyRefresh(obj, target, obj[target].domain)
return
2018-07-30 20:03:49 +09:00
}
2019-11-08 22:52:54 +09:00
var start = 'https://' + obj[target].domain + '/api/v1/accounts/verify_credentials'
2018-01-28 21:22:43 +09:00
fetch(start, {
2019-11-08 22:52:54 +09:00
method: 'GET',
2018-01-28 21:22:43 +09:00
headers: {
2019-11-08 22:52:54 +09:00
'content-type': 'application/json',
Authorization: 'Bearer ' + obj[target].at
2019-10-05 03:51:05 +09:00
}
2019-10-22 14:34:23 +09:00
})
2021-01-19 04:06:13 +09:00
.then(function (response) {
2019-10-31 00:30:26 +09:00
if (!response.ok) {
2021-01-19 04:06:13 +09:00
response.text().then(function (text) {
2019-11-08 22:52:54 +09:00
setLog(response.url, response.status, text)
})
2019-10-31 00:30:26 +09:00
}
if (!response.ok) {
2021-01-19 04:06:13 +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
})
2021-01-19 04:06:13 +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
})
2021-01-19 04:06:13 +09:00
.then(function (json) {
2019-10-22 14:34:23 +09:00
if (json.error) {
2019-11-08 22:52:54 +09:00
console.error('Error:' + json.error)
M.toast({ html: lang.lang_fatalerroroccured + 'Error:' + json.error, displayLength: 5000 })
return
2019-10-22 14:34:23 +09:00
}
2019-11-08 22:52:54 +09:00
var avatar = json['avatar']
2019-10-22 14:34:23 +09:00
//missingがmissingなやつ
2019-11-08 22:52:54 +09:00
if (avatar == '/avatars/original/missing.png' || !avatar) {
avatar = './img/missing.svg'
2019-10-22 14:34:23 +09:00
}
var ref = {
at: obj[target].at,
2021-01-19 04:06:13 +09:00
rt: obj[target].rt ? obj[target].rt : null,
2019-11-08 22:52:54 +09:00
name: json['display_name'],
2019-10-22 14:34:23 +09:00
domain: obj[target].domain,
2019-11-08 22:52:54 +09:00
user: json['acct'],
2019-10-22 14:34:23 +09:00
prof: avatar,
2019-11-08 22:52:54 +09:00
id: json['id'],
vis: json['source']['privacy']
}
if (obj[target].background) {
ref.background = obj[target].background
}
if (obj[target].text) {
ref.text = obj[target].text
}
2019-11-08 22:52:54 +09:00
localStorage.setItem('name_' + target, json['display_name'])
localStorage.setItem('user_' + target, json['acct'])
localStorage.setItem('user-id_' + target, json['id'])
localStorage.setItem('prof_' + target, avatar)
if (json['source']['sensitive']) {
localStorage.setItem('nsfw_' + target, 'true')
2019-10-22 14:34:23 +09:00
} else {
2019-11-08 22:52:54 +09:00
localStorage.removeItem('nsfw_' + target)
2019-10-22 14:34:23 +09:00
}
2019-11-08 22:52:54 +09:00
obj[target] = ref
var json = JSON.stringify(obj)
localStorage.setItem('multi', json)
2018-01-28 21:22:43 +09:00
2019-11-08 22:52:54 +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
)
2021-01-19 04:06:13 +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,
2021-01-19 04:06:13 +09:00
rt: null,
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 {
2021-01-19 04:06:13 +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
2021-04-18 04:23:45 +09:00
var input = document.getElementById('autocomplete-input')
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',
2021-01-19 04:06:13 +09:00
function () {
2021-04-18 04:23:45 +09:00
const instance = M.Autocomplete.getInstance(input)
2019-11-08 22:52:54 +09:00
window.clearInterval(timer)
2021-01-19 04:06:13 +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) {
2021-02-16 22:28:15 +09:00
var start = 'https://www.fediversesearch.com/search/?keyword=' + new_val
2021-02-16 23:27:52 +09:00
fetch(start, {
method: 'GET',
headers: {
'content-type': 'application/json',
2021-04-18 04:23:45 +09:00
}
2021-02-16 23:27:52 +09:00
})
2021-01-19 04:06:13 +09:00
.then(function (response) {
2019-10-31 00:30:26 +09:00
if (!response.ok) {
2021-01-19 04:06:13 +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
})
2021-01-19 04:06:13 +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
})
2021-01-19 04:06:13 +09:00
.then(function (json) {
2019-10-22 14:34:23 +09:00
if (!json.error) {
2021-04-18 04:23:45 +09:00
let data = {}
2021-02-14 11:21:29 +09:00
Object.keys(json.data).forEach(function (key) {
var url = json.data[key]
2021-04-18 04:23:45 +09:00
data[url.uri] = escapeHTML(url.title ? url.title : url.uri)
2019-11-08 22:52:54 +09:00
})
2021-04-18 04:23:45 +09:00
instance.updateData(data)
instance.open()
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
2021-04-18 04:23:45 +09:00
prev_val = 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',
2021-01-19 04:06:13 +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
}
2021-04-18 04:23:45 +09:00
// Or with jQuery
$(document).ready(function () {
$('input.autocomplete').autocomplete({
data: {},
});
});