// ==UserScript==
// @name NGA论坛自定义表情包
// @namespace https://github.com/biuuu
// @version 0.0.4
// @description 冲鸭
// @author 芭芭拉
// @match *://bbs.ngacn.cc/*.php*
// @match *://ngabbs.com/*.php*
// @match *://nga.178.com/*.php*
// @match *://bbs.nga.cn/*.php*
// @grant none
// @downloadURL https://update.greasyfork.icu/scripts/422369/NGA%E8%AE%BA%E5%9D%9B%E8%87%AA%E5%AE%9A%E4%B9%89%E8%A1%A8%E6%83%85%E5%8C%85.user.js
// @updateURL https://update.greasyfork.icu/scripts/422369/NGA%E8%AE%BA%E5%9D%9B%E8%87%AA%E5%AE%9A%E4%B9%89%E8%A1%A8%E6%83%85%E5%8C%85.meta.js
// ==/UserScript==
(async function() {
'use strict';
const addStyle = (css) => {
const style = document.createElement('style')
style.innerText = css
document.head.appendChild(style)
}
const loadScript = async () => {
const script = document.createElement('script')
script.src = 'https://cdn.jsdelivr.net/npm/lodash@4.17.21/lodash.min.js'
document.head.appendChild(script)
return new Promise((rev, rej) => {
script.onload = rev
script.onerror = rej
})
}
await loadScript()
const randomNum = Math.floor(Math.random() * 1e5)
addStyle(`
.single_ttip2 .div3 > div {
padding: 4px 4px 0 4px;
}
.single_ttip2 .div3 > div:empty {
display: inline-block;
padding: 0;
}
.sticker-${randomNum} img {
max-height: 70px;
cursor: pointer;
}
.sticker-${randomNum} {
margin: 0.2em;
width: 962px;
}
.single_ttip2 .block_txt_big {
padding: 0 0.5em;
cursor: pointer;
outline: 0;
margin-left: -0.2em;
margin-right: 0.6em;
}
.single_ttip2 .block_txt_big:hover {
filter: brightness(0.95);
}
.single_ttip2 .block_txt_big:active {
filter: brightness(0.9);
}
.sticker-toolbar-${randomNum} {
position: absolute;
right: 53px;
top: 0;
}
.sticker-import-${randomNum} {
opacity: 0;
position: absolute;
left: 0;
top: 0;
width: 100%;
height: 100%;
}
`)
let boxId = null
const sleep = function (time) {
return new Promise(rev => {
setTimeout(rev, time)
})
}
let stickerMap = new Map([
['原神', [
'./mon_202103/01/i2Q16r-9dvkK6T8S1o-1o.png',
'./mon_202103/01/i2Q16r-j3x7KaT8S1o-1o.png',
'./mon_202103/01/i2Q16r-708aK9T8S1o-1o.png',
'./mon_202103/01/i2Q16r-g3c4K7T8S1o-1o.png',
'./mon_202103/01/i2Q16r-3s4iK7T8S1o-1o.png',
'./mon_202103/01/i2Q16r-ctnwK8T8S1o-1o.png',
'./mon_202103/01/i2Q16r-nikK9T8S1o-1o.png',
'./mon_202103/01/i2Q16r-9ii9K7T8S1o-1o.png',
'./mon_202103/01/i2Q16r-ilggK8T8S1o-1o.png',
'./mon_202103/01/i2Q16r-5v44K9T8S1o-1o.png',
'./mon_202103/01/i2Q16r-enk2K6T8S1o-1o.png',
'./mon_202103/01/i2Q16r-2dfkK8T8S1o-1o.png',
'./mon_202103/01/i2Q16r-dmbuK7T8S1o-1o.png',
'./mon_202103/01/i2Q16r-12xiK7T8S1o-1o.png',
'./mon_202103/01/i2Q16r-9tq0K6T8S1o-1o.png',
'./mon_202103/01/i2Q16r-it1bK8T8S1o-1o.png'
]],
['GBF',[
'./mon_201903/16/fkQ5-i23xK9T8S3c-3c.png',
'./mon_201903/16/fkQ5-1xyeKbT8S3c-3c.png'
]],
['闪耀色彩', [
'./mon_202102/27/-77rdlQj09-9h6dKcT8S2x-2g.png',
'./mon_202102/27/-77rdlQj09-brf3KhT8S2s-2g.png',
'./mon_202102/27/-77rdlQj09-ki6tKhT8S2s-2g.png',
'./mon_202102/27/-77rdlQj09-77piKeT8S2i-2g.png',
'./mon_202102/27/-77rdlQj09-fpreKiToS2x-2g.png',
'./mon_202102/27/-77rdlQj09-3cqxKiToS2x-2g.png',
'./mon_202102/27/-77rdlQj09-d9fpKmToS2x-2g.png',
'./mon_202102/27/-77rdlQj09-19pdKhToS2x-2g.png',
'./mon_202102/27/-77rdlQj09-ac3aKjToS2x-2g.png'
]]
])
let recentStickers = []
try {
let arr = JSON.parse(localStorage.getItem('custom-sticker'))
if (Array.isArray(arr)) {
stickerMap = new Map(arr)
}
} catch (e) {}
try {
recentStickers = JSON.parse(localStorage.getItem('recent-sticker'))
if (!Array.isArray(recentStickers)) {
recentStickers = []
}
} catch (e) {}
const saveCustomSticker = (map = stickerMap) => {
localStorage.setItem('custom-sticker', JSON.stringify([...map]))
}
window.saveRecentSticker = (sticker) => {
if (recentStickers.includes(sticker)) return
recentStickers.push(sticker)
recentStickers = recentStickers.slice(-10)
localStorage.setItem('recent-sticker', JSON.stringify(recentStickers))
}
const urlPrefix = 'https://img.nga.178.com/attachments'
const resolveUrl = (src) => {
let url = src
if (/^https?\:\/\//.test(src)) {
} else if (/^\.\//.test(src)) {
url = `${urlPrefix}${src.replace(/^\./, '')}`
} else if (/^[^\/]/.test(src)) {
url = `${urlPrefix}/${src}`
}
return _.escape(url)
}
const insertStickers = async (stickerBox, list) => {
let html = ''
if (recentStickers.length) {
recentStickers.forEach(sticker => {
const src = resolveUrl(sticker)
const safeSticker = _.escape(sticker)
html += `
`
})
html = `