Greasy Fork is available in English.

表情贴纸增强插件

回复表情,插图扩展插件,在发帖时快速输入自定义表情和论坛BBCODE

// ==UserScript==
// @name        表情贴纸增强插件
// @namespace   https://github.com/HazukiKaguya/Stickers_PlusPlus
// @homepage    https://github.com/HazukiKaguya/Stickers_PlusPlus
// @version     2.1.6
// @author      HazukiKaguya
// @description 回复表情,插图扩展插件,在发帖时快速输入自定义表情和论坛BBCODE
// @icon        https://sticker.inari.site/favicon.ico
// @include     *9shenmi.com*
// @include     https://*kf*
// @include     *miaola*
// @include     *365gal*
// @include     *-plus.net*
// @include     *zdfx.net*
// @include     *saraba1st.com*
// @include     *dmhy.org*
// @copyright   2020-2022, Hazukikaguya
// @grant       GM_getValue
// @grant       GM_setValue
// @grant       GM_deleteValue
// @run-at      document-end
// @license     MIT License
// @require     https://cdn.jsdelivr.net/npm/jquery@2.2.4/dist/jquery.min.js
// ==/UserScript==
// 特别感谢:eddie32 https://greasyfork.org/users/5415-eddie32 & 喵拉布丁 https://github.com/miaolapd
// 更新日志:https://github.com/HazukiKaguya/Stickers_PlusPlus#%E6%9B%B4%E6%96%B0%E8%AE%B0%E5%BD%95


/**
 * 初始化配置
 */
'use strict';
// jQuery隔离
this.$ = this.jQuery = jQuery.noConflict(true);
// 默认配置&本地贴纸源
const updatelog = '版本V2.1.6, 本次更新日志: \n 增加看板娘透明度设置',
    defaultSConf = {
        "version": "2.1.6",
        "kanbansize": "64",
        "kbopacity": "100",
        "kanbanimg": "https://sticker.inari.site/truenight.gif",
        "imgapi": "https://up.inari.site/api/v1/",
        "cloudapi": "https://api.inari.site/?s=App.User_User.",
        "onlineraw": "https://api.inari.site/?s=App.Sticker.",
        "notauthed": false,
        "realedit": false,
        "markdown": false,
        "lcimglists": [],
        "olimglists": []
    }, check = ["kf", "365gal", "miaola", "bakabbs", "9shenmi"], mbcheck = ["&mobile=2", "/simple/"], mqcheck = ["multiquote"],
    FinalList = [], FinalRaw = [], KfSmileList = [], KfSmileCodeList = [], RandomSmileList = [], UsersSmileList = [], MenuList = {},
    uploadfile = ``,
    nullimg = '',
    lengtherrT = "长度不合规,位数应在以下范围内:",
    guestupimgT = "游客上传成功!建议绑定up.inari.site图床账号到云同步账号!",
    imgunbindT = '检测到没有绑定图床账号,是否绑定?不绑定则',
    notbindT = "图片上传将使用游客上传!",
    lenlimiT = "只支持英文、数字和有限的特殊符号如@_",
    notokenT = "未找到有效Token,请先登录!",
    doneT = "操作已完成!",
    errT = "操作失败,请打开控制台查看错误信息",
    resT = "已重置,请刷新!",
    igoT = "非法输入,请检查!",
    renT = "失败!返回码:",
    exiT = '操作已取消!'
    ;
let LocalRaws = [
    { "id": 1, "desc": "AC娘表情贴纸,属于AcSmileList,AC娘。", "cover": "https://sticker.inari.site/acfun/1/1.png", "name": "_Acfun", "title": 'AC娘', "addr": "_AcSmileList", "numstart": [1, 1001, 2001], "numend": [55, 1041, 2056], "url1": ["https://sticker.inari.site/acfun/1/", "https://sticker.inari.site/acfun/2/", "https://sticker.inari.site/acfun/3/"], "url2": [".png", ".png", ".png"] },
    { "id": 2, "desc": "华语第三动漫高手论坛S1的麻将脸表情包喵~", "cover": "https://sticker.inari.site/s1/1.gif", "name": "_S1", "title": 'S1', "addr": "_S1SmileList", "numstart": [1, 1], "numend": [21, 229], "url1": ["https://sticker.inari.site/s1/", "https://sticker.inari.site/s1/"], "url2": [".gif", ".png"] },
    { "id": 3, "desc": "《摇曳百合》的阿卡林的表情包~", "cover": "https://sticker.inari.site/akarin/2/akarin (1).gif", "name": "_Akarin", "title": '阿卡林', "addr": "_AkarinSmileList", "numstart": [1, 1], "numend": [21, 72], "url1": ["https://sticker.inari.site/akarin/2/akarin (", "https://sticker.inari.site/akarin/1/akarin ("], "url2": [").gif", ").png"] },
    { "id": 4, "desc": "小B是画师林大B练习用的看板娘,最初是在sosg论坛上出现~", "cover": "https://sticker.inari.site/lindaB/lindaB (1).jpg", "name": "_xiaoB", "title": '小B', "addr": "_xiaoBSmileList", "numstart": [1], "numend": [52], "url1": ["https://sticker.inari.site/lindaB/lindaB ("], "url2": [").jpg"] },
    { "id": 5, "desc": "微博贴吧表情包", "cover": "https://sticker.inari.site/weibo/1.png", "name": "_Weitb", "title": '微博贴吧', "addr": "_WeitbSmileList", "numstart": [1, 1, 10], "numend": [101, 10, 34], "url1": ["https://sticker.inari.site/weibo/", "https://tb2.bdstatic.com/tb/editor/images/face/i_f0", "https://tb2.bdstatic.com/tb/editor/images/face/i_f"], "url2": [".png", ".png", ".png"] },
    { "id": 6, "desc": "暹罗猫小红豆,世界,就是绕着猫打转!", "cover": "https://sticker.inari.site/usr/Kawaii_Siamese/line/0_show.png", "name": "_Siamese", "title": '小红豆', "addr": "_SiameseSmileList", "numstart": [1, 1, 1], "numend": [25, 25, 41], "url1": ["https://sticker.inari.site/usr/Kawaii_Siamese/wx1/", "https://sticker.inari.site/usr/Kawaii_Siamese/wx2/", "https://sticker.inari.site/usr/Kawaii_Siamese/line/"], "url2": [".png", ".png", ".png"] },
    { "id": 7, "desc": "Lovelive表情贴纸~", "cover": "https://sticker.inari.site/lovelive/2/ll (1).png", "name": "_LL", "title": 'LL', "addr": "_LLSmileList", "numstart": [1, 1], "numend": [42, 20], "url1": ["https://sticker.inari.site/lovelive/2/ll (", "https://sticker.inari.site/lovelive/4/ll ("], "url2": [").png", ").jpg"] },
    { "id": 8, "desc": "少女☆歌剧。去吧,两人一起,摘下那颗星。", "cover": "https://sticker.inari.site/revstar/revstar (1).png", "name": "_Revue", "title": '少歌', "addr": "_RevueSmileList", "numstart": [1], "numend": [41], "url1": ["https://sticker.inari.site/revstar/revstar ("], "url2": [").png"] },
    { "id": 9, "desc": "公主连结Re:Dive。いま、新たな冒険の幕が上がる——", "cover": "https://sticker.inari.site/redive/sticker (1).png", "name": "_Redive", "title": 'PCR', "addr": "_RediveSmileList", "numstart": [1], "numend": [49], "url1": ["https://sticker.inari.site/redive/sticker ("], "url2": [").png"] },
    { "id": 10, "desc": "BanG Dream!噜~ キラキラ☆ドキドキ~ ふえぇ~", "cover": "https://sticker.inari.site/bangdream/bangdream (1).png", "name": "_Bandori", "title": '邦邦', "addr": "_BandoriSmileList", "numstart": [1], "numend": [41], "url1": ["https://sticker.inari.site/bangdream/bangdream ("], "url2": [").png"] },
], ww = window.innerWidth || document.body.clientWidth, wh = window.innerHeight || document.body.clientHeight, customize = defaultSConf,
    loadcustom = true, isKF = false, isMQ = false, isMobile = false, realedits = true, rhview = false,
    userimgst, loclist, $realtimeView, $dialog, $textAreas, $root, $node, $node1, $this, $panel, file, formData, FileData, reader, img, begin,
    OnlineRawslists, olhaved, HeContent, OnlineRaws = [], uupath = [], localSmile = [], KFstyle = "", realeditcheck = '',
    i, s, l, t, aId, aToken, aUser, aPass, pToken, user, pass, loginf, temp,num;
// 客制化配置
if (localStorage.StickerConf) { customize = JSON.parse(localStorage.StickerConf) }
else { loadcustom = false; localStorage.setItem('StickerConf', JSON.stringify(defaultSConf)); }
if (customize.version != defaultSConf.version) {
    console.log("个性化配置版本不匹配,自动进行兼容性变更!");
    customize.version = defaultSConf.version;
    customize.cloudapi = defaultSConf.cloudapi;
    if (!customize.kanbanimg) customize.kanbanimg = defaultSConf.kanbanimg;
    if (!customize.kanbansize) customize.kanbansize = defaultSConf.kanbansize;
    if (!customize.kbopacity) customize.kbopacity = defaultSConf.kbopacity;
    if (!customize.imgapi) customize.imgapi = defaultSConf.imgapi;
    //if (!customize.cloudapi) customize.cloudapi = defaultSConf.cloudapi;
    if (!customize.onlineraw) customize.onlineraw = defaultSConf.onlineraw;
    if (!customize.notauthed) customize.notauthed = defaultSConf.notauthed;
    if (!customize.realedit) customize.realedit = defaultSConf.realedit;
    if (!customize.markdown) customize.markdown = defaultSConf.markdown;
    if (!customize.lcimglists) customize.lcimglists = defaultSConf.lcimglists;
    if (!customize.olimglists) customize.olimglists = defaultSConf.olimglists;
    localStorage.setItem('StickerConf', JSON.stringify(customize));
    localStorage.removeItem('onlineraws'); localStorage.removeItem('Alertless'); sessionStorage.removeItem('localSmile'); sessionStorage.removeItem('OnlineSmile');
    console.log(doneT);
};


/**
 * 初始化杂项
 */
customize.lcimglists ? loclist = customize.lcimglists : loclist = [];
localStorage.userimgst ? userimgst = localStorage.userimgst : userimgst = `["https://sticker.inari.site/null.jpg"]`;
const UserSmileList = JSON.parse(userimgst), iApi = customize.imgapi, cApi = customize.cloudapi, olApi = customize.onlineraw;
let realedit = customize.realedit;
if (localStorage.onlineraws) { OnlineRaws = JSON.parse(localStorage.onlineraws); }
// 网站是否为KF
for (i = 0; i < check.length; i++) { if (window.location.href.indexOf(check[i]) > -1) { isKF = true; KFstyle = 'style="display:none"'; break; } }
// 网站是否为KfMobile
const isKfMobile = typeof Info !== 'undefined' && typeof Info.imgPath !== 'undefined';
let kfImgPath = typeof imgpath !== 'undefined' ? imgpath : ''; if (isKfMobile) kfImgPath = Info.imgPath;
// 是否为移动端页面
for (i = 0; i < mbcheck.length; i++) { if (window.location.href.indexOf(mbcheck[i]) > -1) { isMobile = true; break; } }
// 检测多重引用
for (i = 0; i < mqcheck.length; i++) { if (window.location.href.indexOf(mqcheck[i]) > -1) { isMQ = true; } }
if (realedit && isMQ == false) { realeditcheck = 'checked' }


/**
 * 初始化表情图片
 */
// 灰企鹅
if (isKF) {
    for (i = 1; i < 49; i++) { KfSmileList.push(`/${kfImgPath}/post/smile/em/em${(i) > 9 ? i : ('0' + i)}.gif`); KfSmileCodeList.push(`[s:${i + 9}]`); }
    for (i = 1; i < 204; i++) { KfSmileList.push(`https://sticker.inari.site/pesoguin/${i}.gif`); KfSmileCodeList.push(`[img]https://sticker.inari.site/pesoguin/${i}.gif[/img]`); }
}
else {
    for (i = 1; i < 49; i++) { KfSmileList.push(`https://sticker.inari.site/pesoguin/em${i}.gif`); }
    for (i = 1; i < 204; i++) { KfSmileList.push(`https://sticker.inari.site/pesoguin/${i}.gif`); }
}
// 随机
RandomSmileList.push(`https://sticker.inari.site/yukika/${Math.ceil(Math.random() * 6)}.jpg`);
for (i = 0; i < 29; i++) { RandomSmileList.push(`https://sticker.inari.site/rwebp/${Math.ceil(Math.random() * 6930)}.webp`); }
for (i = 1; i < 10; i++) { RandomSmileList.push(`https://sticker.inari.site/rgif/${Math.ceil(Math.random() * 2555)}.gif`); }
// 自定义
for (i = 0; i < UserSmileList.length; i++) { UsersSmileList.push(`${UserSmileList[i]}#num=${i + 1}`); }
// 来自本地数据源的表情贴纸
for (i = 0; i < loclist.length; i++) { localSmile[i] = LocalRaws[loclist[i]]; }
if (!sessionStorage.localSmile) {
    for (i = 0; i < localSmile.length; i++) {
        localSmile[i].addr = []; for (s = 0; s < localSmile[i].numstart.length; s++) {
            for (t = localSmile[i].numstart[s]; t < localSmile[i].numend[s]; t++) { localSmile[i].addr.push(localSmile[i].url1[s] + t + localSmile[i].url2[s]); }
        }
    }
    sessionStorage.setItem('localSmile', JSON.stringify(localSmile));
}
localSmile = JSON.parse(sessionStorage.localSmile)
// 来自在线数据源的表情贴纸
if (!sessionStorage.OnlineSmile) {
    let onlineSmile = OnlineRaws;
    for (i = 0; i < onlineSmile.length; i++) {
        onlineSmile[i].addr = []; for (s = 0; s < onlineSmile[i].numstart.length; s++) {
            for (t = onlineSmile[i].numstart[s]; t < onlineSmile[i].numend[s]; t++) { onlineSmile[i].addr.push(onlineSmile[i].url1[s] + t + onlineSmile[i].url2[s]); }
        }
    } sessionStorage.setItem('OnlineSmile', JSON.stringify(onlineSmile));
}
let OnlineSmile = JSON.parse(sessionStorage.OnlineSmile)


/**
 * 表情菜单
*/
if (isKF) {
    MenuList['KfSmile'] = { datatype: 'imageLink', title: '小企鹅', desc: 'KF论坛的小企鹅表情', addr: KfSmileList, ref: KfSmileCodeList };
    MenuList['Shortcut'] = {
        datatype: 'plain', title: '快捷', desc: '发帖实用BBcode',
        addr: [
            '[sell=100][/sell]', '[quote][/quote]', '[backcolor=#000][color=#000]在此输入[/color][/backcolor]', '[hide=100][/hide]', '[code][/code]', '[strike][/strike]', '[fly][/fly]', '[color=#00FF00][/color]',
            '[b][/b]', '[u][/u]', '[i][/i]', '[hr]', '[backcolor=][/backcolor]', '[url=][/url]', '[img][/img]', '[url=][img][/img][/url]', '[table][/table]', '[tr][/tr]', '[td][/td]',
            '[align=left][/align]', '[align=center][/align]', '[align=right][/align]', '[audio][/audio]', '[video][/video]', '[email][/email]', '[list][/list]',
            '[/align]这里是签名档内容,可以随意修改,支持bbcode,实验性功能,喵拉手机版不显示,编辑帖子后如果有修改说明会导致喵拉手机版重复显示两次内容。',
            '[align=center][img]此处替换为自定义图片url[/img][/align][align=center][backcolor=#FFF][size=3]  [b]在此输入自定义文字[/b]  [/size][/backcolor][/align]'
        ],
        ref: [
            '出售贴sell=售价', '引用', '隐藏(黑条)', '隐藏hide=神秘等级', '插入代码', '删除线', '跑马灯', '文字颜色', '粗体', '下划线', '斜体', '水平线', '背景色', '插入链接',
            '插入图片', '插入超链接图片', '插入表格', '插入表格行', '插入表格列', '左对齐', '居中', '右对齐', '插入音频', '插入视频', 'Email', '插入列表', '签名档[实验性功能]', '自定义表情配文字'
        ]
    };
}
else if (!isKF) {
    MenuList['KfSmile'] = { datatype: 'image', title: '小企鹅', desc: 'KF论坛的小企鹅表情', addr: KfSmileList };
    MenuList['Shortcut'] = {
        datatype: 'plain', title: 'BBcode', desc: '发帖实用BBcode',
        addr: [
            '[sell=100][/sell]', '[quote][/quote]', '[backcolor=#000][color=#000]在此输入[/color][/backcolor]', '[hide=100][/hide]', '[code][/code]', '[strike][/strike]', '[fly][/fly]', '[color=#00FF00][/color]',
            '[b][/b]', '[u][/u]', '[i][/i]', '[hr]', '[backcolor=][/backcolor]', '[url=][/url]', '[img][/img]', '[url=][img][/img][/url]', '[table][/table]', '[tr][/tr]', '[td][/td]',
            '[align=left][/align]', '[align=center][/align]', '[align=right][/align]', '[audio][/audio]', '[flash=audio][/flash]', '[video][/video]', '[media][/media]', '[flash][/flash]', '[email][/email]', 
	    '[list][/list]', '[font=字体名]文字[/font]', '[collapse=文字]需要折叠的内容[/collapse]', '[dice]d楼层数[/dice]', '[@用户名]or[@用户ID]','[spoiler=折叠内容][/spoiler]','[mediainfo][/mediainfo]'
        ],
        ref: [
            '出售贴sell=售价', '引用', '隐藏(黑条)', '隐藏(hide=)', '插入代码', '删除线', 'Fly', '文字颜色', '粗体', '下划线', '斜体', '水平线', '背景色', '插入链接',
            '插入图片', '插入超链接图片', '插入表格框', '插入表格行', '插入表格列', '左对齐', '居中', '右对齐', '插入音频', '插入flash音频', '插入视频[video]',
	    '插入视频[media]', '插入flash', 'Email', '插入列表', '字体', 'nga折叠内容', 'ngaRoll点', 'nga@用户','U2折叠内容','U2媒体信息'
        ]
    };
};

MenuList['Markdown'] = {
    datatype: 'plain', title: 'M↓', desc: 'Markdown语法,如需全局更换为markdown请前往【自定义】-》【个性设置】,勾选【使用Markdown取代BBcode】',
    addr: [
        '> ', '**', '****', '---', '~~~~', '<u></u>', '``', '[]()', '![]()', '# '
    ],
    ref: [
        '引用', '斜体', '粗体', '分割线', '删除线', '下划线', '代码', '链接', '图片', '标题'
    ]
};
MenuList['Random'] = { datatype: 'image', title: '随机', desc: '从随机表情贴纸池里随机抽取表情贴纸!', addr: RandomSmileList },
    MenuList['Userimg'] = { datatype: 'image', title: '自定义', desc: '你自己新增的表情贴纸都在这里!', addr: UsersSmileList };
MenuList['Kaomoji'] = {
    datatype: 'plain',
    title: ':)',
    desc: '颜文字',
    addr: [
        '(●・ 8 ・●)', '╰(๑◕ ▽ ◕๑)╯', '(ゝω・)', '〜♪♪', '(゚Д゚≡゚Д゚)', '(^o^)ノ', '(|||゚Д゚)', '(`ε´ )', '(╬゚д゚)', '(|||゚д゚)', '( ̄∇ ̄)', '( ̄3 ̄)', '( ̄ー ̄)',
        '( ̄ .  ̄)', '( ̄︿ ̄)', '( ̄︶ ̄)', '(*´ω`*)', '(・ω・)', '(⌒▽⌒)', '( ̄▽ ̄)', '(=・ω・=)', '(・∀・)', '(`・ω・´)', '(〜 ̄△ ̄)〜', '(°∀°)ノ', '( ̄3 ̄)',
        '╮( ̄▽ ̄)╭', '( ´_ゝ`)', 'のヮの', '(ノ؂< ๑)诶嘿☆~', '(<_<)', '(>_>)', '(;¬_¬)', '(▔□▔)/', '(゚Д゚≡゚д゚)!?', 'Σ(゚д゚;)', 'Σ(  ̄□ ̄||)', '(´;ω;`)',
        '(/TДT)/', '(^・ω・^ )', '(。・ω・。)', '(o゚ω゚o)', '(● ̄(エ) ̄●)', 'ε=ε=(ノ≧∇≦)ノ', '(´・_・`)', '(-_-#)', '( ̄へ ̄)', '( ̄ε(# ̄) Σ', 'ヽ(`Д´)ノ', '( ´ρ`)',
        '(╯°口°)╯(┴—┴', '(#-_-)┯━┯', '_(:3」∠)_', '(笑)', '(汗)', '(泣)', '(苦笑)', '(´・ω・`)', '(╯°□°)╯︵ ┻━┻', '(╯‵□′)╯︵┻━┻', '( ゚ω゚)',
        '( ^ω^)', '(。◕∀◕。)', '/( ◕‿‿◕ )\\', 'ε٩( º∀º )۶з', '( ̄ε(# ̄)☆╰╮( ̄▽ ̄///)', '(●´3`)~♪', '_(:з」∠)_', 'хорошо!', '\(^o^)/', '(•̅灬•̅ )',
        '(゚Д゚)', '(;°ほ°)', 'ε=ε=ε=┏(゜ロ゜;)┛', '⎝≧⏝⏝≦⎠', 'ヽ(✿゚▽゚)ノ', '|•ω•`)', '小学生は最高だぜ!!', '焔に舞い上がるスパークよ、邪悪な異性交際に、天罰を与え!'
    ]
};
for (i = 0; i < localSmile.length; i++) { MenuList[`${localSmile[i].name}`] = { datatype: 'image', title: localSmile[i].title, desc: localSmile[i].desc, addr: localSmile[i].addr }; }
for (i = 0; i < OnlineSmile.length; i++) { MenuList[`${OnlineSmile[i].name}`] = { datatype: 'image', title: OnlineSmile[i].title, desc: OnlineSmile[i].desc, addr: OnlineSmile[i].addr }; }


/**
 * 添加BBCode
 * @param textArea 文本框
 * @param {string} code BBCode
 * @param {string} selText 选择文本
 */
const addCode = function (textArea, code, selText = '') {
    let startPos;
    if (customize.markdown == false) {
        startPos = !selText ? (code.indexOf('[img]') > -1 || code.indexOf(']') < 0 ? code.length : code.indexOf(']') + 1) : code.indexOf(selText);
    }
    else if (customize.markdown == true) {
        startPos = !selText ? (code.indexOf('[]') > -1 && code.length < 10 ? code.length - 1 : (code.indexOf('*') > -1 || code.indexOf('`') > -1 || code.indexOf('<') > -1 || code.indexOf('~') > -1 ? Math.floor(code.length / 2) : code.length)) : code.indexOf(selText);
    }
    if (typeof textArea.selectionStart !== 'undefined') {
        let prePos = textArea.selectionStart;
        textArea.value = textArea.value.substring(0, prePos) + code + textArea.value.substring(textArea.selectionEnd);
        textArea.selectionStart = prePos + startPos; textArea.selectionEnd = prePos + startPos + selText.length;
        if ($('#spp-reply-textarea').length > 0) {
            let textArea2 = $('#spp-reply-textarea')[0], prePos = textArea2.selectionStart;
            textArea2.value = textArea2.value.substring(0, prePos) + code + textArea2.value.substring(textArea2.selectionEnd);
            textArea2.selectionStart = prePos + startPos; textArea2.selectionEnd = prePos + startPos + selText.length;
        }
    }
    else { textArea.value += code; if ($('#spp-reply-textarea').length > 0) { $('#spp-reply-textarea')[0].value += code; } }
};


/**
 * 添加Html文本
 * @param {string} code Html文本
 */
const addHCode = function (code) {
    temp = document.createTextNode("\u0001"); $realtimeView.getSelection().getRangeAt(0).insertNode(temp);
    let position = $realtimeView.body.innerHTML.indexOf("\u0001"); temp.parentNode.removeChild(temp);
    if (position > 0) { temp = $realtimeView.createElement("nobr"); temp.innerHTML = code; $realtimeView.getSelection().getRangeAt(0).insertNode(temp); }
    else { $realtimeView.body.innerHTML += code; }
};


/**
 * 显示放大的表情图片
 * @param {jQuery} $img 表情图片对象
 */
const showZoomInImage = function ($img) {
    if ($img.get(0).naturalWidth <= $img.height()) return;
    let offset = $img.offset(), $zoomIn = $(`<img class="stickerpp-zoom-in" src="${$img.attr('src')}" alt="[预览图片]">`).appendTo('body'),
        windowWidth = $(window).width(), zoomInWidth = $zoomIn.outerWidth(),
        top = offset.top - $zoomIn.outerHeight() - 5, left = offset.left + $img.width() / 2 - zoomInWidth / 2;
    if (left < 0) left = 0;
    else if (left + zoomInWidth > windowWidth) left = windowWidth - zoomInWidth;
    $zoomIn.css({ top, left });
};


/**
* 获取表情面板的HTML代码
* @param {string} key 菜单关键字
* @returns {string} 表情面板内容
*/
const getSmilePanelHtml = function (key) {
    let data = MenuList[key]; if (!data) return '';
    let html = '', ref; for (i = 0; i < data.addr.length; i++) {
        if (data.datatype === 'image') { html += `<img class="stickerpp-smile" src="${data.addr[i]}" alt="[表情]">`; }
        else if (data.datatype === 'imageLink') {
            ref = typeof data.ref !== 'undefined' && typeof data.ref[i] !== 'undefined' ? data.ref[i] : '';
            html += `<img class="stickerpp-smile" data-code="${ref}" src="${data.addr[i]}" alt="[表情]">`;
        } else if (data.datatype === 'plain') {
            ref = typeof data.ref !== 'undefined' && typeof data.ref[i] !== 'undefined' ? data.ref[i] : data.addr[i];
            html += `<a class="stickerpp-smile-text" data-code="${data.addr[i]}"  href="#">${ref}</a>`;
        }
    }
    return `<div class="stickerpp-smile-panel" data-key="${key}">${html}</div>`;
};


/**
* 获取子菜单的HTML代码
* @returns {string} 子菜单内容
*/
const getSubMenuHtml = function () {
    let html = '';
    $.each(MenuList, function (key, data) { html += `<a class="stickerpp-sub-menu" data-key="${key}" href="#" title="${data.desc}">${data.title}</a>`; });
    return html;
};


/**
 * 创建容器
 * @param textArea 文本框
 * @param qufen 区分不同文本区域
 */
// 看板娘
let stickerppkanban = document.createElement("div");
if (isKfMobile == true || isMobile == true) {
    if (localStorage.imgmoveMb != null) {
        let imgmoveMb = JSON.parse(localStorage.imgmoveMb);
        stickerppkanban.innerHTML = `<div id = "stickerppkanban" style = "filter:opacity(${customize.kbopacity + "%"});position:fixed;left:${Math.floor(imgmoveMb[0] * ww)}px;top:${Math.floor(imgmoveMb[1] * wh)}px;z-index:88;cursor:pointer;min-width:128px; min-height=128px;" >
  <img class="stickerppkanban" src = ${customize.kanbanimg} width =${Math.floor(customize.kanbansize / 2) + "%"} height =${Math.floor(customize.kanbansize / 2) + "%"}></div>`;
    }
    else {
        stickerppkanban.innerHTML = `<div id = "stickerppkanban" style = "filter:opacity(${customize.kbopacity + "%"});position:fixed;left:5px;top:300px;z-index:88;cursor:pointer;min-width:128px; min-height=128px;" >
  <img class="stickerppkanban" src = ${customize.kanbanimg} width =${Math.floor(customize.kanbansize / 2) + "%"} height =${Math.floor(customize.kanbansize / 2) + "%"}></div>`;
    }
}
else {
    if (localStorage.imgmovePc != null) {
        let imgmovePc = JSON.parse(localStorage.imgmovePc);
        stickerppkanban.innerHTML = `<div id = "stickerppkanban" style = "filter:opacity(${customize.kbopacity + "%"});position:fixed;left:${Math.floor(imgmovePc[0] * ww)}px;top:${Math.floor(imgmovePc[1] * wh)}px;z-index:88;cursor:pointer;min-width:128px; min-height=128px;" >
  <img class="stickerppkanban" src = ${customize.kanbanimg} width =${customize.kanbansize + "%"} height =${customize.kanbansize + "%"}></div>`;
    }
    else {
        stickerppkanban.innerHTML = `<div id = "stickerppkanban" style = "filter:opacity(${customize.kbopacity + "%"});position:fixed;left:5px;top:100px;z-index:88;cursor:pointer;min-width:128px; min-height=128px;" >
  <img class="stickerppkanban" src = ${customize.kanbanimg} width =${customize.kanbansize + "%"} height =${customize.kanbansize + "%"}></div>`;
    }
} document.body.appendChild(stickerppkanban);
let imgpv = document.getElementById("stickerppkanban"); window.onload = function () { drag(imgpv); };
// 表情商店相关
const
    StickerPPDialogHtml = `<form><div class="stickerpp-shop_box" id="StickerPP-shop-dialog" style="display: block; top: 8px; left: 336px;">
     <sheader><logo>&nbsp;&nbsp;&nbsp;表情贴纸商店 | Sticker Shop</logo><span class="stickerpp-close-shop">×&nbsp;&nbsp;</span></sheader>
     <div class="stickerpp-shop_main" ><br><div class="StickerPP-list-content"></div></div>
     <div class="pd_cfg_btns"></div>
     <div class="sticker-pages"><div class="StickerPP-list-pagination"></div></div>
     <div class="stickerpp-shop_footer">
     <a target="_blank" href="https://stickers.inari.site/terms">Terms Of Service/服务条款</a> | <a target="_blank" href="https://stickers.inari.site/rules">Privacy Policy/隐私策略</a> | <a target="_blank" href="https://stickers.inari.site/qa">Q&A/常见问题</a> |
     ©mistakey&nbsp;&nbsp;</div>
 </div></form>`,
    StickerPPUploadHtml = `<form><div class="stickerpp-shop_box" id="StickerPP-shop-dialog" style="display: block; top: 8px; left: 336px;">
     <sheader><logo>&nbsp;&nbsp;&nbsp;表情贴纸商店 | Sticker Shop</logo><span class="stickerpp-close-shop">×&nbsp;&nbsp;</span></sheader>
     <div class="stickerpp-shop_main" ><br>
     <div class="StickerPP-list-content">
     <h3>开发文档: 标准化数据源格式</h3>
     <p>{"id":int,"desc":"这里是描述,鼠标移到该分组时会显示","cover":"url","name":"_Name","title":"展示的名字","addr":"_NameList","numstart":[int,int,...],"numend":[int,int,...],"url1":["url前1","url前2",...],"url2":["url后1","url后1",...]};</p>
     </div>
     </div>
     <div class="sticker-pages"><div class="StickerPP-list-pagination">
     </div>
     </div>
     <div class="stickerpp-shop_footer">
     <a target="_blank" href="https://stickers.inari.site/terms">Terms Of Service/服务条款</a> | <a target="_blank" href="https://stickers.inari.site/rules">Privacy Policy/隐私策略</a> | <a target="_blank" href="https://stickers.inari.site/qa">Q&A/常见问题</a> |
     ©mistakey&nbsp;&nbsp;</div>
 </div></form>`,
    StickerPPlogedUp = `<form method="POST" action="https://api.inari.site/?s=App.Examples_Upload.Go" target="NoRefreash" enctype="multipart/form-data">
     <p><b>检测到已登录,可以在此直接上传表情贴纸组压缩包(最大50M)并获取返回值</b></p>
     <input class='StickerPP-pagination-nowpage-button' type="file" name="file">
     <input class='StickerPP-pagination-nowpage-button' type="submit"></form>
     <iframe src="" frameborder="0" name="NoRefreash" style="width:100%;height:42px"></iframe>`,
    StickerPPunlogUp = `<p><b>未登录或登录失效,登录后创作者可以直接在此上传表情贴纸组压缩包并获取返回值</b></p>`,
    StickerPPtextUp = `<h3>请按如下格式填写""内的内容,然后邮件内容至 <a herf="mailto:Hazukikaguya@office.inari.site">Hazukikaguya@office.inari.site</a></h3><p>
     名称: "这里填写展示在商店页面的描述名称"<br>
     作者: "这里填写作者"<br>
     描述: "这里是描述,鼠标移到该分组时会显示"<br>
     标题: "这里填写启用后展示的名字(如邦邦/S1/AC娘 这种简短的)"<br>
     封面: "这里填写展示在商店页面的封面图片的url链接,建议使用邮件附件"<br>
     链接: "这里填写可下载帖纸组的url/压缩包。登录用户可在此页面上传压缩包并复制返回值,但还是建议创作者直接使用邮件附件"</p>`,
    StickerPPItemHtml = `<div class="sticker-item"><div class="sticker-item-img"><img style="width: 50px; height: 50px;"/></div><div class="sticker-item-name"></div></div>`,
    StickerPPPaginationItemHtml = `<div class="StickerPP-pagination-item-button"></div>`,
    StickerPPNowPageHtml = `<div class="StickerPP-pagination-nowpage-button"></div>`,
    prevNextPageHtml = `<div class="StickerPP-pagination-prev-next"></div>`
    ;
$(document).on("click", "#StickerPP-shop-dialog .sticker-item", function (e) {
    let selctedid = $(e.target).parents(".sticker-item").data("id"), selctedtext = JSON.parse($(e.target).parents(".sticker-item").data("content"));
    localStorage.onlineraws ? OnlineRawslists = JSON.parse(localStorage.onlineraws) : OnlineRawslists = [];
    OnlineRawslists == [] ? olhaved = false : olhaved = OnlineRawslists.some(o => o.id === selctedid);
    if (olhaved == false) {
        if (confirm("是否选择启用ID为" + $(e.target).parents(".sticker-item").data("id") + "的在线表情贴纸" + $(e.target).parents(".sticker-item").text())) {
            customize.olimglists.push(selctedid); OnlineRawslists.push(selctedtext); localStorage.setItem('onlineraws', JSON.stringify(OnlineRawslists));
            localStorage.setItem('StickerConf', JSON.stringify(customize)); sessionStorage.removeItem('OnlineSmile');
        } else { alert("启用操作取消") }
    }
    else if (olhaved == true) {
        if (confirm("是否选择停用ID为" + $(e.target).parents(".sticker-item").data("id") + "的在线表情贴纸" + $(e.target).parents(".sticker-item").text())) {
            const indexToRemove = OnlineRawslists.findIndex((orl) => orl.id === selctedid); OnlineRawslists.splice(indexToRemove, 1);
            customize.olimglists.splice(customize.olimglists.indexOf(selctedid), 1); localStorage.setItem('onlineraws', JSON.stringify(OnlineRawslists));
            localStorage.setItem('StickerConf', JSON.stringify(customize)); sessionStorage.removeItem('OnlineSmile');
        } else { alert("停用操作取消") }
    }
}).on("click", "#StickerPP-shop-dialog .StickerPP-pagination-item-button", function (e) {
    $(document).find('.stickerpp-shop_box').hide(); $dialog = $("#StickerPP-shop-dialog")[0];
    $("body").append(StickerPPDialogHtml); StickerPPLoadSticker($(e.target).data("id"));
}).on("click", "#StickerPP-shop-dialog .StickerPP-pagination-prev-next", function (e) {
    $(document).find('.stickerpp-shop_box').hide(); $dialog = $("#StickerPP-shop-dialog")[0];
    $("body").append(StickerPPDialogHtml); StickerPPLoadSticker($(e.target).data("id"));
}).on('click', '.stickerpp-close-shop', function (e) {
    $(document).find('.stickerpp-shop_box').hide();
});
// 表情菜单
const createContainer = function (textArea, qufen) {
    let $container = $(`<div class="stickerpp-container">
     <div class="stickerpp-menu" id="smilepndw${qufen}" style="text-align:left;">
     <input type= "file"  class="stickerpp-user-p" id="stickerpp-user-p${qufen}" accept="image/*" style="display:none;" >
     <input type="button" class="stickerpp-user-t" value="上传图片" ${KFstyle}>
     <input type="button" class="stickerpp-user-y" value="云同步">
     <input type="button" class="stickerpp-user-i" value="自定义">
     <input type="button" class="stickerpp-user-g" value="表情组设置">&nbsp;
     <span class="stickerpp-close-panel" title="表情增强插件,${updatelog}" style="cursor: pointer;"><b>⑨</b></span>
     ${getSubMenuHtml()}<span class="stickerpp-close-panel">[-]</span>&nbsp;<input type="checkbox" class="realeditclick" id="realedit${qufen}" value="realedit" ${realeditcheck}>可视化编辑
     <div class="stickerpp-diy-panel" style="display:none">
     <input type="button" class="stickerpp-user-c" value="添加贴纸">&nbsp;
     <input type="button" class="stickerpp-user-r" value="导出贴纸">&nbsp;
     <input type="button" class="stickerpp-user-u" value="修改贴纸">&nbsp;
     <input type="button" class="stickerpp-user-d" value="删除贴纸">&nbsp;
     <input type="button" class="stickerpp-user-cfg" value="个性设置">
     <div class="stickerpp-conf-panel" style="display:none">
     <table><tr><td>
     <li><input type="text" class="conftext" id="kanbanimg${qufen}" value="">&nbsp;<input type="button" class="stickerpp-res-kanbanimg" value="默认">(看板娘图片URL)</li>
     <li><input type="number" class="conftext" id="kanbansize${qufen}" value="">&nbsp;<input type="button" class="stickerpp-res-kanbansize" value="默认">(看板娘大小,移动端/2)</li>
     <li><input type="number" class="conftext" id="kbopacity${qufen}" value="">&nbsp;<input type="button" class="stickerpp-res-kbopacity" value="默认">(看板娘透明度百分比,取值0-100)</li>
     <li><input type="text" class="conftext" id="onlineraw${qufen}" value="">&nbsp;<input type="button" class="stickerpp-res-onlineraw" value="默认">(在线贴纸仓库API)</li>
     <li><input type="text" class="conftext" id="imgapi${qufen}" value="">&nbsp;<input type="button" class="stickerpp-res-imgapi" value="默认">(图片上传图床API)</li>
     <li><input type="text" class="conftext" id="olimglists${qufen}" disabled="true" value="">&nbsp;<input type="button" class="stickerpp-res-olimglists" value="默认">(已选在线贴纸ID数组)</li>
     <li><input type="checkbox" class="confbt" id="writeable${qufen}" value="writeable"><span style="cursor: help;color:red" title="请确定你知道你在做什么!在此修改(特别是增加!)已选在线贴纸组ID数组可能会发生不可预知的错误!">编辑ID数组【!】</span>
     <input type="checkbox" class="confbt" id="markdown${qufen}" value="markdown">用M↓取代BBcode
     <input type="checkbox" class="confbt" id="notauthed${qufen}" value="auth">显示未验证贴纸组</li>
     <li><input type="button" class="stickerpp-res-kanbanloc" value="重置看板位置">&nbsp;&nbsp;<input type="button" class="stickerpp-res-hidekanban" value="隐藏看板娘">&nbsp;&nbsp;<input type="button" class="stickerpp-res-all" value="全部初始化">&nbsp;&nbsp;<input type="button" class="stickerpp-conf-close" value="关闭列表"></li>
     </td></tr></table></div></div>
     <div class="stickerpp-acc-panel" style="display:none">
     <input type="button" class="stickerpp-user-reg" value="注册">&nbsp;
     <input type="button" class="stickerpp-user-log" value="登录">&nbsp;
     <input type="button" class="stickerpp-user-img" value="绑定图床">&nbsp;
     <input type="button" class="stickerpp-user-ltc" value="上传云端">&nbsp;
     <input type="button" class="stickerpp-user-ctl" value="恢复本地">&nbsp;
     <input type="button" class="stickerpp-user-out" value="登出"></div>
     <div class="stickerpp-bqz-panel" style="display:none">
     <input type="button" class="stickerpp-user-loc" value="启用的本地表情">&nbsp;
     <input type="button" class="stickerpp-user-oln" value="浏览表情组商店">&nbsp;
     <input type="button" class="stickerpp-user-raw" value="向贴纸商店投稿">&nbsp;
     <div class="stickerpp-loc-panel" style="display:none"><table><tr>
     <td><li><input type="checkbox" class="locbt" id="ng${qufen}0" value="0">AC娘</li></td>
     <td><li><input type="checkbox" class="locbt" id="ng${qufen}1" value="1">S1麻将脸</li></td>
     <td><li><input type="checkbox" class="locbt" id="ng${qufen}3" value="3">看板娘小B</li></td>
     <td><li><input type="checkbox" class="locbt" id="ng${qufen}4" value="4">微博贴吧</li></td>
     <td><li><input type="checkbox" class="locbt" id="ng${qufen}2" value="2">阿卡林</li></td></tr><tr>
     <td><li><input type="checkbox" class="locbt" id="ng${qufen}9" value="9">邦邦</li></td>
     <td><li><input type="checkbox" class="locbt" id="ng${qufen}6" value="6">LoveLive</li></td>
     <td><li><input type="checkbox" class="locbt" id="ng${qufen}8" value="8">公主链接R</li></td>
     <td><li><input type="checkbox" class="locbt" id="ng${qufen}7" value="7">少女歌剧</li></td>
     <td><li><input type="checkbox" class="locbt" id="ng${qufen}5" value="5">小红豆</li></td>
     <td><input type="button" class="stickerpp-loc-close"value="关闭列表" ></td></tr>
     </table></div></div></div>
     <div class="StickerPPHtmlEditerP" id="Htmlediterpannel${qufen}" style="display:none;text-align:left;width=100%" >
     <div class="StickerPPHtmlediterF" id="Htmlediter${qufen}">
         <button class="Heditm" data-edit="undo" title="撤销(Ctrl+Z)">↩️</button>
         <button class="Heditm" data-edit="redo" title="重做(Ctrl+Y)">↪️</button>
         <button class="Heditms" id="HEDurl" title="插入链接">🔗</button>
         <button class="Heditms" id="HEDimg" title="插入图片">🖼️</button>
         <button class="Heditms" id="HEDaudio" title="插入HTML5音频">🎵</button>
         <button class="Heditms" id="HEDvideo" title="插入HTML5视频">🎞️</button>
         <button class="Heditm" data-edit="quote" title="插入引用内容">💬</button>
         <button class="Heditm" data-edit="code" title="插入代码内容" >📄</button>
         <button class="Heditm" data-edit="hide" title="插入隐藏内容">💡</button>
         <button class="Heditm" data-edit="sell" title="插入出售内容">🪙</button>
         <button class="Heditm" data-edit="bold" title="粗体"><b>B</b></button>
         <button class="Heditm" data-edit="italic" title="斜体"><i><b>I</b></i></button>
         <button class="Heditm" data-edit="underline" title="下划线"><u><b>U</b></u></button>
         <button class="Heditm" data-edit="strikeThrough" title="删除线"><s><b>A</b></s></button>
         <button class="Heditm" data-edit="hr" title="插入水平线" ><b>一</b></button>
         <input  class="Heditms" type='color' onblur="document.execCommand('forecolor',false,this.value)" title="字体颜色">
         <input  class="Heditms" type='color' onblur="document.execCommand('backcolor',false,this.value)" title="背景颜色">
         <button class="Heditm" data-edit="justifyLeft" title="左对齐"><b>⤆</b></button>
         <button class="Heditm" data-edit="justifyCenter" title="居中"><b>⟺</b></button>
         <button class="Heditm" data-edit="justifyRight" title="右对齐"><b>⤇</b></button>
         <button class="Heditm" data-edit="Subscript" title="下标">X<b>,</b></button>
         <button class="Heditm" data-edit="Superscript" title="上标">X<b>'</b></button>
         <span title="字体大小设置">
         <button class="Heditm" data-edit="fontSize:1">s</button>
         <button class="Heditm" data-edit="fontSize:3">M</button>
         <button class="Heditm" data-edit="fontSize:5">L</button>
         <button class="Heditm" data-edit="fontSize:7"><b>L</b></button>
       </span>
         <button class="Heditm" data-edit="removeFormat" title="清除选中文本的格式"><b>⨯</b></button>
     </div>
     <div class="StickerPPHtmlEditer" id="Htmleditarea${qufen}" contenteditable="true" spellcheck="false" style="height: 300px;overflow:auto;background:white;border:1px dashed #000;outline:none;margin: 0px; height: 300px;margin: 0px; " ></div>
     </div>
     </div>`).insertBefore($(textArea));
    if (isKfMobile == true) {
        $(`<button class="btn btn-secondary upload-image-btn ml-1" title="上传图片" onclick="$('.stickerpp-user-p').click();">
             <i class="fa fa-picture-o" aria-hidden="true"></i>上传图片</button>`).insertAfter($("#smileDropdownBtn"));
    }
    else if (isKF == true) { $(`<a>&nbsp;</a><input type="button" class="stickerpp-user-pt" value="上传图片" onclick="$('.stickerpp-user-p').click();">`).insertAfter($('[name="Submit"][value!="全站搜索"]')); }
    if (realedit == true && rhview == false && isMQ == false) {
        let $realP = $container.find(`#Htmlediterpannel${qufen}`), $realPHE = $container.find(`#Htmleditarea${qufen}`);
        $realPHE[0].innerHTML = bb2html(textArea.value);
        if ($('#spp-reply-textarea').length > 0) { $realPHE[0].innerHTML = bb2html($('#spp-reply-textarea')[0].value); }
        $realP.show(); $('textarea').hide(); $('#editor-button').hide();
    }
    else if (realedit == false && rhview == false) {
        let $realP = $container.find(`#Htmlediterpannel${qufen}`).hide(), $realPHE = $container.find(`#Htmleditarea${qufen}`);
        $realPHE[0].innerHTML = bb2html(textArea.innerHTML);
        if ($('#spp-reply-textarea').length > 0) { $realPHE[0].innerHTML = bb2html($('#spp-reply-textarea')[0].value); }
        $realP.show(); $realP.hide();
    }
    $container.on('click', '.stickerpp-sub-menu', function (e) {
        e.preventDefault(); $container.find('.stickerpp-acc-panel').hide(); $container.find('.stickerpp-bqz-panel').hide(); $this = $(this); let key = $this.data('key'); if (!key) return;
        $container.find('.stickerpp-sub-menu').removeClass('stickerpp-sub-menu-active'); $this.addClass('stickerpp-sub-menu-active'); $container.find('.stickerpp-smile-panel').hide();
        $container.find('.stickerpp-conf-panel').hide(); $panel = $container.find(`.stickerpp-smile-panel[data-key="${key}"]`);
        if ($panel.length > 0) { $panel.show(); }
        else { $('#smilepndw' + qufen).append($(getSmilePanelHtml(key))).show(); let $panels = $container.find(`.stickerpp-smile-panel[data-key="${key}"]`); $panels.show(); }
    }).on('click', '.stickerpp-smile, .stickerpp-smile-text', function (e) {
        e.preventDefault(); $this = $(this); let code = $this.data('code');
        if (rhview == false && realedit == true) {
            if (!code) { document.execCommand('insertImage', false, $this.attr('src')); }
            else { document.execCommand('insertText', false, code); }
        } else if (rhview == false && realedit == false) {
            if (customize.markdown == false) { if (!code) code = `[img]${$this.attr('src')}[/img]`; addCode(textArea, code); }
            else if (customize.markdown == true) { if (!code) code = `![](${$this.attr('src')})`; addCode(textArea, code); }
        } else if (rhview == true) { if (!code) code = `<img src="${$this.attr('src')}" border="0" alt="" style="max-width:400px"></img>`; addHCode(code); }
        if (/(Mobile|MIDP)/i.test(navigator.userAgent)) textArea.blur(); else textArea.focus();
    }).on('mouseenter', '.stickerpp-smile', function () {
        $('.stickerpp-zoom-in').remove(); showZoomInImage($(this));
    }).on('mouseleave', '.stickerpp-smile', function () {
        $('.stickerpp-zoom-in').remove();
    }).on('change', '.stickerpp-user-p', function (e) {
        e.preventDefault(); file = this.files[0];
        if (file != null) { formData = new FormData(); formData.append('file', file); upimgfunc(formData, textArea); }
    }).on('click', '.stickerpp-user-t', function (e) {
        e.preventDefault(); $('#stickerpp-user-p' + qufen).click();
    }).on('click', '.stickerpp-user-g', function (e) {
        e.preventDefault(); $container.find('.stickerpp-smile-panel').hide(); $container.find('.stickerpp-diy-panel').hide(); $container.find('.stickerpp-acc-panel').hide();
        $this = $(this); $container.find('.stickerpp-user-g').removeClass('stickerpp-user-g-active'); $this.addClass('stickerpp-user-g-active');
        $container.find('.stickerpp-diy-panel').hide(); $panel = $container.find(`.stickerpp-bqz-panel`); $panel.show();
    }).on('click', '.stickerpp-user-i', function (e) {
        e.preventDefault(); $container.find('.stickerpp-acc-panel').hide(); $container.find('.stickerpp-bqz-panel').hide(); $this = $(this);
        $container.find('.stickerpp-user-i').removeClass('stickerpp-user-i-active'); $this.addClass('stickerpp-user-i-active');
        $container.find('.stickerpp-diy-panel').hide(); $panel = $container.find(`.stickerpp-diy-panel`); $panel.show();
    }).on('click', '.stickerpp-user-y', function (e) {
        e.preventDefault(); $container.find('.stickerpp-smile-panel').hide(); $container.find('.stickerpp-diy-panel').hide(); $container.find('.stickerpp-bqz-panel').hide();
        $this = $(this); $container.find('.stickerpp-user-y').removeClass('stickerpp-user-y-active'); $this.addClass('stickerpp-user-y-active');
        $container.find('.stickerpp-acc-panel').hide(); $panel = $container.find(`.stickerpp-acc-panel`); $panel.show();
    }).on('click', '.stickerpp-user-c', function (e) {
        e.preventDefault(); usercfunc();
    }).on('click', '.stickerpp-user-r', function (e) {
        e.preventDefault(); userrfunc();
    }).on('click', '.stickerpp-user-u', function (e) {
        e.preventDefault(); userufunc();
    }).on('click', '.stickerpp-user-d', function (e) {
        e.preventDefault(); userdfunc();
    }).on('click', '.stickerpp-user-ctl', function (e) {
        e.preventDefault();
        if (localStorage.logindata != null) { ctlfunc() }
        else { alert(notokenT) };
    }).on('click', '.stickerpp-user-ltc', function (e) {
        e.preventDefault();
        if (localStorage.logindata != null) { ltcfunc() }
        else { alert(notokenT) };
    }).on('click', '.stickerpp-user-log', function (e) {
        e.preventDefault();
        if (localStorage.logindata == null) { loginfunc() }
        else { alert('请勿重复登录!如需更换账号或Token过期请先登出再登录!') };
    }).on('click', '.stickerpp-user-img', function (e) {
        e.preventDefault();
        if (localStorage.logindata != null) { imgbindcheckfunc() }
        else { alert('请登录云同步账号后再进行绑定!') }
    }).on('click', '.stickerpp-user-reg', function (e) {
        e.preventDefault();
        if (localStorage.logindata == null) { regfunc() }
        else { alert("检测到您已登录!如需更换账号请先登出!"); }
    }).on('click', '.stickerpp-user-out', function (e) {
        e.preventDefault(); localStorage.removeItem('logindata'); GM_deleteValue('sppuid'); GM_deleteValue('spptoken');
        if (confirm("是否同时清除记住的云同步账号&密码?")) { GM_deleteValue('user'); GM_deleteValue('pass'); }
        alert(doneT);
    }).on('click', '.stickerpp-user-loc', function (e) {
        e.preventDefault(); temp = customize.lcimglists.length;
        if (temp == 0) { console.log('none') }
        else if (temp != 0) { t = customize.lcimglists; for (i = 0; i < t.length; i++) { $("#ng" + qufen + t[i]).attr("checked", true); } }
        else { alert(errT); console.log('当前已选本地贴纸组数据为:' + customize.lcimglists) };
        $container.find('.stickerpp-diy-panel').hide(); $this = $(this); $container.find('.stickerpp-user-loc').removeClass('stickerpp-user-loc-active');
        $this.addClass('stickerpp-user-loc-active'); $container.find('.stickerpp-loc-panel').hide(); $panel = $container.find(`.stickerpp-loc-panel`); $panel.show();
    }).on('click', '.stickerpp-user-oln', function (e) {
        e.preventDefault();
        StickerPPShowDialog();
    }).on('click', '.stickerpp-user-raw', function (e) {
        e.preventDefault(); StickerPPShowUpload();
    }).on('click', '.stickerpp-user-cfg', function (e) {
        e.preventDefault(); $container.find('.stickerpp-smile-panel').hide();
        // 载入个性化
        $("#kanbanimg" + qufen).attr("value", customize.kanbanimg);
        $("#kanbansize" + qufen).attr("value", customize.kanbansize);
        $("#kbopacity" + qufen).attr("value", customize.kbopacity);
        $("#onlineraw" + qufen).attr("value", customize.onlineraw);
        $("#imgapi" + qufen).attr("value", customize.imgapi);
        $("#olimglists" + qufen).attr("value", customize.olimglists);
        $("#notauthed" + qufen).attr("checked", customize.notauthed);
        $("#markdown" + qufen).attr("checked", customize.markdown);
        $panel = $container.find(`.stickerpp-conf-panel`); $panel.show();
    }).on('click', '.locbt', function (e) {
        i = e.target.value; customize.lcimglists ? temp = customize.lcimglists : temp = [];
        if (e.target.checked == false) { temp = temp.filter(item => { return item != i }) }
        else { temp.push(i); }
        customize.lcimglists = temp; localStorage.setItem('StickerConf', JSON.stringify(customize)); sessionStorage.removeItem('localSmile');
    }).on('click', '.stickerpp-res-kanbanimg', function () {
        customize.kanbanimg = defaultSConf.kanbanimg; localStorage.setItem('StickerConf', JSON.stringify(customize)); alert(resT);
    }).on('click', '.stickerpp-res-kanbansize', function () {
        customize.kanbansize = defaultSConf.kanbansize; localStorage.setItem('StickerConf', JSON.stringify(customize)); alert(resT);
    }).on('click', '.stickerpp-res-kbopacity', function () {
        customize.kbopacity = defaultSConf.kbopacity; localStorage.setItem('StickerConf', JSON.stringify(customize)); alert(resT);
    }).on('click', '.stickerpp-res-onlineraw', function () {
        customize.onlineraw = defaultSConf.onlineraw; localStorage.setItem('StickerConf', JSON.stringify(customize)); alert(resT);
    }).on('click', '.stickerpp-res-imgapi', function () {
        customize.imgapi = defaultSConf.imgapi; localStorage.setItem('StickerConf', JSON.stringify(customize)); alert(resT);
    }).on('click', '.stickerpp-res-olimglists', function () {
        customize.olimglists = defaultSConf.olimglists; localStorage.setItem('StickerConf', JSON.stringify(customize)); alert(resT);
    }).on('click', '.stickerpp-res-kanbanloc', function () {
        localStorage.removeItem('imgmovePc'); localStorage.removeItem('imgmoveMb'); alert(resT);
    }).on('click', '.stickerpp-res-hidekanban', function () {
        customize.kanbanimg = nullimg; localStorage.setItem('StickerConf', JSON.stringify(customize)); alert(doneT + '请刷新!');
    }).on('click', '.stickerpp-res-all', function () {
        temp = defaultSConf; temp.lcimglists = customize.lcimglists;
        localStorage.setItem('StickerConf', JSON.stringify(temp)); localStorage.removeItem('imgmovePc'); localStorage.removeItem('imgmoveMb');
        sessionStorage.removeItem('localSmile'); sessionStorage.removeItem('OnlineSmile'); alert(resT);
    }).on('click', '.Heditm', function (e) {
        e.preventDefault(); const cmd_val = this.getAttribute("data-edit").split(":"); let CQSHcon = false;
        if (window.getSelection) { CQSHcon = window.getSelection().toString(); }
        if (cmd_val[0] == 'hr') { document.execCommand("insertHTML", false, "<hr>"); }
        else if (cmd_val[0] == 'code' || cmd_val[0] == 'quote') {
            if (CQSHcon == false) { document.execCommand("insertHTML", false, `<br><fieldset><legend>${cmd_val[0]}:</legend>此处输入${cmd_val[0]}内容</fieldset><br>`); }
            else { document.execCommand("insertHTML", false, `<br><fieldset><legend>${cmd_val[0]}:</legend>${CQSHcon}</fieldset><br>`); }
        } else if (cmd_val[0] == 'sell') {
            if (CQSHcon == false) { document.execCommand("insertHTML", false, `<br><fieldset><legend>${cmd_val[0]}=10</legend>此处输入${cmd_val[0]}内容</fieldset><br>`); }
            else { document.execCommand("insertHTML", false, `<br><fieldset><legend>${cmd_val[0]}=10</legend>${CQSHcon}</fieldset><br>`); }
        } else if (cmd_val[0] == 'hide') {
            if (CQSHcon == false) { document.execCommand("insertHTML", false, `<br><fieldset><legend>${cmd_val[0]}=300</legend>此处输入${cmd_val[0]}内容</fieldset><br>`); }
            else { document.execCommand("insertHTML", false, `<br><fieldset><legend>${cmd_val[0]}=300</legend>${CQSHcon}</fieldset><br>`); }
        } else { document.execCommand(cmd_val[0], false, cmd_val[1]); }
    }).on('click', '#HEDurl', function (e) {
        e.preventDefault(); let URLcon = false;
        if (window.getSelection) { URLcon = window.getSelection().toString(); }
        if (URLcon == false) {
            let HEDurl = prompt("请输入要插入的url", 'https://');
            if (HEDurl) {
                let HEDurlT = prompt("请输入插入的url的描述文字,否则默认使用url作为描述文字", '');
                if (HEDurlT) {
                    if (HEDurlT.length > 2) { document.execCommand("insertHTML", false, '<a href="' + HEDurl + '">' + HEDurlT + '</a>'); }
                    else { document.execCommand('CreateLink', HEDurl, HEDurl) }
                } else { document.execCommand('CreateLink', HEDurl, HEDurl) }
            }
        }
        else {
            let HEDurlTU = prompt("请输入要插入的url,否则默认使用选中文本作为url链接", '');
            if (HEDurlTU) {
                if (HEDurlTU.length > 2) { document.execCommand('CreateLink', URLcon, HEDurlTU) }
                else { document.execCommand('CreateLink', URLcon, URLcon) }
            } else { document.execCommand('CreateLink', URLcon, URLcon) }
        }
    }).on('click', '#HEDimg', function (e) {
        e.preventDefault(); temp = prompt("请输入要插入的图片url", 'https://');
        if (temp) { document.execCommand("insertHTML", false, '<img src="' + temp + '" border="0">'); }
    }).on('click', '#HEDaudio', function (e) {
        e.preventDefault();
        let HEDaudio = prompt('请输入HTML5音频实际地址:\n(可直接输入网易云音乐的单曲地址,喵拉将自动转换为外链地址)', 'https://');
        if (HEDaudio) {
            temp = /^https?:\/\/music\.163\.com\/(?:#\/)?song\?id=(\d+)/i.exec(HEDaudio);
            if (temp) HEDaudio = `https://music.miaola.work/163/${temp[1]}.mp3`;
            temp = /^https?:\/\/www\.xiami\.com\/song\/(\w+)/i.exec(HEDaudio);
            if (temp) HEDaudio = `https://music.miaola.work/xiami/${temp[1]}.mp3`;
            document.execCommand("insertHTML", false, `<audio src="${HEDaudio}" controls="" preload="none" style="margin: 3px 0;">[你的浏览器不支持audio标签]</audio><br>`);
        }
    }).on('click', '#HEDvideo', function (e) {
        e.preventDefault();
        let HEDvideo = prompt('请输入HTML5视频实际地址:\n(可直接输入YouTube视频页面的地址,喵拉将自动转换为外链地址)', 'https://');
        if (HEDvideo) {
            temp = /^https?:\/\/(?:www\.)?youtube\.com\/watch\?v=([\w\-]+)/i.exec(HEDvideo);
            if (temp) HEDvideo = `https://video.miaola.work/youtube/${temp[1]}`;
            temp = /^https?:\/\/youtu\.be\/([\w\-]+)$/i.exec(HEDvideo);
            if (temp) HEDvideo = `https://video.miaola.work/youtube/${temp[1]}`;
            document.execCommand("insertHTML", false, `<video src="${HEDvideo}" controls="" preload="none" style="margin: 3px 0;">[你的浏览器不支持video标签]</video><br>`);
        }
    }).on('click', '#notauthed' + qufen, function (e) {
        customize.notauthed = e.target.checked; localStorage.setItem('StickerConf', JSON.stringify(customize));
    }).on('click', '#markdown' + qufen, function (e) {
        customize.markdown = e.target.checked; localStorage.setItem('StickerConf', JSON.stringify(customize));
    }).on('click', '#writeable' + qufen, function (e) {
        e.target.checked ? $("#olimglists" + qufen).attr("disabled", false) : $("#olimglists" + qufen).attr("disabled", true);
    }).on('click', '#realedit' + qufen, function (e) {
        $panel = $(`#Htmlediterpannel${qufen}`);
        if (rhview == false) {
            temp = $container.find(`#Htmleditarea${qufen}`);
            if (e.target.checked) {
                let TeContent = bb2html(textArea.value); temp[0].innerHTML = TeContent;
                if ($('#spp-reply-textarea').length > 0) {
                    let spptextarea = $('#spp-reply-textarea'), sppcontent = bb2html(spptextarea[0].value); temp[0].innerHTML = sppcontent;
                }
                $panel.show(); $('textarea').hide(); $('#editor-button').hide(); customize.realedit = true, realedit = true; localStorage.setItem('StickerConf', JSON.stringify(customize));
            }
            else {
                if (realedits == false) {
                    realedits = true; $('textarea').show(); $('#editor-button').show(); customize.realedit = false; localStorage.setItem('StickerConf', JSON.stringify(customize));
                }
                else {
                    $('textarea').show(); $('#editor-button').show();
                    HeContent = html2bb(temp[0].innerHTML); textArea.innerHTML = HeContent; textArea.innerText = HeContent; textArea.value = HeContent;
                    if ($('#spp-reply-textarea').length > 0) {
                        let spptextarea = $('#spp-reply-textarea'); spptextarea[0].innerHTML = HeContent; spptextarea[0].innerText = HeContent; spptextarea[0].value = HeContent
                    }
                    $panel.hide(); customize.realedit = false; realedit = false; localStorage.setItem('StickerConf', JSON.stringify(customize));
                }
            }
        }
        else if (rhview == true) {
            alert('检测到当前页面自带可视化编辑器!请使用自带的可视化编辑器!');
        }
    }).on('blur', '#Htmleditarea' + qufen, function (e) {
        HeContent = html2bb(e.target.innerHTML);
        textArea.innerHTML = HeContent;
        textArea.innerText = HeContent;
        textArea.value = HeContent;
    }).on('keydown', '#Htmleditarea' + qufen, function (e) {
        if (e.keyCode === 13) { document.execCommand('insertHTML', false, '<br>&nbsp;'); }
    }).on('paste', '#Htmleditarea' + qufen, function (e) {
        temp = event.clipboardData.files;
        if (temp.length > 0) {
            event.preventDefault();
            const pd = event.clipboardData.items[0];
            if (!(/^image\/[jpeg|png|gif|jpg]/.test(pd.type))) { return; }
            const file = event.clipboardData.items[0].getAsFile()
            temp = JSON.stringify(new Date().getTime());
            const files = new File([file], temp + "." + file.name.substr(file.name.lastIndexOf('.') + 1), { type: file.type, lastModified: file.lastModified, });
            formData = new FormData(); reader = new FileReader(); formData.append('file', files);
            reader.readAsDataURL(files); upimgfunc(formData, textArea);
        }
        else;
    }).on('blur', '#kanbanimg' + qufen, function (e) {
        customize.kanbanimg = e.target.value; localStorage.setItem('StickerConf', JSON.stringify(customize));
    }).on('blur', '#kanbansize' + qufen, function (e) {
        customize.kanbansize = e.target.value; localStorage.setItem('StickerConf', JSON.stringify(customize));
    }).on('blur', '#kbopacity' + qufen, function (e) {
        customize.kbopacity = e.target.value; localStorage.setItem('StickerConf', JSON.stringify(customize));
    }).on('blur', '#onlineraw' + qufen, function (e) {
        customize.onlineraw = e.target.value; localStorage.setItem('StickerConf', JSON.stringify(customize));
    }).on('blur', '#imgapi' + qufen, function (e) {
        customize.imgapi = e.target.value; localStorage.setItem('StickerConf', JSON.stringify(customize));
    }).on('blur', '#olimglists' + qufen, function (e) {
        e.target.value == "" ? temp = [] : temp = qc(e.target.value.match(/\d+/g).map(o => +o));
        $.ajax({ url: customize.onlineraw + 'GetListR&page=1&perpage=1', type: 'POST', contentType: false, processData: false, })
            .done(data => {
                if (data.ret == 200) {
                    for (i = 0; i < temp.length; i++) { if (temp[i] <= data.data.total) { get1stfunc(temp[i]); } }
                } else { alert('发生' + data.ret + '错误,' + data.msg); }
            })
            .fail(data => { alert(errT); console.log(data); });
    }).on('click', '.stickerpp-loc-close', function () {
        $container.find('.stickerpp-loc-panel').hide();
    }).on('click', '.stickerpp-conf-close', function () {
        $container.find('.stickerpp-conf-panel').hide();
    }).find('.stickerpp-close-panel').click(function () {
        $container.find('.stickerpp-smile-panel').hide();
        $container.find('.stickerpp-diy-panel').hide();
        $container.find('.stickerpp-acc-panel').hide();
        $container.find('.stickerpp-bqz-panel').hide();
    });
    // 文本区域直接上传图片(文件名使用时间戳)并预览
    document.querySelector('textarea').addEventListener('paste', (event) => {
        temp = event.clipboardData.files;
        if (temp.length > 0) {
            event.preventDefault(); const pd = event.clipboardData.items[0];
            if (!(/^image\/[jpeg|png|gif|jpg]/.test(pd.type))) { return; }
            file = event.clipboardData.items[0].getAsFile();
            temp = JSON.stringify(new Date().getTime());
            const files = new File([file], temp + "." + file.name.substr(file.name.lastIndexOf('.') + 1), { type: file.type, lastModified: file.lastModified, });
            formData = new FormData(); reader = new FileReader(); formData.append('file', files);
            reader.onload = function ({ target }) {
                setTimeout(() => { $(".stickerppkanban").attr('src', target.result) }, 400)
                setTimeout(() => {
                    if (isKfMobile == true) { $(".stickerppkanban").attr('src', 'https://sticker.inari.site/favicon.ico') }
                    else { $(".stickerppkanban").attr('src', customize.kanbanimg) }
                }, 4000)
            }
            reader.readAsDataURL(files); upimgfunc(formData, textArea);
        }
    });
};


/**
 * 方法功能区
 * @param textArea 文本框
 */
// 表情商店方法
const StickerPPShowUpload = function () {
    $dialog = $("#StickerPP-shop-dialog")[0]; $("body").append(StickerPPUploadHtml); $root = $("#StickerPP-shop-dialog .StickerPP-list-content");
    if (localStorage.logindata != null) {
        loginf = JSON.parse(localStorage.logindata); aId = loginf[0]; aToken = loginf[1];
        $.ajax({ url: cApi + 'CheckSession&user_id=' + aId + '&token=' + aToken, type: 'POST', dataType: 'json' })
            .done(data => {
                if (data.ret == 200) {
                    temp = data.data.is_login;
                    if (temp == true) { $root.append($(StickerPPlogedUp)); }
                    else { $root.append($(StickerPPunlogUp)); }
                }
                else { $root.append($(StickerPPunlogUp)); }
            })
            .fail(data => { $root.append($(StickerPPunlogUp)); console.log(data) });
    }
    else { $root.append($(StickerPPunlogUp)); }; $root.append($(StickerPPtextUp));
}
const StickerPPShowDialog = function () { $dialog = $("#StickerPP-shop-dialog")[0]; $("body").append(StickerPPDialogHtml); StickerPPLoadSticker(1); }
const StickerPPLoadSticker = function (thePage) {
    let success = function (data) { loadStickerList(data.data.items); loadStickerListPagination(data.data); };
    customize.notauthed == false ? temp = "GetList" : temp = "GetListR";
    $.ajax({ url: olApi + temp + '&page=' + thePage + '&perpage=20', type: 'POST', dataType: 'json' })
        .done(data => {
            if (data.ret == 200) { success(data); }
            else { alert(data.msg + ' 操作' + renT + data.ret) }
        })
        .fail(data => { alert(errT); console.log(data) });
}
const loadStickerList = function (items) {
    $root = $("#StickerPP-shop-dialog .StickerPP-list-content"); $root.empty();
    $.each(items, function (_, o) {
        temp = JSON.parse(o.content); $node = $(StickerPPItemHtml).prop("title", temp.desc).data("id", o.id).data("content", o.content)
            .find("img").prop("src", temp.cover).end().find(".sticker-item-name").text(o.title).end(); $root.append($node);
    });
}
const loadStickerListPagination = function (data) {
    let total = Math.ceil(data.total / 20), page = data.page, id; $root = $("#StickerPP-shop-dialog .StickerPP-list-pagination");
    if (page != 1) { $root.append($(StickerPPPaginationItemHtml).data("id", 1).text("回首页")); $root.append($(prevNextPageHtml).data("id", page - 1).text("上一页")); }
    if (total < 12 || page < 7) {
        for (i = 1; i < page; ++i) { id = i; $node = $(StickerPPPaginationItemHtml).data("id", id).text(id); $root.append($node); }
        $node1 = $(StickerPPNowPageHtml).data("id", page).text(page); $root.append($node1);
        for (i = page; i < total; ++i) { id = i + 1; $node = $(StickerPPPaginationItemHtml).data("id", id).text(id); $root.append($node); }
    }
    else if (total > 11 && page + 5 < total) {
        for (i = page - 5; i < page; ++i) { id = i; $node = $(StickerPPPaginationItemHtml).data("id", id).text(id); $root.append($node); }
        $node1 = $(StickerPPNowPageHtml).data("id", page).text(page); $root.append($node1);
        for (i = page; i < page + 5; ++i) { id = i + 1; $node = $(StickerPPPaginationItemHtml).data("id", id).text(id); $root.append($node); }
    }
    else if (total > 11 && page + 6 > total) {
        for (i = total - 10; i < page; ++i) { id = i; $node = $(StickerPPPaginationItemHtml).data("id", id).text(id); $root.append($node); }
        $node1 = $(StickerPPNowPageHtml).data("id", page).text(page); $root.append($node1);
        for (i = page; i < total; ++i) { id = i + 1; $node = $(StickerPPPaginationItemHtml).data("id", id).text(id); $root.append($node); }
    }
    if (page != total) { $root.append($(prevNextPageHtml).data("id", page + 1).text("下一页")); $root.append($(StickerPPPaginationItemHtml).data("id", total).text("去末页")); }
}
// 在KF论坛:直接显示表情贴纸增强插件所属域名的图片而不是显示【请手动点击打开本图片】,修复旧的失效的表情贴纸的显示。
if (isKF == true) {
    s = document.getElementsByTagName("img");
    for (i = 0; i < s.length; i++) {
        s[i].src = s[i].src.replace(/mistake.tech\/emote/g, "sticker.inari.site");
        s[i].src = s[i].src.replace(/http:\/\/o6smnd6uw.bkt.clouddn.com\/xds3\/akari/g, "https://sticker.inari.site/akarin/akarin");
        s[i].src = s[i].src.replace(/http:\/\/o6smnd6uw.bkt.clouddn.com\/xds\/2233/g, "https://sticker.inari.site/bili/2233");
        s[i].src = s[i].src.replace(/http:\/\/o6smnd6uw.bkt.clouddn.com\/lovelive\/Lovelive2nd/g, "https://sticker.inari.site/lovelive/Lovelive2nd");
        s[i].src = s[i].src.replace(/http:\/\/smilell2.eclosionstudio.com\/Small\/Lovelive2nd/g, "https://sticker.inari.site/lovelive/Lovelive2nd");
    }
    document.body.querySelectorAll('.readtext a').forEach(i => {
        if (i.innerHTML === '<span class=\"k_f18\">请手动点击打开本图片</span>') {
            t = document.createElement("img"); t.src = i.href;
            if (t.src.match(/https:\/\/sticker.inari.site/)) { i.parentElement.replaceChild(t, i); }
            else if (t.src.match(/http:\/\/tb2.bdstatic.com\/tb\/editor\/images\/face/)) { i.parentElement.replaceChild(t, i); }
        }
    });
  /*  document.body.querySelectorAll('a').forEach(i => {
        if (i.innerHTML === '&lt;	wind_code_1	&gt;') {
            t = document.createElement("img"); t.src = i.href;
             i.parentElement.replaceChild(t, i);
        }
    });*/
    //<a href="https://sm.ms/image/1QrdSctTsVvjoRM" target="_blank">&lt;	wind_code_1	&gt;</a>
}
// 修复实时编辑模式下phpwind的回复某楼
if(isKfMobile==false){
$(document).on('click', "a[title='回复此楼']", function (e) {
    temp = e.target.getAttribute("onclick").replace(/postreply\('*([^\'\"]*)','[^\'\"]*'\);/g, '$1');
    $('.StickerPPHtmlEditer')[0].innerHTML += `<fieldset><legend>quote:</legend>${temp}</fieldset><br>`;})
    .on('click', "a[title='多重回复']", function () { if (realedit == true) { realedits = false }; $('textarea').show(); $('.StickerPPHtmlEditerP').hide(); })
    .on("change", "#attachment_1", function (e) { num = 0; readFile(e, num); })
    .on("change", "#attachment_2", function (e) { num = 1; readFile(e, num); })
    .on("change", "#attachment_3", function (e) { num = 2; readFile(e, num); })
    .on("change", "#attachment_4", function (e) { num = 3; readFile(e, num); })
    .on("change", "#attachment_5", function (e) { num = 4; readFile(e, num); })
    .on("change", "#attachment_6", function (e) { num = 5; readFile(e, num); })
    .on("change", "#attachment_7", function (e) { num = 6; readFile(e, num); })
    .on("change", "#attachment_8", function (e) { num = 7; readFile(e, num); })
    .on("change", "#attachment_9", function (e) { num = 8; readFile(e, num); })
    .on("change", "#attachment_10", function (e) { num = 9; readFile(e, num); })
    .on("click", "#att_span1 .abtn", function () { num = 0; attspan(num); })
    .on("click", "#att_span2 .abtn", function () { num = 1; attspan(num); })
    .on("click", "#att_span3 .abtn", function () { num = 2; attspan(num); })
    .on("click", "#att_span4 .abtn", function () { num = 3; attspan(num); })
    .on("click", "#att_span5 .abtn", function () { num = 4; attspan(num); })
    .on("click", "#att_span6 .abtn", function () { num = 5; attspan(num); })
    .on("click", "#att_span7 .abtn", function () { num = 6; attspan(num); })
    .on("click", "#att_span8 .abtn", function () { num = 7; attspan(num); })
    .on("click", "#att_span9 .abtn", function () { num = 8; attspan(num); })
    .on("click", "#att_span10 .abtn", function () { num = 9; attspan(num); });
}
else if(isKfMobile==true){
    $(document).on('click', "a[title='回复此楼']", function (e) {
    temp = e.target.getAttribute("onclick").replace(/postreply\('*([^\'\"]*)','[^\'\"]*'\);/g, '$1');
    $('.StickerPPHtmlEditer')[0].innerHTML += `<fieldset><legend>quote:</legend>${temp}</fieldset><br>`;})
    .on('click', "button[title='多重回复']", function () { if (realedit == true) { realedits = false }; $('textarea').show(); $('.StickerPPHtmlEditerP').hide(); })
    .on("change", "input[name='attachment_1']", function (e) { num = 0; readFile(e, num); })
    .on("change", "input[name='attachment_2']", function (e) { num = 1; readFile(e, num); })
    .on("change", "input[name='attachment_3']", function (e) { num = 2; readFile(e, num); })
    .on("change", "input[name='attachment_4']", function (e) { num = 3; readFile(e, num); })
    .on("change", "input[name='attachment_5']", function (e) { num = 4; readFile(e, num); })
    .on("change", "input[name='attachment_6']", function (e) { num = 5; readFile(e, num); })
    .on("change", "input[name='attachment_7']", function (e) { num = 6; readFile(e, num); })
    .on("change", "input[name='attachment_8']", function (e) { num = 7; readFile(e, num); })
    .on("change", "input[name='attachment_9']", function (e) { num = 8; readFile(e, num); })
    .on("change", "input[name='attachment_10']", function (e) { num = 9; readFile(e, num); })
    .on("click", "#att_span1 .abtn", function () { num = 0; attspan(num); })
    .on("click", "#att_span2 .abtn", function () { num = 1; attspan(num); })
    .on("click", "#att_span3 .abtn", function () { num = 2; attspan(num); })
    .on("click", "#att_span4 .abtn", function () { num = 3; attspan(num); })
    .on("click", "#att_span5 .abtn", function () { num = 4; attspan(num); })
    .on("click", "#att_span6 .abtn", function () { num = 5; attspan(num); })
    .on("click", "#att_span7 .abtn", function () { num = 6; attspan(num); })
    .on("click", "#att_span8 .abtn", function () { num = 7; attspan(num); })
    .on("click", "#att_span9 .abtn", function () { num = 8; attspan(num); })
    .on("click", "#att_span10 .abtn", function () { num = 9; attspan(num); });
}

function readFile(e, num) {
    FileData = e.target.files[0]; if (!/image\/\w+/.test(FileData.type)) { uupath[num] = uploadfile; }
    else { temp = new FileReader(); temp.readAsDataURL(FileData); temp.onload = function (e) { uupath[num] = this.result; } }
}
function attspan(num) { $('.StickerPPHtmlEditer')[num].innerHTML += `<img src="${uupath[num]}" type="upload_1" width="240">`; }
// html2bb&bb2html
function html2bb(str) {
    str = str.replace(/<img[^>]*smile=\"(\d+)\"[^>]*>/ig, '[s:$1]');
    str = str.replace(/<img[^>]*type=\"(attachment|upload)\_(\d+)\"[^>]*>/ig, '[$1=$2]');
    let code_htm = new Array();
    str = str.replace(/(\r\n|\n|\r)/ig, '');
    str = str.replace(/<p[^>\/]*\/>/ig, '\n');
    str = str.replace(/\son[\w]{3,16}\s?=\s*([\'\"]).+?\1/ig, '');
    str = str.replace(/<fieldset><legend>(Quote|code):<\/legend>(.+?)<\/fieldset>/ig, '[$1]$2[/$1]');
    str = str.replace(/<fieldset><legend>(sell|hide)=(.+?)<\/legend>(.+?)<\/fieldset>/ig, '[$1=$2]$3[/$1]');
    str = str.replace(/<(audio|video)[^>]*src=[\'\"\s]*([^\'\"]*)[^>]*>(.+?)<\/(audio|video)>/ig, '[$1]$2[/$1]');
    str = str.replace(/<(audio|video) src=[\'\"\s]*([^\'\"]*) controls="" preload="none" style="margin: 3px 0;">\[你的浏览器不支持(audio|video)标签\]<\/(audio|video)>/ig, '[$1]$2[/$1]');
    str = str.replace(/<hr[^>]*>/ig, '[hr]');
    str = str.replace(/<(sub|sup|u|strike|b|i|pre)>/ig, '[$1]');
    str = str.replace(/<\/(sub|sup|u|strike|b|i|pre)>/ig, '[/$1]');
    str = str.replace(/<(\/)?strong>/ig, '[$1b]');
    str = str.replace(/<(\/)?em>/ig, '[$1i]');
    str = str.replace(/<(\/)?blockquote([^>]*)>/ig, '[$1blockquote]');
    str = str.replace(/<img[^>]*src=[\'\"\s]*([^\'\"]+)[^>]*>/ig, '[img]$1[/img]');
    str = str.replace(/<a[^>]*href=[\'\"\s]*([^\'\"]*)[^>]*>(.+?)<\/a>/ig, '[url=$1]$2[/url]');
    str = str.replace(/<h([1-6]+)([^>]*)>(.*?)<\/h\1>/ig, function ($1, $2, $3, $4) { return h($3, $4, $2); });
    str = searchtag('table', str, 'table', 1);
    str = searchtag('font', str, 'Font', 1);
    str = searchtag('div', str, 'dsc', 1);
    str = searchtag('p', str, 'p', 1);
    str = searchtag('span', str, 'dsc', 1);
    str = searchtag('ol', str, 'list', 1);
    str = searchtag('ul', str, 'list', 1);
    for (i in code_htm) { str = str.replace("[\twind_phpcode_" + i + "\t]", code_htm[i]); }
    str = str.replace(/&nbsp;/ig, ' ');
    str = str.replace(/<br[^>]*>/ig, '\n');
    str = str.replace(/<[^>]*?>/ig, '');
    str = str.replace(/&amp;/ig, '&');
    str = str.replace(/&quot;/ig, '"');
    str = str.replace(/&lt;/ig, '<');
    str = str.replace(/&gt;/ig, '>');
    return str;
}
function bb2html(str) {
    let code_htm = new Array();
    str = str.replace(/&(?!(#[0-9]+|[a-z]+);)/ig, '&amp;');
    str = str.replace(/</ig, '&lt;');
    str = str.replace(/>/ig, '&gt;');
    str = str.replace(/\n/ig, '<br />');
    str = str.replace(/\[(quote|code)\](.+?)\[\/(quote|code)\]/ig, '<fieldset><legend>$1:</legend>$2</fieldset>');
    str = str.replace(/\[(sell|hide)=(.+?)\](.+?)\[\/(sell|hide)\]/ig, '<fieldset><legend>$1=$2</legend>$3</fieldset>');
    str = str.replace(/\[(audio|video)\](.+?)\[\/(audio|video)\]/ig, '<$1 src="$2" controls="" preload="none" style="margin: 3px 0;">[你的浏览器不支持$1标签]</$1>');
    str = str.replace(/\[hr\]/ig, '<hr />');
    str = str.replace(/\[\/(size|color|font|backcolor)\]/ig, '</font>');
    str = str.replace(/\[(sub|sup|u|i|strike|b|blockquote|li)\]/ig, '<$1>');
    str = str.replace(/\[(quote|code)\]/ig, '<fieldset><legend>$1:</legend>');
    str = str.replace(/\[\/(quote|code)\]/ig, '</fieldset>');
    str = str.replace(/\[\/(sub|sup|u|i|strike|b|blockquote|li)\]/ig, '</$1>');
    str = str.replace(/\[size=(\d+?)\]/ig, '<font size="$1">');
    str = str.replace(/\[color=([^\[\<]+?)\]/ig, '<font color="$1">');
    str = str.replace(/\[backcolor=([^\[\<]+?)\]/ig, '<font style="background-color:$1">');
    str = str.replace(/\[font=([^\[\<]+?)\]/ig, '<font face="$1">');
    str = str.replace(/\[list=(a|A|1)\](.+?)\[\/list\]/ig, '<ol type="$1">$2</ol>');
    str = str.replace(/\[(\/)?list\]/ig, '<$1ul>');
    str = str.replace(/\[(attachment|upload)=(\d+)\]/ig, function ($1, $2, $3) { return attpath($3, $2); });
    str = str.replace(/\[s:(\d+)\]/ig, function ($1, $2) { return smilepath($2); });
    str = str.replace(/\[img\]([^\[]*)\[\/img\]/ig, '<img src="$1" border="0" />');
    str = str.replace(/\[url=([^\]]+)\]([^\[]+)\[\/url\]/ig, '<a href="$1">$2</a>');
    str = searchtag('table', str, 'tableshow', 2);
    str = str.replace(/\[\/align\]/ig, '</p>');
    str = str.replace(/\[(\/)?h([1-6])\]/ig, '<$1h$2>');
    str = str.replace(/\[align=(left|center|right|justify)\]/ig, '<p align="$1">');
    for (i in code_htm) { str = str.replace("[\twind_phpcode_" + i + "\t]", code_htm[i]); }
    return str;
}
// 杂项
function attpath(attid, type) {
    let path = '', upath = false;
    if (type == 'attachment' ) { path = getObj('atturl_' + attid).innerHTML; }
    else if (type == 'upload' ) {
        FileData = $('#attachment_' + attid)[0].files[0];
        if (!/image\/\w+/.test(FileData.type)) { path = ''; upath = false; }
        else { path = uupath[attid - 1]; upath = true; }
    }
    if (!path) { return '[' + type + '=' + attid + ']'; }
    else {
        if (!path.match(/\.(jpg|gif|png|bmp|jpeg)$/ig) && upath == false) { path = imgpath + '/' + stylepath + '/file/zip.gif'; }
        img = imgmaxwh(path, 320);
        if (img.width == 0) { return '<img src="' + path + '" type="' + type + '_' + attid + '" width="240" />'; }
        else { return '<img src="' + path + '" type="' + type + '_' + attid + '" width="' + img.width + '" />'; }
    }
}
function imgmaxwh(url, maxwh) {
    img = new Image(); img.src = url; if (img.width > maxwh || img.width > maxwh) { img.width = (img.width / img.height) > 1 ? maxwh : maxwh * img.width / img.height; }
    return img;
}
function smilepath(NewCode) {
    if (isKF) {
        let stemp = NewCode - 9;
        if (NewCode < 19) { return '<img src="/' + kfImgPath + '/post/smile/em/em0' + stemp + '.gif" smile="' + NewCode + '" />'; }
        else { return '<img src="/' + kfImgPath + '/post/smile/em/em' + stemp + '.gif" smile="' + NewCode + '" />'; }
    }
    else { return '<img src="' + imgpath + '/post/smile/smallface/face' + NewCode + '.gif" smile="' + NewCode + '" />'; }
}
function h(style, code, size) { size = 7 - size; code = '[size=' + size + '][b]' + code + '[/b][/size]'; return p(style, code); }
function p(style, code) {
    if (style.indexOf('align=') != -1) {
        style = findvalue(style, 'align=');
        style = style.replace(/[[^>]*(left|center|right|justify)[^>]*]/ig, '$1');
        code = '[align=' + style + ']' + code + '[/align]';
    }
    else { code += "\n"; }
    return code;
}
function dsc(style, code) {
    temp = [
        ['align', 1, 'align='],
        ['align', 1, 'text-align:'],
        ['backcolor', 2, 'background-color:'],
        ['color', 2, 'color:'],
        ['font', 1, 'font-family:'],
        ['b', 0, 'font-weight:', 'bold'],
        ['i', 0, 'font-style:', 'italic'],
        ['u', 0, 'text-decoration:', 'underline'],
        ['strike', 0, 'text-decoration:', 'line-through']
    ]; style = style.toLowerCase();
    for (i = 0; i < temp.length; i++) {
        begin = style.indexOf(temp[i][2]);
        if (begin == -1) { continue; }
        let value = findvalue(style, temp[i][2]);
        if (temp[i][1] == 2 && value.indexOf('rgb') != -1) { value = colorToRgb(value); }
        if (temp[i][1] == 0) { if (value == temp[i][3]) { code = '[' + temp[i][0] + ']' + code + '[/' + temp[i][0] + ']'; } }
        else { code = '[' + temp[i][0] + '=' + value + ']' + code + '[/' + temp[i][0] + ']'; }
        style = style.replace(temp[i][2], '');
    }
    code = code.replace(/([^>]*)\[align=(left|center|right|justify)\]([^>]*)/ig, '[align=$2]$1$3');
    code = code.replace(/([^>]*)\[\/align\]([^>]*)/ig, '$1$2[/align]');
    return code;
}
function searchtag(tagname, str, action, type) {
    let tag; if (type == 2) { tag = ['[', ']']; }
    else { tag = ['<', '>']; }
    let head = tag[0] + tagname, head_len = head.length, foot = tag[0] + '/' + tagname + tag[1], foot_len = foot.length, strpos = 0;
    do {
        let strlower = str.toLowerCase(); begin = strlower.indexOf(head, strpos);
        if (begin == -1) { break; }
        let strlen = str.length;
        for (i = begin + head_len; i < strlen; i++) { if (str.charAt(i) == tag[1]) break; }
        if (i >= strlen) break;
        let firsttag = i, style = str.substr(begin + head_len, firsttag - begin - head_len), end = strlower.indexOf(foot, firsttag);
        if (end == -1) break;
        let nexttag = strlower.indexOf(head, firsttag);
        while (nexttag != -1 && end != -1) { if (nexttag > end) break; end = strlower.indexOf(foot, end + foot_len); nexttag = strlower.indexOf(head, nexttag + head_len); }
        if (end == -1) { strpos = firsttag; continue; }
        firsttag++;
        let findstr = str.substr(firsttag, end - firsttag);
        str = str.substr(0, begin) + eval(action)(style, findstr, tagname) + str.substr(end + foot_len);
        strpos = begin;
    }
    while (begin != -1); return str;
}
function tableshow(style, str) {
    let width; if (style.substr(0, 1) == '=') { width = style.substr(1); }
    else { width = '100%'; }
    str = str.replace(/\[td=(\d{1,2}),(\d{1,2})(,(\d{1,3}%?))?\]/ig, '<td colspan="$1" rowspan="$2" width="$4">');
    str = str.replace(/\[(tr|td)\]/ig, '<$1>');
    str = str.replace(/\[\/(tr|td)\]/ig, '</$1>');
    return '<table width=' + width + ' class="t" cellspacing=0>' + str + '</table>';
}
function findvalue(style, find) {
    let firstpos = style.indexOf(find) + find.length, len = style.length, start = 0, i;
    for (i = firstpos; i < len; i++) {
        t = style.charAt(i);
        if (start == 0) {
            if (t == '"' || t == "'") { start = i + 1; }
            else if (t != ' ') { start = i; }
            continue;
        }
        if (t == '"' || t == "'" || t == ';') { break; }
    }
    return style.substr(start, i - start);
}
function table(style, str) {
    str = str.replace(/<tr([^>]*)>/ig, '[tr]');
    str = str.replace(/<\/tr>/ig, '[/tr]');
    str = searchtag('td', str, 'td', 1);
    str = searchtag('th', str, 'td', 1);
    temp = ['width=', 'width:']; s = '';
    style = style.toLowerCase();
    for (i in temp) {
        if (style.indexOf(temp[i]) == -1) { continue; }
        s = '=' + findvalue(style, temp[i]); break;
    }
    return '[table' + s + ']' + str + '[/table]';
}
function td(style, str) {
    if (style == '') { return '[td]' + str + '[/td]'; }
    let colspan = 1, rowspan = 1, width = '', value;
    if (style.indexOf('colspan=') != -1) { value = findvalue(style, 'colspan='); if (value > 1) colspan = value; }
    if (style.indexOf('rowspan=') != -1) { value = findvalue(style, 'rowspan='); if (value > 1) rowspan = value; }
    if (style.indexOf('width=') != -1) { width = findvalue(style, 'width='); }
    if (width == '') { return (colspan == 1 && rowspan == 1 ? '[td]' : '[td=' + colspan + ',' + rowspan + ']') + str + '[/td]'; }
    else { return '[td=' + colspan + ',' + rowspan + ',' + width + ']' + str + '[/td]'; }
}
function list(type, code, tagname) {
    code = code.replace(/<(\/)?li>/ig, '[$1li]');
    if (tagname == 'ul') { return '[list]' + code + '[/list]'; }
    if (type && type.indexOf('type=') != '-1') {
        type = findvalue(type, 'type=');
        if (type != 'a' && type != 'A' && type != '1') { type = '1'; }
        return '[list=' + type + ']' + code + '[/list]';
    } else { return '[list=1]' + code + '[/list]'; }
}
function Font(style, str) {
    temp = { 'size': 'size=', 'color': 'color=', 'font': 'face=', 'backcolor': 'background-color:' };
    style = style.toLowerCase();
    for (i in temp) {
        t = style.indexOf(temp[i]); if (t == -1) { continue; }
        s = findvalue(style, temp[i]); if (in_array(i, ['backcolor', 'color']) && s.indexOf('rgb') != -1) { s = colorToRgb(s); }
        str = '[' + i + '=' + s + ']' + str + '[/' + i + ']';
    }
    return str;
}
function colorToRgb(v) {
	if (!v) return '';
    let red,green,blue;
	function hex(d) {
		return (d < 16) ? ("0" + d.toString(16)) : d.toString(16);
	}
	if (typeof v == "number") {
		red = v & 0xFF;
		green = (v >> 8) & 0xFF;
		blue = (v >> 16) & 0xFF;
		return "#" + hex(red) + hex(green) + hex(blue);
	}
	if (v.substr(0, 3) == "rgb") {
		let re = /rgb\s*\(\s*([0-9]+)\s*,\s*([0-9]+)\s*,\s*([0-9]+)\s*\)/;
		if (v.match(re)) {
			red = parseInt(RegExp.$1);
			green = parseInt(RegExp.$2);
			blue = parseInt(RegExp.$3);
			return "#" + hex(red) + hex(green) + hex(blue);
		}
		return null;
	}
	if (v.substr(0, 1) == "#") {
		return v;
	}
	return null;
}
// CURD方法
function usercfunc() {
    temp = prompt("请输入要添加的贴纸的URL,添加多个请用半角,隔开贴纸URL(添加后刷新页面生效)", "https://sticker.inari.site/inari.png");
    if (!temp) return; t = temp.split(','); s = [];
    for (i = 0; i < t.length; i++) {
        if (/(http:\/\/|https:\/\/).*.(png|jpg|jpeg|gif|webp|bmp|tif)+.*$/i.test(t[i])) { s.push(t[i]); }
        else if (/[a-zA-Z0-9\-\.]+\.+[a-zA-Z]+\/.*.(png|jpg|jpeg|gif|webp|bmp|tif)+.*$/i.test(t[i])) { s.push('https://' + t[i]); }
        else if (/[A-Za-z0-9\_\/]+\/+[0-9\/]+.(png|jpg|jpeg|gif|webp)$/i.test(t[i])) { s.push('https://sticker.inari.site/usr/' + t[i]); }
    }
    if (s.length < t.length) { alert('可能存在图片url错误,' + igoT); }
    if (s.length > 0) {
        temp = []; if (localStorage.userimgst) {
            try { temp = JSON.parse(localStorage.userimgst); }
            catch (ex) { console.log(ex); temp = []; }
        }
        temp = [...temp, ...s]; localStorage.setItem('userimgst', JSON.stringify(temp)); alert(doneT); location.reload();
    }
}
function userufunc() {
    i = prompt("请输入要替换的贴纸的序号", "1");
    if (/[0-9]$/i.test(i)) {
        temp = JSON.parse(localStorage.userimgst);
        if (i > temp.length) { alert('序号超出贴纸数,' + igoT); }
        else if (i == 0) { alert(igoT); } else if (i <= temp.length) {
            s = prompt("请输入用于替换的图片url", "https://sticker.inari.site/inari.png");
            if (/(http:\/\/|https:\/\/).*.(png|jpg|jpeg|gif|webp|bmp|tif)+.*$/i.test(s)) {
                if (confirm('确定替换序号为' + i + '的贴纸吗?这是最后一次确认!')) {
                    temp[i - 1] = s; localStorage.setItem('userimgst', JSON.stringify(temp));
                    alert(doneT); location.reload();
                }
            } else if (s == null) { console.log('none') } else { alert(igoT); }
        } else if (i == null) { } else { alert(igoT); }
    }
}
function userrfunc() {
    if (UserSmileList != "https://sticker.inari.site/null.jpg") { prompt("自定义表情贴纸已导出,请复制", UserSmileList) }
    else { alert("自定义表情贴纸为空!"); }
}
function userdfunc() {
    if (confirm('确定删除自定义表情贴纸吗?')) {
        if (confirm('【确定】清空自定义贴纸,【取消】删除指定贴纸。')) {
            if (confirm('确定【清空自定义贴纸】吗?这是【最后一次】确认')) { localStorage.removeItem('userimgst'); alert('已清空自定义贴纸'); location.reload(); }
        }
        else {
            t = prompt("请输入要删除的贴纸的序号", "1");
            if (/[0-9]$/i.test(t)) {
                temp = JSON.parse(localStorage.userimgst);
                if (t > temp.length) { alert('序号超出贴纸数,' + igoT); }
                else if (t == 0) { alert(igoT); }
                else if (t <= temp.length) {
                    if (confirm('确定删除【序号为' + t + '的贴纸】吗?这是【最后一次】确认!')) {
                        for (i = t; i <= temp.length; i++) { temp[i - 1] = temp[i]; }
                        temp.pop(); localStorage.setItem('userimgst', JSON.stringify(temp));
                        alert(doneT); location.reload();
                    }
                } else { alert(igoT) }
            } else if (t == null) { } else { alert(igoT) }
        }
    }
}
// 注册&登录方法
function loginfunc() {
    if (GM_getValue('sppuid', false) != false && GM_getValue('spptoken', false) != false) {
        if (confirm('检测到已在其他网站登录云同步账号,是否使用快速登录?')) {
            localStorage.setItem('logindata', JSON.stringify([GM_getValue('sppuid', false), GM_getValue('spptoken', false)])); imgbindcheckfunc(); return;
        }
    }
    user = prompt("用户名", GM_getValue('user', 'username'));
    if (user != null && user.length <= 50) {
        pass = prompt("密码", GM_getValue('pass', 'password'))
        if (pass != null && pass.length >= 6 && pass.length <= 20) {
            $.ajax({ url: cApi + 'Login&username=' + user + '&password=' + pass, type: 'POST', dataType: 'json' })
                .done(data => {
                    if (data.ret == 200) {
                        temp = data.data; GM_setValue('user', user); GM_setValue('pass', pass); GM_setValue('sppuid', temp.user_id); GM_setValue('spptoken', temp.token);
                        if (temp.is_login == true) { localStorage.setItem('logindata', JSON.stringify([temp.user_id, temp.token])); imgbindcheckfunc(); }
                        else if (temp.is_login == false) { alert('Oops!用户名或密码错误!请检查!') }
                    }
                    else { alert('Oops!' + data.ret + '错误!' + data.msg) }
                })
                .fail(data => { alert(errT); console.log(data) });
        }
        else { pass == null ? alert('登录' + exiT) : alert('密码' + lengtherrT + '6-20位'); }
    }
    else { user == null ? alert('登录' + exiT) : alert('用户名' + lengtherrT + '1-50位'); }
}
function regfunc() {
    user = prompt("请输入1-50位用户名," + lenlimiT, 'username');
    if (user != null && user.length >= 1 && user.length <= 20) {
        pass = prompt("请输入6-20位密码," + lenlimiT, 'password');
        if (pass != null && pass.length >= 6 && pass.length <= 20) {
            temp = prompt("确认密码", 'password');
            if (pass == temp) {
                $.ajax({ url: cApi + 'Register&username=' + user + '&password=' + pass, type: 'POST', dataType: 'json' })
                    .done(data => {
                        if (data.ret == 200) {
                            temp = data.data; localStorage.setItem('logindata', JSON.stringify([temp.user_id, temp.token]));
                            GM_setValue('user', user); GM_setValue('pass', pass); GM_setValue('sppuid', temp.user_id); GM_setValue('spptoken', temp.token);
                            if (confirm(imgunbindT)) { imgbindfunc() }
                            else { alert(notbindT); }
                        }
                        else if (data.ret != 200) { alert('Oops!' + data.ret + '注册' + renT + data.msg) }
                    })
                    .fail(data => { alert(errT); console.log(data) });
            }
            else { alert("两次密码不一致,注册" + exiT); }
        }
        else { pass == null ? alert('注册' + exiT) : alert('密码' + lengtherrT + '6-20位'); }
    }
    else { user == null ? alert('注册' + exiT) : alert('用户名' + lengtherrT + '1-50位'); }
}
// 绑定检测&图床绑定方法
function imgbindcheckfunc() {
    loginf = JSON.parse(localStorage.logindata); aId = loginf[0]; aToken = loginf[1],
        $.ajax({ url: cApi + 'Tutoken&user_id=' + aId + '&token=' + aToken, type: 'POST', dataType: 'json' })
            .done(data => {
                if (data.ret == 200) {
                    temp = data.data;
                    if (temp.tutoken != "") { localStorage.setItem('logindata', JSON.stringify([aId, aToken, temp.tutoken])); alert("检测到您已绑定图床账号!上传图片将使用绑定的图床账号!"); }
                    else if (confirm(imgunbindT + notbindT)) { imgbindfunc() }
                    else { alert(notbindT) }
                } else { alert("检测图床绑定状态" + renT + data.ret) }
            }).fail(data => { alert(errT); console.log(data) });
}
function imgbindfunc() {
    user = prompt("图床账号邮箱", 'example@example.mail'); pass = prompt("图床账号密码", 'password'); formData = '{ "email":"' + user + '" , "password":"' + pass + '" }';
    $.ajax({ url: iApi + 'tokens', type: 'POST', dataType: 'json', data: formData, contentType: "application/json", processData: false, })
        .done(data => {
            if (data.status == true) {
                loginf = JSON.parse(localStorage.logindata); aId = loginf[0]; aToken = loginf[1]; temp = data.data.token;
                localStorage.setItem('logindata', JSON.stringify([aId, aToken, temp]));
                $.ajax({ url: cApi + 'tupdate&user_id=' + aId + '&token=' + aToken + '&tupdate=' + temp, type: 'POST', dataType: 'json' })
                    .done(data => {
                        if (data.ret == 200) { alert("已绑定图床账号!") }
                        else { alert(data.msg + ' 图床账号绑定' + renT + data.ret) }
                    }).fail(data => { alert(errT); console.log(data) });
            } else if (data.status == false) { alert(data.message) }
        }).fail(data => { alert(errT); console.log(data) });
}
// 上载&同步方法
function ltcfunc() {
    loginf = JSON.parse(localStorage.logindata); aId = loginf[0]; aToken = loginf[1];
    temp = localStorage.userimgst;
    if (temp != null) {
        $.ajax({ url: cApi + 'picsupdate&user_id=' + aId + '&token=' + aToken + '&picsdata=' + JSON.parse(temp), type: 'POST', dataType: 'json' })
            .done(data => {
                if (data.ret == 200) {
                    if (confirm('确定同步【本地数据到云端】吗?这是最后一次确认!')) { alert(doneT); }
                    else { alert(exiT) }
                } else { alert(data.msg + '同步操作' + renT + data.ret); }
            })
            .fail(data => { alert(errT); console.log(data) });
    } else { alert('本地数据为空!同步到云端' + exiT); }
}
function ctlfunc() {
    loginf = JSON.parse(localStorage.logindata); aId = loginf[0]; aToken = loginf[1];
    $.ajax({ url: cApi + 'picsdata&user_id=' + aId + '&token=' + aToken, type: 'POST', dataType: 'json' })
        .done(data => {
            if (data.ret == 200) {
                temp = data.data.picsdata; if (temp != "") {
                    if (confirm('确定同步【云端数据到本地】吗?这是最后一次确认!')) { localStorage.setItem('userimgst', JSON.stringify(temp.split(','))); alert(doneT); location.reload(); }
                    else { alert(exiT) }
                } else { alert("云端数据为空!同步到本地" + exiT); }
            } else { alert(data.msg + '同步操作' + renT + data.ret); }
        }).fail(data => { alert(errT); console.log(data) });
}
// 上传图片方法
function upimgfunc(formData, textArea) {
    if (!textArea) textArea = $('textarea')[0];
    temp = localStorage.logindata;
    if (temp == null) {
        $.ajax({ url: iApi + 'upload', type: 'POST', dataType: 'json', data: formData, contentType: false, processData: false, })
            .done(data => {
                if (data.status == true) {
                    temp = data.data.links; setTimeout(() => { alert(guestupimgT); }, 1000);
                    if (rhview == false && realedit == true) { document.execCommand('insertImage', false, temp.url); }
                    else if (rhview == false && realedit == false) {
                        if (customize.markdown == false) { addCode(textArea, temp.bbcode); }
                        else if (customize.markdown == true) { addCode(textArea, `![](${temp.url})`); }
                    } else if (rhview == false && realedit == true) { addHCode(`<img src="${temp.url}" border="0" alt="" style="max-width:400px"></img>`); }
                } else if (data.status == false) { alert(data.message); } else { alert(errT); console.log(data) }
            }).fail(data => { alert(errT); console.log(data) });
    } else {
        loginf = JSON.parse(temp); if (loginf.length == 2) {
            $.ajax({ url: iApi + 'upload', type: 'POST', dataType: 'json', data: formData, contentType: false, processData: false, })
                .done(data => {
                    if (data.status == true) {
                        temp = data.data.links;
                        if (rhview == false && realedit == true) { document.execCommand('insertImage', false, temp.url); }
                        else if (rhview == false && realedit == false) {
                            if (customize.markdown == false) { addCode(textArea, temp.bbcode); }
                            else if (customize.markdown == true) { addCode(textArea, `![](${temp.url})`); }
                        } else if (rhview == false && realedit == true) { addHCode(`<img src="${temp.url}" border="0" alt="" style="max-width:400px"></img>`); }
                        if (!localStorage.Alertless) { alert(guestupimgT); localStorage.setItem('Alertless', true); }
                    } else if (data.status == false) { alert(data.message); } else { alert(errT); console.log(data) }
                }).fail(data => { alert(errT); console.log(data) });
        } else if (loginf.length == 3) {
            $.ajax({
                url: iApi + 'upload', type: 'POST', dataType: 'json', data: formData, contentType: false, processData: false,
                beforeSend: function (xhr) { xhr.setRequestHeader("Authorization", "Bearer " + loginf[2]); }
            }).done(data => {
                if (data.status == true) {
                    temp = data.data.links;
                    if (rhview == false && realedit == true) { document.execCommand('insertImage', false, temp.url); }
                    else if (rhview == false && realedit == false) {
                        if (customize.markdown == false) { addCode(textArea, temp.bbcode); }
                        else if (customize.markdown == true) { addCode(textArea, `![](${temp.url})`); }
                    } else if (rhview == false && realedit == true) { addHCode(`<img src="${temp.url}" border="0" alt="" style="max-width:400px"></img>`); }
                } else if (data.status == false) { alert(data.message); } else { alert(errT); console.log(data) }
            }).fail(data => { alert(errT); console.log(data) });
        }
    }
}
// 单个在线贴纸获取方法
function get1stfunc(e) {
    $.ajax({ url: customize.onlineraw + 'Get&id=' + e, type: 'POST', contentType: false, processData: false, })
        .done(data => {
            if (data.ret == 200) {
                FinalList.push(e); FinalRaw.push(JSON.parse(data.data.content)); customize.olimglists = FinalList;
                localStorage.setItem('onlineraws', JSON.stringify(FinalRaw)); localStorage.setItem('StickerConf', JSON.stringify(customize)); sessionStorage.removeItem('OnlineSmile');
            } else { console.log(data.ret + '错误,' + data.msg); }
        }).fail(data => { alert(errT); console.log(data); });
}
// 数组去重
function qc(arr) { temp = new Set(arr); return Array.from(temp); }
// 看板娘可拖拽,会记录拖拽位置
function drag(obj) {
    ww = window.innerWidth || document.body.clientWidth; wh = window.innerHeight || document.body.clientHeight;
    obj.onmousedown = function (event) {
        obj.setCapture && obj.setCapture(); event = event || window.event;
        l = obj.style.left; t = obj.style.top; let ol = event.clientX - obj.offsetLeft, ot = event.clientY - obj.offsetTop;
        document.onmousemove = function (event) { event = event || window.event; obj.style.left = event.clientX - ol + "px"; obj.style.top = event.clientY - ot + "px"; };
        document.onmouseup = function () {
            document.onmousemove = null; document.onmouseup = null;
            obj.releaseCapture && obj.releaseCapture(); i = obj.style.left; s = obj.style.top;
            if (l == i && t == s) {
                $textAreas = $("textarea"); if (!$textAreas.length) return;
                if ($textAreas.length == 1) { $('.stickerpp-user-p').click(); }
                else { alert("当前存在多个文本区,无法确认上传区域,看板娘点击上传暂不可用!") }
            }
            else {
                if (parseInt(i) < 0) { obj.style.left = '0px'; i = 0 }
                else if (parseInt(i) > 0.95 * ww) { i = 0.95; obj.style.left = 0.95 * ww + 'px' }
                else if (parseInt(i) < 0.95 * ww) { i = parseInt(i) / ww }
                if (parseInt(s) < 0) { obj.style.top = 0.1 * wh + 'px'; s = 0.1 }
                else if (parseInt(s) > 0.9 * wh) { s = 0.9; obj.style.top = 0.9 * wh + 'px' }
                else if (parseInt(s) < 0.9 * wh) { s = parseInt(s) / wh }
                localStorage.setItem('imgmovePc', JSON.stringify([i, s]));
            };
        }; return false;
    };
    obj.addEventListener('touchmove', function (event) {
        event.preventDefault();
        if (event.targetTouches.length == 1) {
            let touch = event.targetTouches[0];
            if (touch.clientX >= 0) {
                if (touch.clientX < ww - 60) { obj.style.left = touch.clientX + 'px'; l = touch.clientX / ww }
                else { obj.style.left = 0.82 * ww + 'px'; l = 0.82 }
            } else if (touch.clientX < 0) { obj.style.left = '0px'; l = 0 }
            if (touch.clientY > 0) {
                if (touch.clientY < 0.99 * wh) { obj.style.top = touch.clientY + 'px'; t = touch.clientY / wh }
                else { obj.style.top = 0.99 * wh + 'px'; t = 0.99 }
            } else if (touch.clientY < 0.05 * wh) { obj.style.top = 0.05 * wh + 'px'; t = 0.05 }
            localStorage.setItem('imgmoveMb', JSON.stringify([l, t]));
        }
    }); return false;
};
// 看板娘网页缩放跟随
window.onresize = function () {
    temp = $('#stickerppkanban'); ww = window.innerWidth || document.body.clientWidth; wh = window.innerHeight || document.body.clientHeight;
    if (isKfMobile || isMobile) {
        if (localStorage.imgmoveMb != null) { let imgmoveMb = JSON.parse(localStorage.imgmoveMb); temp[0].style.left = imgmoveMb[0] * ww + 'px'; temp[0].style.top = imgmoveMb[1] * wh + 'px'; }
    } else {
        if (localStorage.imgmovePc != null) { let imgmovePc = JSON.parse(localStorage.imgmovePc); temp[0].style.left = imgmovePc[0] * ww + 'px'; temp[0].style.top = imgmovePc[1] * wh + 'px'; }
    }
}


/**
 * 添加CSS
 */
const appendCss = function () {
    $('head').append(`<style>
   .stickerpp-container { padding: 5px; vertical-align: middle; font: 12px/1.7em "sans-serif"; }
   .stickerpp-menu { margin-bottom: 5px; }
   .stickerpp-sub-menu { margin: 0 5px; text-decoration: none; border-bottom: 2px solid transparent; }
   .stickerpp-sub-menu:hover, .stickerpp-sub-menu:focus { text-decoration: none; border-color: deeppink; }
   a.stickerpp-sub-menu-active { color: black }
   .stickerpp-smile-panel { display: none; height: 136px; padding: 5px 3px; overflow-y: auto; border-top: 1px solid #ddd; }
   .stickerpp-smile-panel[data-key="Shortcut"] { height: auto; }
   .stickerpp-smile-panel[data-key="Markdown"] { height: auto; }
   .stickerpp-smile { display: inline-block; max-width: 60px; max-height: 60px; cursor: pointer; }
   .stickerpp-smile-text { display: inline-block; padding: 3px 5px; }
   .stickerpp-smile-text:hover { color: #fff !important; background-color: #2b2b2b; text-decoration: none; }
   .stickerpp-close-panel { cursor: pointer; }
   .stickerpp-zoom-in {
     position: absolute; max-width: 150px; max-height: 150px; background-color: #fcfcfc; border: 3px solid rgba(242, 242, 242, 0.6);
     border-radius: 2px; box-shadow: 0 0 3px rgb(102, 102, 102);
   }
   .stickerpp-shop_box sheader {height: 42px;background: rgb(49, 49, 49);display: block;font-size: 100%;margin: 0px;padding: 0px;color: rgb(115, 115, 115);font-family: "Helvetica Neue", Helvetica, arial, sans-serif;line-height: 1.231;}
   .stickerpp-shop_box sheader logo{float: left;margin: 25px 2px 0px 30px;font-size: 150%;padding: 0px;display: block;margin-block-start: 0.67em;margin-block-end: 0.67em;margin-inline-start: 0px;margin-inline-end: 0px;color:#fff;}
   .stickerpp-shop_box sheader span { float: right; margin: 25px 2px 0px 30px;font-size: 150%;padding: 0px;display: block;margin-block-start: 0.67em;margin-block-end: 0.67em;margin-inline-start: 0px;margin-inline-end: 0px;color:#fff;}
   .stickerpp-shop_nav { text-align: right; margin-top: 5px; margin-bottom: -5px; }
   .stickerpp-shop_main fieldset { border: 1px solid #ccccff; padding: 0 6px 6px; }
   .stickerpp-shop_main legend { font-weight: bold; }
   .StickerPP-list-content {display: block;margin-block-start: 0em;margin-block-end: 1em;margin-inline-start: 0px;margin-inline-end: 0px;padding-inline-start: 40px;list-style-type: disc;line-height: 20px;background-color: #fcfcfc}
   .sticker-item-img {text-align: center;}
   .stickerpp-shop_main input[type="color"] { height: 18px; width: 30px; padding: 0; }
   .stickerpp-shop_tips { color: #51d; text-decoration: none; cursor: help; }
   .stickerpp-shop_tips:hover { color: #ff0000; }
   #pdConfigDialog .stickerpp-shop_main { overflow-x: hidden; white-space: nowrap; }
   .stickerpp-shop_panel { display: inline-block; width: 400px; vertical-align: top; }
   .stickerpp-shop_panel + .stickerpp-shop_panel { margin-left: 5px; }
   .stickerpp-shop_btns { background-color: #fcfcfc; text-align: right; padding: 5px; }
   .stickerpp-shop_btns input, .stickerpp-shop_btns button { vertical-align: middle; }
   .stickerpp-shop_btns button { min-width: 64px; }
   .StickerPP-pagination-item-button {border-style: none;display: inline-block; text-align: center; margin: 5px;}
   .StickerPP-pagination-nowpage-button {    border: 1px solid #e5e5e5;color: #00b84f;min-width: 30px;display: inline-block; text-align: center; margin: 5px;}
   .StickerPP-pagination-prev-next {border-style: none;display: inline-block; text-align: center; margin: 5px;}
   .sticker-pages {background-color: #fcfcfc;padding: 8px 0 6px 10px;position: relative;color: #707072;font-size: 10px;margin: 0;text-align: center;width: 100%; }
   .stickerpp-shop_footer {background-color: #f7f7fc;border-top: 1px solid #e6e6e6;padding: 8px 0 6px 10px;position: relative;color: #707072;font-size: 10px;margin: 0;}
   .stickerpp-shop_footer a{color: #707072;font-size: 10px;}
   .pd_custom_script_header { margin: 7px 0; padding: 5px; background-color: #e8e8e8; border-radius: 5px; }
   .pd_custom_script_content { display: none; width: 750px; height: 350px; white-space: pre; }
   .Heditm { border-style: none;display: inline-block; text-align: center;width: 26px;height: 20px;cursor: pointer;}
   .Heditms { border-style: none;display: inline-block; text-align: center;width: 26px;height: 20px;cursor: pointer;}
   .StickerPPHtmlEditer img {max-width:500px}
   .StickerPPHtmlEditer video {max-width:500px}
   </style>`);
    if (isKfMobile == false && isMobile == false) {
        $('head').append(`<style>
   .stickerpp-shop_box {
     position: fixed;display: none; z-index: 1002;
     -webkit-box-shadow: 0px 5px 15px rgba(0, 0, 0, 0.5); -moz-box-shadow: 0px 5px 15px rgba(0, 0, 0, 0.5); box-shadow: 0px 5px 15px rgba(0, 0, 0, 0.5);max-width: 1000px;
     left:0 !important;right:0 !important;margin:auto;}
   .stickerpp-shop_main { background-color: #fcfcfc; padding: 0 10px; font-size: 12px; line-height: 24px; height: 450px;max-height: 450px;}
   .sticker-item {    display: inline-block;margin: 0 60px 26px 0;vertical-align: top;width: 128px;}
   .sticker-item-name {    color: #737373;font-size: 12px;line-height: 1.2;max-height: 38.2px;text-align: center;word-break: break-word;-webkit-line-clamp: 2;-webkit-box-orient: vertical;display: -webkit-box;overflow: hidden;width: 120px}
 </style>`);
    } else if (isKfMobile == true || isMobile == true) {
        $('head').append(`<style>
   #readPage .stickerpp-container, #writeMessagePage .stickerpp-container { margin-top: -10px; }
   .stickerpp-shop_box {
     position: fixed;display: none; z-index: 1002;
     -webkit-box-shadow: 0px 5px 15px rgba(0, 0, 0, 0.5); -moz-box-shadow: 0px 5px 15px rgba(0, 0, 0, 0.5); box-shadow: 0px 5px 15px rgba(0, 0, 0, 0.5);max-width: 400px;
     left:0 !important;right:0 !important;top:50px !important;margin:auto;}
   .stickerpp-shop_main { background-color: #fcfcfc; padding: 0 10px; font-size: 12px; line-height: 24px; height: 520px;max-height: 600px;}
   .sticker-item { display: inline-block;margin: 0 10px 22px 0;vertical-align: top;width: 72px;}
   .sticker-item-name {    color: #737373;font-size: 12px;line-height: 1.2;max-height: 38.2px;text-align: center;word-break: break-word;-webkit-line-clamp: 2;-webkit-box-orient: vertical;display: -webkit-box;overflow: hidden;width: 72px}
 </style>`);
    }
};


/**
 * 初始化
 */
const init = function () { $textAreas = $("textarea"); if (!$textAreas.length) return; appendCss(); $textAreas.each(function (i) { createContainer(this, i); }); };
if (loadcustom == false) {
    alert('首次使用,部署默认设置。您可以在【自定义】->【个性设置】中完成个性化设置!');
    customize.lcimglists = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]; localStorage.setItem('StickerConf', JSON.stringify(customize));
    localStorage.removeItem('onlineraws'); localStorage.removeItem('Alertless'); sessionStorage.removeItem('localSmile'); sessionStorage.removeItem('OnlineSmile');
    alert('当前表情贴纸组为默认设置,您可以在【表情组设置->启用的本地表情组/表情组商店】中选择要启用的表情组!');
};
if ($("iframe[id='e_iframe'],iframe[name='iframe']").length > 0) { $realtimeView = $("iframe[id*='iframe'],iframe[name='iframe']")[0].contentWindow.document, rhview = true; }
init();