// ==UserScript==
// @name EhTagBuilder
// @name:zh-CN E绅士标签构建者
// @namespace http://www.mapaler.com/
// @description Build EhTagTranslater from Wiki.
// @description:zh-CN 从Wiki获取EhTagTranslater数据库,将E绅士TAG翻译为中文
// @include *://github.com/Mapaler/EhTagTranslator*
// @icon http://exhentai.org/favicon.ico
// @version 2.0.2
// @grant none
// @copyright 2016+, Mapaler <mapaler@163.com>
// ==/UserScript==
(function() {
var wiki_URL="https://github.com/Mapaler/EhTagTranslator/wiki"; //GitHub wiki 的地址
var rows_title="rows"; //行名的地址
var buttonInserPlace = document.getElementsByClassName("pagehead-actions")[0]; //按钮插入位置
var windowInserPlace = document.getElementsByClassName("reponav")[0]; //窗口插入位置
var scriptName = typeof(GM_info)!="undefined" ? (GM_info.script.localizedName ? GM_info.script.localizedName : GM_info.script.name) : "EhTagBuilder"; //本程序的名称
var scriptVersion = typeof(GM_info)!="undefined" ? GM_info.script.version : "本地Debug版"; //本程序的版本
var downOverCheckHook; //检测下载是否完成的循环函数
var rowsCount = 0; //行名总数
var rowsCurrent = 0; //当前下载行名
//访GM_xmlhttpRequest函数v1.0
if(typeof(GM_xmlhttpRequest) == "undefined")
{
var GM_xmlhttpRequest = function(GM_param){
var xhr = new XMLHttpRequest(); //创建XMLHttpRequest对象
if(GM_param.responseType) xhr.responseType = GM_param.responseType;
xhr.onreadystatechange = function() //设置回调函数
{
if (xhr.readyState == 4 && xhr.status == 200)
GM_param.onload(xhr);
}
for (var header in GM_param.headers){
xhr.setRequestHeader(header, GM_param.headers[header]);
}
xhr.open(GM_param.method, GM_param.url, true);
xhr.send(GM_param.data ? GM_param.data : null);
}
}
//仿GM_getValue函数v1.0
if(typeof(GM_getValue) == "undefined")
{
var GM_getValue = function(name, type){
var value = localStorage.getItem(name);
if (value == undefined) return value;
if ((/^(?:true|false)$/i.test(value) && type == undefined) || type == "boolean")
{
if (/^true$/i.test(value))
return true;
else if (/^false$/i.test(value))
return false;
else
return Boolean(value);
}
else if((/^\-?[\d\.]+$/i.test(value) && type == undefined) || type == "number")
return Number(value);
else
return value;
}
}
//仿GM_setValue函数v1.0
if(typeof(GM_setValue) == "undefined")
{
var GM_setValue = function(name, value){
localStorage.setItem(name, value);
}
}
//仿GM_deleteValue函数v1.0
if(typeof(GM_deleteValue) == "undefined")
{
var GM_deleteValue = function(name){
localStorage.removeItem(name);
}
}
//仿GM_listValues函数v1.0
if(typeof(GM_listValues) == "undefined")
{
var GM_listValues = function(){
var keys = [];
for (var ki = 0; ki < localStorage.length; ki++)
{
keys.push(localStorage.key(ki));
}
return keys;
}
}
var ds = [];
var rowObj = function(){
var obj = {
name:"",
cname:"",
info:"",
tags:[],
addTagFromName: function(rowObj)
{
if (rowObj == undefined) rowObj = this;
GM_xmlhttpRequest({
method: "GET",
url: wiki_URL + (rowObj.name.length?"/"+rowObj.name:""),
onload: function(response) {
var page_get_w = document.getElementById("ETB_page-get");
if (page_get_w)
{
var statetxt = page_get_w.getElementsByClassName("page-get-" + rowObj.name)[0];
statetxt.classList.add("page-load");
statetxt.innerHTML = "获取成功";
}
dealTags(response.responseText,rowObj.tags);
}
});
},
}
return obj;
}
var tagObj = function(){
var obj = {
type:0,
name:"",
cname:"",
info:"",
}
return obj;
}
//处理行的页面
function dealRows(response, dataset)
{
var parser = new DOMParser();
PageDOM = parser.parseFromString(response, "text/html");
var page_get_w = document.getElementById("ETB_page-get");
if (page_get_w)
{
var statetxt = page_get_w.getElementsByClassName("page-get-rows")[0];
statetxt.classList.add("page-load");
statetxt.innerHTML = "获取成功";
}
var wiki_body = PageDOM.getElementById("wiki-body");
var table = wiki_body.getElementsByTagName("table")[0].tBodies[0];
rowsCount = table.rows.length;
for(var ri=0;ri<table.rows.length;ri++)
{
var trow = table.rows[ri];
var row = new rowObj;
row.name = trow.cells[0].textContent;
row.cname = trow.cells[1].textContent;
row.info = trow.cells[2];
row.addTagFromName();
dataset.push(row);
if (page_get_w)
{
page_get_w.getElementsByClassName("select-menu-list")[0].appendChild(
buildMenuItem((function()
{
var div = document.createElement("div");
var span1 = document.createElement("span");
span1.className = "page-title";
span1.innerHTML = row.cname ;
div.appendChild(span1);
var span2 = document.createElement("span");
span2.className = "page-get-" + row.name;
span2.innerHTML = "等待";
div.appendChild(span2);
return div;
})()
)
);
}
}
}
//获取介绍是图片还是文字
function getInfoString(dom, creatImage)
{
if (creatImage == undefined) creatImage = true;
var info = [];
if (dom.childNodes != undefined)
{
for (var ci = 0; ci < dom.childNodes.length; ci++)
{
var node = dom.childNodes[ci];
info = info.concat(getDomInfoString(node, creatImage))
}
}
function getDomInfoString(node,creatImage)
{
var info = [];
switch (node.nodeName) {
case "BR":
info.push(
"\""
,"\\A"
,"\""
);
break;
case "IMG":
if (creatImage)
{
info.push(
"url(\""
,node.getAttribute("data-canonical-src")
,"\")"
);
}
break;
case "#text":
default:
if ((ci==0 || ci==(dom.childNodes.length-1)) && node.textContent == "\n")
break;
info.push(
"\""
,specialCharToCss(node.textContent)
,"\""
);
break;
}
return info;
}
return info.join("");
}
//生成按钮
function specialCharToCss(str)
{
var strn = str;
strn = strn.replace("\\","\\\\");
strn = strn.replace("\"","\\\"");
strn = strn.replace("\r","");
strn = strn.replace("\n","\\A");
return strn;
}
//处理Tag页面
function dealTags(response, dataset)
{
var parser = new DOMParser();
PageDOM = parser.parseFromString(response, "text/html");
var wiki_body = PageDOM.getElementById("wiki-body");
var table = wiki_body.getElementsByTagName("table")[0].tBodies[0];
for(var ri=0;ri<table.rows.length;ri++)
{
var trow = table.rows[ri];
var tag = new tagObj;
if (trow.cells.length > 2)
{//没有足够单元格的跳过
tag.name = trow.cells[0].textContent;
tag.cname = trow.cells[1];
tag.info = trow.cells[2];
tag.type = tag.name.replace(/\s/ig,"").length < 1 ? 1 : 0;
dataset.push(tag);
}
}
rowsCurrent++;
}
//点击开始任务按钮
function startProgram(dataset){
var downOver = startProgramCheck(dataset);
if (downOverCheckHook == undefined || !downOver)
{
GM_xmlhttpRequest({
method: "GET",
url: wiki_URL + (rows_title.length?"/"+rows_title:""),
onload: function(response) {
dealRows(response.responseText,dataset);
}
});
downOverCheckHook = setInterval(function () { startProgramCheck(dataset) }, 200);
}
if (!downOver)
{
var page_get_w = document.getElementById("ETB_page-get");
if (!page_get_w)
{
windowInserPlace.appendChild(buildMenuModal("window", "ETB_page-get", "数据获取进度", null, [
buildMenuList([
buildMenuItem((function()
{
var div = document.createElement("div");
var span1 = document.createElement("span");
span1.className = "page-title";
span1.innerHTML = "列表页面";
div.appendChild(span1);
var span2 = document.createElement("span");
span2.className = "page-get-rows";
span2.innerHTML = "等待";
div.appendChild(span2);
return div;
})()
)
])
],
[
".ETB_page-get .page-title" + "{\r\n" + [
'font-weight: bold',
'margin-right: 15px',
].join(';\r\n') + "\r\n}",
".ETB_page-get .page-load" + "{\r\n" + [
'color: #0A0',
].join(';\r\n') + "\r\n}",
].join('\r\n')
));
}
else
{
page_get_w.style.display = "block";
}
}
}
//检测下载完成情况
function startProgramCheck(dataset)
{
if (rowsCount > 0 && rowsCurrent >= rowsCount)
{
console.debug("获取完成");
clearInterval(downOverCheckHook);
var css = buildCSS(dataset
,GM_getValue("ETB_create-info","boolean")
,GM_getValue("ETB_create-info-image","boolean")
,GM_getValue("ETB_create-cname-image","boolean")
);
var downBlob = new Blob([css], {'type': 'text\/css'});
var downurl = window.URL.createObjectURL(downBlob);
var css_output_w = document.getElementById("ETB_css-output");
if (!css_output_w)
{
windowInserPlace.appendChild(buildMenuModal("window", "ETB_css-output", "用户样式版EhTagTranslator", null,
[
buildMenuList([
buildMenuItem("CSS文本",
(function()
{
var textarea = document.createElement("textarea");
textarea.id = "ETB_css-textarea";
textarea.name = textarea.id;
textarea.className = "txta " + textarea.id;
textarea.value = css;
textarea.wrap = "off";
textarea.setAttribute("readonly",true);
return textarea;
})()
,buildSVG("css")),
buildMenuItem("直接下载CSS文件",null,buildSVG("download"),downurl,1)
])
],
[
".ETB_css-output .txta" + "{\r\n" + [
'resize: vertical',
'width:100%',
'height:300px',
].join(';\r\n') + "\r\n}",
].join('\r\n')
));
}
else
{
css_output_w.style.display = "block";
css_output_w.getElementsByClassName("ETB_css-textarea")[0].value = css;
css_output_w.getElementsByTagName("a")[0].href = downurl;
}
var page_get_w = document.getElementById("ETB_page-get");
if (page_get_w)
{
page_get_w.parentNode.removeChild(page_get_w);
}
return true;
}
else
{
console.debug("获取%d/%d",rowsCurrent, rowsCount);
return false;
}
}
//开始构建CSS
function buildCSS(dataset, createInfo, createInfoImage, createCnameImage)
{
if (createInfo == undefined) createInfo = true;
if (createInfoImage == undefined) createInfoImage = true;
if (createCnameImage == undefined) createCnameImage = true;
var date = new Date();
var cssAry = [];
//样式信息说明
cssAry.push(
"/* EhTagTranslator 用户样式版,由 " + scriptName + " v" + scriptVersion + " 构建"
," * 构建时间为"
," * " + date.toString()
," */"
)
//样式命名区间与应用范围
cssAry.push(
//▼CSS内容部分
"@namespace url(http://www.w3.org/1999/xhtml);"
,""
,"@-moz-document"
," url-prefix('http://exhentai.org/g/'), "
," url-prefix('http://g.e-hentai.org/g/')"
,"{"
//▲CSS内容部分
);
//链接通用样式部分
cssAry.push(GM_getValue("ETB_global-style"));
for (var ri = 0; ri < dataset.length; ri++)
{
var row = dataset[ri];
cssAry.push( //添加行名的注释
"/* " + row.name
," * " + row.cname
," */"
);
for (var ti = 0; ti < row.tags.length; ti++)
{
var tag = row.tags[ti];
if (tag.type == 0)
{
cssAry.push(""
//▼CSS内容部分
," a[id=\"ta_" + (row.name=="misc"?"":row.name + ":") + tag.name.replace(/ /ig,"_") + "\"]{"
," font-size:0px;"
," }"
," a[id=\"ta_" + (row.name=="misc"?"":row.name + ":") + tag.name.replace(/ /ig,"_") + "\"]::before{"
," content:" + getInfoString(tag.cname, createCnameImage) + ";"
," }"
//▲CSS内容部分
);
if (createInfo)
{
var sinfo = getInfoString(tag.info, createInfoImage);
if (sinfo.replace(/\s/ig,"").length > 0)
{
cssAry.push(""
//▼CSS内容部分
," a[id=\"ta_" + (row.name=="misc"?"":row.name + ":") + tag.name.replace(/ /ig,"_") + "\"]::after{"
," content:" + sinfo + ";"
," }"
//▲CSS内容部分
);
}
}
}
else
{ //将注释写成CSS注释
cssAry.push(
"/* " + tag.cname
," * " + tag.info
," */"
);
}
}
}
cssAry.push(
//▼CSS内容部分
"}"
//▲CSS内容部分
)
var css = cssAry.join("\r\n");
return css;
}
//生成按钮
function buildButton(title, icon, modal)
{
var li = document.createElement("li");
var select_menu = document.createElement("div");
select_menu.className = "select-menu js-menu-container js-select-menu";
li.appendChild(select_menu);
var button = document.createElement("button");
button.className = "btn btn-sm select-menu-button js-menu-target css-truncate";
select_menu.appendChild(button);
var span = document.createElement("span");
span.className = "js-select-button";
if (icon != undefined)
span.appendChild(icon);
span.innerHTML += title;
button.appendChild(span);
select_menu.appendChild(modal);
return li;
}
//生成菜单窗口
function buildMenuModal(mode, id, stitle, filters, lists, sstyle)
{
var modal_holder = document.createElement("div");
modal_holder.className = "select-menu-modal-holder js-menu-content js-navigation-container js-active-navigation-container";
if (id != undefined)
{
modal_holder.id = id;
modal_holder.classList.add(id);
}
if (sstyle != undefined)
{
var style = document.createElement("style");
style.innerHTML = sstyle;
modal_holder.appendChild(style);
}
var modal = document.createElement("div");
modal.className = "select-menu-modal subscription-menu-modal js-menu-content";
modal_holder.appendChild(modal);
var header = document.createElement("div");
header.className = "select-menu-header js-navigation-enable";
modal.appendChild(header);
var CloseSvg = buildSVG("Close");
header.appendChild(CloseSvg);
switch (mode) {
case "window":
modal_holder.style.display = "block";
CloseSvg.onclick = function(){
modal_holder.style.display = "none";
}
break;
case "menu":
default:
break;
}
var title = document.createElement("span");
title.className = "select-menu-title";
title.innerHTML = stitle;
header.appendChild(title);
if (lists != undefined)
{
for(var li = 0; li < lists.length; li++)
{
var list = lists[li];
if (list)
modal.appendChild(list);
}
}
return modal_holder;
}
//构建一个菜单列表框架
function buildMenuList(items)
{
var list = document.createElement("div");
list.className = "select-menu-list js-navigation-container";
if (items != undefined)
{
for(var ii = 0; ii < items.length; ii++)
{
var item = items[ii];
if (item)
list.appendChild(item);
}
}
return list;
}
//构建一个菜单列表项
function buildMenuItem(heading, description, icon, callback, type)
{
if (heading == undefined) heading = "未设定";
var item = document.createElement("div");
if (type == 3)
{
var item = document.createElement("label");
item.setAttribute('for', callback);
}
else if (typeof(callback) == "string")
{
var item = document.createElement("a");
item.target = "_blank";
item.href = callback;
}
else
{
if (callback) item.onclick = callback;
}
item.className = "select-menu-item";
switch (type) {
case 0:
item.classList.add("js-navigation-item");
break;
case 1:
item.classList.add("select-menu-action");
break;
default:
break;
}
if (icon != undefined) item.appendChild(icon);
var item_text = document.createElement("div");
item_text.className = "select-menu-item-text";
item.appendChild(item_text);
if (description != undefined)
{
var item_heading = document.createElement("span");
item_heading.className = "select-menu-item-heading";
if (typeof(heading)=="string")
item_heading.innerHTML = heading;
else
item_heading.appendChild(heading);
var item_description = document.createElement("span");
item_description.className = "description";
if (typeof(description)=="string")
item_description.innerHTML = description;
else
item_description.appendChild(description);
item_text.appendChild(item_heading);
item_text.appendChild(item_description);
}
else
{
if (typeof(heading)=="string")
item_text.innerHTML = heading;
else
item_text.appendChild(heading);
}
return item;
}
//生成svg
function buildSVG(mode,check)
{
if (check == undefined) check = false;
var CloseSvgDiv = document.createElement("div");
var innerHTML = "";
switch (mode) {
case "Close":
innerHTML = '<svg aria-label="Close" class="octicon octicon-x js-menu-close" height="16" role="img" version="1.1" viewBox="0 0 12 16" width="12"><path d="M7.48 8l3.75 3.75-1.48 1.48-3.75-3.75-3.75 3.75-1.48-1.48 3.75-3.75L0.77 4.25l1.48-1.48 3.75 3.75 3.75-3.75 1.48 1.48-3.75 3.75z"/></svg>';
break;
case "Settings":
innerHTML = '<svg width="14" viewBox="0 0 14 16" version="1.1" height="16" class="octicon octicon-question select-menu-item-icon" aria-hidden="true"><path d="M14 8.77V7.17l-1.94-0.64-0.45-1.09 0.88-1.84-1.13-1.13-1.81 0.91-1.09-0.45-0.69-1.92H6.17l-0.63 1.94-1.11 0.45-1.84-0.88-1.13 1.13 0.91 1.81-0.45 1.09L0 7.23v1.59l1.94 0.64 0.45 1.09-0.88 1.84 1.13 1.13 1.81-0.91 1.09 0.45 0.69 1.92h1.59l0.63-1.94 1.11-0.45 1.84 0.88 1.13-1.13-0.92-1.81 0.47-1.09 1.92-0.69zM7 11c-1.66 0-3-1.34-3-3s1.34-3 3-3 3 1.34 3 3-1.34 3-3 3z"/></svg>';
break;
case "check":
innerHTML = '<svg width="12" viewBox="0 0 12 16" version="1.1" height="16" class="octicon octicon-check select-menu-item-icon" aria-hidden="true"><path d="M12 5L4 13 0 9l1.5-1.5 2.5 2.5 6.5-6.5 1.5 1.5z"/></svg>';
break;
case "question":
innerHTML = '<svg width="14" viewBox="0 0 14 16" version="1.1" height="16" class="octicon octicon-question select-menu-item-icon" aria-hidden="true"><path d="M6 10h2v2H6V10z m4-3.5c0 2.14-2 2.5-2 2.5H6c0-0.55 0.45-1 1-1h0.5c0.28 0 0.5-0.22 0.5-0.5v-1c0-0.28-0.22-0.5-0.5-0.5h-1c-0.28 0-0.5 0.22-0.5 0.5v0.5H4c0-1.5 1.5-3 3-3s3 1 3 2.5zM7 2.3c3.14 0 5.7 2.56 5.7 5.7S10.14 13.7 7 13.7 1.3 11.14 1.3 8s2.56-5.7 5.7-5.7m0-1.3C3.14 1 0 4.14 0 8s3.14 7 7 7 7-3.14 7-7S10.86 1 7 1z"/></svg>';
break;
case "download":
innerHTML = '<svg width="16" viewBox="0 0 16 16" version="1.1" height="16" class="octicon octicon-desktop-download select-menu-item-icon" aria-hidden="true"><path d="M4 6h3V0h2v6h3L8 10 4 6z m11-4H11v1h4v8H1V3h4v-1H1c-0.55 0-1 0.45-1 1v9c0 0.55 0.45 1 1 1h5.34c-0.25 0.61-0.86 1.39-2.34 2h8c-1.48-0.61-2.09-1.39-2.34-2h5.34c0.55 0 1-0.45 1-1V3c0-0.55-0.45-1-1-1z"/></svg>';
break;
case "book":
innerHTML = '<svg width="16" viewBox="0 0 16 16" version="1.1" height="16" class="octicon octicon-book select-menu-item-icon" aria-hidden="true"><path d="M2 5h4v1H2v-1z m0 3h4v-1H2v1z m0 2h4v-1H2v1z m11-5H9v1h4v-1z m0 2H9v1h4v-1z m0 2H9v1h4v-1z m2-6v9c0 0.55-0.45 1-1 1H8.5l-1 1-1-1H1c-0.55 0-1-0.45-1-1V3c0-0.55 0.45-1 1-1h5.5l1 1 1-1h5.5c0.55 0 1 0.45 1 1z m-8 0.5l-0.5-0.5H1v9h6V3.5z m7-0.5H8.5l-0.5 0.5v8.5h6V3z"/></svg>';
break;
case "css":
innerHTML = '<img width="16" height="16" class="octicon octicon-question select-menu-item-icon" aria-hidden="true" src=""/>';
break;
case "js":
innerHTML = '<img width="16" height="16" class="octicon octicon-question select-menu-item-icon" aria-hidden="true" src=""/>';
break;
case "eh":
innerHTML = '<img width="16" height="16" class="octicon" aria-hidden="true" src=""/>';
break;
default:
innerHTML = '<svg width="12" viewBox="0 0 12 16" version="1.1" height="16" class="octicon octicon-check select-menu-item-icon" aria-hidden="true"></svg>';
break;
}
CloseSvgDiv.innerHTML = innerHTML;
var CloseSvg = CloseSvgDiv.firstChild;
if(check)
CloseSvg.classList.add("octicon-check");
else
CloseSvg.classList.remove("octicon-check");
return CloseSvg;
}
//打开设置窗口
function startOption()
{
var option_modal_w = document.getElementById("ETB_option");
if (!option_modal_w)
{
windowInserPlace.appendChild(
buildMenuModal("window", "ETB_option", scriptName + " 设置", null, [
buildMenuList([
buildMenuItem("生成简介","生成光标移动到Tag上时出现的简介。",
(function(){
var chk1 = document.createElement("input");
chk1.type = "checkbox";
chk1.id = "ETB_create-info";
chk1.name = "ETB_create-info";
chk1.className = "octicon octicon-question select-menu-item-icon ETB_create-info";
return chk1;
})()
,"ETB_create-info",3),
buildMenuItem("生成简介图片","生成简介中的图片。",
(function(){
var chk2 = document.createElement("input");
chk2.type = "checkbox";
chk2.id = "ETB_create-info-image";
chk2.name = "ETB_create-info-image";
chk2.className = "octicon octicon-question select-menu-item-icon ETB_create-info-image";
return chk2;
})()
,"ETB_create-info-image",3),
buildMenuItem("生成中文名图片","生成中文名中的图片,一般为名称前的小图标。",
(function(){
var chk2 = document.createElement("input");
chk2.type = "checkbox";
chk2.id = "ETB_create-cname-image";
chk2.name = "ETB_create-cname-image";
chk2.className = "octicon octicon-question select-menu-item-icon ETB_create-cname-image";
return chk2;
})()
,"ETB_create-cname-image",3),
buildMenuItem("Tag通用样式",
(function(){
var div = document.createElement("div");
var span1 = document.createElement("span");
span1.innerHTML = "Tag统一应用的样式,可修改为自己喜爱的样式。不会自己写CSS的用户可每次更新本脚本后重置一下,应用最新的通用样式。";
div.appendChild(span1);
var textarea = document.createElement("textarea");
textarea.id = "ETB_global-style";
textarea.name = "ETB_global-style";
textarea.className = "txta ETB_global-style";
textarea.value = GM_getValue("ETB_global-style")?GM_getValue("ETB_global-style"):"";
textarea.wrap = "off";
div.appendChild(textarea);
return div;
})()
,null,"ETB_global-style",3),
]),
buildMenuList([
buildMenuItem(
(function(){
var div = document.createElement("div");
var btn1 = document.createElement("button");
btn1.innerHTML = "重置";
btn1.id = "ETB_reset-option";
btn1.name = "ETB_reset-option";
btn1.className = "btn btn-sm btn-danger ETB_reset-option";
btn1.onclick = function(){
resetOption();
}
div.appendChild(btn1);
/*
var btn2 = document.createElement("button");
btn2.innerHTML = "取消";
btn2.className = "btn btn-sm";
div.appendChild(btn2);
*/
var btn3 = document.createElement("button");
btn3.innerHTML = "保存";
btn3.id = "ETB_save-option";
btn3.name = "ETB_save-option";
btn3.className = "btn btn-sm btn-primary ETB_save-option";
btn3.onclick = function(){
saveOption();
}
div.appendChild(btn3);
return div;
})()
,null,null,null,1),
]),
],
[
".ETB_option .select-menu-item-text" + "{\r\n" + [
'font-weight: normal',
].join(';\r\n') + "\r\n}",
".ETB_option .txta" + "{\r\n" + [
'resize: vertical',
'width: 100%',
'height: 150px',
].join(';\r\n') + "\r\n}",
".ETB_option .ETB_save-option" + "{\r\n" + [
'float: right',
].join(';\r\n') + "\r\n}",
].join('\r\n')
)
);
}
else
{
option_modal_w.style.display = "block";
}
}
//重置设置
function resetOption(part)
{
function partReset(name,value,ispart)
{
if (!ispart || ispart && GM_getValue(name) == undefined)
GM_setValue(name, value);
}
var cssAry = [];
cssAry.push(
//▼CSS内容部分
" #taglist a::before{"
," font-size:12px;"
," }"
," #taglist a::after{"
," color:#fff;"
," font-size:12pt;"
," background: #666;"
," border: 1px solid #fff;"
," border-radius:5px;"
," float:left;"
," position:fixed;"
," z-index:999;"
," padding:2px;"
," box-shadow: 3px 3px 5px #888;"
," min-width:150px;"
," max-width:260px;"
," white-space:pre-wrap;"
," opacity: 0;"
," transition: opacity 0.2s;"
," transform: translate(30px,25px);"
," top:0px;"
," pointer-events:none;"
," }"
," #taglist a:hover::after,#taglist a:focus::after{"
," opacity: 1;"
," transition: opacity 0.5s;"
," }"
//▲CSS内容部分
);
partReset("ETB_global-style",cssAry.join("\r\n"),part);
partReset("ETB_create-info","true",part);
partReset("ETB_create-info-image","true",part);
partReset("ETB_create-cname-image","true",part);
reloadOption();
}
//访问设置用递归函数
function visitChildNodes(dom, callback)
{
callback(dom);
for (var ci = 0; ci < dom.childNodes.length; ci++)
{
visitChildNodes(dom.childNodes[ci], callback);
}
}
//保存设置
function saveOption()
{
var option_modal_w = document.getElementById("ETB_option");
if (option_modal_w)
{
visitChildNodes(option_modal_w,setValue);
}
function setValue(dom)
{
if (dom.name && dom.value != undefined)
{
if (dom.type == "checkbox")
GM_setValue(dom.name, dom.checked);
else
GM_setValue(dom.name, dom.value);
}
}
option_modal_w.style.display = "none";
}
//重新加载设置窗口
function reloadOption()
{
var option_modal_w = document.getElementById("ETB_option");
if (option_modal_w)
{
visitChildNodes(option_modal_w, getValue);
}
function getValue(dom)
{
if (dom.name && dom.value != undefined)
{
var value = GM_getValue(dom.name);
if (value != undefined)
{
if (dom.type != undefined && dom.type == "checkbox")
dom.checked = value;
else
dom.value = value;
}
}
}
}
resetOption(true); //重置设置
var menu_modal = buildMenuModal("menu", null, "请选择任务 v" + scriptVersion, null, [
buildMenuList([
buildMenuItem("生成CSS","生成用户样式版EhTagTranslator,请使用Stylish扩展安装。手机火狐也可使用。",buildSVG("css"),function(){
startProgram(ds);
}
,0),
/*buildMenuItem("生成JSON","生成用户脚本版EhTagTranslator数据库,功能暂未开发。",buildSVG("js"),function(){
alert("设想中功能,暂未开发,仅占位");
}
,0)*/
]),
buildMenuList([
buildMenuItem("设置选项",null,buildSVG("Settings"),function(){startOption();reloadOption();},1),
buildMenuItem("查看使用帮助",null,buildSVG("question"),"https://github.com/Mapaler/EhTagTranslator/blob/master/README.md",1),
buildMenuItem("贡献翻译",null,buildSVG("book"),"https://github.com/Mapaler/EhTagTranslator/wiki",1),
])
]);
buttonInserPlace.insertBefore(buildButton(" " + scriptName + " ", buildSVG("eh"), menu_modal),buttonInserPlace.getElementsByTagName("li")[0]);
})();