绯月表情增强插件

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

目前为 2017-02-15 提交的版本。查看 最新版本

// ==UserScript==
// @name       绯月表情增强插件
// @namespace   https://greasyfork.org/users/5415
// @version     4.3.6
// @author      eddie32
// @description KF论坛专用的回复表情, 插图扩展插件, 在发帖时快速输入自定义表情和论坛BBCODE
// @icon        https://blog.nekohand.moe/favicon.ico
// @homepage    https://github.com/liu599/KF-Emotion-UserScript
// @include     https://*miaola.info/*
// @include     http://*2dkf.com/*
// @include     http://*9moe.com/*
// @include     http://*kfgal.com/*
// @copyright   2014-2017, eddie32
// @grant       none
// @license     MIT
// @run-at      document-end
// ==/UserScript==

(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){
'use strict';

/* eslint linebreak-style: ["error", "windows"] */

var fun = function fun() {
  var imagepath = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';

  var versionNo = '4.3.6';
  /* Address function
   * startNumber: number, indicating the start number;
   * lengthArray: number, indicating the addrArray length;
   * strPrefix: string, address Prefix;
   * strSuffix: string, address Suffix;
   * leadingZero: boolen, true for leading zero in number;
   * addrArray: array, address array, default for empty;
   */
  // 创建表情包数组的函数
  function emAddrArrayHandler(startNumber, lengthArray, strPrefix, strSuffix) {
    var addrArray = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : [];
    var leadingZero = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : false;

    var addrTemp = '';
    var addrNumber = 0;
    for (var j = startNumber; j < lengthArray; j += 1) {
      addrNumber = j;
      if (leadingZero) {
        addrNumber = j > 9 ? j : '0' + j;
      }
      addrTemp = '' + strPrefix + addrNumber + strSuffix;
      addrArray.push(addrTemp);
    }
    return addrArray;
  }
  /* 表情包地址数据 */

  // B站
  var biliEM = emAddrArrayHandler(1, 17, 'http://smile.nekohand.moe/blogAcc/LoveliveEmotion01/EmCol/BiliBili/2233 (', ').gif');
  emAddrArrayHandler(1, 14, 'http://smile.nekohand.moe/blogAcc/Bilibili/xds/', '.png', biliEM);
  emAddrArrayHandler(0, 14, 'http://smile.nekohand.moe/blogAcc/LoveliveEmotion01/EmCol/BiliBili/bilibiliTV (', ').png', biliEM);
  // tora酱
  emAddrArrayHandler(1, 14, 'http://smile.nekohand.moe/blogAcc/LoveliveEmotion01/EmCol/tora/0', '.jpg', biliEM, true);
  // 阿卡林 from 摇曳百合
  var AkariSmile = emAddrArrayHandler(1, 21, 'http://smile.nekohand.moe/blogAcc/LoveliveEmotion01/EmCol/Dynamic/akari', '.gif');
  emAddrArrayHandler(1, 72, 'http://smile.nekohand.moe/blogAcc/LoveliveEmotion01/EmCol/akari/akari', '.png', AkariSmile);
  // New Game kf扩展
  var NewGame = emAddrArrayHandler(2, 64, 'http://nekohand.moe/spsmile/01Sora/0xx', '.png');
  emAddrArrayHandler(1, 20, 'http://ss.nekohand.moe/Asource/EmotionPic/KFEM (', ').gif', NewGame);
  // ACFUN
  var ACSmile4 = emAddrArrayHandler(1, 51, 'http://smile.nekohand.moe/blogAcc/LoveliveEmotion01/EmCol/ACFUN/New/', '.png');
  emAddrArrayHandler(1, 40, 'http://smile.nekohand.moe/blogAcc/LoveliveEmotion01/EmCol/ACFUN/Niming/', '.gif', ACSmile4, true);
  // KF 内置
  var KFSmileURL = emAddrArrayHandler(1, 49, (typeof imagepath !== 'undefined' ? imagepath : '') + '/post/smile/em/em', '.gif', [], true);
  var KFSmileCode = emAddrArrayHandler(10, 58, '[s:', ']');
  // lovelive专用小
  var LoveliveSmalltargetURL = emAddrArrayHandler(1, 41, 'http://smile.nekohand.moe/blogAcc/LoveliveEmotion02/Small/Lovelive2nd', '.png');
  emAddrArrayHandler(1, 41, 'http://smile.nekohand.moe/blogAcc/LoveliveEmotion01/Small/Lovelive', '.png', LoveliveSmalltargetURL);
  // kf快捷代码(需要改写解构赋值)
  var functionDescription = ['出售贴sell=售价', '引用', '隐藏hide=神秘等级', '插入代码', '删除线', '跑马灯', '文字颜色', '粗体', '下划线', '斜体', '水平线', '背景色', '插入图片'];
  var defaultFunction = ['[sell=100][/sell]', '[quote][/quote]', '[hide=100][/hide]', '[code][/code]', '[strike][/strike]', '[fly][/fly]', '[color=#00FF00][/color]', '[b][/b]', '[u][/u]', '[i][/i]', '[hr]', '[backcolor=][/backcolor]', '[img][/img]'];
  // 颜文字
  var emoji = ['(●・ 8 ・●)', '╰(๑◕ ▽ ◕๑)╯', '(ゝω・)', '〜♪♪', '(゚Д゚≡゚Д゚)', '(^o^)ノ', '(|||゚Д゚)', '(`ε´ )', '(╬゚д゚)', '(|||゚д゚)', '( ̄∇ ̄)', '( ̄3 ̄)', '( ̄ー ̄)', '( ̄ .  ̄)', '( ̄︿ ̄)', '( ̄︶ ̄)', '(*´ω`*)', '(・ω・)', '(⌒▽⌒)', '( ̄▽ ̄)', '(=・ω・=)', '(`・ω・´)', '(〜 ̄△ ̄)〜', '(・∀・)', '(°∀°)ノ', '( ̄3 ̄)', '╮( ̄▽ ̄)╭', '( ´_ゝ`)', 'のヮの', '(ノ؂< ๑)诶嘿☆~', '(&lt;_&lt;)', '(&gt;_&gt;)', '(;¬_¬)', '(▔□▔)/', '(゚Д゚≡゚д゚)!?', 'Σ(゚д゚;)', 'Σ(  ̄□ ̄||)', '(´;ω;`)', '(/TДT)/', '(^・ω・^ )', '(。・ω・。)', '(● ̄(エ) ̄●)', 'ε=ε=(ノ≧∇≦)ノ', '(´・_・`)', '(-_-#)', '( ̄へ ̄)', '( ̄ε(# ̄) Σ', 'ヽ(`Д´)ノ', '(╯°口°)╯(┴—┴', '(#-_-)┯━┯', '_(:3」∠)_', '(笑)', '(汗)', '(泣)', '(苦笑)', '(´・ω・`)', '(╯°□°)╯︵ ┻━┻', '(╯‵□′)╯︵┻━┻', '( ´ρ`)', '( ゚ω゚)', '(o゚ω゚o)', '( ^ω^)', '(。◕∀◕。)', '/( ◕‿‿◕ )\\', 'ε٩( º∀º )۶з', '( ̄ε(# ̄)☆╰╮( ̄▽ ̄///)', '(●´3`)~♪', '_(:з」∠)_', 'хорошо!', '\(^o^)/', '(•̅灬•̅ )', '(゚Д゚)', 'まったく、小学生は最高だぜ!!', 'ε=ε=ε=┏(゜ロ゜;)┛', '(;°ほ°)', '⎝≧⏝⏝≦⎠', 'ヽ(✿゚▽゚)ノ', '焔に舞い上がるスパークよ、邪悪な異性交際に、天罰を与え!', '|•ω•`)'];

  var MenuList = {
    item4: { datatype: 'imageLink', title: '固有', addr: KFSmileURL, ref: KFSmileCode },
    item1: { datatype: 'plain', title: '快捷', addr: defaultFunction, ref: functionDescription },
    item2: { datatype: 'plain', title: '颜文字', addr: emoji },
    item5: { datatype: 'image', title: 'ACFUN', addr: ACSmile4 },
    item6: { datatype: 'image', title: '常用', addr: NewGame }, //
    item7: { datatype: 'image', title: 'Akari', addr: AkariSmile }, // Akari
    item8: { datatype: 'image', title: 'BiliBili', addr: biliEM }, // B站
    item3: { datatype: 'image', title: 'LoveLive', addr: LoveliveSmalltargetURL }
  };
  /* eslint-disable no-param-reassign*/
  /* Event 函数 */
  var EventUtil = {
    getEvent: function getEvent(event) {
      return event || window.event;
    },
    getTarget: function getTarget(event) {
      return event.target || event.srcElement;
    },
    preventDefault: function preventDefault(event) {
      if (event.preventDefault) {
        event.preventDefault();
      } else {
        event.returnValue = false;
      }
    },
    stopPropagation: function stopPropagation(event) {
      if (event.stopPropagation) {
        event.stopPropagation();
      } else {
        event.cancelBubble = true;
      }
    },
    addHandler: function addHandler(element, type, handler) {
      if (element.addEventListener) {
        element.addEventListener(type, handler, false); // DOM2
      } else if (element.attachEvent) {
        element.attachEvent('on' + type, handler); // IE
      } else {
        element['on' + type] = handler; // DOM 0
      }
    },
    removeHandler: function removeHandler(element, type, handler) {
      if (element.removeEventListener) {
        element.removeEventListener(type, handler, false); // DOM2
      } else if (element.detachEvent) {
        element.detachEvent('on' + type, handler); // IE
      } else {
        element['on' + type] = null; // DOM 0
      }
    }
  };
  /* eslint-enable no-param-reassign*/
  /* Element 函数*/
  var EleUtil = {
    create: function create(ele) {
      return document.createElement(ele);
    },
    selectID: function selectID(ele) {
      return document.getElementById(ele);
    },
    select: function select(selector) {
      return document.querySelector(selector);
    }
  };
  /* 模块*/
  var mouseOverAction = {
    showImg: function showImg(event) {
      var eventTarget = EventUtil.getTarget(event);
      /* if (!eventTarget.src) {
        return 'undefined';
      }*/
      var largeViewContainer = EleUtil.selectID('largeView');
      var _ref = [document.body.scrollTop, document.body.scrollLeft],
          scrollTopValue = _ref[0],
          scrollLeftValue = _ref[1];

      largeViewContainer.innerHTML = '<img src=' + eventTarget.src + ' />';
      largeViewContainer.style.display = 'block';
      largeViewContainer.style.top = event.clientY + scrollTopValue + 20 + 'px';
      largeViewContainer.style.left = event.clientX + scrollLeftValue + 'px';
      // console.log([event.clientY,event.clientX]);
      // console.log([EleUtil.selectID('largeView').style.top,
      // EleUtil.selectID('largeView').style.left]);
      // console.log([document.body.scrollTop,document.body.scrollLeft]);
    },
    clearImg: function clearImg() {
      EleUtil.selectID('largeView').style.display = 'none';
    }
  };
  var attachAction = {
    attachEmotion: function attachEmotion(event) {
      var eventTarget = EventUtil.getTarget(event);
      // console.log(eventTarget);

      var addressTarget = '';
      var emotionAddress = '';
      if (eventTarget.attributes.length === 2) {
        if (eventTarget.src) {
          addressTarget = eventTarget.src;
          emotionAddress = attachAction.addressParse(addressTarget, 'image');
        } else {
          // console.log(eventTarget.attributes);
          addressTarget = eventTarget.attributes[0].nodeValue;
          emotionAddress = attachAction.addressParse(addressTarget, 'plain');
        }
      } else {
        // console.log(eventTarget.attributes);
        addressTarget = eventTarget.attributes[0].nodeValue;
        emotionAddress = attachAction.addressParse(addressTarget, 'plain');
      }
      var selectTextArea = EleUtil.select('textarea');
      var ovalue = selectTextArea.value;
      var startPos = selectTextArea.selectionStart;
      // const endPos = selectTextArea.selectionEnd;
      selectTextArea.value = '' + ovalue.slice(0, startPos) + emotionAddress + ovalue.slice(startPos);
      // console.log(eventTarget);
      // console.log(emotionAddress);
    },
    addressParse: function addressParse(addStr, pattern) {
      var stringReturn = '';
      if (pattern === 'image') {
        stringReturn = '[img]' + addStr + '[/img]';
      }
      if (pattern === 'plain') {
        stringReturn = decodeURI(addStr);
      }
      if (pattern === 'imageLink') {
        stringReturn = addStr;
      }
      return stringReturn;
    }
  };
  var createItems = {
    createContainer: function createContainer(key) {
      var ItemContainer = EleUtil.create('div');
      ItemContainer.id = 'eddie32' + key;
      EleUtil.selectID('toggleWindow').style.height = '100px';
      EleUtil.selectID('toggleWindow').appendChild(ItemContainer);
      return ItemContainer;
    },
    createImages: function createImages(key) {
      var outerContainer = createItems.createContainer(key);
      // console.log(MenuList[key]);
      var imgList = MenuList[key].addr;
      var imgLength = imgList.length;
      for (var k = 0; k < imgLength; k += 1) {
        var divElement = EleUtil.create('div');
        divElement.className = 'clickItem';
        var imgItem = EleUtil.create('img');
        imgItem.src = imgList[k];
        imgItem.className = 'Ems';
        imgItem.onclick = attachAction.attachEmotion;
        imgItem.onmouseover = mouseOverAction.showImg;
        imgItem.onmouseout = mouseOverAction.clearImg;

        divElement.appendChild(imgItem);
        outerContainer.appendChild(divElement);
      }
    },
    createPlainText: function createPlainText(key) {
      var outerContainer = createItems.createContainer(key);
      var txtList = MenuList[key].addr;
      var txtLength = txtList.length;
      for (var k = 0; k < txtLength; k += 1) {
        var txtItem = EleUtil.create('span');
        txtItem.style.cssText = 'cursor:pointer; margin: 10px 10px;';
        txtItem.innerHTML = '<a data-sign=' + encodeURI(txtList[k]) + ' class=\'txtBtnEmotion\'>' + txtList[k] + '</a>';
        if (MenuList[key].ref) {
          txtItem.innerHTML = '<a data-sign=' + encodeURI(txtList[k]) + ' class=\'txtBtnEmotion\'>' + MenuList[key].ref[k] + '</a>';
          EleUtil.selectID('toggleWindow').style.height = '50px';
        }
        txtItem.onclick = attachAction.attachEmotion;
        txtItem.style.cssText = 'cursor:pointer;padding: 10px 10px:width: 50px;';
        outerContainer.appendChild(txtItem);
      }
    },
    createImageLink: function createImageLink(key) {
      var outerContainer = createItems.createContainer(key);
      var imgList = MenuList[key].addr;
      var refList = MenuList[key].ref;
      var imgLength = imgList.length;
      for (var k = 0; k < imgLength; k += 1) {
        var imgItem = EleUtil.create('img');
        imgItem.dataset.link = refList[k];
        imgItem.src = imgList[k];
        imgItem.className = 'Ems';
        imgItem.onclick = attachAction.attachEmotion;
        imgItem.style.cssText = 'width: 50px !important;height: 50px !important;';
        outerContainer.appendChild(imgItem);
      }
    }
  };
  var clearMenu = {
    clear: function clear() {
      var toggleWindow = EleUtil.selectID('toggleWindow');
      toggleWindow.style.display = 'none';
      var togWinChildren = toggleWindow.childNodes;
      for (var j = 0, len = togWinChildren.length; j < len; j += 1) {
        // console.log(togWinChildren[j]);
        togWinChildren[j].style.display = 'none';
      }
    }
  };
  var expandMenu = {
    init: function init(event) {
      clearMenu.clear();
      var eventTarget = EventUtil.getTarget(event);
      EleUtil.selectID('toggleWindow').style.display = 'block';
      EleUtil.selectID('toggleWindow').style.width = EleUtil.select('textarea').style.width;
      var dataType = eventTarget.attributes[2].nodeValue;
      var dataKey = eventTarget.attributes[1].nodeValue;
      if (EleUtil.select('#eddie32' + dataKey)) {
        EleUtil.select('#eddie32' + dataKey).style.display = 'block';
        if (dataKey === 'item1') EleUtil.selectID('toggleWindow').style.height = '50px';else EleUtil.selectID('toggleWindow').style.height = '100px';
        return;
      }
      if (dataType === 'plain') {
        createItems.createPlainText(dataKey);
      } else if (dataType === 'image') {
        createItems.createImages(dataKey);
      } else if (dataType === 'imageLink') {
        createItems.createImageLink(dataKey);
      }
    }
  };

  var createMenu = {
    defaultID: 'emotion0000',
    main: function main() {
      /* main menu*/
      var mainMenu = EleUtil.create('div');
      mainMenu.innerHTML = '<span id=\'largeView\'></span><span class=\'subMenu\' title=\'\u4E3B\u83DC\u5355 version ' + versionNo + '\'><b>\u2468\u56E7\u2468</b></span>';
      mainMenu.id = createMenu.defaultID;
      var MenuLength = Object.keys(MenuList).length;
      for (var i = 0; i < MenuLength; i += 1) {
        var MenuKey = Object.keys(MenuList)[i];
        var MenuTitle = MenuList[MenuKey].title;
        var MenuType = MenuList[MenuKey].datatype;
        // if (!MenuType || !MenuTitle) console.log(`dataerror  ${MenuKey}`);
        var testMenu = createMenu.subs(MenuTitle, expandMenu.init, MenuKey, MenuType);
        mainMenu.appendChild(testMenu);
      }
      /* close button*/
      var closeBtn = EleUtil.create('span');
      closeBtn.innerHTML = '[x]';
      closeBtn.className = 'subMenu';
      closeBtn.id = 'closeEM';
      closeBtn.onclick = clearMenu.clear;
      closeBtn.style.cssText = 'cursor:pointer';
      mainMenu.appendChild(closeBtn);
      /* dropdown box*/
      var itemWindow = EleUtil.create('div');
      itemWindow.id = 'toggleWindow';
      mainMenu.appendChild(itemWindow);
      /* css style*/
      var styleItem = EleUtil.create('style');
      styleItem.innerHTML = '#emotion0000 {padding:5px 5px; vertical-align: middle;                   font: 12px/16px \'Hiragino Sans GB\',\'Microsoft YaHei\',\'Arial\',\'sans-serif\'}                 #largeView{position:absolute; background: #fff;z-index:5000; opacity: 0.8}                 #largeView img{width: 200px; height:200px;}                 #toggleWindow a{padding: 5px 5px;line-height:2}                 #toggleWindow {height: 100px; padding: 3px 3px; overflow-x: auto; margin-top:6px;                 margin-bottom:6px; border:1px solid #ff4351; display:none;position:relative; z-index:200; }                .clickItem{display:inline-block; z-index:300;}\n                a.subBut{text-decoration: none;color: #fff;}                 .Ems{cursor:pointer;width: 50px;height: 50px;display:inline-block;  z-index:400;}                 a.subBut:hover{color: #fff;}                 a.txtBtnEmotion{text-decoration:none;}                 a.txtBtnEmotion:hover{background:#ff7680; color:#fff; }                 .subMenu{display:inline-block;cursor:pointer; text-align:center; padding: 8px 8px;                 font: 12px/16px \'Hiragino Sans GB\',\'Microsoft YaHei\',\'Arial\',\'sans-serif\';                background-color: #ff4351;border-color: #ff4351;color: #fff;}                 .subMenu:hover, .subMenu:focus, .subMenu:visited{background-color: #ff7680;border-color: #ff7680;color: #fff;}';
      mainMenu.appendChild(styleItem);
      return mainMenu;
    },
    subs: function subs(title, func, subid, subtype) {
      var subMenu = EleUtil.create('span');
      subMenu.id = subid;
      subMenu.className = 'subMenu';
      var subcontent = '<a class=\'subBut\' data-kid=' + subid + ' date-type=' + subtype + '>' + title + '</a>';
      subMenu.onclick = func;
      subMenu.title = title;
      subMenu.innerHTML = subcontent;
      return subMenu;
    }
  };

  if (typeof window !== 'undefined' && document != null) {
    // let testareaEleSet = new WeakSet();
    var testSet = document.getElementsByTagName('textarea');
    // console.log(testSet);
    // console.log(testSet.item(0));
    var mainEmotionMenu = createMenu.main();
    if (document.getElementById('editor-content') !== null) {
      document.getElementById('editor-content').style.position = 'static';
    }
    for (var w = 0; w < testSet.length; w += 1) {
      // console.log(testSet.item(w));
      var elementTest = testSet.item(w);
      // console.log(mainEmotionMenu);
      elementTest.parentNode.insertBefore(mainEmotionMenu, elementTest);
    }
    // NodeList.prototype[Symbol.iterator] = Array.prototype[Symbol.iterator];
    // HTMLCollection.prototype[Symbol.iterator] = Array.prototype[Symbol.iterator];
    // const elementSet = Array.from(document.getElementsByTagName('textarea'));
    /* 兼容性问题 By 喵拉布丁2017.01.30: document.getElementsByTagName方法返回的是HTMLCollection
    在较新版的Firefox中,HTMLCollection支持Iterator接口,所以可以用for...of循环
    而在Chrome中(我只在使用Chromium 50内核的浏览器下测试过),HTMLCollection不支持Iterator接口,不可用直接使用for...of循环
    所以建议楼主还是用老方法吧*/
    // Solution stackflow: http://stackoverflow.com/questions/22754315/foreach-loop-for-htmlcollection-elements
    /* 还有Array.from方法确实能解决Chrome下HTMLCollection不能用for...of循环的问题,不过Chrome 45才开始支持Array.from方法
    若想兼容以前的浏览器的话,可以用for...in循环,或者加个babel-polyfill脚本
    当然你不想兼容使用Chromium 45以前内核的浏览器也没多大问题,现在国内市场份额最多Chromium套壳浏览器--360安全浏览器的最新正式版也是采用Chromium 45内核了*/
    // const elementSetLength = elementSet.length;
    /* if (elementSetLength === 0) {
       console.log('There is no textarea');
    } */
    // testareaEleSet.add(elementSet);
    /* const userOption = {
      userWindowHeight: 120,
      userSelectTextArea: 'last',
    }; */

    /* eslint no-restricted-syntax: [1, "ForOfStatement"] */
    /* for (const elementSingle of elementSet) {
             console.log(elementSingle);
      elementSingle.parentNode.insertBefore(mainEmotionMenu, elementSingle);
    } */
  }
};
// 
fun(imgpath);

},{}]},{},[1])
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browserify/node_modules/browser-pack/_prelude.js","src\\main.js"],"names":[],"mappings":"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","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","/* eslint linebreak-style: [\"error\", \"windows\"] */\r\n\r\n\r\nconst fun = (imagepath = '') => {\r\n  const versionNo = '4.2.2';\r\n    /* Address function\r\n     * startNumber: number, indicating the start number;\r\n     * lengthArray: number, indicating the addrArray length;\r\n     * strPrefix: string, address Prefix;\r\n     * strSuffix: string, address Suffix;\r\n     * leadingZero: boolen, true for leading zero in number;\r\n     * addrArray: array, address array, default for empty;\r\n     */\r\n    // 创建表情包数组的函数\r\n  function emAddrArrayHandler(startNumber, lengthArray, strPrefix,\r\n    strSuffix, addrArray = [], leadingZero = false) {\r\n    let addrTemp = '';\r\n    let addrNumber = 0;\r\n    for (let j = startNumber; j < lengthArray; j += 1) {\r\n      addrNumber = j;\r\n      if (leadingZero) {\r\n        addrNumber = (j > 9) ? (j) : (`0${j}`);\r\n      }\r\n      addrTemp = `${strPrefix}${addrNumber}${strSuffix}`;\r\n      addrArray.push(addrTemp);\r\n    }\r\n    return addrArray;\r\n  }\r\n    /* 表情包地址数据 */\r\n\r\n\r\n    // B站\r\n  const biliEM = emAddrArrayHandler(1, 17, 'http://smile.nekohand.moe/blogAcc/LoveliveEmotion01/EmCol/BiliBili/2233 (',\r\n                                    ').gif');\r\n  emAddrArrayHandler(1, 14, 'http://smile.nekohand.moe/blogAcc/Bilibili/xds/', '.png', biliEM);\r\n  emAddrArrayHandler(0, 14, 'http://smile.nekohand.moe/blogAcc/LoveliveEmotion01/EmCol/BiliBili/bilibiliTV (',\r\n                       ').png', biliEM);\r\n    // tora酱\r\n  emAddrArrayHandler(1, 14, 'http://smile.nekohand.moe/blogAcc/LoveliveEmotion01/EmCol/tora/0',\r\n                       '.jpg', biliEM, true);\r\n    // 阿卡林 from 摇曳百合\r\n  const AkariSmile = emAddrArrayHandler(1, 21, 'http://smile.nekohand.moe/blogAcc/LoveliveEmotion01/EmCol/Dynamic/akari', '.gif');\r\n  emAddrArrayHandler(1, 72, 'http://smile.nekohand.moe/blogAcc/LoveliveEmotion01/EmCol/akari/akari', '.png', AkariSmile);\r\n    // New Game kf扩展\r\n  const NewGame = emAddrArrayHandler(2, 64, 'http://nekohand.moe/spsmile/01Sora/0xx', '.png');\r\n  emAddrArrayHandler(1, 20, 'http://ss.nekohand.moe/Asource/EmotionPic/KFEM (', ').gif', NewGame);\r\n    // ACFUN\r\n  const ACSmile4 = emAddrArrayHandler(1, 51, 'http://smile.nekohand.moe/blogAcc/LoveliveEmotion01/EmCol/ACFUN/New/', '.png');\r\n  emAddrArrayHandler(1, 40, 'http://smile.nekohand.moe/blogAcc/LoveliveEmotion01/EmCol/ACFUN/Niming/', '.gif', ACSmile4, true);\r\n    // KF 内置\r\n  const KFSmileURL = emAddrArrayHandler(1, 49, `${typeof imagepath !== 'undefined' ? imagepath : ''}/post/smile/em/em`,\r\n                                        '.gif', [], true);\r\n  const KFSmileCode = emAddrArrayHandler(10, 58, '[s:',\r\n                                         ']');\r\n    // lovelive专用小\r\n  const LoveliveSmalltargetURL = emAddrArrayHandler(1, 41, 'http://smile.nekohand.moe/blogAcc/LoveliveEmotion02/Small/Lovelive2nd',\r\n                                                    '.png');\r\n  emAddrArrayHandler(1, 41, 'http://smile.nekohand.moe/blogAcc/LoveliveEmotion01/Small/Lovelive',\r\n                       '.png', LoveliveSmalltargetURL);\r\n    // kf快捷代码(需要改写解构赋值)\r\n  const functionDescription = ['出售贴sell=售价', '引用', '隐藏hide=神秘等级', '插入代码', '删除线', '跑马灯', '文字颜色', '粗体',\r\n    '下划线', '斜体', '水平线', '背景色', '插入图片'];\r\n  const defaultFunction = ['[sell=100][/sell]', '[quote][/quote]', '[hide=100][/hide]', '[code][/code]',\r\n    '[strike][/strike]', '[fly][/fly]', '[color=#00FF00][/color]', '[b][/b]', '[u][/u]', '[i][/i]',\r\n    '[hr]', '[backcolor=][/backcolor]', '[img][/img]'];\r\n    // 颜文字\r\n  const emoji = ['(●・ 8 ・●)',\r\n    '╰(๑◕ ▽ ◕๑)╯', '(ゝω・)', '〜♪♪', '(ﾟДﾟ≡ﾟДﾟ)', '(＾o＾)ﾉ', '(|||ﾟДﾟ)', '(`ε´ )', '(╬ﾟдﾟ)', '(|||ﾟдﾟ)', '(￣∇￣)', '(￣3￣)', '(￣ｰ￣)', '(￣ . ￣)', '(￣︿￣)', '(￣︶￣)', '(*´ω`*)', '(・ω・)', '(⌒▽⌒)', '(￣▽￣）', '(=・ω・=)', '(｀・ω・´)', '(〜￣△￣)〜', '(･∀･)',\r\n    '(°∀°)ﾉ', '(￣3￣)', '╮(￣▽￣)╭', '( ´_ゝ｀)', 'のヮの', '(ﾉ؂< ๑）诶嘿☆～', '(&lt;_&lt;)', '(&gt;_&gt;)', '(;¬_¬)', '(▔□▔)/', '(ﾟДﾟ≡ﾟдﾟ)!?', 'Σ(ﾟдﾟ;)', 'Σ( ￣□￣||)',\r\n    '(´；ω；`)', '（/TДT)/', '(^・ω・^ )', '(｡･ω･｡)', '(●￣(ｴ)￣●)', 'ε=ε=(ノ≧∇≦)ノ', '(´･_･`)', '(-_-#)', '（￣へ￣）', '(￣ε(#￣) Σ', 'ヽ(`Д´)ﾉ', '(╯°口°)╯(┴—┴', '（#-_-)┯━┯', '_(:3」∠)_', '(笑)', '(汗)', '(泣)', '(苦笑)', '(´・ω・`)', '(╯°□°）╯︵ ┻━┻', '(╯‵□′)╯︵┻━┻', '( ´ρ`)', '( ﾟωﾟ)', '(oﾟωﾟo)', '(　^ω^)', '(｡◕∀◕｡)', '/( ◕‿‿◕ )\\\\', 'ε٩( º∀º )۶з', '(￣ε(#￣)☆╰╮(￣▽￣///)',\r\n    '（●´3｀）~♪', '_(:з」∠)_', 'хорошо!', '＼(^o^)／', '(•̅灬•̅ )', '(ﾟДﾟ)', 'まったく、小学生は最高だぜ！！', 'ε=ε=ε=┏(゜ロ゜;)┛',\r\n    '(；°ほ°)', '⎝≧⏝⏝≦⎠', 'ヽ(✿ﾟ▽ﾟ)ノ', '焔に舞い上がるスパークよ、邪悪な異性交際に、天罰を与え！', '|•ω•`)'];\r\n\r\n\r\n  const MenuList = {\r\n    item4: { datatype: 'imageLink', title: '固有', addr: KFSmileURL, ref: KFSmileCode },\r\n    item1: { datatype: 'plain', title: '快捷', addr: defaultFunction, ref: functionDescription },\r\n    item2: { datatype: 'plain', title: '颜文字', addr: emoji },\r\n    item5: { datatype: 'image', title: 'ACFUN', addr: ACSmile4 },\r\n    item6: { datatype: 'image', title: '常用', addr: NewGame },  //\r\n    item7: { datatype: 'image', title: 'Akari', addr: AkariSmile }, // Akari\r\n    item8: { datatype: 'image', title: 'BiliBili', addr: biliEM }, // B站\r\n    item3: { datatype: 'image', title: 'LoveLive', addr: LoveliveSmalltargetURL },\r\n  };\r\n  /* eslint-disable no-param-reassign*/\r\n    /* Event 函数 */\r\n  const EventUtil = {\r\n    getEvent(event) {\r\n      return event || window.event;\r\n    },\r\n    getTarget(event) {\r\n      return event.target || event.srcElement;\r\n    },\r\n    preventDefault(event) {\r\n      if (event.preventDefault) {\r\n        event.preventDefault();\r\n      } else {\r\n        event.returnValue = false;\r\n      }\r\n    },\r\n    stopPropagation(event) {\r\n      if (event.stopPropagation) {\r\n        event.stopPropagation();\r\n      } else {\r\n        event.cancelBubble = true;\r\n      }\r\n    },\r\n    addHandler(element, type, handler) {\r\n      if (element.addEventListener) {\r\n        element.addEventListener(type, handler, false);  // DOM2\r\n      } else if (element.attachEvent) {\r\n        element.attachEvent(`on${type}`, handler);  // IE\r\n      } else {\r\n        element[`on${type}`] = handler;  // DOM 0\r\n      }\r\n    },\r\n    removeHandler(element, type, handler) {\r\n      if (element.removeEventListener) {\r\n        element.removeEventListener(type, handler, false); // DOM2\r\n      } else if (element.detachEvent) {\r\n        element.detachEvent(`on${type}`, handler); // IE\r\n      } else {\r\n        element[`on${type}`] = null; // DOM 0\r\n      }\r\n    },\r\n  };\r\n  /* eslint-enable no-param-reassign*/\r\n    /* Element 函数*/\r\n  const EleUtil = {\r\n    create(ele) {\r\n      return document.createElement(ele);\r\n    },\r\n    selectID(ele) {\r\n      return document.getElementById(ele);\r\n    },\r\n    select(selector) {\r\n      return document.querySelector(selector);\r\n    },\r\n  };\r\n    /* 模块*/\r\n  const mouseOverAction = {\r\n    showImg(event) {\r\n      const eventTarget = EventUtil.getTarget(event);\r\n      /* if (!eventTarget.src) {\r\n        return 'undefined';\r\n      }*/\r\n      const largeViewContainer = EleUtil.selectID('largeView');\r\n      const [scrollTopValue, scrollLeftValue] = [document.body.scrollTop, document.body.scrollLeft];\r\n      largeViewContainer.innerHTML = `<img src=${eventTarget.src} />`;\r\n      largeViewContainer.style.display = 'block';\r\n      largeViewContainer.style.top = `${event.clientY + scrollTopValue + 20}px`;\r\n      largeViewContainer.style.left = `${event.clientX + scrollLeftValue}px`;\r\n              // console.log([event.clientY,event.clientX]);\r\n              // console.log([EleUtil.selectID('largeView').style.top,\r\n              // EleUtil.selectID('largeView').style.left]);\r\n              // console.log([document.body.scrollTop,document.body.scrollLeft]);\r\n    },\r\n    clearImg() {\r\n      EleUtil.selectID('largeView').style.display = 'none';\r\n    },\r\n  };\r\n  const attachAction = {\r\n    attachEmotion(event) {\r\n      const eventTarget = EventUtil.getTarget(event);\r\n              // console.log(eventTarget);\r\n\r\n      let addressTarget = '';\r\n      let emotionAddress = '';\r\n      if (eventTarget.attributes.length === 2) {\r\n        if (eventTarget.src) {\r\n          addressTarget = eventTarget.src;\r\n          emotionAddress = attachAction.addressParse(addressTarget, 'image');\r\n        } else {\r\n                      // console.log(eventTarget.attributes);\r\n          addressTarget = eventTarget.attributes[0].nodeValue;\r\n          emotionAddress = attachAction.addressParse(addressTarget, 'plain');\r\n        }\r\n      } else {\r\n                  // console.log(eventTarget.attributes);\r\n        addressTarget = eventTarget.attributes[0].nodeValue;\r\n        emotionAddress = attachAction.addressParse(addressTarget, 'plain');\r\n      }\r\n      const selectTextArea = EleUtil.select('textarea');\r\n      const ovalue = selectTextArea.value;\r\n      const startPos = selectTextArea.selectionStart;\r\n      // const endPos = selectTextArea.selectionEnd;\r\n      selectTextArea.value = `${ovalue.slice(0, startPos)}${emotionAddress}${ovalue.slice(startPos)}`;\r\n              // console.log(eventTarget);\r\n              // console.log(emotionAddress);\r\n    },\r\n    addressParse(addStr, pattern) {\r\n      let stringReturn = '';\r\n      if (pattern === 'image') {\r\n        stringReturn = `[img]${addStr}[/img]`;\r\n      }\r\n      if (pattern === 'plain') {\r\n        stringReturn = decodeURI(addStr);\r\n      }\r\n      if (pattern === 'imageLink') {\r\n        stringReturn = addStr;\r\n      }\r\n      return stringReturn;\r\n    },\r\n  };\r\n  const createItems = {\r\n    createContainer(key) {\r\n      const ItemContainer = EleUtil.create('div');\r\n      ItemContainer.id = `eddie32${key}`;\r\n      EleUtil.selectID('toggleWindow').style.height = '100px';\r\n      EleUtil.selectID('toggleWindow').appendChild(ItemContainer);\r\n      return ItemContainer;\r\n    },\r\n    createImages(key) {\r\n      const outerContainer = createItems.createContainer(key);\r\n            // console.log(MenuList[key]);\r\n      const imgList = MenuList[key].addr;\r\n      const imgLength = imgList.length;\r\n      for (let k = 0; k < imgLength; k += 1) {\r\n        const divElement = EleUtil.create('div');\r\n        divElement.className = 'clickItem';\r\n        const imgItem = EleUtil.create('img');\r\n        imgItem.src = imgList[k];\r\n        imgItem.className = 'Ems';\r\n        imgItem.onclick = attachAction.attachEmotion;\r\n        imgItem.onmouseover = mouseOverAction.showImg;\r\n        imgItem.onmouseout = mouseOverAction.clearImg;\r\n\r\n        divElement.appendChild(imgItem);\r\n        outerContainer.appendChild(divElement);\r\n      }\r\n    },\r\n    createPlainText(key) {\r\n      const outerContainer = createItems.createContainer(key);\r\n      const txtList = MenuList[key].addr;\r\n      const txtLength = txtList.length;\r\n      for (let k = 0; k < txtLength; k += 1) {\r\n        const txtItem = EleUtil.create('span');\r\n        txtItem.style.cssText = 'cursor:pointer; margin: 10px 10px;';\r\n        txtItem.innerHTML = `<a data-sign=${encodeURI(txtList[k])} class='txtBtnEmotion'>${txtList[k]}</a>`;\r\n        if (MenuList[key].ref) {\r\n          txtItem.innerHTML = `<a data-sign=${encodeURI(txtList[k])} class='txtBtnEmotion'>${MenuList[key].ref[k]}</a>`;\r\n          EleUtil.selectID('toggleWindow').style.height = '50px';\r\n        }\r\n        txtItem.onclick = attachAction.attachEmotion;\r\n        txtItem.style.cssText = 'cursor:pointer;padding: 10px 10px:width: 50px;';\r\n        outerContainer.appendChild(txtItem);\r\n      }\r\n    },\r\n    createImageLink(key) {\r\n      const outerContainer = createItems.createContainer(key);\r\n      const imgList = MenuList[key].addr;\r\n      const refList = MenuList[key].ref;\r\n      const imgLength = imgList.length;\r\n      for (let k = 0; k < imgLength; k += 1) {\r\n        const imgItem = EleUtil.create('img');\r\n        imgItem.dataset.link = refList[k];\r\n        imgItem.src = imgList[k];\r\n        imgItem.className = 'Ems';\r\n        imgItem.onclick = attachAction.attachEmotion;\r\n        imgItem.style.cssText = 'width: 50px !important;height: 50px !important;';\r\n        outerContainer.appendChild(imgItem);\r\n      }\r\n    },\r\n  };\r\n  const clearMenu = {\r\n    clear() {\r\n      const toggleWindow = EleUtil.selectID('toggleWindow');\r\n      toggleWindow.style.display = 'none';\r\n      const togWinChildren = toggleWindow.childNodes;\r\n      for (let j = 0, len = togWinChildren.length; j < len; j += 1) {\r\n                // console.log(togWinChildren[j]);\r\n        togWinChildren[j].style.display = 'none';\r\n      }\r\n    },\r\n  };\r\n  const expandMenu = {\r\n    init(event) {\r\n      clearMenu.clear();\r\n      const eventTarget = EventUtil.getTarget(event);\r\n      EleUtil.selectID('toggleWindow').style.display = 'block';\r\n      EleUtil.selectID('toggleWindow').style.width = EleUtil.select('textarea').style.width;\r\n      const dataType = eventTarget.attributes[2].nodeValue;\r\n      const dataKey = eventTarget.attributes[1].nodeValue;\r\n      if (EleUtil.select(`#eddie32${dataKey}`)) {\r\n        EleUtil.select(`#eddie32${dataKey}`).style.display = 'block';\r\n        if (dataKey === 'item1') EleUtil.selectID('toggleWindow').style.height = '50px';\r\n        else EleUtil.selectID('toggleWindow').style.height = '100px';\r\n        return;\r\n      }\r\n      if (dataType === 'plain') {\r\n        createItems.createPlainText(dataKey);\r\n      } else if (dataType === 'image') {\r\n        createItems.createImages(dataKey);\r\n      } else if (dataType === 'imageLink') {\r\n        createItems.createImageLink(dataKey);\r\n      }\r\n    },\r\n\r\n  };\r\n\r\n\r\n  const createMenu = {\r\n    defaultID: 'emotion0000',\r\n    main() {\r\n            /* main menu*/\r\n      const mainMenu = EleUtil.create('div');\r\n      mainMenu.innerHTML = `<span id='largeView'></span><span class='subMenu' title='主菜单 version ${versionNo}'><b>⑨囧⑨</b></span>`;\r\n      mainMenu.id = createMenu.defaultID;\r\n      const MenuLength = Object.keys(MenuList).length;\r\n      for (let i = 0; i < MenuLength; i += 1) {\r\n        const MenuKey = Object.keys(MenuList)[i];\r\n        const MenuTitle = MenuList[MenuKey].title;\r\n        const MenuType = MenuList[MenuKey].datatype;\r\n        // if (!MenuType || !MenuTitle) console.log(`dataerror  ${MenuKey}`);\r\n        const testMenu = createMenu.subs(MenuTitle, expandMenu.init, MenuKey, MenuType);\r\n        mainMenu.appendChild(testMenu);\r\n      }\r\n            /* close button*/\r\n      const closeBtn = EleUtil.create('span');\r\n      closeBtn.innerHTML = '[x]';\r\n      closeBtn.className = 'subMenu';\r\n      closeBtn.id = 'closeEM';\r\n      closeBtn.onclick = clearMenu.clear;\r\n      closeBtn.style.cssText = 'cursor:pointer';\r\n      mainMenu.appendChild(closeBtn);\r\n            /* dropdown box*/\r\n      const itemWindow = EleUtil.create('div');\r\n      itemWindow.id = 'toggleWindow';\r\n      mainMenu.appendChild(itemWindow);\r\n            /* css style*/\r\n      const styleItem = EleUtil.create('style');\r\n      styleItem.innerHTML = `#emotion0000 {padding:5px 5px; vertical-align: middle;   \\\r\n                font: 12px/16px 'Hiragino Sans GB','Microsoft YaHei','Arial','sans-serif'} \\\r\n                #largeView{position:absolute; background: #fff;z-index:5000; opacity: 0.8} \\\r\n                #largeView img{width: 200px; height:200px;} \\\r\n                #toggleWindow a{padding: 5px 5px;line-height:2} \\\r\n                #toggleWindow {height: 100px; padding: 3px 3px; overflow-x: auto; margin-top:6px; \\\r\n                margin-bottom:6px; border:1px solid #ff4351; display:none;position:relative; z-index:200; }\\\r\n                .clickItem{display:inline-block; z-index:300;}\r\n                a.subBut{text-decoration: none;color: #fff;} \\\r\n                .Ems{cursor:pointer;width: 50px;height: 50px;display:inline-block;  z-index:400;} \\\r\n                a.subBut:hover{color: #fff;} \\\r\n                a.txtBtnEmotion{text-decoration:none;} \\\r\n                a.txtBtnEmotion:hover{background:#ff7680; color:#fff; } \\\r\n                .subMenu{display:inline-block;cursor:pointer; text-align:center; padding: 8px 8px; \\\r\n                font: 12px/16px 'Hiragino Sans GB','Microsoft YaHei','Arial','sans-serif';\\\r\n                background-color: #ff4351;border-color: #ff4351;color: #fff;} \\\r\n                .subMenu:hover, .subMenu:focus, .subMenu:visited{background-color: #ff7680;border-color: #ff7680;color: #fff;}`;\r\n      mainMenu.appendChild(styleItem);\r\n      return mainMenu;\r\n    },\r\n    subs(title, func, subid, subtype) {\r\n      const subMenu = EleUtil.create('span');\r\n      subMenu.id = subid;\r\n      subMenu.className = 'subMenu';\r\n      const subcontent = `<a class='subBut' data-kid=${subid} date-type=${subtype}>${title}</a>`;\r\n      subMenu.onclick = func;\r\n      subMenu.title = title;\r\n      subMenu.innerHTML = subcontent;\r\n      return subMenu;\r\n    },\r\n\r\n  };\r\n\r\n  if (typeof window !== 'undefined' && document != null) {\r\n    // let testareaEleSet = new WeakSet();\r\n    const testSet = document.getElementsByTagName('textarea');\r\n    // console.log(testSet);\r\n    // console.log(testSet.item(0));\r\n    const mainEmotionMenu = createMenu.main();\r\n    if (document.getElementById('editor-content') !== null) {\r\n      document.getElementById('editor-content').style.position = 'static';\r\n    }\r\n    for (let w = 0; w < testSet.length; w += 1) {\r\n      // console.log(testSet.item(w));\r\n      const elementTest = testSet.item(w);\r\n      // console.log(mainEmotionMenu);\r\n      elementTest.parentNode.insertBefore(mainEmotionMenu, elementTest);\r\n    }\r\n    // NodeList.prototype[Symbol.iterator] = Array.prototype[Symbol.iterator];\r\n    // HTMLCollection.prototype[Symbol.iterator] = Array.prototype[Symbol.iterator];\r\n    // const elementSet = Array.from(document.getElementsByTagName('textarea'));\r\n        /* 兼容性问题 By 喵拉布丁2017.01.30: document.getElementsByTagName方法返回的是HTMLCollection\r\n在较新版的Firefox中，HTMLCollection支持Iterator接口，所以可以用for...of循环\r\n而在Chrome中（我只在使用Chromium 50内核的浏览器下测试过），HTMLCollection不支持Iterator接口，不可用直接使用for...of循环\r\n所以建议楼主还是用老方法吧*/\r\n        // Solution stackflow: http://stackoverflow.com/questions/22754315/foreach-loop-for-htmlcollection-elements\r\n        /* 还有Array.from方法确实能解决Chrome下HTMLCollection不能用for...of循环的问题，不过Chrome 45才开始支持Array.from方法\r\n若想兼容以前的浏览器的话，可以用for...in循环，或者加个babel-polyfill脚本\r\n当然你不想兼容使用Chromium 45以前内核的浏览器也没多大问题，现在国内市场份额最多Chromium套壳浏览器--360安全浏览器的最新正式版也是采用Chromium 45内核了*/\r\n    // const elementSetLength = elementSet.length;\r\n    /* if (elementSetLength === 0) {\r\n       console.log('There is no textarea');\r\n    } */\r\n    // testareaEleSet.add(elementSet);\r\n    /* const userOption = {\r\n      userWindowHeight: 120,\r\n      userSelectTextArea: 'last',\r\n    }; */\r\n\r\n    /* eslint no-restricted-syntax: [1, \"ForOfStatement\"] */\r\n    /* for (const elementSingle of elementSet) {\r\n             console.log(elementSingle);\r\n      elementSingle.parentNode.insertBefore(mainEmotionMenu, elementSingle);\r\n    } */\r\n  }\r\n};\r\nconst imagepath = '1485412810'; // This is fake.  Global Variable.\r\nfun(imagepath);\r\n"]}