您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
回复表情,插图扩展插件,在发帖时快速输入自定义表情和论坛BBCODE
当前为
// ==UserScript== // @name 表情贴纸增强插件 // @namespace https://github.com/HazukiKaguya/Stickers_PlusPlus // @homepage https://github.com/HazukiKaguya/Stickers_PlusPlus // @version 2.1.5 // @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/[email protected]/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.5, 本次更新日志: \n 增加了一些常用bbcode', defaultSConf = { "version": "2.1.0", "kanbansize": "64", "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.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 = "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 = "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 = "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 = "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> 表情贴纸商店 | Sticker Shop</logo><span class="stickerpp-close-shop">× </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 </div> </div></form>`, StickerPPUploadHtml = `<form><div class="stickerpp-shop_box" id="StickerPP-shop-dialog" style="display: block; top: 8px; left: 336px;"> <sheader><logo> 表情贴纸商店 | Sticker Shop</logo><span class="stickerpp-close-shop">× </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 </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:[email protected]">[email protected]</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="表情组设置"> <span class="stickerpp-close-panel" title="表情增强插件,${updatelog}" style="cursor: pointer;"><b>⑨</b></span> ${getSubMenuHtml()}<span class="stickerpp-close-panel">[-]</span> <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="添加贴纸"> <input type="button" class="stickerpp-user-r" value="导出贴纸"> <input type="button" class="stickerpp-user-u" value="修改贴纸"> <input type="button" class="stickerpp-user-d" value="删除贴纸"> <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=""> <input type="button" class="stickerpp-res-kanbanimg" value="默认">(看板娘图片URL)</li> <li><input type="number" class="conftext" id="kanbansize${qufen}" value=""> <input type="button" class="stickerpp-res-kanbansize" value="默认">(看板娘大小,移动端/2)</li> <li><input type="text" class="conftext" id="onlineraw${qufen}" value=""> <input type="button" class="stickerpp-res-onlineraw" value="默认">(在线贴纸仓库API)</li> <li><input type="text" class="conftext" id="imgapi${qufen}" value=""> <input type="button" class="stickerpp-res-imgapi" value="默认">(图片上传图床API)</li> <li><input type="text" class="conftext" id="olimglists${qufen}" disabled="true" value=""> <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="重置看板位置"> <input type="button" class="stickerpp-res-hidekanban" value="隐藏看板娘"> <input type="button" class="stickerpp-res-all" value="全部初始化"> <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="注册"> <input type="button" class="stickerpp-user-log" value="登录"> <input type="button" class="stickerpp-user-img" value="绑定图床"> <input type="button" class="stickerpp-user-ltc" value="上传云端"> <input type="button" class="stickerpp-user-ctl" value="恢复本地"> <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="启用的本地表情"> <input type="button" class="stickerpp-user-oln" value="浏览表情组商店"> <input type="button" class="stickerpp-user-raw" value="向贴纸商店投稿"> <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> </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 = `})`; 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); $("#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-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> '); } }).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', '#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 === '< wind_code_1 >') { t = document.createElement("img"); t.src = i.href; i.parentElement.replaceChild(t, i); } });*/ //<a href="https://sm.ms/image/1QrdSctTsVvjoRM" target="_blank">< wind_code_1 ></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(/ /ig, ' '); str = str.replace(/<br[^>]*>/ig, '\n'); str = str.replace(/<[^>]*?>/ig, ''); str = str.replace(/&/ig, '&'); str = str.replace(/"/ig, '"'); str = str.replace(/</ig, '<'); str = str.replace(/>/ig, '>'); return str; } function bb2html(str) { let code_htm = new Array(); str = str.replace(/&(?!(#[0-9]+|[a-z]+);)/ig, '&'); str = str.replace(/</ig, '<'); str = str.replace(/>/ig, '>'); 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("图床账号邮箱", '[email protected]'); 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, ``); } } 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, ``); } } 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, ``); } } 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();