// ==UserScript==
// @name 小说下载器
// @name:en novel-downloader
// @name:ja 小説ダウンローダー
// @description 一个可扩展的通用型小说下载器。
// @description:en An scalable universal novel downloader.
// @description:ja スケーラブルなユニバーサル小説ダウンローダー。
// @version 5.2.991
// @author bgme
// @supportURL https://github.com/404-novel-project/novel-downloader
// @exclude *://www.jjwxc.net/onebook.php?novelid=*&chapterid=*
// @exclude *://m.yuzhaige.cc/tag/*/
// @exclude *://m.yuzhaige.cc/sort/*/
// @exclude *://m.yuzhaige.cc/top/*/
// @exclude *://m.yuzhaige.cc/full/*/
// @exclude *://m.yuzhaige.cc/book/*/
// @exclude *://m.yushuge123.com/tag/*/
// @exclude *://m.yushuge123.com/sort/*/
// @exclude *://m.yushuge123.com/top/*/
// @exclude *://m.yushuge123.com/full/*/
// @exclude *://m.yushuge123.com/book/*/
// @exclude *://m.haitangtxt.net/tag/*/
// @exclude *://m.haitangtxt.net/sort/*/
// @exclude *://m.haitangtxt.net/top/*/
// @exclude *://m.haitangtxt.net/full/*/
// @exclude *://m.haitangtxt.net/book/*/
// @exclude *://www.linovel.net/book/*/*.html
// @exclude *://www.qimao.com/shuku/*-*/
// @exclude *://www.trxs.cc/tongren/*/*.html
// @exclude *://www.trxs.me/tongren/*/*.html
// @exclude *://www.trxs123.com/tongren/*/*.html
// @exclude *://www.jpxs123.com/*/*/*.html
// @exclude *://www.tongrenquan.org/tongren/*/*.html
// @exclude *://www.tongrenquan.me/tongren/*/*.html
// @exclude *://trxs.cc/tongren/*/*.html
// @exclude *://trxs.me/tongren/*/*.html
// @exclude *://trxs123.com/tongren/*/*.html
// @exclude *://jpxs123.com/*/*/*.html
// @exclude *://tongrenquan.org/tongren/*/*.html
// @exclude *://tongrenquan.me/tongren/*/*.html
// @exclude *://www.i25zw.com/lastupdate/
// @exclude *://www.i25zw.com/postdate/
// @exclude *://www.i25zw.com/monthvisit/
// @exclude *://www.i25zw.com/goodnum/
// @exclude *://www.i25zw.com/goodnew/
// @exclude *://dijiuben.com/*_*/*.html
// @exclude *://ncode.syosetu.com/*/*/
// @exclude *://novel18.syosetu.com/*/*/
// @exclude *://manhua.idmzj.com/
// @exclude *://houhuayuan.vip/
// @exclude *://book.sfacg.com/Novel/*/*/*/
// @exclude *://www.alphapolis.co.jp/novel/*/*/episode/*
// @exclude *://novelup.plus/story/*/*
// @exclude *://www.linovelib.com/novel/*/*.html
// @exclude *://www.bilinovel.com/novel/*/*.html
// @exclude *://www.qbtr.cc/*/*/*.html
// @exclude *://www.ciyuanji.com/chapter/*
// @match *://book.sfacg.com/Novel/*/MainIndex/
// @match *://book.sfacg.com/Novel/*/
// @match *://m.sfacg.com/b/*/
// @match *://book.qidian.com/info/*
// @match *://www.qidian.com/book/*
// @match *://www.jjwxc.net/onebook.php?novelid=*
// @match *://m.jjwxc.com/book2/*
// @match *://m.jjwxc.net/book2/*
// @match *://www.gongzicp.com/novel-*.html
// @match *://gongzicp.com/novel-*.html
// @match *://m.gongzicp.com/novel-*.html
// @match *://book.zongheng.com/showchapter/*.html
// @match *://book.zongheng.com/book/*.html
// @match *://www.zongheng.com/detail/*
// @match *://huayu.zongheng.com/showchapter/*.html
// @match *://huayu.zongheng.com/book/*.html
// @match *://www.linovel.net/book/*.html
// @match *://www.17k.com/list/*.html
// @match *://www.17k.com/book/*.html
// @match *://www.shuhai.com/book/*.htm
// @match *://mm.shuhai.com/book/*.htm
// @match *://www.tadu.com/book/*
// @match *://www.qimao.com/shuku/*/
// @match *://sosad.fun/threads/*/profile*
// @match *://wenzhan.org/threads/*/profile*
// @match *://sosadfun.com/threads/*/profile*
// @match *://xn--pxtr7m5ny.com/threads/*/profile*
// @match *://xn--pxtr7m.com/threads/*/profile*
// @match *://xn--pxtr7m5ny.net/threads/*/profile*
// @match *://xn--pxtr7m.net/threads/*/profile*
// @match *://sosadfun.link/threads/*/profile*
// @match *://www.sosad.fun/threads/*/profile*
// @match *://www.wenzhan.org/threads/*/profile*
// @match *://www.sosadfun.com/threads/*/profile*
// @match *://www.xn--pxtr7m5ny.com/threads/*/profile*
// @match *://www.xn--pxtr7m.com/threads/*/profile*
// @match *://www.xn--pxtr7m5ny.net/threads/*/profile*
// @match *://www.xn--pxtr7m.net/threads/*/profile*
// @match *://www.sosadfun.link/threads/*/profile*
// @match *://www.uukanshu.com/b/*/
// @match *://www.yiruan.la/article/*.html
// @match *://www.ishuquge.org/txt/*/index.html
// @match *://wap.ishuquge.org/s/*.html
// @match *://wap.ishuquge.org/d/*.html
// @match *://www.xkzw.org/xkzw*/
// @match *://www.lewenn.net/lw*/
// @match *://www.266ks.com/book/*/
// @match *://www.266ks.com/book/*/index*.html
// @match *://www.hetushu.com/book/*/index.html
// @match *://hetushu.com/book/*/index.html
// @match *://www.gashuw.com/biquge_*/
// @match *://www.1pwx.com/*.htm
// @match *://www.81book.com/book/*/
// @match *://www.81zw.com/book/*/
// @match *://m.yushuge123.com/*/*/
// @match *://www.wanben.info/*/
// @match *://m.wanben.info/*/
// @match *://www.idejian.com/book/*/
// @match *://www.wenku8.net/novel/*/*/index.htm
// @match *://www.wenku8.net/book/*.htm
// @match *://www.idmzj.com/info/*.html
// @match *://manhua.idmzj.com/*
// @match *://www.westnovel.com/*/*/
// @match *://www.mht99.com/*/
// @match *://www.banzhuer.org/*_*/
// @match *://www.xbiquge.tw/book/*/
// @match *://www.xsbiquge.la/book/*/
// @match *://www.007zw.com/shuzhai/*/
// @match *://www.linovelib.com/novel/*/catalog
// @match *://www.linovelib.com/novel/*.html
// @match *://www.bilinovel.com/novel/*.html
// @match *://www.bilinovel.com/novel/*/catalog
// @match *://www.luoqiuzw.com/book/*/
// @match *://www.yibige.cc/*/
// @match *://www.fushuwang.org/*/*/*/*.html
// @match *://www.fushuwang.org/*/*/*/*.html?*
// @match *://www.fushuwang.org/*/*/*.html
// @match *://www.fushuwang.org/*/*/*.html?*
// @match *://www.soxscc.net/*/
// @match *://www.soxscc.org/*/
// @match *://www.soxs.cc/*/
// @match *://www.soxscc.cc/*/
// @match *://www.soshuwu.com/*/
// @match *://www.soxscc.net/book/*.html
// @match *://www.soxscc.org/book/*.html
// @match *://www.soxs.cc/book/*.html
// @match *://www.soxscc.cc/book/*.html
// @match *://www.soshuwu.com/book/*.html
// @match *://www.shubaowa.org/*_*/
// @match *://www.fuguoduxs.com/*_*/
// @match *://www.630shu.net/shu/*.html
// @match *://www.trxs.cc/tongren/*.html
// @match *://www.trxs.me/tongren/*.html
// @match *://www.trxs123.com/tongren/*.html
// @match *://www.jpxs123.com/*/*.html
// @match *://www.tongrenquan.org/tongren/*.html
// @match *://www.tongrenquan.me/tongren/*.html
// @match *://trxs.cc/tongren/*.html
// @match *://trxs.me/tongren/*.html
// @match *://trxs123.com/tongren/*.html
// @match *://jpxs123.com/*/*.html
// @match *://tongrenquan.org/tongren/*.html
// @match *://tongrenquan.me/tongren/*.html
// @match *://www.256wenku.com/read/*/index.html
// @match *://www.256wenku.com/read/*/
// @match *://www.biquge66.com/biquge*/
// @match *://*.lofter.com/
// @match *://*.lofter.com/?page=*
// @match *://www.shubl.com/book/book_detail/*
// @match *://m.haitangtxt.net/*/*/
// @match *://ebook.longmabook.com/*
// @match *://www.haitangbook.com/*
// @match *://www.longmabookcn.com/*
// @match *://ebook.lmbooks.com/*
// @match *://www.lmebooks.com/*
// @match *://www.haitbook.com/*
// @match *://www.htwhbook.com/*
// @match *://www.myhtebook.com/*
// @match *://www.lovehtbooks.com/*
// @match *://www.myhtebooks.com/*
// @match *://www.myhtlmebook.com/*
// @match *://jp.myhtebook.com/*
// @match *://jp.myhtlmebook.com/*
// @match *://ebook.urhtbooks.com/*
// @match *://www.urhtbooks.com/*
// @match *://www.newhtbook.com/*
// @match *://www.lvhtebook.com/*
// @match *://jp.lvhtebook.com/*
// @match *://www.htlvbooks.com/*
// @match *://dijiuben.com/*_*
// @match *://www.biquzw.la/*_*/
// @match *://www.i25zw.com/*/
// @match *://www.tycqzw.com/*_*/
// @match *://www.kanunu8.com/*
// @match *://www.ciyuanji.com/*
// @match *://ciyuanji.com/*
// @match *://m.xiaoshuowanben.com/*/
// @match *://www.xiaoshuowanben.com/*/
// @match *://www.ranwen.la/files/article/*/*/
// @match *://www.wangshugu.org/books/*/*/
// @match *://m.baihexs.com/info-*/
// @match *://www.quanshuzhai.com/book/*.html
// @match *://masiro.me/admin/novelView?novel_id=*
// @match *://www.pixiv.net/novel/show.php?*
// @match *://www.pixiv.net/novel/series/*
// @match *://kakuyomu.jp/works/*
// @match *://ncode.syosetu.com/*/
// @match *://ncode.syosetu.com/*
// @match *://novel18.syosetu.com/*/
// @match *://novel18.syosetu.com/*
// @match *://syosetu.org/novel/*/
// @match *://houhuayuan.vip/*
// @match *://zhaoze.vip/*/
// @match *://www.myrics.com/novels/*
// @match *://m.lvsewx.com/ebook/*.html
// @match *://www.lvsewx.com/ebook/*.html
// @match *://www.shencou.com/books/read_*.html
// @match *://www.tianyabooks.com/*/*/
// @match *://www.aixiaxs.net/*/*/
// @match *://jingcaiyuedu6.com/novel/*.html
// @match *://www.hanwujinian.com/book/*
// @match *://manga.bilibili.com/detail/mc*
// @match *://www.aixdzs.com/novel/*
// @match *://www.cool18.com/bbs4/index.php?*
// @match *://www.b5200.net/*_*/
// @match *://www.yqxsge.cc/html/*/*/index.html
// @match *://www.18kanshu.com/*/*/info.html
// @match *://www.18kanshu.com/module/novel/info.php?*
// @match *://www.bixia3.com/txt/*/
// @match *://www.xiaoshuowu.com/html/*/*/
// @match *://www.xrzww.com/bookdetail/*
// @match *://xrzww.com/bookdetail/*
// @match *://www.youdubook.com/bookdetail/*
// @match *://youdubook.com/bookdetail/*
// @match *://colorful-fantasybooks.com/module/novel/info.php?*
// @match *://www.dizishu.com/*/*/
// @match *://www.ibiquge.la/*/*/
// @match *://www.akatsuki-novels.com/stories/index/novel_id~*
// @match *://www.alphapolis.co.jp/novel/*/*
// @match *://novelup.plus/story/*
// @match *://69shuba.cx/book/*.htm
// @match *://book.xbookcn.net/search/label/*
// @match *://new-read.readmoo.com/mooreader/*
// @match *://www.iqingguo.com/book/detail/?id=*
// @match *://www.ywggzy.com/bxwx/*/
// @match *://www.piaotia.com/html/*
// @match *://www.mbtxt.la/go/*/
// @match *://m.kuangguwenhua.com/bqg/*/
// @match *://m.kuangguwenhua.com/bqg/11365/index_*.html
// @match *://www.xyb3.net/5200/*/
// @match *://hongxiuzhao.me/*.html
// @match *://www.mijiashe.com/*/
// @match *://www.duread.cn/book/*
// @match *://www.ttkan.co/novel/chapters/*
// @match *://cn.ttkan.co/novel/chapters/*
// @match *://tw.ttkan.co/novel/chapters/*
// @match *://www.xiaoshuowanben.com/*/
// @match *://www.xbyuan.com/*/
// @match *://www.quanzhifashi.com/novel/*/
// @match *://www.42zw.la/book/*/
// @match *://www.boqugew.com/shu/*/
// @match *://www.qbtr.cc/*/*.html
// @match *://b.guidaye.com/*/*/
// @match *://www.esjzone.me/detail/*
// @match *://www.esjzone.cc/detail/*
// @compatible Firefox 100+
// @compatible Chrome 85+
// @compatible Edge 85+
// @compatible Opera 71+
// @compatible Safari 13.1+
// @connect self
// @connect qidian.com
// @connect yuewen.com
// @connect kuangxiangit.com
// @connect sinaimg.cn
// @connect jjwxc.net
// @connect jjwxc.com
// @connect gashuw.com
// @connect qpic.cn
// @connect zongheng.com
// @connect 17k.com
// @connect uukanshu.com
// @connect aliyuncs.com
// @connect cdn.bcebos.com
// @connect rs.sfacg.com
// @connect shuhai.com
// @connect ch-intel.com
// @connect huluxia.com
// @connect linovel.net
// @connect ax1x.com
// @connect tadu.com
// @connect zhangyue01.com
// @connect cdn.wtzw.com
// @connect wenku8.com
// @connect idmzj.com
// @connect 007zw.com
// @connect hongyeshuzhai.com
// @connect linovelib.com
// @connect soxscc.net
// @connect soxscc.org
// @connect soxs.cc
// @connect soxscc.cc
// @connect soshuwu.com
// @connect idejian.com
// @connect postimg.cc
// @connect lofter.com
// @connect lf127.net
// @connect 126.net
// @connect shubl.com
// @connect loli.net
// @connect alicdn.com
// @connect toutiaoimg.com
// @connect imgdb.cn
// @connect meego.cn
// @connect poco.cn
// @connect dijiuzww.com
// @connect dijiushu.net
// @connect i25zw.com
// @connect sina.com.cn
// @connect ciyuanji.com
// @connect wanben.org
// @connect baihexs.com
// @connect masiro.me
// @connect pximg.net
// @connect mitemin.net
// @connect myrics.com
// @connect jingcaiyuedu6.com
// @connect aixdzs.com
// @connect b5200.net
// @connect xrzww.com
// @connect youdubook.com
// @connect akatsuki-novels.com
// @connect alphapolis.co.jp
// @connect cdn.shucdn.com
// @connect readmoo.com
// @connect qingoo.cn
// @connect sundung.com
// @connect duread.cn
// @connect ttkan.co
// @connect bg3.co
// @connect xiaoshuowanben.com
// @connect xbyuan.com
// @connect *
// @grant unsafeWindow
// @grant GM_info
// @grant GM_xmlhttpRequest
// @grant GM_setValue
// @grant GM_getValue
// @grant GM_deleteValue
// @grant GM.info
// @grant GM.xmlHttpRequest
// @grant GM.setValue
// @grant GM.getValue
// @grant GM.deleteValue
// @homepageURL https://github.com/404-novel-project/novel-downloader
// @icon https://cdn.jsdelivr.net/gh/404-novel-project/novel-downloader/assets/icon.png
// @incompatible Internet Explorer
// @license AGPL-3.0-or-later
// @namespace https://blog.bgme.me
// @noframes
// @require https://unpkg.com/crypto-js@4.1.1/crypto-js.js#sha512-NQVmLzNy4Lr5QTrmXvq/WzTMUnRHmv7nyIT/M6LyGPBS+TIeRxZ+YQaqWxjpRpvRMQSuYPQURZz/+pLi81xXeA==
// @require https://unpkg.com/fflate@0.8.0/umd/index.js#sha512-3yw8GlXXje/3cAJoUioEOZlQkRQptqZLsWUL2KUUkvsiTMpnuXPAn6ESSAeQVLnY+2VrTHOADFMTElWqjKG/Yg==
// @require https://unpkg.com/nunjucks@3.2.4/browser/nunjucks.min.js#sha512-YvU0oaPCJSOIFni9rIOthOs5GgtU5kNZMKQG/Nt33t/H9g/1+TK7KJuMsCZS6v4O3+x253OZlTzPryrUtxxORw==
// @require https://unpkg.com/vue@3.3.4/dist/vue.global.prod.js#sha512-7cmvZh1K81vCevOl9YPcvR6lCFgxol/biMYQ+YwsCiQFePxFrMVbJaHGUlu01/2EhNxKzKRpztUhWrwLyKCfiQ==
// @run-at document-start
// ==/UserScript==
/******/ (() => { // webpackBootstrap
/******/ var __webpack_modules__ = ({
/***/ "./node_modules/@mozilla/readability/Readability-readerable.js":
/***/ ((module) => {
/*
* Copyright (c) 2010 Arc90 Inc
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/*
* This code is heavily based on Arc90's readability.js (1.7.1) script
* available at: http://code.google.com/p/arc90labs-readability
*/
var REGEXPS = {
// NOTE: These two regular expressions are duplicated in
// Readability.js. Please keep both copies in sync.
unlikelyCandidates: /-ad-|ai2html|banner|breadcrumbs|combx|comment|community|cover-wrap|disqus|extra|footer|gdpr|header|legends|menu|related|remark|replies|rss|shoutbox|sidebar|skyscraper|social|sponsor|supplemental|ad-break|agegate|pagination|pager|popup|yom-remote/i,
okMaybeItsACandidate: /and|article|body|column|content|main|shadow/i,
};
function isNodeVisible(node) {
// Have to null-check node.style and node.className.indexOf to deal with SVG and MathML nodes.
return (!node.style || node.style.display != "none")
&& !node.hasAttribute("hidden")
//check for "fallback-image" so that wikimedia math images are displayed
&& (!node.hasAttribute("aria-hidden") || node.getAttribute("aria-hidden") != "true" || (node.className && node.className.indexOf && node.className.indexOf("fallback-image") !== -1));
}
/**
* Decides whether or not the document is reader-able without parsing the whole thing.
* @param {Object} options Configuration object.
* @param {number} [options.minContentLength=140] The minimum node content length used to decide if the document is readerable.
* @param {number} [options.minScore=20] The minumum cumulated 'score' used to determine if the document is readerable.
* @param {Function} [options.visibilityChecker=isNodeVisible] The function used to determine if a node is visible.
* @return {boolean} Whether or not we suspect Readability.parse() will suceeed at returning an article object.
*/
function isProbablyReaderable(doc, options = {}) {
// For backward compatibility reasons 'options' can either be a configuration object or the function used
// to determine if a node is visible.
if (typeof options == "function") {
options = { visibilityChecker: options };
}
var defaultOptions = { minScore: 20, minContentLength: 140, visibilityChecker: isNodeVisible };
options = Object.assign(defaultOptions, options);
var nodes = doc.querySelectorAll("p, pre, article");
// Get <div> nodes which have <br> node(s) and append them into the `nodes` variable.
// Some articles' DOM structures might look like
// <div>
// Sentences<br>
// <br>
// Sentences<br>
// </div>
var brNodes = doc.querySelectorAll("div > br");
if (brNodes.length) {
var set = new Set(nodes);
[].forEach.call(brNodes, function (node) {
set.add(node.parentNode);
});
nodes = Array.from(set);
}
var score = 0;
// This is a little cheeky, we use the accumulator 'score' to decide what to return from
// this callback:
return [].some.call(nodes, function (node) {
if (!options.visibilityChecker(node)) {
return false;
}
var matchString = node.className + " " + node.id;
if (REGEXPS.unlikelyCandidates.test(matchString) &&
!REGEXPS.okMaybeItsACandidate.test(matchString)) {
return false;
}
if (node.matches("li p")) {
return false;
}
var textContentLength = node.textContent.trim().length;
if (textContentLength < options.minContentLength) {
return false;
}
score += Math.sqrt(textContentLength - options.minContentLength);
if (score > options.minScore) {
return true;
}
return false;
});
}
if (true) {
/* global module */
module.exports = isProbablyReaderable;
}
/***/ }),
/***/ "./node_modules/@mozilla/readability/Readability.js":
/***/ ((module) => {
/*
* Copyright (c) 2010 Arc90 Inc
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/*
* This code is heavily based on Arc90's readability.js (1.7.1) script
* available at: http://code.google.com/p/arc90labs-readability
*/
/**
* Public constructor.
* @param {HTMLDocument} doc The document to parse.
* @param {Object} options The options object.
*/
function Readability(doc, options) {
// In some older versions, people passed a URI as the first argument. Cope:
if (options && options.documentElement) {
doc = options;
options = arguments[2];
} else if (!doc || !doc.documentElement) {
throw new Error("First argument to Readability constructor should be a document object.");
}
options = options || {};
this._doc = doc;
this._docJSDOMParser = this._doc.firstChild.__JSDOMParser__;
this._articleTitle = null;
this._articleByline = null;
this._articleDir = null;
this._articleSiteName = null;
this._attempts = [];
// Configurable options
this._debug = !!options.debug;
this._maxElemsToParse = options.maxElemsToParse || this.DEFAULT_MAX_ELEMS_TO_PARSE;
this._nbTopCandidates = options.nbTopCandidates || this.DEFAULT_N_TOP_CANDIDATES;
this._charThreshold = options.charThreshold || this.DEFAULT_CHAR_THRESHOLD;
this._classesToPreserve = this.CLASSES_TO_PRESERVE.concat(options.classesToPreserve || []);
this._keepClasses = !!options.keepClasses;
this._serializer = options.serializer || function(el) {
return el.innerHTML;
};
this._disableJSONLD = !!options.disableJSONLD;
this._allowedVideoRegex = options.allowedVideoRegex || this.REGEXPS.videos;
// Start with all flags set
this._flags = this.FLAG_STRIP_UNLIKELYS |
this.FLAG_WEIGHT_CLASSES |
this.FLAG_CLEAN_CONDITIONALLY;
// Control whether log messages are sent to the console
if (this._debug) {
let logNode = function(node) {
if (node.nodeType == node.TEXT_NODE) {
return `${node.nodeName} ("${node.textContent}")`;
}
let attrPairs = Array.from(node.attributes || [], function(attr) {
return `${attr.name}="${attr.value}"`;
}).join(" ");
return `<${node.localName} ${attrPairs}>`;
};
this.log = function () {
if (typeof console !== "undefined") {
let args = Array.from(arguments, arg => {
if (arg && arg.nodeType == this.ELEMENT_NODE) {
return logNode(arg);
}
return arg;
});
args.unshift("Reader: (Readability)");
console.log.apply(console, args);
} else if (typeof dump !== "undefined") {
/* global dump */
var msg = Array.prototype.map.call(arguments, function(x) {
return (x && x.nodeName) ? logNode(x) : x;
}).join(" ");
dump("Reader: (Readability) " + msg + "\n");
}
};
} else {
this.log = function () {};
}
}
Readability.prototype = {
FLAG_STRIP_UNLIKELYS: 0x1,
FLAG_WEIGHT_CLASSES: 0x2,
FLAG_CLEAN_CONDITIONALLY: 0x4,
// https://developer.mozilla.org/en-US/docs/Web/API/Node/nodeType
ELEMENT_NODE: 1,
TEXT_NODE: 3,
// Max number of nodes supported by this parser. Default: 0 (no limit)
DEFAULT_MAX_ELEMS_TO_PARSE: 0,
// The number of top candidates to consider when analysing how
// tight the competition is among candidates.
DEFAULT_N_TOP_CANDIDATES: 5,
// Element tags to score by default.
DEFAULT_TAGS_TO_SCORE: "section,h2,h3,h4,h5,h6,p,td,pre".toUpperCase().split(","),
// The default number of chars an article must have in order to return a result
DEFAULT_CHAR_THRESHOLD: 500,
// All of the regular expressions in use within readability.
// Defined up here so we don't instantiate them repeatedly in loops.
REGEXPS: {
// NOTE: These two regular expressions are duplicated in
// Readability-readerable.js. Please keep both copies in sync.
unlikelyCandidates: /-ad-|ai2html|banner|breadcrumbs|combx|comment|community|cover-wrap|disqus|extra|footer|gdpr|header|legends|menu|related|remark|replies|rss|shoutbox|sidebar|skyscraper|social|sponsor|supplemental|ad-break|agegate|pagination|pager|popup|yom-remote/i,
okMaybeItsACandidate: /and|article|body|column|content|main|shadow/i,
positive: /article|body|content|entry|hentry|h-entry|main|page|pagination|post|text|blog|story/i,
negative: /-ad-|hidden|^hid$| hid$| hid |^hid |banner|combx|comment|com-|contact|foot|footer|footnote|gdpr|masthead|media|meta|outbrain|promo|related|scroll|share|shoutbox|sidebar|skyscraper|sponsor|shopping|tags|tool|widget/i,
extraneous: /print|archive|comment|discuss|e[\-]?mail|share|reply|all|login|sign|single|utility/i,
byline: /byline|author|dateline|writtenby|p-author/i,
replaceFonts: /<(\/?)font[^>]*>/gi,
normalize: /\s{2,}/g,
videos: /\/\/(www\.)?((dailymotion|youtube|youtube-nocookie|player\.vimeo|v\.qq)\.com|(archive|upload\.wikimedia)\.org|player\.twitch\.tv)/i,
shareElements: /(\b|_)(share|sharedaddy)(\b|_)/i,
nextLink: /(next|weiter|continue|>([^\|]|$)|»([^\|]|$))/i,
prevLink: /(prev|earl|old|new|<|«)/i,
tokenize: /\W+/g,
whitespace: /^\s*$/,
hasContent: /\S$/,
hashUrl: /^#.+/,
srcsetUrl: /(\S+)(\s+[\d.]+[xw])?(\s*(?:,|$))/g,
b64DataUrl: /^data:\s*([^\s;,]+)\s*;\s*base64\s*,/i,
// Commas as used in Latin, Sindhi, Chinese and various other scripts.
// see: https://en.wikipedia.org/wiki/Comma#Comma_variants
commas: /\u002C|\u060C|\uFE50|\uFE10|\uFE11|\u2E41|\u2E34|\u2E32|\uFF0C/g,
// See: https://schema.org/Article
jsonLdArticleTypes: /^Article|AdvertiserContentArticle|NewsArticle|AnalysisNewsArticle|AskPublicNewsArticle|BackgroundNewsArticle|OpinionNewsArticle|ReportageNewsArticle|ReviewNewsArticle|Report|SatiricalArticle|ScholarlyArticle|MedicalScholarlyArticle|SocialMediaPosting|BlogPosting|LiveBlogPosting|DiscussionForumPosting|TechArticle|APIReference$/
},
UNLIKELY_ROLES: [ "menu", "menubar", "complementary", "navigation", "alert", "alertdialog", "dialog" ],
DIV_TO_P_ELEMS: new Set([ "BLOCKQUOTE", "DL", "DIV", "IMG", "OL", "P", "PRE", "TABLE", "UL" ]),
ALTER_TO_DIV_EXCEPTIONS: ["DIV", "ARTICLE", "SECTION", "P"],
PRESENTATIONAL_ATTRIBUTES: [ "align", "background", "bgcolor", "border", "cellpadding", "cellspacing", "frame", "hspace", "rules", "style", "valign", "vspace" ],
DEPRECATED_SIZE_ATTRIBUTE_ELEMS: [ "TABLE", "TH", "TD", "HR", "PRE" ],
// The commented out elements qualify as phrasing content but tend to be
// removed by readability when put into paragraphs, so we ignore them here.
PHRASING_ELEMS: [
// "CANVAS", "IFRAME", "SVG", "VIDEO",
"ABBR", "AUDIO", "B", "BDO", "BR", "BUTTON", "CITE", "CODE", "DATA",
"DATALIST", "DFN", "EM", "EMBED", "I", "IMG", "INPUT", "KBD", "LABEL",
"MARK", "MATH", "METER", "NOSCRIPT", "OBJECT", "OUTPUT", "PROGRESS", "Q",
"RUBY", "SAMP", "SCRIPT", "SELECT", "SMALL", "SPAN", "STRONG", "SUB",
"SUP", "TEXTAREA", "TIME", "VAR", "WBR"
],
// These are the classes that readability sets itself.
CLASSES_TO_PRESERVE: [ "page" ],
// These are the list of HTML entities that need to be escaped.
HTML_ESCAPE_MAP: {
"lt": "<",
"gt": ">",
"amp": "&",
"quot": '"',
"apos": "'",
},
/**
* Run any post-process modifications to article content as necessary.
*
* @param Element
* @return void
**/
_postProcessContent: function(articleContent) {
// Readability cannot open relative uris so we convert them to absolute uris.
this._fixRelativeUris(articleContent);
this._simplifyNestedElements(articleContent);
if (!this._keepClasses) {
// Remove classes.
this._cleanClasses(articleContent);
}
},
/**
* Iterates over a NodeList, calls `filterFn` for each node and removes node
* if function returned `true`.
*
* If function is not passed, removes all the nodes in node list.
*
* @param NodeList nodeList The nodes to operate on
* @param Function filterFn the function to use as a filter
* @return void
*/
_removeNodes: function(nodeList, filterFn) {
// Avoid ever operating on live node lists.
if (this._docJSDOMParser && nodeList._isLiveNodeList) {
throw new Error("Do not pass live node lists to _removeNodes");
}
for (var i = nodeList.length - 1; i >= 0; i--) {
var node = nodeList[i];
var parentNode = node.parentNode;
if (parentNode) {
if (!filterFn || filterFn.call(this, node, i, nodeList)) {
parentNode.removeChild(node);
}
}
}
},
/**
* Iterates over a NodeList, and calls _setNodeTag for each node.
*
* @param NodeList nodeList The nodes to operate on
* @param String newTagName the new tag name to use
* @return void
*/
_replaceNodeTags: function(nodeList, newTagName) {
// Avoid ever operating on live node lists.
if (this._docJSDOMParser && nodeList._isLiveNodeList) {
throw new Error("Do not pass live node lists to _replaceNodeTags");
}
for (const node of nodeList) {
this._setNodeTag(node, newTagName);
}
},
/**
* Iterate over a NodeList, which doesn't natively fully implement the Array
* interface.
*
* For convenience, the current object context is applied to the provided
* iterate function.
*
* @param NodeList nodeList The NodeList.
* @param Function fn The iterate function.
* @return void
*/
_forEachNode: function(nodeList, fn) {
Array.prototype.forEach.call(nodeList, fn, this);
},
/**
* Iterate over a NodeList, and return the first node that passes
* the supplied test function
*
* For convenience, the current object context is applied to the provided
* test function.
*
* @param NodeList nodeList The NodeList.
* @param Function fn The test function.
* @return void
*/
_findNode: function(nodeList, fn) {
return Array.prototype.find.call(nodeList, fn, this);
},
/**
* Iterate over a NodeList, return true if any of the provided iterate
* function calls returns true, false otherwise.
*
* For convenience, the current object context is applied to the
* provided iterate function.
*
* @param NodeList nodeList The NodeList.
* @param Function fn The iterate function.
* @return Boolean
*/
_someNode: function(nodeList, fn) {
return Array.prototype.some.call(nodeList, fn, this);
},
/**
* Iterate over a NodeList, return true if all of the provided iterate
* function calls return true, false otherwise.
*
* For convenience, the current object context is applied to the
* provided iterate function.
*
* @param NodeList nodeList The NodeList.
* @param Function fn The iterate function.
* @return Boolean
*/
_everyNode: function(nodeList, fn) {
return Array.prototype.every.call(nodeList, fn, this);
},
/**
* Concat all nodelists passed as arguments.
*
* @return ...NodeList
* @return Array
*/
_concatNodeLists: function() {
var slice = Array.prototype.slice;
var args = slice.call(arguments);
var nodeLists = args.map(function(list) {
return slice.call(list);
});
return Array.prototype.concat.apply([], nodeLists);
},
_getAllNodesWithTag: function(node, tagNames) {
if (node.querySelectorAll) {
return node.querySelectorAll(tagNames.join(","));
}
return [].concat.apply([], tagNames.map(function(tag) {
var collection = node.getElementsByTagName(tag);
return Array.isArray(collection) ? collection : Array.from(collection);
}));
},
/**
* Removes the class="" attribute from every element in the given
* subtree, except those that match CLASSES_TO_PRESERVE and
* the classesToPreserve array from the options object.
*
* @param Element
* @return void
*/
_cleanClasses: function(node) {
var classesToPreserve = this._classesToPreserve;
var className = (node.getAttribute("class") || "")
.split(/\s+/)
.filter(function(cls) {
return classesToPreserve.indexOf(cls) != -1;
})
.join(" ");
if (className) {
node.setAttribute("class", className);
} else {
node.removeAttribute("class");
}
for (node = node.firstElementChild; node; node = node.nextElementSibling) {
this._cleanClasses(node);
}
},
/**
* Converts each <a> and <img> uri in the given element to an absolute URI,
* ignoring #ref URIs.
*
* @param Element
* @return void
*/
_fixRelativeUris: function(articleContent) {
var baseURI = this._doc.baseURI;
var documentURI = this._doc.documentURI;
function toAbsoluteURI(uri) {
// Leave hash links alone if the base URI matches the document URI:
if (baseURI == documentURI && uri.charAt(0) == "#") {
return uri;
}
// Otherwise, resolve against base URI:
try {
return new URL(uri, baseURI).href;
} catch (ex) {
// Something went wrong, just return the original:
}
return uri;
}
var links = this._getAllNodesWithTag(articleContent, ["a"]);
this._forEachNode(links, function(link) {
var href = link.getAttribute("href");
if (href) {
// Remove links with javascript: URIs, since
// they won't work after scripts have been removed from the page.
if (href.indexOf("javascript:") === 0) {
// if the link only contains simple text content, it can be converted to a text node
if (link.childNodes.length === 1 && link.childNodes[0].nodeType === this.TEXT_NODE) {
var text = this._doc.createTextNode(link.textContent);
link.parentNode.replaceChild(text, link);
} else {
// if the link has multiple children, they should all be preserved
var container = this._doc.createElement("span");
while (link.firstChild) {
container.appendChild(link.firstChild);
}
link.parentNode.replaceChild(container, link);
}
} else {
link.setAttribute("href", toAbsoluteURI(href));
}
}
});
var medias = this._getAllNodesWithTag(articleContent, [
"img", "picture", "figure", "video", "audio", "source"
]);
this._forEachNode(medias, function(media) {
var src = media.getAttribute("src");
var poster = media.getAttribute("poster");
var srcset = media.getAttribute("srcset");
if (src) {
media.setAttribute("src", toAbsoluteURI(src));
}
if (poster) {
media.setAttribute("poster", toAbsoluteURI(poster));
}
if (srcset) {
var newSrcset = srcset.replace(this.REGEXPS.srcsetUrl, function(_, p1, p2, p3) {
return toAbsoluteURI(p1) + (p2 || "") + p3;
});
media.setAttribute("srcset", newSrcset);
}
});
},
_simplifyNestedElements: function(articleContent) {
var node = articleContent;
while (node) {
if (node.parentNode && ["DIV", "SECTION"].includes(node.tagName) && !(node.id && node.id.startsWith("readability"))) {
if (this._isElementWithoutContent(node)) {
node = this._removeAndGetNext(node);
continue;
} else if (this._hasSingleTagInsideElement(node, "DIV") || this._hasSingleTagInsideElement(node, "SECTION")) {
var child = node.children[0];
for (var i = 0; i < node.attributes.length; i++) {
child.setAttribute(node.attributes[i].name, node.attributes[i].value);
}
node.parentNode.replaceChild(child, node);
node = child;
continue;
}
}
node = this._getNextNode(node);
}
},
/**
* Get the article title as an H1.
*
* @return string
**/
_getArticleTitle: function() {
var doc = this._doc;
var curTitle = "";
var origTitle = "";
try {
curTitle = origTitle = doc.title.trim();
// If they had an element with id "title" in their HTML
if (typeof curTitle !== "string")
curTitle = origTitle = this._getInnerText(doc.getElementsByTagName("title")[0]);
} catch (e) {/* ignore exceptions setting the title. */}
var titleHadHierarchicalSeparators = false;
function wordCount(str) {
return str.split(/\s+/).length;
}
// If there's a separator in the title, first remove the final part
if ((/ [\|\-\\\/>»] /).test(curTitle)) {
titleHadHierarchicalSeparators = / [\\\/>»] /.test(curTitle);
curTitle = origTitle.replace(/(.*)[\|\-\\\/>»] .*/gi, "$1");
// If the resulting title is too short (3 words or fewer), remove
// the first part instead:
if (wordCount(curTitle) < 3)
curTitle = origTitle.replace(/[^\|\-\\\/>»]*[\|\-\\\/>»](.*)/gi, "$1");
} else if (curTitle.indexOf(": ") !== -1) {
// Check if we have an heading containing this exact string, so we
// could assume it's the full title.
var headings = this._concatNodeLists(
doc.getElementsByTagName("h1"),
doc.getElementsByTagName("h2")
);
var trimmedTitle = curTitle.trim();
var match = this._someNode(headings, function(heading) {
return heading.textContent.trim() === trimmedTitle;
});
// If we don't, let's extract the title out of the original title string.
if (!match) {
curTitle = origTitle.substring(origTitle.lastIndexOf(":") + 1);
// If the title is now too short, try the first colon instead:
if (wordCount(curTitle) < 3) {
curTitle = origTitle.substring(origTitle.indexOf(":") + 1);
// But if we have too many words before the colon there's something weird
// with the titles and the H tags so let's just use the original title instead
} else if (wordCount(origTitle.substr(0, origTitle.indexOf(":"))) > 5) {
curTitle = origTitle;
}
}
} else if (curTitle.length > 150 || curTitle.length < 15) {
var hOnes = doc.getElementsByTagName("h1");
if (hOnes.length === 1)
curTitle = this._getInnerText(hOnes[0]);
}
curTitle = curTitle.trim().replace(this.REGEXPS.normalize, " ");
// If we now have 4 words or fewer as our title, and either no
// 'hierarchical' separators (\, /, > or ») were found in the original
// title or we decreased the number of words by more than 1 word, use
// the original title.
var curTitleWordCount = wordCount(curTitle);
if (curTitleWordCount <= 4 &&
(!titleHadHierarchicalSeparators ||
curTitleWordCount != wordCount(origTitle.replace(/[\|\-\\\/>»]+/g, "")) - 1)) {
curTitle = origTitle;
}
return curTitle;
},
/**
* Prepare the HTML document for readability to scrape it.
* This includes things like stripping javascript, CSS, and handling terrible markup.
*
* @return void
**/
_prepDocument: function() {
var doc = this._doc;
// Remove all style tags in head
this._removeNodes(this._getAllNodesWithTag(doc, ["style"]));
if (doc.body) {
this._replaceBrs(doc.body);
}
this._replaceNodeTags(this._getAllNodesWithTag(doc, ["font"]), "SPAN");
},
/**
* Finds the next node, starting from the given node, and ignoring
* whitespace in between. If the given node is an element, the same node is
* returned.
*/
_nextNode: function (node) {
var next = node;
while (next
&& (next.nodeType != this.ELEMENT_NODE)
&& this.REGEXPS.whitespace.test(next.textContent)) {
next = next.nextSibling;
}
return next;
},
/**
* Replaces 2 or more successive <br> elements with a single <p>.
* Whitespace between <br> elements are ignored. For example:
* <div>foo<br>bar<br> <br><br>abc</div>
* will become:
* <div>foo<br>bar<p>abc</p></div>
*/
_replaceBrs: function (elem) {
this._forEachNode(this._getAllNodesWithTag(elem, ["br"]), function(br) {
var next = br.nextSibling;
// Whether 2 or more <br> elements have been found and replaced with a
// <p> block.
var replaced = false;
// If we find a <br> chain, remove the <br>s until we hit another node
// or non-whitespace. This leaves behind the first <br> in the chain
// (which will be replaced with a <p> later).
while ((next = this._nextNode(next)) && (next.tagName == "BR")) {
replaced = true;
var brSibling = next.nextSibling;
next.parentNode.removeChild(next);
next = brSibling;
}
// If we removed a <br> chain, replace the remaining <br> with a <p>. Add
// all sibling nodes as children of the <p> until we hit another <br>
// chain.
if (replaced) {
var p = this._doc.createElement("p");
br.parentNode.replaceChild(p, br);
next = p.nextSibling;
while (next) {
// If we've hit another <br><br>, we're done adding children to this <p>.
if (next.tagName == "BR") {
var nextElem = this._nextNode(next.nextSibling);
if (nextElem && nextElem.tagName == "BR")
break;
}
if (!this._isPhrasingContent(next))
break;
// Otherwise, make this node a child of the new <p>.
var sibling = next.nextSibling;
p.appendChild(next);
next = sibling;
}
while (p.lastChild && this._isWhitespace(p.lastChild)) {
p.removeChild(p.lastChild);
}
if (p.parentNode.tagName === "P")
this._setNodeTag(p.parentNode, "DIV");
}
});
},
_setNodeTag: function (node, tag) {
this.log("_setNodeTag", node, tag);
if (this._docJSDOMParser) {
node.localName = tag.toLowerCase();
node.tagName = tag.toUpperCase();
return node;
}
var replacement = node.ownerDocument.createElement(tag);
while (node.firstChild) {
replacement.appendChild(node.firstChild);
}
node.parentNode.replaceChild(replacement, node);
if (node.readability)
replacement.readability = node.readability;
for (var i = 0; i < node.attributes.length; i++) {
try {
replacement.setAttribute(node.attributes[i].name, node.attributes[i].value);
} catch (ex) {
/* it's possible for setAttribute() to throw if the attribute name
* isn't a valid XML Name. Such attributes can however be parsed from
* source in HTML docs, see https://github.com/whatwg/html/issues/4275,
* so we can hit them here and then throw. We don't care about such
* attributes so we ignore them.
*/
}
}
return replacement;
},
/**
* Prepare the article node for display. Clean out any inline styles,
* iframes, forms, strip extraneous <p> tags, etc.
*
* @param Element
* @return void
**/
_prepArticle: function(articleContent) {
this._cleanStyles(articleContent);
// Check for data tables before we continue, to avoid removing items in
// those tables, which will often be isolated even though they're
// visually linked to other content-ful elements (text, images, etc.).
this._markDataTables(articleContent);
this._fixLazyImages(articleContent);
// Clean out junk from the article content
this._cleanConditionally(articleContent, "form");
this._cleanConditionally(articleContent, "fieldset");
this._clean(articleContent, "object");
this._clean(articleContent, "embed");
this._clean(articleContent, "footer");
this._clean(articleContent, "link");
this._clean(articleContent, "aside");
// Clean out elements with little content that have "share" in their id/class combinations from final top candidates,
// which means we don't remove the top candidates even they have "share".
var shareElementThreshold = this.DEFAULT_CHAR_THRESHOLD;
this._forEachNode(articleContent.children, function (topCandidate) {
this._cleanMatchedNodes(topCandidate, function (node, matchString) {
return this.REGEXPS.shareElements.test(matchString) && node.textContent.length < shareElementThreshold;
});
});
this._clean(articleContent, "iframe");
this._clean(articleContent, "input");
this._clean(articleContent, "textarea");
this._clean(articleContent, "select");
this._clean(articleContent, "button");
this._cleanHeaders(articleContent);
// Do these last as the previous stuff may have removed junk
// that will affect these
this._cleanConditionally(articleContent, "table");
this._cleanConditionally(articleContent, "ul");
this._cleanConditionally(articleContent, "div");
// replace H1 with H2 as H1 should be only title that is displayed separately
this._replaceNodeTags(this._getAllNodesWithTag(articleContent, ["h1"]), "h2");
// Remove extra paragraphs
this._removeNodes(this._getAllNodesWithTag(articleContent, ["p"]), function (paragraph) {
var imgCount = paragraph.getElementsByTagName("img").length;
var embedCount = paragraph.getElementsByTagName("embed").length;
var objectCount = paragraph.getElementsByTagName("object").length;
// At this point, nasty iframes have been removed, only remain embedded video ones.
var iframeCount = paragraph.getElementsByTagName("iframe").length;
var totalCount = imgCount + embedCount + objectCount + iframeCount;
return totalCount === 0 && !this._getInnerText(paragraph, false);
});
this._forEachNode(this._getAllNodesWithTag(articleContent, ["br"]), function(br) {
var next = this._nextNode(br.nextSibling);
if (next && next.tagName == "P")
br.parentNode.removeChild(br);
});
// Remove single-cell tables
this._forEachNode(this._getAllNodesWithTag(articleContent, ["table"]), function(table) {
var tbody = this._hasSingleTagInsideElement(table, "TBODY") ? table.firstElementChild : table;
if (this._hasSingleTagInsideElement(tbody, "TR")) {
var row = tbody.firstElementChild;
if (this._hasSingleTagInsideElement(row, "TD")) {
var cell = row.firstElementChild;
cell = this._setNodeTag(cell, this._everyNode(cell.childNodes, this._isPhrasingContent) ? "P" : "DIV");
table.parentNode.replaceChild(cell, table);
}
}
});
},
/**
* Initialize a node with the readability object. Also checks the
* className/id for special names to add to its score.
*
* @param Element
* @return void
**/
_initializeNode: function(node) {
node.readability = {"contentScore": 0};
switch (node.tagName) {
case "DIV":
node.readability.contentScore += 5;
break;
case "PRE":
case "TD":
case "BLOCKQUOTE":
node.readability.contentScore += 3;
break;
case "ADDRESS":
case "OL":
case "UL":
case "DL":
case "DD":
case "DT":
case "LI":
case "FORM":
node.readability.contentScore -= 3;
break;
case "H1":
case "H2":
case "H3":
case "H4":
case "H5":
case "H6":
case "TH":
node.readability.contentScore -= 5;
break;
}
node.readability.contentScore += this._getClassWeight(node);
},
_removeAndGetNext: function(node) {
var nextNode = this._getNextNode(node, true);
node.parentNode.removeChild(node);
return nextNode;
},
/**
* Traverse the DOM from node to node, starting at the node passed in.
* Pass true for the second parameter to indicate this node itself
* (and its kids) are going away, and we want the next node over.
*
* Calling this in a loop will traverse the DOM depth-first.
*/
_getNextNode: function(node, ignoreSelfAndKids) {
// First check for kids if those aren't being ignored
if (!ignoreSelfAndKids && node.firstElementChild) {
return node.firstElementChild;
}
// Then for siblings...
if (node.nextElementSibling) {
return node.nextElementSibling;
}
// And finally, move up the parent chain *and* find a sibling
// (because this is depth-first traversal, we will have already
// seen the parent nodes themselves).
do {
node = node.parentNode;
} while (node && !node.nextElementSibling);
return node && node.nextElementSibling;
},
// compares second text to first one
// 1 = same text, 0 = completely different text
// works the way that it splits both texts into words and then finds words that are unique in second text
// the result is given by the lower length of unique parts
_textSimilarity: function(textA, textB) {
var tokensA = textA.toLowerCase().split(this.REGEXPS.tokenize).filter(Boolean);
var tokensB = textB.toLowerCase().split(this.REGEXPS.tokenize).filter(Boolean);
if (!tokensA.length || !tokensB.length) {
return 0;
}
var uniqTokensB = tokensB.filter(token => !tokensA.includes(token));
var distanceB = uniqTokensB.join(" ").length / tokensB.join(" ").length;
return 1 - distanceB;
},
_checkByline: function(node, matchString) {
if (this._articleByline) {
return false;
}
if (node.getAttribute !== undefined) {
var rel = node.getAttribute("rel");
var itemprop = node.getAttribute("itemprop");
}
if ((rel === "author" || (itemprop && itemprop.indexOf("author") !== -1) || this.REGEXPS.byline.test(matchString)) && this._isValidByline(node.textContent)) {
this._articleByline = node.textContent.trim();
return true;
}
return false;
},
_getNodeAncestors: function(node, maxDepth) {
maxDepth = maxDepth || 0;
var i = 0, ancestors = [];
while (node.parentNode) {
ancestors.push(node.parentNode);
if (maxDepth && ++i === maxDepth)
break;
node = node.parentNode;
}
return ancestors;
},
/***
* grabArticle - Using a variety of metrics (content score, classname, element types), find the content that is
* most likely to be the stuff a user wants to read. Then return it wrapped up in a div.
*
* @param page a document to run upon. Needs to be a full document, complete with body.
* @return Element
**/
_grabArticle: function (page) {
this.log("**** grabArticle ****");
var doc = this._doc;
var isPaging = page !== null;
page = page ? page : this._doc.body;
// We can't grab an article if we don't have a page!
if (!page) {
this.log("No body found in document. Abort.");
return null;
}
var pageCacheHtml = page.innerHTML;
while (true) {
this.log("Starting grabArticle loop");
var stripUnlikelyCandidates = this._flagIsActive(this.FLAG_STRIP_UNLIKELYS);
// First, node prepping. Trash nodes that look cruddy (like ones with the
// class name "comment", etc), and turn divs into P tags where they have been
// used inappropriately (as in, where they contain no other block level elements.)
var elementsToScore = [];
var node = this._doc.documentElement;
let shouldRemoveTitleHeader = true;
while (node) {
if (node.tagName === "HTML") {
this._articleLang = node.getAttribute("lang");
}
var matchString = node.className + " " + node.id;
if (!this._isProbablyVisible(node)) {
this.log("Removing hidden node - " + matchString);
node = this._removeAndGetNext(node);
continue;
}
// User is not able to see elements applied with both "aria-modal = true" and "role = dialog"
if (node.getAttribute("aria-modal") == "true" && node.getAttribute("role") == "dialog") {
node = this._removeAndGetNext(node);
continue;
}
// Check to see if this node is a byline, and remove it if it is.
if (this._checkByline(node, matchString)) {
node = this._removeAndGetNext(node);
continue;
}
if (shouldRemoveTitleHeader && this._headerDuplicatesTitle(node)) {
this.log("Removing header: ", node.textContent.trim(), this._articleTitle.trim());
shouldRemoveTitleHeader = false;
node = this._removeAndGetNext(node);
continue;
}
// Remove unlikely candidates
if (stripUnlikelyCandidates) {
if (this.REGEXPS.unlikelyCandidates.test(matchString) &&
!this.REGEXPS.okMaybeItsACandidate.test(matchString) &&
!this._hasAncestorTag(node, "table") &&
!this._hasAncestorTag(node, "code") &&
node.tagName !== "BODY" &&
node.tagName !== "A") {
this.log("Removing unlikely candidate - " + matchString);
node = this._removeAndGetNext(node);
continue;
}
if (this.UNLIKELY_ROLES.includes(node.getAttribute("role"))) {
this.log("Removing content with role " + node.getAttribute("role") + " - " + matchString);
node = this._removeAndGetNext(node);
continue;
}
}
// Remove DIV, SECTION, and HEADER nodes without any content(e.g. text, image, video, or iframe).
if ((node.tagName === "DIV" || node.tagName === "SECTION" || node.tagName === "HEADER" ||
node.tagName === "H1" || node.tagName === "H2" || node.tagName === "H3" ||
node.tagName === "H4" || node.tagName === "H5" || node.tagName === "H6") &&
this._isElementWithoutContent(node)) {
node = this._removeAndGetNext(node);
continue;
}
if (this.DEFAULT_TAGS_TO_SCORE.indexOf(node.tagName) !== -1) {
elementsToScore.push(node);
}
// Turn all divs that don't have children block level elements into p's
if (node.tagName === "DIV") {
// Put phrasing content into paragraphs.
var p = null;
var childNode = node.firstChild;
while (childNode) {
var nextSibling = childNode.nextSibling;
if (this._isPhrasingContent(childNode)) {
if (p !== null) {
p.appendChild(childNode);
} else if (!this._isWhitespace(childNode)) {
p = doc.createElement("p");
node.replaceChild(p, childNode);
p.appendChild(childNode);
}
} else if (p !== null) {
while (p.lastChild && this._isWhitespace(p.lastChild)) {
p.removeChild(p.lastChild);
}
p = null;
}
childNode = nextSibling;
}
// Sites like http://mobile.slate.com encloses each paragraph with a DIV
// element. DIVs with only a P element inside and no text content can be
// safely converted into plain P elements to avoid confusing the scoring
// algorithm with DIVs with are, in practice, paragraphs.
if (this._hasSingleTagInsideElement(node, "P") && this._getLinkDensity(node) < 0.25) {
var newNode = node.children[0];
node.parentNode.replaceChild(newNode, node);
node = newNode;
elementsToScore.push(node);
} else if (!this._hasChildBlockElement(node)) {
node = this._setNodeTag(node, "P");
elementsToScore.push(node);
}
}
node = this._getNextNode(node);
}
/**
* Loop through all paragraphs, and assign a score to them based on how content-y they look.
* Then add their score to their parent node.
*
* A score is determined by things like number of commas, class names, etc. Maybe eventually link density.
**/
var candidates = [];
this._forEachNode(elementsToScore, function(elementToScore) {
if (!elementToScore.parentNode || typeof(elementToScore.parentNode.tagName) === "undefined")
return;
// If this paragraph is less than 25 characters, don't even count it.
var innerText = this._getInnerText(elementToScore);
if (innerText.length < 25)
return;
// Exclude nodes with no ancestor.
var ancestors = this._getNodeAncestors(elementToScore, 5);
if (ancestors.length === 0)
return;
var contentScore = 0;
// Add a point for the paragraph itself as a base.
contentScore += 1;
// Add points for any commas within this paragraph.
contentScore += innerText.split(this.REGEXPS.commas).length;
// For every 100 characters in this paragraph, add another point. Up to 3 points.
contentScore += Math.min(Math.floor(innerText.length / 100), 3);
// Initialize and score ancestors.
this._forEachNode(ancestors, function(ancestor, level) {
if (!ancestor.tagName || !ancestor.parentNode || typeof(ancestor.parentNode.tagName) === "undefined")
return;
if (typeof(ancestor.readability) === "undefined") {
this._initializeNode(ancestor);
candidates.push(ancestor);
}
// Node score divider:
// - parent: 1 (no division)
// - grandparent: 2
// - great grandparent+: ancestor level * 3
if (level === 0)
var scoreDivider = 1;
else if (level === 1)
scoreDivider = 2;
else
scoreDivider = level * 3;
ancestor.readability.contentScore += contentScore / scoreDivider;
});
});
// After we've calculated scores, loop through all of the possible
// candidate nodes we found and find the one with the highest score.
var topCandidates = [];
for (var c = 0, cl = candidates.length; c < cl; c += 1) {
var candidate = candidates[c];
// Scale the final candidates score based on link density. Good content
// should have a relatively small link density (5% or less) and be mostly
// unaffected by this operation.
var candidateScore = candidate.readability.contentScore * (1 - this._getLinkDensity(candidate));
candidate.readability.contentScore = candidateScore;
this.log("Candidate:", candidate, "with score " + candidateScore);
for (var t = 0; t < this._nbTopCandidates; t++) {
var aTopCandidate = topCandidates[t];
if (!aTopCandidate || candidateScore > aTopCandidate.readability.contentScore) {
topCandidates.splice(t, 0, candidate);
if (topCandidates.length > this._nbTopCandidates)
topCandidates.pop();
break;
}
}
}
var topCandidate = topCandidates[0] || null;
var neededToCreateTopCandidate = false;
var parentOfTopCandidate;
// If we still have no top candidate, just use the body as a last resort.
// We also have to copy the body node so it is something we can modify.
if (topCandidate === null || topCandidate.tagName === "BODY") {
// Move all of the page's children into topCandidate
topCandidate = doc.createElement("DIV");
neededToCreateTopCandidate = true;
// Move everything (not just elements, also text nodes etc.) into the container
// so we even include text directly in the body:
while (page.firstChild) {
this.log("Moving child out:", page.firstChild);
topCandidate.appendChild(page.firstChild);
}
page.appendChild(topCandidate);
this._initializeNode(topCandidate);
} else if (topCandidate) {
// Find a better top candidate node if it contains (at least three) nodes which belong to `topCandidates` array
// and whose scores are quite closed with current `topCandidate` node.
var alternativeCandidateAncestors = [];
for (var i = 1; i < topCandidates.length; i++) {
if (topCandidates[i].readability.contentScore / topCandidate.readability.contentScore >= 0.75) {
alternativeCandidateAncestors.push(this._getNodeAncestors(topCandidates[i]));
}
}
var MINIMUM_TOPCANDIDATES = 3;
if (alternativeCandidateAncestors.length >= MINIMUM_TOPCANDIDATES) {
parentOfTopCandidate = topCandidate.parentNode;
while (parentOfTopCandidate.tagName !== "BODY") {
var listsContainingThisAncestor = 0;
for (var ancestorIndex = 0; ancestorIndex < alternativeCandidateAncestors.length && listsContainingThisAncestor < MINIMUM_TOPCANDIDATES; ancestorIndex++) {
listsContainingThisAncestor += Number(alternativeCandidateAncestors[ancestorIndex].includes(parentOfTopCandidate));
}
if (listsContainingThisAncestor >= MINIMUM_TOPCANDIDATES) {
topCandidate = parentOfTopCandidate;
break;
}
parentOfTopCandidate = parentOfTopCandidate.parentNode;
}
}
if (!topCandidate.readability) {
this._initializeNode(topCandidate);
}
// Because of our bonus system, parents of candidates might have scores
// themselves. They get half of the node. There won't be nodes with higher
// scores than our topCandidate, but if we see the score going *up* in the first
// few steps up the tree, that's a decent sign that there might be more content
// lurking in other places that we want to unify in. The sibling stuff
// below does some of that - but only if we've looked high enough up the DOM
// tree.
parentOfTopCandidate = topCandidate.parentNode;
var lastScore = topCandidate.readability.contentScore;
// The scores shouldn't get too low.
var scoreThreshold = lastScore / 3;
while (parentOfTopCandidate.tagName !== "BODY") {
if (!parentOfTopCandidate.readability) {
parentOfTopCandidate = parentOfTopCandidate.parentNode;
continue;
}
var parentScore = parentOfTopCandidate.readability.contentScore;
if (parentScore < scoreThreshold)
break;
if (parentScore > lastScore) {
// Alright! We found a better parent to use.
topCandidate = parentOfTopCandidate;
break;
}
lastScore = parentOfTopCandidate.readability.contentScore;
parentOfTopCandidate = parentOfTopCandidate.parentNode;
}
// If the top candidate is the only child, use parent instead. This will help sibling
// joining logic when adjacent content is actually located in parent's sibling node.
parentOfTopCandidate = topCandidate.parentNode;
while (parentOfTopCandidate.tagName != "BODY" && parentOfTopCandidate.children.length == 1) {
topCandidate = parentOfTopCandidate;
parentOfTopCandidate = topCandidate.parentNode;
}
if (!topCandidate.readability) {
this._initializeNode(topCandidate);
}
}
// Now that we have the top candidate, look through its siblings for content
// that might also be related. Things like preambles, content split by ads
// that we removed, etc.
var articleContent = doc.createElement("DIV");
if (isPaging)
articleContent.id = "readability-content";
var siblingScoreThreshold = Math.max(10, topCandidate.readability.contentScore * 0.2);
// Keep potential top candidate's parent node to try to get text direction of it later.
parentOfTopCandidate = topCandidate.parentNode;
var siblings = parentOfTopCandidate.children;
for (var s = 0, sl = siblings.length; s < sl; s++) {
var sibling = siblings[s];
var append = false;
this.log("Looking at sibling node:", sibling, sibling.readability ? ("with score " + sibling.readability.contentScore) : "");
this.log("Sibling has score", sibling.readability ? sibling.readability.contentScore : "Unknown");
if (sibling === topCandidate) {
append = true;
} else {
var contentBonus = 0;
// Give a bonus if sibling nodes and top candidates have the example same classname
if (sibling.className === topCandidate.className && topCandidate.className !== "")
contentBonus += topCandidate.readability.contentScore * 0.2;
if (sibling.readability &&
((sibling.readability.contentScore + contentBonus) >= siblingScoreThreshold)) {
append = true;
} else if (sibling.nodeName === "P") {
var linkDensity = this._getLinkDensity(sibling);
var nodeContent = this._getInnerText(sibling);
var nodeLength = nodeContent.length;
if (nodeLength > 80 && linkDensity < 0.25) {
append = true;
} else if (nodeLength < 80 && nodeLength > 0 && linkDensity === 0 &&
nodeContent.search(/\.( |$)/) !== -1) {
append = true;
}
}
}
if (append) {
this.log("Appending node:", sibling);
if (this.ALTER_TO_DIV_EXCEPTIONS.indexOf(sibling.nodeName) === -1) {
// We have a node that isn't a common block level element, like a form or td tag.
// Turn it into a div so it doesn't get filtered out later by accident.
this.log("Altering sibling:", sibling, "to div.");
sibling = this._setNodeTag(sibling, "DIV");
}
articleContent.appendChild(sibling);
// Fetch children again to make it compatible
// with DOM parsers without live collection support.
siblings = parentOfTopCandidate.children;
// siblings is a reference to the children array, and
// sibling is removed from the array when we call appendChild().
// As a result, we must revisit this index since the nodes
// have been shifted.
s -= 1;
sl -= 1;
}
}
if (this._debug)
this.log("Article content pre-prep: " + articleContent.innerHTML);
// So we have all of the content that we need. Now we clean it up for presentation.
this._prepArticle(articleContent);
if (this._debug)
this.log("Article content post-prep: " + articleContent.innerHTML);
if (neededToCreateTopCandidate) {
// We already created a fake div thing, and there wouldn't have been any siblings left
// for the previous loop, so there's no point trying to create a new div, and then
// move all the children over. Just assign IDs and class names here. No need to append
// because that already happened anyway.
topCandidate.id = "readability-page-1";
topCandidate.className = "page";
} else {
var div = doc.createElement("DIV");
div.id = "readability-page-1";
div.className = "page";
while (articleContent.firstChild) {
div.appendChild(articleContent.firstChild);
}
articleContent.appendChild(div);
}
if (this._debug)
this.log("Article content after paging: " + articleContent.innerHTML);
var parseSuccessful = true;
// Now that we've gone through the full algorithm, check to see if
// we got any meaningful content. If we didn't, we may need to re-run
// grabArticle with different flags set. This gives us a higher likelihood of
// finding the content, and the sieve approach gives us a higher likelihood of
// finding the -right- content.
var textLength = this._getInnerText(articleContent, true).length;
if (textLength < this._charThreshold) {
parseSuccessful = false;
page.innerHTML = pageCacheHtml;
if (this._flagIsActive(this.FLAG_STRIP_UNLIKELYS)) {
this._removeFlag(this.FLAG_STRIP_UNLIKELYS);
this._attempts.push({articleContent: articleContent, textLength: textLength});
} else if (this._flagIsActive(this.FLAG_WEIGHT_CLASSES)) {
this._removeFlag(this.FLAG_WEIGHT_CLASSES);
this._attempts.push({articleContent: articleContent, textLength: textLength});
} else if (this._flagIsActive(this.FLAG_CLEAN_CONDITIONALLY)) {
this._removeFlag(this.FLAG_CLEAN_CONDITIONALLY);
this._attempts.push({articleContent: articleContent, textLength: textLength});
} else {
this._attempts.push({articleContent: articleContent, textLength: textLength});
// No luck after removing flags, just return the longest text we found during the different loops
this._attempts.sort(function (a, b) {
return b.textLength - a.textLength;
});
// But first check if we actually have something
if (!this._attempts[0].textLength) {
return null;
}
articleContent = this._attempts[0].articleContent;
parseSuccessful = true;
}
}
if (parseSuccessful) {
// Find out text direction from ancestors of final top candidate.
var ancestors = [parentOfTopCandidate, topCandidate].concat(this._getNodeAncestors(parentOfTopCandidate));
this._someNode(ancestors, function(ancestor) {
if (!ancestor.tagName)
return false;
var articleDir = ancestor.getAttribute("dir");
if (articleDir) {
this._articleDir = articleDir;
return true;
}
return false;
});
return articleContent;
}
}
},
/**
* Check whether the input string could be a byline.
* This verifies that the input is a string, and that the length
* is less than 100 chars.
*
* @param possibleByline {string} - a string to check whether its a byline.
* @return Boolean - whether the input string is a byline.
*/
_isValidByline: function(byline) {
if (typeof byline == "string" || byline instanceof String) {
byline = byline.trim();
return (byline.length > 0) && (byline.length < 100);
}
return false;
},
/**
* Converts some of the common HTML entities in string to their corresponding characters.
*
* @param str {string} - a string to unescape.
* @return string without HTML entity.
*/
_unescapeHtmlEntities: function(str) {
if (!str) {
return str;
}
var htmlEscapeMap = this.HTML_ESCAPE_MAP;
return str.replace(/&(quot|amp|apos|lt|gt);/g, function(_, tag) {
return htmlEscapeMap[tag];
}).replace(/&#(?:x([0-9a-z]{1,4})|([0-9]{1,4}));/gi, function(_, hex, numStr) {
var num = parseInt(hex || numStr, hex ? 16 : 10);
return String.fromCharCode(num);
});
},
/**
* Try to extract metadata from JSON-LD object.
* For now, only Schema.org objects of type Article or its subtypes are supported.
* @return Object with any metadata that could be extracted (possibly none)
*/
_getJSONLD: function (doc) {
var scripts = this._getAllNodesWithTag(doc, ["script"]);
var metadata;
this._forEachNode(scripts, function(jsonLdElement) {
if (!metadata && jsonLdElement.getAttribute("type") === "application/ld+json") {
try {
// Strip CDATA markers if present
var content = jsonLdElement.textContent.replace(/^\s*<!\[CDATA\[|\]\]>\s*$/g, "");
var parsed = JSON.parse(content);
if (
!parsed["@context"] ||
!parsed["@context"].match(/^https?\:\/\/schema\.org$/)
) {
return;
}
if (!parsed["@type"] && Array.isArray(parsed["@graph"])) {
parsed = parsed["@graph"].find(function(it) {
return (it["@type"] || "").match(
this.REGEXPS.jsonLdArticleTypes
);
});
}
if (
!parsed ||
!parsed["@type"] ||
!parsed["@type"].match(this.REGEXPS.jsonLdArticleTypes)
) {
return;
}
metadata = {};
if (typeof parsed.name === "string" && typeof parsed.headline === "string" && parsed.name !== parsed.headline) {
// we have both name and headline element in the JSON-LD. They should both be the same but some websites like aktualne.cz
// put their own name into "name" and the article title to "headline" which confuses Readability. So we try to check if either
// "name" or "headline" closely matches the html title, and if so, use that one. If not, then we use "name" by default.
var title = this._getArticleTitle();
var nameMatches = this._textSimilarity(parsed.name, title) > 0.75;
var headlineMatches = this._textSimilarity(parsed.headline, title) > 0.75;
if (headlineMatches && !nameMatches) {
metadata.title = parsed.headline;
} else {
metadata.title = parsed.name;
}
} else if (typeof parsed.name === "string") {
metadata.title = parsed.name.trim();
} else if (typeof parsed.headline === "string") {
metadata.title = parsed.headline.trim();
}
if (parsed.author) {
if (typeof parsed.author.name === "string") {
metadata.byline = parsed.author.name.trim();
} else if (Array.isArray(parsed.author) && parsed.author[0] && typeof parsed.author[0].name === "string") {
metadata.byline = parsed.author
.filter(function(author) {
return author && typeof author.name === "string";
})
.map(function(author) {
return author.name.trim();
})
.join(", ");
}
}
if (typeof parsed.description === "string") {
metadata.excerpt = parsed.description.trim();
}
if (
parsed.publisher &&
typeof parsed.publisher.name === "string"
) {
metadata.siteName = parsed.publisher.name.trim();
}
if (typeof parsed.datePublished === "string") {
metadata.datePublished = parsed.datePublished.trim();
}
return;
} catch (err) {
this.log(err.message);
}
}
});
return metadata ? metadata : {};
},
/**
* Attempts to get excerpt and byline metadata for the article.
*
* @param {Object} jsonld — object containing any metadata that
* could be extracted from JSON-LD object.
*
* @return Object with optional "excerpt" and "byline" properties
*/
_getArticleMetadata: function(jsonld) {
var metadata = {};
var values = {};
var metaElements = this._doc.getElementsByTagName("meta");
// property is a space-separated list of values
var propertyPattern = /\s*(article|dc|dcterm|og|twitter)\s*:\s*(author|creator|description|published_time|title|site_name)\s*/gi;
// name is a single value
var namePattern = /^\s*(?:(dc|dcterm|og|twitter|weibo:(article|webpage))\s*[\.:]\s*)?(author|creator|description|title|site_name)\s*$/i;
// Find description tags.
this._forEachNode(metaElements, function(element) {
var elementName = element.getAttribute("name");
var elementProperty = element.getAttribute("property");
var content = element.getAttribute("content");
if (!content) {
return;
}
var matches = null;
var name = null;
if (elementProperty) {
matches = elementProperty.match(propertyPattern);
if (matches) {
// Convert to lowercase, and remove any whitespace
// so we can match below.
name = matches[0].toLowerCase().replace(/\s/g, "");
// multiple authors
values[name] = content.trim();
}
}
if (!matches && elementName && namePattern.test(elementName)) {
name = elementName;
if (content) {
// Convert to lowercase, remove any whitespace, and convert dots
// to colons so we can match below.
name = name.toLowerCase().replace(/\s/g, "").replace(/\./g, ":");
values[name] = content.trim();
}
}
});
// get title
metadata.title = jsonld.title ||
values["dc:title"] ||
values["dcterm:title"] ||
values["og:title"] ||
values["weibo:article:title"] ||
values["weibo:webpage:title"] ||
values["title"] ||
values["twitter:title"];
if (!metadata.title) {
metadata.title = this._getArticleTitle();
}
// get author
metadata.byline = jsonld.byline ||
values["dc:creator"] ||
values["dcterm:creator"] ||
values["author"];
// get description
metadata.excerpt = jsonld.excerpt ||
values["dc:description"] ||
values["dcterm:description"] ||
values["og:description"] ||
values["weibo:article:description"] ||
values["weibo:webpage:description"] ||
values["description"] ||
values["twitter:description"];
// get site name
metadata.siteName = jsonld.siteName ||
values["og:site_name"];
// get article published time
metadata.publishedTime = jsonld.datePublished ||
values["article:published_time"] || null;
// in many sites the meta value is escaped with HTML entities,
// so here we need to unescape it
metadata.title = this._unescapeHtmlEntities(metadata.title);
metadata.byline = this._unescapeHtmlEntities(metadata.byline);
metadata.excerpt = this._unescapeHtmlEntities(metadata.excerpt);
metadata.siteName = this._unescapeHtmlEntities(metadata.siteName);
metadata.publishedTime = this._unescapeHtmlEntities(metadata.publishedTime);
return metadata;
},
/**
* Check if node is image, or if node contains exactly only one image
* whether as a direct child or as its descendants.
*
* @param Element
**/
_isSingleImage: function(node) {
if (node.tagName === "IMG") {
return true;
}
if (node.children.length !== 1 || node.textContent.trim() !== "") {
return false;
}
return this._isSingleImage(node.children[0]);
},
/**
* Find all <noscript> that are located after <img> nodes, and which contain only one
* <img> element. Replace the first image with the image from inside the <noscript> tag,
* and remove the <noscript> tag. This improves the quality of the images we use on
* some sites (e.g. Medium).
*
* @param Element
**/
_unwrapNoscriptImages: function(doc) {
// Find img without source or attributes that might contains image, and remove it.
// This is done to prevent a placeholder img is replaced by img from noscript in next step.
var imgs = Array.from(doc.getElementsByTagName("img"));
this._forEachNode(imgs, function(img) {
for (var i = 0; i < img.attributes.length; i++) {
var attr = img.attributes[i];
switch (attr.name) {
case "src":
case "srcset":
case "data-src":
case "data-srcset":
return;
}
if (/\.(jpg|jpeg|png|webp)/i.test(attr.value)) {
return;
}
}
img.parentNode.removeChild(img);
});
// Next find noscript and try to extract its image
var noscripts = Array.from(doc.getElementsByTagName("noscript"));
this._forEachNode(noscripts, function(noscript) {
// Parse content of noscript and make sure it only contains image
var tmp = doc.createElement("div");
tmp.innerHTML = noscript.innerHTML;
if (!this._isSingleImage(tmp)) {
return;
}
// If noscript has previous sibling and it only contains image,
// replace it with noscript content. However we also keep old
// attributes that might contains image.
var prevElement = noscript.previousElementSibling;
if (prevElement && this._isSingleImage(prevElement)) {
var prevImg = prevElement;
if (prevImg.tagName !== "IMG") {
prevImg = prevElement.getElementsByTagName("img")[0];
}
var newImg = tmp.getElementsByTagName("img")[0];
for (var i = 0; i < prevImg.attributes.length; i++) {
var attr = prevImg.attributes[i];
if (attr.value === "") {
continue;
}
if (attr.name === "src" || attr.name === "srcset" || /\.(jpg|jpeg|png|webp)/i.test(attr.value)) {
if (newImg.getAttribute(attr.name) === attr.value) {
continue;
}
var attrName = attr.name;
if (newImg.hasAttribute(attrName)) {
attrName = "data-old-" + attrName;
}
newImg.setAttribute(attrName, attr.value);
}
}
noscript.parentNode.replaceChild(tmp.firstElementChild, prevElement);
}
});
},
/**
* Removes script tags from the document.
*
* @param Element
**/
_removeScripts: function(doc) {
this._removeNodes(this._getAllNodesWithTag(doc, ["script", "noscript"]));
},
/**
* Check if this node has only whitespace and a single element with given tag
* Returns false if the DIV node contains non-empty text nodes
* or if it contains no element with given tag or more than 1 element.
*
* @param Element
* @param string tag of child element
**/
_hasSingleTagInsideElement: function(element, tag) {
// There should be exactly 1 element child with given tag
if (element.children.length != 1 || element.children[0].tagName !== tag) {
return false;
}
// And there should be no text nodes with real content
return !this._someNode(element.childNodes, function(node) {
return node.nodeType === this.TEXT_NODE &&
this.REGEXPS.hasContent.test(node.textContent);
});
},
_isElementWithoutContent: function(node) {
return node.nodeType === this.ELEMENT_NODE &&
node.textContent.trim().length == 0 &&
(node.children.length == 0 ||
node.children.length == node.getElementsByTagName("br").length + node.getElementsByTagName("hr").length);
},
/**
* Determine whether element has any children block level elements.
*
* @param Element
*/
_hasChildBlockElement: function (element) {
return this._someNode(element.childNodes, function(node) {
return this.DIV_TO_P_ELEMS.has(node.tagName) ||
this._hasChildBlockElement(node);
});
},
/***
* Determine if a node qualifies as phrasing content.
* https://developer.mozilla.org/en-US/docs/Web/Guide/HTML/Content_categories#Phrasing_content
**/
_isPhrasingContent: function(node) {
return node.nodeType === this.TEXT_NODE || this.PHRASING_ELEMS.indexOf(node.tagName) !== -1 ||
((node.tagName === "A" || node.tagName === "DEL" || node.tagName === "INS") &&
this._everyNode(node.childNodes, this._isPhrasingContent));
},
_isWhitespace: function(node) {
return (node.nodeType === this.TEXT_NODE && node.textContent.trim().length === 0) ||
(node.nodeType === this.ELEMENT_NODE && node.tagName === "BR");
},
/**
* Get the inner text of a node - cross browser compatibly.
* This also strips out any excess whitespace to be found.
*
* @param Element
* @param Boolean normalizeSpaces (default: true)
* @return string
**/
_getInnerText: function(e, normalizeSpaces) {
normalizeSpaces = (typeof normalizeSpaces === "undefined") ? true : normalizeSpaces;
var textContent = e.textContent.trim();
if (normalizeSpaces) {
return textContent.replace(this.REGEXPS.normalize, " ");
}
return textContent;
},
/**
* Get the number of times a string s appears in the node e.
*
* @param Element
* @param string - what to split on. Default is ","
* @return number (integer)
**/
_getCharCount: function(e, s) {
s = s || ",";
return this._getInnerText(e).split(s).length - 1;
},
/**
* Remove the style attribute on every e and under.
* TODO: Test if getElementsByTagName(*) is faster.
*
* @param Element
* @return void
**/
_cleanStyles: function(e) {
if (!e || e.tagName.toLowerCase() === "svg")
return;
// Remove `style` and deprecated presentational attributes
for (var i = 0; i < this.PRESENTATIONAL_ATTRIBUTES.length; i++) {
e.removeAttribute(this.PRESENTATIONAL_ATTRIBUTES[i]);
}
if (this.DEPRECATED_SIZE_ATTRIBUTE_ELEMS.indexOf(e.tagName) !== -1) {
e.removeAttribute("width");
e.removeAttribute("height");
}
var cur = e.firstElementChild;
while (cur !== null) {
this._cleanStyles(cur);
cur = cur.nextElementSibling;
}
},
/**
* Get the density of links as a percentage of the content
* This is the amount of text that is inside a link divided by the total text in the node.
*
* @param Element
* @return number (float)
**/
_getLinkDensity: function(element) {
var textLength = this._getInnerText(element).length;
if (textLength === 0)
return 0;
var linkLength = 0;
// XXX implement _reduceNodeList?
this._forEachNode(element.getElementsByTagName("a"), function(linkNode) {
var href = linkNode.getAttribute("href");
var coefficient = href && this.REGEXPS.hashUrl.test(href) ? 0.3 : 1;
linkLength += this._getInnerText(linkNode).length * coefficient;
});
return linkLength / textLength;
},
/**
* Get an elements class/id weight. Uses regular expressions to tell if this
* element looks good or bad.
*
* @param Element
* @return number (Integer)
**/
_getClassWeight: function(e) {
if (!this._flagIsActive(this.FLAG_WEIGHT_CLASSES))
return 0;
var weight = 0;
// Look for a special classname
if (typeof(e.className) === "string" && e.className !== "") {
if (this.REGEXPS.negative.test(e.className))
weight -= 25;
if (this.REGEXPS.positive.test(e.className))
weight += 25;
}
// Look for a special ID
if (typeof(e.id) === "string" && e.id !== "") {
if (this.REGEXPS.negative.test(e.id))
weight -= 25;
if (this.REGEXPS.positive.test(e.id))
weight += 25;
}
return weight;
},
/**
* Clean a node of all elements of type "tag".
* (Unless it's a youtube/vimeo video. People love movies.)
*
* @param Element
* @param string tag to clean
* @return void
**/
_clean: function(e, tag) {
var isEmbed = ["object", "embed", "iframe"].indexOf(tag) !== -1;
this._removeNodes(this._getAllNodesWithTag(e, [tag]), function(element) {
// Allow youtube and vimeo videos through as people usually want to see those.
if (isEmbed) {
// First, check the elements attributes to see if any of them contain youtube or vimeo
for (var i = 0; i < element.attributes.length; i++) {
if (this._allowedVideoRegex.test(element.attributes[i].value)) {
return false;
}
}
// For embed with <object> tag, check inner HTML as well.
if (element.tagName === "object" && this._allowedVideoRegex.test(element.innerHTML)) {
return false;
}
}
return true;
});
},
/**
* Check if a given node has one of its ancestor tag name matching the
* provided one.
* @param HTMLElement node
* @param String tagName
* @param Number maxDepth
* @param Function filterFn a filter to invoke to determine whether this node 'counts'
* @return Boolean
*/
_hasAncestorTag: function(node, tagName, maxDepth, filterFn) {
maxDepth = maxDepth || 3;
tagName = tagName.toUpperCase();
var depth = 0;
while (node.parentNode) {
if (maxDepth > 0 && depth > maxDepth)
return false;
if (node.parentNode.tagName === tagName && (!filterFn || filterFn(node.parentNode)))
return true;
node = node.parentNode;
depth++;
}
return false;
},
/**
* Return an object indicating how many rows and columns this table has.
*/
_getRowAndColumnCount: function(table) {
var rows = 0;
var columns = 0;
var trs = table.getElementsByTagName("tr");
for (var i = 0; i < trs.length; i++) {
var rowspan = trs[i].getAttribute("rowspan") || 0;
if (rowspan) {
rowspan = parseInt(rowspan, 10);
}
rows += (rowspan || 1);
// Now look for column-related info
var columnsInThisRow = 0;
var cells = trs[i].getElementsByTagName("td");
for (var j = 0; j < cells.length; j++) {
var colspan = cells[j].getAttribute("colspan") || 0;
if (colspan) {
colspan = parseInt(colspan, 10);
}
columnsInThisRow += (colspan || 1);
}
columns = Math.max(columns, columnsInThisRow);
}
return {rows: rows, columns: columns};
},
/**
* Look for 'data' (as opposed to 'layout') tables, for which we use
* similar checks as
* https://searchfox.org/mozilla-central/rev/f82d5c549f046cb64ce5602bfd894b7ae807c8f8/accessible/generic/TableAccessible.cpp#19
*/
_markDataTables: function(root) {
var tables = root.getElementsByTagName("table");
for (var i = 0; i < tables.length; i++) {
var table = tables[i];
var role = table.getAttribute("role");
if (role == "presentation") {
table._readabilityDataTable = false;
continue;
}
var datatable = table.getAttribute("datatable");
if (datatable == "0") {
table._readabilityDataTable = false;
continue;
}
var summary = table.getAttribute("summary");
if (summary) {
table._readabilityDataTable = true;
continue;
}
var caption = table.getElementsByTagName("caption")[0];
if (caption && caption.childNodes.length > 0) {
table._readabilityDataTable = true;
continue;
}
// If the table has a descendant with any of these tags, consider a data table:
var dataTableDescendants = ["col", "colgroup", "tfoot", "thead", "th"];
var descendantExists = function(tag) {
return !!table.getElementsByTagName(tag)[0];
};
if (dataTableDescendants.some(descendantExists)) {
this.log("Data table because found data-y descendant");
table._readabilityDataTable = true;
continue;
}
// Nested tables indicate a layout table:
if (table.getElementsByTagName("table")[0]) {
table._readabilityDataTable = false;
continue;
}
var sizeInfo = this._getRowAndColumnCount(table);
if (sizeInfo.rows >= 10 || sizeInfo.columns > 4) {
table._readabilityDataTable = true;
continue;
}
// Now just go by size entirely:
table._readabilityDataTable = sizeInfo.rows * sizeInfo.columns > 10;
}
},
/* convert images and figures that have properties like data-src into images that can be loaded without JS */
_fixLazyImages: function (root) {
this._forEachNode(this._getAllNodesWithTag(root, ["img", "picture", "figure"]), function (elem) {
// In some sites (e.g. Kotaku), they put 1px square image as base64 data uri in the src attribute.
// So, here we check if the data uri is too short, just might as well remove it.
if (elem.src && this.REGEXPS.b64DataUrl.test(elem.src)) {
// Make sure it's not SVG, because SVG can have a meaningful image in under 133 bytes.
var parts = this.REGEXPS.b64DataUrl.exec(elem.src);
if (parts[1] === "image/svg+xml") {
return;
}
// Make sure this element has other attributes which contains image.
// If it doesn't, then this src is important and shouldn't be removed.
var srcCouldBeRemoved = false;
for (var i = 0; i < elem.attributes.length; i++) {
var attr = elem.attributes[i];
if (attr.name === "src") {
continue;
}
if (/\.(jpg|jpeg|png|webp)/i.test(attr.value)) {
srcCouldBeRemoved = true;
break;
}
}
// Here we assume if image is less than 100 bytes (or 133B after encoded to base64)
// it will be too small, therefore it might be placeholder image.
if (srcCouldBeRemoved) {
var b64starts = elem.src.search(/base64\s*/i) + 7;
var b64length = elem.src.length - b64starts;
if (b64length < 133) {
elem.removeAttribute("src");
}
}
}
// also check for "null" to work around https://github.com/jsdom/jsdom/issues/2580
if ((elem.src || (elem.srcset && elem.srcset != "null")) && elem.className.toLowerCase().indexOf("lazy") === -1) {
return;
}
for (var j = 0; j < elem.attributes.length; j++) {
attr = elem.attributes[j];
if (attr.name === "src" || attr.name === "srcset" || attr.name === "alt") {
continue;
}
var copyTo = null;
if (/\.(jpg|jpeg|png|webp)\s+\d/.test(attr.value)) {
copyTo = "srcset";
} else if (/^\s*\S+\.(jpg|jpeg|png|webp)\S*\s*$/.test(attr.value)) {
copyTo = "src";
}
if (copyTo) {
//if this is an img or picture, set the attribute directly
if (elem.tagName === "IMG" || elem.tagName === "PICTURE") {
elem.setAttribute(copyTo, attr.value);
} else if (elem.tagName === "FIGURE" && !this._getAllNodesWithTag(elem, ["img", "picture"]).length) {
//if the item is a <figure> that does not contain an image or picture, create one and place it inside the figure
//see the nytimes-3 testcase for an example
var img = this._doc.createElement("img");
img.setAttribute(copyTo, attr.value);
elem.appendChild(img);
}
}
}
});
},
_getTextDensity: function(e, tags) {
var textLength = this._getInnerText(e, true).length;
if (textLength === 0) {
return 0;
}
var childrenLength = 0;
var children = this._getAllNodesWithTag(e, tags);
this._forEachNode(children, (child) => childrenLength += this._getInnerText(child, true).length);
return childrenLength / textLength;
},
/**
* Clean an element of all tags of type "tag" if they look fishy.
* "Fishy" is an algorithm based on content length, classnames, link density, number of images & embeds, etc.
*
* @return void
**/
_cleanConditionally: function(e, tag) {
if (!this._flagIsActive(this.FLAG_CLEAN_CONDITIONALLY))
return;
// Gather counts for other typical elements embedded within.
// Traverse backwards so we can remove nodes at the same time
// without effecting the traversal.
//
// TODO: Consider taking into account original contentScore here.
this._removeNodes(this._getAllNodesWithTag(e, [tag]), function(node) {
// First check if this node IS data table, in which case don't remove it.
var isDataTable = function(t) {
return t._readabilityDataTable;
};
var isList = tag === "ul" || tag === "ol";
if (!isList) {
var listLength = 0;
var listNodes = this._getAllNodesWithTag(node, ["ul", "ol"]);
this._forEachNode(listNodes, (list) => listLength += this._getInnerText(list).length);
isList = listLength / this._getInnerText(node).length > 0.9;
}
if (tag === "table" && isDataTable(node)) {
return false;
}
// Next check if we're inside a data table, in which case don't remove it as well.
if (this._hasAncestorTag(node, "table", -1, isDataTable)) {
return false;
}
if (this._hasAncestorTag(node, "code")) {
return false;
}
var weight = this._getClassWeight(node);
this.log("Cleaning Conditionally", node);
var contentScore = 0;
if (weight + contentScore < 0) {
return true;
}
if (this._getCharCount(node, ",") < 10) {
// If there are not very many commas, and the number of
// non-paragraph elements is more than paragraphs or other
// ominous signs, remove the element.
var p = node.getElementsByTagName("p").length;
var img = node.getElementsByTagName("img").length;
var li = node.getElementsByTagName("li").length - 100;
var input = node.getElementsByTagName("input").length;
var headingDensity = this._getTextDensity(node, ["h1", "h2", "h3", "h4", "h5", "h6"]);
var embedCount = 0;
var embeds = this._getAllNodesWithTag(node, ["object", "embed", "iframe"]);
for (var i = 0; i < embeds.length; i++) {
// If this embed has attribute that matches video regex, don't delete it.
for (var j = 0; j < embeds[i].attributes.length; j++) {
if (this._allowedVideoRegex.test(embeds[i].attributes[j].value)) {
return false;
}
}
// For embed with <object> tag, check inner HTML as well.
if (embeds[i].tagName === "object" && this._allowedVideoRegex.test(embeds[i].innerHTML)) {
return false;
}
embedCount++;
}
var linkDensity = this._getLinkDensity(node);
var contentLength = this._getInnerText(node).length;
var haveToRemove =
(img > 1 && p / img < 0.5 && !this._hasAncestorTag(node, "figure")) ||
(!isList && li > p) ||
(input > Math.floor(p/3)) ||
(!isList && headingDensity < 0.9 && contentLength < 25 && (img === 0 || img > 2) && !this._hasAncestorTag(node, "figure")) ||
(!isList && weight < 25 && linkDensity > 0.2) ||
(weight >= 25 && linkDensity > 0.5) ||
((embedCount === 1 && contentLength < 75) || embedCount > 1);
// Allow simple lists of images to remain in pages
if (isList && haveToRemove) {
for (var x = 0; x < node.children.length; x++) {
let child = node.children[x];
// Don't filter in lists with li's that contain more than one child
if (child.children.length > 1) {
return haveToRemove;
}
}
let li_count = node.getElementsByTagName("li").length;
// Only allow the list to remain if every li contains an image
if (img == li_count) {
return false;
}
}
return haveToRemove;
}
return false;
});
},
/**
* Clean out elements that match the specified conditions
*
* @param Element
* @param Function determines whether a node should be removed
* @return void
**/
_cleanMatchedNodes: function(e, filter) {
var endOfSearchMarkerNode = this._getNextNode(e, true);
var next = this._getNextNode(e);
while (next && next != endOfSearchMarkerNode) {
if (filter.call(this, next, next.className + " " + next.id)) {
next = this._removeAndGetNext(next);
} else {
next = this._getNextNode(next);
}
}
},
/**
* Clean out spurious headers from an Element.
*
* @param Element
* @return void
**/
_cleanHeaders: function(e) {
let headingNodes = this._getAllNodesWithTag(e, ["h1", "h2"]);
this._removeNodes(headingNodes, function(node) {
let shouldRemove = this._getClassWeight(node) < 0;
if (shouldRemove) {
this.log("Removing header with low class weight:", node);
}
return shouldRemove;
});
},
/**
* Check if this node is an H1 or H2 element whose content is mostly
* the same as the article title.
*
* @param Element the node to check.
* @return boolean indicating whether this is a title-like header.
*/
_headerDuplicatesTitle: function(node) {
if (node.tagName != "H1" && node.tagName != "H2") {
return false;
}
var heading = this._getInnerText(node, false);
this.log("Evaluating similarity of header:", heading, this._articleTitle);
return this._textSimilarity(this._articleTitle, heading) > 0.75;
},
_flagIsActive: function(flag) {
return (this._flags & flag) > 0;
},
_removeFlag: function(flag) {
this._flags = this._flags & ~flag;
},
_isProbablyVisible: function(node) {
// Have to null-check node.style and node.className.indexOf to deal with SVG and MathML nodes.
return (!node.style || node.style.display != "none")
&& (!node.style || node.style.visibility != "hidden")
&& !node.hasAttribute("hidden")
//check for "fallback-image" so that wikimedia math images are displayed
&& (!node.hasAttribute("aria-hidden") || node.getAttribute("aria-hidden") != "true" || (node.className && node.className.indexOf && node.className.indexOf("fallback-image") !== -1));
},
/**
* Runs readability.
*
* Workflow:
* 1. Prep the document by removing script tags, css, etc.
* 2. Build readability's DOM tree.
* 3. Grab the article content from the current dom tree.
* 4. Replace the current DOM tree with the new one.
* 5. Read peacefully.
*
* @return void
**/
parse: function () {
// Avoid parsing too large documents, as per configuration option
if (this._maxElemsToParse > 0) {
var numTags = this._doc.getElementsByTagName("*").length;
if (numTags > this._maxElemsToParse) {
throw new Error("Aborting parsing document; " + numTags + " elements found");
}
}
// Unwrap image from noscript
this._unwrapNoscriptImages(this._doc);
// Extract JSON-LD metadata before removing scripts
var jsonLd = this._disableJSONLD ? {} : this._getJSONLD(this._doc);
// Remove script tags from the document.
this._removeScripts(this._doc);
this._prepDocument();
var metadata = this._getArticleMetadata(jsonLd);
this._articleTitle = metadata.title;
var articleContent = this._grabArticle();
if (!articleContent)
return null;
this.log("Grabbed: " + articleContent.innerHTML);
this._postProcessContent(articleContent);
// If we haven't found an excerpt in the article's metadata, use the article's
// first paragraph as the excerpt. This is used for displaying a preview of
// the article's content.
if (!metadata.excerpt) {
var paragraphs = articleContent.getElementsByTagName("p");
if (paragraphs.length > 0) {
metadata.excerpt = paragraphs[0].textContent.trim();
}
}
var textContent = articleContent.textContent;
return {
title: this._articleTitle,
byline: metadata.byline || this._articleByline,
dir: this._articleDir,
lang: this._articleLang,
content: this._serializer(articleContent),
textContent: textContent,
length: textContent.length,
excerpt: metadata.excerpt,
siteName: metadata.siteName || this._articleSiteName,
publishedTime: metadata.publishedTime
};
}
};
if (true) {
/* global module */
module.exports = Readability;
}
/***/ }),
/***/ "./node_modules/@mozilla/readability/index.js":
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
/* eslint-env node */
var Readability = __webpack_require__("./node_modules/@mozilla/readability/Readability.js");
var isProbablyReaderable = __webpack_require__("./node_modules/@mozilla/readability/Readability-readerable.js");
module.exports = {
Readability: Readability,
isProbablyReaderable: isProbablyReaderable
};
/***/ }),
/***/ "./src/ui/ChapterList.less":
/***/ ((module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ A: () => (__WEBPACK_DEFAULT_EXPORT__)
/* harmony export */ });
/* harmony import */ var _node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./node_modules/css-loader/dist/runtime/noSourceMaps.js");
/* harmony import */ var _node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./node_modules/css-loader/dist/runtime/api.js");
/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__);
// Imports
var ___CSS_LOADER_EXPORT___ = _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default()((_node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0___default()));
// Module
___CSS_LOADER_EXPORT___.push([module.id, `:root {
--good-chapter-color: #41b883;
--bad-chapter-color: #e73838;
--warning-chapter-color: #ff9900;
}
div.chapter-list-loading {
padding-top: 5em;
padding-bottom: 5em;
text-align: center;
}
div.chapter-list {
max-height: 200px;
overflow-y: scroll;
}
div.chapter-list .section {
margin-top: 1.5em;
display: grid;
grid-template-columns: 32% 32% 32%;
}
div.chapter-list .section > h3:first-child {
grid-column-end: span 3;
text-align: center;
}
div.chapter-list .section > div.chapter {
text-align: center;
padding-top: 0.5em;
padding-bottom: 0.3em;
padding-left: 23px;
padding-right: 20px;
border: 1px solid #d9d9d9;
border-radius: 5px;
margin-left: 10px;
margin-top: 5px;
margin-right: 0;
margin-bottom: 0;
}
div.chapter-list .section a.disabled {
pointer-events: none;
cursor: default;
}
div.chapter-list .section a {
text-decoration: none;
}
div.chapter-list div.chapter.good {
background: var(--good-chapter-color);
}
div.chapter-list div.chapter.bad {
background: var(--bad-chapter-color);
}
div.chapter-list div.chapter.good.warning {
background: var(--warning-chapter-color);
}
div.chapter-list div.chapter.bad a,
div.chapter-list div.chapter.good a {
color: white;
font-size: 0.9em;
}
.nd-setting-body span.good {
color: var(--good-chapter-color);
}
.nd-setting-body span.bad {
color: var(--bad-chapter-color);
}
.nd-setting-body span.warning {
color: var(--warning-chapter-color);
}
`, ""]);
// Exports
/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (___CSS_LOADER_EXPORT___);
/***/ }),
/***/ "./src/ui/TestUI.less":
/***/ ((module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ A: () => (__WEBPACK_DEFAULT_EXPORT__)
/* harmony export */ });
/* harmony import */ var _node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./node_modules/css-loader/dist/runtime/noSourceMaps.js");
/* harmony import */ var _node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./node_modules/css-loader/dist/runtime/api.js");
/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__);
// Imports
var ___CSS_LOADER_EXPORT___ = _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default()((_node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0___default()));
// Module
___CSS_LOADER_EXPORT___.push([module.id, `#test-page-div {
max-height: 300px;
overflow-y: scroll;
}
#test-page-div table {
text-align: center;
}
#test-page-div td {
all: revert;
padding-top: 0.3em;
}
#test-page-div td > img {
max-height: 15em;
}
#test-page-div tr > td:nth-child(1) {
font-weight: bold;
min-width: 7em;
}
#test-page-div tr > td:nth-child(2) div,
#test-page-div tr > td:nth-child(2) p {
text-align: left;
}
#test-page-div hr {
margin-top: 1.5em;
margin-bottom: 1.5em;
}
#test-page-div h2 {
text-align: center;
margin-bottom: 1.3em;
}
#test-page-div h4 {
text-align: center;
}
#test-page-div .chapter p {
line-height: 1.4;
}
#test-page-div .chapter img {
max-width: 95%;
}
#test-page-div .preview-chapter-setting {
text-align: center;
}
`, ""]);
// Exports
/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (___CSS_LOADER_EXPORT___);
/***/ }),
/***/ "./src/ui/button.less":
/***/ ((module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ A: () => (__WEBPACK_DEFAULT_EXPORT__)
/* harmony export */ });
/* harmony import */ var _node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./node_modules/css-loader/dist/runtime/noSourceMaps.js");
/* harmony import */ var _node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./node_modules/css-loader/dist/runtime/api.js");
/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__);
// Imports
var ___CSS_LOADER_EXPORT___ = _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default()((_node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0___default()));
// Module
___CSS_LOADER_EXPORT___.push([module.id, `.button-div {
position: fixed;
top: 15%;
right: 5%;
z-index: 10000;
}
.button-div button {
border-style: none;
text-align: center;
vertical-align: baseline;
background-color: rgba(128, 128, 128, 0.2);
padding: 3px;
border-radius: 12px;
min-width: auto;
min-height: auto;
}
.button-div img.start,
.button-div img.jump {
height: 2em;
}
.button-div img.setting {
height: 1em;
}
`, ""]);
// Exports
/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (___CSS_LOADER_EXPORT___);
/***/ }),
/***/ "./src/ui/setting.less":
/***/ ((module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ A: () => (__WEBPACK_DEFAULT_EXPORT__)
/* harmony export */ });
/* harmony import */ var _node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./node_modules/css-loader/dist/runtime/noSourceMaps.js");
/* harmony import */ var _node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./node_modules/css-loader/dist/runtime/api.js");
/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__);
// Imports
var ___CSS_LOADER_EXPORT___ = _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default()((_node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0___default()));
// Module
___CSS_LOADER_EXPORT___.push([module.id, `.nd-setting-body {
background: #e0e0e0;
padding: 1em;
border-top-right-radius: 3px;
}
.nd-setting-body hr {
margin-top: 0.8em;
margin-bottom: 0.8em;
}
.nd-setting-body input[type="checkbox"],
.nd-setting-body input[type="radio"],
.nd-setting-body input[type="text"] {
position: static;
opacity: 1;
margin: auto;
padding: initial;
appearance: revert !important;
-webkit-appearance: revert !important;
all: revert;
}
dialog-ui .tab-button {
padding: 6px 10px;
border-top-left-radius: 3px;
border-top-right-radius: 3px;
border: 1px solid #ccc;
cursor: pointer;
background: #f0f0f0;
margin-bottom: -1px;
margin-right: -1px;
color: black;
line-height: normal;
display: inline-block;
text-align: center;
font-weight: bold;
max-width: 9em;
box-sizing: initial;
}
dialog-ui .tab-button:hover {
background: #e0e0e0;
}
dialog-ui .tab-button.active {
background: #e0e0e0;
}
dialog-ui #nd-setting-tab-1 input + label {
all: revert;
}
dialog-ui #nd-setting-tab-2 select {
all: revert;
}
.nd-setting-footer {
background: #e0e0e0;
padding-bottom: 0.7em;
text-align: center;
border-bottom-left-radius: 3px;
border-bottom-right-radius: 3px;
}
.nd-setting-footer > button {
all: revert;
}
/* 日志页面 */
#novel-downloader-log {
max-height: 300px;
overflow: scroll;
}
/* 彩色斜纹 来自:https://www.zhangxinxu.com/wordpress/2021/05/css-html-hr/ */
.hr-twill-colorful {
all: revert;
border: 0;
padding: 3px;
background: linear-gradient(135deg, red, orange, green, blue, purple);
--mask-image: repeating-linear-gradient(135deg, #000 0px, #000 1px, transparent 1px, transparent 6px);
-webkit-mask-image: var(--mask-image);
mask-image: var(--mask-image);
}
/* 两头虚 来自:https://www.zhangxinxu.com/wordpress/2021/05/css-html-hr/ */
.hr-edge-weak {
all: revert;
border: 0;
padding-top: 1px;
background: linear-gradient(to right, transparent, #d0d0d5, transparent);
}
`, ""]);
// Exports
/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (___CSS_LOADER_EXPORT___);
/***/ }),
/***/ "./src/save/main.css":
/***/ ((module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ A: () => (__WEBPACK_DEFAULT_EXPORT__)
/* harmony export */ });
/* harmony import */ var _node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./node_modules/css-loader/dist/runtime/noSourceMaps.js");
/* harmony import */ var _node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./node_modules/css-loader/dist/runtime/api.js");
/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__);
// Imports
var ___CSS_LOADER_EXPORT___ = _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default()((_node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0___default()));
// Module
___CSS_LOADER_EXPORT___.push([module.id, `h1 {
line-height: 130%;
text-align: center;
font-weight: bold;
font-size: xx-large;
margin-top: 3.2em;
margin-bottom: 3.3em;
}
h2 {
line-height: 130%;
text-align: center;
font-weight: bold;
font-size: x-large;
margin-top: 1.2em;
margin-bottom: 2.3em;
}
div {
margin: 0;
padding: 0;
text-align: justify;
}
p {
text-indent: 2em;
display: block;
line-height: 1.3em;
margin-top: 0.4em;
margin-bottom: 0.4em;
}
img {
vertical-align: text-bottom;
max-width: 90%;
}
.title {
margin-bottom: 0.7em;
}
`, ""]);
// Exports
/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (___CSS_LOADER_EXPORT___);
/***/ }),
/***/ "./src/save/sgc-toc.css":
/***/ ((module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ A: () => (__WEBPACK_DEFAULT_EXPORT__)
/* harmony export */ });
/* harmony import */ var _node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./node_modules/css-loader/dist/runtime/noSourceMaps.js");
/* harmony import */ var _node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./node_modules/css-loader/dist/runtime/api.js");
/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__);
// Imports
var ___CSS_LOADER_EXPORT___ = _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default()((_node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0___default()));
// Module
___CSS_LOADER_EXPORT___.push([module.id, `div.sgc-toc-title {
font-size: 2em;
font-weight: bold;
margin-bottom: 1em;
text-align: center;
}
div.sgc-toc-level-1 {
margin-left: 0em;
}
div.sgc-toc-level-2 {
margin-left: 2em;
}
div.sgc-toc-level-3 {
margin-left: 2em;
}
div.sgc-toc-level-4 {
margin-left: 2em;
}
div.sgc-toc-level-5 {
margin-left: 2em;
}
div.sgc-toc-level-6 {
margin-left: 2em;
}
`, ""]);
// Exports
/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (___CSS_LOADER_EXPORT___);
/***/ }),
/***/ "./src/save/toc.css":
/***/ ((module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ A: () => (__WEBPACK_DEFAULT_EXPORT__)
/* harmony export */ });
/* harmony import */ var _node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./node_modules/css-loader/dist/runtime/noSourceMaps.js");
/* harmony import */ var _node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./node_modules/css-loader/dist/runtime/api.js");
/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__);
// Imports
var ___CSS_LOADER_EXPORT___ = _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default()((_node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0___default()));
// Module
___CSS_LOADER_EXPORT___.push([module.id, `img {
max-width: 100%;
max-height: 15em;
}
.introduction {
font-size: smaller;
max-height: 18em;
overflow-y: scroll;
}
.introduction p {
text-indent: 0;
}
.bookurl {
text-align: center;
font-size: smaller;
padding-top: 1em;
padding-bottom: 0.5em;
margin-top: 0.4em;
}
.bookurl > a {
color: gray;
}
.info h3 {
padding-left: 0.5em;
margin-top: -1.2em;
margin-bottom: 0.5em;
}
.section {
margin-top: 1.5em;
display: grid;
grid-template-columns: 33% 33% 33%;
}
.section > h2:first-child {
grid-column-end: span 3;
}
.section > .chapter {
padding-bottom: 0.3em;
text-align: center;
}
.main > h1 {
margin-top: 1.5em;
margin-bottom: 1.5em;
}
a.disabled {
pointer-events: none;
cursor: default;
color: gray;
}
.author::before {
content: "作者:";
}
.author {
text-align: center;
margin-top: -3em;
margin-bottom: 3em;
}
`, ""]);
// Exports
/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (___CSS_LOADER_EXPORT___);
/***/ }),
/***/ "./src/save/web.css":
/***/ ((module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ A: () => (__WEBPACK_DEFAULT_EXPORT__)
/* harmony export */ });
/* harmony import */ var _node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./node_modules/css-loader/dist/runtime/noSourceMaps.js");
/* harmony import */ var _node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./node_modules/css-loader/dist/runtime/api.js");
/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__);
// Imports
var ___CSS_LOADER_EXPORT___ = _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default()((_node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0___default()));
// Module
___CSS_LOADER_EXPORT___.push([module.id, `body {
background-color: #f0f0f2;
margin: 0;
padding: 0;
font-family: -apple-system, system-ui, BlinkMacSystemFont, "Segoe UI",
"Open Sans", "Helvetica Neue", Helvetica, Arial, sans-serif;
}
div.main {
width: 900px;
margin: 5em auto;
padding: 2em;
background-color: #fdfdff;
border-radius: 0.5em;
box-shadow: 2px 3px 7px 2px rgba(0, 0, 0, 0.02);
}
@media (max-width: 700px) {
div.main {
margin: 0 auto;
width: auto;
}
}
`, ""]);
// Exports
/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (___CSS_LOADER_EXPORT___);
/***/ }),
/***/ "./src/ui/FilterTab.css":
/***/ ((module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ A: () => (__WEBPACK_DEFAULT_EXPORT__)
/* harmony export */ });
/* harmony import */ var _node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./node_modules/css-loader/dist/runtime/noSourceMaps.js");
/* harmony import */ var _node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./node_modules/css-loader/dist/runtime/api.js");
/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__);
// Imports
var ___CSS_LOADER_EXPORT___ = _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default()((_node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0___default()));
// Module
___CSS_LOADER_EXPORT___.push([module.id, `.filter-setting {
padding-top: 0.4em;
padding-bottom: 0.8em;
text-align: center;
}
.filter-input + .filter-setter {
margin-top: 1em;
}
.filter-description {
font-size: larger;
color: cornflowerblue;
}
`, ""]);
// Exports
/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (___CSS_LOADER_EXPORT___);
/***/ }),
/***/ "./src/ui/dialog.css":
/***/ ((module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ A: () => (__WEBPACK_DEFAULT_EXPORT__)
/* harmony export */ });
/* harmony import */ var _node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./node_modules/css-loader/dist/runtime/noSourceMaps.js");
/* harmony import */ var _node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./node_modules/css-loader/dist/runtime/api.js");
/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__);
// Imports
var ___CSS_LOADER_EXPORT___ = _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default()((_node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0___default()));
// Module
___CSS_LOADER_EXPORT___.push([module.id, `.overlay {
visibility: hidden;
opacity: 0;
z-index: 100000;
position: fixed;
top: -50%;
left: -50%;
height: 200%;
width: 200%;
background-color: black;
}
.overlay.open {
opacity: 0.8;
visibility: visible;
transition: opacity 0.2s ease-in;
}
.overlay:not(.open) {
transition: visibility 0.2s step-end, opacity 0.2s ease-in;
}
.out {
position: fixed;
top: 0;
left: 0;
height: 100%;
width: 100%;
display: flex;
justify-content: center;
align-items: center;
z-index: 100001;
}
.dialog {
width: 720px;
max-height: 70%;
display: none;
opacity: 0;
z-index: 100100;
position: fixed;
margin: 0;
padding: 0;
}
.dialog.open {
opacity: 1;
display: block;
transition: opacity 0.2s ease-in;
}
.dialog > * {
box-sizing: border-box;
}
.dialog > .titlebar {
background-color: white;
min-height: 24px;
position: relative;
}
.dialog-title {
padding: 10px;
text-transform: uppercase;
background: #ff7bac;
color: #ffffff;
margin: 0;
font-size: 1.5em;
text-align: center;
}
.dialog-close {
background: #ff7bac;
color: #ffffff;
font-style: normal;
font-weight: 400;
font-variant: normal;
text-transform: none;
line-height: 1;
user-select: none;
cursor: pointer;
font-size: 120%;
margin: 0;
padding: 0;
width: 3.6em;
height: 92%;
border: 1px solid transparent;
transition-duration: 0.2s;
display: block;
position: absolute;
right: 0;
top: 0;
white-space: nowrap;
}
.dialog > .body {
background-color: white;
border: 1px solid rgb(255 125 175 / 80%);
text-align: left;
line-height: 1.5;
padding: 1em;
overflow: auto;
min-width: 280px;
height: calc(100% - 2.1em);
max-height: 900px;
}
`, ""]);
// Exports
/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (___CSS_LOADER_EXPORT___);
/***/ }),
/***/ "./src/ui/progress.css":
/***/ ((module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ A: () => (__WEBPACK_DEFAULT_EXPORT__)
/* harmony export */ });
/* harmony import */ var _node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./node_modules/css-loader/dist/runtime/noSourceMaps.js");
/* harmony import */ var _node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./node_modules/css-loader/dist/runtime/api.js");
/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__);
// Imports
var ___CSS_LOADER_EXPORT___ = _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default()((_node_modules_css_loader_dist_runtime_noSourceMaps_js__WEBPACK_IMPORTED_MODULE_0___default()));
// Module
___CSS_LOADER_EXPORT___.push([module.id, `#nd-progress {
position: fixed;
bottom: 8%;
right: 3%;
z-index: 2147483647;
border-style: none;
text-align: center;
vertical-align: baseline;
background-color: rgba(210, 210, 210, 0.2);
padding: 6px;
border-radius: 12px;
}
#chapter-progress {
--color: green;
--position: 0%;
width: 200px;
height: 10px;
border-radius: 30px;
background-color: #ccc;
background-image: radial-gradient(
closest-side circle at var(--position),
var(--color),
var(--color) 100%,
transparent
),
linear-gradient(var(--color), var(--color));
background-image: -webkit-radial-gradient(
var(--position),
circle closest-side,
var(--color),
var(--color) 100%,
transparent
),
-webkit-linear-gradient(var(--color), var(--color));
background-size: 100%, var(--position);
background-repeat: no-repeat;
}
#zip-progress {
--color: yellow;
--position: 0%;
width: 200px;
height: 10px;
border-radius: 30px;
background-color: #ccc;
background-image: radial-gradient(
closest-side circle at var(--position),
var(--color),
var(--color) 100%,
transparent
),
linear-gradient(var(--color), var(--color));
background-image: -webkit-radial-gradient(
var(--position),
circle closest-side,
var(--color),
var(--color) 100%,
transparent
),
-webkit-linear-gradient(var(--color), var(--color));
background-size: 100%, var(--position);
background-repeat: no-repeat;
margin-top: 5px;
}
`, ""]);
// Exports
/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (___CSS_LOADER_EXPORT___);
/***/ }),
/***/ "./node_modules/css-loader/dist/runtime/api.js":
/***/ ((module) => {
"use strict";
/*
MIT License http://www.opensource.org/licenses/mit-license.php
Author Tobias Koppers @sokra
*/
module.exports = function (cssWithMappingToString) {
var list = [];
// return the list of modules as css string
list.toString = function toString() {
return this.map(function (item) {
var content = "";
var needLayer = typeof item[5] !== "undefined";
if (item[4]) {
content += "@supports (".concat(item[4], ") {");
}
if (item[2]) {
content += "@media ".concat(item[2], " {");
}
if (needLayer) {
content += "@layer".concat(item[5].length > 0 ? " ".concat(item[5]) : "", " {");
}
content += cssWithMappingToString(item);
if (needLayer) {
content += "}";
}
if (item[2]) {
content += "}";
}
if (item[4]) {
content += "}";
}
return content;
}).join("");
};
// import a list of modules into the list
list.i = function i(modules, media, dedupe, supports, layer) {
if (typeof modules === "string") {
modules = [[null, modules, undefined]];
}
var alreadyImportedModules = {};
if (dedupe) {
for (var k = 0; k < this.length; k++) {
var id = this[k][0];
if (id != null) {
alreadyImportedModules[id] = true;
}
}
}
for (var _k = 0; _k < modules.length; _k++) {
var item = [].concat(modules[_k]);
if (dedupe && alreadyImportedModules[item[0]]) {
continue;
}
if (typeof layer !== "undefined") {
if (typeof item[5] === "undefined") {
item[5] = layer;
} else {
item[1] = "@layer".concat(item[5].length > 0 ? " ".concat(item[5]) : "", " {").concat(item[1], "}");
item[5] = layer;
}
}
if (media) {
if (!item[2]) {
item[2] = media;
} else {
item[1] = "@media ".concat(item[2], " {").concat(item[1], "}");
item[2] = media;
}
}
if (supports) {
if (!item[4]) {
item[4] = "".concat(supports);
} else {
item[1] = "@supports (".concat(item[4], ") {").concat(item[1], "}");
item[4] = supports;
}
}
list.push(item);
}
};
return list;
};
/***/ }),
/***/ "./node_modules/css-loader/dist/runtime/noSourceMaps.js":
/***/ ((module) => {
"use strict";
module.exports = function (i) {
return i[1];
};
/***/ }),
/***/ "./node_modules/file-saver/dist/FileSaver.min.js":
/***/ (function(module, exports, __webpack_require__) {
var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;(function(a,b){if(true)!(__WEBPACK_AMD_DEFINE_ARRAY__ = [], __WEBPACK_AMD_DEFINE_FACTORY__ = (b),
__WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ?
(__WEBPACK_AMD_DEFINE_FACTORY__.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__)) : __WEBPACK_AMD_DEFINE_FACTORY__),
__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));else {}})(this,function(){"use strict";function b(a,b){return"undefined"==typeof b?b={autoBom:!1}:"object"!=typeof b&&(console.warn("Deprecated: Expected third argument to be a object"),b={autoBom:!b}),b.autoBom&&/^\s*(?:text\/\S*|application\/xml|\S*\/\S*\+xml)\s*;.*charset\s*=\s*utf-8/i.test(a.type)?new Blob(["\uFEFF",a],{type:a.type}):a}function c(a,b,c){var d=new XMLHttpRequest;d.open("GET",a),d.responseType="blob",d.onload=function(){g(d.response,b,c)},d.onerror=function(){console.error("could not download file")},d.send()}function d(a){var b=new XMLHttpRequest;b.open("HEAD",a,!1);try{b.send()}catch(a){}return 200<=b.status&&299>=b.status}function e(a){try{a.dispatchEvent(new MouseEvent("click"))}catch(c){var b=document.createEvent("MouseEvents");b.initMouseEvent("click",!0,!0,window,0,0,0,80,20,!1,!1,!1,!1,0,null),a.dispatchEvent(b)}}var f="object"==typeof window&&window.window===window?window:"object"==typeof self&&self.self===self?self:"object"==typeof __webpack_require__.g&&__webpack_require__.g.global===__webpack_require__.g?__webpack_require__.g:void 0,a=f.navigator&&/Macintosh/.test(navigator.userAgent)&&/AppleWebKit/.test(navigator.userAgent)&&!/Safari/.test(navigator.userAgent),g=f.saveAs||("object"!=typeof window||window!==f?function(){}:"download"in HTMLAnchorElement.prototype&&!a?function(b,g,h){var i=f.URL||f.webkitURL,j=document.createElement("a");g=g||b.name||"download",j.download=g,j.rel="noopener","string"==typeof b?(j.href=b,j.origin===location.origin?e(j):d(j.href)?c(b,g,h):e(j,j.target="_blank")):(j.href=i.createObjectURL(b),setTimeout(function(){i.revokeObjectURL(j.href)},4E4),setTimeout(function(){e(j)},0))}:"msSaveOrOpenBlob"in navigator?function(f,g,h){if(g=g||f.name||"download","string"!=typeof f)navigator.msSaveOrOpenBlob(b(f,h),g);else if(d(f))c(f,g,h);else{var i=document.createElement("a");i.href=f,i.target="_blank",setTimeout(function(){e(i)})}}:function(b,d,e,g){if(g=g||open("","_blank"),g&&(g.document.title=g.document.body.innerText="downloading..."),"string"==typeof b)return c(b,d,e);var h="application/octet-stream"===b.type,i=/constructor/i.test(f.HTMLElement)||f.safari,j=/CriOS\/[\d]+/.test(navigator.userAgent);if((j||h&&i||a)&&"undefined"!=typeof FileReader){var k=new FileReader;k.onloadend=function(){var a=k.result;a=j?a:a.replace(/^data:[^;]*;/,"data:attachment/file;"),g?g.location.href=a:location=a,g=null},k.readAsDataURL(b)}else{var l=f.URL||f.webkitURL,m=l.createObjectURL(b);g?g.location=m:location.href=m,g=null,setTimeout(function(){l.revokeObjectURL(m)},4E4)}});f.saveAs=g.saveAs=g, true&&(module.exports=g)});
//# sourceMappingURL=FileSaver.min.js.map
/***/ }),
/***/ "./node_modules/loglevel/lib/loglevel.js":
/***/ (function(module, exports, __webpack_require__) {
var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_RESULT__;/*
* loglevel - https://github.com/pimterry/loglevel
*
* Copyright (c) 2013 Tim Perry
* Licensed under the MIT license.
*/
(function (root, definition) {
"use strict";
if (true) {
!(__WEBPACK_AMD_DEFINE_FACTORY__ = (definition),
__WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ?
(__WEBPACK_AMD_DEFINE_FACTORY__.call(exports, __webpack_require__, exports, module)) :
__WEBPACK_AMD_DEFINE_FACTORY__),
__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));
} else {}
}(this, function () {
"use strict";
// Slightly dubious tricks to cut down minimized file size
var noop = function() {};
var undefinedType = "undefined";
var isIE = (typeof window !== undefinedType) && (typeof window.navigator !== undefinedType) && (
/Trident\/|MSIE /.test(window.navigator.userAgent)
);
var logMethods = [
"trace",
"debug",
"info",
"warn",
"error"
];
var _loggersByName = {};
var defaultLogger = null;
// Cross-browser bind equivalent that works at least back to IE6
function bindMethod(obj, methodName) {
var method = obj[methodName];
if (typeof method.bind === 'function') {
return method.bind(obj);
} else {
try {
return Function.prototype.bind.call(method, obj);
} catch (e) {
// Missing bind shim or IE8 + Modernizr, fallback to wrapping
return function() {
return Function.prototype.apply.apply(method, [obj, arguments]);
};
}
}
}
// Trace() doesn't print the message in IE, so for that case we need to wrap it
function traceForIE() {
if (console.log) {
if (console.log.apply) {
console.log.apply(console, arguments);
} else {
// In old IE, native console methods themselves don't have apply().
Function.prototype.apply.apply(console.log, [console, arguments]);
}
}
if (console.trace) console.trace();
}
// Build the best logging method possible for this env
// Wherever possible we want to bind, not wrap, to preserve stack traces
function realMethod(methodName) {
if (methodName === 'debug') {
methodName = 'log';
}
if (typeof console === undefinedType) {
return false; // No method possible, for now - fixed later by enableLoggingWhenConsoleArrives
} else if (methodName === 'trace' && isIE) {
return traceForIE;
} else if (console[methodName] !== undefined) {
return bindMethod(console, methodName);
} else if (console.log !== undefined) {
return bindMethod(console, 'log');
} else {
return noop;
}
}
// These private functions always need `this` to be set properly
function replaceLoggingMethods() {
/*jshint validthis:true */
var level = this.getLevel();
// Replace the actual methods.
for (var i = 0; i < logMethods.length; i++) {
var methodName = logMethods[i];
this[methodName] = (i < level) ?
noop :
this.methodFactory(methodName, level, this.name);
}
// Define log.log as an alias for log.debug
this.log = this.debug;
// Return any important warnings.
if (typeof console === undefinedType && level < this.levels.SILENT) {
return "No console available for logging";
}
}
// In old IE versions, the console isn't present until you first open it.
// We build realMethod() replacements here that regenerate logging methods
function enableLoggingWhenConsoleArrives(methodName) {
return function () {
if (typeof console !== undefinedType) {
replaceLoggingMethods.call(this);
this[methodName].apply(this, arguments);
}
};
}
// By default, we use closely bound real methods wherever possible, and
// otherwise we wait for a console to appear, and then try again.
function defaultMethodFactory(methodName, _level, _loggerName) {
/*jshint validthis:true */
return realMethod(methodName) ||
enableLoggingWhenConsoleArrives.apply(this, arguments);
}
function Logger(name, factory) {
// Private instance variables.
var self = this;
/**
* The level inherited from a parent logger (or a global default). We
* cache this here rather than delegating to the parent so that it stays
* in sync with the actual logging methods that we have installed (the
* parent could change levels but we might not have rebuilt the loggers
* in this child yet).
* @type {number}
*/
var inheritedLevel;
/**
* The default level for this logger, if any. If set, this overrides
* `inheritedLevel`.
* @type {number|null}
*/
var defaultLevel;
/**
* A user-specific level for this logger. If set, this overrides
* `defaultLevel`.
* @type {number|null}
*/
var userLevel;
var storageKey = "loglevel";
if (typeof name === "string") {
storageKey += ":" + name;
} else if (typeof name === "symbol") {
storageKey = undefined;
}
function persistLevelIfPossible(levelNum) {
var levelName = (logMethods[levelNum] || 'silent').toUpperCase();
if (typeof window === undefinedType || !storageKey) return;
// Use localStorage if available
try {
window.localStorage[storageKey] = levelName;
return;
} catch (ignore) {}
// Use session cookie as fallback
try {
window.document.cookie =
encodeURIComponent(storageKey) + "=" + levelName + ";";
} catch (ignore) {}
}
function getPersistedLevel() {
var storedLevel;
if (typeof window === undefinedType || !storageKey) return;
try {
storedLevel = window.localStorage[storageKey];
} catch (ignore) {}
// Fallback to cookies if local storage gives us nothing
if (typeof storedLevel === undefinedType) {
try {
var cookie = window.document.cookie;
var cookieName = encodeURIComponent(storageKey);
var location = cookie.indexOf(cookieName + "=");
if (location !== -1) {
storedLevel = /^([^;]+)/.exec(
cookie.slice(location + cookieName.length + 1)
)[1];
}
} catch (ignore) {}
}
// If the stored level is not valid, treat it as if nothing was stored.
if (self.levels[storedLevel] === undefined) {
storedLevel = undefined;
}
return storedLevel;
}
function clearPersistedLevel() {
if (typeof window === undefinedType || !storageKey) return;
// Use localStorage if available
try {
window.localStorage.removeItem(storageKey);
} catch (ignore) {}
// Use session cookie as fallback
try {
window.document.cookie =
encodeURIComponent(storageKey) + "=; expires=Thu, 01 Jan 1970 00:00:00 UTC";
} catch (ignore) {}
}
function normalizeLevel(input) {
var level = input;
if (typeof level === "string" && self.levels[level.toUpperCase()] !== undefined) {
level = self.levels[level.toUpperCase()];
}
if (typeof level === "number" && level >= 0 && level <= self.levels.SILENT) {
return level;
} else {
throw new TypeError("log.setLevel() called with invalid level: " + input);
}
}
/*
*
* Public logger API - see https://github.com/pimterry/loglevel for details
*
*/
self.name = name;
self.levels = { "TRACE": 0, "DEBUG": 1, "INFO": 2, "WARN": 3,
"ERROR": 4, "SILENT": 5};
self.methodFactory = factory || defaultMethodFactory;
self.getLevel = function () {
if (userLevel != null) {
return userLevel;
} else if (defaultLevel != null) {
return defaultLevel;
} else {
return inheritedLevel;
}
};
self.setLevel = function (level, persist) {
userLevel = normalizeLevel(level);
if (persist !== false) { // defaults to true
persistLevelIfPossible(userLevel);
}
// NOTE: in v2, this should call rebuild(), which updates children.
return replaceLoggingMethods.call(self);
};
self.setDefaultLevel = function (level) {
defaultLevel = normalizeLevel(level);
if (!getPersistedLevel()) {
self.setLevel(level, false);
}
};
self.resetLevel = function () {
userLevel = null;
clearPersistedLevel();
replaceLoggingMethods.call(self);
};
self.enableAll = function(persist) {
self.setLevel(self.levels.TRACE, persist);
};
self.disableAll = function(persist) {
self.setLevel(self.levels.SILENT, persist);
};
self.rebuild = function () {
if (defaultLogger !== self) {
inheritedLevel = normalizeLevel(defaultLogger.getLevel());
}
replaceLoggingMethods.call(self);
if (defaultLogger === self) {
for (var childName in _loggersByName) {
_loggersByName[childName].rebuild();
}
}
};
// Initialize all the internal levels.
inheritedLevel = normalizeLevel(
defaultLogger ? defaultLogger.getLevel() : "WARN"
);
var initialLevel = getPersistedLevel();
if (initialLevel != null) {
userLevel = normalizeLevel(initialLevel);
}
replaceLoggingMethods.call(self);
}
/*
*
* Top-level API
*
*/
defaultLogger = new Logger();
defaultLogger.getLogger = function getLogger(name) {
if ((typeof name !== "symbol" && typeof name !== "string") || name === "") {
throw new TypeError("You must supply a name when creating a logger.");
}
var logger = _loggersByName[name];
if (!logger) {
logger = _loggersByName[name] = new Logger(
name,
defaultLogger.methodFactory
);
}
return logger;
};
// Grab the current global log variable in case of overwrite
var _log = (typeof window !== undefinedType) ? window.log : undefined;
defaultLogger.noConflict = function() {
if (typeof window !== undefinedType &&
window.log === defaultLogger) {
window.log = _log;
}
return defaultLogger;
};
defaultLogger.getLoggers = function getLoggers() {
return _loggersByName;
};
// ES6 default export, for compatibility
defaultLogger['default'] = defaultLogger;
return defaultLogger;
}));
/***/ }),
/***/ "./node_modules/magic-bytes.js/dist/index.js":
/***/ (function(__unused_webpack_module, exports, __webpack_require__) {
"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.filetypeextension = exports.filetypemime = exports.filetypename = exports.filetypeinfo = void 0;
const pattern_tree_1 = __importDefault(__webpack_require__("./node_modules/magic-bytes.js/dist/model/pattern-tree.js"));
const toHex_1 = __webpack_require__("./node_modules/magic-bytes.js/dist/model/toHex.js");
const patternTree = pattern_tree_1.default();
const filetypeinfo = (bytes) => {
let tree = patternTree;
for (const k of Object.keys(tree.offset)) {
const offset = toHex_1.fromHex(k);
const offsetExceedsFile = offset >= bytes.length;
if (offsetExceedsFile) {
continue;
}
const node = patternTree.offset[k];
const guessed = walkTree(offset, bytes, node);
if (guessed.length > 0) {
return guessed;
}
}
if (tree.noOffset === null) {
return [];
}
return walkTree(0, bytes, tree.noOffset);
};
exports.filetypeinfo = filetypeinfo;
const walkTree = (index, bytes, node) => {
let step = node;
let guessFile = [];
while (true) {
const currentByte = toHex_1.toHex(bytes[index]);
if (step.bytes["?"] && !step.bytes[currentByte]) {
step = step.bytes["?"];
}
else {
step = step.bytes[currentByte];
}
if (!step) {
return guessFile;
}
if (step && step.matches) {
guessFile = step.matches.slice(0);
}
index += 1;
}
};
exports["default"] = exports.filetypeinfo;
const filetypename = (bytes) => exports.filetypeinfo(bytes).map((e) => e.typename);
exports.filetypename = filetypename;
const filetypemime = (bytes) => exports.filetypeinfo(bytes)
.map((e) => (e.mime ? e.mime : null))
.filter((x) => x !== null);
exports.filetypemime = filetypemime;
const filetypeextension = (bytes) => exports.filetypeinfo(bytes)
.map((e) => (e.extension ? e.extension : null))
.filter((x) => x !== null);
exports.filetypeextension = filetypeextension;
/***/ }),
/***/ "./node_modules/magic-bytes.js/dist/model/pattern-tree.js":
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
const toHex_1 = __webpack_require__("./node_modules/magic-bytes.js/dist/model/toHex.js");
const tree_1 = __webpack_require__("./node_modules/magic-bytes.js/dist/model/tree.js");
// https://en.wikipedia.org/wiki/List_of_file_signatures
let tree = {
noOffset: null,
offset: {},
};
const add = (typename, signature, additionalInfo, offset) => {
if (offset) {
const existing = tree.offset[toHex_1.toHex(offset)];
if (!existing) {
tree.offset[toHex_1.toHex(offset)] = tree_1.createComplexNode(typename, signature.map((e) => e.toLowerCase()), additionalInfo);
}
else {
const merged = tree_1.merge(tree_1.createNode(typename, signature.map((e) => e.toLowerCase()), additionalInfo), { ...existing });
tree.offset[toHex_1.toHex(offset)] = merged;
}
}
else {
if (tree.noOffset === null) {
tree.noOffset = tree_1.createComplexNode(typename, signature.map((e) => e.toLowerCase()), additionalInfo);
}
else {
tree.noOffset = tree_1.merge(tree_1.createNode(typename, signature.map((e) => e.toLowerCase()), additionalInfo), tree.noOffset);
}
}
};
add("gif", ["0x47", "0x49", "0x46", "0x38", "0x37", "0x61"], {
mime: "image/gif",
extension: "gif",
});
add("gif", ["0x47", "0x49", "0x46", "0x38", "0x39", "0x61"], {
mime: "image/gif",
extension: "gif",
});
add("jpg", ["0xFF", "0xD8", "0xFF"], {
mime: "image/jpeg",
extension: "jpeg",
});
add("webp", [
"0x52",
"0x49",
"0x46",
"0x46",
"?",
"?",
"?",
"?",
"0x57",
"0x45",
"0x42",
"0x50",
], { mime: "image/webp", extension: "webp" });
add("heif", ["0x66", "0x74", "0x79", "0x70", "0x6D", "0x69", "0x66", "0x31"], { mime: "image/heif", extension: "heif" }, 4);
add("heif", ["0x66", "0x74", "0x79", "0x70", "0x68", "0x65", "0x69", "0x63"], { mime: "image/heif", extension: "heic" }, 4);
add("rpm", ["0xed", "0xab", "0xee", "0xdb"]);
add("bin", ["0x53", "0x50", "0x30", "0x31"], {
mime: "application/octet-stream",
extension: "bin",
});
add("pic", ["0x00"]);
add("pif", ["0x00"]);
add("sea", ["0x00"]);
add("ytr", ["0x00"]);
// 66747970
// 6D703432
add("mp4", ["0x66", "0x74", "0x79", "0x70"], { mime: "video/mp4", extension: "mp4" }, 0x4);
add("ttf", ["0x00", "0x01", "0x00", "0x00", "0x00"], {
mime: "font/ttf",
extension: "ttf",
});
add("otf", ["0x4F", "0x54", "0x54", "0x4F"], {
mime: "font/otf",
extension: "otf",
});
add("eot", ["0x50", "0x4C"], {
mime: "application/vnd.ms-fontobject",
extension: "eot",
});
add("woff", ["0x77", "0x4F", "0x46", "0x46"], {
mime: "font/woff",
extension: "woff",
});
add("woff2", ["0x77", "0x4F", "0x46", "0x32"], {
mime: "font/woff2",
extension: "woff2",
});
add("pdb", [
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
]);
add("dba", ["0xBE", "0xBA", "0xFE", "0xCA"]);
add("dba2", ["0x00", "0x01", "0x42", "0x44"]);
add("tda", ["0x00", "0x01", "0x44", "0x54"]);
add("tda2", ["0x00", "0x01", "0x00", "0x00"]);
add("ico", ["0x00", "0x00", "0x01", "0x00"], {
mime: "image/x-icon",
extension: "ico",
});
add("3gp", ["0x66", "0x74", "0x79", "0x70", "0x33", "0x67"]);
add("z", ["0x1F", "0x9D"]);
add("tar.z", ["0x1F", "0xA0"]);
add("bac", [
"0x42",
"0x41",
"0x43",
"0x4B",
"0x4D",
"0x49",
"0x4B",
"0x45",
"0x44",
"0x49",
"0x53",
"0x4B",
]);
add("bz2", ["0x42", "0x5A", "0x68"], {
mime: "application/x-bzip2",
extension: "bz2",
});
add("tif", ["0x49", "0x49", "0x2A", "0x00"], {
mime: "image/tiff",
extension: "tif",
});
add("tiff", ["0x4D", "0x4D", "0x00", "0x2A"], {
mime: "image/tiff",
extension: "tiff",
});
add("cr2", [
"0x49",
"0x49",
"0x2A",
"0x00",
"0x10",
"0x00",
"0x00",
"0x00",
"0x43",
"0x52",
]);
add("cin", ["0x80", "0x2A", "0x5F", "0xD7"]);
add("cin1", ["0x52", "0x4E", "0x43", "0x01"]);
add("cin2", ["0x52", "0x4E", "0x43", "0x02"]);
add("dpx", ["0x53", "0x44", "0x50", "0x58"]);
add("dpx2", ["0x58", "0x50", "0x44", "0x53"]);
add("exr", ["0x76", "0x2F", "0x31", "0x01"]);
add("bpg", ["0x42", "0x50", "0x47", "0xFB"]);
add("ilbm", [
"0x46",
"0x4F",
"0x52",
"0x4D",
"?",
"?",
"?",
"?",
"0x49",
"0x4C",
"0x42",
"0x4D",
]);
add("8svx", [
"0x46",
"0x4F",
"0x52",
"0x4D",
"?",
"?",
"?",
"?",
"0x38",
"0x53",
"0x56",
"0x58",
]);
add("acbm", [
"0x46",
"0x4F",
"0x52",
"0x4D",
"?",
"?",
"?",
"?",
"0x41",
"0x43",
"0x42",
"0x4D",
]);
add("anbm", [
"0x46",
"0x4F",
"0x52",
"0x4D",
"?",
"?",
"?",
"?",
"0x41",
"0x4E",
"0x42",
"0x4D",
]);
add("anim", [
"0x46",
"0x4F",
"0x52",
"0x4D",
"?",
"?",
"?",
"?",
"0x41",
"0x4E",
"0x49",
"0x4D",
]);
add("faxx", [
"0x46",
"0x4F",
"0x52",
"0x4D",
"?",
"?",
"?",
"?",
"0x46",
"0x41",
"0x58",
"0x58",
]);
add("ftxt", [
"0x46",
"0x4F",
"0x52",
"0x4D",
"?",
"?",
"?",
"?",
"0x46",
"0x54",
"0x58",
"0x54",
]);
add("smus", [
"0x46",
"0x4F",
"0x52",
"0x4D",
"?",
"?",
"?",
"?",
"0x53",
"0x4D",
"0x55",
"0x53",
]);
add("cmus", [
"0x46",
"0x4F",
"0x52",
"0x4D",
"?",
"?",
"?",
"?",
"0x43",
"0x4D",
"0x55",
"0x53",
]);
add("yuvn", [
"0x46",
"0x4F",
"0x52",
"0x4D",
"?",
"?",
"?",
"?",
"0x59",
"0x55",
"0x56",
"0x4E",
]);
add("iff", [
"0x46",
"0x4F",
"0x52",
"0x4D",
"?",
"?",
"?",
"?",
"0x46",
"0x41",
"0x4E",
"0x54",
]);
add("aiff", [
"0x46",
"0x4F",
"0x52",
"0x4D",
"?",
"?",
"?",
"?",
"0x41",
"0x49",
"0x46",
"0x46",
], { mime: "audio/x-aiff", extension: "aiff" });
add("idx", ["0x49", "0x4E", "0x44", "0x58"]);
add("lz", ["0x4C", "0x5A", "0x49", "0x50"]);
add("exe", ["0x4D", "0x5A"]);
add("zip", ["0x50", "0x4B", "0x03", "0x04"], {
mime: "application/zip",
extension: "zip",
});
add("zip", ["0x50", "0x4B", "0x05", "0x06"], {
mime: "application/zip",
extension: "zip",
});
add("zip", ["0x50", "0x4B", "0x07", "0x08"], {
mime: "application/zip",
extension: "zip",
});
add("jar", ["0x50", "0x4B", "0x03", "0x04"], {
mime: "application/java-archive",
extension: "jar",
});
add("jar", ["0x50", "0x4B", "0x05", "0x06"], {
mime: "application/java-archive",
extension: "jar",
});
add("jar", ["0x50", "0x4B", "0x07", "0x08"], {
mime: "application/java-archive",
extension: "jar",
});
add("odt", ["0x50", "0x4B", "0x03", "0x04"], {
mime: "application/vnd.oasis.opendocument.text",
extension: "odt",
});
add("odt", ["0x50", "0x4B", "0x05", "0x06"], {
mime: "application/vnd.oasis.opendocument.text",
extension: "odt",
});
add("odt", ["0x50", "0x4B", "0x07", "0x08"], {
mime: "application/vnd.oasis.opendocument.text",
extension: "odt",
});
add("ods", ["0x50", "0x4B", "0x03", "0x04"], {
mime: "application/vnd.oasis.opendocument.spreadsheet",
extension: "ods",
});
add("ods", ["0x50", "0x4B", "0x05", "0x06"], {
mime: "application/vnd.oasis.opendocument.spreadsheet",
extension: "ods",
});
add("ods", ["0x50", "0x4B", "0x07", "0x08"], {
mime: "application/vnd.oasis.opendocument.spreadsheet",
extension: "ods",
});
add("odp", ["0x50", "0x4B", "0x03", "0x04"], {
mime: "application/vnd.oasis.opendocument.presentation",
extension: "odp",
});
add("odp", ["0x50", "0x4B", "0x05", "0x06"], {
mime: "application/vnd.oasis.opendocument.presentation",
extension: "odp",
});
add("odp", ["0x50", "0x4B", "0x07", "0x08"], {
mime: "application/vnd.oasis.opendocument.presentation",
extension: "odp",
});
add("docx", ["0x50", "0x4B", "0x03", "0x04"], {
mime: "application/vnd.openxmlformats-officedocument.wordprocessingml.document",
extension: "docx",
});
add("docx", ["0x50", "0x4B", "0x05", "0x06"], {
mime: "application/vnd.openxmlformats-officedocument.wordprocessingml.document",
extension: "docx",
});
add("docx", ["0x50", "0x4B", "0x07", "0x08"], {
mime: "application/vnd.openxmlformats-officedocument.wordprocessingml.document",
extension: "docx",
});
add("xlsx", ["0x50", "0x4B", "0x03", "0x04"], {
mime: "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",
extension: "xlsx",
});
add("xlsx", ["0x50", "0x4B", "0x05", "0x06"], {
mime: "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",
extension: "xlsx",
});
add("xlsx", ["0x50", "0x4B", "0x07", "0x08"], {
mime: "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",
extension: "xlsx",
});
add("pptx", ["0x50", "0x4B", "0x03", "0x04"], {
mime: "application/vnd.openxmlformats-officedocument.presentationml.presentation",
extension: "pptx",
});
add("pptx", ["0x50", "0x4B", "0x05", "0x06"], {
mime: "application/vnd.openxmlformats-officedocument.presentationml.presentation",
extension: "pptx",
});
add("pptx", ["0x50", "0x4B", "0x07", "0x08"], {
mime: "application/vnd.openxmlformats-officedocument.presentationml.presentation",
extension: "pptx",
});
add("vsdx", ["0x50", "0x4B", "0x03", "0x04"], {
mime: "application/vnd.ms-visio.drawing",
extension: "vsdx",
});
add("vsdx", ["0x50", "0x4B", "0x05", "0x06"], {
mime: "application/vnd.ms-visio.drawing",
extension: "vsdx",
});
add("vsdx", ["0x50", "0x4B", "0x07", "0x08"], {
mime: "application/vnd.ms-visio.drawing",
extension: "vsdx",
});
add("apk", ["0x50", "0x4B", "0x03", "0x04"], {
mime: "application/vnd.android.package-archive",
extension: "apk",
});
add("apk", ["0x50", "0x4B", "0x05", "0x06"], {
mime: "application/vnd.android.package-archive",
extension: "apk",
});
add("apk", ["0x50", "0x4B", "0x07", "0x08"], {
mime: "application/vnd.android.package-archive",
extension: "apk",
});
add("aar", ["0x50", "0x4B", "0x03", "0x04"], {
mime: "application/vnd.android.package-archive",
extension: "aar",
});
add("aar", ["0x50", "0x4B", "0x05", "0x06"], {
mime: "application/vnd.android.package-archive",
extension: "aar",
});
add("aar", ["0x50", "0x4B", "0x07", "0x08"], {
mime: "application/vnd.android.package-archive",
extension: "aar",
});
add("rar", ["0x52", "0x61", "0x72", "0x21", "0x1A", "0x07", "0x00"], {
mime: "application/vnd.rar",
extension: "rar",
});
add("rar", ["0x52", "0x61", "0x72", "0x21", "0x1A", "0x07", "0x01", "0x00"], {
mime: "application/vnd.rar",
extension: "rar",
});
add("rar", ["0x7F", "0x45", "0x4C", "0x46"], {
mime: "application/vnd.rar",
extension: "rar",
});
add("png", ["0x89", "0x50", "0x4E", "0x47", "0x0D", "0x0A", "0x1A", "0x0A"], {
mime: "image/png",
extension: "png",
});
add("apng", ["0x89", "0x50", "0x4E", "0x47", "0x0D", "0x0A", "0x1A", "0x0A"], {
mime: "image/apng",
extension: "apng",
});
add("class", ["0xCA", "0xFE", "0xBA", "0xBE"]);
add("class", ["0xEF", "0xBB", "0xBF"]);
add("class", ["0xFE", "0xed", "0xFA", "0xCE"], undefined, 0x1000);
add("class", ["0xFE", "0xed", "0xFA", "0xCF"], undefined, 0x1000);
add("class", ["0xCE", "0xFA", "0xed", "0xFE"]);
add("class", ["0xCF", "0xFA", "0xed", "0xFE"]);
add("class", ["0xFF", "0xFE"]);
add("class", ["0xFF", "0xFE"]);
add("class", ["0xFF", "0xFE", "0x00", "0x00"]);
add("ps", ["0x25", "0x21", "0x50", "0x53"], {
mime: "application/postscript",
extension: ".ps"
});
add("pdf", ["0x25", "0x50", "0x44", "0x46"], {
mime: "application/pdf",
extension: "pdf",
});
add("asf", [
"0x30",
"0x26",
"0xB2",
"0x75",
"0x8E",
"0x66",
"0xCF",
"0x11",
"0xA6",
"0xD9",
"0x00",
"0xAA",
"0x00",
"0x62",
"0xCE",
"0x6C",
]);
add("wma", [
"0x30",
"0x26",
"0xB2",
"0x75",
"0x8E",
"0x66",
"0xCF",
"0x11",
"0xA6",
"0xD9",
"0x00",
"0xAA",
"0x00",
"0x62",
"0xCE",
"0x6C",
]);
add("wmv", [
"0x30",
"0x26",
"0xB2",
"0x75",
"0x8E",
"0x66",
"0xCF",
"0x11",
"0xA6",
"0xD9",
"0x00",
"0xAA",
"0x00",
"0x62",
"0xCE",
"0x6C",
]);
add("deploymentimage", [
"0x24",
"0x53",
"0x44",
"0x49",
"0x30",
"0x30",
"0x30",
"0x31",
]);
// ogg video ' theora'
add("ogv", [
"0x4F",
"0x67",
"0x67",
"0x53",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"0x80",
"0x74",
"0x68",
"0x65",
"0x6F",
"0x72",
"0x61",
], {
mime: "video/ogg",
extension: "ogv",
});
// ogg video '\x01video'
add("ogm", [
"0x4F",
"0x67",
"0x67",
"0x53",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"0x01",
"0x76",
"0x69",
"0x64",
"0x65",
"0x6F",
"0x00",
], {
mime: "video/ogg",
extension: "ogm",
});
// ogg audio ' FLAC'
add("oga", [
"0x4F",
"0x67",
"0x67",
"0x53",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"0x7F",
"0x46",
"0x4C",
"0x41",
"0x43",
], {
mime: "audio/ogg",
extension: "oga",
});
// ogg audio 'Speex '
add("spx", [
"0x4F",
"0x67",
"0x67",
"0x53",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"0x53",
"0x70",
"0x65",
"0x65",
"0x78",
"0x20",
"0x20",
], {
mime: "audio/ogg",
extension: "spx",
});
// ogg audio '\x01vorbis '
add("ogg", [
"0x4F",
"0x67",
"0x67",
"0x53",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"?",
"0x01",
"0x76",
"0x6F",
"0x72",
"0x62",
"0x69",
"0x73",
], {
mime: "audio/ogg",
extension: "ogg",
});
// default OGG container
add("ogx", ["0x4F", "0x67", "0x67", "0x53"], {
mime: "application/ogg",
extension: "ogx",
});
add("psd", ["0x38", "0x42", "0x50", "0x53"], {
mime: "application/x-photoshop",
extension: "psd",
});
add("clip", ["0x43", "0x53", "0x46", "0x43", "0x48", "0x55", "0x4e", "0x4b"]);
add("wav", [
"0x52",
"0x49",
"0x46",
"0x46",
"?",
"?",
"?",
"?",
"0x57",
"0x41",
"0x56",
"0x45",
], { mime: "audio/x-wav", extension: "wav" });
add("avi", [
"0x52",
"0x49",
"0x46",
"0x46",
"?",
"?",
"?",
"?",
"0x41",
"0x56",
"0x49",
"0x20",
], { mime: "video/x-msvideo", extension: "avi" });
add("mp3", ["0xFF", "0xFB"], { mime: "audio/mpeg", extension: "mp3" });
add("mp3", ["0xFF", "0xF3"], { mime: "audio/mpeg", extension: "mp3" });
add("mp3", ["0xFF", "0xF2"], { mime: "audio/mpeg", extension: "mp3" });
add("mp3", ["0x49", "0x44", "0x33"], { mime: "audio/mpeg", extension: "mp3" });
add("bmp", ["0x42", "0x4D"], { mime: "image/bmp", extension: "bmp" });
add("iso", ["0x43", "0x44", "0x30", "0x30", "0x31"]);
add("flac", ["0x66", "0x4C", "0x61", "0x43"]);
add("mid", ["0x4D", "0x54", "0x68", "0x64"], {
mime: "audio/midi",
extension: "mid",
});
add("midi", ["0x4D", "0x54", "0x68", "0x64"], {
mime: "audio/midi",
extension: "midi",
});
add("doc", ["0xD0", "0xCF", "0x11", "0xE0", "0xA1", "0xB1", "0x1A", "0xE1"], {
mime: "application/msword",
extension: "doc",
});
add("xls", ["0xD0", "0xCF", "0x11", "0xE0", "0xA1", "0xB1", "0x1A", "0xE1"], {
mime: "application/vnd.ms-excel",
extension: "xls",
});
add("ppt", ["0xD0", "0xCF", "0x11", "0xE0", "0xA1", "0xB1", "0x1A", "0xE1"], {
mime: "application/vnd.ms-powerpoint",
extension: "ppt",
});
add("msg", ["0xD0", "0xCF", "0x11", "0xE0", "0xA1", "0xB1", "0x1A", "0xE1"]);
add("dex", ["0x64", "0x65", "0x78", "0x0A", "0x30", "0x33", "0x35", "0x00"]);
add("vmdk", ["0x4B", "0x44", "0x4D"]);
add("crx", ["0x43", "0x72", "0x32", "0x34"]);
add("fh8", ["0x41", "0x47", "0x44", "0x33"]);
add("cwk", [
"0x05",
"0x07",
"0x00",
"0x00",
"0x42",
"0x4F",
"0x42",
"0x4F",
"0x05",
"0x07",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x01",
]);
add("cwk", [
"0x06",
"0x07",
"0xE1",
"0x00",
"0x42",
"0x4F",
"0x42",
"0x4F",
"0x06",
"0x07",
"0xE1",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x00",
"0x01",
]);
add("toast", ["0x45", "0x52", "0x02", "0x00", "0x00", "0x00"]);
add("toast", ["0x8B", "0x45", "0x52", "0x02", "0x00", "0x00", "0x00"]);
add("dmg", ["0x78", "0x01", "0x73", "0x0D", "0x62", "0x62", "0x60"]);
add("xar", ["0x78", "0x61", "0x72", "0x21"]);
add("dat", ["0x50", "0x4D", "0x4F", "0x43", "0x43", "0x4D", "0x4F", "0x43"]);
add("nes", ["0x4E", "0x45", "0x53", "0x1A"]);
add("tar", ["0x75", "0x73", "0x74", "0x61", "0x72", "0x00", "0x30", "0x30"], {
// As per Mozilla documentation available at:
// https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/MIME_types/Common_types
// or wikipedia page:
// https://en.wikipedia.org/wiki/List_of_archive_formats
mime: "application/x-tar",
extension: "tar"
}, 0x101);
add("tar", ["0x75", "0x73", "0x74", "0x61", "0x72", "0x20", "0x20", "0x00"], {
mime: "application/x-tar",
extension: "tar"
}, 0x101);
add("tox", ["0x74", "0x6F", "0x78", "0x33"]);
add("mlv", ["0x4D", "0x4C", "0x56", "0x49"]);
add("windowsupdate", [
"0x44",
"0x43",
"0x4D",
"0x01",
"0x50",
"0x41",
"0x33",
"0x30",
]);
add("7z", ["0x37", "0x7A", "0xBC", "0xAF", "0x27", "0x1C"], {
mime: "application/x-7z-compressed",
extension: "7z",
});
add("gz", ["0x1F", "0x8B"], { mime: "application/gzip", extension: "gz" });
add("tar.gz", ["0x1F", "0x8B"], {
mime: "application/gzip",
extension: "tar.gz",
});
add("xz", ["0xFD", "0x37", "0x7A", "0x58", "0x5A", "0x00", "0x00"], {
mime: "application/gzip",
extension: "xz",
});
add("tar.xz", ["0xFD", "0x37", "0x7A", "0x58", "0x5A", "0x00", "0x00"], {
mime: "application/gzip",
extension: "tar.xz",
});
add("lz2", ["0x04", "0x22", "0x4D", "0x18"]);
add("cab", ["0x4D", "0x53", "0x43", "0x46"]);
add("mkv", ["0x1A", "0x45", "0xDF", "0xA3"], {
mime: "video/x-matroska",
extension: "mkv",
});
add("mka", ["0x1A", "0x45", "0xDF", "0xA3"], {
mime: "audio/x-matroska",
extension: "mka",
});
add("mks", ["0x1A", "0x45", "0xDF", "0xA3"], {
mime: "video/x-matroska",
extension: "mks",
});
add("mk3d", ["0x1A", "0x45", "0xDF", "0xA3"]);
add("webm", ["0x1A", "0x45", "0xDF", "0xA3"], {
mime: "audio/webm",
extension: "webm",
});
add("dcm", ["0x44", "0x49", "0x43", "0x4D"], undefined, 0x80);
add("xml", ["0x3C", "0x3f", "0x78", "0x6d", "0x6C", "0x20"], {
mime: "application/xml",
extension: "xml",
});
add("wasm", ["0x00", "0x61", "0x73", "0x6d"], {
mime: "application/wasm",
extension: "wasm",
});
add("lep", ["0xCF", "0x84", "0x01"]);
add("swf", ["0x43", "0x57", "0x53"], {
mime: "application/x-shockwave-flash",
extension: "swf",
});
add("swf", ["0x46", "0x57", "0x53"], {
mime: "application/x-shockwave-flash",
extension: "swf",
});
add("deb", ["0x21", "0x3C", "0x61", "0x72", "0x63", "0x68", "0x3E"]);
add("rtf", ["0x7B", "0x5C", "0x72", "0x74", "0x66", "0x31"], {
mime: "application/rtf",
extension: "rtf",
});
add("m2p", ["0x00", "0x00", "0x01", "0xBA"]);
add("vob", ["0x00", "0x00", "0x01", "0xBA"]);
add("mpg", ["0x00", "0x00", "0x01", "0xBA"], {
mime: "video/mpeg",
extension: "mpg",
});
add("mpeg", ["0x00", "0x00", "0x01", "0xBA"], {
mime: "video/mpeg",
extension: "mpeg",
});
add("mpeg", ["0x47"], { mime: "video/mpeg", extension: "mpeg" });
add("mpeg", ["0x00", "0x00", "0x01", "0xB3"], {
mime: "video/mpeg",
extension: "mpeg",
});
// mov 'free' TODO: find test file
add("mov", ["0x66", "0x72", "0x65", "0x65"], {
mime: "video/quicktime",
extension: "mov",
}, 0x4);
// mov 'mdat'
add("mov", ["0x6D", "0x64", "0x61", "0x74"], {
mime: "video/quicktime",
extension: "mov",
}, 0x4);
// mov 'moov' TODO: find test file
add("mov", ["0x6D", "0x6F", "0x6F", "0x76"], {
mime: "video/quicktime",
extension: "mov",
}, 0x4);
// move 'wide' TODO: find test file
add("mov", ["0x77", "0x69", "0x64", "0x65"], {
mime: "video/quicktime",
extension: "mov",
}, 0x4);
// mov 'ftypqt'
add("mov", ["0x66", "0x74", "0x79", "0x70", "0x71", "0x74"], {
mime: "video/quicktime",
extension: "mov",
}, 0x4);
add("hl2demo", ["0x48", "0x4C", "0x32", "0x44", "0x45", "0x4D", "0x4F"]);
add("txt", ["0xEF", "0xBB", "0xBF"], {
mime: "text/plain; charset=UTF-8",
extension: "txt",
});
add("txt", ["0xFF", "0xFE"], {
mime: "text/plain; charset=UTF-16LE",
extension: "txt",
});
add("txt", ["0xFE", "0xFF"], {
mime: "text/plain; charset=UTF-16BE",
extension: "txt",
});
add("txt", ["0xFF", "0xFE", "0x00", "0x00"], {
mime: "text/plain; charset=UTF-32LE",
extension: "txt",
});
add("txt", ["0x00", "0x00", "0xFE", "0xFF"], {
mime: "text/plain; charset=UTF-32BE",
extension: "txt",
});
add("SubRip", ["0x31", "0x0D", "0x0A", "0x30", "0x30", "0x3A"], {
mime: "application/x-subrip",
extension: "srt",
});
add("WebVTT", [
"0xEF",
"0xBB",
"0xBF",
"0x57",
"0x45",
"0x42",
"0x56",
"0x54",
"0x54",
"0x0A",
], {
mime: "text/vtt",
extension: "vtt",
});
add("WebVTT", [
"0xEF",
"0xBB",
"0xBF",
"0x57",
"0x45",
"0x42",
"0x56",
"0x54",
"0x54",
"0x0D",
], {
mime: "text/vtt",
extension: "vtt",
});
add("WebVTT", [
"0xEF",
"0xBB",
"0xBF",
"0x57",
"0x45",
"0x42",
"0x56",
"0x54",
"0x54",
"0x20",
], {
mime: "text/vtt",
extension: "vtt",
});
add("WebVTT", [
"0xEF",
"0xBB",
"0xBF",
"0x57",
"0x45",
"0x42",
"0x56",
"0x54",
"0x54",
"0x09",
], {
mime: "text/vtt",
extension: "vtt",
});
add("WebVTT", ["0x57", "0x45", "0x42", "0x56", "0x54", "0x54", "0x0A"], {
mime: "text/vtt",
extension: "vtt",
});
add("WebVTT", ["0x57", "0x45", "0x42", "0x56", "0x54", "0x54", "0x0D"], {
mime: "text/vtt",
extension: "vtt",
});
add("WebVTT", ["0x57", "0x45", "0x42", "0x56", "0x54", "0x54", "0x20"], {
mime: "text/vtt",
extension: "vtt",
});
add("WebVTT", ["0x57", "0x45", "0x42", "0x56", "0x54", "0x54", "0x09"], {
mime: "text/vtt",
extension: "vtt",
});
add("Json", ["0x7B"], {
mime: "application/json",
extension: ".json",
});
add("Json", ["0x5B"], {
mime: "application/json",
extension: ".json",
});
add("ELF", ["0x7F", "0x45", "0x4C", "0x46"], {
mime: "application/x-executable",
extension: ".elf",
});
add("Mach-O", ["0xFE", "0xED", "0xFA", "0xC"], {
mime: "application/x-mach-binary",
extension: ".o",
});
add("Mach-O", ["0xFE", "0xED", "0xFA", "0xCF"], {
mime: "application/x-executable",
extension: "elf",
});
add("EML", ["0x52", "0x65", "0x63", "0x65", "0x69", "0x76", "0x65", "0x64", "0x3A"], {
mime: "message/rfc822",
extension: ".eml",
});
add("SVG", ["0x3c", "0x73", "0x76", "0x67"], {
mime: "image/svg+xml",
extension: "svg",
});
exports["default"] = () => tree;
/***/ }),
/***/ "./node_modules/magic-bytes.js/dist/model/toHex.js":
/***/ ((__unused_webpack_module, exports) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.fromHex = exports.toHex = void 0;
const hex = (num) => new Number(num).toString(16).toLowerCase();
const toHex = (num) => `0x${hex(num).length === 1 ? "0" + hex(num) : hex(num)}`;
exports.toHex = toHex;
const fromHex = (hex) => new Number(hex);
exports.fromHex = fromHex;
/***/ }),
/***/ "./node_modules/magic-bytes.js/dist/model/tree.js":
/***/ ((__unused_webpack_module, exports) => {
"use strict";
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.createComplexNode = exports.createNode = exports.merge = void 0;
const createMatch = (leaf) => ({
typename: leaf.typename,
mime: leaf.info.mime,
extension: leaf.info.extension,
});
const isMatchingNode = (tree, path) => tree && path.length === 0;
const head = (arr) => arr[0];
const tail = (arr) => arr.slice(1, arr.length);
const merge = (node, tree) => {
if (node.bytes.length === 0)
return tree;
const currentByte = head(node.bytes); // 0
const path = tail(node.bytes); // [1,2]
const currentTree = tree.bytes[currentByte];
// traversed to end. Just add key to leaf.
if (isMatchingNode(currentTree, path)) {
const matchingNode = tree.bytes[currentByte];
tree.bytes[currentByte] = {
...matchingNode,
matches: [
...(matchingNode.matches ? matchingNode.matches : []),
createMatch(node),
],
};
return tree;
}
// Path exists already, Merge subtree
if (tree.bytes[currentByte]) {
tree.bytes[currentByte] = exports.merge(exports.createNode(node.typename, path, node.info), tree.bytes[currentByte]);
return tree;
}
// Tree did not exist before
if (!tree.bytes[currentByte]) {
tree.bytes[currentByte] = {
...tree.bytes[currentByte],
...exports.createComplexNode(node.typename, path, node.info),
};
}
return tree;
};
exports.merge = merge;
const createNode = (typename, bytes, info) => {
return { typename, bytes, info: info ? info : {} };
};
exports.createNode = createNode;
const createComplexNode = (typename, bytes, info) => {
let obj = {
bytes: {},
matches: undefined,
};
const currentKey = head(bytes); // 0
const path = tail(bytes); // [1,2]
if (bytes.length === 0) {
return {
matches: [
createMatch({
typename: typename,
info: info ? { extension: info.extension, mime: info.mime } : {},
}),
],
bytes: {},
};
}
obj.bytes[currentKey] = exports.createComplexNode(typename, path, info);
return obj;
};
exports.createComplexNode = createComplexNode;
/***/ }),
/***/ "./node_modules/mime-db/index.js":
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
/*!
* mime-db
* Copyright(c) 2014 Jonathan Ong
* Copyright(c) 2015-2022 Douglas Christopher Wilson
* MIT Licensed
*/
/**
* Module exports.
*/
module.exports = __webpack_require__("./node_modules/mime-db/db.json")
/***/ }),
/***/ "./node_modules/source-map-js/lib/array-set.js":
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
/* -*- Mode: js; js-indent-level: 2; -*- */
/*
* Copyright 2011 Mozilla Foundation and contributors
* Licensed under the New BSD license. See LICENSE or:
* http://opensource.org/licenses/BSD-3-Clause
*/
var util = __webpack_require__("./node_modules/source-map-js/lib/util.js");
var has = Object.prototype.hasOwnProperty;
var hasNativeMap = typeof Map !== "undefined";
/**
* A data structure which is a combination of an array and a set. Adding a new
* member is O(1), testing for membership is O(1), and finding the index of an
* element is O(1). Removing elements from the set is not supported. Only
* strings are supported for membership.
*/
function ArraySet() {
this._array = [];
this._set = hasNativeMap ? new Map() : Object.create(null);
}
/**
* Static method for creating ArraySet instances from an existing array.
*/
ArraySet.fromArray = function ArraySet_fromArray(aArray, aAllowDuplicates) {
var set = new ArraySet();
for (var i = 0, len = aArray.length; i < len; i++) {
set.add(aArray[i], aAllowDuplicates);
}
return set;
};
/**
* Return how many unique items are in this ArraySet. If duplicates have been
* added, than those do not count towards the size.
*
* @returns Number
*/
ArraySet.prototype.size = function ArraySet_size() {
return hasNativeMap ? this._set.size : Object.getOwnPropertyNames(this._set).length;
};
/**
* Add the given string to this set.
*
* @param String aStr
*/
ArraySet.prototype.add = function ArraySet_add(aStr, aAllowDuplicates) {
var sStr = hasNativeMap ? aStr : util.toSetString(aStr);
var isDuplicate = hasNativeMap ? this.has(aStr) : has.call(this._set, sStr);
var idx = this._array.length;
if (!isDuplicate || aAllowDuplicates) {
this._array.push(aStr);
}
if (!isDuplicate) {
if (hasNativeMap) {
this._set.set(aStr, idx);
} else {
this._set[sStr] = idx;
}
}
};
/**
* Is the given string a member of this set?
*
* @param String aStr
*/
ArraySet.prototype.has = function ArraySet_has(aStr) {
if (hasNativeMap) {
return this._set.has(aStr);
} else {
var sStr = util.toSetString(aStr);
return has.call(this._set, sStr);
}
};
/**
* What is the index of the given string in the array?
*
* @param String aStr
*/
ArraySet.prototype.indexOf = function ArraySet_indexOf(aStr) {
if (hasNativeMap) {
var idx = this._set.get(aStr);
if (idx >= 0) {
return idx;
}
} else {
var sStr = util.toSetString(aStr);
if (has.call(this._set, sStr)) {
return this._set[sStr];
}
}
throw new Error('"' + aStr + '" is not in the set.');
};
/**
* What is the element at the given index?
*
* @param Number aIdx
*/
ArraySet.prototype.at = function ArraySet_at(aIdx) {
if (aIdx >= 0 && aIdx < this._array.length) {
return this._array[aIdx];
}
throw new Error('No element indexed by ' + aIdx);
};
/**
* Returns the array representation of this set (which has the proper indices
* indicated by indexOf). Note that this is a copy of the internal array used
* for storing the members so that no one can mess with internal state.
*/
ArraySet.prototype.toArray = function ArraySet_toArray() {
return this._array.slice();
};
exports.C = ArraySet;
/***/ }),
/***/ "./node_modules/source-map-js/lib/base64-vlq.js":
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
/* -*- Mode: js; js-indent-level: 2; -*- */
/*
* Copyright 2011 Mozilla Foundation and contributors
* Licensed under the New BSD license. See LICENSE or:
* http://opensource.org/licenses/BSD-3-Clause
*
* Based on the Base 64 VLQ implementation in Closure Compiler:
* https://code.google.com/p/closure-compiler/source/browse/trunk/src/com/google/debugging/sourcemap/Base64VLQ.java
*
* Copyright 2011 The Closure Compiler Authors. All rights reserved.
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are
* met:
*
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above
* copyright notice, this list of conditions and the following
* disclaimer in the documentation and/or other materials provided
* with the distribution.
* * Neither the name of Google Inc. nor the names of its
* contributors may be used to endorse or promote products derived
* from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
var base64 = __webpack_require__("./node_modules/source-map-js/lib/base64.js");
// A single base 64 digit can contain 6 bits of data. For the base 64 variable
// length quantities we use in the source map spec, the first bit is the sign,
// the next four bits are the actual value, and the 6th bit is the
// continuation bit. The continuation bit tells us whether there are more
// digits in this value following this digit.
//
// Continuation
// | Sign
// | |
// V V
// 101011
var VLQ_BASE_SHIFT = 5;
// binary: 100000
var VLQ_BASE = 1 << VLQ_BASE_SHIFT;
// binary: 011111
var VLQ_BASE_MASK = VLQ_BASE - 1;
// binary: 100000
var VLQ_CONTINUATION_BIT = VLQ_BASE;
/**
* Converts from a two-complement value to a value where the sign bit is
* placed in the least significant bit. For example, as decimals:
* 1 becomes 2 (10 binary), -1 becomes 3 (11 binary)
* 2 becomes 4 (100 binary), -2 becomes 5 (101 binary)
*/
function toVLQSigned(aValue) {
return aValue < 0
? ((-aValue) << 1) + 1
: (aValue << 1) + 0;
}
/**
* Converts to a two-complement value from a value where the sign bit is
* placed in the least significant bit. For example, as decimals:
* 2 (10 binary) becomes 1, 3 (11 binary) becomes -1
* 4 (100 binary) becomes 2, 5 (101 binary) becomes -2
*/
function fromVLQSigned(aValue) {
var isNegative = (aValue & 1) === 1;
var shifted = aValue >> 1;
return isNegative
? -shifted
: shifted;
}
/**
* Returns the base 64 VLQ encoded value.
*/
exports.encode = function base64VLQ_encode(aValue) {
var encoded = "";
var digit;
var vlq = toVLQSigned(aValue);
do {
digit = vlq & VLQ_BASE_MASK;
vlq >>>= VLQ_BASE_SHIFT;
if (vlq > 0) {
// There are still more digits in this value, so we must make sure the
// continuation bit is marked.
digit |= VLQ_CONTINUATION_BIT;
}
encoded += base64.encode(digit);
} while (vlq > 0);
return encoded;
};
/**
* Decodes the next base 64 VLQ value from the given string and returns the
* value and the rest of the string via the out parameter.
*/
exports.decode = function base64VLQ_decode(aStr, aIndex, aOutParam) {
var strLen = aStr.length;
var result = 0;
var shift = 0;
var continuation, digit;
do {
if (aIndex >= strLen) {
throw new Error("Expected more digits in base 64 VLQ value.");
}
digit = base64.decode(aStr.charCodeAt(aIndex++));
if (digit === -1) {
throw new Error("Invalid base64 digit: " + aStr.charAt(aIndex - 1));
}
continuation = !!(digit & VLQ_CONTINUATION_BIT);
digit &= VLQ_BASE_MASK;
result = result + (digit << shift);
shift += VLQ_BASE_SHIFT;
} while (continuation);
aOutParam.value = fromVLQSigned(result);
aOutParam.rest = aIndex;
};
/***/ }),
/***/ "./node_modules/source-map-js/lib/base64.js":
/***/ ((__unused_webpack_module, exports) => {
/* -*- Mode: js; js-indent-level: 2; -*- */
/*
* Copyright 2011 Mozilla Foundation and contributors
* Licensed under the New BSD license. See LICENSE or:
* http://opensource.org/licenses/BSD-3-Clause
*/
var intToCharMap = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'.split('');
/**
* Encode an integer in the range of 0 to 63 to a single base 64 digit.
*/
exports.encode = function (number) {
if (0 <= number && number < intToCharMap.length) {
return intToCharMap[number];
}
throw new TypeError("Must be between 0 and 63: " + number);
};
/**
* Decode a single base 64 character code digit to an integer. Returns -1 on
* failure.
*/
exports.decode = function (charCode) {
var bigA = 65; // 'A'
var bigZ = 90; // 'Z'
var littleA = 97; // 'a'
var littleZ = 122; // 'z'
var zero = 48; // '0'
var nine = 57; // '9'
var plus = 43; // '+'
var slash = 47; // '/'
var littleOffset = 26;
var numberOffset = 52;
// 0 - 25: ABCDEFGHIJKLMNOPQRSTUVWXYZ
if (bigA <= charCode && charCode <= bigZ) {
return (charCode - bigA);
}
// 26 - 51: abcdefghijklmnopqrstuvwxyz
if (littleA <= charCode && charCode <= littleZ) {
return (charCode - littleA + littleOffset);
}
// 52 - 61: 0123456789
if (zero <= charCode && charCode <= nine) {
return (charCode - zero + numberOffset);
}
// 62: +
if (charCode == plus) {
return 62;
}
// 63: /
if (charCode == slash) {
return 63;
}
// Invalid base64 digit.
return -1;
};
/***/ }),
/***/ "./node_modules/source-map-js/lib/mapping-list.js":
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
/* -*- Mode: js; js-indent-level: 2; -*- */
/*
* Copyright 2014 Mozilla Foundation and contributors
* Licensed under the New BSD license. See LICENSE or:
* http://opensource.org/licenses/BSD-3-Clause
*/
var util = __webpack_require__("./node_modules/source-map-js/lib/util.js");
/**
* Determine whether mappingB is after mappingA with respect to generated
* position.
*/
function generatedPositionAfter(mappingA, mappingB) {
// Optimized for most common case
var lineA = mappingA.generatedLine;
var lineB = mappingB.generatedLine;
var columnA = mappingA.generatedColumn;
var columnB = mappingB.generatedColumn;
return lineB > lineA || lineB == lineA && columnB >= columnA ||
util.compareByGeneratedPositionsInflated(mappingA, mappingB) <= 0;
}
/**
* A data structure to provide a sorted view of accumulated mappings in a
* performance conscious manner. It trades a neglibable overhead in general
* case for a large speedup in case of mappings being added in order.
*/
function MappingList() {
this._array = [];
this._sorted = true;
// Serves as infimum
this._last = {generatedLine: -1, generatedColumn: 0};
}
/**
* Iterate through internal items. This method takes the same arguments that
* `Array.prototype.forEach` takes.
*
* NOTE: The order of the mappings is NOT guaranteed.
*/
MappingList.prototype.unsortedForEach =
function MappingList_forEach(aCallback, aThisArg) {
this._array.forEach(aCallback, aThisArg);
};
/**
* Add the given source mapping.
*
* @param Object aMapping
*/
MappingList.prototype.add = function MappingList_add(aMapping) {
if (generatedPositionAfter(this._last, aMapping)) {
this._last = aMapping;
this._array.push(aMapping);
} else {
this._sorted = false;
this._array.push(aMapping);
}
};
/**
* Returns the flat, sorted array of mappings. The mappings are sorted by
* generated position.
*
* WARNING: This method returns internal data without copying, for
* performance. The return value must NOT be mutated, and should be treated as
* an immutable borrow. If you want to take ownership, you must make your own
* copy.
*/
MappingList.prototype.toArray = function MappingList_toArray() {
if (!this._sorted) {
this._array.sort(util.compareByGeneratedPositionsInflated);
this._sorted = true;
}
return this._array;
};
exports.P = MappingList;
/***/ }),
/***/ "./node_modules/source-map-js/lib/source-map-generator.js":
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
/* -*- Mode: js; js-indent-level: 2; -*- */
/*
* Copyright 2011 Mozilla Foundation and contributors
* Licensed under the New BSD license. See LICENSE or:
* http://opensource.org/licenses/BSD-3-Clause
*/
var base64VLQ = __webpack_require__("./node_modules/source-map-js/lib/base64-vlq.js");
var util = __webpack_require__("./node_modules/source-map-js/lib/util.js");
var ArraySet = (__webpack_require__("./node_modules/source-map-js/lib/array-set.js")/* .ArraySet */ .C);
var MappingList = (__webpack_require__("./node_modules/source-map-js/lib/mapping-list.js")/* .MappingList */ .P);
/**
* An instance of the SourceMapGenerator represents a source map which is
* being built incrementally. You may pass an object with the following
* properties:
*
* - file: The filename of the generated source.
* - sourceRoot: A root for all relative URLs in this source map.
*/
function SourceMapGenerator(aArgs) {
if (!aArgs) {
aArgs = {};
}
this._file = util.getArg(aArgs, 'file', null);
this._sourceRoot = util.getArg(aArgs, 'sourceRoot', null);
this._skipValidation = util.getArg(aArgs, 'skipValidation', false);
this._sources = new ArraySet();
this._names = new ArraySet();
this._mappings = new MappingList();
this._sourcesContents = null;
}
SourceMapGenerator.prototype._version = 3;
/**
* Creates a new SourceMapGenerator based on a SourceMapConsumer
*
* @param aSourceMapConsumer The SourceMap.
*/
SourceMapGenerator.fromSourceMap =
function SourceMapGenerator_fromSourceMap(aSourceMapConsumer) {
var sourceRoot = aSourceMapConsumer.sourceRoot;
var generator = new SourceMapGenerator({
file: aSourceMapConsumer.file,
sourceRoot: sourceRoot
});
aSourceMapConsumer.eachMapping(function (mapping) {
var newMapping = {
generated: {
line: mapping.generatedLine,
column: mapping.generatedColumn
}
};
if (mapping.source != null) {
newMapping.source = mapping.source;
if (sourceRoot != null) {
newMapping.source = util.relative(sourceRoot, newMapping.source);
}
newMapping.original = {
line: mapping.originalLine,
column: mapping.originalColumn
};
if (mapping.name != null) {
newMapping.name = mapping.name;
}
}
generator.addMapping(newMapping);
});
aSourceMapConsumer.sources.forEach(function (sourceFile) {
var sourceRelative = sourceFile;
if (sourceRoot !== null) {
sourceRelative = util.relative(sourceRoot, sourceFile);
}
if (!generator._sources.has(sourceRelative)) {
generator._sources.add(sourceRelative);
}
var content = aSourceMapConsumer.sourceContentFor(sourceFile);
if (content != null) {
generator.setSourceContent(sourceFile, content);
}
});
return generator;
};
/**
* Add a single mapping from original source line and column to the generated
* source's line and column for this source map being created. The mapping
* object should have the following properties:
*
* - generated: An object with the generated line and column positions.
* - original: An object with the original line and column positions.
* - source: The original source file (relative to the sourceRoot).
* - name: An optional original token name for this mapping.
*/
SourceMapGenerator.prototype.addMapping =
function SourceMapGenerator_addMapping(aArgs) {
var generated = util.getArg(aArgs, 'generated');
var original = util.getArg(aArgs, 'original', null);
var source = util.getArg(aArgs, 'source', null);
var name = util.getArg(aArgs, 'name', null);
if (!this._skipValidation) {
this._validateMapping(generated, original, source, name);
}
if (source != null) {
source = String(source);
if (!this._sources.has(source)) {
this._sources.add(source);
}
}
if (name != null) {
name = String(name);
if (!this._names.has(name)) {
this._names.add(name);
}
}
this._mappings.add({
generatedLine: generated.line,
generatedColumn: generated.column,
originalLine: original != null && original.line,
originalColumn: original != null && original.column,
source: source,
name: name
});
};
/**
* Set the source content for a source file.
*/
SourceMapGenerator.prototype.setSourceContent =
function SourceMapGenerator_setSourceContent(aSourceFile, aSourceContent) {
var source = aSourceFile;
if (this._sourceRoot != null) {
source = util.relative(this._sourceRoot, source);
}
if (aSourceContent != null) {
// Add the source content to the _sourcesContents map.
// Create a new _sourcesContents map if the property is null.
if (!this._sourcesContents) {
this._sourcesContents = Object.create(null);
}
this._sourcesContents[util.toSetString(source)] = aSourceContent;
} else if (this._sourcesContents) {
// Remove the source file from the _sourcesContents map.
// If the _sourcesContents map is empty, set the property to null.
delete this._sourcesContents[util.toSetString(source)];
if (Object.keys(this._sourcesContents).length === 0) {
this._sourcesContents = null;
}
}
};
/**
* Applies the mappings of a sub-source-map for a specific source file to the
* source map being generated. Each mapping to the supplied source file is
* rewritten using the supplied source map. Note: The resolution for the
* resulting mappings is the minimium of this map and the supplied map.
*
* @param aSourceMapConsumer The source map to be applied.
* @param aSourceFile Optional. The filename of the source file.
* If omitted, SourceMapConsumer's file property will be used.
* @param aSourceMapPath Optional. The dirname of the path to the source map
* to be applied. If relative, it is relative to the SourceMapConsumer.
* This parameter is needed when the two source maps aren't in the same
* directory, and the source map to be applied contains relative source
* paths. If so, those relative source paths need to be rewritten
* relative to the SourceMapGenerator.
*/
SourceMapGenerator.prototype.applySourceMap =
function SourceMapGenerator_applySourceMap(aSourceMapConsumer, aSourceFile, aSourceMapPath) {
var sourceFile = aSourceFile;
// If aSourceFile is omitted, we will use the file property of the SourceMap
if (aSourceFile == null) {
if (aSourceMapConsumer.file == null) {
throw new Error(
'SourceMapGenerator.prototype.applySourceMap requires either an explicit source file, ' +
'or the source map\'s "file" property. Both were omitted.'
);
}
sourceFile = aSourceMapConsumer.file;
}
var sourceRoot = this._sourceRoot;
// Make "sourceFile" relative if an absolute Url is passed.
if (sourceRoot != null) {
sourceFile = util.relative(sourceRoot, sourceFile);
}
// Applying the SourceMap can add and remove items from the sources and
// the names array.
var newSources = new ArraySet();
var newNames = new ArraySet();
// Find mappings for the "sourceFile"
this._mappings.unsortedForEach(function (mapping) {
if (mapping.source === sourceFile && mapping.originalLine != null) {
// Check if it can be mapped by the source map, then update the mapping.
var original = aSourceMapConsumer.originalPositionFor({
line: mapping.originalLine,
column: mapping.originalColumn
});
if (original.source != null) {
// Copy mapping
mapping.source = original.source;
if (aSourceMapPath != null) {
mapping.source = util.join(aSourceMapPath, mapping.source)
}
if (sourceRoot != null) {
mapping.source = util.relative(sourceRoot, mapping.source);
}
mapping.originalLine = original.line;
mapping.originalColumn = original.column;
if (original.name != null) {
mapping.name = original.name;
}
}
}
var source = mapping.source;
if (source != null && !newSources.has(source)) {
newSources.add(source);
}
var name = mapping.name;
if (name != null && !newNames.has(name)) {
newNames.add(name);
}
}, this);
this._sources = newSources;
this._names = newNames;
// Copy sourcesContents of applied map.
aSourceMapConsumer.sources.forEach(function (sourceFile) {
var content = aSourceMapConsumer.sourceContentFor(sourceFile);
if (content != null) {
if (aSourceMapPath != null) {
sourceFile = util.join(aSourceMapPath, sourceFile);
}
if (sourceRoot != null) {
sourceFile = util.relative(sourceRoot, sourceFile);
}
this.setSourceContent(sourceFile, content);
}
}, this);
};
/**
* A mapping can have one of the three levels of data:
*
* 1. Just the generated position.
* 2. The Generated position, original position, and original source.
* 3. Generated and original position, original source, as well as a name
* token.
*
* To maintain consistency, we validate that any new mapping being added falls
* in to one of these categories.
*/
SourceMapGenerator.prototype._validateMapping =
function SourceMapGenerator_validateMapping(aGenerated, aOriginal, aSource,
aName) {
// When aOriginal is truthy but has empty values for .line and .column,
// it is most likely a programmer error. In this case we throw a very
// specific error message to try to guide them the right way.
// For example: https://github.com/Polymer/polymer-bundler/pull/519
if (aOriginal && typeof aOriginal.line !== 'number' && typeof aOriginal.column !== 'number') {
throw new Error(
'original.line and original.column are not numbers -- you probably meant to omit ' +
'the original mapping entirely and only map the generated position. If so, pass ' +
'null for the original mapping instead of an object with empty or null values.'
);
}
if (aGenerated && 'line' in aGenerated && 'column' in aGenerated
&& aGenerated.line > 0 && aGenerated.column >= 0
&& !aOriginal && !aSource && !aName) {
// Case 1.
return;
}
else if (aGenerated && 'line' in aGenerated && 'column' in aGenerated
&& aOriginal && 'line' in aOriginal && 'column' in aOriginal
&& aGenerated.line > 0 && aGenerated.column >= 0
&& aOriginal.line > 0 && aOriginal.column >= 0
&& aSource) {
// Cases 2 and 3.
return;
}
else {
throw new Error('Invalid mapping: ' + JSON.stringify({
generated: aGenerated,
source: aSource,
original: aOriginal,
name: aName
}));
}
};
/**
* Serialize the accumulated mappings in to the stream of base 64 VLQs
* specified by the source map format.
*/
SourceMapGenerator.prototype._serializeMappings =
function SourceMapGenerator_serializeMappings() {
var previousGeneratedColumn = 0;
var previousGeneratedLine = 1;
var previousOriginalColumn = 0;
var previousOriginalLine = 0;
var previousName = 0;
var previousSource = 0;
var result = '';
var next;
var mapping;
var nameIdx;
var sourceIdx;
var mappings = this._mappings.toArray();
for (var i = 0, len = mappings.length; i < len; i++) {
mapping = mappings[i];
next = ''
if (mapping.generatedLine !== previousGeneratedLine) {
previousGeneratedColumn = 0;
while (mapping.generatedLine !== previousGeneratedLine) {
next += ';';
previousGeneratedLine++;
}
}
else {
if (i > 0) {
if (!util.compareByGeneratedPositionsInflated(mapping, mappings[i - 1])) {
continue;
}
next += ',';
}
}
next += base64VLQ.encode(mapping.generatedColumn
- previousGeneratedColumn);
previousGeneratedColumn = mapping.generatedColumn;
if (mapping.source != null) {
sourceIdx = this._sources.indexOf(mapping.source);
next += base64VLQ.encode(sourceIdx - previousSource);
previousSource = sourceIdx;
// lines are stored 0-based in SourceMap spec version 3
next += base64VLQ.encode(mapping.originalLine - 1
- previousOriginalLine);
previousOriginalLine = mapping.originalLine - 1;
next += base64VLQ.encode(mapping.originalColumn
- previousOriginalColumn);
previousOriginalColumn = mapping.originalColumn;
if (mapping.name != null) {
nameIdx = this._names.indexOf(mapping.name);
next += base64VLQ.encode(nameIdx - previousName);
previousName = nameIdx;
}
}
result += next;
}
return result;
};
SourceMapGenerator.prototype._generateSourcesContent =
function SourceMapGenerator_generateSourcesContent(aSources, aSourceRoot) {
return aSources.map(function (source) {
if (!this._sourcesContents) {
return null;
}
if (aSourceRoot != null) {
source = util.relative(aSourceRoot, source);
}
var key = util.toSetString(source);
return Object.prototype.hasOwnProperty.call(this._sourcesContents, key)
? this._sourcesContents[key]
: null;
}, this);
};
/**
* Externalize the source map.
*/
SourceMapGenerator.prototype.toJSON =
function SourceMapGenerator_toJSON() {
var map = {
version: this._version,
sources: this._sources.toArray(),
names: this._names.toArray(),
mappings: this._serializeMappings()
};
if (this._file != null) {
map.file = this._file;
}
if (this._sourceRoot != null) {
map.sourceRoot = this._sourceRoot;
}
if (this._sourcesContents) {
map.sourcesContent = this._generateSourcesContent(map.sources, map.sourceRoot);
}
return map;
};
/**
* Render the source map being generated to a string.
*/
SourceMapGenerator.prototype.toString =
function SourceMapGenerator_toString() {
return JSON.stringify(this.toJSON());
};
exports.x = SourceMapGenerator;
/***/ }),
/***/ "./node_modules/source-map-js/lib/util.js":
/***/ ((__unused_webpack_module, exports) => {
/* -*- Mode: js; js-indent-level: 2; -*- */
/*
* Copyright 2011 Mozilla Foundation and contributors
* Licensed under the New BSD license. See LICENSE or:
* http://opensource.org/licenses/BSD-3-Clause
*/
/**
* This is a helper function for getting values from parameter/options
* objects.
*
* @param args The object we are extracting values from
* @param name The name of the property we are getting.
* @param defaultValue An optional value to return if the property is missing
* from the object. If this is not specified and the property is missing, an
* error will be thrown.
*/
function getArg(aArgs, aName, aDefaultValue) {
if (aName in aArgs) {
return aArgs[aName];
} else if (arguments.length === 3) {
return aDefaultValue;
} else {
throw new Error('"' + aName + '" is a required argument.');
}
}
exports.getArg = getArg;
var urlRegexp = /^(?:([\w+\-.]+):)?\/\/(?:(\w+:\w+)@)?([\w.-]*)(?::(\d+))?(.*)$/;
var dataUrlRegexp = /^data:.+\,.+$/;
function urlParse(aUrl) {
var match = aUrl.match(urlRegexp);
if (!match) {
return null;
}
return {
scheme: match[1],
auth: match[2],
host: match[3],
port: match[4],
path: match[5]
};
}
exports.urlParse = urlParse;
function urlGenerate(aParsedUrl) {
var url = '';
if (aParsedUrl.scheme) {
url += aParsedUrl.scheme + ':';
}
url += '//';
if (aParsedUrl.auth) {
url += aParsedUrl.auth + '@';
}
if (aParsedUrl.host) {
url += aParsedUrl.host;
}
if (aParsedUrl.port) {
url += ":" + aParsedUrl.port
}
if (aParsedUrl.path) {
url += aParsedUrl.path;
}
return url;
}
exports.urlGenerate = urlGenerate;
var MAX_CACHED_INPUTS = 32;
/**
* Takes some function `f(input) -> result` and returns a memoized version of
* `f`.
*
* We keep at most `MAX_CACHED_INPUTS` memoized results of `f` alive. The
* memoization is a dumb-simple, linear least-recently-used cache.
*/
function lruMemoize(f) {
var cache = [];
return function(input) {
for (var i = 0; i < cache.length; i++) {
if (cache[i].input === input) {
var temp = cache[0];
cache[0] = cache[i];
cache[i] = temp;
return cache[0].result;
}
}
var result = f(input);
cache.unshift({
input,
result,
});
if (cache.length > MAX_CACHED_INPUTS) {
cache.pop();
}
return result;
};
}
/**
* Normalizes a path, or the path portion of a URL:
*
* - Replaces consecutive slashes with one slash.
* - Removes unnecessary '.' parts.
* - Removes unnecessary '<dir>/..' parts.
*
* Based on code in the Node.js 'path' core module.
*
* @param aPath The path or url to normalize.
*/
var normalize = lruMemoize(function normalize(aPath) {
var path = aPath;
var url = urlParse(aPath);
if (url) {
if (!url.path) {
return aPath;
}
path = url.path;
}
var isAbsolute = exports.isAbsolute(path);
// Split the path into parts between `/` characters. This is much faster than
// using `.split(/\/+/g)`.
var parts = [];
var start = 0;
var i = 0;
while (true) {
start = i;
i = path.indexOf("/", start);
if (i === -1) {
parts.push(path.slice(start));
break;
} else {
parts.push(path.slice(start, i));
while (i < path.length && path[i] === "/") {
i++;
}
}
}
for (var part, up = 0, i = parts.length - 1; i >= 0; i--) {
part = parts[i];
if (part === '.') {
parts.splice(i, 1);
} else if (part === '..') {
up++;
} else if (up > 0) {
if (part === '') {
// The first part is blank if the path is absolute. Trying to go
// above the root is a no-op. Therefore we can remove all '..' parts
// directly after the root.
parts.splice(i + 1, up);
up = 0;
} else {
parts.splice(i, 2);
up--;
}
}
}
path = parts.join('/');
if (path === '') {
path = isAbsolute ? '/' : '.';
}
if (url) {
url.path = path;
return urlGenerate(url);
}
return path;
});
exports.normalize = normalize;
/**
* Joins two paths/URLs.
*
* @param aRoot The root path or URL.
* @param aPath The path or URL to be joined with the root.
*
* - If aPath is a URL or a data URI, aPath is returned, unless aPath is a
* scheme-relative URL: Then the scheme of aRoot, if any, is prepended
* first.
* - Otherwise aPath is a path. If aRoot is a URL, then its path portion
* is updated with the result and aRoot is returned. Otherwise the result
* is returned.
* - If aPath is absolute, the result is aPath.
* - Otherwise the two paths are joined with a slash.
* - Joining for example 'http://' and 'www.example.com' is also supported.
*/
function join(aRoot, aPath) {
if (aRoot === "") {
aRoot = ".";
}
if (aPath === "") {
aPath = ".";
}
var aPathUrl = urlParse(aPath);
var aRootUrl = urlParse(aRoot);
if (aRootUrl) {
aRoot = aRootUrl.path || '/';
}
// `join(foo, '//www.example.org')`
if (aPathUrl && !aPathUrl.scheme) {
if (aRootUrl) {
aPathUrl.scheme = aRootUrl.scheme;
}
return urlGenerate(aPathUrl);
}
if (aPathUrl || aPath.match(dataUrlRegexp)) {
return aPath;
}
// `join('http://', 'www.example.com')`
if (aRootUrl && !aRootUrl.host && !aRootUrl.path) {
aRootUrl.host = aPath;
return urlGenerate(aRootUrl);
}
var joined = aPath.charAt(0) === '/'
? aPath
: normalize(aRoot.replace(/\/+$/, '') + '/' + aPath);
if (aRootUrl) {
aRootUrl.path = joined;
return urlGenerate(aRootUrl);
}
return joined;
}
exports.join = join;
exports.isAbsolute = function (aPath) {
return aPath.charAt(0) === '/' || urlRegexp.test(aPath);
};
/**
* Make a path relative to a URL or another path.
*
* @param aRoot The root path or URL.
* @param aPath The path or URL to be made relative to aRoot.
*/
function relative(aRoot, aPath) {
if (aRoot === "") {
aRoot = ".";
}
aRoot = aRoot.replace(/\/$/, '');
// It is possible for the path to be above the root. In this case, simply
// checking whether the root is a prefix of the path won't work. Instead, we
// need to remove components from the root one by one, until either we find
// a prefix that fits, or we run out of components to remove.
var level = 0;
while (aPath.indexOf(aRoot + '/') !== 0) {
var index = aRoot.lastIndexOf("/");
if (index < 0) {
return aPath;
}
// If the only part of the root that is left is the scheme (i.e. http://,
// file:///, etc.), one or more slashes (/), or simply nothing at all, we
// have exhausted all components, so the path is not relative to the root.
aRoot = aRoot.slice(0, index);
if (aRoot.match(/^([^\/]+:\/)?\/*$/)) {
return aPath;
}
++level;
}
// Make sure we add a "../" for each component we removed from the root.
return Array(level + 1).join("../") + aPath.substr(aRoot.length + 1);
}
exports.relative = relative;
var supportsNullProto = (function () {
var obj = Object.create(null);
return !('__proto__' in obj);
}());
function identity (s) {
return s;
}
/**
* Because behavior goes wacky when you set `__proto__` on objects, we
* have to prefix all the strings in our set with an arbitrary character.
*
* See https://github.com/mozilla/source-map/pull/31 and
* https://github.com/mozilla/source-map/issues/30
*
* @param String aStr
*/
function toSetString(aStr) {
if (isProtoString(aStr)) {
return '$' + aStr;
}
return aStr;
}
exports.toSetString = supportsNullProto ? identity : toSetString;
function fromSetString(aStr) {
if (isProtoString(aStr)) {
return aStr.slice(1);
}
return aStr;
}
exports.fromSetString = supportsNullProto ? identity : fromSetString;
function isProtoString(s) {
if (!s) {
return false;
}
var length = s.length;
if (length < 9 /* "__proto__".length */) {
return false;
}
if (s.charCodeAt(length - 1) !== 95 /* '_' */ ||
s.charCodeAt(length - 2) !== 95 /* '_' */ ||
s.charCodeAt(length - 3) !== 111 /* 'o' */ ||
s.charCodeAt(length - 4) !== 116 /* 't' */ ||
s.charCodeAt(length - 5) !== 111 /* 'o' */ ||
s.charCodeAt(length - 6) !== 114 /* 'r' */ ||
s.charCodeAt(length - 7) !== 112 /* 'p' */ ||
s.charCodeAt(length - 8) !== 95 /* '_' */ ||
s.charCodeAt(length - 9) !== 95 /* '_' */) {
return false;
}
for (var i = length - 10; i >= 0; i--) {
if (s.charCodeAt(i) !== 36 /* '$' */) {
return false;
}
}
return true;
}
/**
* Comparator between two mappings where the original positions are compared.
*
* Optionally pass in `true` as `onlyCompareGenerated` to consider two
* mappings with the same original source/line/column, but different generated
* line and column the same. Useful when searching for a mapping with a
* stubbed out mapping.
*/
function compareByOriginalPositions(mappingA, mappingB, onlyCompareOriginal) {
var cmp = strcmp(mappingA.source, mappingB.source);
if (cmp !== 0) {
return cmp;
}
cmp = mappingA.originalLine - mappingB.originalLine;
if (cmp !== 0) {
return cmp;
}
cmp = mappingA.originalColumn - mappingB.originalColumn;
if (cmp !== 0 || onlyCompareOriginal) {
return cmp;
}
cmp = mappingA.generatedColumn - mappingB.generatedColumn;
if (cmp !== 0) {
return cmp;
}
cmp = mappingA.generatedLine - mappingB.generatedLine;
if (cmp !== 0) {
return cmp;
}
return strcmp(mappingA.name, mappingB.name);
}
exports.compareByOriginalPositions = compareByOriginalPositions;
function compareByOriginalPositionsNoSource(mappingA, mappingB, onlyCompareOriginal) {
var cmp
cmp = mappingA.originalLine - mappingB.originalLine;
if (cmp !== 0) {
return cmp;
}
cmp = mappingA.originalColumn - mappingB.originalColumn;
if (cmp !== 0 || onlyCompareOriginal) {
return cmp;
}
cmp = mappingA.generatedColumn - mappingB.generatedColumn;
if (cmp !== 0) {
return cmp;
}
cmp = mappingA.generatedLine - mappingB.generatedLine;
if (cmp !== 0) {
return cmp;
}
return strcmp(mappingA.name, mappingB.name);
}
exports.compareByOriginalPositionsNoSource = compareByOriginalPositionsNoSource;
/**
* Comparator between two mappings with deflated source and name indices where
* the generated positions are compared.
*
* Optionally pass in `true` as `onlyCompareGenerated` to consider two
* mappings with the same generated line and column, but different
* source/name/original line and column the same. Useful when searching for a
* mapping with a stubbed out mapping.
*/
function compareByGeneratedPositionsDeflated(mappingA, mappingB, onlyCompareGenerated) {
var cmp = mappingA.generatedLine - mappingB.generatedLine;
if (cmp !== 0) {
return cmp;
}
cmp = mappingA.generatedColumn - mappingB.generatedColumn;
if (cmp !== 0 || onlyCompareGenerated) {
return cmp;
}
cmp = strcmp(mappingA.source, mappingB.source);
if (cmp !== 0) {
return cmp;
}
cmp = mappingA.originalLine - mappingB.originalLine;
if (cmp !== 0) {
return cmp;
}
cmp = mappingA.originalColumn - mappingB.originalColumn;
if (cmp !== 0) {
return cmp;
}
return strcmp(mappingA.name, mappingB.name);
}
exports.compareByGeneratedPositionsDeflated = compareByGeneratedPositionsDeflated;
function compareByGeneratedPositionsDeflatedNoLine(mappingA, mappingB, onlyCompareGenerated) {
var cmp = mappingA.generatedColumn - mappingB.generatedColumn;
if (cmp !== 0 || onlyCompareGenerated) {
return cmp;
}
cmp = strcmp(mappingA.source, mappingB.source);
if (cmp !== 0) {
return cmp;
}
cmp = mappingA.originalLine - mappingB.originalLine;
if (cmp !== 0) {
return cmp;
}
cmp = mappingA.originalColumn - mappingB.originalColumn;
if (cmp !== 0) {
return cmp;
}
return strcmp(mappingA.name, mappingB.name);
}
exports.compareByGeneratedPositionsDeflatedNoLine = compareByGeneratedPositionsDeflatedNoLine;
function strcmp(aStr1, aStr2) {
if (aStr1 === aStr2) {
return 0;
}
if (aStr1 === null) {
return 1; // aStr2 !== null
}
if (aStr2 === null) {
return -1; // aStr1 !== null
}
if (aStr1 > aStr2) {
return 1;
}
return -1;
}
/**
* Comparator between two mappings with inflated source and name strings where
* the generated positions are compared.
*/
function compareByGeneratedPositionsInflated(mappingA, mappingB) {
var cmp = mappingA.generatedLine - mappingB.generatedLine;
if (cmp !== 0) {
return cmp;
}
cmp = mappingA.generatedColumn - mappingB.generatedColumn;
if (cmp !== 0) {
return cmp;
}
cmp = strcmp(mappingA.source, mappingB.source);
if (cmp !== 0) {
return cmp;
}
cmp = mappingA.originalLine - mappingB.originalLine;
if (cmp !== 0) {
return cmp;
}
cmp = mappingA.originalColumn - mappingB.originalColumn;
if (cmp !== 0) {
return cmp;
}
return strcmp(mappingA.name, mappingB.name);
}
exports.compareByGeneratedPositionsInflated = compareByGeneratedPositionsInflated;
/**
* Strip any JSON XSSI avoidance prefix from the string (as documented
* in the source maps specification), and then parse the string as
* JSON.
*/
function parseSourceMapInput(str) {
return JSON.parse(str.replace(/^\)]}'[^\n]*\n/, ''));
}
exports.parseSourceMapInput = parseSourceMapInput;
/**
* Compute the URL of a source given the the source root, the source's
* URL, and the source map's URL.
*/
function computeSourceURL(sourceRoot, sourceURL, sourceMapURL) {
sourceURL = sourceURL || '';
if (sourceRoot) {
// This follows what Chrome does.
if (sourceRoot[sourceRoot.length - 1] !== '/' && sourceURL[0] !== '/') {
sourceRoot += '/';
}
// The spec says:
// Line 4: An optional source root, useful for relocating source
// files on a server or removing repeated values in the
// “sources” entry. This value is prepended to the individual
// entries in the “source” field.
sourceURL = sourceRoot + sourceURL;
}
// Historically, SourceMapConsumer did not take the sourceMapURL as
// a parameter. This mode is still somewhat supported, which is why
// this code block is conditional. However, it's preferable to pass
// the source map URL to SourceMapConsumer, so that this function
// can implement the source URL resolution algorithm as outlined in
// the spec. This block is basically the equivalent of:
// new URL(sourceURL, sourceMapURL).toString()
// ... except it avoids using URL, which wasn't available in the
// older releases of node still supported by this library.
//
// The spec says:
// If the sources are not absolute URLs after prepending of the
// “sourceRoot”, the sources are resolved relative to the
// SourceMap (like resolving script src in a html document).
if (sourceMapURL) {
var parsed = urlParse(sourceMapURL);
if (!parsed) {
throw new Error("sourceMapURL could not be parsed");
}
if (parsed.path) {
// Strip the last path component, but keep the "/".
var index = parsed.path.lastIndexOf('/');
if (index >= 0) {
parsed.path = parsed.path.substring(0, index + 1);
}
}
sourceURL = join(urlGenerate(parsed), sourceURL);
}
return normalize(sourceURL);
}
exports.computeSourceURL = computeSourceURL;
/***/ }),
/***/ "./node_modules/streamsaver/StreamSaver.js":
/***/ (function(module) {
/*! streamsaver. MIT License. Jimmy Wärting <https://jimmy.warting.se/opensource> */
/* global chrome location ReadableStream define MessageChannel TransformStream */
;((name, definition) => {
true
? module.exports = definition()
: 0
})('streamSaver', () => {
'use strict'
const global = typeof window === 'object' ? window : this
if (!global.HTMLElement) console.warn('streamsaver is meant to run on browsers main thread')
let mitmTransporter = null
let supportsTransferable = false
const test = fn => { try { fn() } catch (e) {} }
const ponyfill = global.WebStreamsPolyfill || {}
const isSecureContext = global.isSecureContext
// TODO: Must come up with a real detection test (#69)
let useBlobFallback = /constructor/i.test(global.HTMLElement) || !!global.safari || !!global.WebKitPoint
const downloadStrategy = isSecureContext || 'MozAppearance' in document.documentElement.style
? 'iframe'
: 'navigate'
const streamSaver = {
createWriteStream,
WritableStream: global.WritableStream || ponyfill.WritableStream,
supported: true,
version: { full: '2.0.5', major: 2, minor: 0, dot: 5 },
mitm: 'https://jimmywarting.github.io/StreamSaver.js/mitm.html?version=2.0.0'
}
/**
* create a hidden iframe and append it to the DOM (body)
*
* @param {string} src page to load
* @return {HTMLIFrameElement} page to load
*/
function makeIframe (src) {
if (!src) throw new Error('meh')
const iframe = document.createElement('iframe')
iframe.hidden = true
iframe.src = src
iframe.loaded = false
iframe.name = 'iframe'
iframe.isIframe = true
iframe.postMessage = (...args) => iframe.contentWindow.postMessage(...args)
iframe.addEventListener('load', () => {
iframe.loaded = true
}, { once: true })
document.body.appendChild(iframe)
return iframe
}
/**
* create a popup that simulates the basic things
* of what a iframe can do
*
* @param {string} src page to load
* @return {object} iframe like object
*/
function makePopup (src) {
const options = 'width=200,height=100'
const delegate = document.createDocumentFragment()
const popup = {
frame: global.open(src, 'popup', options),
loaded: false,
isIframe: false,
isPopup: true,
remove () { popup.frame.close() },
addEventListener (...args) { delegate.addEventListener(...args) },
dispatchEvent (...args) { delegate.dispatchEvent(...args) },
removeEventListener (...args) { delegate.removeEventListener(...args) },
postMessage (...args) { popup.frame.postMessage(...args) }
}
const onReady = evt => {
if (evt.source === popup.frame) {
popup.loaded = true
global.removeEventListener('message', onReady)
popup.dispatchEvent(new Event('load'))
}
}
global.addEventListener('message', onReady)
return popup
}
try {
// We can't look for service worker since it may still work on http
new Response(new ReadableStream())
if (isSecureContext && !('serviceWorker' in navigator)) {
useBlobFallback = true
}
} catch (err) {
useBlobFallback = true
}
test(() => {
// Transferable stream was first enabled in chrome v73 behind a flag
const { readable } = new TransformStream()
const mc = new MessageChannel()
mc.port1.postMessage(readable, [readable])
mc.port1.close()
mc.port2.close()
supportsTransferable = true
// Freeze TransformStream object (can only work with native)
Object.defineProperty(streamSaver, 'TransformStream', {
configurable: false,
writable: false,
value: TransformStream
})
})
function loadTransporter () {
if (!mitmTransporter) {
mitmTransporter = isSecureContext
? makeIframe(streamSaver.mitm)
: makePopup(streamSaver.mitm)
}
}
/**
* @param {string} filename filename that should be used
* @param {object} options [description]
* @param {number} size deprecated
* @return {WritableStream<Uint8Array>}
*/
function createWriteStream (filename, options, size) {
let opts = {
size: null,
pathname: null,
writableStrategy: undefined,
readableStrategy: undefined
}
let bytesWritten = 0 // by StreamSaver.js (not the service worker)
let downloadUrl = null
let channel = null
let ts = null
// normalize arguments
if (Number.isFinite(options)) {
[ size, options ] = [ options, size ]
console.warn('[StreamSaver] Deprecated pass an object as 2nd argument when creating a write stream')
opts.size = size
opts.writableStrategy = options
} else if (options && options.highWaterMark) {
console.warn('[StreamSaver] Deprecated pass an object as 2nd argument when creating a write stream')
opts.size = size
opts.writableStrategy = options
} else {
opts = options || {}
}
if (!useBlobFallback) {
loadTransporter()
channel = new MessageChannel()
// Make filename RFC5987 compatible
filename = encodeURIComponent(filename.replace(/\//g, ':'))
.replace(/['()]/g, escape)
.replace(/\*/g, '%2A')
const response = {
transferringReadable: supportsTransferable,
pathname: opts.pathname || Math.random().toString().slice(-6) + '/' + filename,
headers: {
'Content-Type': 'application/octet-stream; charset=utf-8',
'Content-Disposition': "attachment; filename*=UTF-8''" + filename
}
}
if (opts.size) {
response.headers['Content-Length'] = opts.size
}
const args = [ response, '*', [ channel.port2 ] ]
if (supportsTransferable) {
const transformer = downloadStrategy === 'iframe' ? undefined : {
// This transformer & flush method is only used by insecure context.
transform (chunk, controller) {
if (!(chunk instanceof Uint8Array)) {
throw new TypeError('Can only write Uint8Arrays')
}
bytesWritten += chunk.length
controller.enqueue(chunk)
if (downloadUrl) {
location.href = downloadUrl
downloadUrl = null
}
},
flush () {
if (downloadUrl) {
location.href = downloadUrl
}
}
}
ts = new streamSaver.TransformStream(
transformer,
opts.writableStrategy,
opts.readableStrategy
)
const readableStream = ts.readable
channel.port1.postMessage({ readableStream }, [ readableStream ])
}
channel.port1.onmessage = evt => {
// Service worker sent us a link that we should open.
if (evt.data.download) {
// Special treatment for popup...
if (downloadStrategy === 'navigate') {
mitmTransporter.remove()
mitmTransporter = null
if (bytesWritten) {
location.href = evt.data.download
} else {
downloadUrl = evt.data.download
}
} else {
if (mitmTransporter.isPopup) {
mitmTransporter.remove()
mitmTransporter = null
// Special case for firefox, they can keep sw alive with fetch
if (downloadStrategy === 'iframe') {
makeIframe(streamSaver.mitm)
}
}
// We never remove this iframes b/c it can interrupt saving
makeIframe(evt.data.download)
}
} else if (evt.data.abort) {
chunks = []
channel.port1.postMessage('abort') //send back so controller is aborted
channel.port1.onmessage = null
channel.port1.close()
channel.port2.close()
channel = null
}
}
if (mitmTransporter.loaded) {
mitmTransporter.postMessage(...args)
} else {
mitmTransporter.addEventListener('load', () => {
mitmTransporter.postMessage(...args)
}, { once: true })
}
}
let chunks = []
return (!useBlobFallback && ts && ts.writable) || new streamSaver.WritableStream({
write (chunk) {
if (!(chunk instanceof Uint8Array)) {
throw new TypeError('Can only write Uint8Arrays')
}
if (useBlobFallback) {
// Safari... The new IE6
// https://github.com/jimmywarting/StreamSaver.js/issues/69
//
// even though it has everything it fails to download anything
// that comes from the service worker..!
chunks.push(chunk)
return
}
// is called when a new chunk of data is ready to be written
// to the underlying sink. It can return a promise to signal
// success or failure of the write operation. The stream
// implementation guarantees that this method will be called
// only after previous writes have succeeded, and never after
// close or abort is called.
// TODO: Kind of important that service worker respond back when
// it has been written. Otherwise we can't handle backpressure
// EDIT: Transferable streams solves this...
channel.port1.postMessage(chunk)
bytesWritten += chunk.length
if (downloadUrl) {
location.href = downloadUrl
downloadUrl = null
}
},
close () {
if (useBlobFallback) {
const blob = new Blob(chunks, { type: 'application/octet-stream; charset=utf-8' })
const link = document.createElement('a')
link.href = URL.createObjectURL(blob)
link.download = filename
link.click()
} else {
channel.port1.postMessage('end')
}
},
abort () {
chunks = []
channel.port1.postMessage('abort')
channel.port1.onmessage = null
channel.port1.close()
channel.port2.close()
channel = null
}
}, opts.writableStrategy)
}
return streamSaver
})
/***/ }),
/***/ "./src/lib/GM.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ JU: () => (/* binding */ _GM_deleteValue),
/* harmony export */ JX: () => (/* binding */ _GM_info),
/* harmony export */ er: () => (/* binding */ _GM_getValue),
/* harmony export */ mN: () => (/* binding */ _GM_setValue),
/* harmony export */ nV: () => (/* binding */ _GM_xmlhttpRequest)
/* harmony export */ });
function get_GM_info() {
if (typeof GM_info !== "undefined") {
return GM_info;
}
if (typeof GM !== "undefined" && typeof GM.info !== "undefined") {
return GM.info;
}
throw new Error("Not found: GM_info and GM.info!");
}
const _GM_info = get_GM_info();
function _GM_xmlhttpRequest(details) {
if (typeof GM_xmlhttpRequest === "function") {
GM_xmlhttpRequest(details);
return;
}
if (typeof GM !== "undefined" && typeof GM.xmlHttpRequest === "function") {
GM.xmlHttpRequest(details);
return;
}
throw new Error("Not found: GM_xmlhttpRequest or GM.xmlHttpRequest!");
}
async function _GM_setValue(name, value) {
if (typeof GM_setValue === "function") {
return GM_setValue(name, value);
}
if (typeof GM !== "undefined" && typeof GM.setValue === "function") {
return await GM.setValue(name, value);
}
throw new Error("Not found: GM_setValue or GM.setValue!");
}
async function _GM_getValue(name, defaultValue) {
if (typeof GM_getValue === "function") {
return GM_getValue(name, defaultValue);
}
if (typeof GM !== "undefined" && typeof GM.getValue === "function") {
return await GM.getValue(name, defaultValue);
}
throw new Error("Not found: GM_getValue or GM.getValue!");
}
async function _GM_deleteValue(name) {
if (typeof GM_deleteValue === "function") {
return GM_deleteValue(name);
}
if (typeof GM !== "undefined" && typeof GM.deleteValue === "function") {
return await GM.deleteValue(name);
}
throw new Error("Not found: GM_deleteValue or GM.deleteValue!");
}
/***/ }),
/***/ "./src/lib/attachments.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Ld: () => (/* binding */ putAttachmentClassCache),
/* harmony export */ VJ: () => (/* binding */ getRandomName),
/* harmony export */ _s: () => (/* binding */ getAttachmentClassCache),
/* harmony export */ an: () => (/* binding */ getExt),
/* harmony export */ "if": () => (/* binding */ getAttachment),
/* harmony export */ rd: () => (/* binding */ clearAttachmentClassCache)
/* harmony export */ });
/* harmony import */ var _main_Attachment__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/main/Attachment.ts");
/* harmony import */ var _hash__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/hash.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _misc__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/lib/misc.ts");
/* harmony import */ var magic_bytes_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./node_modules/magic-bytes.js/dist/index.js");
/* harmony import */ var magic_bytes_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(magic_bytes_js__WEBPACK_IMPORTED_MODULE_0__);
let attachmentClassCache = [];
function getAttachmentClassCache(url) {
return attachmentClassCache.find((attachmentClass) => attachmentClass.url === url);
}
function putAttachmentClassCache(attachmentClass) {
attachmentClassCache.push(attachmentClass);
return true;
}
function clearAttachmentClassCache() {
attachmentClassCache = [];
}
async function getAttachment(url, mode, prefix = "", noMD5 = false, comments = getRandomName(), options) {
if (mode === "naive") {
const u = new URL(url);
if (document.location.protocol === "https:" && u.protocol === "http:") {
u.protocol = document.location.protocol;
url = u.href;
}
}
const imgClassCache = getAttachmentClassCache(url);
if (imgClassCache) {
return imgClassCache;
}
const imgClass = new _main_Attachment__WEBPACK_IMPORTED_MODULE_1__/* .AttachmentClass */ .q(url, comments, mode, options?.referrerMode, options?.customReferer);
imgClass.comments = comments;
const blob = await imgClass.init();
if (blob) {
if (noMD5) {
imgClass.name = getLastPart(url);
}
else {
const hash = await (0,_hash__WEBPACK_IMPORTED_MODULE_2__/* .calculateSha1 */ .Q)(blob);
const ext = await getExt(blob, url);
imgClass.name = [prefix, hash, ".", ext].join("");
}
}
putAttachmentClassCache(imgClass);
_log__WEBPACK_IMPORTED_MODULE_3___default().debug(`[attachment]下载附件完成! url:${imgClass.url}, name: ${imgClass.name}`);
return imgClass;
}
function getRandomName() {
return `__${(0,_misc__WEBPACK_IMPORTED_MODULE_4__/* .randomUUID */ .N4)()}__`;
}
async function getExt(b, u) {
const ext = (0,magic_bytes_js__WEBPACK_IMPORTED_MODULE_0__.filetypeextension)(new Uint8Array(await b.arrayBuffer()));
if (ext.length !== 0) {
return ext[0];
}
const contentType = b.type.split(";")[0].split("/")[1];
const contentTypeBlackList = ["octet-stream"];
if (contentTypeBlackList.includes(contentType)) {
return getExtFromUrl(u);
}
else {
return contentType;
}
}
function getExtFromUrl(u) {
const _u = new URL(u);
const p = _u.pathname;
return p.substring(p.lastIndexOf(".") + 1);
}
function getLastPart(u) {
const _u = new URL(u);
const p = _u.pathname;
return p.substring(p.lastIndexOf("/") + 1);
}
/***/ }),
/***/ "./src/lib/cleanDOM.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ N0: () => (/* binding */ convertFixWidth),
/* harmony export */ U9: () => (/* binding */ convertBr),
/* harmony export */ WF: () => (/* binding */ convertFixWidthText),
/* harmony export */ an: () => (/* binding */ cleanDOM),
/* harmony export */ eu: () => (/* binding */ isFixWidth),
/* harmony export */ is: () => (/* binding */ htmlTrim)
/* harmony export */ });
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _attachments__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/dom.ts");
const BlockElements = [
"address",
"article",
"aside",
"blockquote",
"details",
"dialog",
"dd",
"div",
"dl",
"dt",
"fieldset",
"figcaption",
"figure",
"footer",
"form",
"h1",
"h2",
"h3",
"h4",
"h5",
"h6",
"header",
"hgroup",
"hr",
"li",
"main",
"nav",
"ol",
"p",
"pre",
"section",
"table",
"ul",
];
const InlineElements = [
"a",
"abbr",
"acronym",
"audio",
"b",
"bdi",
"bdo",
"big",
"br",
"button",
"canvas",
"cite",
"code",
"data",
"datalist",
"del",
"dfn",
"em",
"embed",
"i",
"iframe",
"img",
"input",
"ins",
"kbd",
"label",
"map",
"mark",
"meter",
"noscript",
"object",
"output",
"picture",
"progress",
"q",
"ruby",
"s",
"samp",
"script",
"select",
"slot",
"small",
"span",
"font",
"strong",
"sub",
"sup",
"svg",
"template",
"textarea",
"time",
"u",
"tt",
"var",
"video",
"wbr",
];
const keepElements = [
"aside",
"blockquote",
"details",
"figure",
"h1",
"h2",
"h3",
"h4",
"h5",
"h6",
"hr",
"ul",
"ol",
"li",
"pre",
];
const IgnoreElements = [
"#comment",
"fieldset",
"legend",
"input",
"label",
"form",
"button",
"canvas",
"datalist",
"embed",
"iframe",
"map",
"meter",
"noscript",
"object",
"output",
"progress",
"script",
"style",
"link",
"select",
"slot",
"svg",
"template",
"video",
"wbr",
];
function isBaseElem(node) {
const nodeName = node.nodeName.toLowerCase();
if (node instanceof Text) {
return true;
}
if (node.childElementCount === 0) {
return true;
}
if (InlineElements.includes(nodeName)) {
return true;
}
return Array.from(node.children).every((child) => {
const n = child.nodeName.toLowerCase();
return InlineElements.includes(n);
});
}
function isBaseElemWithKeep(node) {
const nodeName = node.nodeName.toLowerCase();
if (keepElements.includes(nodeName)) {
return true;
}
return isBaseElem(node);
}
function* findBase(elem, withKeep = true) {
let is;
if (withKeep) {
is = isBaseElemWithKeep;
}
else {
is = isBaseElem;
}
const childNodes = Array.from(elem.childNodes).filter((node) => {
if (node instanceof Text) {
const textContent = node.textContent;
if (textContent === null) {
return false;
}
if (textContent.trim() === "") {
return false;
}
}
return true;
});
for (const child of childNodes) {
const childNodeName = child.nodeName.toLowerCase();
if (!IgnoreElements.includes(childNodeName)) {
if (is(child)) {
yield child;
}
else {
yield* findBase(child, withKeep);
}
}
}
}
async function cleanDOM(elem, imgMode, options) {
const baseNodes = [...findBase(elem)];
const _obj = await loop(baseNodes, document.createElement("div"));
const obj = await awaitAttachments(_obj);
return postHook(obj);
async function blockElement(element) {
const map = new Map();
const divList = [
"article",
"dialog",
"div",
"footer",
"header",
"main",
"section",
"hgroup",
];
function div(elem) {
if (elem instanceof HTMLElement) {
const nodes = [...findBase(elem)];
return loop(nodes, document.createElement("div"));
}
return null;
}
divList.forEach((n) => map.set(n, div));
const pList = ["address", "p", "dd", "dt", "figcaption", "dl"];
function p(elem) {
if (elem instanceof HTMLElement) {
const nodes = [...findBase(elem)];
return loop(nodes, document.createElement("p"));
}
return null;
}
pList.forEach((n) => map.set(n, p));
const blockquoteList = ["aside", "blockquote"];
async function blockquote(elem) {
if (elem instanceof HTMLElement) {
const nodes = [...findBase(elem)];
const { dom, text, images } = await loop(nodes, document.createElement("blockquote"));
const outText = text
.split("\n")
.map((l) => l.replace(/^/, "> "))
.join("\n");
return {
dom,
text: outText,
images,
};
}
return null;
}
blockquoteList.forEach((n) => map.set(n, blockquote));
const headerList = ["h1", "h2", "h3", "h4", "h5", "h6"];
function header(elem) {
if (elem instanceof HTMLElement) {
const nodeName = elem.nodeName.toLowerCase();
const n = parseInt(nodeName.substring(1));
const dom = document.createElement(nodeName);
dom.innerHTML = elem.innerHTML;
const text = "#".repeat(n) + " " + elem.innerText;
const images = [];
return {
dom,
text,
images,
};
}
return null;
}
headerList.forEach((n) => map.set(n, header));
const preList = ["pre", "textarea"];
function pre(elem) {
if (elem instanceof HTMLElement) {
const dom = document.createElement("pre");
dom.innerHTML = elem.innerHTML;
const text = "```\n" + elem.innerText + "\n```";
const images = [];
return {
dom,
text,
images,
};
}
return null;
}
preList.forEach((n) => map.set(n, pre));
function hr(elem) {
if (elem instanceof HTMLHRElement) {
const dom = document.createElement("hr");
const text = "-".repeat(20);
const images = [];
return {
dom,
text,
images,
};
}
return null;
}
map.set("hr", hr);
async function common1(boldName, baseName, elem) {
const bold = elem.querySelector(boldName);
let s;
let sText = "";
if (bold instanceof HTMLElement) {
s = document.createElement(boldName);
s.innerHTML = bold.innerHTML;
sText = "**" + bold.innerText + "**";
bold.remove();
}
const base = document.createElement(baseName);
if (s)
base.appendChild(s);
const nodes = [...findBase(elem)];
const { dom, text, images } = await loop(nodes, base);
const outText = sText + "\n\n" + text;
return {
dom,
text: outText,
images,
};
}
function details(elem) {
return common1("summary", "details", elem);
}
map.set("details", details);
function figure(elem) {
return common1("figcaption", "figure", elem);
}
map.set("figure", figure);
function listItem(elem) {
if (elem instanceof HTMLLIElement) {
const dom = document.createElement("li");
dom.innerHTML = elem.innerHTML;
let prefix = "- ";
const parent = elem.parentNode;
if (parent instanceof HTMLOListElement) {
const start = parent.getAttribute("start");
const index = Array.prototype.indexOf.call(parent.children, elem);
prefix = (start ? Number(start) + index : index + 1) + ". ";
}
const text = prefix + elem.innerText;
const images = [];
return {
dom,
text,
images,
};
}
return null;
}
map.set("li", listItem);
const listList = ["ul", "ol"];
function list(elem) {
const nodeName = elem.nodeName.toLowerCase();
if (elem instanceof HTMLUListElement ||
elem instanceof HTMLOListElement) {
const tdom = document.createElement(nodeName);
const nodes = [...findBase(elem)];
return loop(nodes, tdom);
}
return null;
}
listList.forEach((n) => map.set(n, list));
function table(elem) {
if (elem instanceof HTMLTableElement) {
const dom = elem.cloneNode(true);
const text = processTable(elem);
const images = [];
return { dom, text, images };
}
return null;
function fixText(text) {
return text.trim().replaceAll("\t", "");
}
function processTable(tableDom) {
let markdown_string = "";
let table_header = "|";
let table_header_footer = "|";
let table_rows = "";
let table_header_found = false;
let table_header_cell_count = 0;
let prev_row_cell_count = 0;
Array.from(tableDom.querySelectorAll("thead > tr > td")).forEach((td) => {
table_header_cell_count++;
table_header = table_header + fixText(td.innerText) + "|";
table_header_footer = table_header_footer + "--- |";
table_header_found = true;
});
Array.from(tableDom.querySelectorAll("tr")).forEach((tr) => {
if (!table_header_found) {
Array.from(tr.querySelectorAll("th")).forEach((th) => {
table_header_cell_count++;
table_header = table_header + fixText(th.innerText) + "|";
table_header_footer = table_header_footer + "--- |";
table_header_found = true;
});
}
let table_row = "";
let curr_row_cell_count = 0;
Array.from(tr.querySelectorAll("td"))
.filter((td) => !Array.from(tableDom.querySelectorAll("thead > tr > td")).includes(td))
.forEach((td) => {
curr_row_cell_count++;
table_row = table_row + fixText(td.innerText) + "|";
});
if (prev_row_cell_count != 0 &&
curr_row_cell_count != prev_row_cell_count) {
markdown_string =
"ERROR: Your HTML table rows don't have the same number of cells. Colspan not supported.";
return false;
}
if (curr_row_cell_count) {
table_rows += "|" + table_row + "\n";
prev_row_cell_count = curr_row_cell_count;
}
});
if (markdown_string == "") {
if (table_header_found) {
if (table_header_cell_count != prev_row_cell_count) {
throw new Error("ERROR: The number of cells in your header doesn't match the number of cells in your rows.");
}
}
else {
for (let i = 0; i < prev_row_cell_count; i++) {
table_header = table_header + "|";
table_header_footer = table_header_footer + "--- |";
}
}
markdown_string += table_header + "\n";
markdown_string += table_header_footer + "\n";
markdown_string += table_rows;
}
return markdown_string;
}
}
map.set("table", table);
const nodeName = element.nodeName.toLowerCase();
const fn = map.get(nodeName) ?? p;
const obj = await fn(element);
if (!obj) {
return null;
}
const { dom, text, images } = obj;
if (element.getAttribute("data-keep")) {
const dk = element.getAttribute("data-keep");
const keeps = dk.split(",").map((k) => k.trim());
keeps.forEach((k) => {
if (dom instanceof HTMLElement && element.getAttribute(k)) {
dom.setAttribute(k, element.getAttribute(k));
}
});
}
return { dom, text, images };
}
async function inlineElement(element) {
const map = new Map();
const defaultList = [
"abbr",
"acronym",
"bdi",
"bdo",
"cite",
"data",
"dfn",
"span",
"font",
"time",
"u",
"tt",
"#text",
];
async function defaultHandler(elem) {
if ((elem instanceof HTMLElement && elem.childElementCount === 0) ||
elem instanceof Text) {
let text;
if (elem instanceof HTMLElement) {
text = elem.innerText.trim();
}
if (elem instanceof Text) {
text = elem.textContent?.trim() ?? "";
}
if (typeof text === "string") {
const dom = new Text(text);
const images = [];
return {
dom,
text: text.replaceAll("\n", ""),
images,
};
}
}
if (elem instanceof HTMLElement && elem.childElementCount !== 0) {
const nodes = [...findBase(elem)];
const { dom, text, images } = await loop(nodes, document.createElement(elem.nodeName.toLowerCase()));
return {
dom,
text,
images,
};
}
return null;
}
defaultList.forEach((n) => map.set(n, defaultHandler));
async function a(elem) {
if (elem instanceof HTMLAnchorElement) {
if (elem.childElementCount === 0) {
if (elem.href.startsWith("https://") ||
elem.href.startsWith("http://")) {
const { href, textContent } = elem;
const dom = document.createElement("a");
if (elem.getAttribute("href")?.startsWith("#")) {
dom.href = elem.getAttribute("href");
}
else {
dom.href = href;
}
dom.textContent = textContent;
const text = `[${textContent}](${href})`;
const images = [];
return {
dom,
text,
images,
};
}
}
else {
const outterA = document.createElement("a");
if (elem.href.startsWith("https://") ||
elem.href.startsWith("http://")) {
outterA.href = elem.href;
}
const nodes = [...findBase(elem)];
const { dom, text, images } = await loop(nodes, outterA);
return {
dom,
text,
images,
};
}
}
return null;
}
map.set("a", a);
function getImg(url) {
const imgClassCache = (0,_attachments__WEBPACK_IMPORTED_MODULE_0__/* .getAttachmentClassCache */ ._s)(url);
if (imgClassCache) {
const dom = document.createElement("img");
dom.setAttribute("data-src-address", imgClassCache.name);
dom.alt = url;
dom.title = url;
const text = `![${url}](${imgClassCache.name})`;
const images = [imgClassCache];
return {
dom,
text,
images,
};
}
else {
const comments = (0,_attachments__WEBPACK_IMPORTED_MODULE_0__/* .getRandomName */ .VJ)();
const noMd5 = options?.keepImageName ?? false;
const imgOptions = {
referrerMode: options?.referrerMode,
customReferer: options?.customReferer,
};
const imgClass = (0,_attachments__WEBPACK_IMPORTED_MODULE_0__/* .getAttachment */ ["if"])(url, imgMode, "chapter-", noMd5, comments, imgOptions);
const dom = document.createElement("img");
dom.setAttribute("data-src-address", comments);
dom.alt = url;
dom.title = url;
const text = `![${url}](${comments})`;
const images = [imgClass];
return {
dom,
text,
images,
};
}
}
function img(elem) {
if (elem instanceof HTMLImageElement) {
const url = elem.src;
return getImg(url);
}
return null;
}
map.set("img", img);
function audio(elem) {
if (elem instanceof HTMLAudioElement) {
const url = elem.src;
const attachmentCache = (0,_attachments__WEBPACK_IMPORTED_MODULE_0__/* .getAttachmentClassCache */ ._s)(url);
if (attachmentCache) {
const dom = document.createElement("audio");
dom.innerText = "Your browser does not support the audio element.";
dom.setAttribute("data-src-address", attachmentCache.name);
dom.setAttribute("controls", "");
dom.setAttribute("preload", "metadata");
dom.title = url;
const text = dom.outerHTML;
const images = [attachmentCache];
return {
dom,
text,
images,
};
}
else {
const comments = (0,_attachments__WEBPACK_IMPORTED_MODULE_0__/* .getRandomName */ .VJ)();
const noMd5 = options?.keepImageName ?? false;
const attachmentOptions = {
referrerMode: options?.referrerMode,
customReferer: options?.customReferer,
};
const attachment = (0,_attachments__WEBPACK_IMPORTED_MODULE_0__/* .getAttachment */ ["if"])(url, imgMode, "chapter-", noMd5, comments, attachmentOptions);
const dom = document.createElement("audio");
dom.innerText = "Your browser does not support the audio element.";
dom.setAttribute("data-src-address", comments);
dom.setAttribute("controls", "");
dom.setAttribute("preload", "metadata");
dom.title = url;
const text = dom.outerHTML;
const images = [attachment];
return {
dom,
text,
images,
};
}
}
return null;
}
map.set("audio", audio);
function picture(elem) {
if (elem instanceof HTMLPictureElement) {
const img = elem.querySelector("img");
if (img) {
const url = img.src;
return getImg(url);
}
else {
_log__WEBPACK_IMPORTED_MODULE_1___default().warn("[cleanDom][picture]未发现 img", elem);
return null;
}
}
return null;
}
map.set("picture", picture);
function ruby(elem) {
if (elem instanceof HTMLElement) {
const nodeArray = Array.from(elem.childNodes).map((node) => {
if (node instanceof Text && node.textContent?.trim()) {
const rb = document.createElement("rb");
rb.innerText = node.textContent.trim();
return rb;
}
else {
return node.cloneNode(true);
}
});
const dom = document.createElement("ruby");
nodeArray.forEach((node) => dom.appendChild(node));
let text;
if (nodeArray.some((node) => node.nodeName.toLowerCase() === "rt") &&
nodeArray.some((node) => node.nodeName.toLowerCase() === "rb")) {
text =
nodeArray
.filter((node) => node.nodeName.toLowerCase() === "rb")
.map((n) => n.innerText)
.join() +
"(" +
nodeArray
.filter((node) => node.nodeName.toLowerCase() === "rt")
.map((n) => n.innerText)
.join() +
")";
}
else {
text = elem.innerText;
}
const images = [];
return {
dom,
text,
images,
};
}
return null;
}
map.set("ruby", ruby);
function br() {
const dom = document.createElement("br");
const text = "\n";
const images = [];
return {
dom,
text,
images,
};
}
map.set("br", br);
async function common(nodeName, getText, elem) {
if (elem instanceof HTMLElement) {
if (elem.childElementCount === 0) {
const textContent = elem.innerText.trim();
const dom = document.createElement(nodeName);
dom.innerText = textContent;
const text = getText(textContent);
const images = [];
return {
dom,
text,
images,
};
}
else {
const nodes = [...findBase(elem)];
const { dom, text, images } = await loop(nodes, document.createElement(nodeName));
return {
dom,
text,
images,
};
}
}
return null;
}
const strongList = ["b", "big", "mark", "samp", "strong"];
function strong(elem) {
return common("strong", (textContent) => `**${textContent.replaceAll("\n", "**\n**")}**`, elem);
}
strongList.forEach((n) => map.set(n, strong));
const codeList = ["code", "kbd"];
function code(elem) {
return common("code", (textContent) => `\`${textContent}\``, elem);
}
codeList.forEach((n) => map.set(n, code));
const sList = ["del", "s"];
function s(elem) {
return common("s", (textContent) => `~~${textContent}~~`, elem);
}
sList.forEach((n) => map.set(n, s));
const emList = ["em", "i", "q", "var"];
function em(elem) {
return common("em", (textContent) => `*${textContent}*`, elem);
}
emList.forEach((n) => map.set(n, em));
function ins(elem) {
return common("ins", (textContent) => `++${textContent}++`, elem);
}
map.set("ins", ins);
function small(elem) {
return common("small", (textContent) => `<small>${textContent}</small>`, elem);
}
map.set("small", small);
function sup(elem) {
return common("sup", (textContent) => `<sup>${textContent}</sup>`, elem);
}
map.set("sup", sup);
function sub(elem) {
return common("sub", (textContent) => `<sub>${textContent}</sub>`, elem);
}
map.set("sub", sub);
const nodeName = element.nodeName.toLowerCase();
const fn = map.get(nodeName);
if (fn) {
const obj = await fn(element);
if (!obj) {
return null;
}
const { dom, text, images } = obj;
if (element instanceof Element && element.getAttribute("data-keep")) {
const dk = element.getAttribute("data-keep");
const keeps = dk.split(",").map((k) => k.trim());
keeps.forEach((k) => {
if (dom instanceof HTMLElement && element.getAttribute(k)) {
dom.setAttribute(k, element.getAttribute(k));
}
});
}
return { dom, text, images };
}
else {
const output = defaultHandler(element);
_log__WEBPACK_IMPORTED_MODULE_1___default().warn("[cleanDom]发现未知行内元素!");
_log__WEBPACK_IMPORTED_MODULE_1___default().warn([element.nodeName.toLowerCase(), element]);
return output;
}
}
async function loop(nodes, _outDom) {
let _outText = "";
let _outImages = [];
for (const node of nodes) {
const bNname = node.nodeName.toLowerCase();
if (bNname === "textarea" || BlockElements.includes(bNname)) {
if (node instanceof HTMLElement) {
const tobj = await blockElement(node);
if (tobj) {
const { dom: tdom, text: ttext, images: timages } = tobj;
_outDom.appendChild(tdom);
_outText = _outText + "\n" + ttext + "\n";
_outImages = _outImages.concat(timages);
continue;
}
}
}
if (node instanceof Text || InlineElements.includes(bNname)) {
const tobj = await inlineElement(node);
if (tobj) {
const { dom: tdom, text: ttext, images: timages } = tobj;
_outDom.appendChild(tdom);
_outText = _outText + ttext;
_outImages = _outImages.concat(timages);
continue;
}
}
}
return {
dom: _outDom,
text: _outText,
images: _outImages,
};
}
async function awaitAttachments({ dom, text, images, }) {
const attachments = await Promise.all(images);
attachments.forEach((attach) => {
if (attach.comments) {
dom.innerHTML = dom.innerHTML.replaceAll(attach.comments, attach.name);
text = text.replaceAll(attach.comments, attach.name);
}
});
return {
dom,
text,
images: attachments,
};
}
function postHook({ dom, text, images, }) {
htmlTrim(dom);
dom = convertBr(dom);
Array.from(dom.children).forEach((child) => child.replaceWith(convertBr(child)));
convertBlankParagraphElement(dom);
text = text.trim();
return {
dom,
text,
images,
};
}
}
function htmlTrim(dom) {
const childNodes = Array.from(dom.childNodes);
remove(childNodes);
const childNodesR = Array.from(dom.childNodes).reverse();
remove(childNodesR);
function remove(nodes) {
for (const node of nodes) {
if (node instanceof Text) {
if (node.textContent?.trim() === "") {
node.remove();
continue;
}
else {
break;
}
}
if (node instanceof HTMLBRElement) {
node.remove();
continue;
}
if (node instanceof HTMLParagraphElement && isBlankParagraph(node)) {
node.remove();
continue;
}
if (node instanceof HTMLElement && node.nodeName.toLowerCase() !== "br") {
break;
}
}
}
}
function isBlankParagraph(node) {
return (node instanceof HTMLParagraphElement &&
node.innerText.trim() === "" &&
Array.from(node.childNodes).every((n) => n instanceof Text));
}
function convertBr(dom, force = false) {
if (onlyTextAndBr(dom) && (countBr(dom) > 4 || force)) {
const outDom = document.createElement("div");
const childNodes = dom.childNodes;
let brCount = 0;
let buffer = [];
for (const node of Array.from(childNodes)) {
if (node instanceof HTMLBRElement) {
if (brCount === 0 && buffer.length !== 0) {
const p = document.createElement("p");
buffer.forEach((n) => p.appendChild(n));
outDom.appendChild(p);
buffer = [];
}
brCount++;
continue;
}
if (node instanceof HTMLHRElement) {
brCount = 0;
if (buffer.length !== 0) {
const p = document.createElement("p");
buffer.forEach((n) => p.appendChild(n));
outDom.appendChild(p);
buffer = [];
}
const hr = document.createElement("hr");
outDom.appendChild(hr);
continue;
}
if (brCount === 0) {
buffer.push(node);
continue;
}
else {
if (brCount > 2) {
let brRemainder = brCount - 2;
const brp = document.createElement("p");
while (brRemainder > 0) {
brRemainder--;
const br = document.createElement("br");
brp.appendChild(br);
}
outDom.appendChild(brp);
}
brCount = 0;
buffer.push(node);
continue;
}
}
brCount = 0;
if (buffer.length !== 0) {
const p = document.createElement("p");
buffer.forEach((n) => p.appendChild(n));
outDom.appendChild(p);
buffer = [];
}
return outDom;
}
else {
return dom;
}
function countBr(d) {
return Array.from(d.childNodes).filter((n) => n instanceof HTMLBRElement)
.length;
}
function onlyTextAndBr(d) {
return Array.from(d.childNodes)
.map((n) => n.nodeName.toLowerCase())
.every((nn) => ["#text", "hr", ...InlineElements].includes(nn));
}
}
function convertBlankParagraphElement(dom) {
const nodes = Array.from(dom.children);
let count = 0;
let buffer = [];
for (const node of nodes) {
if (isBlankParagraph(node)) {
count++;
buffer.push(node);
}
else if (count !== 0) {
const p = document.createElement("p");
while (count > 0) {
count--;
const br = document.createElement("br");
p.appendChild(br);
}
buffer[0].replaceWith(p);
buffer.forEach((n) => n.remove());
count = 0;
buffer = [];
}
}
}
function convertFixWidthText(node, width = 35, out = document.createElement("div")) {
const ns = node.textContent?.split("\n") ?? [];
let text = "";
for (const n of ns) {
if (n === "") {
out.appendChild(new Text(text));
out.appendChild(document.createElement("br"));
text = "";
continue;
}
if ((0,_dom__WEBPACK_IMPORTED_MODULE_2__/* .fullWidthLength */ .QJ)(n) > width - 5 && (0,_dom__WEBPACK_IMPORTED_MODULE_2__/* .fullWidthLength */ .QJ)(n) < width + 5) {
text = text + n;
continue;
}
else {
if (text !== "") {
text = text + n;
out.appendChild(new Text(text));
out.appendChild(document.createElement("br"));
text = "";
continue;
}
else {
out.appendChild(new Text(n));
out.appendChild(document.createElement("br"));
continue;
}
}
}
if (text !== "") {
out.appendChild(new Text(text));
out.appendChild(document.createElement("br"));
text = "";
}
htmlTrim(out);
return convertBr(out);
}
function convertFixWidth(node, width = 35) {
Array.from(node.querySelectorAll("br")).forEach((node) => {
const previous = node.previousSibling;
const next = node.nextSibling;
if (previous instanceof Text &&
next instanceof Text &&
(previous.textContent ? (0,_dom__WEBPACK_IMPORTED_MODULE_2__/* .fullWidthLength */ .QJ)(previous.textContent) : 0) >
width - 5 &&
(previous.textContent ? (0,_dom__WEBPACK_IMPORTED_MODULE_2__/* .fullWidthLength */ .QJ)(previous.textContent) : 0) <
width + 5) {
node.remove();
}
});
const group = (texts) => {
const out = [];
let group = [];
let whole = "";
for (const text of texts) {
const w = text.wholeText;
if (whole !== w) {
if (group.length !== 0) {
out.push(group);
}
whole = w;
group = [text];
}
else {
group.push(text);
}
}
if (group.length !== 0) {
out.push(group);
}
return out;
};
const merge = (groups) => {
for (const g of groups) {
const old = g[0];
const newText = new Text(old.wholeText);
old.replaceWith(newText);
g.forEach((t) => t.remove());
}
};
const ts = Array.from(node.childNodes).filter((node) => node instanceof Text && node.wholeText !== node.textContent);
const gts = group(ts);
merge(gts);
Array.from(node.childNodes)
.filter((node) => node instanceof Text)
.forEach((text) => {
const p = document.createElement("p");
convertFixWidthText(text, width, p);
text.replaceWith(p);
});
Array.from(node.querySelectorAll("p"))
.filter((p) => p.innerText.trim() === "" &&
(0,_dom__WEBPACK_IMPORTED_MODULE_2__/* .getPreviousSibling */ .UN)(p) instanceof HTMLElement &&
(0,_dom__WEBPACK_IMPORTED_MODULE_2__/* .getNextSibling */ .wX)(p) instanceof HTMLElement)
.forEach((p) => p.remove());
Array.from(node.querySelectorAll("p"))
.filter((p) => (0,_dom__WEBPACK_IMPORTED_MODULE_2__/* .getPreviousBrCount */ .Jw)(p) === 2)
.forEach((p) => (0,_dom__WEBPACK_IMPORTED_MODULE_2__/* .removePreviousBr */ .S0)(p));
if (isFixWidthP(node)) {
const ps = Array.from(node.querySelectorAll("p"));
let text = "";
for (const node of ps) {
const n = node.innerText.trim();
if ((0,_dom__WEBPACK_IMPORTED_MODULE_2__/* .fullWidthLength */ .QJ)(n) > width - 5 && (0,_dom__WEBPACK_IMPORTED_MODULE_2__/* .fullWidthLength */ .QJ)(n) < width + 5) {
text = text + n;
node.remove();
continue;
}
else {
if (text !== "") {
text = text + n;
const newP = document.createElement("p");
newP.innerText = text;
node.replaceWith(newP);
text = "";
continue;
}
else {
continue;
}
}
}
}
function isFixWidthP(node) {
const lengths = Array.from(node.querySelectorAll("p")).map((p) => (0,_dom__WEBPACK_IMPORTED_MODULE_2__/* .fullWidthLength */ .QJ)(p.innerText.trim()));
const lt = lengths.filter((i) => i > width + 5).length;
return lt < 5;
}
}
function isFixWidth(node, width = 35) {
let ns;
if (node instanceof Text) {
ns = node.textContent?.split("\n").map((n) => n.trim()) ?? [];
}
if (node instanceof HTMLElement) {
const reducer = (out, cur) => {
if (cur instanceof Text) {
const t = cur.textContent?.trim() ?? "";
if (t.includes("\n")) {
t.split("\n")
.map((n) => n.trim())
.forEach((n) => out.push(n));
return out;
}
else {
out.push(t);
return out;
}
}
else {
return out;
}
};
ns = Array.from(node.childNodes).reduce(reducer, []);
}
if (!ns) {
throw new Error("ns is null");
}
const lengths = ns.map((l) => (0,_dom__WEBPACK_IMPORTED_MODULE_2__/* .fullWidthLength */ .QJ)(l));
const lt = lengths.filter((i) => i > width + 5).length;
return lt < 5;
}
/***/ }),
/***/ "./src/lib/dom.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Fv: () => (/* binding */ childNodesCopy),
/* harmony export */ Jw: () => (/* binding */ getPreviousBrCount),
/* harmony export */ K4: () => (/* binding */ getNodeTextLength),
/* harmony export */ Md: () => (/* binding */ insertBrBeforeText),
/* harmony export */ QJ: () => (/* binding */ fullWidthLength),
/* harmony export */ S0: () => (/* binding */ removePreviousBr),
/* harmony export */ Sf: () => (/* binding */ rm2),
/* harmony export */ UN: () => (/* binding */ getPreviousSibling),
/* harmony export */ Zn: () => (/* binding */ escapeHTML),
/* harmony export */ _r: () => (/* binding */ createStyle),
/* harmony export */ a_: () => (/* binding */ createEl),
/* harmony export */ d6: () => (/* binding */ sandboxed),
/* harmony export */ dK: () => (/* binding */ isHidden),
/* harmony export */ e_: () => (/* binding */ getMaxDepth),
/* harmony export */ j3: () => (/* binding */ rms),
/* harmony export */ pI: () => (/* binding */ convertHTMLtoXHTML),
/* harmony export */ rm: () => (/* binding */ rm),
/* harmony export */ wX: () => (/* binding */ getNextSibling)
/* harmony export */ });
/* unused harmony export getCookie */
function rm(selector, all = false, dom) {
if (all) {
const rs = dom.querySelectorAll(selector);
rs.forEach((e) => e.remove());
}
else {
const r = dom.querySelector(selector);
if (r) {
r.remove();
}
}
}
function rm2(filters, dom) {
function doRemove(nodes) {
Array.from(nodes.childNodes).forEach((node) => {
let text;
if (node.nodeName === "#text") {
text = node.textContent ?? "";
}
else {
text = node.innerText;
}
if (text.length < 200 || node instanceof Text) {
for (const filter of filters) {
if (filter instanceof RegExp) {
if (filter.test(text)) {
node.remove();
}
}
if (typeof filter === "string") {
if (text.includes(filter)) {
node.remove();
}
}
}
}
else {
doRemove(node);
}
});
}
doRemove(dom);
}
function rms(filters, dom) {
for (const ad of filters) {
if (typeof ad === "string") {
dom.innerHTML = dom.innerHTML.replaceAll(ad, "");
}
else if (ad instanceof RegExp) {
dom.innerHTML = dom.innerHTML.replace(ad, "");
}
}
return dom;
}
function childNodesCopy(src, dest) {
const childrens = Array.from(src.childNodes);
childrens.forEach((node) => dest.appendChild(node));
}
function getMaxDepth(element) {
const descendants = element.querySelectorAll("*");
const depths = Array.from(descendants)
.filter((elem) => elem.childElementCount === 0)
.map((elem) => getDepth(elem, 0));
return Math.max(...depths);
function getDepth(elem, depth) {
if (element.isSameNode(elem)) {
return depth;
}
else {
const parentElement = elem.parentElement;
if (parentElement) {
return getDepth(parentElement, depth + 1);
}
else {
return depth;
}
}
}
}
function getNodeTextLength(element) {
return Array.from(element.childNodes)
.filter((node) => node.nodeName === "#text")
.reduce((sum, curNode) => {
if (!sum) {
sum = 0;
}
sum = sum + (curNode.textContent?.trim().length ?? 0);
return sum;
}, 0);
}
function sandboxed(code) {
const frame = document.createElement("iframe");
document.body.appendChild(frame);
const argVerify = /^[$A-Z_][0-9A-Z_$]*$/i;
if (frame.contentWindow) {
const F = frame.contentWindow.Function;
const args = Object.keys(frame.contentWindow)
.filter((it) => argVerify.test(it))
.join();
document.body.removeChild(frame);
return F(args, code)();
}
}
function getCookie(name) {
const reg = new RegExp("(^| )" + name + "=([^;]*)(;|$)");
const arr = document.cookie.match(reg);
if (arr) {
return arr[2];
}
else {
return null;
}
}
function createEl(el) {
const _el = document.createElement("div");
_el.innerHTML = el;
if (_el.childElementCount === 1 && _el.firstElementChild) {
return _el.firstElementChild;
}
else {
throw new Error("Create HTMLElement Failed!");
}
}
function createStyle(style, id) {
const el = createEl(`<style>${style}</style>`);
if (id) {
el.id = id;
}
return el;
}
function getNextSibling(node) {
if (node.nextSibling instanceof HTMLElement) {
return node.nextSibling;
}
if (node.nextSibling instanceof Text) {
if (node.nextSibling.textContent?.trim() !== "") {
return node.nextSibling;
}
else {
return node.nextSibling.nextSibling;
}
}
}
function getPreviousSibling(node) {
if (node.previousSibling instanceof HTMLElement) {
return node.previousSibling;
}
if (node.previousSibling instanceof Text) {
if (node.previousSibling.textContent?.trim() !== "") {
return node.previousSibling;
}
else {
return node.previousSibling.previousSibling;
}
}
}
function getPreviousBrCount(node) {
const previous = getPreviousSibling(node);
if (previous instanceof HTMLBRElement) {
return getPreviousBrCount(previous) + 1;
}
else {
return 0;
}
}
function removePreviousBr(node) {
const previous = getPreviousSibling(node);
if (node instanceof HTMLBRElement) {
node.remove();
}
if (previous instanceof HTMLBRElement) {
return removePreviousBr(previous);
}
else {
return;
}
}
function fullWidthLength(input) {
const length = Array.from(input).reduce((p, c) => {
const code = c.codePointAt(0);
if (code === undefined) {
return p;
}
if (code < 128) {
return p + 0.5;
}
else {
return p + 1;
}
}, 0);
return length;
}
function convertHTMLtoXHTML(input) {
let doc;
if (typeof input === "string") {
doc = new DOMParser().parseFromString(input, "text/html");
}
if (input instanceof Document) {
doc = input;
}
if (doc instanceof Document) {
return new XMLSerializer().serializeToString(doc);
}
else {
throw new Error("input format error!");
}
}
function insertBrBeforeText(elem) {
for (const node of Array.from(elem.childNodes)) {
if (node instanceof Text && node.textContent?.trim() !== "") {
node.parentElement?.insertBefore(document.createElement("br"), node);
}
}
}
function isHidden(el) {
return el.offsetParent === null;
}
function escapeHTML(str) {
const p = document.createElement("p");
p.appendChild(document.createTextNode(str));
return p.innerHTML;
}
/***/ }),
/***/ "./src/lib/hash.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Q: () => (/* binding */ calculateSha1)
/* harmony export */ });
/* harmony import */ var crypto_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("crypto-js");
/* harmony import */ var crypto_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(crypto_js__WEBPACK_IMPORTED_MODULE_0__);
async function calculateSha1(blob) {
if (typeof crypto?.subtle?.digest === "function") {
const arrayBuffer = await blob.arrayBuffer();
const hashBuffer = await crypto.subtle.digest("SHA-1", arrayBuffer);
const hashArray = Array.from(new Uint8Array(hashBuffer));
const hashHex = hashArray
.map((b) => b.toString(16).padStart(2, "0"))
.join("");
return hashHex;
}
else {
return new Promise((resolve, rejects) => {
const reader = new FileReader();
reader.readAsArrayBuffer(blob);
reader.onloadend = () => {
if (reader.result) {
const wordArray = crypto_js__WEBPACK_IMPORTED_MODULE_0__.lib.WordArray.create(reader.result);
const hash = crypto_js__WEBPACK_IMPORTED_MODULE_0__.SHA1(wordArray).toString();
resolve(hash);
}
else {
rejects(Error("计算MD5值出错"));
return;
}
};
});
}
}
/***/ }),
/***/ "./src/lib/http.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ J5: () => (/* binding */ fetchWithRetry),
/* harmony export */ _V: () => (/* binding */ gfetch),
/* harmony export */ bx: () => (/* binding */ ggetText),
/* harmony export */ eF: () => (/* binding */ getFrameContentCondition),
/* harmony export */ kP: () => (/* binding */ getHtmlDomWithRetry),
/* harmony export */ pG: () => (/* binding */ ggetHtmlDOM),
/* harmony export */ q4: () => (/* binding */ getText),
/* harmony export */ wA: () => (/* binding */ getHtmlDOM)
/* harmony export */ });
/* unused harmony exports fetchWithTimeout, ggetHtmlDomWithRetry, getFrameContentEvent */
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _setting__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/setting.ts");
/* harmony import */ var _GM__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/lib/GM.ts");
/* harmony import */ var _misc__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/misc.ts");
globalThis.fetch = new Proxy(globalThis.fetch, {
apply(target, thisArg, argArray) {
_log__WEBPACK_IMPORTED_MODULE_0___default().debug("[debug]fetch:");
_log__WEBPACK_IMPORTED_MODULE_0___default().debug(argArray);
return Reflect.apply(target, thisArg, argArray);
},
});
async function fetchWithRetry(input, init) {
let retry = _setting__WEBPACK_IMPORTED_MODULE_1__/* .retryLimit */ .Iz;
while (retry > 0) {
const resp = await fetch(input, init);
if (resp.ok) {
return resp;
}
else {
await (0,_misc__WEBPACK_IMPORTED_MODULE_2__/* .sleep */ .yy)(1000 * (_setting__WEBPACK_IMPORTED_MODULE_1__/* .retryLimit */ .Iz - retry));
retry--;
}
}
throw new Error(`Fetch with retry failed! Url: ${input}`);
}
async function fetchWithTimeout(input, options = {}, timeout = 8000) {
const controller = new AbortController();
const id = setTimeout(() => controller.abort(), timeout);
const response = await fetch(input, {
...options,
signal: controller.signal,
});
clearTimeout(id);
return response;
}
function gfetch(url, { method = "GET", headers, data, cookie, binary, nocache, revalidate, timeout, context, responseType, overrideMimeType, anonymous, user, password, } = {}) {
return new Promise((resolve, reject) => {
_log__WEBPACK_IMPORTED_MODULE_0___default().debug("[debug]gfetch:");
_log__WEBPACK_IMPORTED_MODULE_0___default().debug(Array.from(arguments));
(0,_GM__WEBPACK_IMPORTED_MODULE_3__/* ._GM_xmlhttpRequest */ .nV)({
url,
method,
headers,
data,
cookie,
binary,
nocache,
revalidate,
timeout,
context,
responseType,
overrideMimeType,
anonymous,
user,
password,
onload: (obj) => {
resolve(obj);
},
onerror: (err) => {
reject(err);
},
});
});
}
async function getText(input, charset, init, test = (response) => Promise.resolve(false)) {
if (typeof input === "string") {
const _url = new URL(input);
if (document.location.protocol === "https:" && _url.protocol === "http:") {
_url.protocol = "https:";
input = _url.toString();
}
}
if (charset === undefined) {
return fetch(input, init)
.then(async (response) => {
if (response.ok || (await test(response))) {
return response.text();
}
else {
throw new Error(`Bad response! ${input}`);
}
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_0___default().error(error));
}
else {
return fetch(input, init)
.then(async (response) => {
if (response.ok || (await test(response))) {
return response.arrayBuffer();
}
else {
throw new Error(`Bad response! ${input}`);
}
})
.then((buffer) => {
const decoder = new TextDecoder(charset);
const text = decoder.decode(buffer);
return text;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_0___default().error(error));
}
}
async function getHtmlDOM(input, charset, init, test = (response) => Promise.resolve(false)) {
const htmlText = await getText(input, charset, init, test);
if (!htmlText) {
throw new Error("Fetch Content failed!");
}
const doc = new DOMParser().parseFromString(htmlText, "text/html");
if (!doc.querySelector("base")) {
const base = doc.createElement("base");
if (typeof input === "string") {
base.href = input;
}
else {
base.href = input.url;
}
doc.head.appendChild(base);
}
return doc;
}
async function getHtmlDomWithRetry(input, charset, init, test = (response) => Promise.resolve(false)) {
let retry = _setting__WEBPACK_IMPORTED_MODULE_1__/* .retryLimit */ .Iz;
let doc = null;
while (retry > 0) {
try {
doc = await getHtmlDOM(input, charset, init, test);
retry = 0;
}
catch (error) {
_log__WEBPACK_IMPORTED_MODULE_0___default().error(`抓取${input}失败,重试第${_setting__WEBPACK_IMPORTED_MODULE_1__/* .retryLimit */ .Iz - retry}次。`);
_log__WEBPACK_IMPORTED_MODULE_0___default().error(error);
retry--;
await (0,_misc__WEBPACK_IMPORTED_MODULE_2__/* .sleep */ .yy)(1000 * (_setting__WEBPACK_IMPORTED_MODULE_1__/* .retryLimit */ .Iz - retry));
}
}
return doc;
}
async function ggetText(url, charset, init, test = (response) => Promise.resolve(false)) {
let _init = init ? (0,_misc__WEBPACK_IMPORTED_MODULE_2__/* .deepcopy */ .OJ)(init) : undefined;
if (charset === undefined) {
return gfetch(url, init)
.then(async (response) => {
if ((response.status >= 200 && response.status <= 299) ||
(await test(response))) {
return response.responseText;
}
else {
throw new Error(`Bad response! ${url}`);
}
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_0___default().error(error));
}
else {
if (_init) {
_init.responseType = "arraybuffer";
}
else {
_init = { responseType: "arraybuffer" };
}
return gfetch(url, _init)
.then(async (response) => {
if ((response.status >= 200 && response.status <= 299) ||
(await test(response))) {
return response.response;
}
else {
throw new Error(`Bad response! ${url}`);
}
})
.then((buffer) => {
const decoder = new TextDecoder(charset);
const text = decoder.decode(buffer);
return text;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_0___default().error(error));
}
}
async function ggetHtmlDOM(url, charset, init, test = (response) => Promise.resolve(false)) {
const htmlText = await ggetText(url, charset, init, test);
if (!htmlText) {
throw new Error("Fetch Content failed!");
}
const doc = new DOMParser().parseFromString(htmlText, "text/html");
if (!doc.querySelector("base")) {
const base = doc.createElement("base");
base.href = url;
doc.head.appendChild(base);
}
return doc;
}
async function ggetHtmlDomWithRetry(url, charset, init, test = (response) => Promise.resolve(false)) {
let retry = retryLimit;
let doc = null;
while (retry > 0) {
try {
doc = await ggetHtmlDOM(url, charset, init, test);
retry = 0;
}
catch (error) {
log.error(`抓取${url}失败,重试第${retryLimit - retry}次。`);
retry--;
await sleep(1000 * (retryLimit - retry));
}
}
return doc;
}
function getFrameContentEvent(url, timeout = 0, eventType = "load", sandboxs) {
const frame = document.createElement("iframe");
frame.src = url;
frame.width = "1";
frame.height = "1";
sandboxs?.forEach((s) => frame.sandbox.add(s));
frame.addEventListener("error", (error) => log.error(error));
const promise = new Promise((resolve, reject) => {
frame.addEventListener(eventType, function (event) {
const frameSelf = event.target;
setTimeout(() => {
if (!frameSelf) {
reject(new Error("EventTarget Not Found!"));
}
const doc = frameSelf.contentWindow?.document ?? null;
frameSelf.remove();
resolve(doc);
}, timeout);
});
});
log.debug("[debug]getFrameContent:" + url);
document.body.appendChild(frame);
return promise;
}
async function getFrameContentCondition(url, stopCondition, sandboxs) {
const frame = document.createElement("iframe");
frame.src = url;
frame.width = "1";
frame.height = "1";
sandboxs?.forEach((s) => frame.sandbox.add(s));
frame.addEventListener("error", (error) => _log__WEBPACK_IMPORTED_MODULE_0___default().error(error));
_log__WEBPACK_IMPORTED_MODULE_0___default().debug("[debug]getFrameContent:" + url);
const promise = new Promise((resolve, reject) => {
if (!frame) {
reject(new Error("Frame Not Found!"));
}
let timerId = 0;
const loopFunc = () => {
if (stopCondition(frame)) {
const doc = frame.contentWindow?.document ?? null;
frame.remove();
window.clearInterval(timerId);
resolve(doc);
}
};
timerId = window.setInterval(loopFunc, 1000);
setTimeout(() => {
frame.remove();
window.clearInterval(timerId);
reject(new Error("Frame Timeout!"));
}, 30 * 1000);
});
document.body.appendChild(frame);
return promise;
}
/***/ }),
/***/ "./src/lib/misc.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ N4: () => (/* binding */ randomUUID),
/* harmony export */ OH: () => (/* binding */ mimetyepToCompressible),
/* harmony export */ OJ: () => (/* binding */ deepcopy),
/* harmony export */ ZA: () => (/* binding */ saveToArchiveOrg),
/* harmony export */ dB: () => (/* binding */ extensionToMimetype),
/* harmony export */ rr: () => (/* binding */ concurrencyRun),
/* harmony export */ y1: () => (/* binding */ range),
/* harmony export */ yy: () => (/* binding */ sleep)
/* harmony export */ });
/* unused harmony exports regexpEscape, mean, sd */
/* harmony import */ var _main_main__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/main/main.ts");
/* harmony import */ var _GM__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/GM.ts");
/* harmony import */ var mime_db__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./node_modules/mime-db/index.js");
function concurrencyRun(list, limit, asyncHandle, options = {}) {
const { signal, reason } = options;
const listCopy = [...list];
const asyncList = [];
while (limit--) {
asyncList.push(recursion(listCopy));
}
return Promise.all(asyncList);
async function recursion(arr) {
if (signal?.aborted) {
if (reason) {
throw new _main_main__WEBPACK_IMPORTED_MODULE_1__/* .ExpectError */ .K5(reason);
}
else {
throw new _main_main__WEBPACK_IMPORTED_MODULE_1__/* .ExpectError */ .K5("concurrencyRun was aborted!");
}
}
await asyncHandle(arr.shift());
if (arr.length !== 0) {
return recursion(arr);
}
else {
return "finish!";
}
}
}
function sleep(ms) {
return new Promise((resolve) => setTimeout(resolve, ms));
}
function deepcopy(obj) {
return JSON.parse(JSON.stringify(obj));
}
function regexpEscape(str) {
return str.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
}
async function saveToArchiveOrg(url) {
const req = await fetch("https://save.bgme.bid/save", {
body: JSON.stringify({
url,
}),
headers: {
"content-type": "application/json; charset=utf-8",
"x-requested-with": `novel-downloader ${_GM__WEBPACK_IMPORTED_MODULE_2__/* ._GM_info */ .JX.script.version}; ${_GM__WEBPACK_IMPORTED_MODULE_2__/* ._GM_info */ .JX.scriptHandler} ${_GM__WEBPACK_IMPORTED_MODULE_2__/* ._GM_info */ .JX.version}`,
},
method: "POST",
});
return await req.json();
}
function mean(list) {
if (list.length === 0) {
return 0;
}
const sum = list.reduce((p, c) => p + c);
return sum / list.length;
}
function sd(list) {
if (list.length === 0) {
return 0;
}
const m = mean(list);
const variance = list.map((x) => Math.pow(x - m, 2)).reduce((p, c) => p + c) / list.length;
const sd = Math.sqrt(variance);
return sd;
}
function createUUID() {
const s = new Array(36);
const hexDigits = "0123456789abcdef";
for (let i = 0; i < 36; i++) {
s[i] = hexDigits.substr(Math.floor(Math.random() * 0x10), 1);
}
s[14] = "4";
s[19] = hexDigits.substr((s[19] & 0x3) | 0x8, 1);
s[8] = s[13] = s[18] = s[23] = "-";
const uuid = s.join("");
return uuid;
}
function randomUUID() {
if (typeof crypto.randomUUID === "function") {
return crypto.randomUUID();
}
else {
return createUUID();
}
}
function extensionToMimetype(ext) {
for (const [mimetype, entry] of Object.entries(mime_db__WEBPACK_IMPORTED_MODULE_0__)) {
if (entry.extensions?.includes(ext)) {
return mimetype;
}
}
return "application/octet-stream";
}
function mimetyepToCompressible(mimeType) {
if (mime_db__WEBPACK_IMPORTED_MODULE_0__[mimeType]) {
const entry = mime_db__WEBPACK_IMPORTED_MODULE_0__[mimeType];
if (entry["compressible"]) {
return entry["compressible"];
}
}
return false;
}
function range(size, startAt = 0) {
return [...Array(size).keys()].map((i) => i + startAt);
}
/***/ }),
/***/ "./src/lib/readability.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ fetchAndParse: () => (/* binding */ fetchAndParse),
/* harmony export */ gfetchAndParse: () => (/* binding */ gfetchAndParse),
/* harmony export */ parse: () => (/* binding */ parse)
/* harmony export */ });
/* harmony import */ var _mozilla_readability__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./node_modules/@mozilla/readability/index.js");
/* harmony import */ var _mozilla_readability__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_mozilla_readability__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _http__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/http.ts");
function parse(doc, options) {
const obj = new _mozilla_readability__WEBPACK_IMPORTED_MODULE_0__.Readability(doc, options).parse();
if (obj) {
if (typeof obj.content === "string") {
obj.content = (0,_dom__WEBPACK_IMPORTED_MODULE_1__/* .createEl */ .a_)(obj.content);
}
}
return obj;
}
async function fetchAndParse(url, charset, init, patch, options) {
let doc = await (0,_http__WEBPACK_IMPORTED_MODULE_2__/* .getHtmlDOM */ .wA)(url, charset, init);
if (typeof patch === "function") {
doc = patch(doc);
}
return parse(doc, options);
}
async function gfetchAndParse(url, charset, init, patch, options) {
let doc = await (0,_http__WEBPACK_IMPORTED_MODULE_2__/* .ggetHtmlDOM */ .pG)(url, charset, init);
if (typeof patch === "function") {
doc = patch(doc);
}
return parse(doc, options);
}
/***/ }),
/***/ "./src/lib/rule.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ $l: () => (/* binding */ chapterHiddenFix),
/* harmony export */ HV: () => (/* binding */ introDomHandle),
/* harmony export */ hR: () => (/* binding */ deDuplicate),
/* harmony export */ lq: () => (/* binding */ getSectionName),
/* harmony export */ sy: () => (/* binding */ centerDetct),
/* harmony export */ u1: () => (/* binding */ nextPageParse)
/* harmony export */ });
/* unused harmony export reIndex */
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _cleanDOM__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _http__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var p_limit__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./node_modules/p-limit/index.js");
/* harmony import */ var _main_main__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/main/main.ts");
async function introDomHandle(introDom, domPatch) {
if (introDom === null) {
return [null, null, null];
}
else {
if (domPatch) {
introDom = domPatch(introDom.cloneNode(true));
}
const { dom: introCleanDom, text: introCleantext, images: introCleanimages, } = await (0,_cleanDOM__WEBPACK_IMPORTED_MODULE_1__/* .cleanDOM */ .an)(introDom, "TM");
return [introCleantext, introCleanDom, introCleanimages];
}
}
async function nextPageParse({ chapterName, chapterUrl, charset, selector, contentPatch, getNextPage, continueCondition, enableCleanDOM, getHtmlDomFunc = _http__WEBPACK_IMPORTED_MODULE_2__/* .getHtmlDOM */ .wA, }) {
_log__WEBPACK_IMPORTED_MODULE_3___default().debug(`[Chapter]请求 ${chapterUrl}`);
let nowUrl = chapterUrl;
let doc = await getHtmlDomFunc(chapterUrl, charset);
const content = document.createElement("div");
let flag = false;
do {
let _content = doc.querySelector(selector);
const nextLink = getNextPage(doc);
if (continueCondition(_content, nextLink)) {
if (nextLink !== nowUrl) {
flag = true;
}
else {
_log__WEBPACK_IMPORTED_MODULE_3___default().error("网站页面出错,URL: " + nowUrl);
flag = false;
}
}
else {
flag = false;
}
_content = contentPatch(_content, doc);
for (const _c of Array.from(_content.childNodes)) {
content.appendChild(_c.cloneNode(true));
}
if (flag) {
_log__WEBPACK_IMPORTED_MODULE_3___default().debug(`[Chapter]请求 ${nextLink}`);
nowUrl = nextLink;
doc = await getHtmlDomFunc(nextLink, charset);
}
} while (flag);
let dom, text, images;
if (enableCleanDOM || enableCleanDOM === undefined) {
const obj = await (0,_cleanDOM__WEBPACK_IMPORTED_MODULE_1__/* .cleanDOM */ .an)(content, "TM");
dom = obj.dom;
text = obj.text;
images = obj.images;
}
else {
dom = null;
text = null;
images = null;
}
return {
chapterName,
contentRaw: content,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: null,
};
}
function getSectionName(chapterElement, sections, getName) {
const _sections = Array.from(sections);
let sectionName = null;
for (const sElem of _sections) {
const position = chapterElement.compareDocumentPosition(sElem);
if (position & Node.DOCUMENT_POSITION_DISCONNECTED) {
return null;
}
if (position & Node.DOCUMENT_POSITION_PRECEDING) {
sectionName = getName(sElem);
}
if (position & Node.DOCUMENT_POSITION_FOLLOWING) {
break;
}
}
return sectionName;
}
function centerDetct(element) {
const docEl = document.documentElement;
const bodyEl = document.body;
const vw = Math.min(docEl.clientWidth, window.innerWidth);
const vh = Math.min(docEl.clientHeight, window.innerHeight);
const tolx = vw * 0.15;
const toly = Math.min(bodyEl.scrollHeight * 0.1, vh * 0.3);
const rect = element.getBoundingClientRect();
const distanceToTop = window.scrollY + rect.top;
const distanceToBottom = bodyEl.scrollHeight - distanceToTop - element.scrollHeight;
const distanceToRight = vw - rect.right;
const percentY = element.scrollHeight / bodyEl.scrollHeight;
if (rect.left < tolx ||
distanceToRight < tolx ||
distanceToTop < toly ||
distanceToBottom < toly) {
return [false, element, percentY];
}
return [true, element, percentY];
}
function reIndex(chapters) {
chapters = chapters.sort((a, b) => a.chapterNumber - b.chapterNumber);
let i = 0;
let sectionName = "";
let s = 0;
let si = 0;
for (const chapter of chapters) {
i++;
chapter.chapterNumber = i;
if (chapter.sectionName) {
if (chapter.sectionName !== sectionName) {
sectionName = chapter.sectionName;
s++;
si = 0;
}
si++;
chapter.sectionNumber = s;
chapter.sectionChapterNumber = si;
}
}
return chapters;
}
function deDuplicate(chapters) {
const obj = chapters.reduce((obj, cur) => {
const url = cur.chapterUrl;
if (obj[url] === undefined) {
obj[url] = cur;
}
else if (Array.isArray(obj[url])) {
obj[url].push(cur);
}
else {
obj[url] = [obj[url], cur];
}
return obj;
}, {});
const reducer = (out, cur) => {
if (Array.isArray(cur)) {
const url = cur[0].chapterUrl;
if (url === "") {
out.push(...cur);
}
else {
out.push(cur.sort((a, b) => a.chapterNumber - b.chapterNumber).slice(-1)[0]);
}
}
else {
out.push(cur);
}
return out;
};
const results = Object.values(obj).reduce(reducer, []);
reIndex(results);
return results;
}
async function chapterHiddenFix(book, invalidTest, getPrevHref, concurrencyLimit, sleepTime = 500, getHtmlDomFunc = _http__WEBPACK_IMPORTED_MODULE_2__/* .getHtmlDOM */ .wA) {
const { chapters } = book;
const invalidChapterList = chapters.filter(invalidTest);
if (concurrencyLimit === 1) {
for (const ic of invalidChapterList) {
fix(ic, chapters);
await new Promise(resolve => setTimeout(resolve, Math.random() * 100 + sleepTime));
}
}
else {
const limit = (0,p_limit__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .A)(concurrencyLimit);
const tasks = invalidChapterList.map((ic) => {
return limit(() => fix(ic, chapters));
});
await Promise.all(tasks);
}
async function fix(invalidChapter, chapterList) {
const no = invalidChapter.chapterNumber;
const nextChapter = chapterList.filter((c) => c.chapterNumber === no + 1)?.[0];
if (nextChapter) {
const nextChapterUrl = nextChapter.chapterUrl;
const doc = await getHtmlDomFunc(nextChapterUrl, nextChapter.charset);
const href = getPrevHref(doc);
if (href) {
invalidChapter.chapterUrl = href;
invalidChapter.status = _main_main__WEBPACK_IMPORTED_MODULE_4__/* .Status */ .nW.pending;
}
return invalidChapter;
}
}
}
/***/ }),
/***/ "./src/log.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ M6: () => (/* binding */ saveLogTextToFile),
/* harmony export */ gh: () => (/* binding */ getLogText),
/* harmony export */ kc: () => (/* binding */ logText)
/* harmony export */ });
/* harmony import */ var file_saver__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./node_modules/file-saver/dist/FileSaver.min.js");
/* harmony import */ var file_saver__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(file_saver__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var loglevel__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var loglevel__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(loglevel__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _setting__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/setting.ts");
if (_setting__WEBPACK_IMPORTED_MODULE_2__/* .enableDebug */ .Nw.value) {
loglevel__WEBPACK_IMPORTED_MODULE_1___default().setLevel("trace");
}
else {
loglevel__WEBPACK_IMPORTED_MODULE_1___default().setLevel("info");
}
let logText = "";
function getLogText() {
return logText;
}
const originalFactory = (loglevel__WEBPACK_IMPORTED_MODULE_1___default().methodFactory);
(loglevel__WEBPACK_IMPORTED_MODULE_1___default().methodFactory) = (methodName, logLevel, loggerName) => {
const rawMethod = originalFactory(methodName, logLevel, loggerName);
return (message) => {
try {
if (typeof message === "object") {
if (message instanceof Error) {
logText += message.name;
logText += message.message;
logText += message.stack;
}
else {
logText += JSON.stringify(message, undefined, 2) + "\n";
}
}
else {
logText += message + "\n";
}
}
catch (error) {
loglevel__WEBPACK_IMPORTED_MODULE_1___default().error(error);
}
rawMethod(message);
};
};
loglevel__WEBPACK_IMPORTED_MODULE_1___default().setLevel(loglevel__WEBPACK_IMPORTED_MODULE_1___default().getLevel());
function saveLogTextToFile() {
(0,file_saver__WEBPACK_IMPORTED_MODULE_0__.saveAs)(new Blob([logText], { type: "text/plain; charset=UTF-8" }), `novel-downloader-${Date.now().toString()}.log`);
}
/***/ }),
/***/ "./src/main/Attachment.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ q: () => (/* binding */ AttachmentClass)
/* harmony export */ });
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_misc__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/misc.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _setting__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/setting.ts");
/* harmony import */ var _main__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/main/main.ts");
class AttachmentClass {
url;
name;
mode;
status = _main__WEBPACK_IMPORTED_MODULE_0__/* .Status */ .nW.pending;
retryTime = 0;
Blob;
comments;
referrerMode;
_init;
_TMinit;
constructor(url, name, mode, referrerMode = _main__WEBPACK_IMPORTED_MODULE_0__/* .ReferrerMode */ .ls.keep, customReferer = "", init) {
this.url = url;
this.name = name;
this.mode = mode;
this.referrerMode = referrerMode;
const defaultInit = {
init: {
referrerPolicy: "strict-origin-when-cross-origin",
},
TMinit: {
headers: { Referer: document.location.origin },
responseType: "blob",
},
};
if (!init) {
({ init: this._init, TMinit: this._TMinit } = defaultInit);
if (this.referrerMode === _main__WEBPACK_IMPORTED_MODULE_0__/* .ReferrerMode */ .ls.none) {
this._init.referrerPolicy = "no-referrer";
this._TMinit.headers = {};
}
if (this.referrerMode === _main__WEBPACK_IMPORTED_MODULE_0__/* .ReferrerMode */ .ls.self) {
this._TMinit.headers = { Referer: new URL(url).origin };
}
if (this.referrerMode === _main__WEBPACK_IMPORTED_MODULE_0__/* .ReferrerMode */ .ls.custom &&
customReferer.startsWith("http")) {
this._TMinit.headers = { Referer: customReferer };
}
}
else {
({ init: this._init, TMinit: this._TMinit } = (0,_lib_misc__WEBPACK_IMPORTED_MODULE_1__/* .deepcopy */ .OJ)(init));
this._TMinit.responseType = "blob";
if (this._init.responseType) {
delete this._init.responseType;
}
}
}
async init() {
if (this.mode === "naive") {
this.Blob = await this.download();
}
else {
this.Blob = await this.tmDownload();
}
if (this.Blob) {
_log__WEBPACK_IMPORTED_MODULE_2___default().info(`[attachment] ${this.url} 下载完成。`);
}
return this.Blob;
}
download() {
this.status = _main__WEBPACK_IMPORTED_MODULE_0__/* .Status */ .nW.downloading;
return fetch(this.url, this._init)
.then((response) => {
if (response.ok) {
this.status = _main__WEBPACK_IMPORTED_MODULE_0__/* .Status */ .nW.finished;
return response.blob();
}
else {
if (response.status === 404) {
this.status = _main__WEBPACK_IMPORTED_MODULE_0__/* .Status */ .nW.failed;
}
throw new Error(`Bad response!\nRequest url: ${this.url}\nStatus code: ${response.status}`);
}
})
.catch(async (err) => {
this.retryTime++;
_log__WEBPACK_IMPORTED_MODULE_2___default().error(`[attachment]下载 ${this.url} 出错,第${this.retryTime}次重试,下载模式:${this.mode}`);
if (this.status !== _main__WEBPACK_IMPORTED_MODULE_0__/* .Status */ .nW.failed && this.retryTime < _setting__WEBPACK_IMPORTED_MODULE_3__/* .retryLimit */ .Iz) {
await (0,_lib_misc__WEBPACK_IMPORTED_MODULE_1__/* .sleep */ .yy)(this.retryTime * 1500);
return this.download();
}
else {
this.status = _main__WEBPACK_IMPORTED_MODULE_0__/* .Status */ .nW.failed;
_log__WEBPACK_IMPORTED_MODULE_2___default().error(err);
_log__WEBPACK_IMPORTED_MODULE_2___default().trace(err);
return null;
}
});
}
tmDownload() {
this.status = _main__WEBPACK_IMPORTED_MODULE_0__/* .Status */ .nW.downloading;
return (0,_lib_http__WEBPACK_IMPORTED_MODULE_4__/* .gfetch */ ._V)(this.url, this._TMinit)
.then((response) => {
if (response.status >= 200 && response.status <= 299) {
this.status = _main__WEBPACK_IMPORTED_MODULE_0__/* .Status */ .nW.finished;
return response.response;
}
else {
if (response.status === 404) {
this.status = _main__WEBPACK_IMPORTED_MODULE_0__/* .Status */ .nW.failed;
}
throw new Error(`Bad response!\nRequest url: ${this.url}\nStatus code: ${response.status}`);
}
})
.catch(async (err) => {
this.retryTime++;
_log__WEBPACK_IMPORTED_MODULE_2___default().error(`[attachment]下载 ${this.url} 出错,第${this.retryTime}次重试,下载模式:${this.mode}`);
if (this.status !== _main__WEBPACK_IMPORTED_MODULE_0__/* .Status */ .nW.failed && this.retryTime < _setting__WEBPACK_IMPORTED_MODULE_3__/* .retryLimit */ .Iz) {
await (0,_lib_misc__WEBPACK_IMPORTED_MODULE_1__/* .sleep */ .yy)(this.retryTime * 1000);
return this.tmDownload();
}
else {
this.status = _main__WEBPACK_IMPORTED_MODULE_0__/* .Status */ .nW.failed;
_log__WEBPACK_IMPORTED_MODULE_2___default().error(err);
_log__WEBPACK_IMPORTED_MODULE_2___default().trace(err);
return null;
}
});
}
toJSON() {
return {
url: this.url,
name: this.name,
mode: this.mode,
status: this.status,
retryTime: this.retryTime,
};
}
}
/***/ }),
/***/ "./src/main/Book.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
// EXPORTS
__webpack_require__.d(__webpack_exports__, {
E: () => (/* binding */ Book)
});
;// ./src/lib/removeTrackParam.ts
const general = [
"nx_source",
"_zucks_suid",
"cmpid",
"asgtbndr",
"guccounter",
"guce_referrer",
"guce_referrer_sig",
"_openstat",
"action_object_map",
"action_ref_map",
"action_type_map",
"fb_action_ids",
"fb_action_types",
"fb_comment_id",
"fb_ref",
"fb_source",
"fbclid",
"xtor",
"utm_campaign",
"utm_channel",
"utm_cid",
"utm_content",
"utm_id",
"utm_medium",
"utm_name",
"utm_place",
"utm_pubreferrer",
"utm_reader",
"utm_referrer",
"utm_serial",
"utm_social",
"utm_social-type",
"utm_source",
"utm_swu",
"utm_term",
"utm_userid",
"utm_viz_id",
"utm_product",
"utm_campaignid",
"utm_ad",
"utm_brand",
"utm_emcid",
"utm_emmid",
"utm_umguk",
"gbraid",
"wbraid",
"gclsrc",
"gclid",
"yclid",
"dpg_source",
"dpg_campaign",
"dpg_medium",
"dpg_content",
"admitad_uid",
"adjust_tracker",
"adjust_adgroup",
"adjust_campaign",
"bsft_clkid",
"bsft_eid",
"bsft_mid",
"bsft_uid",
"bsft_aaid",
"bsft_ek",
"mtm_campaign",
"mtm_cid",
"mtm_content",
"mtm_group",
"mtm_keyword",
"mtm_medium",
"mtm_placement",
"mtm_source",
"pk_campaign",
"pk_medium",
"pk_source",
"_branch_match_id",
"vc_lpp",
"ml_subscriber",
"ml_subscriber_hash",
"rb_clickid",
"oly_anon_id",
"oly_enc_id",
"dt_dapp",
"dt_platform",
"spm",
"scm",
];
const specific = {
"bilibili.com": [
"from",
"seid",
"share_source",
"spm_id_from",
"from_spm_id",
"share_medium",
"share_plat",
"share_session_id",
"share_source",
"share_tag",
"timestamp",
"unique_k",
"from_source",
"refer_from",
],
};
function findSpecial(host) {
let lastPos = 0;
let domain = host;
while (lastPos >= 0) {
if (specific[domain]) {
return specific[domain];
}
lastPos = host.indexOf(".", lastPos + 1);
domain = host.slice(lastPos + 1);
}
}
function removeTrackParm(_url) {
const url = new URL(_url);
const host = url.hostname;
const search = url.searchParams;
general.forEach((s) => search.delete(s));
const special = findSpecial(host);
if (special) {
special.forEach((s) => search.delete(s));
}
url.hash = "";
return url.href;
}
// EXTERNAL MODULE: ./node_modules/loglevel/lib/loglevel.js
var loglevel = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
var loglevel_default = /*#__PURE__*/__webpack_require__.n(loglevel);
;// ./src/main/Book.ts
class Book {
saveType = {
epub: true,
txt: true,
raw: false,
};
bookname;
author;
introduction;
introductionHTML;
additionalMetadate;
chapters;
saveOptions;
constructor({ bookUrl, bookname, author, introduction, introductionHTML, additionalMetadate, chapters, }) {
this.bookUrl = bookUrl;
this.bookname = bookname;
this.author = author;
this.introduction = introduction;
this.introductionHTML = introductionHTML;
this.additionalMetadate = additionalMetadate;
this.chapters = chapters;
loglevel_default().debug("[Book]初始化完成");
}
_bookUrl = "";
get bookUrl() {
return this._bookUrl;
}
set bookUrl(v) {
this._bookUrl = removeTrackParm(v);
}
_ToCUrl;
get ToCUrl() {
return this._ToCUrl;
}
set ToCUrl(v) {
if (v) {
this._ToCUrl = removeTrackParm(v);
}
}
toJSON() {
return {
bookUrl: this.bookUrl,
ToCUrl: this.ToCUrl,
bookname: this.bookname,
author: this.author,
introduction: this.introduction,
introductionHTML: this.introductionHTML
? this.introductionHTML.outerHTML
: this.introductionHTML,
additionalMetadate: this.additionalMetadate,
};
}
}
/***/ }),
/***/ "./src/main/Chapter.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ I: () => (/* binding */ Chapter)
/* harmony export */ });
/* harmony import */ var _lib_misc__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/misc.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_1__);
/* harmony import */ var _setting__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/setting.ts");
/* harmony import */ var _main__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/main/main.ts");
class Chapter {
bookUrl;
bookname;
chapterUrl;
chapterNumber;
chapterName;
isVIP;
isPaid;
sectionName;
sectionNumber;
sectionChapterNumber;
chapterParse;
charset;
options;
status = _main__WEBPACK_IMPORTED_MODULE_0__/* .Status */ .nW.pending;
retryTime = 0;
contentRaw;
contentText;
contentHTML;
contentImages;
additionalMetadate;
chapterHtmlFileName;
book;
constructor({ bookUrl, bookname, chapterUrl, chapterNumber, chapterName, isVIP, isPaid, sectionName, sectionNumber, sectionChapterNumber, chapterParse, charset, options, }) {
this.bookUrl = bookUrl;
this.bookname = bookname;
this.chapterUrl = chapterUrl;
this.chapterNumber = chapterNumber;
this.chapterName = chapterName;
this.isVIP = isVIP;
this.isPaid = isPaid;
this.sectionName = sectionName;
this.sectionNumber = sectionNumber;
this.sectionChapterNumber = sectionChapterNumber;
this.chapterParse = chapterParse;
this.charset = charset;
this.options = options;
}
async init() {
const { chapterName, contentRaw, contentText, contentHTML, contentImages, additionalMetadate, } = await this.parse();
this.chapterName = chapterName;
this.contentRaw = contentRaw;
this.contentText = contentText;
this.contentHTML = contentHTML;
this.contentImages = contentImages;
this.additionalMetadate = additionalMetadate;
if (this.status === _main__WEBPACK_IMPORTED_MODULE_0__/* .Status */ .nW.failed) {
_log__WEBPACK_IMPORTED_MODULE_1___default().error(`[Chapter]章节名:${this.chapterName}, \
分卷名:${this.sectionName}, URL:${this.chapterUrl}, \
VIP:${this.isVIP}, Paid:${this.isPaid}, \
isNull:${!this.contentHTML} 解析出错。`);
}
else {
_log__WEBPACK_IMPORTED_MODULE_1___default().info(`[Chapter]章节名:${this.chapterName}, \
分卷名:${this.sectionName}, URL:${this.chapterUrl}, \
VIP:${this.isVIP}, Paid:${this.isPaid}, \
isNull:${!this.contentHTML} 解析成功。`);
}
return this;
}
async parse() {
this.status = _main__WEBPACK_IMPORTED_MODULE_0__/* .Status */ .nW.downloading;
return this.chapterParse(this.chapterUrl, this.chapterName, this.isVIP, this.isPaid, this.charset, this.options)
.then(async (obj) => {
const contentImages = obj.contentImages;
if (contentImages) {
let downloadingImages = contentImages.filter((imgObj) => imgObj.status === _main__WEBPACK_IMPORTED_MODULE_0__/* .Status */ .nW.downloading);
while (downloadingImages.length) {
await (0,_lib_misc__WEBPACK_IMPORTED_MODULE_2__/* .sleep */ .yy)(500);
downloadingImages = contentImages.filter((imgObj) => imgObj.status === _main__WEBPACK_IMPORTED_MODULE_0__/* .Status */ .nW.downloading);
}
}
this.status = _main__WEBPACK_IMPORTED_MODULE_0__/* .Status */ .nW.finished;
return obj;
})
.catch(async (err) => {
this.retryTime++;
_log__WEBPACK_IMPORTED_MODULE_1___default().error(`[Chapter]${this.chapterName}解析出错,第${this.retryTime}次重试,章节地址:${this.chapterUrl}`);
if (this.status !== _main__WEBPACK_IMPORTED_MODULE_0__/* .Status */ .nW.failed && this.retryTime < _setting__WEBPACK_IMPORTED_MODULE_3__/* .retryLimit */ .Iz) {
await (0,_lib_misc__WEBPACK_IMPORTED_MODULE_2__/* .sleep */ .yy)(this.retryTime * 1500);
return this.parse();
}
else {
this.status = _main__WEBPACK_IMPORTED_MODULE_0__/* .Status */ .nW.failed;
_log__WEBPACK_IMPORTED_MODULE_1___default().error(err);
_log__WEBPACK_IMPORTED_MODULE_1___default().trace(err);
window.failedCount++;
return {
chapterName: this.chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
});
}
toJSON() {
return {
bookUrl: this.bookUrl,
bookname: this.bookname,
chapterUrl: this.chapterUrl,
chapterNumber: this.chapterNumber,
chapterName: this.chapterName,
isVIP: this.isPaid,
isPaid: this.isPaid,
sectionName: this.sectionName,
sectionNumber: this.sectionNumber,
sectionChapterNumber: this.sectionChapterNumber,
status: this.status,
retryTime: this.retryTime,
chapterHtmlFileName: this.chapterHtmlFileName,
};
}
}
/***/ }),
/***/ "./src/main/main.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ K5: () => (/* binding */ ExpectError),
/* harmony export */ ls: () => (/* binding */ ReferrerMode),
/* harmony export */ nW: () => (/* binding */ Status)
/* harmony export */ });
var Status;
(function (Status) {
Status[Status["pending"] = 0] = "pending";
Status[Status["downloading"] = 1] = "downloading";
Status[Status["failed"] = 2] = "failed";
Status[Status["finished"] = 3] = "finished";
Status[Status["aborted"] = 4] = "aborted";
Status[Status["saved"] = 5] = "saved";
})(Status || (Status = {}));
var ReferrerMode;
(function (ReferrerMode) {
ReferrerMode[ReferrerMode["keep"] = 0] = "keep";
ReferrerMode[ReferrerMode["none"] = 1] = "none";
ReferrerMode[ReferrerMode["self"] = 2] = "self";
ReferrerMode[ReferrerMode["custom"] = 3] = "custom";
})(ReferrerMode || (ReferrerMode = {}));
class ExpectError extends Error {
}
/***/ }),
/***/ "./src/rules.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
// EXPORTS
__webpack_require__.d(__webpack_exports__, {
Q: () => (/* binding */ BaseRuleClass)
});
// EXTERNAL MODULE: ./src/lib/attachments.ts
var attachments = __webpack_require__("./src/lib/attachments.ts");
// EXTERNAL MODULE: ./src/lib/misc.ts
var misc = __webpack_require__("./src/lib/misc.ts");
// EXTERNAL MODULE: ./node_modules/loglevel/lib/loglevel.js
var loglevel = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
var loglevel_default = /*#__PURE__*/__webpack_require__.n(loglevel);
// EXTERNAL MODULE: ./src/log.ts
var log = __webpack_require__("./src/log.ts");
// EXTERNAL MODULE: ./src/main/main.ts
var main = __webpack_require__("./src/main/main.ts");
// EXTERNAL MODULE: ./node_modules/file-saver/dist/FileSaver.min.js
var FileSaver_min = __webpack_require__("./node_modules/file-saver/dist/FileSaver.min.js");
// EXTERNAL MODULE: ./src/setting.ts
var setting = __webpack_require__("./src/setting.ts");
// EXTERNAL MODULE: ./src/save/sgc-toc.css
var sgc_toc = __webpack_require__("./src/save/sgc-toc.css");
// EXTERNAL MODULE: ./src/save/web.css
var web = __webpack_require__("./src/save/web.css");
// EXTERNAL MODULE: ./src/lib/GM.ts
var GM = __webpack_require__("./src/lib/GM.ts");
;// external "fflate"
const external_fflate_namespaceObject = fflate;
// EXTERNAL MODULE: ./node_modules/streamsaver/StreamSaver.js
var StreamSaver = __webpack_require__("./node_modules/streamsaver/StreamSaver.js");
var StreamSaver_default = /*#__PURE__*/__webpack_require__.n(StreamSaver);
;// ./src/lib/zip.ts
async function setStreamSaverSetting() {
const rawMitm = new URL(streamSaver.mitm);
const mitm = new URL("https://cors.bgme.bid/");
mitm.pathname = rawMitm.origin + rawMitm.pathname;
streamSaver.mitm = mitm.href;
streamSaver.supported =
streamSupport() && (await mitmPageAvailability(mitm.href));
}
class FflateZip {
filename;
stream;
zcount = 0;
count = 0;
filenameList = [];
zipOut = new Blob([], { type: "application/zip" });
savedZip;
constructor(filename, stream, mimetype = "application/zip") {
loglevel_default().info(`[fflateZip] filename: ${filename}, stream: ${stream}, streamSaver.supported: ${(StreamSaver_default()).supported}`);
const self = this;
this.filename = filename;
this.stream = false;
let writer;
if (this.stream) {
const fileStream = StreamSaver_default().createWriteStream(self.filename);
writer =
fileStream.getWriter();
}
this.savedZip = new external_fflate_namespaceObject.Zip((err, dat, final) => {
if (err) {
loglevel_default().error(err);
loglevel_default().trace(err);
if (self.stream) {
writer.abort();
}
throw err;
}
if (self.stream) {
writer.write(dat);
}
else {
self.zipOut = new Blob([self.zipOut, dat], { type: mimetype });
}
if (final) {
if (self.stream) {
writer.close();
loglevel_default().info("[fflateZip] ZIP生成完毕");
}
else {
nonStream();
}
}
function nonStream() {
loglevel_default().info("[fflateZip] ZIP生成完毕,文件大小:" + self.zipOut.size);
try {
(0,FileSaver_min.saveAs)(self.zipOut, self.filename);
self.zipOut = new Blob([], { type: "application/zip" });
}
catch (error) {
loglevel_default().error("[fflateZip]" + error);
loglevel_default().trace(error);
}
}
});
}
async file(filename, fileBlob, nocompress = false) {
if (this.filenameList.includes(filename)) {
loglevel_default().warn(`filename ${filename} has existed on zip.`);
return;
}
this.filenameList.push(filename);
this.count++;
const buffer = await fileBlob.arrayBuffer();
const chunk = new Uint8Array(buffer);
if (!((0,misc/* mimetyepToCompressible */.OH)((0,misc/* extensionToMimetype */.dB)(filename.split(".").slice(-1)[0])) || (0,misc/* mimetyepToCompressible */.OH)(fileBlob.type)) ||
nocompress) {
const nonStreamingFile = new external_fflate_namespaceObject.ZipPassThrough(filename);
this.savedZip.add(nonStreamingFile);
nonStreamingFile.push(chunk, true);
this.zcount++;
}
else {
const nonStreamingFile = new external_fflate_namespaceObject.AsyncZipDeflate(filename, {
level: 9,
});
this.savedZip.add(nonStreamingFile);
nonStreamingFile.push(chunk, true);
this.zcount++;
}
}
async generateAsync() {
while (this.count !== this.zcount) {
await (0,misc/* sleep */.yy)(100);
}
this.savedZip.end();
}
}
// EXTERNAL MODULE: ./src/save/main.css
var save_main = __webpack_require__("./src/save/main.css");
// EXTERNAL MODULE: ./src/save/toc.css
var toc = __webpack_require__("./src/save/toc.css");
// EXTERNAL MODULE: ./src/lib/dom.ts
var dom = __webpack_require__("./src/lib/dom.ts");
;// ./src/save/options.ts
class Common {
genMetaDateTxt(book) {
let metaDateText = `题名:${book.bookname}\n作者:${book.author}`;
if (book.additionalMetadate.tags) {
metaDateText += `\nTag列表:${book.additionalMetadate.tags.join("、")}`;
}
metaDateText += `\n原始网址:${book.bookUrl}`;
if (book.additionalMetadate.cover) {
metaDateText += `\n封面图片地址:${book.additionalMetadate.cover.url}`;
}
if (book.introduction) {
metaDateText += `\n简介:${book.introduction}`;
}
metaDateText += `\n下载时间:${new Date().toISOString()}\n本文件由小说下载器生成,软件地址:https://github.com/404-novel-project/novel-downloader\n\n`;
return metaDateText;
}
getChapterNumberToSave(chapter, chapters) {
return `${"0".repeat(Math.max(chapters.length.toString().length, 5) -
Math.trunc(chapter.chapterNumber).toString().length)}${chapter.chapterNumber.toString()}`;
}
}
function saveOptionsValidate(data) {
const keyNamesS = ["mainStyleText", "tocStyleText"];
const keyNamesF = [
"getchapterName",
"genSectionText",
"genChapterText",
"chapterSort",
];
function keyNametest(keyname) {
const keyList = [...keyNamesS, ...keyNamesF];
return keyList.includes(keyname);
}
function keyNamesStest(keyname) {
if (keyNamesS.includes(keyname)) {
if (typeof data[keyname] === "string") {
return true;
}
}
return false;
}
function keyNamesFtest(keyname) {
if (keyNamesF.includes(keyname)) {
if (typeof data[keyname] === "function") {
return true;
}
}
return false;
}
if (typeof data !== "object") {
return false;
}
if (Object.keys(data).length === 0) {
return false;
}
for (const keyname in data) {
if (Object.prototype.hasOwnProperty.call(data, keyname)) {
if (!keyNametest(keyname)) {
return false;
}
if (!(keyNamesStest(keyname) || keyNamesFtest(keyname))) {
return false;
}
}
}
return true;
}
class Options extends Common {
mainStyleText = save_main/* default */.A;
tocStyleText = toc/* default */.A;
getchapterName(chapter) {
if (chapter.chapterName) {
return chapter.chapterName;
}
else {
return chapter.chapterNumber.toString();
}
}
genSectionText(sectionName) {
return (`${"=".repeat(20)}\n\n\n\n# ${sectionName}\n\n\n\n${"=".repeat(20)}` +
"\n\n");
}
genChapterText(chapterName, contentText) {
return `${chapterName}\n${"=".repeat((0,dom/* fullWidthLength */.QJ)(chapterName) * 2 + 10)}\n\n${contentText}\n\n`;
}
chapterSort(a, b) {
return a.chapterNumber - b.chapterNumber;
}
}
// EXTERNAL MODULE: ./src/save/misc.ts
var save_misc = __webpack_require__("./src/save/misc.ts");
;// ./src/save/chapter.html.j2
// Module
var code = "<!DOCTYPE html>\n<html>\n <head>\n <meta name=\"viewport\" content=\"width=device-width,initial-scale=1\">\n <meta name=\"referrer\" content=\"same-origin\">\n <meta name=\"generator\" content=\"https://github.com/404-novel-project/novel-downloader\">\n <meta name=\"source\" content=\"{{ chapterUrl }}\">\n <link href=\"style.css\" type=\"text/css\" rel=\"stylesheet\">\n <title>{{ chapterName }}</title>\n </head>\n <body>\n <div class=\"main\">\n <h2>{{ chapterName }}</h2>\n {{ outerHTML }}\n </div>\n <!-- <" + "script type=\"text/javascript\" src=\"web.js\"><" + "/script> -->\n </body>\n</html>\n";
// Exports
/* harmony default export */ const chapter_html = (code);
;// ./src/save/index.html.j2
// Module
var index_html_code = "<!DOCTYPE html>\n<html>\n <head>\n <meta name=\"viewport\" content=\"width=device-width,initial-scale=1\">\n <meta name=\"referrer\" content=\"same-origin\">\n <meta name=\"generator\" content=\"https://github.com/404-novel-project/novel-downloader\">\n <meta name=\"date-creation\" content=\"{{ creationDate }}\">\n <link href=\"style.css\" type=\"text/css\" rel=\"stylesheet\">\n <link href=\"web.css\" type=\"text/css\" rel=\"stylesheet\">\n <link href=\"toc.css\" type=\"text/css\" rel=\"stylesheet\">\n <title>{{ bookname }}</title>\n </head>\n <body>\n <div class=\"main\">\n <h1>{{ bookname }}</h1>\n <h3 class=\"author\">{{ author }}</h3>\n <div class=\"info\">\n {% if cover -%}\n <img class=\"cover\" data-src-address=\"{{ cover.name }}\">\n {%- endif %} \n {% if introductionHTML -%}\n <div>\n <h3>简介</h3>\n <div class=\"introduction\">{{ introductionHTML }}</div>\n </div>\n {%- endif %}\n </div>\n <div class=\"bookurl\">\n <a href=\"{{ bookUrl }}\">打开原始网站</a>\n </div>\n <hr>\n {% for sectionObj in sectionsObj -%}\n <div id=\"section{{ sectionObj.sectionNumber }}\" class=\"section\">\n {% if sectionObj.sectionName %}\n <h2 class=\"section-label\">{{ sectionObj.sectionName }}</h2>\n {% endif %}\n {% for chapter in sectionObj.chpaters -%}\n <div class=\"chapter\">\n {% if not (chapter.contentHTML or chapter.status === Status.saved) -%}\n <a class=\"disabled\" href=\"{{ chapter.chapterHtmlFileName }}\">{{ chapter.chapterName }}</a>\n {%- else -%}\n <a href=\"{{ chapter.chapterHtmlFileName }}\">{{ chapter.chapterName }}</a>\n {%- endif %}\n </div>\n {%- endfor %}\n </div>\n {%- endfor %} \n </div>\n </body>\n</html>";
// Exports
/* harmony default export */ const index_html = (index_html_code);
;// ./src/save/section.html.j2
// Module
var section_html_code = "<!DOCTYPE html>\n<html>\n <head>\n <meta name=\"viewport\" content=\"width=device-width,initial-scale=1\">\n <meta name=\"referrer\" content=\"same-origin\">\n <meta name=\"generator\" content=\"https://github.com/404-novel-project/novel-downloader\">\n <link href=\"style.css\" type=\"text/css\" rel=\"stylesheet\">\n <title>{{ sectionName }}</title>\n </head>\n <body>\n <div class=\"main\"><h1>{{ sectionName }}</h1></div>\n </body>\n</html>\n";
// Exports
/* harmony default export */ const section_html = (section_html_code);
;// external "nunjucks"
const external_nunjucks_namespaceObject = nunjucks;
;// ./src/save/epub.ts
const env = new external_nunjucks_namespaceObject.Environment(undefined, { autoescape: false });
const section = new external_nunjucks_namespaceObject.Template(section_html, env, undefined, true);
const chapterTemplt = new external_nunjucks_namespaceObject.Template(chapter_html, env, undefined, true);
const index = new external_nunjucks_namespaceObject.Template(index_html, env, undefined, true);
function getDateString() {
const date = new Date();
const year = date.getFullYear();
const _monty = new Date().getMonth() + 1;
const monty = _monty < 10 ? `0${_monty}` : _monty;
const _day = date.getDate();
const day = _day < 10 ? `0${_day}` : _day;
return `${year}-${monty}-${day}`;
}
const uuid = (0,misc/* randomUUID */.N4)();
const content_opf = `<?xml version="1.0" encoding="utf-8"?>
<package version="3.0" unique-identifier="BookId" prefix="rendition: http://www.idpf.org/vocab/rendition/#" xmlns="http://www.idpf.org/2007/opf">
<metadata xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:dcterms="http://purl.org/dc/terms/" xmlns:opf="http://www.idpf.org/2007/opf">
<dc:identifier id="BookId">urn:uuid:${uuid}</dc:identifier>
<meta content="${GM/* _GM_info */.JX.script.version}" name="novel-downloader version"/>
<meta content="https://github.com/404-novel-project/novel-downloader" name="generator"/>
<meta property="dcterms:created">${getDateString()}</meta>
<meta property="dcterms:modified">${new Date()
.toISOString()
.replace(/\.\d\d\dZ$/, "Z")}</meta>
</metadata>
<manifest>
<item id="ncx" href="toc.ncx" media-type="application/x-dtbncx+xml"/>
<item id="navid" href="nav.xhtml" media-type="application/xhtml+xml" properties="nav"/>
<item id="sgc-toc.css" href="sgc-toc.css" media-type="text/css"/>
<item id="style.css" href="style.css" media-type="text/css"/>
<item id="cover.xhtml" href="cover.xhtml" media-type="application/xhtml+xml" properties="svg"/>
<item id="info.xhtml" href="info.xhtml" media-type="application/xhtml+xml"/>
<item id="message.xhtml" href="message.xhtml" media-type="application/xhtml+xml"/>
<item id="TOC.xhtml" href="TOC.xhtml" media-type="application/xhtml+xml"/>
</manifest>
<spine toc="ncx">
<itemref idref="cover.xhtml"/>
<itemref idref="info.xhtml"/>
<itemref idref="message.xhtml"/>
<itemref idref="TOC.xhtml"/>
</spine>
<guide>
<reference type="cover" title="Cover" href="cover.xhtml"/>
<reference type="toc" title="Table of Contents" href="TOC.xhtml"/>
</guide>
</package>`;
const toc_ncx = `<?xml version="1.0" encoding="utf-8" ?>
<ncx version="2005-1" xmlns="http://www.daisy.org/z3986/2005/ncx/">
<head>
<meta content="urn:uuid:${uuid}" name="dtb:uid"/>
<meta content="2" name="dtb:depth"/>
<meta content="0" name="dtb:totalPageCount"/>
<meta content="0" name="dtb:maxPageNumber"/>
</head>
<docTitle>
<text></text>
</docTitle>
<navMap>
</navMap>
</ncx>`;
const TOC_xhtml = `<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml" xmlns:epub="http://www.idpf.org/2007/ops">
<head>
<title>Table of Contents</title>
<link href="sgc-toc.css" rel="stylesheet" type="text/css"/>
</head>
<body>
<div class="sgc-toc-title">
目录
</div>
</body>
</html>`;
const nav_xhtml = `<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml" xmlns:epub="http://www.idpf.org/2007/ops">
<head>
<meta charset="utf-8"/>
<title>ePub Nav</title>
<style type="text/css">
ol { list-style-type: none; }
</style>
</head>
<body epub:type="frontmatter">
<nav epub:type="toc" id="toc" role="doc-toc">
<h1>Table of Contents</h1>
</nav>
<nav epub:type="landmarks" id="landmarks" hidden=""><h2>Guide</h2>
<ol>
<li><a epub:type="cover" href="cover.xhtml">Cover</a></li>
<li><a epub:type="toc" href="TOC.xhtml">Table of Contents</a></li>
</ol>
</nav>
</body>
</html>`;
const getCoverXhtml = (coverName) => `<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml" xmlns:epub="http://www.idpf.org/2007/ops">
<head>
<title>Cover</title>
</head>
<body>
<div style="text-align: center; padding: 0pt; margin: 0pt;">
<svg xmlns="http://www.w3.org/2000/svg" height="100%" preserveAspectRatio="xMidYMid meet" version="1.1" viewBox="0 0 368 460" width="100%" xmlns:xlink="http://www.w3.org/1999/xlink"><image width="368" height="460" xlink:href="${coverName}"/></svg>
</div>
</body>
</html>`;
const getInfoXhtml = (title, author) => `<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml" xmlns:epub="http://www.idpf.org/2007/ops">
<head>
<title>信息页</title>
<link href="style.css" type="text/css" rel="stylesheet"/>
</head>
<body>
<div class="main">
<h1>${title}</h1>
${author ? `<h2>作者:${author}</h2>` : ""}
</div>
</body>
</html>`;
const getMessageXhtml = (book) => `<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml" xmlns:epub="http://www.idpf.org/2007/ops">
<head>
<title>信息页</title>
<link href="style.css" type="text/css" rel="stylesheet"/>
</head>
<body>
<div class="main">
<div><strong>制作信息</strong></div>
<hr/>
<div>题名:${book.bookname}</div>
<div>作者:${book.author}</div>
<div>原始地址:<a href="${book.bookUrl}">${book.bookUrl}</a></div>
<div>本文件由<a href="https://github.com/404-novel-project/novel-downloader">小说下载器</a>生成。</div>
${book.introductionHTML
? `<hr/><span>简介:</span>${book.introductionHTML.outerHTML}`
: ""}
${book.additionalMetadate.tags
? `<hr/><div>Tag列表:${book.additionalMetadate.tags.join("、")}</div>`
: ""}
</div>
</body>
</html>`;
class EPUB extends Options {
contentOpf = new DOMParser().parseFromString(content_opf, "application/xml");
metadata = this.contentOpf.querySelector("metadata");
manifest = this.contentOpf.querySelector("manifest");
spine = this.contentOpf.querySelector("spine");
guide = this.contentOpf.querySelector("guide");
ncx = new DOMParser().parseFromString(toc_ncx, "application/xml");
navMap = this.ncx.querySelector("navMap");
navHtml = new DOMParser().parseFromString(nav_xhtml, "application/xhtml+xml");
navHtmlToc = this.navHtml.getElementById("toc");
toc = new DOMParser().parseFromString(TOC_xhtml, "application/xhtml+xml");
tocBody = this.toc.body;
book;
chapters;
epubZip;
constructor(book, streamZip, options) {
super();
const self = this;
this.book = book;
this.chapters = this.book.chapters;
const zipFilename = `[${this.book.author}]${this.book.bookname}.epub`;
this.epubZip = new FflateZip(zipFilename, streamZip, "application/epub+zip");
loglevel_default().debug("[save-epub]保存epub基本文件");
saveEpubMimetype();
if (options) {
Object.assign(this, options);
}
async function saveEpubMimetype() {
await self.epubZip.file("mimetype", new Blob(["application/epub+zip"]), true);
await self.epubZip.file("META-INF/container.xml", new Blob([
`<?xml version="1.0" encoding="UTF-8"?>
<container version="1.0" xmlns="urn:oasis:names:tc:opendocument:xmlns:container">
<rootfiles>
<rootfile full-path="OEBPS/content.opf" media-type="application/oebps-package+xml"/>
</rootfiles>
</container>`,
]));
}
}
static genChapterHtmlFile(chapterObj) {
const _htmlText = chapterTemplt.render({
chapterUrl: chapterObj.chapterUrl,
chapterName: chapterObj.chapterName,
outerHTML: chapterObj.contentHTML?.outerHTML ?? "",
});
const htmlText = (0,dom/* convertHTMLtoXHTML */.pI)(_htmlText);
return new Blob([
`<?xml version="1.0" encoding="utf-8"?>`,
htmlText
.replaceAll("<p><br /></p>", "")
.replaceAll("<p><br/></p>", "")
.replaceAll("data-src-address", "src")
.replaceAll(/[\u{0000}-\u{001f}]/gu, "")
.replaceAll(/[\u{007f}-\u{009f}]/gu, "")
.replace('<html xmlns="http://www.w3.org/1999/xhtml">', '<html xmlns="http://www.w3.org/1999/xhtml" xmlns:epub="http://www.idpf.org/2007/ops">'),
], {
type: "application/xhtml+xml",
});
}
async saveEpub() {
const self = this;
loglevel_default().debug("[save-epub]保存样式文件");
await saveStyle();
loglevel_default().debug("[save-epub]更新Metadata");
await updateMetadata();
if (this.book.additionalMetadate.attachments) {
loglevel_default().debug("[save]保存书籍附件");
for (const bookAttachment of this.book.additionalMetadate.attachments) {
await this.addAttachment(bookAttachment);
}
}
loglevel_default().debug("[save-epub]保存仅标题章节文件");
await saveStubChapters(this.chapters);
loglevel_default().debug("[save-epub]保存目录文件");
await saveToC();
await saveZipFiles();
await this.epubZip.generateAsync();
async function saveStyle() {
await self.epubZip.file("OEBPS/style.css", new Blob([self.mainStyleText]));
await self.epubZip.file("OEBPS/sgc-toc.css", new Blob([sgc_toc/* default */.A]));
}
async function updateMetadata() {
const title = self.contentOpf.createElement("dc:title");
title.textContent = self.book.bookname;
self.metadata.appendChild(title);
self.ncx.querySelector("docTitle > text").innerHTML =
(0,dom/* escapeHTML */.Zn)(self.book.bookname);
const author = self.contentOpf.createElement("dc:creator");
author.setAttribute("id", "cre");
author.textContent = self.book.author;
self.metadata.appendChild(author);
const authorMeta = self.contentOpf.createElement("meta");
authorMeta.setAttribute("refines", "#cre");
authorMeta.setAttribute("property", "role");
authorMeta.setAttribute("scheme", "marc:relators");
authorMeta.textContent = "aut";
self.metadata.appendChild(authorMeta);
const source = self.contentOpf.createElement("dc:source");
source.textContent = self.book.bookUrl;
self.metadata.appendChild(source);
const language = self.contentOpf.createElement("dc:language");
language.textContent = self.book.additionalMetadate.language ?? "zh";
self.metadata.appendChild(language);
if (self.book.introduction) {
const introduction = self.contentOpf.createElement("dc:description");
introduction.textContent = self.book.introduction;
self.metadata.appendChild(introduction);
}
if (self.book.additionalMetadate.cover) {
await self.addAttachment(self.book.additionalMetadate.cover);
const cover = self.contentOpf.createElement("meta");
cover.setAttribute("name", "cover");
cover.setAttribute("content", self.book.additionalMetadate.cover.name);
self.metadata.appendChild(cover);
await self.epubZip.file("OEBPS/cover.xhtml", new Blob([getCoverXhtml(self.book.additionalMetadate.cover.name)], {
type: "application/xhtml+xml",
}));
}
else {
self.manifest.querySelector('item[id="cover.xhtml"]')?.remove();
self.spine.querySelector('itemref[idref="cover.xhtml"]')?.remove();
self.guide.querySelector('reference[type="cover"]')?.remove();
}
if (self.book.additionalMetadate.tags) {
for (const _tag of self.book.additionalMetadate.tags) {
const tag = self.contentOpf.createElement("dc:subject");
tag.textContent = _tag;
self.metadata.appendChild(tag);
}
}
await self.epubZip.file("OEBPS/info.xhtml", new Blob([
getInfoXhtml(self.book.bookname, self.book.author)
.replaceAll(/[\u{0000}-\u{001f}]/gu, "")
.replaceAll(/[\u{007f}-\u{009f}]/gu, ""),
], {
type: "application/xhtml+xml",
}));
await self.epubZip.file("OEBPS/message.xhtml", new Blob([
(0,dom/* convertHTMLtoXHTML */.pI)(getMessageXhtml(self.book))
.replaceAll(/[\u{0000}-\u{001f}]/gu, "")
.replaceAll(/[\u{007f}-\u{009f}]/gu, ""),
], {
type: "application/xhtml+xml",
}));
}
async function saveStubChapters(chapters) {
chapters = chapters.filter((c) => c.status !== main/* Status */.nW.saved);
for (const c of chapters) {
if (c.status === main/* Status */.nW.finished) {
await self.addChapter(c);
}
else {
await self.addChapter(c, "Stub");
}
}
}
async function saveToC() {
loglevel_default().debug("[save-epub]对 chapters 排序");
self.chapters.sort(self.chapterSort);
const sectionsListObj = (0,save_misc/* getSectionsObj */.e)(self.chapters, self.chapterSort);
let i = 0;
let sectionNumberG = null;
let sectionNavPoint;
let sectionTOCDiv;
const navHtmlTocOl = self.navHtml.createElement("ol");
self.navHtmlToc.appendChild(navHtmlTocOl);
let sectionNavOl;
for (const sectionObj of sectionsListObj) {
const { sectionName, sectionNumber, chpaters } = sectionObj;
if (sectionNumber !== sectionNumberG) {
const sectionNumberToSave = self.getChapterNumberToSave(chpaters[0], self.chapters);
const sectionHtmlFileName = `No${sectionNumberToSave}Section.xhtml`;
if (sectionName) {
sectionNumberG = sectionNumber;
loglevel_default().debug(`[save-epub]保存卷HTML文件:${sectionName}`);
const sectionHTMLBlob = genSectionHtmlFile(sectionName);
await self.epubZip.file(`OEBPS/${sectionHtmlFileName}`, sectionHTMLBlob);
appendManifest(sectionHtmlFileName);
appendSpine(sectionHtmlFileName);
i++;
const navPoint = genNavPoint(i, sectionName, sectionHtmlFileName);
if (sectionNavPoint) {
self.navMap.appendChild(sectionNavPoint);
}
sectionNavPoint = navPoint;
const li = genNavHtmlLi(sectionName, sectionHtmlFileName);
sectionNavOl = self.navHtml.createElement("ol");
li.appendChild(sectionNavOl);
navHtmlTocOl.appendChild(li);
const div = genTocDiv("sgc-toc-level-1", sectionName, sectionHtmlFileName);
if (sectionTOCDiv) {
self.tocBody.appendChild(sectionTOCDiv);
}
sectionTOCDiv = div;
}
}
for (const chpater of chpaters) {
const chapterHtmlFileName = chpater.chapterHtmlFileName;
if (sectionName) {
appendSpine(chapterHtmlFileName);
i++;
const navPoint = genNavPoint(i, chpater.chapterName ?? "", chapterHtmlFileName);
sectionNavPoint?.appendChild(navPoint);
sectionNavOl?.appendChild(genNavHtmlLi(chpater.chapterName ?? "", chapterHtmlFileName));
const div = genTocDiv("sgc-toc-level-2", chpater.chapterName ?? "", chapterHtmlFileName);
sectionTOCDiv?.appendChild(div);
}
else {
appendSpine(chapterHtmlFileName);
i++;
const navPoint = genNavPoint(i, chpater.chapterName ?? "", chapterHtmlFileName);
self.navMap.appendChild(navPoint);
navHtmlTocOl.appendChild(genNavHtmlLi(chpater.chapterName ?? "", chapterHtmlFileName));
const div = genTocDiv("sgc-toc-level-2", chpater.chapterName ?? "", chapterHtmlFileName);
self.tocBody.appendChild(div);
}
}
}
if (sectionNavPoint) {
self.navMap.appendChild(sectionNavPoint);
}
if (sectionTOCDiv) {
self.tocBody.appendChild(sectionTOCDiv);
}
await self.epubZip.file("OEBPS/content.opf", new Blob([
new XMLSerializer()
.serializeToString(self.contentOpf)
.replaceAll('xmlns=""', "")
.replaceAll(/[\u{0000}-\u{001f}]/gu, "")
.replaceAll(/[\u{007f}-\u{009f}]/gu, ""),
], { type: "application/oebps-package+xml" }));
await self.epubZip.file("OEBPS/toc.ncx", new Blob([
new XMLSerializer()
.serializeToString(self.ncx)
.replaceAll('xmlns=""', "")
.replaceAll(/[\u{0000}-\u{001f}]/gu, "")
.replaceAll(/[\u{007f}-\u{009f}]/gu, ""),
], { type: "application/x-dtbncx+xml" }));
await self.epubZip.file("OEBPS/nav.xhtml", new Blob([
new XMLSerializer()
.serializeToString(self.navHtml)
.replaceAll(/[\u{0000}-\u{001f}]/gu, "")
.replaceAll(/[\u{007f}-\u{009f}]/gu, ""),
], {
type: "application/xhtml+xml",
}));
await self.epubZip.file("OEBPS/TOC.xhtml", new Blob([
new XMLSerializer()
.serializeToString(self.toc)
.replaceAll(/[\u{0000}-\u{001f}]/gu, "")
.replaceAll(/[\u{007f}-\u{009f}]/gu, ""),
], { type: "application/xhtml+xml" }));
function appendManifest(htmlFileName) {
const item = self.contentOpf.createElement("item");
item.id = htmlFileName;
item.setAttribute("href", htmlFileName);
item.setAttribute("media-type", "application/xhtml+xml");
if (!self.manifest.querySelector(`itme[id="${htmlFileName}"]`)) {
self.manifest.appendChild(item);
}
}
function appendSpine(htmlFileName) {
const itemref = self.contentOpf.createElement("itemref");
itemref.setAttribute("idref", htmlFileName);
self.spine.appendChild(itemref);
}
function genNavPoint(num, name, htmlFileName) {
const navPoint = self.ncx.createElement("navPoint");
navPoint.id = `navPoint-${num}`;
navPoint.setAttribute("playOrder", num.toString());
const navLabel = self.ncx.createElement("navLabel");
const text = self.ncx.createElement("text");
text.textContent = name;
const content = self.ncx.createElement("content");
content.setAttribute("src", htmlFileName);
navLabel.appendChild(text);
navPoint.appendChild(navLabel);
navPoint.appendChild(content);
return navPoint;
}
function genNavHtmlLi(name, htmlFileName) {
const li = self.navHtml.createElement("li");
const a = self.navHtml.createElement("a");
a.textContent = name;
a.href = htmlFileName;
li.appendChild(a);
return li;
}
function genTocDiv(className, name, htmlFileName) {
const div = self.toc.createElement("div");
div.className = className;
const a = self.toc.createElement("a");
a.href = htmlFileName;
a.innerText = name;
div.appendChild(a);
return div;
}
function genSectionHtmlFile(sectionName) {
const _htmlText = section.render({ sectionName: sectionName });
const htmlText = (0,dom/* convertHTMLtoXHTML */.pI)(_htmlText);
return new Blob([
`<?xml version="1.0" encoding="utf-8"?>`,
htmlText
.replaceAll("data-src-address", "src")
.replaceAll(/[\u{0000}-\u{001f}]/gu, "")
.replaceAll(/[\u{007f}-\u{009f}]/gu, "")
.replace('<html xmlns="http://www.w3.org/1999/xhtml">', '<html xmlns="http://www.w3.org/1999/xhtml" xmlns:epub="http://www.idpf.org/2007/ops">'),
], {
type: "application/xhtml+xml",
});
}
}
async function saveZipFiles() {
loglevel_default().debug("[save-zip]保存元数据文本");
const metaDateText = self.genMetaDateTxt(self.book);
await self.epubZip.file("OEBPS/info.txt", new Blob([metaDateText], { type: "text/plain;charset=utf-8" }));
loglevel_default().debug("[save-zip]保存web样式");
await self.epubZip.file("OEBPS/web.css", new Blob([web/* default */.A], { type: "text/css;charset=utf-8" }));
modifyTocStyleText();
await self.epubZip.file("OEBPS/toc.css", new Blob([self.tocStyleText], { type: "text/css;charset=utf-8" }));
await self.epubZip.file("OEBPS/web.js", new Blob([
`if (typeof fetch === "function" && !navigator.userAgent.includes("calibre-viewer") && navigator.userAgent.startsWith("Mozilla/5.0")) {
const link = document.createElement("link");
link.type = "text/css";
link.rel = "stylesheet";
link.href = "web.css";
document.head.append(link);
}`,
], { type: "application/javascript" }));
loglevel_default().debug("[save-zip]开始生成并保存 index.html");
await saveIndex();
loglevel_default().debug("[save-zip]开始保存 Meta Data Json");
await saveMetaJson();
function modifyTocStyleText() {
if (self.book.additionalMetadate.cover) {
self.tocStyleText = `${self.tocStyleText}
.info {
display: grid;
grid-template-columns: 30% 70%;
}`;
}
else {
self.tocStyleText = `${self.tocStyleText}
.info {
display: grid;
grid-template-columns: 100%;
}`;
}
}
async function saveIndex() {
loglevel_default().debug("[save]对 chapters 排序");
self.chapters.sort(self.chapterSort);
const sectionsListObj = (0,save_misc/* getSectionsObj */.e)(self.chapters, self.chapterSort);
const _indexHtmlText = index.render({
creationDate: Date.now(),
bookname: self.book.bookname,
author: self.book.author,
cover: self.book.additionalMetadate.cover,
introductionHTML: self.book.introductionHTML?.outerHTML,
bookUrl: self.book.bookUrl,
sectionsObj: Object.values(sectionsListObj),
Status: main/* Status */.nW,
});
const indexHtmlText = (0,dom/* convertHTMLtoXHTML */.pI)(_indexHtmlText);
await self.epubZip.file("OEBPS/index.xhtml", new Blob([
indexHtmlText
.replaceAll("data-src-address", "src")
.replaceAll(/[\u{0000}-\u{001f}]/gu, "")
.replaceAll(/[\u{007f}-\u{009f}]/gu, ""),
], {
type: "application/xhtml+xml; charset=UTF-8",
}));
}
async function saveMetaJson() {
await self.epubZip.file("OEBPS/book.json", new Blob([JSON.stringify(self.book)], {
type: "application/json; charset=utf-8",
}));
await self.epubZip.file("OEBPS/chapters.json", new Blob([JSON.stringify(self.book.chapters)], {
type: "application/json; charset=utf-8",
}));
}
}
}
async addChapter(chapter, suffix = "") {
const chapterName = this.getchapterName(chapter);
const chapterNumberToSave = this.getChapterNumberToSave(chapter, this.chapters);
const chapterHtmlFileName = `No${chapterNumberToSave}Chapter${suffix}.xhtml`;
chapter.chapterHtmlFileName = chapterHtmlFileName;
loglevel_default().debug(`[save-epub]保存章HTML文件:${chapterName}`);
const chapterHTMLBlob = EPUB.genChapterHtmlFile(chapter);
await this.epubZip.file(`OEBPS/${chapterHtmlFileName}`, chapterHTMLBlob);
const item = this.contentOpf.createElement("item");
item.id = chapterHtmlFileName;
item.setAttribute("href", chapterHtmlFileName);
item.setAttribute("media-type", "application/xhtml+xml");
if (!this.manifest.querySelector(`item[id="${chapterHtmlFileName}"]`)) {
this.manifest.appendChild(item);
}
if (chapter.contentImages && chapter.contentImages.length !== 0) {
loglevel_default().debug(`[save-epub]保存章节附件:${chapterName}`);
for (const attachment of chapter.contentImages) {
await this.addAttachment(attachment);
}
}
}
async addAttachment(attachment) {
if (attachment.status === main/* Status */.nW.finished && attachment.Blob) {
loglevel_default().debug(`[save-epub]添加附件,文件名:${attachment.name},对象`, attachment.Blob);
await this.epubZip.file(`OEBPS/${attachment.name}`, attachment.Blob);
const item = this.contentOpf.createElement("item");
item.id = attachment.name;
item.setAttribute("href", attachment.name);
const mimetype = (0,misc/* extensionToMimetype */.dB)(attachment.name.substring(attachment.name.lastIndexOf(".") + 1));
item.setAttribute("media-type", mimetype);
if (!this.manifest.querySelector(`item[id="${attachment.name}"]`)) {
this.manifest.appendChild(item);
}
}
else if (attachment.status === main/* Status */.nW.saved) {
loglevel_default().debug(`[save-epub]附件${attachment.name}已添加`);
}
else {
loglevel_default().warn(`[save-epub]添加附件${attachment.name}失败,该附件未完成或内容为空。`);
loglevel_default().warn(attachment);
}
}
}
;// ./src/save/txt.ts
class TXT extends Options {
book;
savedTextArray = [];
saveFileNameBase;
constructor(book, options) {
super();
this.book = book;
this.saveFileNameBase = `[${this.book.author}]${this.book.bookname}`;
if (options) {
Object.assign(this, options);
}
}
saveTxt() {
const chapters = this.book.chapters;
const metaDateText = this.genMetaDateTxt(this.book);
this.savedTextArray.push(metaDateText);
loglevel_default().debug("[save]对 chapters 排序");
chapters.sort(this.chapterSort);
const sections = [];
for (const chapterTemp of chapters) {
const chapterName = this.getchapterName(chapterTemp);
if (chapterTemp.sectionName &&
!sections.includes(chapterTemp.sectionName)) {
sections.push(chapterTemp.sectionName);
const sectionText = this.genSectionText(chapterTemp.sectionName);
this.savedTextArray.push(sectionText);
}
const chapterText = this.genChapterText(chapterName, chapterTemp.contentText ?? "");
this.savedTextArray.push(chapterText);
if (!setting/* enableDebug */.Nw.value) {
chapterTemp.contentText = null;
}
}
loglevel_default().info("[save]保存TXT文件");
const savedText = this.savedTextArray.join("\n").replaceAll("\n", "\r\n");
(0,FileSaver_min.saveAs)(new Blob([savedText], { type: "text/plain;charset=utf-8" }), `${this.saveFileNameBase}.txt`);
}
}
;// ./src/save/raw.ts
class Raw {
book;
epubZip;
constructor(book) {
this.book = book;
if (this.book.saveType.raw instanceof Object) {
const zipFilename = `[${this.book.author}]${this.book.bookname}.${this.book.saveType.raw.ext}`;
this.epubZip = new FflateZip(zipFilename, false, (0,misc/* extensionToMimetype */.dB)(this.book.saveType.raw.ext));
}
else {
throw new Error("init raw save zip failed!");
}
}
async saveRaw() {
const attachments = this.book.additionalMetadate.attachments;
const tasks = attachments?.map(async (attach) => {
if (attach.Blob) {
await this.epubZip.file(attach.name, attach.Blob, attach.comments === "nocompress");
}
}) ?? [];
await Promise.all(tasks);
await this.epubZip.generateAsync();
}
}
;// ./src/save/save.ts
class SaveBook {
saveType;
txt;
epub;
raw;
constructor(book, streamZip, options) {
const _options = {};
if (options !== undefined) {
Object.assign(_options, options);
}
if (book.saveOptions !== undefined) {
Object.assign(_options, book.saveOptions);
}
this.saveType = book.saveType;
this.txt = new TXT(book, _options);
this.epub = new EPUB(book, streamZip, _options);
if (this.saveType.raw instanceof Object) {
this.raw = new Raw(book);
}
}
static saveLog() {
(0,FileSaver_min.saveAs)(new Blob([log/* logText */.kc], { type: "text/plain; charset=UTF-8" }), "debug.log");
}
async addChapter(chapter) {
await this.epub.addChapter(chapter);
if (!setting/* enableDebug */.Nw.value) {
chapter.contentRaw = null;
chapter.contentHTML = null;
chapter.contentImages = null;
}
if (chapter.contentImages && chapter.contentImages.length !== 0) {
for (const attachment of chapter.contentImages) {
attachment.status = main/* Status */.nW.saved;
if (!setting/* enableDebug */.Nw.value) {
attachment.Blob = null;
}
}
}
chapter.status = main/* Status */.nW.saved;
}
async save() {
if (setting/* TxtDownload */.Jv.value && this.saveType.txt) {
this.saveTxt();
}
if (setting/* enableDebug */.Nw.value) {
SaveBook.saveLog();
}
if (setting/* EpubDownload */.Zz.value && this.saveType.epub) {
await this.saveEpub();
}
if (this.saveType.raw instanceof Object) {
await this.saveRaw();
}
}
saveTxt() {
this.txt.saveTxt();
}
async saveEpub() {
await this.epub.saveEpub();
}
async saveRaw() {
await this.raw.saveRaw();
}
}
;// ./src/stat.ts
const statKeyName = "novel-downloader-22932304826849026";
const domain = document.location.hostname;
async function getStatData() {
const _data = (await (0,GM/* _GM_getValue */.er)(statKeyName));
let statData;
if (_data) {
statData = JSON.parse(_data);
}
else {
statData = { success: {}, failed: {} };
}
return statData;
}
const saveData = async (statData) => {
const dataJSON = JSON.stringify(statData);
await (0,GM/* _GM_setValue */.mN)(statKeyName, dataJSON);
return statData;
};
const dataPlus = async (key) => {
const statData = await getStatData();
const tmpData = statData[key];
if (tmpData[domain]) {
tmpData[domain] = tmpData[domain] + 1;
}
else {
tmpData[domain] = 1;
}
return saveData(statData);
};
const successPlus = () => {
return dataPlus("success");
};
const failedPlus = () => {
return dataPlus("failed");
};
const printStat = async () => {
const statData = await getStatData();
loglevel_default().info("[stat]小说下载器脚本运行情况统计:");
loglevel_default().info(statData);
for (const k in statData) {
if (Object.prototype.hasOwnProperty.call(statData, k)) {
loglevel_default().info(`[stat]${k}:`);
const subData = statData[k];
for (const j in subData) {
if (Object.prototype.hasOwnProperty.call(subData, j)) {
loglevel_default().info(` ${j}: ${subData[j]}`);
}
}
}
}
};
const resetStat = () => {
const statData = { success: {}, failed: {} };
return saveData(statData);
};
// EXTERNAL MODULE: ./src/ui/progress.ts + 1 modules
var progress = __webpack_require__("./src/ui/progress.ts");
;// ./src/rules.ts
class BaseRuleClass {
attachmentMode = "TM";
charset = document.characterSet;
concurrencyLimit = 10;
sleepTime = 50;
maxSleepTime = 500;
streamZip = false;
needLogin = false;
nsfw = false;
maxRunLimit;
saveOptions;
book;
saveType;
bcWorker = new BroadcastChannel("novel-downloader-worker");
bcWorkerMessages = [];
audio;
constructor() {
const broadcastChannelWorker = this.bcWorker;
const messages = this.bcWorkerMessages;
broadcastChannelWorker.onmessage = (ev) => {
const message = ev.data;
if (message.type === "ping") {
const pong = {
type: "pong",
src: message.workerId,
workerId: window.workerId,
url: document.location.href,
};
broadcastChannelWorker.postMessage(pong);
}
if (message.type === "pong") {
messages.push(message);
}
if (message.type === "close") {
loglevel_default().debug(`${window.workerId} has closed!`);
}
};
}
async run() {
loglevel_default().info(`[run]下载开始`);
const self = this;
try {
await self.preHook();
await initBook();
const saveBookObj = initSave(self.book);
await saveHook();
await self.initChapters(self.book, saveBookObj).catch((error) => {
if (error instanceof main/* ExpectError */.K5) {
console.warn(error);
}
else {
throw error;
}
});
await save(saveBookObj);
self.postHook();
return self.book;
}
catch (error) {
self.catchError(error);
}
async function initBook() {
if (window._book &&
window._url === document.location.href) {
self.book = window._book;
}
else {
self.book = await self.bookParse();
window._book = self.book;
window._url = document.location.href;
}
loglevel_default().debug("[book]Book object:\n" + JSON.stringify(self.book));
}
function initSave(book) {
loglevel_default().debug("[run]保存数据");
if (setting/* enableCustomSaveOptions */.k8 &&
typeof unsafeWindow.saveOptions === "object" &&
saveOptionsValidate(unsafeWindow.saveOptions)) {
const saveOptions = unsafeWindow.saveOptions;
if (saveOptions) {
loglevel_default().info("[run]发现自定义保存参数,内容如下\n", saveOptions);
return new SaveBook(book, self.streamZip, saveOptions);
}
}
return new SaveBook(book, self.streamZip);
}
async function saveHook() {
if (setting/* enableSaveToArchiveOrg */.KV &&
!self.needLogin &&
self.book?.bookUrl &&
window.localStorageExpired.get(`${self.book.bookUrl}_saveToArchiveOrg`) === undefined &&
(await (0,setting/* getCustomEnableSaveToArchiveOrg */.BV)())) {
console.log("[saveToArchiveOrg]保存当前书页至 archive.org");
try {
window.localStorageExpired.set(`${self.book.bookUrl}_saveToArchiveOrg`, true, 86400);
}
catch (error) {
}
(0,misc/* saveToArchiveOrg */.ZA)(self.book.bookUrl).then((r) => loglevel_default().info(r));
if (self.book.ToCUrl) {
(0,misc/* saveToArchiveOrg */.ZA)(self.book.ToCUrl).then((r) => loglevel_default().info(r));
}
}
}
async function save(saveObj) {
loglevel_default().debug("[run]开始保存文件");
await saveObj.save();
}
}
async preHook() {
const self = this;
if (!(await preTest())) {
const alertText = `当前网站目前最多允许${self.maxRunLimit}个下载任务同时进行。\n请待其它下载任务完成后,再行尝试。`;
alert(alertText);
loglevel_default().info(`[run]${alertText}`);
throw new main/* ExpectError */.K5(alertText);
}
self.audio = new Audio("data:audio/mp3;base64,SUQzBAAAAAAAI1RTU0UAAAAPAAADTGF2ZjU3LjcxLjEwMAAAAAAAAAAAAAAA/+M4wAAAAAAAAAAAAEluZm8AAAAPAAAAEAAABVgANTU1NTU1Q0NDQ0NDUFBQUFBQXl5eXl5ea2tra2tra3l5eXl5eYaGhoaGhpSUlJSUlKGhoaGhoaGvr6+vr6+8vLy8vLzKysrKysrX19fX19fX5eXl5eXl8vLy8vLy////////AAAAAExhdmM1Ny44OQAAAAAAAAAAAAAAACQCgAAAAAAAAAVY82AhbwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA/+MYxAALACwAAP/AADwQKVE9YWDGPkQWpT66yk4+zIiYPoTUaT3tnU487uNhOvEmQDaCm1Yz1c6DPjbs6zdZVBk0pdGpMzxF/+MYxA8L0DU0AP+0ANkwmYaAMkOKDDjmYoMtwNMyDxMzDHE/MEsLow9AtDnBlQgDhTx+Eye0GgMHoCyDC8gUswJcMVMABBGj/+MYxBoK4DVpQP8iAtVmDk7LPgi8wvDzI4/MWAwK1T7rxOQwtsItMMQBazAowc4wZMC5MF4AeQAGDpruNuMEzyfjLBJhACU+/+MYxCkJ4DVcAP8MAO9J9THVg6oxRMGNMIqCCTAEwzwwBkINOPAs/iwjgBnMepYyId0PhWo+80PXMVsBFzD/AiwwfcKGMEJB/+MYxDwKKDVkAP8eAF8wMwIxMlpU/OaDPLpNKkEw4dRoBh6qP2FC8jCJQFcweQIPMHOBtTBoAVcwOoCNMYDI0u0Dd8ANTIsy/+MYxE4KUDVsAP8eAFBVpgVVPjdGeTEWQr0wdcDtMCeBgDBkgRgwFYB7Pv/zqx0yQQMCCgKNgonHKj6RRVkxM0GwML0AhDAN/+MYxF8KCDVwAP8MAIHZMDDA3DArAQo3K+TF5WOBDQw0lgcKQUJxhT5sxRcwQQI+EIPWMA7AVBoTABgTgzfBN+ajn3c0lZMe/+MYxHEJyDV0AP7MAA4eEwsqP/PDmzC/gNcwXUGaMBVBIwMEsmB6gaxhVuGkpoqMZMQjooTBwM0+S8FTMC0BcjBTgPwwOQDm/+MYxIQKKDV4AP8WADAzAKQwI4CGPhWOEwCFAiBAYQnQMT+uwXUeGzjBWQVkwTcENMBzA2zAGgFEJfSPkPSZzPXgqFy2h0xB/+MYxJYJCDV8AP7WAE0+7kK7MQrATDAvQRIwOADKMBuA9TAYQNM3AiOSPjGxowgHMKFGcBNMQU1FMy45OS41VVU/31eYM4sK/+MYxKwJaDV8AP7SAI4y1Yq0MmOIADGwBZwwlgIJMztCM0qU5TQPG/MSkn8yEROzCdAxECVMQU1FMy45OS41VTe7Ohk+Pqcx/+MYxMEJMDWAAP6MADVLDFUx+4J6Mq7NsjN2zXo8V5fjVJCXNOhwM0vTCDAxFpMYYQU+RlVMQU1FMy45OS41VVVVVVVVVVVV/+MYxNcJADWAAP7EAFVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVV/+MYxOsJwDWEAP7SAFVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVV/+MYxPMLoDV8AP+eAFVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVV/+MYxPQL0DVcAP+0AFVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVV");
self.audio.loop = true;
await self.audio.play();
window.onbeforeunload = (e) => {
e.preventDefault();
const confirmationText = "您正尝试离开本页面,当前页面有下载任务正在运行,是否确认离开?";
return (e.returnValue = confirmationText);
};
window.downloading = true;
async function preTest() {
const broadcastChannelWorker = self.bcWorker;
const messages = self.bcWorkerMessages;
const ping = {
type: "ping",
workerId: window.workerId,
url: document.location.href,
};
broadcastChannelWorker.postMessage(ping);
await (0,misc/* sleep */.yy)(300);
const workers = messages
.filter((m) => m.type === "pong" &&
m.src === window.workerId &&
m.workerId !== window.workerId)
.map((m) => ({
id: m.workerId,
url: m.url,
}));
loglevel_default().info(JSON.stringify(workers, undefined, 4));
const nowRunning = workers.length;
loglevel_default().info(`[preTest]nowRunning: ${nowRunning}`);
if (self.maxRunLimit) {
return nowRunning < self.maxRunLimit;
}
else {
return true;
}
}
}
async initChapters(book, saveBookObj) {
const self = this;
loglevel_default().info(`[initChapters]开始初始化章节`);
Object.entries(self).forEach((kv) => loglevel_default().info(`[initChapters] ${kv[0]}: ${kv[1]}`));
const chapters = getChapters(book);
if (chapters.length === 0) {
loglevel_default().error(`[initChapters]初始化章节出错,未找到需初始化章节`);
return [];
}
progress.vm.totalChapterNumber = chapters.length;
if (self.concurrencyLimit === 1) {
let chapteri = -1;
for (const chapter of chapters) {
if (window.failedCount > 10) {
if (!window.stopFlag.aborted) {
window.stopController.abort();
console.error("连续十章下载失败,放弃本次下载。\n请附上相关日志至支持地址进行反馈。\n支持地址:https://github.com/404-novel-project/novel-downloader");
alert("连续十章下载失败,放弃本次下载。\n请附上相关日志至支持地址进行反馈。\n支持地址:https://github.com/404-novel-project/novel-downloader");
(0,log/* saveLogTextToFile */.M6)();
}
}
if (window.stopFlag.aborted) {
throw new main/* ExpectError */.K5("[chapter]收到停止信号,停止继续下载。");
}
try {
chapteri++;
await (0,misc/* sleep */.yy)(Math.min(self.maxSleepTime, chapteri * self.sleepTime) + Math.round(Math.random() * 1000));
let chapterObj = await chapter.init();
chapterObj = await postChapterParseHook(chapterObj, saveBookObj);
}
catch (error) {
loglevel_default().error(error);
loglevel_default().trace(error);
}
}
}
else {
const asyncHandle = async (curChapter) => {
if (window.failedCount > 10) {
if (!window.stopFlag.aborted) {
window.stopController.abort();
console.error("连续十章下载失败,放弃本次下载。\n请附上相关日志至支持地址进行反馈。\n支持地址:https://github.com/404-novel-project/novel-downloader");
alert("连续十章下载失败,放弃本次下载。\n请附上相关日志至支持地址进行反馈。\n支持地址:https://github.com/404-novel-project/novel-downloader");
(0,log/* saveLogTextToFile */.M6)();
}
}
if (curChapter === undefined) {
return null;
}
try {
let chapterObj = await curChapter.init();
chapterObj = await postChapterParseHook(chapterObj, saveBookObj);
return chapterObj;
}
catch (error) {
loglevel_default().error(error);
loglevel_default().trace(error);
}
};
await (0,misc/* concurrencyRun */.rr)(chapters, self.concurrencyLimit, asyncHandle, {
signal: window.stopFlag,
reason: "[chapter]收到停止信号,停止继续下载。",
});
}
loglevel_default().info(`[initChapters]章节初始化完毕`);
return chapters;
function getChapters(_book) {
function isEnable() {
if (setting/* enableCustomChapterFilter */.U5 &&
typeof unsafeWindow.chapterFilter === "function") {
let text = "[initChapters]发现自定义筛选函数,自定义筛选函数内容如下:\n";
text += unsafeWindow.chapterFilter?.toString();
loglevel_default().info(text);
return true;
}
else {
return false;
}
}
function _filter(chapter) {
let b = true;
try {
const u = unsafeWindow.chapterFilter?.(chapter);
if (typeof u === "boolean") {
b = u;
}
}
catch (error) {
loglevel_default().error("运行自定义筛选函数时出错。", error);
loglevel_default().trace(error);
}
return b;
}
let _chapters = _book.chapters.filter((chapter) => chapter.status === main/* Status */.nW.pending);
const enabled = isEnable();
if (enabled) {
loglevel_default().debug("[initChapters]筛选需下载章节");
_chapters = _chapters.filter((chapter) => _filter(chapter));
}
return _chapters;
}
async function postChapterParseHook(chapter, saveObj) {
if (chapter.contentHTML !== undefined) {
await saveObj.addChapter(chapter);
progress.vm.finishedChapterNumber++;
}
return chapter;
}
}
postHook() {
const self = this;
(0,attachments/* clearAttachmentClassCache */.rd)();
self.audio?.pause();
self.audio?.remove();
const closeMessage = {
type: "close",
workerId: window.workerId,
url: document.location.href,
};
self.bcWorker.postMessage(closeMessage);
self.bcWorker.onmessage = null;
self.bcWorker.close();
self.bcWorkerMessages.splice(0, self.bcWorkerMessages.length);
window.onbeforeunload = null;
window.downloading = false;
progress.vm.reset();
window._book = undefined;
window._url = undefined;
postCallback();
successPlus().then(() => {
printStat();
});
function postCallback() {
if (setting/* enableCustomFinishCallback */.zb &&
typeof unsafeWindow.customFinishCallback ===
"function") {
const customFinishCallback = unsafeWindow
.customFinishCallback;
if (customFinishCallback) {
loglevel_default().info(`发现自定义结束回调函数,内容如下:\n${customFinishCallback.toString()}`);
customFinishCallback();
}
}
}
}
catchError(error) {
const self = this;
loglevel_default().error(error);
loglevel_default().trace(error);
self.postHook();
if (!(error instanceof main/* ExpectError */.K5)) {
document.getElementById("button-div")?.remove();
loglevel_default().error("运行过程出错,请附上相关日志至支持地址进行反馈。\n支持地址:https://github.com/404-novel-project/novel-downloader");
failedPlus();
alert("运行过程出错,请附上相关日志至支持地址进行反馈。\n支持地址:https://github.com/404-novel-project/novel-downloader");
window.open("https://github.com/404-novel-project/novel-downloader/issues");
(0,log/* saveLogTextToFile */.M6)();
}
}
}
/***/ }),
/***/ "./src/rules/biquge/mht.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ mht: () => (/* binding */ mht)
/* harmony export */ });
/* harmony import */ var _onePage_template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePage/template.ts");
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/rules/biquge/template.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/lib/cleanDOM.ts");
const mht = () => (0,_onePage_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
...(0,_template__WEBPACK_IMPORTED_MODULE_1__/* .baseOnePage */ .Tm)((introDom) => introDom, 5),
getContentFromUrl: async (chapterUrl, chapterName, charset) => {
const ngetHtmlDOM = (input, charset, init) => {
const test = async (response) => {
const resp = response.clone();
const text = await resp.text();
return text.includes('<div id="content">');
};
return (0,_lib_http__WEBPACK_IMPORTED_MODULE_2__/* .getHtmlDOM */ .wA)(input, charset, init, test);
};
const { contentRaw } = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_3__/* .nextPageParse */ .u1)({
chapterName,
chapterUrl,
charset,
selector: "#content",
contentPatch: (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_4__.rm)("p[data-id]", true, content);
(0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_5__/* .htmlTrim */ .is)(content);
return content;
},
getNextPage: (doc) => doc.querySelector(".bottem2 > a:nth-child(4)")
.href,
continueCondition: (_content, nextLink) => new URL(nextLink).pathname.includes("_"),
enableCleanDOM: false,
getHtmlDomFunc: ngetHtmlDOM,
});
return contentRaw;
},
contentPatch: (dom) => dom,
});
/***/ }),
/***/ "./src/rules/biquge/multiIndexNextPage.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ c226ks: () => (/* binding */ c226ks),
/* harmony export */ znlzd: () => (/* binding */ znlzd)
/* harmony export */ });
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/biquge/template.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/dom.ts");
const znlzd = () => (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkBiqugeMultiIndexNextPage */ .FN)((dom) => dom, (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)("div", true, content);
return content;
}, (doc) => doc.querySelector("div.section-opt:nth-child(1) > a:nth-child(5)")?.href ?? "", (_content, nextLink) => {
if (nextLink === "") {
return false;
}
const pathname = nextLink.split("/").slice(-1)[0];
return pathname.includes("_");
}, 3);
const c226ks = () => (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkBiqugeMultiIndexNextPage */ .FN)((introDom) => introDom, (content) => content, (doc) => doc.querySelector("section.g-content-nav > a:nth-child(3)").href, (_content, nextLink) => {
const pathname = nextLink.split("/").slice(-1)[0];
return pathname.includes("_");
});
/***/ }),
/***/ "./src/rules/biquge/nextPage.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ mijiashe: () => (/* binding */ mijiashe),
/* harmony export */ xinwanben: () => (/* binding */ xinwanben),
/* harmony export */ ywggzy: () => (/* binding */ ywggzy)
/* harmony export */ });
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/biquge/template.ts");
const xinwanben = () => (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkBiqugeNextPage */ .uk)((introDom) => {
const _bookname = introDom.innerHTML.match(/《(.*)》/);
let bookname;
if (_bookname?.length === 2) {
bookname = _bookname[1];
}
const adList = [
"还不错的话请不要忘记向您QQ群和微博里的朋友推荐哦!",
"小说免费阅读地址:",
];
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__/* .rm2 */ .Sf)(adList, introDom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__/* .rms */ .j3)([`${bookname}小说简介:`], introDom);
return introDom;
}, (content) => {
const filters = [
"手机用户输入地址",
"提示:浏览器搜索",
"把本站分享那些需要的小伙伴!找不到书请留言!",
"【完本神站】",
];
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__/* .rm2 */ .Sf)(filters, content);
(0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_2__/* .htmlTrim */ .is)(content);
return content;
}, (doc) => doc.querySelector("#next_url").href, (_content, nextLink) => new URL(nextLink).pathname.includes("_"));
const mijiashe = () => (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkBiqugeNextPage */ .uk)((introDom) => {
const _bookname = introDom.innerHTML.match(/《(.*)》/);
let bookname;
if (_bookname?.length === 2) {
bookname = _bookname[1];
}
const adList = [
"还不错的话请不要忘记向您QQ群和微博里的朋友推荐哦!",
"小说免费阅读地址:",
];
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__/* .rm2 */ .Sf)(adList, introDom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__/* .rms */ .j3)([`${bookname}小说简介:`], introDom);
return introDom;
}, (content) => {
const filters = [
"谨记我们的网址,祝大家阅读愉快!别忘了多多宣传宣传。",
"【提示】:如果觉得此文不错,请推荐给更多小伙伴吧!分享也是一种享受。",
];
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__/* .rm2 */ .Sf)(filters, content);
(0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_2__/* .htmlTrim */ .is)(content);
return content;
}, (doc) => doc.querySelector("#next_url").href, (_content, nextLink) => new URL(nextLink).pathname.includes("_"));
const ywggzy = () => (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkBiqugeNextPage */ .uk)((initroDom) => initroDom, (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)(".posterror", false, content);
return content;
}, (doc) => doc.querySelector("div.section-opt:nth-child(1) > a:nth-child(5)")?.href ?? "", (_content, nextLink) => new URL(nextLink).pathname.includes("_"));
/***/ }),
/***/ "./src/rules/biquge/onePage.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ b5200: () => (/* binding */ b5200),
/* harmony export */ biquwx: () => (/* binding */ biquwx),
/* harmony export */ bxwx333: () => (/* binding */ bxwx333),
/* harmony export */ c25zw: () => (/* binding */ c25zw),
/* harmony export */ common: () => (/* binding */ common),
/* harmony export */ dijiubook: () => (/* binding */ dijiubook),
/* harmony export */ gebiqu: () => (/* binding */ gebiqu),
/* harmony export */ la42zw: () => (/* binding */ la42zw),
/* harmony export */ lewenn: () => (/* binding */ lewenn),
/* harmony export */ luoqiuzw: () => (/* binding */ luoqiuzw),
/* harmony export */ lusetxt: () => (/* binding */ lusetxt),
/* harmony export */ ranwen: () => (/* binding */ ranwen),
/* harmony export */ shuquge: () => (/* binding */ shuquge),
/* harmony export */ tycqxs: () => (/* binding */ tycqxs),
/* harmony export */ xbiquge: () => (/* binding */ xbiquge),
/* harmony export */ xbiqugeLa: () => (/* binding */ xbiqugeLa),
/* harmony export */ xyb3: () => (/* binding */ xyb3),
/* harmony export */ yqxs: () => (/* binding */ yqxs),
/* harmony export */ yruan: () => (/* binding */ yruan)
/* harmony export */ });
/* harmony import */ var _lib_misc__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/misc.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/rules/biquge/template.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/lib/cleanDOM.ts");
const commonContentPatch = (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__.rm)("script", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__.rm)("div[style]", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__.rm)("div[align]", true, content);
return content;
};
const common = () => (0,_template__WEBPACK_IMPORTED_MODULE_1__/* .mkBiquge */ .Wt)((introDom) => introDom, commonContentPatch);
const gebiqu = () => (0,_template__WEBPACK_IMPORTED_MODULE_1__/* .mkBiquge */ .Wt)((introDom) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__/* .rms */ .j3)([/如果您喜欢.+,别忘记分享给朋友/g], introDom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__.rm)('a[href^="http://down.gebiqu.com"]', false, introDom);
return introDom;
}, (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__/* .rms */ .j3)([/"www.gashuw.com"/g], content);
return content;
});
const luoqiuzw = () => (0,_template__WEBPACK_IMPORTED_MODULE_1__/* .mkBiquge */ .Wt)((introDom) => introDom, (content) => {
const ad = content.firstElementChild;
if (ad.innerText.includes("天才一秒记住本站地址:")) {
ad.remove();
}
const ads = ["记住网址m.luoqiuxzw.com"];
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__/* .rms */ .j3)(ads, content);
return content;
});
const biquwx = () => (0,_template__WEBPACK_IMPORTED_MODULE_1__/* .mkBiquge */ .Wt)((introDom) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__/* .rms */ .j3)([
/本站提示:各位书友要是觉得《.+》还不错的话请不要忘记向您QQ群和微博里的朋友推荐哦!/,
], introDom);
return introDom;
}, (content) => content, 1);
const tycqxs = () => (0,_template__WEBPACK_IMPORTED_MODULE_1__/* .mkBiquge */ .Wt)((introDom) => introDom, (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__.rm)("a", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__/* .rms */ .j3)(["推荐都市大神老施新书:"], content);
return content;
});
const dijiubook = () => (0,_template__WEBPACK_IMPORTED_MODULE_1__/* .mkBiquge */ .Wt)((introDom) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__/* .rms */ .j3)(["本书网址:"], introDom);
return introDom;
}, (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__.rm)("a", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__.rm)('img[src$="alipay.png"]', true, content);
return content;
}, 1, 50, 3000, (classThis) => {
classThis.maxRunLimit = 1;
const chapterParse = classThis.chapterParse;
classThis.chapterParse = async (...args) => {
const obj = await chapterParse(...args);
await (0,_lib_misc__WEBPACK_IMPORTED_MODULE_2__/* .sleep */ .yy)(3000 * Math.random());
return obj;
};
return classThis;
}, (chapter) => {
const url = new URL(chapter.chapterUrl);
if (url.host === "m.dijiuben.com" || url.href.endsWith(".apk")) {
return;
}
else {
return chapter;
}
});
const c25zw = () => (0,_template__WEBPACK_IMPORTED_MODULE_1__/* .mkBiquge */ .Wt)((introDom) => {
introDom.querySelector("font")?.parentElement?.remove();
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__/* .rms */ .j3)(["简介:"], introDom);
return introDom;
}, (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__.rm)(".bottem", false, content);
return content;
});
const xbiquge = () => (0,_template__WEBPACK_IMPORTED_MODULE_1__/* .mkBiquge */ .Wt)((introDom) => introDom, (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__/* .rms */ .j3)([/笔趣阁 www.xbiquge.tw,最快更新.+ !/], content);
return content;
});
const yruan = () => (0,_template__WEBPACK_IMPORTED_MODULE_1__/* .mkBiquge */ .Wt)((introDom) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__/* .rm2 */ .Sf)(["本站提示:各位书友要是觉得"], introDom);
return introDom;
}, (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__.rm)("b", true, content);
return content;
}, 3);
const ranwen = () => (0,_template__WEBPACK_IMPORTED_MODULE_1__/* .mkBiquge */ .Wt)((introDom) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__/* .rm2 */ .Sf)(["还不错的话请不要忘记向您QQ群和微博里的朋友推荐哦!"], introDom);
return introDom;
}, (content) => content);
const b5200 = () => (0,_template__WEBPACK_IMPORTED_MODULE_1__/* .mkBiquge */ .Wt)((introDom) => introDom, (content) => content, 1);
const bxwx333 = () => (0,_template__WEBPACK_IMPORTED_MODULE_1__/* .mkBiquge */ .Wt)((introDom) => introDom, (content) => {
content.querySelector("#xuanchuan")?.parentElement?.remove();
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__.rm)("div[style]", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__.rm)(".bottem2", true, content);
return content;
}, undefined, undefined, undefined, undefined, undefined, "#zjneirong");
const xbiqugeLa = () => (0,_template__WEBPACK_IMPORTED_MODULE_1__/* .mkBiquge */ .Wt)((introDom) => {
introDom.querySelector("font")?.parentElement?.remove();
return introDom;
}, (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__/* .rm2 */ .Sf)(["手机站全新改版升级地址"], content);
return content;
}, 1);
const shuquge = () => (0,_template__WEBPACK_IMPORTED_MODULE_1__/* .mkBiquge */ .Wt)((introDom) => {
document.querySelector(".noshow")?.classList.remove("noshow");
if (document.querySelector(".showall")) {
document.querySelector(".showall").innerHTML = "";
}
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__/* .rms */ .j3)([
/作者:.+所写的《.+》无弹窗免费全文阅读为转载作品,章节由网友发布。/,
/推荐地址:https?:\/\/www\.ishuquge\.org\/txt\/\d+\/index\.html/g,
], introDom);
return introDom;
}, (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__/* .rm2 */ .Sf)(["请记住本书首发域名:", "www.ishuquge.org"], content);
return content;
}, 1);
const lusetxt = () => (0,_template__WEBPACK_IMPORTED_MODULE_1__/* .mkBiquge */ .Wt)((introDom) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__/* .rm2 */ .Sf)(["无弹窗免费全文阅读为转载作品", "无弹窗推荐地址", "简介:"], introDom);
return introDom;
}, (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__.rm)("script", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__.rm)("div[style]", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__.rm)("div[align]", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__/* .rm2 */ .Sf)(["https://www.lvsewx.com/books", "请记住本书首发域名"], content);
(0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_3__/* .htmlTrim */ .is)(content);
return content;
});
const yqxs = () => (0,_template__WEBPACK_IMPORTED_MODULE_1__/* .mkBiquge */ .Wt)((introDom) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__/* .rms */ .j3)(["<span>简介:</span>"], introDom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__/* .rm2 */ .Sf)(["推荐地址:"], introDom);
return introDom;
}, (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__.rm)("script", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__.rm)('div[align="center"]', false, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__/* .rm2 */ .Sf)(["//www.yqxsge.cc/html/", "请记住本书首发域名"], content);
return content;
});
const lewenn = () => (0,_template__WEBPACK_IMPORTED_MODULE_1__/* .mkBiquge */ .Wt)((introDom) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__/* .rms */ .j3)([
/各位书友要是觉得《.*》还不错的话请不要忘记向您QQ群和微博里的朋友推荐哦!/,
], introDom);
return introDom;
}, (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__.rm)("script", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__.rm)('div[align="center"]', false, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__/* .rm2 */ .Sf)(["//www.lewenn.net/lw", "1秒记住乐文小说网"], content);
return content;
});
const xyb3 = () => (0,_template__WEBPACK_IMPORTED_MODULE_1__/* .mkBiquge */ .Wt)((introDom) => introDom, (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__.rm)("script", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__.rm)("div[style]", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__.rm)("div[align]", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__/* .rm2 */ .Sf)([
"由于各种问题yb3.cc地址更改为xyb3.net请大家收藏新地址避免迷路",
"网页版章节内容慢,请下载好阅小说app阅读最新内容",
"请退出转码页面,请下载好阅小说app 阅读最新章节。",
"https://www.xyb3.net",
], content);
return content;
});
const la42zw = () => (0,_template__WEBPACK_IMPORTED_MODULE_1__/* .mkBiquge */ .Wt)((introDom) => introDom, (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__.rm)("div#content > p:first-child", false, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__/* .rms */ .j3)([
"首发网址https://m.42zw.la",
"记住网址m.42zw.la",
"一秒记住https://m.42zw.la"
], content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_0__.rm)("br", true, content);
return content;
});
/***/ }),
/***/ "./src/rules/biquge/template.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ FN: () => (/* binding */ mkBiqugeMultiIndexNextPage),
/* harmony export */ Tm: () => (/* binding */ baseOnePage),
/* harmony export */ Wt: () => (/* binding */ mkBiquge),
/* harmony export */ uk: () => (/* binding */ mkBiqugeNextPage)
/* harmony export */ });
/* unused harmony exports baseMultiIndex, mkBiqugeMultiIndex */
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _onePage_template__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/rules/onePage/template.ts");
/* harmony import */ var _onePageWithMultiIndexPage_template__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/rules/onePageWithMultiIndexPage/template.ts");
function base(introDomPatch, concurrencyLimit, sleepTime, maxSleepTime, overRide, postHook) {
return {
bookUrl: document.location.href,
bookname: document.querySelector("#info h1, .info h2, .info h1").innerText
.trim()
.replace(/最新章节$/, ""),
author: document.querySelector("#info > p:nth-child(2), #info > div:nth-child(2), .info .author, .small > span:nth-child(1), .info .fix > p:nth-child(1)").innerText
.replace(/作(\s+)?者[::]/, "")
.trim(),
introDom: document.querySelector("#intro, .intro, .book-intro, .desc"),
introDomPatch,
coverUrl: document.querySelector("#fmimg > img, .info > .cover > img, .book-boxs > .img > img, .imgbox > img")?.src ?? null,
postHook: (chapter) => {
if (chapter.sectionName) {
if (chapter.sectionName.includes("《")) {
chapter.sectionName = chapter.sectionName
.replace(`《${chapter.bookname}》`, "")
.trim();
}
else {
chapter.sectionName = chapter.sectionName
.replace(chapter.bookname, "")
.trim();
}
}
if (postHook) {
return postHook(chapter);
}
return chapter;
},
concurrencyLimit,
sleepTime,
maxSleepTime,
overrideConstructor: (classThis) => {
const rawBookParse = classThis.bookParse;
classThis.bookParse = async () => {
const book = (await Reflect.apply(rawBookParse, classThis, []));
const chapters = book.chapters;
book.chapters = (0,_lib_rule__WEBPACK_IMPORTED_MODULE_0__/* .deDuplicate */ .hR)(chapters);
return book;
};
if (overRide) {
overRide(classThis);
}
return classThis;
},
};
}
function baseOnePage(introDomPatch, concurrencyLimit, sleepTime, maxSleepTime, overRide, postHook) {
return {
...base(introDomPatch, concurrencyLimit, sleepTime, maxSleepTime, overRide, postHook),
aList: document.querySelectorAll("#list a, .listmain a, .book-item a"),
sections: document.querySelectorAll("#list dt, .listmain dt, .layout-tit"),
getSName: (sElem) => {
const b = sElem.querySelector("b");
if (b) {
return b.innerText;
}
return sElem.innerText;
},
};
}
function baseMultiIndex(introDomPatch, concurrencyLimit, sleepTime, maxSleepTime, overRide, postHook) {
return {
...base(introDomPatch, concurrencyLimit, sleepTime, maxSleepTime, overRide, postHook),
getIndexUrls: () => Array.from(document.querySelectorAll('select[name="pageselect"] > option')).map((o) => document.location.origin + o.getAttribute("value")),
getAList: (doc) => {
const sectionList = Array.from(doc.querySelectorAll("ul.section-list.fix, ul.list")).slice(-1)[0];
if (!sectionList) {
throw new Error("获取章节列表失败!");
}
return sectionList.querySelectorAll("li > a");
},
};
}
function mkBiquge(introDomPatch, contentPatch, concurrencyLimit, sleepTime, maxSleepTime, overRide, postHook, chapterContenSelector = "#content") {
return (0,_onePage_template__WEBPACK_IMPORTED_MODULE_1__/* .mkRuleClass */ .N)({
...baseOnePage(introDomPatch, concurrencyLimit, sleepTime, maxSleepTime, overRide, postHook),
getContent: (doc) => doc.querySelector(chapterContenSelector),
contentPatch,
});
}
function mkBiqugeNextPage(introDomPatch, contentPatch, getNextPage, continueCondition, concurrencyLimit, sleepTime, maxSleepTime, overRide, postHook, chapterContenSelector = "#content") {
return (0,_onePage_template__WEBPACK_IMPORTED_MODULE_1__/* .mkRuleClass */ .N)({
...baseOnePage(introDomPatch, concurrencyLimit, sleepTime, maxSleepTime, overRide, postHook),
getContentFromUrl: async (chapterUrl, chapterName, charset) => {
const { contentRaw } = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_0__/* .nextPageParse */ .u1)({
chapterName,
chapterUrl,
charset,
selector: chapterContenSelector,
contentPatch,
getNextPage,
continueCondition,
enableCleanDOM: false,
});
return contentRaw;
},
contentPatch: (dom) => dom,
});
}
function mkBiqugeMultiIndexNextPage(introDomPatch, contentPatch, getNextPage, continueCondition, concurrencyLimit, sleepTime, maxSleepTime, overRide, postHook, chapterContenSelector = "#content") {
return (0,_onePageWithMultiIndexPage_template__WEBPACK_IMPORTED_MODULE_2__/* .mkRuleClass */ .N)({
...baseMultiIndex(introDomPatch, concurrencyLimit, sleepTime, maxSleepTime, overRide, postHook),
getContentFromUrl: async (chapterUrl, chapterName, charset) => {
const { contentRaw } = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_0__/* .nextPageParse */ .u1)({
chapterName,
chapterUrl,
charset,
selector: chapterContenSelector,
contentPatch,
getNextPage,
continueCondition,
enableCleanDOM: false,
});
return contentRaw;
},
contentPatch: (dom) => dom,
});
}
function mkBiqugeMultiIndex(introDomPatch, contentPatch, concurrencyLimit, sleepTime, maxSleepTime, overRide, postHook, chapterContenSelector = "#content") {
return mkRuleClassMultiIndex({
...baseMultiIndex(introDomPatch, concurrencyLimit, sleepTime, maxSleepTime, overRide, postHook),
getContent: (doc) => doc.querySelector(chapterContenSelector),
contentPatch,
});
}
/***/ }),
/***/ "./src/rules/mbtxt/mbtxt.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ mbtxt: () => (/* binding */ mbtxt)
/* harmony export */ });
/* harmony import */ var _onePage_template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePage/template.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/dom.ts");
const mbtxt = () => (0,_onePage_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector(".booktitle").innerText.trim(),
author: document.querySelector("a.red").innerText.trim(),
introDom: document.querySelector(".bookintro"),
introDomPatch: (dom) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)(".visible-xs", true, dom);
return dom;
},
coverUrl: document.querySelector(".bookcover > img")?.src,
aList: document.querySelectorAll("#list-chapterAll > dd > a"),
getContentFromUrl: async (chapterUrl, chapterName, charset) => {
const { contentRaw } = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_2__/* .nextPageParse */ .u1)({
chapterName,
chapterUrl,
charset,
selector: ".readcontent",
contentPatch: (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)(".kongwen", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)(".readmiddle", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)(".text-danger.text-center", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__/* .rms */ .j3)(["-->>"], content);
return content;
},
getNextPage: (doc) => doc.querySelector("#linkNext")?.href ?? "",
continueCondition: (content, nextLink) => {
if (nextLink === "") {
return false;
}
return nextLink.includes("_");
},
enableCleanDOM: false,
});
return contentRaw;
},
contentPatch: (dom) => dom,
});
/***/ }),
/***/ "./src/rules/mbtxt/quanshuzhai.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ quanshuzhai: () => (/* binding */ quanshuzhai)
/* harmony export */ });
/* harmony import */ var _onePage_template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePage/template.ts");
const quanshuzhai = () => (0,_onePage_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector(".booktitle").innerText.trim(),
author: document.querySelector("a.red").innerText.trim(),
introDom: document.querySelector(".bookintro"),
introDomPatch: (dom) => dom,
coverUrl: null,
aList: document.querySelectorAll("#list-chapterAll > dd > a"),
getContent: (doc) => doc.querySelector(".readcontent"),
contentPatch: (dom) => dom,
});
/***/ }),
/***/ "./src/rules/onePage/256wxc.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ c256wxc: () => (/* binding */ c256wxc)
/* harmony export */ });
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePage/template.ts");
const c256wxc = (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector(".art_tit").innerText.trim(),
author: (document.querySelector("span.bookinfo:nth-child(1) > a") ??
document.querySelector("span.bookinfo:nth-child(1)")).innerText
.replace(/^作者:/, "")
.trim(),
introDom: document.querySelector(".infotype > p"),
introDomPatch: (introDom) => introDom,
coverUrl: null,
aList: document.querySelectorAll(".catalog > li > a"),
getContent: (doc) => doc.querySelector(".book_con"),
contentPatch: (content) => content,
});
/***/ }),
/***/ "./src/rules/onePage/630shu.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ c630shu: () => (/* binding */ c630shu)
/* harmony export */ });
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePage/template.ts");
const c630shu = (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector("#info > h1").innerText.trim(),
author: document.querySelector("div.options > span.item:nth-child(1) > a").innerText.trim(),
introDom: document.querySelector("#intro"),
introDomPatch: (introDom) => introDom,
coverUrl: document.querySelector(".img_in > img").src,
aList: document.querySelectorAll(".zjlist > dd > a"),
getContent: (doc) => doc.querySelector("#content"),
contentPatch: (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__/* .rms */ .j3)([/恋上你看书网 WWW.630SHU.NET ,最快更新.+最新章节!/], content);
return content;
},
});
/***/ }),
/***/ "./src/rules/onePage/aixdzs.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ aixdzs: () => (/* binding */ aixdzs)
/* harmony export */ });
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePage/template.ts");
const aixdzs = () => (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector(".d_info > h1").innerText.trim(),
author: document.querySelector(".d_ac > ul:nth-child(1) > li:nth-child(1) > a:nth-child(2)").innerText.trim(),
introDom: document.querySelector(".d_co"),
introDomPatch: (dom) => dom,
coverUrl: document.querySelector(".d_af > img").src,
aList: document.querySelectorAll("#i-chapter li.chapter > a"),
sections: document.querySelectorAll("#i-chapter li.volume"),
getSName: (dom) => dom.innerText.trim(),
getContent: (doc) => doc.querySelector(".content"),
contentPatch: (dom) => dom,
});
/***/ }),
/***/ "./src/rules/onePage/boqugew.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ boqugew: () => (/* binding */ boqugew)
/* harmony export */ });
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePage/template.ts");
const boqugew = () => (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector("h1.bookTitle").innerText.trim(),
author: document.querySelector("p.booktag > a:first-child").innerText.replace(/作(\s+)?者[::]/, "").trim(),
introDom: document.querySelector("p#bookIntro"),
introDomPatch: (introDom) => introDom,
coverUrl: document.querySelector("img.img-thumbnail").src,
aList: document.querySelectorAll("div#list-chapterAll > dl > dd > a"),
getContent: (doc) => doc.querySelector("div#htmlContent"),
contentPatch: (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__/* .rms */ .j3)([
"记住网址m.boqugew.com",
"一秒记住http://m.boqugew.com",
"首发网址http://m.boqugew.com"
], content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)("br", true, content);
return content;
},
});
/***/ }),
/***/ "./src/rules/onePage/colorful-fantasybooks.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ fantasybooks: () => (/* binding */ fantasybooks)
/* harmony export */ });
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePage/template.ts");
const fantasybooks = () => (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector(".works-intro-title > strong").innerText.trim(),
author: document.querySelector(".works-intro-digi > span:nth-child(1) > em:nth-child(1)").innerText.trim(),
introDom: document.querySelector(".works-intro-short"),
introDomPatch: (dom) => dom,
coverUrl: document.querySelector(".works-cover > img")
.src,
aList: document.querySelectorAll(".works-chapter-list .works-chapter-item > a"),
sections: document.querySelectorAll(".vloume"),
getSName: (sElem) => sElem.innerText.trim(),
getContent: (doc) => doc.querySelector("#content_cust"),
contentPatch: (content) => {
Array.from(content.children)
.filter((node) => node.nodeName === "SPAN" && node.childNodes.length > 15)
.map((span) => {
const div = document.createElement("div");
div.innerHTML = span.innerHTML;
Array.from(div.querySelectorAll("p"))
.filter((node) => node.childElementCount === 1 &&
node.children[0].nodeName === "BR")
.forEach((pbrp) => pbrp.remove());
span.replaceWith(div);
});
return content;
},
concurrencyLimit: 3,
nsfw: true,
});
/***/ }),
/***/ "./src/rules/onePage/dizishu.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ dizishu: () => (/* binding */ dizishu)
/* harmony export */ });
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePage/template.ts");
const dizishu = () => (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector(".book-text > h1").innerText.trim(),
author: document.querySelector(".book-text > span").innerText
.replace("著", "")
.trim(),
introDom: document.querySelector(".intro"),
introDomPatch: (introDom) => introDom,
coverUrl: document.querySelector("#fengmian img")
?.src,
aList: document.querySelectorAll("#list > .book-chapter-list .cf li > a"),
sections: document.querySelectorAll("#list > .book-chapter-list > h3"),
getSName: (sElem) => sElem.innerText.trim(),
getContentFromUrl: async (chapterUrl, chapterName, charset) => {
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_1__/* .getHtmlDOM */ .wA)(chapterUrl, charset);
const script1 = Array.from(doc.querySelectorAll("script"))
.filter((s) => s.innerHTML.includes("chapterid="))?.[0]
?.innerHTML.split("\n")
.filter((line) => !(line.includes("cpstr=") ||
line.includes("get_content()") ||
line.includes("xid=")))
.join("\n");
const script2 = Array.from(doc.querySelectorAll("script"))
.filter((s) => s.innerHTML.includes("ssid"))?.[0]
?.innerHTML.split("\n")
.filter((line) => line.includes("var ssid") || line.includes("var hou"))
.join("\n");
const request = new Function(`${script2};${script1};
const xid=Math.floor(bookid/1000);
const url = \`${document.location.origin}/files/article/html\${ssid}/\${xid}/\${bookid}/\${chapterid}\${hou}\`;
return new Request(url, {
headers: {
accept: "text/plain, */*; q=0.01",
"x-requested-with": "XMLHttpRequest",
},
referrer: "${document.location.origin}",
method: "GET",
mode: "cors",
credentials: "include",
});`)();
const text = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_1__/* .getText */ .q4)(request, charset);
const cctxt = new Function(`${text};return cctxt;`)();
if (cctxt) {
const contentRaw = document.createElement("div");
contentRaw.innerHTML = cctxt;
return contentRaw;
}
else {
return null;
}
},
contentPatch: (content) => content,
overrideConstructor: (classThis) => {
const rawBookParse = classThis.bookParse;
classThis.bookParse = async () => {
const book = (await Reflect.apply(rawBookParse, classThis, []));
const chapters = book.chapters;
book.chapters = (0,_lib_rule__WEBPACK_IMPORTED_MODULE_2__/* .deDuplicate */ .hR)(chapters);
return book;
};
return classThis;
},
});
/***/ }),
/***/ "./src/rules/onePage/guidaye.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ guidaye: () => (/* binding */ guidaye)
/* harmony export */ });
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/rules/onePage/template.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_0__);
const guidaye = async () => {
const getAList = async () => {
const num = +document.querySelector("div.pager > span:nth-child(1)").innerText
.replace(/页次:.+\//g, "")
.trim();
const sid = document.querySelector("div#bookiddata").dataset.sid ||
"";
const api = "https://b.guidaye.com/e/extend/bookpage/pages.php?id=" + sid;
const htm = document.createElement("div");
_log__WEBPACK_IMPORTED_MODULE_0___default().info("[guidaye]" + "作品编号: " + sid + ", 列表页数: " + num);
for (let i = 0; i < num; i++) {
_log__WEBPACK_IMPORTED_MODULE_0___default().info("获取列表:" + i);
const resp = await fetch(api, {
method: "POST",
mode: "cors",
cache: "no-cache",
credentials: "same-origin",
headers: {
"Content-Type": "application/x-www-form-urlencoded; charset=UTF-8",
},
body: "pageNum=" + i,
});
if (!resp.ok) {
_log__WEBPACK_IMPORTED_MODULE_0___default().error("获取列表错误:" + resp.status);
}
const result = (await resp.json());
result.list.forEach((list) => {
const ul = document.createElement("a");
ul.href = list.pic;
ul.innerText = list.title;
htm.appendChild(ul);
return;
});
}
_log__WEBPACK_IMPORTED_MODULE_0___default().info("[guidaye]列表生成完毕");
return htm.querySelectorAll("a");
};
return (0,_template__WEBPACK_IMPORTED_MODULE_1__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector("div.book-describe > h1").innerText.trim(),
author: document.querySelector("div.book-describe > p").innerText
.trim()
.replace(/作者:|作品集/g, ""),
introDom: document.querySelector("div.describe-html"),
introDomPatch: (introDom) => introDom,
coverUrl: document.querySelector("div.book-img > img")
.src,
aList: await getAList(),
getContent: (doc) => doc.querySelector("div#nr1"),
contentPatch: (content) => {
return content;
},
});
};
/***/ }),
/***/ "./src/rules/onePage/hongxiuzhao.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
// EXPORTS
__webpack_require__.d(__webpack_exports__, {
hongxiuzhao: () => (/* binding */ hongxiuzhao)
});
// EXTERNAL MODULE: ./src/rules/onePage/template.ts
var template = __webpack_require__("./src/rules/onePage/template.ts");
// EXTERNAL MODULE: ./src/lib/dom.ts
var lib_dom = __webpack_require__("./src/lib/dom.ts");
;// ./src/rules/lib/hongxiuzhao.ts
const table = {
"\ue2a9": "\u5634",
"\ue2ba": "\u4e0b",
"\ue2bb": "\u5934",
"\ue2d1": "\u4f53",
"\ue321": "\u515a",
"\ue2a5": "\u5165",
"\ue2b4": "\u7c97",
"\ue2c4": "\u63a8",
"\ue316": "\u6237",
"\ue310": "\u9017",
"\ue2a1": "\u5598",
"\ue2a8": "\u8ff7",
"\ue2cd": "\u94bb",
"\ue307": "\u542e",
"\ue30c": "\u7684",
"\ue315": "\u8482",
"\ue298": "\u9053",
"\ue2ca": "\u5e72",
"\ue2ad": "\u803b",
"\ue2ef": "\u817f",
"\ue294": "\u786c",
"\ue2c9": "\u4e73",
"\ue2c5": "\u7cbe",
"\ue2fc": "\u7f69",
"\ue317": "\u80a5",
"\ue309": "\u8131",
"\ue2e4": "\u6f0f",
"\ue320": "\u5171",
"\ue2ae": "\u88f8",
"\ue2b7": "\u6d41",
"\ue2b1": "\u8179",
"\ue313": "\u80c0",
"\ue2b0": "\u81c0",
"\ue2e0": "\u8272",
"\ue2d0": "\u9a9a",
"\ue312": "\u6d1e",
"\ue2c7": "\u54ac",
"\ue2de": "\u6839",
"\ue304": "\u5c3b",
"\ue2a7": "\u7fd8",
"\ue2f0": "\u7231",
"\ue2db": "\u830e",
"\ue2ed": "\u6c9f",
"\ue2a2": "\u7ffb",
"\ue29a": "\u6345",
"\ue2e7": "\u5c3f",
"\ue2d3": "\u638f",
"\ue2b8": "\u6deb",
"\ue2ea": "\u60c5",
"\ue2ce": "\u6f6e",
"\ue2c1": "\u9634",
"\ue2b3": "\u8089",
"\ue2d8": "\u88e4",
"\ue2bc": "\u63d2",
"\ue290": "\u64cd",
"\ue29d": "\u634f",
"\ue322": "\u4e60",
"\ue29c": "\u8eab",
"\ue2d6": "\u53c9",
"\ue30b": "\u53e3",
"\ue2e5": "\u75d2",
"\ue30d": "\u889c",
"\ue2a3": "\u63e1",
"\ue2ff": "\u8f6f",
"\ue2f3": "\u6db2",
"\ue306": "\u4ea4",
"\ue2d9": "\u62d4",
"\ue2dc": "\u4e30",
"\ue301": "\u67d4",
"\ue311": "\u8170",
"\ue303": "\u5439",
"\ue305": "\u7206",
"\ue2ec": "\u8bf1",
"\ue2e2": "\u9f9f",
"\ue2c2": "\u811a",
"\ue2f1": "\u575a",
"\ue2bd": "\u8214",
"\ue2e6": "\u9876",
"\ue30f": "\u5987",
"\ue2b9": "\u5507",
"\ue2bf": "\u5c44",
"\ue2c6": "\u5a9a",
"\ue30a": "\u9732",
"\ue2f7": "\u7a74",
"\ue2ab": "\u6478",
"\ue2c3": "\u5c04",
"\ue30e": "\u547b",
"\ue2ee": "\u543b",
"\ue299": "\u6bdb",
"\ue2f4": "\u5973",
"\ue2fb": "\u64a9",
"\ue2cc": "\u6b32",
"\ue2dd": "\u542b",
"\ue2be": "\u6e29",
"\ue295": "\u5978",
"\ue308": "\u6c34",
"\ue2af": "\u5f04",
"\ue2b2": "\u9e21",
"\ue2da": "\u5149",
"\ue2f8": "\u767d",
"\ue314": "\u554a",
"\ue2e9": "\u52c3",
"\ue2c8": "\u8210",
"\ue291": "\u5ae9",
"\ue29e": "\u82de",
"\ue2b5": "\u80a4",
"\ue2c0": "\u7ea4",
"\ue2f6": "\u5c4c",
"\ue2f9": "\u8dc3",
"\ue2e1": "\u80f8",
"\ue2f5": "\u5c3c",
"\ue2eb": "\u808f",
"\ue2cb": "\u629a",
"\ue2df": "\u6d6a",
"\ue300": "\u871c",
"\ue2d4": "\u6ee1",
"\ue2aa": "\u6252",
"\ue302": "\u6413",
"\ue292": "\u62b1",
"\ue2e8": "\u8361",
"\ue29f": "\u80a1",
"\ue293": "\u63c9",
"\ue2cf": "\u505a",
"\ue29b": "\u50ac",
"\ue2fd": "\u88d9",
"\ue2b6": "\u633a",
"\ue297": "\u5904",
"\ue2fa": "\u5976",
"\ue323": "\u4ea7",
"\ue2e3": "\u836f",
"\ue2d7": "\u6027",
"\ue2a0": "\u63f4",
"\ue2d2": "\u623f",
"\ue2d5": "\u9633",
"\ue2fe": "\u6ed1",
"\ue296": "\u5438",
"\ue2ac": "\u67de",
};
;// ./src/rules/onePage/hongxiuzhao.ts
const hongxiuzhao = () => (0,template/* mkRuleClass */.N)({
bookUrl: document.location.href,
bookname: document
.querySelector(".m-bookdetail div.f-fl > h1")
?.innerText.trim() ?? "",
author: document
.querySelector(".author > a:nth-child(1)")
?.innerText.trim() ?? "",
introDom: document.querySelector(".summery") ?? undefined,
introDomPatch: (dom) => {
(0,lib_dom.rm)("strong", false, dom);
(0,lib_dom.rm)("em", false, dom);
return dom;
},
coverUrl: document.querySelector(".cover > img")?.src,
additionalMetadatePatch: (additionalMetadate) => {
additionalMetadate.tags = Array.from(document.querySelectorAll(".tags > a")).map((a) => a.innerText.trim());
return additionalMetadate;
},
aList: document.querySelectorAll(".m-chapters li > a"),
getContent: (doc) => doc.querySelector(".article-content"),
contentPatch: (content) => {
(0,lib_dom.rm)("mark", true, content);
(0,lib_dom.rm)("h1", true, content);
(0,lib_dom.rm)("ins", true, content);
(0,lib_dom.rm)("script", true, content);
(0,lib_dom.rm)("p[style]", true, content);
(0,lib_dom.rm)('a[href="https://hongxiuzh.com"]', true, content);
for (const k in table) {
content.innerHTML = content.innerHTML.replaceAll(k, table[k]);
}
return content;
},
});
/***/ }),
/***/ "./src/rules/onePage/original/akatsuki.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ akatsuki: () => (/* binding */ akatsuki)
/* harmony export */ });
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePage/template.ts");
const akatsuki = () => (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.origin + document.location.pathname,
bookname: document.querySelector("#LookNovel").innerText.trim(),
author: document.querySelector(".box.story > h3.font-bb:nth-last-of-type(1) > a").innerText.trim(),
introDom: document.querySelector(".box.story.body-normal > .body-normal > div"),
introDomPatch: (dom) => dom,
coverUrl: document.querySelector("div.font-bb > center > img")
?.src ?? null,
aList: document.querySelectorAll("table.list td > a"),
sections: document.querySelectorAll("table.list td[colspan] > b"),
getSName: (sElem) => sElem.innerText.trim(),
getContent: (doc) => {
doc.querySelectorAll("center > img").forEach((img) => {
const parent = img.parentElement;
parent?.replaceWith(img);
});
const contentRaw = document.createElement("div");
const nodes = Array.from(doc.querySelectorAll(".body-novel, .body-novel + hr"));
if (nodes.length > 1) {
const previous = nodes[0].previousElementSibling;
if (previous?.nodeName.toLowerCase() === "div") {
nodes.unshift(previous);
}
}
for (const node of nodes) {
if (node instanceof HTMLDivElement && node.className === "body-novel") {
contentRaw.appendChild((0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_1__/* .convertBr */ .U9)(node, true));
}
else {
contentRaw.appendChild(node);
}
}
return contentRaw;
},
contentPatch: (content) => content,
concurrencyLimit: 2,
language: "ja",
});
/***/ }),
/***/ "./src/rules/onePage/original/alphapolis.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ alphapolis: () => (/* binding */ alphapolis)
/* harmony export */ });
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePage/template.ts");
const alphapolis = () => (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector("h1.title").innerText.trim(),
author: document.querySelector("div.author > span:nth-child(1) > a:nth-child(1)").innerText.trim(),
introDom: document.querySelector(".abstract"),
introDomPatch: (dom) => dom,
coverUrl: document.querySelector("div.cover > a > img")
?.src ?? null,
additionalMetadatePatch: (additionalMetadate) => {
additionalMetadate.tags = Array.from(document.querySelectorAll(".content-tags > .tag > a")).map((a) => a.innerText.trim());
return additionalMetadate;
},
aList: document.querySelectorAll(".episodes > .episode > a"),
getAName: (aElem) => aElem.querySelector(".title")?.innerText.trim(),
sections: document.querySelectorAll(".episodes > h3"),
getSName: (sElem) => sElem.innerText.trim(),
getContent: (doc) => doc.querySelector("#novelBody"),
contentPatch: (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__/* .insertBrBeforeText */ .Md)(content);
return content;
},
language: "ja",
});
/***/ }),
/***/ "./src/rules/onePage/original/esjzone.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ esjzone: () => (/* binding */ esjzone)
/* harmony export */ });
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePage/template.ts");
const esjzone = () => (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector(".book-detail h2").innerText.trim(),
author: Array.from(document.querySelectorAll('ul.book-detail li')).find(li => li.textContent && li.textContent.includes('作者:'))?.querySelector('a')?.innerText.trim() || "Unknown Author",
introDom: document.querySelector(".description"),
introDomPatch: (dom) => dom,
additionalMetadatePatch: (additionalMetadate) => {
additionalMetadate.tags = Array.from(document.querySelectorAll('section.widget-tags.m-t-20 a.tag')).map((a) => a.innerText);
return additionalMetadate;
},
coverUrl: document.querySelector("div.product-gallery")?.querySelector("img")?.getAttribute("src") ?? null,
aList: document.querySelectorAll('#chapterList a'),
getAName: (aElem) => aElem?.innerText.trim(),
getContent: (dom) => dom.querySelector('.forum-content'),
contentPatch: (dom) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)('h3', true, dom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)('footer', true, dom);
return dom;
},
language: "zh",
needLogin: true,
});
/***/ }),
/***/ "./src/rules/onePage/original/houhuayuan.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ houhuayuan: () => (/* binding */ houhuayuan)
/* harmony export */ });
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePage/template.ts");
const houhuayuan = () => {
const seriesbox = document.querySelector(".seriesbox");
let bookUrl;
let bookname;
let author = document.querySelector("h3.author")?.innerText
.replace(/♥|作者: /g, "")
.trim();
if (author === "") {
author = "佚名";
}
const aList = [];
if (seriesbox) {
const lis = seriesbox.querySelectorAll("ul.serieslist-ul > li");
for (const li of Array.from(lis)) {
if (li.className === "serieslist-li") {
const a = li.querySelector("a");
if (a) {
aList.push(a);
}
}
else if (li.className === "serieslist-li-current") {
const a = document.createElement("a");
a.innerText = document.querySelector(".entry-title").innerText.trim();
a.href = document.location.href;
aList.push(a);
}
}
const aFirst = aList[0];
bookname = aFirst.innerText
.replace(/第.+章$|\s序$/, "")
.trim();
bookUrl = aFirst.href;
}
else {
bookUrl = document.location.href;
bookname = document.querySelector(".entry-title").innerText.trim();
const a = document.createElement("a");
a.innerText = bookname;
a.href = bookUrl;
aList.push(a);
}
return (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl,
bookname,
author,
aList,
getContentFromUrl: async (chapterUrl, chapterName, charset) => {
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_1__/* .getHtmlDOM */ .wA)(chapterUrl, charset);
const pageLinks = doc.querySelectorAll(".page-links > a.post-page-numbers");
if (pageLinks) {
const content = document.createElement("div");
const _content0 = doc.querySelector("header + div.entry-content");
if (_content0) {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__/* .childNodesCopy */ .Fv)(_content0, content);
}
const pageUrls = Array.from(pageLinks).map((a) => a.href);
for (const url of pageUrls) {
const docc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_1__/* .getHtmlDOM */ .wA)(url, charset);
const _content1 = docc.querySelector("header + div.entry-content");
if (_content1) {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__/* .childNodesCopy */ .Fv)(_content1, content);
}
}
return content;
}
else {
return doc.querySelector("header + div.entry-content");
}
},
contentPatch: (dom) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__.rm)('div[id^="stage-"]', true, dom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__.rm)('div[id^="zhaoz-"]', true, dom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__.rm)("div.seriesbox", true, dom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__.rm)("fieldset", true, dom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__.rm)("div.wpulike", true, dom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__.rm)(".simplefavorite-button", true, dom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__.rm)(".page-links", true, dom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__/* .rm2 */ .Sf)([" – 蔷薇后花园", " – 黑沼泽俱乐部"], dom);
Array.from(dom.querySelectorAll("img")).forEach((img) => (img.src = img.getAttribute("data-src") ?? ""));
return dom;
},
nsfw: true,
});
};
/***/ }),
/***/ "./src/rules/onePage/original/kakuyomu.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ kakuyomu: () => (/* binding */ kakuyomu)
/* harmony export */ });
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePage/template.ts");
function clickButtonFromSpan(spanElements, targetText) {
spanElements.forEach(span => {
if (span.textContent?.includes(targetText)) {
const describedById = span.id;
if (describedById) {
const button = document.querySelector(`button[aria-describedby="${describedById}"]`);
button?.click();
}
}
});
}
function clickButtonFromDiv(divElements, targetText) {
divElements.forEach(div => {
if (div.textContent?.includes(targetText)) {
let parent = div;
while (parent && parent.nodeName !== 'BUTTON') {
parent = parent.parentElement;
}
parent?.click();
}
});
}
function clickButtonWithSVGAndH3(buttons) {
buttons.forEach(button => {
const svg = button.querySelector('svg[class^="Icons_icon"]');
const h3 = button.querySelector('h3');
if (svg && h3) {
const hasFlipClass = Array.from(svg.classList).some(className => className.startsWith('Icons_flip'));
if (!hasFlipClass) {
button.click();
}
}
});
}
const spanElements = document.querySelectorAll('span');
const divElements = document.querySelectorAll('div');
const buttons = document.querySelectorAll('button[class^="Button_button"]');
clickButtonFromSpan(spanElements, "…続きを読む");
clickButtonFromDiv(divElements, "つづきを表示");
clickButtonWithSVGAndH3(buttons);
const kakuyomu = () => (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector("h1").innerText.trim(),
author: document.querySelector("div[class*=partialGiftWidgetActivityName] > a").innerText.trim(),
introDom: document.querySelector("div[class*=CollapseTextWithKakuyomuLinks]"),
introDomPatch: (dom) => dom,
coverUrl: null,
additionalMetadatePatch: (additionalMetadate) => {
additionalMetadate.tags = Array.from(document.querySelectorAll("#workMeta-tags > li > a")).map((a) => a.innerText);
return additionalMetadate;
},
aList: document.querySelectorAll("a[class*=WorkTocSection_link]"),
getAName: (aElem) => aElem.querySelector('div[class*="Typography"]').innerText.trim(),
sections: document.querySelectorAll("h3"),
getSName: (dom) => dom.innerText.trim(),
getContent: (dom) => dom.querySelector(".widget-episodeBody"),
contentPatch: (dom) => dom,
language: "ja",
});
/***/ }),
/***/ "./src/rules/onePage/original/masiro.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ masiro: () => (/* binding */ masiro)
/* harmony export */ });
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePage/template.ts");
const masiro = () => (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector(".novel-title").innerText.trim(),
author: document.querySelector(".author > a").innerText.trim(),
introDom: document.querySelector(".brief"),
introDomPatch: (dom) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__/* .rms */ .j3)(["简介:"], dom);
return dom;
},
coverUrl: document.querySelector("div.mailbox-attachment-icon > a > img.img").src,
additionalMetadatePatch: (additionalMetadate) => {
additionalMetadate.tags = Array.from(document.querySelectorAll("div.n-detail > div.tags a")).map((a) => a.innerText);
return additionalMetadate;
},
aList: document.querySelectorAll(".chapter-ul ul.episode-ul > a"),
getAName: (aElem) => aElem.querySelector('span[style^="overflow: hidden;"]').innerText.trim(),
getIsVIP: (aElem) => {
let isVIP = false;
let isPaid = false;
const small = aElem.querySelector("small");
if (small) {
const text = small.innerText.trim();
if (text !== "") {
isVIP = true;
if (text === "已购") {
isPaid = true;
}
}
}
return { isVIP, isPaid };
},
sections: document.querySelectorAll("li.chapter-box > span + b"),
getSName: (dom) => dom.innerText.trim(),
getContent: (dom) => dom.querySelector("div.box-body.nvl-content"),
contentPatch: (dom) => dom,
concurrencyLimit: 1,
sleepTime: 100,
maxSleepTime: 3000,
needLogin: true,
});
/***/ }),
/***/ "./src/rules/onePage/original/ptwxz.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ ptwxz: () => (/* binding */ ptwxz)
/* harmony export */ });
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePage/template.ts");
const ptwxz = () => (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector("h1")?.innerText.trim().replace('最新章节', '') ?? "",
author: document.querySelector('.list')?.textContent?.split(' \u00A0')[0]?.replace('作者:', '')?.trim() ?? "",
introDom: document.querySelector("#intro") ?? undefined,
introDomPatch: (dom) => dom,
coverUrl: document.location.href.replace(/(https:\/\/www\.piaotia\.com)\/html\/(\d+)\/(\d+)(\/index.html)?\/?$/, '$1/files/article/image/$2/$3/$3s.jpg'),
getAName: (aElem) => aElem.innerText.trim(),
aList: document.querySelectorAll('ul > li > a'),
getContent: (dom) => {
const delay = (ms) => new Promise(resolve => setTimeout(resolve, ms));
delay(1000);
return dom.body;
},
concurrencyLimit: 1,
sleepTime: 400,
maxSleepTime: 400,
contentPatch: (dom) => {
const title = dom.querySelector('h1')?.textContent?.trim() ?? '';
const table = dom.querySelector('table');
const bottomLink = dom.querySelector("div.bottomlink");
if (!table || !bottomLink) {
throw new Error('The required elements are not found in the DOM.');
}
let content = '';
let currentNode = table.nextSibling;
while (currentNode && currentNode !== bottomLink) {
if (currentNode.nodeType === Node.TEXT_NODE || (currentNode.nodeType === Node.ELEMENT_NODE && currentNode.nodeName.toLowerCase() !== 'table' && currentNode.nodeName.toLowerCase() !== 'div')) {
let textContent = currentNode.textContent || '';
if (currentNode.nodeType === Node.ELEMENT_NODE && currentNode.nodeName.toLowerCase() === 'br') {
textContent = '\n';
}
textContent.split('\n').forEach((line) => {
const trimmedLine = line.trim();
if (trimmedLine && title !== trimmedLine) {
content += `<p>${trimmedLine}</p>`;
}
});
}
currentNode = currentNode.nextSibling;
}
const divElement = document.createElement('div');
divElement.innerHTML = content;
return divElement;
}
});
/***/ }),
/***/ "./src/rules/onePage/original/syosetu.ts":
/***/ ((module, __webpack_exports__, __webpack_require__) => {
"use strict";
__webpack_require__.a(module, async (__webpack_handle_async_dependencies__, __webpack_async_result__) => { try {
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ syosetu: () => (/* binding */ syosetu),
/* harmony export */ syosetuOrg: () => (/* binding */ syosetuOrg)
/* harmony export */ });
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePage/template.ts");
const currentPageIndexBox = document.querySelector('.p-eplist');
const firstPageAnchor = document.querySelector('.c-pager__item--first');
const lastPageAnchor = document.querySelector('.c-pager__item--last');
if (firstPageAnchor && lastPageAnchor) {
const currentURL = window.location.pathname + window.location.search;
const lastPageHref = lastPageAnchor.getAttribute('href') ? lastPageAnchor.getAttribute('href') : currentURL;
const firstPageHref = firstPageAnchor.getAttribute('href') ? firstPageAnchor.getAttribute('href') : currentURL;
const hrefLastPageMatch = lastPageHref ? lastPageHref.match(/(.*\/\?p=)(\d+)/) : null;
const hrefFirstPageMatch = firstPageHref ? firstPageHref.match(/(.*\/\?p=)(\d+)/) : null;
const baseUrl = hrefLastPageMatch ? hrefLastPageMatch[1] : hrefFirstPageMatch ? hrefFirstPageMatch[1] : '';
const lastPageNumber = hrefLastPageMatch ? parseInt(hrefLastPageMatch[2], 10) : 1;
const currentPageNumberMatch = currentURL.match(/(.*\/\?p=)(\d+)/);
const currentPageNumber = currentPageNumberMatch ? parseInt(currentPageNumberMatch[2], 10) : 1;
const fetchAndAppendContent = async (pageNumber, insertAfterCurrentBox) => {
try {
const response = await fetch(`${baseUrl}${pageNumber}`);
const html = await response.text();
const parser = new DOMParser();
const doc = parser.parseFromString(html, 'text/html');
const pageIndexBox = doc.querySelector('.p-eplist');
if (pageIndexBox && currentPageIndexBox) {
const childrenArray = Array.from(pageIndexBox.children);
if (insertAfterCurrentBox) {
childrenArray.forEach(child => {
currentPageIndexBox.appendChild(child.cloneNode(true));
});
}
else {
childrenArray.reverse().forEach(child => {
currentPageIndexBox.insertBefore(child.cloneNode(true), currentPageIndexBox.firstChild);
});
}
}
}
catch (error) {
console.error('Error fetching page:', error);
}
};
for (let i = currentPageNumber - 1; i > 0; i--) {
await fetchAndAppendContent(i, false);
}
const endPageNumber = lastPageNumber === -1 ? currentPageNumber : lastPageNumber;
for (let i = currentPageNumber + 1; i <= endPageNumber; i++) {
await fetchAndAppendContent(i, true);
}
}
const syosetu = () => {
const getIntroDom = () => {
const a = document.querySelector("#novel_ex > .more");
if (a) {
a.click();
}
return document.querySelector("#novel_ex");
};
const getAList = () => {
const _aList = document.querySelectorAll("body > div.l-container > main > article > div.p-eplist > div > a");
if (_aList.length !== 0) {
return _aList;
}
else {
const a = document.createElement("a");
a.href = document.location.href;
a.innerText = document.querySelector(".p-novel__title")?.innerText;
return [a];
}
};
const getNsfw = () => {
const host = document.location.host;
return host === "novel18.syosetu.com";
};
return (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector(".p-novel__title").innerText.trim(),
author: document.querySelector("div.p-novel__author").innerText,
introDom: getIntroDom(),
introDomPatch: (dom) => dom,
coverUrl: null,
aList: getAList(),
sections: document.querySelectorAll(".p-eplist__chapter-title"),
getSName: (dom) => dom.innerText.trim(),
getContent: (dom) => {
const content = document.createElement("div");
const novelP = dom.querySelector(".p-novel__text--preface");
const novelHonbun = dom.querySelector(".p-novel__text:not(.p-novel__text--preface):not(.p-novel__text--afterword)");
const novelA = dom.querySelector(".p-novel__text--afterword");
if (novelP) {
content.appendChild(novelP);
const hr = dom.createElement("hr");
content.appendChild(hr);
}
if (novelHonbun) {
content.appendChild(novelHonbun);
}
if (novelA) {
const hr = dom.createElement("hr");
content.appendChild(hr);
content.appendChild(novelA);
}
return content;
},
contentPatch: (dom) => dom,
nsfw: getNsfw(),
needLogin: getNsfw(),
language: "ja",
});
};
const syosetuOrg = () => {
const getAList = () => {
const _aList = document.querySelectorAll('tr[class^="bgcolor"] > td > a');
if (_aList.length !== 0) {
return _aList;
}
else {
const a = document.createElement("a");
a.href = document.location.href;
a.innerText = document.querySelector("div.ss:nth-child(1) > p:nth-child(1) > span:nth-child(1) > a:nth-child(1)")?.innerText;
return [a];
}
};
const aList = getAList();
const getIntroDom = () => {
if (aList.length === 1 &&
aList[0].href === document.location.href) {
return undefined;
}
return document.querySelector("div.ss:nth-child(2)");
};
return (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector('div.ss > span[itemprop="name"], div.ss:nth-child(1) > p:nth-child(1) > span:nth-child(1) > a:nth-child(1)').innerText.trim(),
author: document.querySelector('div.ss span[itemprop="author"] > a, div.ss:nth-child(1) > p:nth-child(1) > a:nth-child(2)')?.innerText.trim(),
introDom: getIntroDom(),
introDomPatch: (dom) => dom,
coverUrl: null,
additionalMetadatePatch: (additionalMetadate) => {
additionalMetadate.tags = Array.from(document.querySelectorAll('span[itemprop="keywords"] > a, a.alert_color')).map((a) => a.innerText);
return additionalMetadate;
},
aList,
sections: document.querySelectorAll('div.ss > table > tbody > tr > td[colspan="2"] > strong'),
getSName: (dom) => dom.innerText.trim(),
getContent: (doc) => {
if (aList.length === 1 &&
aList[0].href === document.location.href) {
return doc.querySelector("div#maind > div.ss:nth-child(2)");
}
return doc.querySelector("div#maind > div.ss:nth-child(1)");
},
contentPatch: (dom) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)("p:nth-child(1)", false, dom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)("div.novelnavi", true, dom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)('div[style*="text-align:right;"]', true, dom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)("div#maegaki_open", true, dom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)("div#atogaki_open", true, dom);
dom.querySelectorAll('a[name="img"]').forEach((a) => {
const img = document.createElement("img");
img.src = a.href;
img.alt = a.innerText;
a.replaceWith(img);
});
return dom;
},
language: "ja",
});
};
__webpack_async_result__();
} catch(e) { __webpack_async_result__(e); } }, 1);
/***/ }),
/***/ "./src/rules/onePage/qbtrcc.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ qbtrcc: () => (/* binding */ qbtrcc)
/* harmony export */ });
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePage/template.ts");
const qbtrcc = () => (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector("div.infos > h1").innerText.trim(),
author: document.querySelector("div.infos > div.date > span").innerText.replace("作者:", "").trim(),
introDom: document.querySelector("div.infos > p"),
introDomPatch: (introDom) => introDom,
coverUrl: "https://www.qbtr.cc/skin/default/images/bbb2.png",
aList: document.querySelectorAll("ul.clearfix > li > a"),
getContent: (doc) => doc.querySelector("div.read_chapterDetail"),
contentPatch: (content) => content,
});
/***/ }),
/***/ "./src/rules/onePage/qzxsw.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ qzxsw: () => (/* binding */ qzxsw)
/* harmony export */ });
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePage/template.ts");
const qzxsw = () => (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector("div.introduce > h1").innerText.trim(),
author: document.querySelector("div.introduce > p.bq > span:nth-child(2) > a").innerText.trim(),
introDom: document.querySelector("div.introduce > p.jj"),
introDomPatch: (introDom) => introDom,
coverUrl: document.querySelector("div.pic > img").src,
aList: document.querySelectorAll("div.ml_list > ul > li > a"),
getContent: (doc) => doc.querySelector(".articlecontent"),
contentPatch: (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__/* .rms */ .j3)([
"一秒记住m.quanzhifashi。com",
"m.quanzhifashi.com",
"http://m.quanzhifashi.com首发"
], content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)("br", true, content);
return content;
},
});
/***/ }),
/***/ "./src/rules/onePage/soxscc.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ soxscc: () => (/* binding */ soxscc)
/* harmony export */ });
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePage/template.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/dom.ts");
const soxscc = () => (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector(".xiaoshuo > h1").innerText.trim(),
author: document.querySelector(".xiaoshuo > h6:nth-child(3) > a").innerText.trim(),
introDom: document.querySelector("#intro"),
introDomPatch: (dom) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)("span.tags", false, dom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)("q", true, dom);
return dom;
},
coverUrl: document.querySelector(".book_cover > img")
.src,
aList: document.querySelectorAll("div.novel_list[id] dd > a"),
sections: document.querySelectorAll("div.novel_list[id] dl > dt:nth-child(1) > b:nth-child(1)"),
getSName: (sElem) => sElem.innerText.trim(),
getContent: (doc) => doc.querySelector("div.content[id]"),
contentPatch: (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__/* .rm2 */ .Sf)([
"最新章节地址:",
"全文阅读地址:",
"txt下载地址:",
"手机阅读:",
'为了方便下次阅读,你可以点击下方的"收藏"记录本次',
"请向你的朋友(QQ、博客、微信等方式)推荐本书",
"您可以在百度里搜索",
], content);
return content;
},
});
/***/ }),
/***/ "./src/rules/onePage/template.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ N: () => (/* binding */ mkRuleClass)
/* harmony export */ });
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules.ts");
/* harmony import */ var _main_main__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/main/main.ts");
function mkRuleClass({ bookUrl, bookname, author, introDom, introDomPatch, coverUrl, additionalMetadatePatch, aList, getAName, getIsVIP, sections, getSName, postHook, getContentFromUrl, getContent, contentPatch, concurrencyLimit, sleepTime, maxSleepTime, needLogin, nsfw, cleanDomOptions, overrideConstructor, language, }) {
return class extends _rules__WEBPACK_IMPORTED_MODULE_0__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
if (concurrencyLimit) {
this.concurrencyLimit = concurrencyLimit;
}
if (sleepTime) {
this.sleepTime = sleepTime;
}
if (maxSleepTime) {
this.maxSleepTime = maxSleepTime;
}
if (needLogin) {
this.needLogin = needLogin;
}
if (nsfw) {
this.nsfw = nsfw;
}
if (overrideConstructor) {
overrideConstructor(this);
}
}
async bookParse() {
let introduction = null;
let introductionHTML = null;
if (introDom && introDomPatch) {
[introduction, introductionHTML] = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_1__/* .introDomHandle */ .HV)(introDom, introDomPatch);
}
const additionalMetadate = {
language: language ?? "zh",
};
if (coverUrl) {
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_2__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_3___default().error(error));
}
if (additionalMetadatePatch) {
Object.assign(additionalMetadate, additionalMetadatePatch(additionalMetadate));
}
const chapters = [];
let chapterNumber = 0;
let sectionNumber = 0;
let sectionChapterNumber = 0;
let sectionName = null;
let hasSection = false;
if (sections &&
sections instanceof NodeList &&
typeof getSName === "function") {
hasSection = true;
}
for (const aElem of Array.from(aList)) {
let chapterName;
if (getAName) {
chapterName = getAName(aElem);
}
else {
chapterName = aElem.innerText.trim();
}
const chapterUrl = aElem.href;
if (hasSection && sections && getSName) {
const _sectionName = (0,_lib_rule__WEBPACK_IMPORTED_MODULE_1__/* .getSectionName */ .lq)(aElem, sections, getSName);
if (_sectionName !== sectionName) {
sectionName = _sectionName;
sectionNumber++;
sectionChapterNumber = 0;
}
}
chapterNumber++;
sectionChapterNumber++;
let isVIP = false;
let isPaid = false;
if (getIsVIP) {
({ isVIP, isPaid } = getIsVIP(aElem));
}
let chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_4__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP,
isPaid,
sectionName,
sectionNumber: hasSection ? sectionNumber : null,
sectionChapterNumber: hasSection ? sectionChapterNumber : null,
chapterParse: this.chapterParse,
charset: this.charset,
options: { bookname },
});
if (isVIP && !isPaid) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_5__/* .Status */ .nW.aborted;
}
if (typeof postHook === "function") {
chapter = postHook(chapter);
}
if (chapter) {
chapters.push(chapter);
}
}
return new _main_Book__WEBPACK_IMPORTED_MODULE_6__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
let content;
if (typeof getContentFromUrl === "function") {
content = await getContentFromUrl(chapterUrl, chapterName, charset);
}
else if (typeof getContent === "function") {
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_7__/* .getHtmlDOM */ .wA)(chapterUrl, charset);
content = getContent(doc);
}
else {
throw Error("未发现 getContentFromUrl 或 getContent");
}
if (content) {
content = contentPatch(content);
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_8__/* .cleanDOM */ .an)(content, "TM", cleanDomOptions);
return {
chapterName,
contentRaw: content,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: null,
};
}
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
};
}
/***/ }),
/***/ "./src/rules/onePage/tianyabooks.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ tianyabooks: () => (/* binding */ tianyabooks)
/* harmony export */ });
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePage/template.ts");
const tianyabooks = () => (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector(".book > h1")?.innerText
.replace(/[《》]/g, "")
.trim(),
author: document.querySelector(".book > h2 > a").innerText.trim(),
introDom: document.querySelector(".description"),
introDomPatch: (dom) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)("h3", false, dom);
return dom;
},
coverUrl: null,
aList: document.querySelectorAll(".book > dl > dd > a"),
sections: document.querySelectorAll(".book > dl > dt"),
getSName: (dom) => dom.innerText.trim(),
getContent: (doc) => doc.querySelector("#main"),
contentPatch: (dom) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)("div.crumb", false, dom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)("h1", false, dom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)('p[align="center"]', false, dom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)("table", true, dom);
return dom;
},
});
/***/ }),
/***/ "./src/rules/onePage/trxs.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ trxs: () => (/* binding */ trxs)
/* harmony export */ });
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePage/template.ts");
const trxs = () => (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector(".infos > h1").innerText
.split("(")[0]
.trim(),
author: document.querySelector(".date > span > a, .date > span").innerText
.replace("作者:", "")
.trim(),
introDom: document.querySelector(".infos > p"),
introDomPatch: (introDom) => introDom,
coverUrl: document.querySelector(".pic > img").src,
aList: document.querySelectorAll("div.book_list > ul.clearfix > li > a"),
getContent: (doc) => doc.querySelector(".read_chapterDetail"),
contentPatch: (content) => content,
});
/***/ }),
/***/ "./src/rules/onePage/uukanshu.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ uukanshu: () => (/* binding */ uukanshu)
/* harmony export */ });
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePage/template.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/dom.ts");
const uukanshu = () => {
const button = document.querySelector('span[onclick="javascript:reverse(this);"]');
const reverse = unsafeWindow.reverse;
if (button.innerText === "顺序排列") {
reverse(button);
}
return (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector("dd.jieshao_content > h1 > a").innerText
.replace("最新章节", "")
.trim(),
author: document.querySelector("dd.jieshao_content > h2 > a").innerText.trim(),
introDom: document.querySelector("dd.jieshao_content > h3"),
introDomPatch: (dom) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__/* .rms */ .j3)([
/^.+简介:\s+www\.uukanshu\.com\s+/,
/\s+https:\/\/www\.uukanshu\.com/,
/-+/,
], dom);
return dom;
},
coverUrl: document.querySelector("a.bookImg > img")
.src,
aList: document.querySelectorAll("#chapterList > li > a"),
sections: document.querySelectorAll("#chapterList > li.volume"),
getSName: (sElem) => sElem.innerText.trim(),
getContent: (doc) => doc.querySelector("#contentbox"),
contentPatch: (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)(".ad_content", true, content);
const adReplace = [
/[UuUu]+看书\s*[ww]+.[UuUu]+[kk][aa][nn][ss][hh][UuUu].[nn][ee][tt]/g,
/[UuUu]+看书\s*[ww]+.[UuUu]+[kk][aa][nn][ss][hh][UuUu].[cCc][oOo][mMm]/g,
/[UU]*看书[(\\(].*?[)\\)]文字首发。/,
/请记住本书首发域名:。?/g,
/笔趣阁手机版阅读网址:/g,
/小说网手机版阅读网址:/g,
/https:\/\//g,
/http:\/\//g,
/UU看书\s+欢迎广大书友光临阅读,最新、最快、最火的连载作品尽在UU看书!UU看书。;?/g,
];
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__/* .rms */ .j3)(adReplace, content);
return content;
},
});
};
/***/ }),
/***/ "./src/rules/onePage/wanben.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ wanben: () => (/* binding */ wanben)
/* harmony export */ });
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePage/template.ts");
const wanben = () => (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector(".detailTitle > h1").innerText.trim(),
author: document.querySelector(".writer > a").innerText.trim(),
introDom: document.querySelector(".detailTopMid > table:nth-child(3) > tbody:nth-child(1) > tr:nth-child(3) > td:nth-child(2)"),
introDomPatch: (introDom) => introDom,
coverUrl: document.querySelector(".detailTopLeft > img")?.src,
aList: document.querySelectorAll(".chapter li > a"),
getContentFromUrl: async (chapterUrl, chapterName, charset) => {
const { contentRaw } = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_1__/* .nextPageParse */ .u1)({
chapterName,
chapterUrl,
charset,
selector: "div.readerCon",
contentPatch: (content, doc) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__.rm)("script", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__.rm)("div[style]", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__.rm)("a", true, content);
const ads = [
"【提示】:如果觉得此文不错,请推荐给更多小伙伴吧!分享也是一种享受。",
"【看书助手】",
"百万热门书籍终身无广告免费阅读",
"【完本神站】",
"一秒记住、永不丢失!"
];
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__/* .rm2 */ .Sf)(ads, content);
(0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_3__/* .htmlTrim */ .is)(content);
return content;
},
getNextPage: (doc) => doc.querySelector(".readPage > a:nth-child(3)")
.href,
continueCondition: (_content, nextLink) => {
const pathname = nextLink.split("/").slice(-1)[0];
return pathname.includes("_");
},
enableCleanDOM: false,
});
return contentRaw;
},
contentPatch: (content) => content,
});
/***/ }),
/***/ "./src/rules/onePage/westnovel.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ westnovel: () => (/* binding */ westnovel)
/* harmony export */ });
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePage/template.ts");
const westnovel = () => (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector(".btitle > h1 > a").innerText.trim(),
author: document.querySelector(".btitle > em:nth-child(2)").innerText
.replace("作者:", "")
.trim(),
introDom: document.querySelector(".intro-p > p:nth-child(1)"),
introDomPatch: (introDom) => introDom,
coverUrl: document.querySelector(".img-img")?.src,
aList: document.querySelectorAll(".chapterlist > dd > a"),
getContent: (doc) => doc.querySelector("#BookText"),
contentPatch: (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)("div.ads", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)("div.link", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)("h4", true, content);
return content;
},
});
/***/ }),
/***/ "./src/rules/onePage/xbyuan.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ xbyuan: () => (/* binding */ xbyuan)
/* harmony export */ });
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePage/template.ts");
const $ = (selector) => document.querySelector(selector);
const $$ = (selector) => document.querySelectorAll(selector);
const xbyuan = () => (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: location.href,
bookname: $("#info h1").innerText.trim(),
author: $("#info .small > span").innerText.trim(),
introDom: $("#intro > p"),
introDomPatch: (_) => _,
coverUrl: $("#fmimg img").src,
aList: $$("#list dl")[1].querySelectorAll("a"),
async getContentFromUrl(chapterUrl, chapterName, charset) {
const { contentRaw } = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_1__/* .nextPageParse */ .u1)({
chapterName,
chapterUrl,
charset,
selector: "#nr_content > p",
contentPatch(content, doc) {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__.rm)("a", true, content);
const ads = [
"精华书阁",
"最新章节!",
"最快更新,为了您下次还能查看到本书的最快更新,请务必保存好书签!",
"https://www.xbyuan.com",
];
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__/* .rm2 */ .Sf)(ads, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__/* .rms */ .j3)(["(本章未完,请点击下一页继续阅读)"], content);
(0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_3__/* .htmlTrim */ .is)(content);
return content;
},
getNextPage(doc) {
return doc.querySelector("#nexturl").href;
},
continueCondition(content, nextLink) {
const pathname = nextLink.split("/").slice(-1)[0];
return pathname.includes("_");
},
});
return contentRaw;
},
contentPatch: (content) => {
content.innerHTML = content.innerHTML
.replaceAll("「", "“")
.replaceAll("」", "”");
return content;
},
});
/***/ }),
/***/ "./src/rules/onePageWithMultiIndexPage/69shu.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ c69shu: () => (/* binding */ c69shu)
/* harmony export */ });
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePageWithMultiIndexPage/template.ts");
const c69shu = () => (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector("h1")?.innerText ?? "",
author: document.querySelector(".booknav2 > p:nth-child(3) > a")?.innerText ?? "",
introDom: document.querySelector(".lastcontent"),
introDomPatch: (content) => content,
coverUrl: document.querySelector(".bookimg2 > img")?.src ?? null,
getIndexPages: async () => {
const indexPages = [];
const menuUrl = document.querySelector('a.btn.more-btn[href^="https://69shuba.cx/book/"]').href;
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_1__/* .getHtmlDOM */ .wA)(menuUrl, "GBK");
indexPages.push(doc);
return indexPages;
},
getAList: (doc) => Array.from(doc.querySelectorAll("#catalog ul a")).reverse(),
getAName: (aElem) => aElem.innerText.trim(),
getContent: (doc) => doc.querySelector(".txtnav"),
contentPatch: (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__.rm)(".hide720, .txtright, .bottom-ad", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__/* .rm2 */ .Sf)([/^谷[\u4e00-\u9fa5]{0,1}$/gm], content);
const walker = document.createTreeWalker(content, NodeFilter.SHOW_TEXT, null);
const nodesToReplace = [];
while (walker.nextNode()) {
const node = walker.currentNode;
if (node.parentNode &&
node.parentNode.nodeName !== 'P' &&
node.textContent &&
node.textContent.trim() !== '') {
nodesToReplace.push(node);
}
}
nodesToReplace.forEach((node) => {
const p = document.createElement('p');
p.textContent = node.textContent;
if (node.parentNode) {
node.parentNode.replaceChild(p, node);
}
});
const paragraphs = content.querySelectorAll('p');
const brRegex = /<br\s*\/?>/i;
paragraphs.forEach((p) => {
if (brRegex.test(p.innerHTML)) {
const parts = p.innerHTML.split(brRegex);
const fragment = document.createDocumentFragment();
parts.forEach((part) => {
const newP = document.createElement('p');
newP.innerHTML = part.trim();
if (newP.innerHTML !== '') {
fragment.appendChild(newP);
}
});
if (p.parentNode) {
p.parentNode.replaceChild(fragment, p);
}
}
});
return content;
},
language: "zh"
});
/***/ }),
/***/ "./src/rules/onePageWithMultiIndexPage/baihexs.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ baihexs: () => (/* binding */ baihexs)
/* harmony export */ });
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePageWithMultiIndexPage/template.ts");
const baihexs = () => {
const bookUrl = document.location.href;
const bookId = /(\d+)\/?$/.exec(document.location.href)?.[1];
if (!bookId) {
throw Error("获取书籍信息出错!");
}
return (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl,
bookname: document.querySelector(".block_txt2 > h2 > a").innerText.trim(),
author: document.querySelector(".block_txt2 > p:nth-child(4)").innerText
.replace("作者:", "")
.trim(),
introDom: document.querySelector(".intro_info"),
introDomPatch: (dom) => dom,
coverUrl: document.querySelector(".block_img2 > img")
?.src,
getIndexUrls: async () => {
const contentPageUrl = `${document.location.origin}/wapbook-${bookId}`;
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_1__/* .getHtmlDOM */ .wA)(contentPageUrl + "/", document.characterSet);
const a = doc.querySelector("div.page > a:nth-last-child(1)");
const maxNumber = /(\d+)\/?$/.exec(a.href)?.[1];
if (!maxNumber) {
throw Error("获取章节列表时出错!");
}
const indexUrls = [];
for (let i = 1; i <= parseInt(maxNumber, 10); i++) {
const url = contentPageUrl + `_${i}/`;
indexUrls.push(url);
}
return indexUrls;
},
getAList: (doc) => doc.querySelectorAll(".chapter > li > a"),
getContent: (doc) => doc.querySelector("#nr1"),
contentPatch: (dom) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__/* .rm2 */ .Sf)(["请您牢记:百合小说网"], dom);
return dom;
},
concurrencyLimit: 3,
});
};
/***/ }),
/***/ "./src/rules/onePageWithMultiIndexPage/original/novelup.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ novelup: () => (/* binding */ novelup)
/* harmony export */ });
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePageWithMultiIndexPage/template.ts");
const novelup = () => {
const bookUrl = document.location.origin + document.location.pathname;
return (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl,
bookname: document.querySelector("#section_episode_info_table > div:nth-child(2) > table:nth-child(1) > tbody:nth-child(1) > tr:nth-child(1) > td:nth-child(2)").innerText.trim(),
author: document.querySelector("#section_episode_info_table > div:nth-child(2) > table:nth-child(1) > tbody:nth-child(1) > tr:nth-child(2) > td:nth-child(2) > a:nth-child(1)").innerText.trim(),
introDom: document.querySelector(".novel_synopsis"),
introDomPatch: (dom) => {
Array.from(dom.querySelectorAll("p")).forEach((p) => {
const div = document.createElement("div");
div.innerHTML = p.innerHTML.split("\n").join("<br>");
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__/* .insertBrBeforeText */ .Md)(div);
p.replaceWith(div);
});
return dom;
},
coverUrl: document.querySelector(".novel_cover img")?.src ??
null,
getIndexPages: async () => {
const indexPages = [];
let nextUrl = bookUrl;
do {
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_2__/* .getHtmlDOM */ .wA)(nextUrl);
indexPages.push(doc);
nextUrl =
doc.querySelector("div.move_set:nth-child(4) > div:nth-child(3) > a")?.href ?? null;
} while (nextUrl);
return indexPages;
},
getAList: (doc) => doc.querySelectorAll(".episode_list li > .episode_link > a"),
getSections: (doc) => doc.querySelectorAll(".episode_list li.chapter"),
getSName: (sElem) => sElem.querySelector("cite")?.innerText.trim() ?? "",
getContent: (doc) => doc.querySelector(".content"),
contentPatch: (content) => {
Array.from(content.querySelectorAll("p")).forEach((p) => {
const div = document.createElement("div");
div.innerHTML = p.innerHTML.split("\n").join("<br>");
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__/* .insertBrBeforeText */ .Md)(div);
p.replaceWith(div);
});
return content;
},
language: "ja",
});
};
/***/ }),
/***/ "./src/rules/onePageWithMultiIndexPage/template.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ N: () => (/* binding */ mkRuleClass)
/* harmony export */ });
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_misc__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/lib/misc.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules.ts");
/* harmony import */ var _main_main__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/main/main.ts");
function mkRuleClass({ bookUrl, bookname, author, introDom, introDomPatch, coverUrl, getIndexUrls, getIndexPages, getAList, getAName, getIsVIP, getSections, getSName, postHook, getContentFromUrl, getContent, contentPatch, concurrencyLimit, sleepTime, maxSleepTime, needLogin, nsfw, cleanDomOptions, overrideConstructor, language, }) {
return class extends _rules__WEBPACK_IMPORTED_MODULE_0__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
if (concurrencyLimit) {
this.concurrencyLimit = concurrencyLimit;
}
if (sleepTime) {
this.sleepTime = sleepTime;
}
if (maxSleepTime) {
this.maxSleepTime = maxSleepTime;
}
if (needLogin) {
this.needLogin = needLogin;
}
if (nsfw) {
this.nsfw = nsfw;
}
if (overrideConstructor) {
overrideConstructor(this);
}
}
async bookParse() {
let [introduction, introductionHTML] = [null, null];
if (introDom && introDomPatch) {
[introduction, introductionHTML] = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_1__/* .introDomHandle */ .HV)(introDom, introDomPatch);
}
const additionalMetadate = {
language: language ?? "zh",
};
if (coverUrl) {
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_2__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_3___default().error(error));
}
let indexPages;
if (typeof getIndexPages === "function") {
indexPages = await getIndexPages();
}
else if (typeof getIndexUrls === "function") {
const indexUrls = await getIndexUrls();
const _indexPage = [];
await (0,_lib_misc__WEBPACK_IMPORTED_MODULE_4__/* .concurrencyRun */ .rr)(indexUrls, this.concurrencyLimit, async (url) => {
_log__WEBPACK_IMPORTED_MODULE_3___default().info(`[BookParse]抓取目录页:${url}`);
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_5__/* .getHtmlDomWithRetry */ .kP)(url, this.charset);
_indexPage.push([doc, url]);
return doc;
});
indexPages = _indexPage
.sort((a, b) => {
const aUrl = a[1];
const bUrl = b[1];
return indexUrls.indexOf(aUrl) - indexUrls.indexOf(bUrl);
})
.map((l) => l[0]);
}
else {
throw Error("未发现 getIndexUrls 或 getIndexPages");
}
const chapters = [];
let chapterNumber = 0;
let sectionNumber = 0;
let sectionChapterNumber = 0;
let sectionName = null;
for (const doc of indexPages) {
if (!doc) {
continue;
}
let sections;
let hasSection;
if (typeof getSections === "function") {
sections = getSections(doc);
hasSection = true;
}
const aList = getAList(doc);
for (const aElem of Array.from(aList)) {
let chapterName;
if (getAName) {
chapterName = getAName(aElem);
}
else {
chapterName = aElem.innerText.trim();
}
const chapterUrl = aElem.href;
if (hasSection && sections && getSName) {
const _sectionName = (0,_lib_rule__WEBPACK_IMPORTED_MODULE_1__/* .getSectionName */ .lq)(aElem, sections, getSName);
if (_sectionName !== null && _sectionName !== sectionName) {
sectionName = _sectionName;
sectionNumber++;
sectionChapterNumber = 0;
}
}
chapterNumber++;
sectionChapterNumber++;
let isVIP = false;
let isPaid = false;
if (getIsVIP) {
({ isVIP, isPaid } = getIsVIP(aElem));
}
let chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_6__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP,
isPaid,
sectionName,
sectionNumber: hasSection ? sectionNumber : null,
sectionChapterNumber: hasSection ? sectionChapterNumber : null,
chapterParse: this.chapterParse,
charset: this.charset,
options: { bookname },
});
if (isVIP && !isPaid) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_7__/* .Status */ .nW.aborted;
}
if (typeof postHook === "function") {
chapter = postHook(chapter);
}
if (chapter) {
chapters.push(chapter);
}
}
}
return new _main_Book__WEBPACK_IMPORTED_MODULE_8__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
let content;
if (typeof getContentFromUrl === "function") {
content = await getContentFromUrl(chapterUrl, chapterName, charset);
}
else if (typeof getContent === "function") {
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_5__/* .getHtmlDOM */ .wA)(chapterUrl, charset);
content = getContent(doc);
}
else {
throw Error("未发现 getContentFromUrl 或 getContent");
}
if (content) {
content = contentPatch(content);
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_9__/* .cleanDOM */ .an)(content, "TM", cleanDomOptions);
return {
chapterName,
contentRaw: content,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: null,
};
}
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
};
}
/***/ }),
/***/ "./src/rules/onePageWithMultiIndexPage/wanben.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ wanben: () => (/* binding */ wanben)
/* harmony export */ });
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePageWithMultiIndexPage/template.ts");
const wanben = () => {
const getIntroDom = () => {
const a = document.querySelector(".bookInfo > a");
if (a) {
a.click();
a.remove();
}
return document.querySelector(".bookInfo");
};
return (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector("div.bookPhr > h2").innerText.trim(),
author: document.querySelector("div.bookPhrMid > p:nth-child(1)").innerText
.replace("作者:", "")
.trim(),
introDom: getIntroDom(),
introDomPatch: (dom) => dom,
coverUrl: document.querySelector("div.bookImg > img")
?.src,
getIndexUrls: async () => {
const contentPageUrl = document.querySelector("#contentbox > div.detailDiv > div.category > a").href;
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_1__/* .getHtmlDOM */ .wA)(contentPageUrl, document.characterSet);
const aList = doc.querySelectorAll("div.pageBg div.pagenum a");
const indexUrls = Array.from(aList).map((a) => a.href);
return indexUrls;
},
getAList: (doc) => doc.querySelectorAll("div.chapterDiv > div.chapterList > ul > a"),
getContentFromUrl: async (chapterUrl, chapterName, charset) => {
const { contentRaw } = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_2__/* .nextPageParse */ .u1)({
chapterName,
chapterUrl,
charset,
selector: "div.raderCon",
contentPatch: (content, doc) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_3__.rm)("script", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_3__.rm)("[style]", true, content);
const ads = [
"【提示】:如果觉得此文不错,请推荐给更多小伙伴吧!分享也是一种享受。",
"【看书助手】",
"【完本神站】",
"百万热门书籍终身无广告免费阅读",
];
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_3__/* .rm2 */ .Sf)(ads, content);
(0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_4__/* .htmlTrim */ .is)(content);
return content;
},
getNextPage: (doc) => doc.querySelector("div.page > a:nth-child(3)")
.href,
continueCondition: (_content, nextLink) => {
const pathname = nextLink.split("/").slice(-1)[0];
return pathname.includes("_");
},
enableCleanDOM: false,
});
return contentRaw;
},
contentPatch: (dom) => dom,
});
};
/***/ }),
/***/ "./src/rules/onePageWithMultiIndexPage/xbookcn.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ xbookcn: () => (/* binding */ xbookcn)
/* harmony export */ });
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _template__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/onePageWithMultiIndexPage/template.ts");
const xbookcn = () => (0,_template__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
bookname: document.querySelector(".status-msg-body")?.textContent ?? "",
author: document.querySelector(".entry-content > p:nth-child(1)")?.innerText.split(":")[1] ?? "",
introDom: document.querySelector(".entry-content"),
introDomPatch: (content) => content,
coverUrl: null,
getIndexPages: async () => {
const bookUrl = document.location.origin + document.location.pathname;
const indexPages = [];
let nextUrl = bookUrl;
do {
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_1__/* .getHtmlDOM */ .wA)(nextUrl, "UTF-8");
indexPages.push(doc);
nextUrl =
doc.querySelector("#Blog1_blog-pager-older-link")?.href ?? null;
} while (nextUrl);
return indexPages;
},
getAList: (doc) => doc.querySelectorAll("h3 > a"),
getAName: (aElem) => aElem.innerText.trim(),
getContent: (doc) => doc.querySelector(".entry-content"),
contentPatch: (content) => content,
language: "zh",
});
/***/ }),
/***/ "./src/rules/special/original/17k.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ C17k: () => (/* binding */ C17k)
/* harmony export */ });
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_4__);
/* harmony import */ var _main_main__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/main/main.ts");
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules.ts");
class C17k extends _rules__WEBPACK_IMPORTED_MODULE_0__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
this.charset = "UTF-8";
this.concurrencyLimit = 5;
}
async bookParse() {
const bookUrl = document.location.href.replace("/list/", "/book/");
const bookname = document.querySelector("h1.Title").innerText.trim();
const author = document.querySelector("div.Author > a").innerText.trim();
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_1__/* .getHtmlDOM */ .wA)(bookUrl, undefined);
const introDom = doc.querySelector("#bookInfo p.intro > a");
const [introduction, introductionHTML] = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_2__/* .introDomHandle */ .HV)(introDom);
const additionalMetadate = {};
const coverUrl = doc.querySelector("#bookCover img.book").src;
if (coverUrl) {
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_3__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_4___default().error(error));
}
const chapters = [];
const sections = document.querySelectorAll("dl.Volume");
let chapterNumber = 0;
for (let i = 0; i < sections.length; i++) {
const s = sections[i];
const sectionNumber = i + 1;
const sectionName = s.querySelector("dt > span.tit").innerText.trim();
let sectionChapterNumber = 0;
const cs = s.querySelectorAll("dd > a");
for (const a of Array.from(cs)) {
const span = a.firstElementChild;
chapterNumber++;
sectionChapterNumber++;
const chapterName = span.innerText.trim();
const chapterUrl = a.href;
const isVIP = () => {
return !!span?.className.includes("vip");
};
const isPaid = () => {
return false;
};
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_5__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP: isVIP(),
isPaid: isPaid(),
sectionName,
sectionNumber,
sectionChapterNumber,
chapterParse: this.chapterParse,
charset: this.charset,
options: {},
});
const isLogin = () => {
return false;
};
if (isVIP() && !(isLogin() && chapter.isPaid)) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_6__/* .Status */ .nW.aborted;
}
chapters.push(chapter);
}
}
const book = new _main_Book__WEBPACK_IMPORTED_MODULE_7__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
book.ToCUrl = document.location.href;
return book;
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
async function publicChapter() {
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_1__/* .getHtmlDOM */ .wA)(chapterUrl, charset);
chapterName = doc.querySelector("#readArea > div.readAreaBox.content > h1").innerText.trim();
const content = doc.querySelector("#readArea > div.readAreaBox.content > div.p");
if (content) {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_8__.rm)("p.copy", false, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_8__.rm)("#banner_content", false, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_8__.rm)("div.qrcode", false, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_8__.rm)("div.chapter_text_ad", false, content);
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_9__/* .cleanDOM */ .an)(content, "TM");
return {
chapterName,
contentRaw: content,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: null,
};
}
else {
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
}
async function vipChapter() {
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
if (isVIP) {
return vipChapter();
}
else {
return publicChapter();
}
}
}
/***/ }),
/***/ "./src/rules/special/original/bilibili.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ MangaBilibili: () => (/* binding */ MangaBilibili)
/* harmony export */ });
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_misc__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/lib/misc.ts");
/* harmony import */ var _lib_hash__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__("./src/lib/hash.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _main_Attachment__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__("./src/main/Attachment.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_main__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/main/main.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules.ts");
class MangaBilibili extends _rules__WEBPACK_IMPORTED_MODULE_0__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "naive";
this.concurrencyLimit = 1;
this.streamZip = true;
}
async bookParse() {
const _comic_id = /\/mc(\d+)$/.exec(document.location.pathname)?.[1];
if (!_comic_id) {
throw new Error("获取 comic_id 失败!");
}
const comic_id = parseInt(_comic_id);
const signIn = await isSignin(comic_id);
const detail = await getDetail(comic_id);
const bookUrl = document.location.href;
const bookname = detail.title;
const author = detail.author_name.join(", ");
const introduction = detail.evaluate;
const introductionHTML = document.createElement("div");
introductionHTML.innerText = detail.evaluate;
const additionalMetadate = {};
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_1__/* .getAttachment */ ["if"])(detail.vertical_cover, this.attachmentMode, "vertical_cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_2___default().error(error));
additionalMetadate.tags = detail.styles;
additionalMetadate.attachments = [];
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_1__/* .getAttachment */ ["if"])(detail.horizontal_cover, this.attachmentMode, "horizontal_cover-")
.then((coverClass) => {
additionalMetadate.attachments?.push(coverClass);
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_2___default().error(error));
const chapters = detail.ep_list.map((ep) => {
const chapterUrl = `https://manga.bilibili.com/mc${comic_id}/${ep.id}?from=manga_detail`;
const chapterNumber = ep.ord;
const chapterName = [ep.short_title.trim(), ep.title.trim()].join(" ");
const isVIP = ep.pay_gold !== 0;
const isPaid = isVIP ? !ep.is_locked : true;
const options = {
comic_id,
ep_id: ep.id,
};
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_3__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP,
isPaid,
sectionName: null,
sectionNumber: null,
sectionChapterNumber: null,
chapterParse: this.chapterParse,
charset: this.charset,
options,
});
if (ep.is_locked || ep.type === 6) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_4__/* .Status */ .nW.aborted;
}
return chapter;
});
return new _main_Book__WEBPACK_IMPORTED_MODULE_5__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
async function isSignin(comic_id) {
const body = { comic_id };
const resp = await fetch("https://manga.bilibili.com/twirp/bookshelf.v1.Bookshelf/HasFavorite?device=pc&platform=web", {
headers: {
Accept: "application/json, text/plain, */*",
"Content-Type": "application/json;charset=utf-8",
},
body: JSON.stringify(body),
method: "POST",
});
return resp.ok;
}
async function getDetail(comic_id) {
const url = "https://manga.bilibili.com/twirp/comic.v1.Comic/ComicDetail?device=pc&platform=web";
const body = {
comic_id,
};
const headers = {
accept: "application/json, text/plain, */*",
"content-type": "application/json;charset=UTF-8",
};
const init = {
headers,
body: JSON.stringify(body),
method: "POST",
};
const resp = await fetch(url, init);
const data = (await resp.json());
if (data.code === 0) {
return data.data;
}
else {
throw new Error("获取目录失败!");
}
}
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
const paths = await getImageIndex(options.ep_id);
const _outs = [];
const worker = async (path) => {
const obj = await getImage(path);
const out = {
path,
obj,
};
_outs.push(out);
return out;
};
await (0,_lib_misc__WEBPACK_IMPORTED_MODULE_6__/* .concurrencyRun */ .rr)(paths, 3, worker);
_outs.sort((a, b) => paths.indexOf(a.path) - paths.indexOf(b.path));
const outs = _outs.map((out) => out.obj);
const dom = document.createElement("div");
outs.forEach((o) => {
const p = document.createElement("p");
p.appendChild(o.dom);
dom.appendChild(p);
});
const text = outs.map((o) => o.text).join("\n\n");
const images = outs.map((o) => o.images);
return {
chapterName,
contentRaw: dom,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: null,
};
async function getImageIndex(ep_id) {
const url = "https://manga.bilibili.com/twirp/comic.v1.Comic/GetImageIndex?device=pc&platform=web";
const body = {
ep_id,
};
const headers = {
Accept: "application/json, text/plain, */*",
"Content-Type": "application/json;charset=utf-8",
};
const init = {
headers,
body: JSON.stringify(body),
method: "POST",
mode: "cors",
credentials: "include",
};
const resp = await fetch(url, init);
const data = (await resp.json());
if (data.code === 0) {
const images = data.data.images;
return images.map((i) => i.path);
}
else {
throw new Error(`抓取章节图片索引失败! ep_id: ${ep_id}, code: ${data.code}, mes: ${data.msg}`);
}
}
async function getImage(path) {
const token = await getImageToken(path);
if (token) {
const img = await getImage(token);
const _dom = document.createElement("img");
_dom.setAttribute("data-src-address", img.name);
_dom.alt = img.url;
const _text = `![${img.url}](${img.name})`;
_log__WEBPACK_IMPORTED_MODULE_2___default().info(`ep_id: ${options.ep_id}, path: ${path} 抓取成功!`);
return {
dom: _dom,
text: _text,
images: img,
};
}
throw new Error("获取图片 " + path + " 失败!");
async function getImageToken(path) {
const url = "https://manga.bilibili.com/twirp/comic.v1.Comic/ImageToken?device=pc&platform=web";
const body = {
urls: JSON.stringify([path]),
};
const headers = {
Accept: "application/json, text/plain, */*",
"Content-Type": "application/json;charset=utf-8",
};
const init = {
headers,
body: JSON.stringify(body),
method: "POST",
referrer: chapterUrl,
};
const resp = await fetch(url, init);
const data = (await resp.json());
if (data.code === 0) {
return data.data[0];
}
}
async function getImage(_token) {
const url = _token.url + "?token=" + _token.token;
const headers = {
Accept: "application/json, text/plain, */*",
};
const init = {
headers,
method: "GET",
};
const resp = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_7__/* .fetchWithRetry */ .J5)(url, init);
const blob = await resp.blob();
const hash = await (0,_lib_hash__WEBPACK_IMPORTED_MODULE_8__/* .calculateSha1 */ .Q)(blob);
const ext = await (0,_lib_attachments__WEBPACK_IMPORTED_MODULE_1__/* .getExt */ .an)(blob, url);
const name = ["cm-", hash, ".", ext].join("");
const imgClass = new _main_Attachment__WEBPACK_IMPORTED_MODULE_9__/* .AttachmentClass */ .q(url, name, "naive");
imgClass.Blob = blob;
imgClass.status = _main_main__WEBPACK_IMPORTED_MODULE_4__/* .Status */ .nW.finished;
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_1__/* .putAttachmentClassCache */ .Ld)(imgClass);
return imgClass;
}
}
}
}
/***/ }),
/***/ "./src/rules/special/original/ciweimao.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Duread: () => (/* binding */ Duread),
/* harmony export */ Shubl: () => (/* binding */ Shubl)
/* harmony export */ });
/* harmony import */ var crypto_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("crypto-js");
/* harmony import */ var crypto_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(crypto_js__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_5__);
/* harmony import */ var _main_main__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/main/main.ts");
/* harmony import */ var _main_Attachment__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__("./src/main/Attachment.ts");
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/rules.ts");
class Shubl extends _rules__WEBPACK_IMPORTED_MODULE_1__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
this.concurrencyLimit = 1;
this.maxRunLimit = 1;
}
async bookParse() {
const bookUrl = document.location.href;
const bookname = document.querySelector(".book-title > span").innerText.trim();
const author = document.querySelector("div.username").innerText.trim();
const introDom = document.querySelector(".book-brief");
const [introduction, introductionHTML] = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_2__/* .introDomHandle */ .HV)(introDom, (introDomI) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_3__/* .rms */ .j3)(["简介:"], introDomI);
return introDomI;
});
const additionalMetadate = {};
const coverUrl = document.querySelector(".book-img")
.src;
if (coverUrl) {
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_4__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_5___default().error(error));
}
additionalMetadate.tags = Array.from(document.querySelectorAll("div.row > span.tag")).map((span) => span.innerText.trim());
const chapters = [];
const chapterTitleList = Array.from(document.querySelectorAll("#chapter_list > div.chapter > div.chapter-title")).map((div) => div.innerText.trim());
const articlesList = document.querySelectorAll("#chapter_list > div.chapter > div.articles");
const sectionLength = chapterTitleList.length;
let chapterNumber = 0;
for (let i = 0; i < sectionLength; i++) {
const s = articlesList[i];
const sectionNumber = i + 1;
const sectionName = chapterTitleList[i];
let sectionChapterNumber = 0;
const cs = s.querySelectorAll("span.chapter_item");
for (const c of Array.from(cs)) {
chapterNumber++;
sectionChapterNumber++;
const a = c.querySelector("a");
if (a) {
const chapterName = a.innerText.trim();
const chapterUrl = a.href;
const isVIP = () => {
return c.childElementCount === 2;
};
const isPaid = () => {
return isVIP() && c.querySelector("i")?.className === "unlock";
};
const isLogin = () => {
return (document.querySelector("#header > div.container > div.right.pull-right")?.childElementCount === 3);
};
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_6__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP: isVIP(),
isPaid: isPaid(),
sectionName,
sectionNumber,
sectionChapterNumber,
chapterParse: this.chapterParse,
charset: this.charset,
options: {},
});
if (isVIP() && !(isLogin() && isPaid())) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_7__/* .Status */ .nW.aborted;
}
chapters.push(chapter);
}
}
}
return new _main_Book__WEBPACK_IMPORTED_MODULE_8__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
const rootPath = "https://www.shubl.com/";
const [parentWidth, setFontSize] = [939.2, "18"];
return getChapter({
chapterUrl,
chapterName,
isVIP,
isPaid,
charset,
options,
rootPath,
parentWidth,
setFontSize,
});
}
}
class Duread extends _rules__WEBPACK_IMPORTED_MODULE_1__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
this.concurrencyLimit = 1;
this.maxRunLimit = 1;
}
async bookParse() {
const bookUrl = document.location.href;
const bookname = document.querySelector(".book-title > span").innerText.trim();
const author = document.querySelector("div.username").innerText.trim();
const introDom = document.querySelector(".book-brief");
const [introduction, introductionHTML] = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_2__/* .introDomHandle */ .HV)(introDom, (introDomI) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_3__/* .rms */ .j3)(["简介:"], introDomI);
return introDomI;
});
const additionalMetadate = {};
const coverUrl = document.querySelector(".book-img")
.src;
if (coverUrl) {
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_4__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_5___default().error(error));
}
additionalMetadate.tags = Array.from(document.querySelectorAll("div.row > span.tag")).map((span) => span.innerText.trim());
const chapters = [];
const chapterTitleList = Array.from(document.querySelectorAll("#chapter_list > div.chapter > div.chapter-title")).map((div) => div.innerText.trim());
const articlesList = document.querySelectorAll("#chapter_list > div.chapter > div.articles");
const sectionLength = chapterTitleList.length;
let chapterNumber = 0;
for (let i = 0; i < sectionLength; i++) {
const s = articlesList[i];
const sectionNumber = i + 1;
const sectionName = chapterTitleList[i];
let sectionChapterNumber = 0;
const cs = s.querySelectorAll("span.chapter_item");
for (const c of Array.from(cs)) {
chapterNumber++;
sectionChapterNumber++;
const a = c.querySelector("a");
if (a) {
const chapterName = a.innerText.trim();
const chapterUrl = a.href;
const isVIP = () => {
return c.childElementCount === 2;
};
const isPaid = () => {
return isVIP() && c.querySelector("i")?.className === "unlock";
};
const isLogin = () => {
return (document.querySelector("#header > div.container > div.right.pull-right")?.childElementCount === 3);
};
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_6__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP: isVIP(),
isPaid: isPaid(),
sectionName,
sectionNumber,
sectionChapterNumber,
chapterParse: this.chapterParse,
charset: this.charset,
options: {},
});
if (isVIP() && !(isLogin() && isPaid())) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_7__/* .Status */ .nW.aborted;
}
chapters.push(chapter);
}
}
}
return new _main_Book__WEBPACK_IMPORTED_MODULE_8__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
const rootPath = "https://www.duread.cn/";
const [parentWidth, setFontSize] = [939.2, "18"];
return getChapter({
chapterUrl,
chapterName,
isVIP,
isPaid,
charset,
options,
rootPath,
parentWidth,
setFontSize,
});
}
}
function getChapter({ chapterUrl, chapterName, isVIP, isPaid, charset, options, rootPath, parentWidth, setFontSize, }) {
function decrypt(item) {
let message = item.content;
const keys = item.keys;
const len = item.keys.length;
const accessKey = item.accessKey;
const accessKeyList = accessKey.split("");
const charsNotLatinNum = accessKeyList.length;
const output = [];
output.push(keys[accessKeyList[charsNotLatinNum - 1].charCodeAt(0) % len]);
output.push(keys[accessKeyList[0].charCodeAt(0) % len]);
for (let i = 0; i < output.length; i++) {
message = atob(message);
const data = output[i];
const iv = btoa(message.substr(0, 16));
const keys255 = btoa(message.substr(16));
const pass = crypto_js__WEBPACK_IMPORTED_MODULE_0__.format.OpenSSL.parse(keys255);
message = crypto_js__WEBPACK_IMPORTED_MODULE_0__.AES.decrypt(pass, crypto_js__WEBPACK_IMPORTED_MODULE_0__.enc.Base64.parse(data), {
iv: crypto_js__WEBPACK_IMPORTED_MODULE_0__.enc.Base64.parse(iv),
format: crypto_js__WEBPACK_IMPORTED_MODULE_0__.format.OpenSSL,
});
if (i < output.length - 1) {
message = message.toString(crypto_js__WEBPACK_IMPORTED_MODULE_0__.enc.Base64);
message = atob(message);
}
}
return message.toString(crypto_js__WEBPACK_IMPORTED_MODULE_0__.enc.Utf8);
}
async function getChapterAuthorSay() {
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_9__/* .getHtmlDOM */ .wA)(chapterUrl, undefined);
const chapterAuthorSays = doc.querySelectorAll("#J_BookCnt .chapter.author_say");
let divChapterAuthorSay;
if (chapterAuthorSays.length !== 0) {
const hr = document.createElement("hr");
divChapterAuthorSay = document.createElement("div");
divChapterAuthorSay.appendChild(hr);
for (const chapterAuthorSay of Array.from(chapterAuthorSays)) {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_3__.rm)("i", true, chapterAuthorSay);
divChapterAuthorSay.appendChild(chapterAuthorSay);
}
}
return divChapterAuthorSay;
}
const chapterId = chapterUrl.split("/").slice(-1)[0];
async function publicChapter() {
async function chapterDecrypt(chapterIdt, refererUrl) {
const accessKeyUrl = rootPath + "chapter/ajax_get_session_code";
const chapterContentUrl = rootPath + "chapter/get_book_chapter_detail_info";
_log__WEBPACK_IMPORTED_MODULE_5___default().debug(`[Chapter]请求 ${accessKeyUrl} Referer ${refererUrl}`);
const accessKeyObj = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_9__/* .gfetch */ ._V)(accessKeyUrl, {
method: "POST",
headers: {
Accept: "application/json, text/javascript, */*; q=0.01",
"Content-Type": "application/x-www-form-urlencoded; charset=UTF-8",
Referer: refererUrl,
Origin: document.location.origin,
"X-Requested-With": "XMLHttpRequest",
},
data: `chapter_id=${chapterIdt}`,
responseType: "json",
})
.then((response) => response.response)
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_5___default().error(error));
const chapter_access_key = accessKeyObj
.chapter_access_key;
_log__WEBPACK_IMPORTED_MODULE_5___default().debug(`[Chapter]请求 ${chapterContentUrl} Referer ${refererUrl}`);
const chapterContentObj = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_9__/* .gfetch */ ._V)(chapterContentUrl, {
method: "POST",
headers: {
Accept: "application/json, text/javascript, */*; q=0.01",
"Content-Type": "application/x-www-form-urlencoded; charset=UTF-8",
Referer: refererUrl,
Origin: document.location.origin,
"X-Requested-With": "XMLHttpRequest",
},
data: `chapter_id=${chapterIdt}&chapter_access_key=${chapter_access_key}`,
responseType: "json",
})
.then((response) => response.response)
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_5___default().error(error));
if (chapterContentObj.code !== 100000) {
_log__WEBPACK_IMPORTED_MODULE_5___default().error(chapterContentObj);
throw new Error(`下载 ${refererUrl} 失败`);
}
return decrypt({
content: chapterContentObj.chapter_content,
keys: chapterContentObj.encryt_keys,
accessKey: chapter_access_key,
});
}
const divChapterAuthorSay = await getChapterAuthorSay();
const content = document.createElement("div");
const decryptDate = await chapterDecrypt(chapterId, chapterUrl);
content.innerHTML = decryptDate;
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_3__.rm)(".chapter span", true, content);
if (divChapterAuthorSay) {
content.appendChild(divChapterAuthorSay);
}
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_10__/* .cleanDOM */ .an)(content, "TM");
return {
chapterName,
contentRaw: content,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: null,
};
}
async function vipChapter(parentWidth, setFontSize) {
async function vipChapterDecrypt(chapterIdi, refererUrl) {
const imageSessionCodeUrl = rootPath + "chapter/ajax_get_image_session_code";
_log__WEBPACK_IMPORTED_MODULE_5___default().debug(`[Chapter]请求 ${imageSessionCodeUrl} Referer ${refererUrl}`);
const imageSessionCodeObject = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_9__/* .gfetch */ ._V)(imageSessionCodeUrl, {
method: "POST",
headers: {
Accept: "application/json, text/javascript, */*; q=0.01",
Referer: refererUrl,
Origin: document.location.origin,
"X-Requested-With": "XMLHttpRequest",
},
responseType: "json",
})
.then((response) => response.response)
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_5___default().error(error));
if (imageSessionCodeObject.code !== 100000) {
_log__WEBPACK_IMPORTED_MODULE_5___default().error(imageSessionCodeObject);
throw new Error(`下载 ${refererUrl} 失败`);
}
const imageCode = decrypt({
content: imageSessionCodeObject.image_code,
keys: imageSessionCodeObject.encryt_keys,
accessKey: imageSessionCodeObject
.access_key,
});
const vipCHapterImageUrlI = rootPath +
"chapter/book_chapter_image?chapter_id=" +
chapterIdi +
"&area_width=" +
parentWidth +
"&font=undefined" +
"&font_size=" +
setFontSize +
"&image_code=" +
imageCode +
"&bg_color_name=white" +
"&text_color_name=white";
return vipCHapterImageUrlI;
}
const getIsLogin = () => {
if (document.location.host === "www.duread.cn") {
return (document.querySelector("div.dropdown-menu")?.childElementCount === 3);
}
else if (document.location.host === "www.shubl.com") {
return (document.querySelector("div.pull-right:nth-child(2)")
?.childElementCount === 3);
}
else {
return (document.querySelector(".login-info.ly-fr")?.childElementCount === 1);
}
};
const isLogin = getIsLogin();
if (isLogin && isPaid) {
const divChapterAuthorSay = await getChapterAuthorSay();
const vipCHapterImageUrl = await vipChapterDecrypt(chapterId, chapterUrl);
_log__WEBPACK_IMPORTED_MODULE_5___default().debug(`[Chapter]请求 ${vipCHapterImageUrl} Referer ${chapterUrl}`);
const vipCHapterImageBlob = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_9__/* .gfetch */ ._V)(vipCHapterImageUrl, {
method: "GET",
headers: {
Referer: chapterUrl,
Accept: "image/avif,image/webp,image/apng,image/svg+xml,image/*,*/*;q=0.8",
},
responseType: "blob",
})
.then((response) => response.response)
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_5___default().error(error));
const vipCHapterName = `vipCHapter${chapterId}.png`;
const vipCHapterImage = new _main_Attachment__WEBPACK_IMPORTED_MODULE_11__/* .AttachmentClass */ .q(vipCHapterImageUrl, vipCHapterName, "TM");
if (vipCHapterImageBlob) {
vipCHapterImage.Blob = vipCHapterImageBlob;
vipCHapterImage.status = _main_main__WEBPACK_IMPORTED_MODULE_7__/* .Status */ .nW.finished;
}
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_4__/* .putAttachmentClassCache */ .Ld)(vipCHapterImage);
const contentImages = [vipCHapterImage];
let ddom;
let dtext;
if (divChapterAuthorSay) {
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_10__/* .cleanDOM */ .an)(divChapterAuthorSay, "TM");
[ddom, dtext] = [dom, text, images];
}
const img = document.createElement("img");
img.setAttribute("data-src-address", vipCHapterName);
img.alt = vipCHapterImageUrl;
const contentHTML = document.createElement("div");
contentHTML.appendChild(img);
if (ddom) {
contentHTML.appendChild(ddom);
}
let contentText = `VIP章节,请打开HTML文件查看。\n![${vipCHapterImageUrl}](${vipCHapterName})`;
if (dtext) {
contentText = contentText + "\n\n" + dtext;
}
return {
chapterName,
contentRaw: contentHTML,
contentText,
contentHTML,
contentImages,
additionalMetadate: null,
};
}
else {
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
}
if (isVIP) {
return vipChapter(parentWidth, setFontSize);
}
else {
return publicChapter();
}
}
/***/ }),
/***/ "./src/rules/special/original/ciyuanji.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Ciyuanji: () => (/* binding */ Ciyuanji)
/* harmony export */ });
/* harmony import */ var crypto_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("crypto-js");
/* harmony import */ var crypto_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(crypto_js__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_4__);
/* harmony import */ var _main_main__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/main/main.ts");
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/rules.ts");
class Ciyuanji extends _rules__WEBPACK_IMPORTED_MODULE_1__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
this.concurrencyLimit = 1;
}
async bookParse() {
const bookUrl = document.location.href;
const bookObject = unsafeWindow.__NEXT_DATA__.props.pageProps.book;
const bookId = bookObject.bookId;
const bookname = bookObject.bookName;
const author = bookObject.authorName;
const introDom = document.createElement("div");
introDom.innerHTML = bookObject.notes.replace("/\n/g", "<br/><br/>");
const [introduction, introductionHTML] = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_2__/* .introDomHandle */ .HV)(introDom);
const additionalMetadate = {};
const coverUrl = bookObject.imgUrl;
if (coverUrl) {
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_3__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_4___default().error(error));
}
additionalMetadate.tags = bookObject.tagList.map((tagobj) => tagobj.tagName);
const bookChapterObject = unsafeWindow.__NEXT_DATA__.props.pageProps.bookChapter;
const chapterList = bookChapterObject.chapterList;
const chapters = [];
let chapterNumber = 0;
let sectionName = null;
let sectionNumber = 0;
let sectionChapterNumber = 0;
for (const chapterObj of chapterList) {
const chapterId = chapterObj.chapterId;
const chapterUrl = `${document.location.origin}/chapter/${bookId}_${chapterId}`;
const chapterName = chapterObj.chapterName;
const _sectionName = chapterObj.title;
if (sectionName !== _sectionName) {
sectionName = _sectionName;
sectionNumber++;
sectionChapterNumber = 0;
}
chapterNumber++;
sectionChapterNumber++;
const isVIP = chapterObj.isFee === "1";
const isPaid = chapterObj.isBuy === "1";
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_5__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP,
isPaid,
sectionName,
sectionNumber,
sectionChapterNumber,
chapterParse: this.chapterParse,
charset: this.charset,
options: {},
});
if (chapter.isVIP && !chapter.isPaid) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_6__/* .Status */ .nW.aborted;
}
chapters.push(chapter);
}
return new _main_Book__WEBPACK_IMPORTED_MODULE_7__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
const data = {
key: "ZUreQN0Epkpxh3pooWOgixjTfPwumCTYWzYTQ7SMgDnqFLQ1s9tqpVhkGf02we89moQwhSQ07DVzc3LWupRgbVvm29aYeY7zyFN",
type1: "PC-Token",
type2: "PC-UserInfo",
type3: "PC-Enum",
type4: "PC-IsActivityStart",
f: "NpkTYvpvhJjEog8Y051gQDHmReY54z5t3F0zSd9QEFuxWGqfC8g8Y4GPuabq0KPdxArlji4dSnnHCARHnkqYBLu7iIw55ibTo18",
};
function encrypt(input) {
if (input && "string" === typeof input) {
const key = crypto_js__WEBPACK_IMPORTED_MODULE_0__.enc.Utf8.parse(data.key);
return crypto_js__WEBPACK_IMPORTED_MODULE_0__.DES.encrypt(input, key, {
mode: crypto_js__WEBPACK_IMPORTED_MODULE_0__.mode.ECB,
padding: crypto_js__WEBPACK_IMPORTED_MODULE_0__.pad.Pkcs7,
}).toString();
}
}
function decrypt(input) {
if (input && "string" === typeof input) {
input = input.replace(/\n/g, "");
const key = crypto_js__WEBPACK_IMPORTED_MODULE_0__.enc.Utf8.parse(data.key);
return crypto_js__WEBPACK_IMPORTED_MODULE_0__.DES.decrypt(input, key, {
mode: crypto_js__WEBPACK_IMPORTED_MODULE_0__.mode.ECB,
padding: crypto_js__WEBPACK_IMPORTED_MODULE_0__.pad.Pkcs7,
}).toString(crypto_js__WEBPACK_IMPORTED_MODULE_0__.enc.Utf8);
}
}
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_8__/* .getHtmlDOM */ .wA)(chapterUrl, charset);
const nextDataElement = document.getElementById("__NEXT_DATA__");
if (!nextDataElement) {
throw new Error("无法找到'__NEXT_DATA__',下载失败");
}
const __NEXT_DATA__ = JSON.parse(nextDataElement.innerHTML);
const chapterObj = __NEXT_DATA__.props.pageProps.chapterContent.chapter;
const content = document.createElement("div");
const chapterContent = decrypt(chapterObj.chapterContentFormat);
if (chapterContent) {
content.innerHTML = chapterContent;
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_9__/* .cleanDOM */ .an)(content, "TM");
return {
chapterName,
contentRaw: content,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: null,
};
}
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
}
/***/ }),
/***/ "./src/rules/special/original/cool18.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Cool18: () => (/* binding */ Cool18)
/* harmony export */ });
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules.ts");
class Cool18 extends _rules__WEBPACK_IMPORTED_MODULE_0__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
this.nsfw = true;
}
async bookParse() {
const bookUrl = document.location.href;
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_1__/* .getHtmlDOM */ .wA)(bookUrl, this.charset);
const title = doc.querySelector('.show_content > center > font[size="6"] > b').innerText.trim();
const matchs = /[【《](.+)[】》](.+)?作者:([^\s-]+)/.exec(title);
let bookname = title;
let author = "";
if (matchs) {
bookname = matchs[1];
author = matchs[3];
}
const introduction = null;
const introductionHTML = null;
const additionalMetadate = {};
const _aElems = Array.from(document.querySelectorAll(".show_content > pre a, body > table:nth-child(7) > tbody:nth-child(1) > tr:nth-child(1) > td:nth-child(1) > ul:nth-child(2) > li > a"));
const _a = document.createElement("a");
_a.href = document.location.href;
_a.innerText = title;
_aElems.push(_a);
const aElems = _aElems
.filter((a) => {
const href = a.href;
const url = new URL(href);
return (url.searchParams.get("act") === "threadview" &&
url.searchParams.has("tid"));
})
.filter((a) => a.innerText.includes("(无内容)") === false)
.filter((item, pos, self) => {
const urls = self.map((a) => a.href);
const url = item.href;
return urls.indexOf(url) === pos;
})
.sort((a, b) => {
const _aTid = new URL(a.href).searchParams.get("tid");
const _bTid = new URL(b.href).searchParams.get("tid");
const aTid = parseInt(_aTid);
const bTid = parseInt(_bTid);
return aTid - bTid;
});
const chapters = aElems.map((a) => {
const chapterUrl = a.href;
const chapterNumber = -1;
const chapterName = a.innerText
.replace(`【${bookname}】`, "")
.replace(`《${bookname}》`, "")
.replace(`作者:${author}`, "")
.trim();
return new _main_Chapter__WEBPACK_IMPORTED_MODULE_2__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP: false,
isPaid: false,
sectionName: null,
sectionNumber: null,
sectionChapterNumber: null,
chapterParse: this.chapterParse,
charset: this.charset,
options: { bookname, author },
});
});
let i = 0;
for (const chapter of chapters) {
i++;
chapter.chapterNumber = i;
}
return new _main_Book__WEBPACK_IMPORTED_MODULE_3__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_1__/* .getHtmlDOM */ .wA)(chapterUrl, charset);
chapterName = doc.querySelector('.show_content > center > font[size="6"] > b').innerText
.replace(`【${options.bookname}】`, "")
.replace(`《${options.bookname}》`, "")
.replace(`作者:${options.author}`, "")
.trim();
const dom = doc.querySelector(".show_content > pre, .show_content > div");
if (dom) {
Array.from(dom.querySelectorAll('font[color*="E6E6DD"]')).forEach((f) => f.remove());
const contentRaw = document.createElement("div");
const nodes = Array.from(dom.childNodes);
if (nodes.length > 10) {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_4__/* .childNodesCopy */ .Fv)(dom, contentRaw);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_4__.rm)("a", true, contentRaw);
(0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_5__/* .convertFixWidth */ .N0)(contentRaw);
}
else {
for (const node of nodes) {
if (node instanceof Text && (node.textContent?.length ?? 0) > 200) {
if ((0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_5__/* .isFixWidth */ .eu)(node)) {
contentRaw.appendChild((0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_5__/* .convertFixWidthText */ .WF)(node));
continue;
}
else {
const div = document.createElement("div");
div.innerText = node.textContent?.trim() ?? "";
contentRaw.appendChild(div);
continue;
}
}
contentRaw.appendChild(node);
}
Array.from(contentRaw.querySelectorAll("p"))
.filter((p) => p.innerText.trim() === "" &&
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_4__/* .getPreviousSibling */ .UN)(p) instanceof HTMLElement &&
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_4__/* .getNextSibling */ .wX)(p) instanceof HTMLElement)
.forEach((p) => p.remove());
}
const { dom: contentHTML, text: contentText, images: contentImages, } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_5__/* .cleanDOM */ .an)(contentRaw, "TM");
return {
chapterName,
contentRaw,
contentText,
contentHTML,
contentImages,
additionalMetadate: null,
};
}
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
}
/***/ }),
/***/ "./src/rules/special/original/gongzicp.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Gongzicp: () => (/* binding */ Gongzicp)
/* harmony export */ });
/* harmony import */ var crypto_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("crypto-js");
/* harmony import */ var crypto_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(crypto_js__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _lib_misc__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__("./src/lib/misc.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _main_main__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/main/main.ts");
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/rules.ts");
/* harmony import */ var _setting__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__("./src/setting.ts");
class Gongzicp extends _rules__WEBPACK_IMPORTED_MODULE_1__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
this.concurrencyLimit = 1;
this.maxRunLimit = 1;
}
async bookParse() {
const bookUrl = document.location.href;
const bookId = document.querySelector("span.c-light-gray").innerText.replace("CP", "");
if (!bookId) {
throw new Error("获取bookID出错");
}
const novelGetInfoBaseUrl = "https://www.gongzicp.com/webapi/novel/novelGetInfo";
const novelGetInfoUrl = new URL(novelGetInfoBaseUrl);
novelGetInfoUrl.searchParams.set("id", bookId);
_log__WEBPACK_IMPORTED_MODULE_2___default().debug(`请求地址: ${novelGetInfoUrl.toString()}`);
const novelInfo = await fetch(novelGetInfoUrl.toString(), {
credentials: "include",
headers: {
Accept: "application/json, text/plain, */*",
Client: "pc",
Lang: "cn",
"Content-Type": "application/json;charset=utf-8",
},
referrer: bookUrl,
method: "GET",
mode: "cors",
})
.then((response) => response.json())
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_2___default().error(error));
if (novelInfo.code !== 200) {
throw new Error(`数据接口请求失败,URL:${novelGetInfoUrl.toString()}`);
}
const data = novelInfo.data;
const bookname = data.novelInfo.novel_name;
const author = data.novelInfo.author_nickname;
const introDom = document.createElement("div");
introDom.innerHTML = data.novelInfo.novel_info;
const [introduction, introductionHTML] = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_3__/* .introDomHandle */ .HV)(introDom);
const additionalMetadate = {};
const coverUrl = data.novelInfo.novel_cover;
if (coverUrl) {
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_4__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_2___default().error(error));
}
additionalMetadate.tags = data.novelInfo.tag_list;
async function isLogin() {
const getUserInfoUrl = "https://www.gongzicp.com/webapi/user/getUserInfo";
_log__WEBPACK_IMPORTED_MODULE_2___default().debug(`正在请求: ${getUserInfoUrl}`);
const userInfo = await fetch(getUserInfoUrl, {
headers: {
accept: "application/json, text/javascript, */*; q=0.01",
"x-requested-with": "XMLHttpRequest",
},
method: "GET",
mode: "cors",
credentials: "include",
})
.then((response) => response.json())
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_2___default().error(error));
return userInfo.code === 200;
}
const logined = await isLogin();
const chapters = [];
const _chapterList = data.chapterList;
let sectionNumber = 0;
let sectionName = null;
let sectionChapterNumber = 0;
for (const chapterObj of _chapterList) {
if (chapterObj.type === "volume") {
sectionNumber = chapterObj.vid;
sectionName = chapterObj.name;
sectionChapterNumber = 0;
}
else if (chapterObj.type === "item") {
const chapterUrl = [
document.location.origin,
`read-${chapterObj.id}.html`,
].join("/");
const chapterNumber = parseInt(chapterObj.order);
const chapterName = chapterObj.name;
const isVIP = chapterObj.pay;
const isPaid = chapterObj.is_sub;
const isLock = chapterObj.lock || chapterObj.chapter_status !== 1;
sectionChapterNumber++;
const chapterOption = {
novel_id: data.novelInfo.novel_id,
chapter_id: chapterObj.id,
};
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_5__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP,
isPaid,
sectionName,
sectionNumber,
sectionChapterNumber,
chapterParse: this.chapterParse,
charset: this.charset,
options: chapterOption,
});
if ((isVIP && !(logined && chapter.isPaid)) || isLock) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_6__/* .Status */ .nW.aborted;
}
chapters.push(chapter);
}
}
return new _main_Book__WEBPACK_IMPORTED_MODULE_7__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
function cpDecrypt(input) {
class CP {
iv;
key;
constructor(iv, key) {
iv += parseInt("165455", 14).toString(32);
this.iv = crypto_js__WEBPACK_IMPORTED_MODULE_0__.enc.Utf8.parse("$h$b3!" + iv);
key = atob(key) + parseInt("4d5a6c8", 14).toString(36);
this.key = crypto_js__WEBPACK_IMPORTED_MODULE_0__.enc.Utf8.parse(key + "A");
}
encrypt(input) {
if (typeof input === "string") {
const str = JSON.stringify(input);
const byte = crypto_js__WEBPACK_IMPORTED_MODULE_0__.enc.Utf8.parse(str);
return crypto_js__WEBPACK_IMPORTED_MODULE_0__.AES.encrypt(byte, this.key, {
mode: crypto_js__WEBPACK_IMPORTED_MODULE_0__.mode.CBC,
padding: crypto_js__WEBPACK_IMPORTED_MODULE_0__.pad.Pkcs7,
iv: this.iv,
});
}
}
decrypt(input) {
const byte = crypto_js__WEBPACK_IMPORTED_MODULE_0__.AES.decrypt(input, this.key, {
mode: crypto_js__WEBPACK_IMPORTED_MODULE_0__.mode.CBC,
padding: crypto_js__WEBPACK_IMPORTED_MODULE_0__.pad.Pkcs7,
iv: this.iv,
});
return crypto_js__WEBPACK_IMPORTED_MODULE_0__.enc.Utf8.stringify(byte).toString();
}
}
const cp = new CP("iGzsYn", "dTBMUnJidSRFbg==");
const content = cp.decrypt(input);
return content;
}
function randomWalker() {
_log__WEBPACK_IMPORTED_MODULE_2___default().info("[chapter]随机翻页中……");
if (document.location.pathname.includes("novel")) {
document.querySelector(".chapter-list .chapter a").click();
}
if (document.location.pathname.includes("read")) {
const rightMenu = document.querySelector(".right-menu");
if (rightMenu?.childElementCount === 6) {
document.querySelector(".right-menu > div:nth-child(3) > a:nth-child(1)").click();
}
else if (rightMenu?.childElementCount === 7) {
if (document.querySelector("div.content.unpaid")) {
document.querySelector(".right-menu > div:nth-child(3) > a:nth-child(1)").click();
}
else if (Math.random() < 0.3) {
document.querySelector(".right-menu > div:nth-child(3) > a:nth-child(1)").click();
}
else {
document.querySelector(".right-menu > div:nth-child(4) > a:nth-child(1)").click();
}
}
}
}
async function getChapter() {
const cid = options.chapter_id;
const chapterGetInfoBaseUrl = "https://www.gongzicp.com/webapi/novel/chapterGetInfo";
const chapterGetInfoUrl = new URL(chapterGetInfoBaseUrl);
chapterGetInfoUrl.searchParams.set("cid", cid.toString());
chapterGetInfoUrl.searchParams.set("server", "0");
let retryTime = 0;
async function getChapterInfo(url) {
_log__WEBPACK_IMPORTED_MODULE_2___default().debug(`请求地址: ${url}, Referrer: ${chapterUrl},retryTime:${retryTime}`);
const resultI = await fetch(url, {
credentials: "include",
headers: {
Accept: "application/json, text/plain, */*",
Client: "pc",
"Content-Type": "application/json",
},
referrer: chapterUrl,
method: "GET",
})
.then((resp) => resp.json())
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_2___default().error(error));
if (resultI.data.chapterInfo.content.length !== 0 &&
resultI.data.chapterInfo.content.length < 30) {
retryTime++;
if (retryTime > _setting__WEBPACK_IMPORTED_MODULE_8__/* .retryLimit */ .Iz) {
_log__WEBPACK_IMPORTED_MODULE_2___default().error(`请求 ${url} 失败`);
throw new Error(`请求 ${url} 失败`);
}
_log__WEBPACK_IMPORTED_MODULE_2___default().warn("[chapter]疑似被阻断,进行随机翻页……");
const walkerTime = Math.round(Math.random() * retryTime) + 1;
for (let i = 0; i < walkerTime; i++) {
await (0,_lib_misc__WEBPACK_IMPORTED_MODULE_9__/* .sleep */ .yy)(3000 + Math.round(Math.random() * 5000));
randomWalker();
}
await (0,_lib_misc__WEBPACK_IMPORTED_MODULE_9__/* .sleep */ .yy)(3000 + Math.round(Math.random() * 2000));
return getChapterInfo(url);
}
else {
retryTime = 0;
return resultI;
}
}
const result = await getChapterInfo(chapterGetInfoUrl.toString());
if (result.code === 200) {
const chapterInfo = result.data.chapterInfo;
if (chapterInfo.chapterPrice !== 0 &&
chapterInfo.content.length === 0) {
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
else if (chapterInfo.chapterPrice === 0 ||
(chapterInfo.chapterPrice !== 0 && chapterInfo.content.length !== 0)) {
const content = cpDecrypt(chapterInfo.content);
const contentRaw = document.createElement("pre");
contentRaw.innerHTML = content;
let contentText = content
.split("\n")
.map((p) => p.trim())
.join("\n\n");
let contentHTML;
const _contentHTML = document.createElement("div");
_contentHTML.innerHTML = content
.split("\n")
.map((p) => p.trim())
.map((p) => {
if (p.length === 0) {
return "<p><br/></p>";
}
else {
return `<p>${p}</p>`;
}
})
.join("\n");
if (chapterInfo.postscript === null || chapterInfo.postscript.length === 0) {
contentHTML = _contentHTML;
}
else {
contentHTML = document.createElement("div");
contentHTML.className = "main";
const hr = document.createElement("hr");
const authorSayDom = document.createElement("div");
authorSayDom.innerHTML = chapterInfo.postscript
.split("\n")
.map((p) => {
if (p.length === 0) {
return "<p><br/></p>";
}
else {
return `<p>${p}</p>`;
}
})
.join("\n");
contentHTML.appendChild(_contentHTML);
contentHTML.appendChild(hr);
contentHTML.appendChild(authorSayDom);
contentRaw.innerHTML = [
contentRaw.innerHTML,
"-".repeat(20),
chapterInfo.postscript,
].join("\n\n");
contentText = [
contentText,
"-".repeat(20),
chapterInfo.postscript,
].join("\n\n");
}
await (0,_lib_misc__WEBPACK_IMPORTED_MODULE_9__/* .sleep */ .yy)(3000 + Math.round(Math.random() * 5000));
return {
chapterName,
contentRaw,
contentText,
contentHTML,
contentImages: null,
additionalMetadate: null,
};
}
}
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
async function antiAntiCrawler() {
if (Math.random() < 0.2) {
randomWalker();
}
await (0,_lib_misc__WEBPACK_IMPORTED_MODULE_9__/* .sleep */ .yy)(3000 + Math.round(Math.random() * 4000));
}
async function publicChapter() {
await antiAntiCrawler();
return getChapter();
}
async function vipChapter() {
await antiAntiCrawler();
return getChapter();
}
if (isVIP) {
return vipChapter();
}
else {
return publicChapter();
}
}
}
/***/ }),
/***/ "./src/rules/special/original/hanwujinian.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Hanwujinian: () => (/* binding */ Hanwujinian)
/* harmony export */ });
/* harmony import */ var crypto_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("crypto-js");
/* harmony import */ var crypto_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(crypto_js__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_5__);
/* harmony import */ var _main_main__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/main/main.ts");
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/rules.ts");
class Hanwujinian extends _rules__WEBPACK_IMPORTED_MODULE_1__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
}
async bookParse() {
const bookUrl = document.location.href;
const anotherPageUrl = document.querySelector("a.titleText_3").href;
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_2__/* .getHtmlDOM */ .wA)(anotherPageUrl, this.charset);
const bookname = document.querySelector("span.titleText_1").innerText.trim();
const author = document.querySelector("span.authorText_1").innerText.trim();
const introDom = document.querySelector("#introtext");
const [introduction, introductionHTML] = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_3__/* .introDomHandle */ .HV)(introDom);
const coverUrl = document.querySelector(".wR_JSAS > img").src;
const additionalMetadate = {};
if (coverUrl) {
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_4__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_5___default().error(error));
}
additionalMetadate.tags = Array.from(document.querySelectorAll("div.labelBox_1 > span")).map((span) => span?.innerText.trim());
const chapters = [];
let chapterNumber = 0;
let sectionNumber = 0;
let sectionChapterNumber = 0;
let sectionName = null;
const signIn = document.querySelector("#userMeun") !== null;
const sections = doc.querySelectorAll('div.wR_JS > div.wR_JC[style*="margin: 30px auto;"]');
const divList = doc.querySelectorAll("div.wR_JS > div.wR_JC > div.wR_JSAC");
for (const divElem of Array.from(divList)) {
const aElem = divElem.querySelector("a");
const chapterName = aElem.innerText.trim();
const chapterUrl = aElem.href;
if (sections.length !== 0) {
const _sectionName = (0,_lib_rule__WEBPACK_IMPORTED_MODULE_3__/* .getSectionName */ .lq)(aElem, sections, (dom) => dom.innerText.trim());
if (_sectionName !== sectionName) {
sectionName = _sectionName;
sectionNumber++;
sectionChapterNumber = 0;
}
}
chapterNumber++;
sectionChapterNumber++;
const icon = divElem.querySelector("img");
const isVIP = icon !== null;
const isPaid = isVIP ? icon.src.includes("lock_2_off.png") : false;
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_6__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP,
isPaid,
sectionName,
sectionNumber,
sectionChapterNumber,
chapterParse: this.chapterParse,
charset: this.charset,
options: { bookname },
});
if (chapter.isVIP) {
if (signIn) {
if (chapter.isPaid === false) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_7__/* .Status */ .nW.aborted;
}
}
else {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_7__/* .Status */ .nW.aborted;
}
}
chapters.push(chapter);
}
const book = new _main_Book__WEBPACK_IMPORTED_MODULE_8__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
book.ToCUrl = anotherPageUrl;
return book;
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_2__/* .getHtmlDOM */ .wA)(chapterUrl, charset);
const script = Array.from(doc.querySelectorAll("script")).filter((s) => s.innerHTML.includes("var chapterContent"))?.[0];
const getContent = (CryptoJS, chapterContent) => {
function AesDecrypt(content) {
const keys = {
key: "2018122911430000",
iv: "048fe2a99140c0e6",
};
const key = CryptoJS.enc.Latin1.parse(keys.key);
const iv = CryptoJS.enc.Latin1.parse(keys.iv);
const d = CryptoJS.AES.decrypt(content, key, {
iv,
padding: CryptoJS.pad.ZeroPadding,
});
return d.toString(CryptoJS.enc.Utf8);
}
const text = decodeURI(AesDecrypt(chapterContent));
const div = document.createElement("div");
div.innerText = text;
return div;
};
if (script) {
const chapterContentLine = script.innerHTML
.split("\n")
.filter((l) => l.includes("var chapterContent"))?.[0];
const content = new Function("CryptoJS", `${chapterContentLine};return (${getContent.toString()})(CryptoJS, chapterContent);`)(crypto_js__WEBPACK_IMPORTED_MODULE_0__);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_9__/* .rm2 */ .Sf)(["更多优惠快去下载寒武纪年小说APP哦"], content);
content.innerHTML = content.innerHTML.replaceAll("%3A", ":");
content.innerHTML = content.innerHTML.replaceAll("++++【", "【");
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_10__/* .cleanDOM */ .an)(content, "TM");
return {
chapterName,
contentRaw: content,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: null,
};
}
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
}
/***/ }),
/***/ "./src/rules/special/original/iqingguo.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Iqingguo: () => (/* binding */ Iqingguo)
/* harmony export */ });
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/rules.ts");
/* harmony import */ var crypto_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("crypto-js");
/* harmony import */ var crypto_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(crypto_js__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_3__);
class Iqingguo extends _rules__WEBPACK_IMPORTED_MODULE_1__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.concurrencyLimit = 2;
this.attachmentMode = "TM";
}
async bookParse() {
const bookId = new URLSearchParams(document.location.search).get("id");
if (!bookId) {
throw new Error("无法找到 bookId!");
}
const bookPath = `/v1/books/${bookId}/cover`;
const catalogPath = `/v1/books/${bookId}/catalog`;
const bookData = (await get(bookPath))
.cover;
const catalogData = await get(catalogPath);
const bookUrl = document.location.href;
const bookname = bookData.name;
const author = bookData.user.author;
const introduction = bookData.description;
const introductionHTML = document.createElement("div");
introductionHTML.innerText = introduction;
const coverUrl = bookData.url;
const additionalMetadate = {
lastModified: bookData.latestModified,
tags: [bookData.genre, bookData.subGenre],
language: "zh",
ids: bookId,
};
if (coverUrl) {
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_2__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((img) => {
additionalMetadate.cover = img;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_3___default().error(error));
}
const chapters = catalogData.map((c) => {
const chapterUrl = "https://www.iqingguo.com/book/reading?" +
new URLSearchParams({ id: bookId, cid: c.id }).toString();
return new _main_Chapter__WEBPACK_IMPORTED_MODULE_4__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber: c.sn,
chapterName: c.name,
isVIP: false,
isPaid: false,
sectionName: null,
sectionNumber: null,
sectionChapterNumber: null,
chapterParse: this.chapterParse,
charset: this.charset,
options: {
bookId,
chapterId: c.id,
},
});
});
return new _main_Book__WEBPACK_IMPORTED_MODULE_5__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
const chapterPath = `/v1/chapters/${options.chapterId}`;
const data = await get(chapterPath);
chapterName = data.name;
const contentRaw = document.createElement("div");
contentRaw.innerText = data.content;
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_6__/* .cleanDOM */ .an)(contentRaw, "TM");
const additionalMetadate = {
lastModified: data.updateTime,
};
return {
chapterName,
contentRaw,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate,
};
}
}
function sign(path, params) {
params = params ?? {};
Object.assign(params, {
packageName: "com.iqingoo.reader.web",
t: Math.ceil(new Date().getTime() / 1e3),
});
const orderd = Object.keys(params)
.sort()
.reduce((obj, key) => {
obj[key] = params[key];
return obj;
}, {});
const l = path + "?" + new URLSearchParams(orderd).toString();
orderd.sign = crypto_js__WEBPACK_IMPORTED_MODULE_0__.MD5(decodeURI(l)).toString(crypto_js__WEBPACK_IMPORTED_MODULE_0__.enc.Hex);
return orderd;
}
async function get(path, params) {
const origin = "https://iqg-api.qingoo.cn";
const parm = sign(path, params);
const url = origin + path + "?" + new URLSearchParams(parm).toString();
const resp = await fetch(url, {
headers: {
accept: "application/json, text/plain, */*",
},
method: "GET",
mode: "cors",
credentials: "include",
});
const _data = (await resp.json());
if (_data.code !== 200) {
throw new Error("请求出错! " + url);
}
return _data.data;
}
/***/ }),
/***/ "./src/rules/special/original/jjwxc.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
// EXPORTS
__webpack_require__.d(__webpack_exports__, {
Jjwxc: () => (/* binding */ Jjwxc)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/generator/token-before.js
var token_before_namespaceObject = {};
__webpack_require__.r(token_before_namespaceObject);
__webpack_require__.d(token_before_namespaceObject, {
safe: () => (safe),
spec: () => (spec)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/lexer/units.js
var units_namespaceObject = {};
__webpack_require__.r(units_namespaceObject);
__webpack_require__.d(units_namespaceObject, {
angle: () => (angle),
decibel: () => (decibel),
flex: () => (flex),
frequency: () => (frequency),
length: () => (units_length),
resolution: () => (resolution),
semitones: () => (semitones),
time: () => (time)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/lexer/trace.js
var trace_namespaceObject = {};
__webpack_require__.r(trace_namespaceObject);
__webpack_require__.d(trace_namespaceObject, {
getTrace: () => (getTrace),
isKeyword: () => (isKeyword),
isProperty: () => (isProperty),
isType: () => (isType)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/AnPlusB.js
var AnPlusB_namespaceObject = {};
__webpack_require__.r(AnPlusB_namespaceObject);
__webpack_require__.d(AnPlusB_namespaceObject, {
generate: () => (AnPlusB_generate),
name: () => (AnPlusB_name),
parse: () => (AnPlusB_parse),
structure: () => (structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/Atrule.js
var Atrule_namespaceObject = {};
__webpack_require__.r(Atrule_namespaceObject);
__webpack_require__.d(Atrule_namespaceObject, {
generate: () => (Atrule_generate),
name: () => (Atrule_name),
parse: () => (Atrule_parse),
structure: () => (Atrule_structure),
walkContext: () => (walkContext)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/AtrulePrelude.js
var AtrulePrelude_namespaceObject = {};
__webpack_require__.r(AtrulePrelude_namespaceObject);
__webpack_require__.d(AtrulePrelude_namespaceObject, {
generate: () => (AtrulePrelude_generate),
name: () => (AtrulePrelude_name),
parse: () => (AtrulePrelude_parse),
structure: () => (AtrulePrelude_structure),
walkContext: () => (AtrulePrelude_walkContext)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/AttributeSelector.js
var AttributeSelector_namespaceObject = {};
__webpack_require__.r(AttributeSelector_namespaceObject);
__webpack_require__.d(AttributeSelector_namespaceObject, {
generate: () => (AttributeSelector_generate),
name: () => (AttributeSelector_name),
parse: () => (AttributeSelector_parse),
structure: () => (AttributeSelector_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/Block.js
var Block_namespaceObject = {};
__webpack_require__.r(Block_namespaceObject);
__webpack_require__.d(Block_namespaceObject, {
generate: () => (Block_generate),
name: () => (Block_name),
parse: () => (Block_parse),
structure: () => (Block_structure),
walkContext: () => (Block_walkContext)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/Brackets.js
var Brackets_namespaceObject = {};
__webpack_require__.r(Brackets_namespaceObject);
__webpack_require__.d(Brackets_namespaceObject, {
generate: () => (Brackets_generate),
name: () => (Brackets_name),
parse: () => (Brackets_parse),
structure: () => (Brackets_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/CDC.js
var CDC_namespaceObject = {};
__webpack_require__.r(CDC_namespaceObject);
__webpack_require__.d(CDC_namespaceObject, {
generate: () => (CDC_generate),
name: () => (CDC_name),
parse: () => (CDC_parse),
structure: () => (CDC_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/CDO.js
var CDO_namespaceObject = {};
__webpack_require__.r(CDO_namespaceObject);
__webpack_require__.d(CDO_namespaceObject, {
generate: () => (CDO_generate),
name: () => (CDO_name),
parse: () => (CDO_parse),
structure: () => (CDO_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/ClassSelector.js
var ClassSelector_namespaceObject = {};
__webpack_require__.r(ClassSelector_namespaceObject);
__webpack_require__.d(ClassSelector_namespaceObject, {
generate: () => (ClassSelector_generate),
name: () => (ClassSelector_name),
parse: () => (ClassSelector_parse),
structure: () => (ClassSelector_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/Combinator.js
var Combinator_namespaceObject = {};
__webpack_require__.r(Combinator_namespaceObject);
__webpack_require__.d(Combinator_namespaceObject, {
generate: () => (Combinator_generate),
name: () => (Combinator_name),
parse: () => (Combinator_parse),
structure: () => (Combinator_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/Comment.js
var Comment_namespaceObject = {};
__webpack_require__.r(Comment_namespaceObject);
__webpack_require__.d(Comment_namespaceObject, {
generate: () => (Comment_generate),
name: () => (Comment_name),
parse: () => (Comment_parse),
structure: () => (Comment_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/Declaration.js
var Declaration_namespaceObject = {};
__webpack_require__.r(Declaration_namespaceObject);
__webpack_require__.d(Declaration_namespaceObject, {
generate: () => (Declaration_generate),
name: () => (Declaration_name),
parse: () => (Declaration_parse),
structure: () => (Declaration_structure),
walkContext: () => (Declaration_walkContext)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/DeclarationList.js
var DeclarationList_namespaceObject = {};
__webpack_require__.r(DeclarationList_namespaceObject);
__webpack_require__.d(DeclarationList_namespaceObject, {
generate: () => (DeclarationList_generate),
name: () => (DeclarationList_name),
parse: () => (DeclarationList_parse),
structure: () => (DeclarationList_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/Dimension.js
var Dimension_namespaceObject = {};
__webpack_require__.r(Dimension_namespaceObject);
__webpack_require__.d(Dimension_namespaceObject, {
generate: () => (Dimension_generate),
name: () => (Dimension_name),
parse: () => (Dimension_parse),
structure: () => (Dimension_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/Function.js
var Function_namespaceObject = {};
__webpack_require__.r(Function_namespaceObject);
__webpack_require__.d(Function_namespaceObject, {
generate: () => (Function_generate),
name: () => (Function_name),
parse: () => (Function_parse),
structure: () => (Function_structure),
walkContext: () => (Function_walkContext)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/Hash.js
var Hash_namespaceObject = {};
__webpack_require__.r(Hash_namespaceObject);
__webpack_require__.d(Hash_namespaceObject, {
generate: () => (Hash_generate),
name: () => (Hash_name),
parse: () => (Hash_parse),
structure: () => (Hash_structure),
xxx: () => (xxx)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/Identifier.js
var Identifier_namespaceObject = {};
__webpack_require__.r(Identifier_namespaceObject);
__webpack_require__.d(Identifier_namespaceObject, {
generate: () => (Identifier_generate),
name: () => (Identifier_name),
parse: () => (Identifier_parse),
structure: () => (Identifier_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/IdSelector.js
var IdSelector_namespaceObject = {};
__webpack_require__.r(IdSelector_namespaceObject);
__webpack_require__.d(IdSelector_namespaceObject, {
generate: () => (IdSelector_generate),
name: () => (IdSelector_name),
parse: () => (IdSelector_parse),
structure: () => (IdSelector_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/MediaFeature.js
var MediaFeature_namespaceObject = {};
__webpack_require__.r(MediaFeature_namespaceObject);
__webpack_require__.d(MediaFeature_namespaceObject, {
generate: () => (MediaFeature_generate),
name: () => (MediaFeature_name),
parse: () => (MediaFeature_parse),
structure: () => (MediaFeature_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/MediaQuery.js
var MediaQuery_namespaceObject = {};
__webpack_require__.r(MediaQuery_namespaceObject);
__webpack_require__.d(MediaQuery_namespaceObject, {
generate: () => (MediaQuery_generate),
name: () => (MediaQuery_name),
parse: () => (MediaQuery_parse),
structure: () => (MediaQuery_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/MediaQueryList.js
var MediaQueryList_namespaceObject = {};
__webpack_require__.r(MediaQueryList_namespaceObject);
__webpack_require__.d(MediaQueryList_namespaceObject, {
generate: () => (MediaQueryList_generate),
name: () => (MediaQueryList_name),
parse: () => (MediaQueryList_parse),
structure: () => (MediaQueryList_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/NestingSelector.js
var NestingSelector_namespaceObject = {};
__webpack_require__.r(NestingSelector_namespaceObject);
__webpack_require__.d(NestingSelector_namespaceObject, {
generate: () => (NestingSelector_generate),
name: () => (NestingSelector_name),
parse: () => (NestingSelector_parse),
structure: () => (NestingSelector_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/Nth.js
var Nth_namespaceObject = {};
__webpack_require__.r(Nth_namespaceObject);
__webpack_require__.d(Nth_namespaceObject, {
generate: () => (Nth_generate),
name: () => (Nth_name),
parse: () => (Nth_parse),
structure: () => (Nth_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/Number.js
var Number_namespaceObject = {};
__webpack_require__.r(Number_namespaceObject);
__webpack_require__.d(Number_namespaceObject, {
generate: () => (Number_generate),
name: () => (Number_name),
parse: () => (Number_parse),
structure: () => (Number_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/Operator.js
var Operator_namespaceObject = {};
__webpack_require__.r(Operator_namespaceObject);
__webpack_require__.d(Operator_namespaceObject, {
generate: () => (Operator_generate),
name: () => (Operator_name),
parse: () => (Operator_parse),
structure: () => (Operator_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/Parentheses.js
var Parentheses_namespaceObject = {};
__webpack_require__.r(Parentheses_namespaceObject);
__webpack_require__.d(Parentheses_namespaceObject, {
generate: () => (Parentheses_generate),
name: () => (Parentheses_name),
parse: () => (Parentheses_parse),
structure: () => (Parentheses_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/Percentage.js
var Percentage_namespaceObject = {};
__webpack_require__.r(Percentage_namespaceObject);
__webpack_require__.d(Percentage_namespaceObject, {
generate: () => (Percentage_generate),
name: () => (Percentage_name),
parse: () => (Percentage_parse),
structure: () => (Percentage_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/PseudoClassSelector.js
var PseudoClassSelector_namespaceObject = {};
__webpack_require__.r(PseudoClassSelector_namespaceObject);
__webpack_require__.d(PseudoClassSelector_namespaceObject, {
generate: () => (PseudoClassSelector_generate),
name: () => (PseudoClassSelector_name),
parse: () => (PseudoClassSelector_parse),
structure: () => (PseudoClassSelector_structure),
walkContext: () => (PseudoClassSelector_walkContext)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/PseudoElementSelector.js
var PseudoElementSelector_namespaceObject = {};
__webpack_require__.r(PseudoElementSelector_namespaceObject);
__webpack_require__.d(PseudoElementSelector_namespaceObject, {
generate: () => (PseudoElementSelector_generate),
name: () => (PseudoElementSelector_name),
parse: () => (PseudoElementSelector_parse),
structure: () => (PseudoElementSelector_structure),
walkContext: () => (PseudoElementSelector_walkContext)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/Ratio.js
var Ratio_namespaceObject = {};
__webpack_require__.r(Ratio_namespaceObject);
__webpack_require__.d(Ratio_namespaceObject, {
generate: () => (Ratio_generate),
name: () => (Ratio_name),
parse: () => (Ratio_parse),
structure: () => (Ratio_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/Raw.js
var Raw_namespaceObject = {};
__webpack_require__.r(Raw_namespaceObject);
__webpack_require__.d(Raw_namespaceObject, {
generate: () => (Raw_generate),
name: () => (Raw_name),
parse: () => (Raw_parse),
structure: () => (Raw_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/Rule.js
var Rule_namespaceObject = {};
__webpack_require__.r(Rule_namespaceObject);
__webpack_require__.d(Rule_namespaceObject, {
generate: () => (Rule_generate),
name: () => (Rule_name),
parse: () => (Rule_parse),
structure: () => (Rule_structure),
walkContext: () => (Rule_walkContext)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/Selector.js
var Selector_namespaceObject = {};
__webpack_require__.r(Selector_namespaceObject);
__webpack_require__.d(Selector_namespaceObject, {
generate: () => (Selector_generate),
name: () => (Selector_name),
parse: () => (Selector_parse),
structure: () => (Selector_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/SelectorList.js
var SelectorList_namespaceObject = {};
__webpack_require__.r(SelectorList_namespaceObject);
__webpack_require__.d(SelectorList_namespaceObject, {
generate: () => (SelectorList_generate),
name: () => (SelectorList_name),
parse: () => (SelectorList_parse),
structure: () => (SelectorList_structure),
walkContext: () => (SelectorList_walkContext)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/String.js
var String_namespaceObject = {};
__webpack_require__.r(String_namespaceObject);
__webpack_require__.d(String_namespaceObject, {
generate: () => (String_generate),
name: () => (String_name),
parse: () => (String_parse),
structure: () => (String_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/StyleSheet.js
var StyleSheet_namespaceObject = {};
__webpack_require__.r(StyleSheet_namespaceObject);
__webpack_require__.d(StyleSheet_namespaceObject, {
generate: () => (StyleSheet_generate),
name: () => (StyleSheet_name),
parse: () => (StyleSheet_parse),
structure: () => (StyleSheet_structure),
walkContext: () => (StyleSheet_walkContext)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/TypeSelector.js
var TypeSelector_namespaceObject = {};
__webpack_require__.r(TypeSelector_namespaceObject);
__webpack_require__.d(TypeSelector_namespaceObject, {
generate: () => (TypeSelector_generate),
name: () => (TypeSelector_name),
parse: () => (TypeSelector_parse),
structure: () => (TypeSelector_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/UnicodeRange.js
var UnicodeRange_namespaceObject = {};
__webpack_require__.r(UnicodeRange_namespaceObject);
__webpack_require__.d(UnicodeRange_namespaceObject, {
generate: () => (UnicodeRange_generate),
name: () => (UnicodeRange_name),
parse: () => (UnicodeRange_parse),
structure: () => (UnicodeRange_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/Url.js
var Url_namespaceObject = {};
__webpack_require__.r(Url_namespaceObject);
__webpack_require__.d(Url_namespaceObject, {
generate: () => (Url_generate),
name: () => (Url_name),
parse: () => (Url_parse),
structure: () => (Url_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/Value.js
var Value_namespaceObject = {};
__webpack_require__.r(Value_namespaceObject);
__webpack_require__.d(Value_namespaceObject, {
generate: () => (Value_generate),
name: () => (Value_name),
parse: () => (Value_parse),
structure: () => (Value_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/WhiteSpace.js
var WhiteSpace_namespaceObject = {};
__webpack_require__.r(WhiteSpace_namespaceObject);
__webpack_require__.d(WhiteSpace_namespaceObject, {
generate: () => (WhiteSpace_generate),
name: () => (WhiteSpace_name),
parse: () => (WhiteSpace_parse),
structure: () => (WhiteSpace_structure)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/index.js
var node_namespaceObject = {};
__webpack_require__.r(node_namespaceObject);
__webpack_require__.d(node_namespaceObject, {
AnPlusB: () => (AnPlusB_namespaceObject),
Atrule: () => (Atrule_namespaceObject),
AtrulePrelude: () => (AtrulePrelude_namespaceObject),
AttributeSelector: () => (AttributeSelector_namespaceObject),
Block: () => (Block_namespaceObject),
Brackets: () => (Brackets_namespaceObject),
CDC: () => (CDC_namespaceObject),
CDO: () => (CDO_namespaceObject),
ClassSelector: () => (ClassSelector_namespaceObject),
Combinator: () => (Combinator_namespaceObject),
Comment: () => (Comment_namespaceObject),
Declaration: () => (Declaration_namespaceObject),
DeclarationList: () => (DeclarationList_namespaceObject),
Dimension: () => (Dimension_namespaceObject),
Function: () => (Function_namespaceObject),
Hash: () => (Hash_namespaceObject),
IdSelector: () => (IdSelector_namespaceObject),
Identifier: () => (Identifier_namespaceObject),
MediaFeature: () => (MediaFeature_namespaceObject),
MediaQuery: () => (MediaQuery_namespaceObject),
MediaQueryList: () => (MediaQueryList_namespaceObject),
NestingSelector: () => (NestingSelector_namespaceObject),
Nth: () => (Nth_namespaceObject),
Number: () => (Number_namespaceObject),
Operator: () => (Operator_namespaceObject),
Parentheses: () => (Parentheses_namespaceObject),
Percentage: () => (Percentage_namespaceObject),
PseudoClassSelector: () => (PseudoClassSelector_namespaceObject),
PseudoElementSelector: () => (PseudoElementSelector_namespaceObject),
Ratio: () => (Ratio_namespaceObject),
Raw: () => (Raw_namespaceObject),
Rule: () => (Rule_namespaceObject),
Selector: () => (Selector_namespaceObject),
SelectorList: () => (SelectorList_namespaceObject),
String: () => (String_namespaceObject),
StyleSheet: () => (StyleSheet_namespaceObject),
TypeSelector: () => (TypeSelector_namespaceObject),
UnicodeRange: () => (UnicodeRange_namespaceObject),
Url: () => (Url_namespaceObject),
Value: () => (Value_namespaceObject),
WhiteSpace: () => (WhiteSpace_namespaceObject)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/scope/index.js
var scope_namespaceObject = {};
__webpack_require__.r(scope_namespaceObject);
__webpack_require__.d(scope_namespaceObject, {
AtrulePrelude: () => (atrulePrelude),
Selector: () => (selector),
Value: () => (value)
});
// NAMESPACE OBJECT: ./node_modules/css-tree/lib/syntax/node/index-parse.js
var index_parse_namespaceObject = {};
__webpack_require__.r(index_parse_namespaceObject);
__webpack_require__.d(index_parse_namespaceObject, {
AnPlusB: () => (AnPlusB_parse),
Atrule: () => (Atrule_parse),
AtrulePrelude: () => (AtrulePrelude_parse),
AttributeSelector: () => (AttributeSelector_parse),
Block: () => (Block_parse),
Brackets: () => (Brackets_parse),
CDC: () => (CDC_parse),
CDO: () => (CDO_parse),
ClassSelector: () => (ClassSelector_parse),
Combinator: () => (Combinator_parse),
Comment: () => (Comment_parse),
Declaration: () => (Declaration_parse),
DeclarationList: () => (DeclarationList_parse),
Dimension: () => (Dimension_parse),
Function: () => (Function_parse),
Hash: () => (Hash_parse),
IdSelector: () => (IdSelector_parse),
Identifier: () => (Identifier_parse),
MediaFeature: () => (MediaFeature_parse),
MediaQuery: () => (MediaQuery_parse),
MediaQueryList: () => (MediaQueryList_parse),
NestingSelector: () => (NestingSelector_parse),
Nth: () => (Nth_parse),
Number: () => (Number_parse),
Operator: () => (Operator_parse),
Parentheses: () => (Parentheses_parse),
Percentage: () => (Percentage_parse),
PseudoClassSelector: () => (PseudoClassSelector_parse),
PseudoElementSelector: () => (PseudoElementSelector_parse),
Ratio: () => (Ratio_parse),
Raw: () => (Raw_parse),
Rule: () => (Rule_parse),
Selector: () => (Selector_parse),
SelectorList: () => (SelectorList_parse),
String: () => (String_parse),
StyleSheet: () => (StyleSheet_parse),
TypeSelector: () => (TypeSelector_parse),
UnicodeRange: () => (UnicodeRange_parse),
Url: () => (Url_parse),
Value: () => (Value_parse),
WhiteSpace: () => (WhiteSpace_parse)
});
// EXTERNAL MODULE: ./src/lib/attachments.ts
var attachments = __webpack_require__("./src/lib/attachments.ts");
// EXTERNAL MODULE: ./src/lib/cleanDOM.ts
var cleanDOM = __webpack_require__("./src/lib/cleanDOM.ts");
// EXTERNAL MODULE: ./src/lib/http.ts
var http = __webpack_require__("./src/lib/http.ts");
// EXTERNAL MODULE: ./src/lib/misc.ts
var misc = __webpack_require__("./src/lib/misc.ts");
// EXTERNAL MODULE: ./src/lib/dom.ts
var lib_dom = __webpack_require__("./src/lib/dom.ts");
// EXTERNAL MODULE: ./src/lib/rule.ts
var rule = __webpack_require__("./src/lib/rule.ts");
// EXTERNAL MODULE: ./node_modules/loglevel/lib/loglevel.js
var loglevel = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
var loglevel_default = /*#__PURE__*/__webpack_require__.n(loglevel);
// EXTERNAL MODULE: ./src/main/main.ts
var main = __webpack_require__("./src/main/main.ts");
// EXTERNAL MODULE: ./src/main/Attachment.ts
var Attachment = __webpack_require__("./src/main/Attachment.ts");
// EXTERNAL MODULE: ./src/main/Chapter.ts
var Chapter = __webpack_require__("./src/main/Chapter.ts");
// EXTERNAL MODULE: ./src/main/Book.ts + 1 modules
var Book = __webpack_require__("./src/main/Book.ts");
// EXTERNAL MODULE: ./src/rules.ts + 12 modules
var rules = __webpack_require__("./src/rules.ts");
// EXTERNAL MODULE: ./src/setting.ts
var setting = __webpack_require__("./src/setting.ts");
;// ./src/rules/lib/jjwxcFontDecode.ts
async function replaceJjwxcCharacter(fontName, inputText) {
let outputText = inputText;
const jjwxcFontTable = await getJjwxcFontTable(fontName);
if (jjwxcFontTable) {
for (const jjwxcCharacter in jjwxcFontTable) {
if (Object.prototype.hasOwnProperty.call(jjwxcFontTable, jjwxcCharacter)) {
const normalCharacter = jjwxcFontTable[jjwxcCharacter];
outputText = outputText.replaceAll(jjwxcCharacter, normalCharacter);
}
}
outputText = outputText.replace(/\u200c/g, "");
}
return outputText;
}
async function getJjwxcFontTable(fontName) {
const jjwxcFontTableLocal = false;
if (jjwxcFontTableLocal) {
return jjwxcFontTableLocal;
}
else if (setting/* enableJjwxcRemoteFont */.ts) {
return await fetchRemoteFont(fontName);
}
else {
return undefined;
}
}
async function fetchRemoteFont(fontName) {
const url = `https://jjwxc.bgme.bid/api/${fontName}/table`;
loglevel_default().info(`[jjwxc-font]开始请求远程字体对照表 ${fontName}`);
let retry = setting/* retryLimit */.Iz;
while (retry > 0) {
let resp;
try {
resp = await fetch(url);
}
catch (error) {
loglevel_default().error(error);
retry--;
if (retry > 0) {
await (0,misc/* sleep */.yy)(5000);
continue;
}
else {
loglevel_default().info(`[jjwxc-font]远程字体对照表 ${fontName} 下载失败`);
return undefined;
}
}
if (resp.ok) {
loglevel_default().info(`[jjwxc-font]远程字体对照表 ${fontName} 下载成功`);
return (await resp.json());
}
else {
retry--;
if (retry > 0) {
await (0,misc/* sleep */.yy)(5000);
}
else {
loglevel_default().info(`[jjwxc-font]远程字体对照表 ${fontName} 下载失败`);
return undefined;
}
}
}
}
// EXTERNAL MODULE: ./src/lib/GM.ts
var GM = __webpack_require__("./src/lib/GM.ts");
;// ./node_modules/css-tree/lib/tokenizer/types.js
// CSS Syntax Module Level 3
// https://www.w3.org/TR/css-syntax-3/
const EOF = 0; // <EOF-token>
const Ident = 1; // <ident-token>
const Function = 2; // <function-token>
const AtKeyword = 3; // <at-keyword-token>
const Hash = 4; // <hash-token>
const types_String = 5; // <string-token>
const BadString = 6; // <bad-string-token>
const Url = 7; // <url-token>
const BadUrl = 8; // <bad-url-token>
const Delim = 9; // <delim-token>
const types_Number = 10; // <number-token>
const Percentage = 11; // <percentage-token>
const Dimension = 12; // <dimension-token>
const WhiteSpace = 13; // <whitespace-token>
const CDO = 14; // <CDO-token>
const CDC = 15; // <CDC-token>
const Colon = 16; // <colon-token> :
const Semicolon = 17; // <semicolon-token> ;
const Comma = 18; // <comma-token> ,
const LeftSquareBracket = 19; // <[-token>
const RightSquareBracket = 20; // <]-token>
const LeftParenthesis = 21; // <(-token>
const RightParenthesis = 22; // <)-token>
const LeftCurlyBracket = 23; // <{-token>
const RightCurlyBracket = 24; // <}-token>
const Comment = 25;
;// ./node_modules/css-tree/lib/tokenizer/char-code-definitions.js
const char_code_definitions_EOF = 0;
// https://drafts.csswg.org/css-syntax-3/
// § 4.2. Definitions
// digit
// A code point between U+0030 DIGIT ZERO (0) and U+0039 DIGIT NINE (9).
function isDigit(code) {
return code >= 0x0030 && code <= 0x0039;
}
// hex digit
// A digit, or a code point between U+0041 LATIN CAPITAL LETTER A (A) and U+0046 LATIN CAPITAL LETTER F (F),
// or a code point between U+0061 LATIN SMALL LETTER A (a) and U+0066 LATIN SMALL LETTER F (f).
function isHexDigit(code) {
return (
isDigit(code) || // 0 .. 9
(code >= 0x0041 && code <= 0x0046) || // A .. F
(code >= 0x0061 && code <= 0x0066) // a .. f
);
}
// uppercase letter
// A code point between U+0041 LATIN CAPITAL LETTER A (A) and U+005A LATIN CAPITAL LETTER Z (Z).
function isUppercaseLetter(code) {
return code >= 0x0041 && code <= 0x005A;
}
// lowercase letter
// A code point between U+0061 LATIN SMALL LETTER A (a) and U+007A LATIN SMALL LETTER Z (z).
function isLowercaseLetter(code) {
return code >= 0x0061 && code <= 0x007A;
}
// letter
// An uppercase letter or a lowercase letter.
function isLetter(code) {
return isUppercaseLetter(code) || isLowercaseLetter(code);
}
// non-ASCII code point
// A code point with a value equal to or greater than U+0080 <control>.
function isNonAscii(code) {
return code >= 0x0080;
}
// name-start code point
// A letter, a non-ASCII code point, or U+005F LOW LINE (_).
function isNameStart(code) {
return isLetter(code) || isNonAscii(code) || code === 0x005F;
}
// name code point
// A name-start code point, a digit, or U+002D HYPHEN-MINUS (-).
function char_code_definitions_isName(code) {
return isNameStart(code) || isDigit(code) || code === 0x002D;
}
// non-printable code point
// A code point between U+0000 NULL and U+0008 BACKSPACE, or U+000B LINE TABULATION,
// or a code point between U+000E SHIFT OUT and U+001F INFORMATION SEPARATOR ONE, or U+007F DELETE.
function isNonPrintable(code) {
return (
(code >= 0x0000 && code <= 0x0008) ||
(code === 0x000B) ||
(code >= 0x000E && code <= 0x001F) ||
(code === 0x007F)
);
}
// newline
// U+000A LINE FEED. Note that U+000D CARRIAGE RETURN and U+000C FORM FEED are not included in this definition,
// as they are converted to U+000A LINE FEED during preprocessing.
// TODO: we doesn't do a preprocessing, so check a code point for U+000D CARRIAGE RETURN and U+000C FORM FEED
function isNewline(code) {
return code === 0x000A || code === 0x000D || code === 0x000C;
}
// whitespace
// A newline, U+0009 CHARACTER TABULATION, or U+0020 SPACE.
function isWhiteSpace(code) {
return isNewline(code) || code === 0x0020 || code === 0x0009;
}
// § 4.3.8. Check if two code points are a valid escape
function char_code_definitions_isValidEscape(first, second) {
// If the first code point is not U+005C REVERSE SOLIDUS (\), return false.
if (first !== 0x005C) {
return false;
}
// Otherwise, if the second code point is a newline or EOF, return false.
if (isNewline(second) || second === char_code_definitions_EOF) {
return false;
}
// Otherwise, return true.
return true;
}
// § 4.3.9. Check if three code points would start an identifier
function isIdentifierStart(first, second, third) {
// Look at the first code point:
// U+002D HYPHEN-MINUS
if (first === 0x002D) {
// If the second code point is a name-start code point or a U+002D HYPHEN-MINUS,
// or the second and third code points are a valid escape, return true. Otherwise, return false.
return (
isNameStart(second) ||
second === 0x002D ||
char_code_definitions_isValidEscape(second, third)
);
}
// name-start code point
if (isNameStart(first)) {
// Return true.
return true;
}
// U+005C REVERSE SOLIDUS (\)
if (first === 0x005C) {
// If the first and second code points are a valid escape, return true. Otherwise, return false.
return char_code_definitions_isValidEscape(first, second);
}
// anything else
// Return false.
return false;
}
// § 4.3.10. Check if three code points would start a number
function isNumberStart(first, second, third) {
// Look at the first code point:
// U+002B PLUS SIGN (+)
// U+002D HYPHEN-MINUS (-)
if (first === 0x002B || first === 0x002D) {
// If the second code point is a digit, return true.
if (isDigit(second)) {
return 2;
}
// Otherwise, if the second code point is a U+002E FULL STOP (.)
// and the third code point is a digit, return true.
// Otherwise, return false.
return second === 0x002E && isDigit(third) ? 3 : 0;
}
// U+002E FULL STOP (.)
if (first === 0x002E) {
// If the second code point is a digit, return true. Otherwise, return false.
return isDigit(second) ? 2 : 0;
}
// digit
if (isDigit(first)) {
// Return true.
return 1;
}
// anything else
// Return false.
return 0;
}
//
// Misc
//
// detect BOM (https://en.wikipedia.org/wiki/Byte_order_mark)
function isBOM(code) {
// UTF-16BE
if (code === 0xFEFF) {
return 1;
}
// UTF-16LE
if (code === 0xFFFE) {
return 1;
}
return 0;
}
// Fast code category
// Only ASCII code points has a special meaning, that's why we define a maps for 0..127 codes only
const CATEGORY = new Array(0x80);
const EofCategory = 0x80;
const WhiteSpaceCategory = 0x82;
const DigitCategory = 0x83;
const NameStartCategory = 0x84;
const NonPrintableCategory = 0x85;
for (let i = 0; i < CATEGORY.length; i++) {
CATEGORY[i] =
isWhiteSpace(i) && WhiteSpaceCategory ||
isDigit(i) && DigitCategory ||
isNameStart(i) && NameStartCategory ||
isNonPrintable(i) && NonPrintableCategory ||
i || EofCategory;
}
function charCodeCategory(code) {
return code < 0x80 ? CATEGORY[code] : NameStartCategory;
}
;// ./node_modules/css-tree/lib/tokenizer/utils.js
function getCharCode(source, offset) {
return offset < source.length ? source.charCodeAt(offset) : 0;
}
function getNewlineLength(source, offset, code) {
if (code === 13 /* \r */ && getCharCode(source, offset + 1) === 10 /* \n */) {
return 2;
}
return 1;
}
function cmpChar(testStr, offset, referenceCode) {
let code = testStr.charCodeAt(offset);
// code.toLowerCase() for A..Z
if (isUppercaseLetter(code)) {
code = code | 32;
}
return code === referenceCode;
}
function cmpStr(testStr, start, end, referenceStr) {
if (end - start !== referenceStr.length) {
return false;
}
if (start < 0 || end > testStr.length) {
return false;
}
for (let i = start; i < end; i++) {
const referenceCode = referenceStr.charCodeAt(i - start);
let testCode = testStr.charCodeAt(i);
// testCode.toLowerCase() for A..Z
if (isUppercaseLetter(testCode)) {
testCode = testCode | 32;
}
if (testCode !== referenceCode) {
return false;
}
}
return true;
}
function findWhiteSpaceStart(source, offset) {
for (; offset >= 0; offset--) {
if (!isWhiteSpace(source.charCodeAt(offset))) {
break;
}
}
return offset + 1;
}
function findWhiteSpaceEnd(source, offset) {
for (; offset < source.length; offset++) {
if (!isWhiteSpace(source.charCodeAt(offset))) {
break;
}
}
return offset;
}
function findDecimalNumberEnd(source, offset) {
for (; offset < source.length; offset++) {
if (!isDigit(source.charCodeAt(offset))) {
break;
}
}
return offset;
}
// § 4.3.7. Consume an escaped code point
function utils_consumeEscaped(source, offset) {
// It assumes that the U+005C REVERSE SOLIDUS (\) has already been consumed and
// that the next input code point has already been verified to be part of a valid escape.
offset += 2;
// hex digit
if (isHexDigit(getCharCode(source, offset - 1))) {
// Consume as many hex digits as possible, but no more than 5.
// Note that this means 1-6 hex digits have been consumed in total.
for (const maxOffset = Math.min(source.length, offset + 5); offset < maxOffset; offset++) {
if (!isHexDigit(getCharCode(source, offset))) {
break;
}
}
// If the next input code point is whitespace, consume it as well.
const code = getCharCode(source, offset);
if (isWhiteSpace(code)) {
offset += getNewlineLength(source, offset, code);
}
}
return offset;
}
// §4.3.11. Consume a name
// Note: This algorithm does not do the verification of the first few code points that are necessary
// to ensure the returned code points would constitute an <ident-token>. If that is the intended use,
// ensure that the stream starts with an identifier before calling this algorithm.
function consumeName(source, offset) {
// Let result initially be an empty string.
// Repeatedly consume the next input code point from the stream:
for (; offset < source.length; offset++) {
const code = source.charCodeAt(offset);
// name code point
if (char_code_definitions_isName(code)) {
// Append the code point to result.
continue;
}
// the stream starts with a valid escape
if (char_code_definitions_isValidEscape(code, getCharCode(source, offset + 1))) {
// Consume an escaped code point. Append the returned code point to result.
offset = utils_consumeEscaped(source, offset) - 1;
continue;
}
// anything else
// Reconsume the current input code point. Return result.
break;
}
return offset;
}
// §4.3.12. Consume a number
function consumeNumber(source, offset) {
let code = source.charCodeAt(offset);
// 2. If the next input code point is U+002B PLUS SIGN (+) or U+002D HYPHEN-MINUS (-),
// consume it and append it to repr.
if (code === 0x002B || code === 0x002D) {
code = source.charCodeAt(offset += 1);
}
// 3. While the next input code point is a digit, consume it and append it to repr.
if (isDigit(code)) {
offset = findDecimalNumberEnd(source, offset + 1);
code = source.charCodeAt(offset);
}
// 4. If the next 2 input code points are U+002E FULL STOP (.) followed by a digit, then:
if (code === 0x002E && isDigit(source.charCodeAt(offset + 1))) {
// 4.1 Consume them.
// 4.2 Append them to repr.
offset += 2;
// 4.3 Set type to "number".
// TODO
// 4.4 While the next input code point is a digit, consume it and append it to repr.
offset = findDecimalNumberEnd(source, offset);
}
// 5. If the next 2 or 3 input code points are U+0045 LATIN CAPITAL LETTER E (E)
// or U+0065 LATIN SMALL LETTER E (e), ... , followed by a digit, then:
if (cmpChar(source, offset, 101 /* e */)) {
let sign = 0;
code = source.charCodeAt(offset + 1);
// ... optionally followed by U+002D HYPHEN-MINUS (-) or U+002B PLUS SIGN (+) ...
if (code === 0x002D || code === 0x002B) {
sign = 1;
code = source.charCodeAt(offset + 2);
}
// ... followed by a digit
if (isDigit(code)) {
// 5.1 Consume them.
// 5.2 Append them to repr.
// 5.3 Set type to "number".
// TODO
// 5.4 While the next input code point is a digit, consume it and append it to repr.
offset = findDecimalNumberEnd(source, offset + 1 + sign + 1);
}
}
return offset;
}
// § 4.3.14. Consume the remnants of a bad url
// ... its sole use is to consume enough of the input stream to reach a recovery point
// where normal tokenizing can resume.
function consumeBadUrlRemnants(source, offset) {
// Repeatedly consume the next input code point from the stream:
for (; offset < source.length; offset++) {
const code = source.charCodeAt(offset);
// U+0029 RIGHT PARENTHESIS ())
// EOF
if (code === 0x0029) {
// Return.
offset++;
break;
}
if (char_code_definitions_isValidEscape(code, getCharCode(source, offset + 1))) {
// Consume an escaped code point.
// Note: This allows an escaped right parenthesis ("\)") to be encountered
// without ending the <bad-url-token>. This is otherwise identical to
// the "anything else" clause.
offset = utils_consumeEscaped(source, offset);
}
}
return offset;
}
// § 4.3.7. Consume an escaped code point
// Note: This algorithm assumes that escaped is valid without leading U+005C REVERSE SOLIDUS (\)
function utils_decodeEscaped(escaped) {
// Single char escaped that's not a hex digit
if (escaped.length === 1 && !isHexDigit(escaped.charCodeAt(0))) {
return escaped[0];
}
// Interpret the hex digits as a hexadecimal number.
let code = parseInt(escaped, 16);
if (
(code === 0) || // If this number is zero,
(code >= 0xD800 && code <= 0xDFFF) || // or is for a surrogate,
(code > 0x10FFFF) // or is greater than the maximum allowed code point
) {
// ... return U+FFFD REPLACEMENT CHARACTER
code = 0xFFFD;
}
// Otherwise, return the code point with that value.
return String.fromCodePoint(code);
}
;// ./node_modules/css-tree/lib/tokenizer/names.js
/* harmony default export */ const names = ([
'EOF-token',
'ident-token',
'function-token',
'at-keyword-token',
'hash-token',
'string-token',
'bad-string-token',
'url-token',
'bad-url-token',
'delim-token',
'number-token',
'percentage-token',
'dimension-token',
'whitespace-token',
'CDO-token',
'CDC-token',
'colon-token',
'semicolon-token',
'comma-token',
'[-token',
']-token',
'(-token',
')-token',
'{-token',
'}-token'
]);
;// ./node_modules/css-tree/lib/tokenizer/adopt-buffer.js
const MIN_SIZE = 16 * 1024;
function adoptBuffer(buffer = null, size) {
if (buffer === null || buffer.length < size) {
return new Uint32Array(Math.max(size + 1024, MIN_SIZE));
}
return buffer;
};
;// ./node_modules/css-tree/lib/tokenizer/OffsetToLocation.js
const N = 10;
const F = 12;
const R = 13;
function computeLinesAndColumns(host) {
const source = host.source;
const sourceLength = source.length;
const startOffset = source.length > 0 ? isBOM(source.charCodeAt(0)) : 0;
const lines = adoptBuffer(host.lines, sourceLength);
const columns = adoptBuffer(host.columns, sourceLength);
let line = host.startLine;
let column = host.startColumn;
for (let i = startOffset; i < sourceLength; i++) {
const code = source.charCodeAt(i);
lines[i] = line;
columns[i] = column++;
if (code === N || code === R || code === F) {
if (code === R && i + 1 < sourceLength && source.charCodeAt(i + 1) === N) {
i++;
lines[i] = line;
columns[i] = column;
}
line++;
column = 1;
}
}
lines[sourceLength] = line;
columns[sourceLength] = column;
host.lines = lines;
host.columns = columns;
host.computed = true;
}
class OffsetToLocation {
constructor() {
this.lines = null;
this.columns = null;
this.computed = false;
}
setSource(source, startOffset = 0, startLine = 1, startColumn = 1) {
this.source = source;
this.startOffset = startOffset;
this.startLine = startLine;
this.startColumn = startColumn;
this.computed = false;
}
getLocation(offset, filename) {
if (!this.computed) {
computeLinesAndColumns(this);
}
return {
source: filename,
offset: this.startOffset + offset,
line: this.lines[offset],
column: this.columns[offset]
};
}
getLocationRange(start, end, filename) {
if (!this.computed) {
computeLinesAndColumns(this);
}
return {
source: filename,
start: {
offset: this.startOffset + start,
line: this.lines[start],
column: this.columns[start]
},
end: {
offset: this.startOffset + end,
line: this.lines[end],
column: this.columns[end]
}
};
}
};
;// ./node_modules/css-tree/lib/tokenizer/TokenStream.js
const OFFSET_MASK = 0x00FFFFFF;
const TYPE_SHIFT = 24;
const balancePair = new Map([
[Function, RightParenthesis],
[LeftParenthesis, RightParenthesis],
[LeftSquareBracket, RightSquareBracket],
[LeftCurlyBracket, RightCurlyBracket]
]);
class TokenStream {
constructor(source, tokenize) {
this.setSource(source, tokenize);
}
reset() {
this.eof = false;
this.tokenIndex = -1;
this.tokenType = 0;
this.tokenStart = this.firstCharOffset;
this.tokenEnd = this.firstCharOffset;
}
setSource(source = '', tokenize = () => {}) {
source = String(source || '');
const sourceLength = source.length;
const offsetAndType = adoptBuffer(this.offsetAndType, source.length + 1); // +1 because of eof-token
const balance = adoptBuffer(this.balance, source.length + 1);
let tokenCount = 0;
let balanceCloseType = 0;
let balanceStart = 0;
let firstCharOffset = -1;
// capture buffers
this.offsetAndType = null;
this.balance = null;
tokenize(source, (type, start, end) => {
switch (type) {
default:
balance[tokenCount] = sourceLength;
break;
case balanceCloseType: {
let balancePrev = balanceStart & OFFSET_MASK;
balanceStart = balance[balancePrev];
balanceCloseType = balanceStart >> TYPE_SHIFT;
balance[tokenCount] = balancePrev;
balance[balancePrev++] = tokenCount;
for (; balancePrev < tokenCount; balancePrev++) {
if (balance[balancePrev] === sourceLength) {
balance[balancePrev] = tokenCount;
}
}
break;
}
case LeftParenthesis:
case Function:
case LeftSquareBracket:
case LeftCurlyBracket:
balance[tokenCount] = balanceStart;
balanceCloseType = balancePair.get(type);
balanceStart = (balanceCloseType << TYPE_SHIFT) | tokenCount;
break;
}
offsetAndType[tokenCount++] = (type << TYPE_SHIFT) | end;
if (firstCharOffset === -1) {
firstCharOffset = start;
}
});
// finalize buffers
offsetAndType[tokenCount] = (EOF << TYPE_SHIFT) | sourceLength; // <EOF-token>
balance[tokenCount] = sourceLength;
balance[sourceLength] = sourceLength; // prevents false positive balance match with any token
while (balanceStart !== 0) {
const balancePrev = balanceStart & OFFSET_MASK;
balanceStart = balance[balancePrev];
balance[balancePrev] = sourceLength;
}
this.source = source;
this.firstCharOffset = firstCharOffset === -1 ? 0 : firstCharOffset;
this.tokenCount = tokenCount;
this.offsetAndType = offsetAndType;
this.balance = balance;
this.reset();
this.next();
}
lookupType(offset) {
offset += this.tokenIndex;
if (offset < this.tokenCount) {
return this.offsetAndType[offset] >> TYPE_SHIFT;
}
return EOF;
}
lookupOffset(offset) {
offset += this.tokenIndex;
if (offset < this.tokenCount) {
return this.offsetAndType[offset - 1] & OFFSET_MASK;
}
return this.source.length;
}
lookupValue(offset, referenceStr) {
offset += this.tokenIndex;
if (offset < this.tokenCount) {
return cmpStr(
this.source,
this.offsetAndType[offset - 1] & OFFSET_MASK,
this.offsetAndType[offset] & OFFSET_MASK,
referenceStr
);
}
return false;
}
getTokenStart(tokenIndex) {
if (tokenIndex === this.tokenIndex) {
return this.tokenStart;
}
if (tokenIndex > 0) {
return tokenIndex < this.tokenCount
? this.offsetAndType[tokenIndex - 1] & OFFSET_MASK
: this.offsetAndType[this.tokenCount] & OFFSET_MASK;
}
return this.firstCharOffset;
}
substrToCursor(start) {
return this.source.substring(start, this.tokenStart);
}
isBalanceEdge(pos) {
return this.balance[this.tokenIndex] < pos;
}
isDelim(code, offset) {
if (offset) {
return (
this.lookupType(offset) === Delim &&
this.source.charCodeAt(this.lookupOffset(offset)) === code
);
}
return (
this.tokenType === Delim &&
this.source.charCodeAt(this.tokenStart) === code
);
}
skip(tokenCount) {
let next = this.tokenIndex + tokenCount;
if (next < this.tokenCount) {
this.tokenIndex = next;
this.tokenStart = this.offsetAndType[next - 1] & OFFSET_MASK;
next = this.offsetAndType[next];
this.tokenType = next >> TYPE_SHIFT;
this.tokenEnd = next & OFFSET_MASK;
} else {
this.tokenIndex = this.tokenCount;
this.next();
}
}
next() {
let next = this.tokenIndex + 1;
if (next < this.tokenCount) {
this.tokenIndex = next;
this.tokenStart = this.tokenEnd;
next = this.offsetAndType[next];
this.tokenType = next >> TYPE_SHIFT;
this.tokenEnd = next & OFFSET_MASK;
} else {
this.eof = true;
this.tokenIndex = this.tokenCount;
this.tokenType = EOF;
this.tokenStart = this.tokenEnd = this.source.length;
}
}
skipSC() {
while (this.tokenType === WhiteSpace || this.tokenType === Comment) {
this.next();
}
}
skipUntilBalanced(startToken, stopConsume) {
let cursor = startToken;
let balanceEnd;
let offset;
loop:
for (; cursor < this.tokenCount; cursor++) {
balanceEnd = this.balance[cursor];
// stop scanning on balance edge that points to offset before start token
if (balanceEnd < startToken) {
break loop;
}
offset = cursor > 0 ? this.offsetAndType[cursor - 1] & OFFSET_MASK : this.firstCharOffset;
// check stop condition
switch (stopConsume(this.source.charCodeAt(offset))) {
case 1: // just stop
break loop;
case 2: // stop & included
cursor++;
break loop;
default:
// fast forward to the end of balanced block
if (this.balance[balanceEnd] === cursor) {
cursor = balanceEnd;
}
}
}
this.skip(cursor - this.tokenIndex);
}
forEachToken(fn) {
for (let i = 0, offset = this.firstCharOffset; i < this.tokenCount; i++) {
const start = offset;
const item = this.offsetAndType[i];
const end = item & OFFSET_MASK;
const type = item >> TYPE_SHIFT;
offset = end;
fn(type, start, end, i);
}
}
dump() {
const tokens = new Array(this.tokenCount);
this.forEachToken((type, start, end, index) => {
tokens[index] = {
idx: index,
type: names[type],
chunk: this.source.substring(start, end),
balance: this.balance[index]
};
});
return tokens;
}
};
;// ./node_modules/css-tree/lib/tokenizer/index.js
function tokenize(source, onToken) {
function getCharCode(offset) {
return offset < sourceLength ? source.charCodeAt(offset) : 0;
}
// § 4.3.3. Consume a numeric token
function consumeNumericToken() {
// Consume a number and let number be the result.
offset = consumeNumber(source, offset);
// If the next 3 input code points would start an identifier, then:
if (isIdentifierStart(getCharCode(offset), getCharCode(offset + 1), getCharCode(offset + 2))) {
// Create a <dimension-token> with the same value and type flag as number, and a unit set initially to the empty string.
// Consume a name. Set the <dimension-token>’s unit to the returned value.
// Return the <dimension-token>.
type = Dimension;
offset = consumeName(source, offset);
return;
}
// Otherwise, if the next input code point is U+0025 PERCENTAGE SIGN (%), consume it.
if (getCharCode(offset) === 0x0025) {
// Create a <percentage-token> with the same value as number, and return it.
type = Percentage;
offset++;
return;
}
// Otherwise, create a <number-token> with the same value and type flag as number, and return it.
type = types_Number;
}
// § 4.3.4. Consume an ident-like token
function consumeIdentLikeToken() {
const nameStartOffset = offset;
// Consume a name, and let string be the result.
offset = consumeName(source, offset);
// If string’s value is an ASCII case-insensitive match for "url",
// and the next input code point is U+0028 LEFT PARENTHESIS ((), consume it.
if (cmpStr(source, nameStartOffset, offset, 'url') && getCharCode(offset) === 0x0028) {
// While the next two input code points are whitespace, consume the next input code point.
offset = findWhiteSpaceEnd(source, offset + 1);
// If the next one or two input code points are U+0022 QUOTATION MARK ("), U+0027 APOSTROPHE ('),
// or whitespace followed by U+0022 QUOTATION MARK (") or U+0027 APOSTROPHE ('),
// then create a <function-token> with its value set to string and return it.
if (getCharCode(offset) === 0x0022 ||
getCharCode(offset) === 0x0027) {
type = Function;
offset = nameStartOffset + 4;
return;
}
// Otherwise, consume a url token, and return it.
consumeUrlToken();
return;
}
// Otherwise, if the next input code point is U+0028 LEFT PARENTHESIS ((), consume it.
// Create a <function-token> with its value set to string and return it.
if (getCharCode(offset) === 0x0028) {
type = Function;
offset++;
return;
}
// Otherwise, create an <ident-token> with its value set to string and return it.
type = Ident;
}
// § 4.3.5. Consume a string token
function consumeStringToken(endingCodePoint) {
// This algorithm may be called with an ending code point, which denotes the code point
// that ends the string. If an ending code point is not specified,
// the current input code point is used.
if (!endingCodePoint) {
endingCodePoint = getCharCode(offset++);
}
// Initially create a <string-token> with its value set to the empty string.
type = types_String;
// Repeatedly consume the next input code point from the stream:
for (; offset < source.length; offset++) {
const code = source.charCodeAt(offset);
switch (charCodeCategory(code)) {
// ending code point
case endingCodePoint:
// Return the <string-token>.
offset++;
return;
// EOF
// case EofCategory:
// This is a parse error. Return the <string-token>.
// return;
// newline
case WhiteSpaceCategory:
if (isNewline(code)) {
// This is a parse error. Reconsume the current input code point,
// create a <bad-string-token>, and return it.
offset += getNewlineLength(source, offset, code);
type = BadString;
return;
}
break;
// U+005C REVERSE SOLIDUS (\)
case 0x005C:
// If the next input code point is EOF, do nothing.
if (offset === source.length - 1) {
break;
}
const nextCode = getCharCode(offset + 1);
// Otherwise, if the next input code point is a newline, consume it.
if (isNewline(nextCode)) {
offset += getNewlineLength(source, offset + 1, nextCode);
} else if (char_code_definitions_isValidEscape(code, nextCode)) {
// Otherwise, (the stream starts with a valid escape) consume
// an escaped code point and append the returned code point to
// the <string-token>’s value.
offset = utils_consumeEscaped(source, offset) - 1;
}
break;
// anything else
// Append the current input code point to the <string-token>’s value.
}
}
}
// § 4.3.6. Consume a url token
// Note: This algorithm assumes that the initial "url(" has already been consumed.
// This algorithm also assumes that it’s being called to consume an "unquoted" value, like url(foo).
// A quoted value, like url("foo"), is parsed as a <function-token>. Consume an ident-like token
// automatically handles this distinction; this algorithm shouldn’t be called directly otherwise.
function consumeUrlToken() {
// Initially create a <url-token> with its value set to the empty string.
type = Url;
// Consume as much whitespace as possible.
offset = findWhiteSpaceEnd(source, offset);
// Repeatedly consume the next input code point from the stream:
for (; offset < source.length; offset++) {
const code = source.charCodeAt(offset);
switch (charCodeCategory(code)) {
// U+0029 RIGHT PARENTHESIS ())
case 0x0029:
// Return the <url-token>.
offset++;
return;
// EOF
// case EofCategory:
// This is a parse error. Return the <url-token>.
// return;
// whitespace
case WhiteSpaceCategory:
// Consume as much whitespace as possible.
offset = findWhiteSpaceEnd(source, offset);
// If the next input code point is U+0029 RIGHT PARENTHESIS ()) or EOF,
// consume it and return the <url-token>
// (if EOF was encountered, this is a parse error);
if (getCharCode(offset) === 0x0029 || offset >= source.length) {
if (offset < source.length) {
offset++;
}
return;
}
// otherwise, consume the remnants of a bad url, create a <bad-url-token>,
// and return it.
offset = consumeBadUrlRemnants(source, offset);
type = BadUrl;
return;
// U+0022 QUOTATION MARK (")
// U+0027 APOSTROPHE (')
// U+0028 LEFT PARENTHESIS (()
// non-printable code point
case 0x0022:
case 0x0027:
case 0x0028:
case NonPrintableCategory:
// This is a parse error. Consume the remnants of a bad url,
// create a <bad-url-token>, and return it.
offset = consumeBadUrlRemnants(source, offset);
type = BadUrl;
return;
// U+005C REVERSE SOLIDUS (\)
case 0x005C:
// If the stream starts with a valid escape, consume an escaped code point and
// append the returned code point to the <url-token>’s value.
if (char_code_definitions_isValidEscape(code, getCharCode(offset + 1))) {
offset = utils_consumeEscaped(source, offset) - 1;
break;
}
// Otherwise, this is a parse error. Consume the remnants of a bad url,
// create a <bad-url-token>, and return it.
offset = consumeBadUrlRemnants(source, offset);
type = BadUrl;
return;
// anything else
// Append the current input code point to the <url-token>’s value.
}
}
}
// ensure source is a string
source = String(source || '');
const sourceLength = source.length;
let start = isBOM(getCharCode(0));
let offset = start;
let type;
// https://drafts.csswg.org/css-syntax-3/#consume-token
// § 4.3.1. Consume a token
while (offset < sourceLength) {
const code = source.charCodeAt(offset);
switch (charCodeCategory(code)) {
// whitespace
case WhiteSpaceCategory:
// Consume as much whitespace as possible. Return a <whitespace-token>.
type = WhiteSpace;
offset = findWhiteSpaceEnd(source, offset + 1);
break;
// U+0022 QUOTATION MARK (")
case 0x0022:
// Consume a string token and return it.
consumeStringToken();
break;
// U+0023 NUMBER SIGN (#)
case 0x0023:
// If the next input code point is a name code point or the next two input code points are a valid escape, then:
if (char_code_definitions_isName(getCharCode(offset + 1)) || char_code_definitions_isValidEscape(getCharCode(offset + 1), getCharCode(offset + 2))) {
// Create a <hash-token>.
type = Hash;
// If the next 3 input code points would start an identifier, set the <hash-token>’s type flag to "id".
// if (isIdentifierStart(getCharCode(offset + 1), getCharCode(offset + 2), getCharCode(offset + 3))) {
// // TODO: set id flag
// }
// Consume a name, and set the <hash-token>’s value to the returned string.
offset = consumeName(source, offset + 1);
// Return the <hash-token>.
} else {
// Otherwise, return a <delim-token> with its value set to the current input code point.
type = Delim;
offset++;
}
break;
// U+0027 APOSTROPHE (')
case 0x0027:
// Consume a string token and return it.
consumeStringToken();
break;
// U+0028 LEFT PARENTHESIS (()
case 0x0028:
// Return a <(-token>.
type = LeftParenthesis;
offset++;
break;
// U+0029 RIGHT PARENTHESIS ())
case 0x0029:
// Return a <)-token>.
type = RightParenthesis;
offset++;
break;
// U+002B PLUS SIGN (+)
case 0x002B:
// If the input stream starts with a number, ...
if (isNumberStart(code, getCharCode(offset + 1), getCharCode(offset + 2))) {
// ... reconsume the current input code point, consume a numeric token, and return it.
consumeNumericToken();
} else {
// Otherwise, return a <delim-token> with its value set to the current input code point.
type = Delim;
offset++;
}
break;
// U+002C COMMA (,)
case 0x002C:
// Return a <comma-token>.
type = Comma;
offset++;
break;
// U+002D HYPHEN-MINUS (-)
case 0x002D:
// If the input stream starts with a number, reconsume the current input code point, consume a numeric token, and return it.
if (isNumberStart(code, getCharCode(offset + 1), getCharCode(offset + 2))) {
consumeNumericToken();
} else {
// Otherwise, if the next 2 input code points are U+002D HYPHEN-MINUS U+003E GREATER-THAN SIGN (->), consume them and return a <CDC-token>.
if (getCharCode(offset + 1) === 0x002D &&
getCharCode(offset + 2) === 0x003E) {
type = CDC;
offset = offset + 3;
} else {
// Otherwise, if the input stream starts with an identifier, ...
if (isIdentifierStart(code, getCharCode(offset + 1), getCharCode(offset + 2))) {
// ... reconsume the current input code point, consume an ident-like token, and return it.
consumeIdentLikeToken();
} else {
// Otherwise, return a <delim-token> with its value set to the current input code point.
type = Delim;
offset++;
}
}
}
break;
// U+002E FULL STOP (.)
case 0x002E:
// If the input stream starts with a number, ...
if (isNumberStart(code, getCharCode(offset + 1), getCharCode(offset + 2))) {
// ... reconsume the current input code point, consume a numeric token, and return it.
consumeNumericToken();
} else {
// Otherwise, return a <delim-token> with its value set to the current input code point.
type = Delim;
offset++;
}
break;
// U+002F SOLIDUS (/)
case 0x002F:
// If the next two input code point are U+002F SOLIDUS (/) followed by a U+002A ASTERISK (*),
if (getCharCode(offset + 1) === 0x002A) {
// ... consume them and all following code points up to and including the first U+002A ASTERISK (*)
// followed by a U+002F SOLIDUS (/), or up to an EOF code point.
type = Comment;
offset = source.indexOf('*/', offset + 2);
offset = offset === -1 ? source.length : offset + 2;
} else {
type = Delim;
offset++;
}
break;
// U+003A COLON (:)
case 0x003A:
// Return a <colon-token>.
type = Colon;
offset++;
break;
// U+003B SEMICOLON (;)
case 0x003B:
// Return a <semicolon-token>.
type = Semicolon;
offset++;
break;
// U+003C LESS-THAN SIGN (<)
case 0x003C:
// If the next 3 input code points are U+0021 EXCLAMATION MARK U+002D HYPHEN-MINUS U+002D HYPHEN-MINUS (!--), ...
if (getCharCode(offset + 1) === 0x0021 &&
getCharCode(offset + 2) === 0x002D &&
getCharCode(offset + 3) === 0x002D) {
// ... consume them and return a <CDO-token>.
type = CDO;
offset = offset + 4;
} else {
// Otherwise, return a <delim-token> with its value set to the current input code point.
type = Delim;
offset++;
}
break;
// U+0040 COMMERCIAL AT (@)
case 0x0040:
// If the next 3 input code points would start an identifier, ...
if (isIdentifierStart(getCharCode(offset + 1), getCharCode(offset + 2), getCharCode(offset + 3))) {
// ... consume a name, create an <at-keyword-token> with its value set to the returned value, and return it.
type = AtKeyword;
offset = consumeName(source, offset + 1);
} else {
// Otherwise, return a <delim-token> with its value set to the current input code point.
type = Delim;
offset++;
}
break;
// U+005B LEFT SQUARE BRACKET ([)
case 0x005B:
// Return a <[-token>.
type = LeftSquareBracket;
offset++;
break;
// U+005C REVERSE SOLIDUS (\)
case 0x005C:
// If the input stream starts with a valid escape, ...
if (char_code_definitions_isValidEscape(code, getCharCode(offset + 1))) {
// ... reconsume the current input code point, consume an ident-like token, and return it.
consumeIdentLikeToken();
} else {
// Otherwise, this is a parse error. Return a <delim-token> with its value set to the current input code point.
type = Delim;
offset++;
}
break;
// U+005D RIGHT SQUARE BRACKET (])
case 0x005D:
// Return a <]-token>.
type = RightSquareBracket;
offset++;
break;
// U+007B LEFT CURLY BRACKET ({)
case 0x007B:
// Return a <{-token>.
type = LeftCurlyBracket;
offset++;
break;
// U+007D RIGHT CURLY BRACKET (})
case 0x007D:
// Return a <}-token>.
type = RightCurlyBracket;
offset++;
break;
// digit
case DigitCategory:
// Reconsume the current input code point, consume a numeric token, and return it.
consumeNumericToken();
break;
// name-start code point
case NameStartCategory:
// Reconsume the current input code point, consume an ident-like token, and return it.
consumeIdentLikeToken();
break;
// EOF
// case EofCategory:
// Return an <EOF-token>.
// break;
// anything else
default:
// Return a <delim-token> with its value set to the current input code point.
type = Delim;
offset++;
}
// put token to stream
onToken(type, start, start = offset);
}
}
;// ./node_modules/css-tree/lib/utils/List.js
//
// list
// ┌──────┐
// ┌──────────────┼─head │
// │ │ tail─┼──────────────┐
// │ └──────┘ │
// ▼ ▼
// item item item item
// ┌──────┐ ┌──────┐ ┌──────┐ ┌──────┐
// null ◀──┼─prev │◀───┼─prev │◀───┼─prev │◀───┼─prev │
// │ next─┼───▶│ next─┼───▶│ next─┼───▶│ next─┼──▶ null
// ├──────┤ ├──────┤ ├──────┤ ├──────┤
// │ data │ │ data │ │ data │ │ data │
// └──────┘ └──────┘ └──────┘ └──────┘
//
let releasedCursors = null;
class List_List {
static createItem(data) {
return {
prev: null,
next: null,
data
};
}
constructor() {
this.head = null;
this.tail = null;
this.cursor = null;
}
createItem(data) {
return List_List.createItem(data);
}
// cursor helpers
allocateCursor(prev, next) {
let cursor;
if (releasedCursors !== null) {
cursor = releasedCursors;
releasedCursors = releasedCursors.cursor;
cursor.prev = prev;
cursor.next = next;
cursor.cursor = this.cursor;
} else {
cursor = {
prev,
next,
cursor: this.cursor
};
}
this.cursor = cursor;
return cursor;
}
releaseCursor() {
const { cursor } = this;
this.cursor = cursor.cursor;
cursor.prev = null;
cursor.next = null;
cursor.cursor = releasedCursors;
releasedCursors = cursor;
}
updateCursors(prevOld, prevNew, nextOld, nextNew) {
let { cursor } = this;
while (cursor !== null) {
if (cursor.prev === prevOld) {
cursor.prev = prevNew;
}
if (cursor.next === nextOld) {
cursor.next = nextNew;
}
cursor = cursor.cursor;
}
}
*[Symbol.iterator]() {
for (let cursor = this.head; cursor !== null; cursor = cursor.next) {
yield cursor.data;
}
}
// getters
get size() {
let size = 0;
for (let cursor = this.head; cursor !== null; cursor = cursor.next) {
size++;
}
return size;
}
get isEmpty() {
return this.head === null;
}
get first() {
return this.head && this.head.data;
}
get last() {
return this.tail && this.tail.data;
}
// convertors
fromArray(array) {
let cursor = null;
this.head = null;
for (let data of array) {
const item = List_List.createItem(data);
if (cursor !== null) {
cursor.next = item;
} else {
this.head = item;
}
item.prev = cursor;
cursor = item;
}
this.tail = cursor;
return this;
}
toArray() {
return [...this];
}
toJSON() {
return [...this];
}
// array-like methods
forEach(fn, thisArg = this) {
// push cursor
const cursor = this.allocateCursor(null, this.head);
while (cursor.next !== null) {
const item = cursor.next;
cursor.next = item.next;
fn.call(thisArg, item.data, item, this);
}
// pop cursor
this.releaseCursor();
}
forEachRight(fn, thisArg = this) {
// push cursor
const cursor = this.allocateCursor(this.tail, null);
while (cursor.prev !== null) {
const item = cursor.prev;
cursor.prev = item.prev;
fn.call(thisArg, item.data, item, this);
}
// pop cursor
this.releaseCursor();
}
reduce(fn, initialValue, thisArg = this) {
// push cursor
let cursor = this.allocateCursor(null, this.head);
let acc = initialValue;
let item;
while (cursor.next !== null) {
item = cursor.next;
cursor.next = item.next;
acc = fn.call(thisArg, acc, item.data, item, this);
}
// pop cursor
this.releaseCursor();
return acc;
}
reduceRight(fn, initialValue, thisArg = this) {
// push cursor
let cursor = this.allocateCursor(this.tail, null);
let acc = initialValue;
let item;
while (cursor.prev !== null) {
item = cursor.prev;
cursor.prev = item.prev;
acc = fn.call(thisArg, acc, item.data, item, this);
}
// pop cursor
this.releaseCursor();
return acc;
}
some(fn, thisArg = this) {
for (let cursor = this.head; cursor !== null; cursor = cursor.next) {
if (fn.call(thisArg, cursor.data, cursor, this)) {
return true;
}
}
return false;
}
map(fn, thisArg = this) {
const result = new List_List();
for (let cursor = this.head; cursor !== null; cursor = cursor.next) {
result.appendData(fn.call(thisArg, cursor.data, cursor, this));
}
return result;
}
filter(fn, thisArg = this) {
const result = new List_List();
for (let cursor = this.head; cursor !== null; cursor = cursor.next) {
if (fn.call(thisArg, cursor.data, cursor, this)) {
result.appendData(cursor.data);
}
}
return result;
}
nextUntil(start, fn, thisArg = this) {
if (start === null) {
return;
}
// push cursor
const cursor = this.allocateCursor(null, start);
while (cursor.next !== null) {
const item = cursor.next;
cursor.next = item.next;
if (fn.call(thisArg, item.data, item, this)) {
break;
}
}
// pop cursor
this.releaseCursor();
}
prevUntil(start, fn, thisArg = this) {
if (start === null) {
return;
}
// push cursor
const cursor = this.allocateCursor(start, null);
while (cursor.prev !== null) {
const item = cursor.prev;
cursor.prev = item.prev;
if (fn.call(thisArg, item.data, item, this)) {
break;
}
}
// pop cursor
this.releaseCursor();
}
// mutation
clear() {
this.head = null;
this.tail = null;
}
copy() {
const result = new List_List();
for (let data of this) {
result.appendData(data);
}
return result;
}
prepend(item) {
// head
// ^
// item
this.updateCursors(null, item, this.head, item);
// insert to the beginning of the list
if (this.head !== null) {
// new item <- first item
this.head.prev = item;
// new item -> first item
item.next = this.head;
} else {
// if list has no head, then it also has no tail
// in this case tail points to the new item
this.tail = item;
}
// head always points to new item
this.head = item;
return this;
}
prependData(data) {
return this.prepend(List_List.createItem(data));
}
append(item) {
return this.insert(item);
}
appendData(data) {
return this.insert(List_List.createItem(data));
}
insert(item, before = null) {
if (before !== null) {
// prev before
// ^
// item
this.updateCursors(before.prev, item, before, item);
if (before.prev === null) {
// insert to the beginning of list
if (this.head !== before) {
throw new Error('before doesn\'t belong to list');
}
// since head points to before therefore list doesn't empty
// no need to check tail
this.head = item;
before.prev = item;
item.next = before;
this.updateCursors(null, item);
} else {
// insert between two items
before.prev.next = item;
item.prev = before.prev;
before.prev = item;
item.next = before;
}
} else {
// tail
// ^
// item
this.updateCursors(this.tail, item, null, item);
// insert to the ending of the list
if (this.tail !== null) {
// last item -> new item
this.tail.next = item;
// last item <- new item
item.prev = this.tail;
} else {
// if list has no tail, then it also has no head
// in this case head points to new item
this.head = item;
}
// tail always points to new item
this.tail = item;
}
return this;
}
insertData(data, before) {
return this.insert(List_List.createItem(data), before);
}
remove(item) {
// item
// ^
// prev next
this.updateCursors(item, item.prev, item, item.next);
if (item.prev !== null) {
item.prev.next = item.next;
} else {
if (this.head !== item) {
throw new Error('item doesn\'t belong to list');
}
this.head = item.next;
}
if (item.next !== null) {
item.next.prev = item.prev;
} else {
if (this.tail !== item) {
throw new Error('item doesn\'t belong to list');
}
this.tail = item.prev;
}
item.prev = null;
item.next = null;
return item;
}
push(data) {
this.insert(List_List.createItem(data));
}
pop() {
return this.tail !== null ? this.remove(this.tail) : null;
}
unshift(data) {
this.prepend(List_List.createItem(data));
}
shift() {
return this.head !== null ? this.remove(this.head) : null;
}
prependList(list) {
return this.insertList(list, this.head);
}
appendList(list) {
return this.insertList(list);
}
insertList(list, before) {
// ignore empty lists
if (list.head === null) {
return this;
}
if (before !== undefined && before !== null) {
this.updateCursors(before.prev, list.tail, before, list.head);
// insert in the middle of dist list
if (before.prev !== null) {
// before.prev <-> list.head
before.prev.next = list.head;
list.head.prev = before.prev;
} else {
this.head = list.head;
}
before.prev = list.tail;
list.tail.next = before;
} else {
this.updateCursors(this.tail, list.tail, null, list.head);
// insert to end of the list
if (this.tail !== null) {
// if destination list has a tail, then it also has a head,
// but head doesn't change
// dest tail -> source head
this.tail.next = list.head;
// dest tail <- source head
list.head.prev = this.tail;
} else {
// if list has no a tail, then it also has no a head
// in this case points head to new item
this.head = list.head;
}
// tail always start point to new item
this.tail = list.tail;
}
list.head = null;
list.tail = null;
return this;
}
replace(oldItem, newItemOrList) {
if ('head' in newItemOrList) {
this.insertList(newItemOrList, oldItem);
} else {
this.insert(newItemOrList, oldItem);
}
this.remove(oldItem);
}
}
;// ./node_modules/css-tree/lib/utils/create-custom-error.js
function createCustomError(name, message) {
// use Object.create(), because some VMs prevent setting line/column otherwise
// (iOS Safari 10 even throws an exception)
const error = Object.create(SyntaxError.prototype);
const errorStack = new Error();
return Object.assign(error, {
name,
message,
get stack() {
return (errorStack.stack || '').replace(/^(.+\n){1,3}/, `${name}: ${message}\n`);
}
});
};
;// ./node_modules/css-tree/lib/parser/SyntaxError.js
const MAX_LINE_LENGTH = 100;
const OFFSET_CORRECTION = 60;
const TAB_REPLACEMENT = ' ';
function sourceFragment({ source, line, column }, extraLines) {
function processLines(start, end) {
return lines
.slice(start, end)
.map((line, idx) =>
String(start + idx + 1).padStart(maxNumLength) + ' |' + line
).join('\n');
}
const lines = source.split(/\r\n?|\n|\f/);
const startLine = Math.max(1, line - extraLines) - 1;
const endLine = Math.min(line + extraLines, lines.length + 1);
const maxNumLength = Math.max(4, String(endLine).length) + 1;
let cutLeft = 0;
// column correction according to replaced tab before column
column += (TAB_REPLACEMENT.length - 1) * (lines[line - 1].substr(0, column - 1).match(/\t/g) || []).length;
if (column > MAX_LINE_LENGTH) {
cutLeft = column - OFFSET_CORRECTION + 3;
column = OFFSET_CORRECTION - 2;
}
for (let i = startLine; i <= endLine; i++) {
if (i >= 0 && i < lines.length) {
lines[i] = lines[i].replace(/\t/g, TAB_REPLACEMENT);
lines[i] =
(cutLeft > 0 && lines[i].length > cutLeft ? '\u2026' : '') +
lines[i].substr(cutLeft, MAX_LINE_LENGTH - 2) +
(lines[i].length > cutLeft + MAX_LINE_LENGTH - 1 ? '\u2026' : '');
}
}
return [
processLines(startLine, line),
new Array(column + maxNumLength + 2).join('-') + '^',
processLines(line, endLine)
].filter(Boolean).join('\n');
}
function SyntaxError_SyntaxError(message, source, offset, line, column) {
const error = Object.assign(createCustomError('SyntaxError', message), {
source,
offset,
line,
column,
sourceFragment(extraLines) {
return sourceFragment({ source, line, column }, isNaN(extraLines) ? 0 : extraLines);
},
get formattedMessage() {
return (
`Parse error: ${message}\n` +
sourceFragment({ source, line, column }, 2)
);
}
});
return error;
}
;// ./node_modules/css-tree/lib/parser/sequence.js
function readSequence(recognizer) {
const children = this.createList();
let space = false;
const context = {
recognizer
};
while (!this.eof) {
switch (this.tokenType) {
case Comment:
this.next();
continue;
case WhiteSpace:
space = true;
this.next();
continue;
}
let child = recognizer.getNode.call(this, context);
if (child === undefined) {
break;
}
if (space) {
if (recognizer.onWhiteSpace) {
recognizer.onWhiteSpace.call(this, child, children, context);
}
space = false;
}
children.push(child);
}
if (space && recognizer.onWhiteSpace) {
recognizer.onWhiteSpace.call(this, null, children, context);
}
return children;
};
;// ./node_modules/css-tree/lib/parser/create.js
const NOOP = () => {};
const EXCLAMATIONMARK = 0x0021; // U+0021 EXCLAMATION MARK (!)
const NUMBERSIGN = 0x0023; // U+0023 NUMBER SIGN (#)
const SEMICOLON = 0x003B; // U+003B SEMICOLON (;)
const LEFTCURLYBRACKET = 0x007B; // U+007B LEFT CURLY BRACKET ({)
const NULL = 0;
function createParseContext(name) {
return function() {
return this[name]();
};
}
function fetchParseValues(dict) {
const result = Object.create(null);
for (const name in dict) {
const item = dict[name];
const fn = item.parse || item;
if (fn) {
result[name] = fn;
}
}
return result;
}
function processConfig(config) {
const parseConfig = {
context: Object.create(null),
scope: Object.assign(Object.create(null), config.scope),
atrule: fetchParseValues(config.atrule),
pseudo: fetchParseValues(config.pseudo),
node: fetchParseValues(config.node)
};
for (const name in config.parseContext) {
switch (typeof config.parseContext[name]) {
case 'function':
parseConfig.context[name] = config.parseContext[name];
break;
case 'string':
parseConfig.context[name] = createParseContext(config.parseContext[name]);
break;
}
}
return {
config: parseConfig,
...parseConfig,
...parseConfig.node
};
}
function createParser(config) {
let source = '';
let filename = '<unknown>';
let needPositions = false;
let onParseError = NOOP;
let onParseErrorThrow = false;
const locationMap = new OffsetToLocation();
const parser = Object.assign(new TokenStream(), processConfig(config || {}), {
parseAtrulePrelude: true,
parseRulePrelude: true,
parseValue: true,
parseCustomProperty: false,
readSequence: readSequence,
consumeUntilBalanceEnd: () => 0,
consumeUntilLeftCurlyBracket(code) {
return code === LEFTCURLYBRACKET ? 1 : 0;
},
consumeUntilLeftCurlyBracketOrSemicolon(code) {
return code === LEFTCURLYBRACKET || code === SEMICOLON ? 1 : 0;
},
consumeUntilExclamationMarkOrSemicolon(code) {
return code === EXCLAMATIONMARK || code === SEMICOLON ? 1 : 0;
},
consumeUntilSemicolonIncluded(code) {
return code === SEMICOLON ? 2 : 0;
},
createList() {
return new List_List();
},
createSingleNodeList(node) {
return new List_List().appendData(node);
},
getFirstListNode(list) {
return list && list.first;
},
getLastListNode(list) {
return list && list.last;
},
parseWithFallback(consumer, fallback) {
const startToken = this.tokenIndex;
try {
return consumer.call(this);
} catch (e) {
if (onParseErrorThrow) {
throw e;
}
const fallbackNode = fallback.call(this, startToken);
onParseErrorThrow = true;
onParseError(e, fallbackNode);
onParseErrorThrow = false;
return fallbackNode;
}
},
lookupNonWSType(offset) {
let type;
do {
type = this.lookupType(offset++);
if (type !== WhiteSpace) {
return type;
}
} while (type !== NULL);
return NULL;
},
charCodeAt(offset) {
return offset >= 0 && offset < source.length ? source.charCodeAt(offset) : 0;
},
substring(offsetStart, offsetEnd) {
return source.substring(offsetStart, offsetEnd);
},
substrToCursor(start) {
return this.source.substring(start, this.tokenStart);
},
cmpChar(offset, charCode) {
return cmpChar(source, offset, charCode);
},
cmpStr(offsetStart, offsetEnd, str) {
return cmpStr(source, offsetStart, offsetEnd, str);
},
consume(tokenType) {
const start = this.tokenStart;
this.eat(tokenType);
return this.substrToCursor(start);
},
consumeFunctionName() {
const name = source.substring(this.tokenStart, this.tokenEnd - 1);
this.eat(Function);
return name;
},
consumeNumber(type) {
const number = source.substring(this.tokenStart, consumeNumber(source, this.tokenStart));
this.eat(type);
return number;
},
eat(tokenType) {
if (this.tokenType !== tokenType) {
const tokenName = names[tokenType].slice(0, -6).replace(/-/g, ' ').replace(/^./, m => m.toUpperCase());
let message = `${/[[\](){}]/.test(tokenName) ? `"${tokenName}"` : tokenName} is expected`;
let offset = this.tokenStart;
// tweak message and offset
switch (tokenType) {
case Ident:
// when identifier is expected but there is a function or url
if (this.tokenType === Function || this.tokenType === Url) {
offset = this.tokenEnd - 1;
message = 'Identifier is expected but function found';
} else {
message = 'Identifier is expected';
}
break;
case Hash:
if (this.isDelim(NUMBERSIGN)) {
this.next();
offset++;
message = 'Name is expected';
}
break;
case Percentage:
if (this.tokenType === types_Number) {
offset = this.tokenEnd;
message = 'Percent sign is expected';
}
break;
}
this.error(message, offset);
}
this.next();
},
eatIdent(name) {
if (this.tokenType !== Ident || this.lookupValue(0, name) === false) {
this.error(`Identifier "${name}" is expected`);
}
this.next();
},
eatDelim(code) {
if (!this.isDelim(code)) {
this.error(`Delim "${String.fromCharCode(code)}" is expected`);
}
this.next();
},
getLocation(start, end) {
if (needPositions) {
return locationMap.getLocationRange(
start,
end,
filename
);
}
return null;
},
getLocationFromList(list) {
if (needPositions) {
const head = this.getFirstListNode(list);
const tail = this.getLastListNode(list);
return locationMap.getLocationRange(
head !== null ? head.loc.start.offset - locationMap.startOffset : this.tokenStart,
tail !== null ? tail.loc.end.offset - locationMap.startOffset : this.tokenStart,
filename
);
}
return null;
},
error(message, offset) {
const location = typeof offset !== 'undefined' && offset < source.length
? locationMap.getLocation(offset)
: this.eof
? locationMap.getLocation(findWhiteSpaceStart(source, source.length - 1))
: locationMap.getLocation(this.tokenStart);
throw new SyntaxError_SyntaxError(
message || 'Unexpected input',
source,
location.offset,
location.line,
location.column
);
}
});
const parse = function(source_, options) {
source = source_;
options = options || {};
parser.setSource(source, tokenize);
locationMap.setSource(
source,
options.offset,
options.line,
options.column
);
filename = options.filename || '<unknown>';
needPositions = Boolean(options.positions);
onParseError = typeof options.onParseError === 'function' ? options.onParseError : NOOP;
onParseErrorThrow = false;
parser.parseAtrulePrelude = 'parseAtrulePrelude' in options ? Boolean(options.parseAtrulePrelude) : true;
parser.parseRulePrelude = 'parseRulePrelude' in options ? Boolean(options.parseRulePrelude) : true;
parser.parseValue = 'parseValue' in options ? Boolean(options.parseValue) : true;
parser.parseCustomProperty = 'parseCustomProperty' in options ? Boolean(options.parseCustomProperty) : false;
const { context = 'default', onComment } = options;
if (context in parser.context === false) {
throw new Error('Unknown context `' + context + '`');
}
if (typeof onComment === 'function') {
parser.forEachToken((type, start, end) => {
if (type === Comment) {
const loc = parser.getLocation(start, end);
const value = cmpStr(source, end - 2, end, '*/')
? source.slice(start + 2, end - 2)
: source.slice(start + 2, end);
onComment(value, loc);
}
});
}
const ast = parser.context[context].call(parser, options);
if (!parser.eof) {
parser.error();
}
return ast;
};
return Object.assign(parse, {
SyntaxError: SyntaxError_SyntaxError,
config: parser.config
});
};
// EXTERNAL MODULE: ./node_modules/source-map-js/lib/source-map-generator.js
var source_map_generator = __webpack_require__("./node_modules/source-map-js/lib/source-map-generator.js");
;// ./node_modules/css-tree/lib/generator/sourceMap.js
const trackNodes = new Set(['Atrule', 'Selector', 'Declaration']);
function generateSourceMap(handlers) {
const map = new source_map_generator/* SourceMapGenerator */.x();
const generated = {
line: 1,
column: 0
};
const original = {
line: 0, // should be zero to add first mapping
column: 0
};
const activatedGenerated = {
line: 1,
column: 0
};
const activatedMapping = {
generated: activatedGenerated
};
let line = 1;
let column = 0;
let sourceMappingActive = false;
const origHandlersNode = handlers.node;
handlers.node = function(node) {
if (node.loc && node.loc.start && trackNodes.has(node.type)) {
const nodeLine = node.loc.start.line;
const nodeColumn = node.loc.start.column - 1;
if (original.line !== nodeLine ||
original.column !== nodeColumn) {
original.line = nodeLine;
original.column = nodeColumn;
generated.line = line;
generated.column = column;
if (sourceMappingActive) {
sourceMappingActive = false;
if (generated.line !== activatedGenerated.line ||
generated.column !== activatedGenerated.column) {
map.addMapping(activatedMapping);
}
}
sourceMappingActive = true;
map.addMapping({
source: node.loc.source,
original,
generated
});
}
}
origHandlersNode.call(this, node);
if (sourceMappingActive && trackNodes.has(node.type)) {
activatedGenerated.line = line;
activatedGenerated.column = column;
}
};
const origHandlersEmit = handlers.emit;
handlers.emit = function(value, type, auto) {
for (let i = 0; i < value.length; i++) {
if (value.charCodeAt(i) === 10) { // \n
line++;
column = 0;
} else {
column++;
}
}
origHandlersEmit(value, type, auto);
};
const origHandlersResult = handlers.result;
handlers.result = function() {
if (sourceMappingActive) {
map.addMapping(activatedMapping);
}
return {
css: origHandlersResult(),
map
};
};
return handlers;
};
;// ./node_modules/css-tree/lib/generator/token-before.js
const PLUSSIGN = 0x002B; // U+002B PLUS SIGN (+)
const HYPHENMINUS = 0x002D; // U+002D HYPHEN-MINUS (-)
const code = (type, value) => {
if (type === Delim) {
type = value;
}
if (typeof type === 'string') {
const charCode = type.charCodeAt(0);
return charCode > 0x7F ? 0x8000 : charCode << 8;
}
return type;
};
// https://www.w3.org/TR/css-syntax-3/#serialization
// The only requirement for serialization is that it must "round-trip" with parsing,
// that is, parsing the stylesheet must produce the same data structures as parsing,
// serializing, and parsing again, except for consecutive <whitespace-token>s,
// which may be collapsed into a single token.
const specPairs = [
[Ident, Ident],
[Ident, Function],
[Ident, Url],
[Ident, BadUrl],
[Ident, '-'],
[Ident, types_Number],
[Ident, Percentage],
[Ident, Dimension],
[Ident, CDC],
[Ident, LeftParenthesis],
[AtKeyword, Ident],
[AtKeyword, Function],
[AtKeyword, Url],
[AtKeyword, BadUrl],
[AtKeyword, '-'],
[AtKeyword, types_Number],
[AtKeyword, Percentage],
[AtKeyword, Dimension],
[AtKeyword, CDC],
[Hash, Ident],
[Hash, Function],
[Hash, Url],
[Hash, BadUrl],
[Hash, '-'],
[Hash, types_Number],
[Hash, Percentage],
[Hash, Dimension],
[Hash, CDC],
[Dimension, Ident],
[Dimension, Function],
[Dimension, Url],
[Dimension, BadUrl],
[Dimension, '-'],
[Dimension, types_Number],
[Dimension, Percentage],
[Dimension, Dimension],
[Dimension, CDC],
['#', Ident],
['#', Function],
['#', Url],
['#', BadUrl],
['#', '-'],
['#', types_Number],
['#', Percentage],
['#', Dimension],
['#', CDC], // https://github.com/w3c/csswg-drafts/pull/6874
['-', Ident],
['-', Function],
['-', Url],
['-', BadUrl],
['-', '-'],
['-', types_Number],
['-', Percentage],
['-', Dimension],
['-', CDC], // https://github.com/w3c/csswg-drafts/pull/6874
[types_Number, Ident],
[types_Number, Function],
[types_Number, Url],
[types_Number, BadUrl],
[types_Number, types_Number],
[types_Number, Percentage],
[types_Number, Dimension],
[types_Number, '%'],
[types_Number, CDC], // https://github.com/w3c/csswg-drafts/pull/6874
['@', Ident],
['@', Function],
['@', Url],
['@', BadUrl],
['@', '-'],
['@', CDC], // https://github.com/w3c/csswg-drafts/pull/6874
['.', types_Number],
['.', Percentage],
['.', Dimension],
['+', types_Number],
['+', Percentage],
['+', Dimension],
['/', '*']
];
// validate with scripts/generate-safe
const safePairs = specPairs.concat([
[Ident, Hash],
[Dimension, Hash],
[Hash, Hash],
[AtKeyword, LeftParenthesis],
[AtKeyword, types_String],
[AtKeyword, Colon],
[Percentage, Percentage],
[Percentage, Dimension],
[Percentage, Function],
[Percentage, '-'],
[RightParenthesis, Ident],
[RightParenthesis, Function],
[RightParenthesis, Percentage],
[RightParenthesis, Dimension],
[RightParenthesis, Hash],
[RightParenthesis, '-']
]);
function createMap(pairs) {
const isWhiteSpaceRequired = new Set(
pairs.map(([prev, next]) => (code(prev) << 16 | code(next)))
);
return function(prevCode, type, value) {
const nextCode = code(type, value);
const nextCharCode = value.charCodeAt(0);
const emitWs =
(nextCharCode === HYPHENMINUS &&
type !== Ident &&
type !== Function &&
type !== CDC) ||
(nextCharCode === PLUSSIGN)
? isWhiteSpaceRequired.has(prevCode << 16 | nextCharCode << 8)
: isWhiteSpaceRequired.has(prevCode << 16 | nextCode);
if (emitWs) {
this.emit(' ', WhiteSpace, true);
}
return nextCode;
};
}
const spec = createMap(specPairs);
const safe = createMap(safePairs);
;// ./node_modules/css-tree/lib/generator/create.js
const REVERSESOLIDUS = 0x005c; // U+005C REVERSE SOLIDUS (\)
function processChildren(node, delimeter) {
if (typeof delimeter === 'function') {
let prev = null;
node.children.forEach(node => {
if (prev !== null) {
delimeter.call(this, prev);
}
this.node(node);
prev = node;
});
return;
}
node.children.forEach(this.node, this);
}
function processChunk(chunk) {
tokenize(chunk, (type, start, end) => {
this.token(type, chunk.slice(start, end));
});
}
function createGenerator(config) {
const types = new Map();
for (let name in config.node) {
const item = config.node[name];
const fn = item.generate || item;
if (typeof fn === 'function') {
types.set(name, item.generate || item);
}
}
return function(node, options) {
let buffer = '';
let prevCode = 0;
let handlers = {
node(node) {
if (types.has(node.type)) {
types.get(node.type).call(publicApi, node);
} else {
throw new Error('Unknown node type: ' + node.type);
}
},
tokenBefore: safe,
token(type, value) {
prevCode = this.tokenBefore(prevCode, type, value);
this.emit(value, type, false);
if (type === Delim && value.charCodeAt(0) === REVERSESOLIDUS) {
this.emit('\n', WhiteSpace, true);
}
},
emit(value) {
buffer += value;
},
result() {
return buffer;
}
};
if (options) {
if (typeof options.decorator === 'function') {
handlers = options.decorator(handlers);
}
if (options.sourceMap) {
handlers = generateSourceMap(handlers);
}
if (options.mode in token_before_namespaceObject) {
handlers.tokenBefore = token_before_namespaceObject[options.mode];
}
}
const publicApi = {
node: (node) => handlers.node(node),
children: processChildren,
token: (type, value) => handlers.token(type, value),
tokenize: processChunk
};
handlers.node(node);
return handlers.result();
};
};
;// ./node_modules/css-tree/lib/convertor/create.js
function createConvertor(walk) {
return {
fromPlainObject(ast) {
walk(ast, {
enter(node) {
if (node.children && node.children instanceof List_List === false) {
node.children = new List_List().fromArray(node.children);
}
}
});
return ast;
},
toPlainObject(ast) {
walk(ast, {
leave(node) {
if (node.children && node.children instanceof List_List) {
node.children = node.children.toArray();
}
}
});
return ast;
}
};
};
;// ./node_modules/css-tree/lib/walker/create.js
const { hasOwnProperty: create_hasOwnProperty } = Object.prototype;
const noop = function() {};
function ensureFunction(value) {
return typeof value === 'function' ? value : noop;
}
function invokeForType(fn, type) {
return function(node, item, list) {
if (node.type === type) {
fn.call(this, node, item, list);
}
};
}
function getWalkersFromStructure(name, nodeType) {
const structure = nodeType.structure;
const walkers = [];
for (const key in structure) {
if (create_hasOwnProperty.call(structure, key) === false) {
continue;
}
let fieldTypes = structure[key];
const walker = {
name: key,
type: false,
nullable: false
};
if (!Array.isArray(fieldTypes)) {
fieldTypes = [fieldTypes];
}
for (const fieldType of fieldTypes) {
if (fieldType === null) {
walker.nullable = true;
} else if (typeof fieldType === 'string') {
walker.type = 'node';
} else if (Array.isArray(fieldType)) {
walker.type = 'list';
}
}
if (walker.type) {
walkers.push(walker);
}
}
if (walkers.length) {
return {
context: nodeType.walkContext,
fields: walkers
};
}
return null;
}
function getTypesFromConfig(config) {
const types = {};
for (const name in config.node) {
if (create_hasOwnProperty.call(config.node, name)) {
const nodeType = config.node[name];
if (!nodeType.structure) {
throw new Error('Missed `structure` field in `' + name + '` node type definition');
}
types[name] = getWalkersFromStructure(name, nodeType);
}
}
return types;
}
function createTypeIterator(config, reverse) {
const fields = config.fields.slice();
const contextName = config.context;
const useContext = typeof contextName === 'string';
if (reverse) {
fields.reverse();
}
return function(node, context, walk, walkReducer) {
let prevContextValue;
if (useContext) {
prevContextValue = context[contextName];
context[contextName] = node;
}
for (const field of fields) {
const ref = node[field.name];
if (!field.nullable || ref) {
if (field.type === 'list') {
const breakWalk = reverse
? ref.reduceRight(walkReducer, false)
: ref.reduce(walkReducer, false);
if (breakWalk) {
return true;
}
} else if (walk(ref)) {
return true;
}
}
}
if (useContext) {
context[contextName] = prevContextValue;
}
};
}
function createFastTraveralMap({
StyleSheet,
Atrule,
Rule,
Block,
DeclarationList
}) {
return {
Atrule: {
StyleSheet,
Atrule,
Rule,
Block
},
Rule: {
StyleSheet,
Atrule,
Rule,
Block
},
Declaration: {
StyleSheet,
Atrule,
Rule,
Block,
DeclarationList
}
};
}
function createWalker(config) {
const types = getTypesFromConfig(config);
const iteratorsNatural = {};
const iteratorsReverse = {};
const breakWalk = Symbol('break-walk');
const skipNode = Symbol('skip-node');
for (const name in types) {
if (create_hasOwnProperty.call(types, name) && types[name] !== null) {
iteratorsNatural[name] = createTypeIterator(types[name], false);
iteratorsReverse[name] = createTypeIterator(types[name], true);
}
}
const fastTraversalIteratorsNatural = createFastTraveralMap(iteratorsNatural);
const fastTraversalIteratorsReverse = createFastTraveralMap(iteratorsReverse);
const walk = function(root, options) {
function walkNode(node, item, list) {
const enterRet = enter.call(context, node, item, list);
if (enterRet === breakWalk) {
return true;
}
if (enterRet === skipNode) {
return false;
}
if (iterators.hasOwnProperty(node.type)) {
if (iterators[node.type](node, context, walkNode, walkReducer)) {
return true;
}
}
if (leave.call(context, node, item, list) === breakWalk) {
return true;
}
return false;
}
let enter = noop;
let leave = noop;
let iterators = iteratorsNatural;
let walkReducer = (ret, data, item, list) => ret || walkNode(data, item, list);
const context = {
break: breakWalk,
skip: skipNode,
root,
stylesheet: null,
atrule: null,
atrulePrelude: null,
rule: null,
selector: null,
block: null,
declaration: null,
function: null
};
if (typeof options === 'function') {
enter = options;
} else if (options) {
enter = ensureFunction(options.enter);
leave = ensureFunction(options.leave);
if (options.reverse) {
iterators = iteratorsReverse;
}
if (options.visit) {
if (fastTraversalIteratorsNatural.hasOwnProperty(options.visit)) {
iterators = options.reverse
? fastTraversalIteratorsReverse[options.visit]
: fastTraversalIteratorsNatural[options.visit];
} else if (!types.hasOwnProperty(options.visit)) {
throw new Error('Bad value `' + options.visit + '` for `visit` option (should be: ' + Object.keys(types).sort().join(', ') + ')');
}
enter = invokeForType(enter, options.visit);
leave = invokeForType(leave, options.visit);
}
}
if (enter === noop && leave === noop) {
throw new Error('Neither `enter` nor `leave` walker handler is set or both aren\'t a function');
}
walkNode(root);
};
walk.break = breakWalk;
walk.skip = skipNode;
walk.find = function(ast, fn) {
let found = null;
walk(ast, function(node, item, list) {
if (fn.call(this, node, item, list)) {
found = node;
return breakWalk;
}
});
return found;
};
walk.findLast = function(ast, fn) {
let found = null;
walk(ast, {
reverse: true,
enter(node, item, list) {
if (fn.call(this, node, item, list)) {
found = node;
return breakWalk;
}
}
});
return found;
};
walk.findAll = function(ast, fn) {
const found = [];
walk(ast, function(node, item, list) {
if (fn.call(this, node, item, list)) {
found.push(node);
}
});
return found;
};
return walk;
};
;// ./node_modules/css-tree/lib/definition-syntax/generate.js
function generate_noop(value) {
return value;
}
function generateMultiplier(multiplier) {
const { min, max, comma } = multiplier;
if (min === 0 && max === 0) {
return comma ? '#?' : '*';
}
if (min === 0 && max === 1) {
return '?';
}
if (min === 1 && max === 0) {
return comma ? '#' : '+';
}
if (min === 1 && max === 1) {
return '';
}
return (
(comma ? '#' : '') +
(min === max
? '{' + min + '}'
: '{' + min + ',' + (max !== 0 ? max : '') + '}'
)
);
}
function generateTypeOpts(node) {
switch (node.type) {
case 'Range':
return (
' [' +
(node.min === null ? '-∞' : node.min) +
',' +
(node.max === null ? '∞' : node.max) +
']'
);
default:
throw new Error('Unknown node type `' + node.type + '`');
}
}
function generateSequence(node, decorate, forceBraces, compact) {
const combinator = node.combinator === ' ' || compact ? node.combinator : ' ' + node.combinator + ' ';
const result = node.terms
.map(term => internalGenerate(term, decorate, forceBraces, compact))
.join(combinator);
if (node.explicit || forceBraces) {
return (compact || result[0] === ',' ? '[' : '[ ') + result + (compact ? ']' : ' ]');
}
return result;
}
function internalGenerate(node, decorate, forceBraces, compact) {
let result;
switch (node.type) {
case 'Group':
result =
generateSequence(node, decorate, forceBraces, compact) +
(node.disallowEmpty ? '!' : '');
break;
case 'Multiplier':
// return since node is a composition
return (
internalGenerate(node.term, decorate, forceBraces, compact) +
decorate(generateMultiplier(node), node)
);
case 'Type':
result = '<' + node.name + (node.opts ? decorate(generateTypeOpts(node.opts), node.opts) : '') + '>';
break;
case 'Property':
result = '<\'' + node.name + '\'>';
break;
case 'Keyword':
result = node.name;
break;
case 'AtKeyword':
result = '@' + node.name;
break;
case 'Function':
result = node.name + '(';
break;
case 'String':
case 'Token':
result = node.value;
break;
case 'Comma':
result = ',';
break;
default:
throw new Error('Unknown node type `' + node.type + '`');
}
return decorate(result, node);
}
function generate(node, options) {
let decorate = generate_noop;
let forceBraces = false;
let compact = false;
if (typeof options === 'function') {
decorate = options;
} else if (options) {
forceBraces = Boolean(options.forceBraces);
compact = Boolean(options.compact);
if (typeof options.decorate === 'function') {
decorate = options.decorate;
}
}
return internalGenerate(node, decorate, forceBraces, compact);
};
;// ./node_modules/css-tree/lib/lexer/error.js
const defaultLoc = { offset: 0, line: 1, column: 1 };
function locateMismatch(matchResult, node) {
const tokens = matchResult.tokens;
const longestMatch = matchResult.longestMatch;
const mismatchNode = longestMatch < tokens.length ? tokens[longestMatch].node || null : null;
const badNode = mismatchNode !== node ? mismatchNode : null;
let mismatchOffset = 0;
let mismatchLength = 0;
let entries = 0;
let css = '';
let start;
let end;
for (let i = 0; i < tokens.length; i++) {
const token = tokens[i].value;
if (i === longestMatch) {
mismatchLength = token.length;
mismatchOffset = css.length;
}
if (badNode !== null && tokens[i].node === badNode) {
if (i <= longestMatch) {
entries++;
} else {
entries = 0;
}
}
css += token;
}
if (longestMatch === tokens.length || entries > 1) { // last
start = fromLoc(badNode || node, 'end') || buildLoc(defaultLoc, css);
end = buildLoc(start);
} else {
start = fromLoc(badNode, 'start') ||
buildLoc(fromLoc(node, 'start') || defaultLoc, css.slice(0, mismatchOffset));
end = fromLoc(badNode, 'end') ||
buildLoc(start, css.substr(mismatchOffset, mismatchLength));
}
return {
css,
mismatchOffset,
mismatchLength,
start,
end
};
}
function fromLoc(node, point) {
const value = node && node.loc && node.loc[point];
if (value) {
return 'line' in value ? buildLoc(value) : value;
}
return null;
}
function buildLoc({ offset, line, column }, extra) {
const loc = {
offset,
line,
column
};
if (extra) {
const lines = extra.split(/\n|\r\n?|\f/);
loc.offset += extra.length;
loc.line += lines.length - 1;
loc.column = lines.length === 1 ? loc.column + extra.length : lines.pop().length + 1;
}
return loc;
}
const SyntaxReferenceError = function(type, referenceName) {
const error = createCustomError(
'SyntaxReferenceError',
type + (referenceName ? ' `' + referenceName + '`' : '')
);
error.reference = referenceName;
return error;
};
const SyntaxMatchError = function(message, syntax, node, matchResult) {
const error = createCustomError('SyntaxMatchError', message);
const {
css,
mismatchOffset,
mismatchLength,
start,
end
} = locateMismatch(matchResult, node);
error.rawMessage = message;
error.syntax = syntax ? generate(syntax) : '<generic>';
error.css = css;
error.mismatchOffset = mismatchOffset;
error.mismatchLength = mismatchLength;
error.message = message + '\n' +
' syntax: ' + error.syntax + '\n' +
' value: ' + (css || '<empty string>') + '\n' +
' --------' + new Array(error.mismatchOffset + 1).join('-') + '^';
Object.assign(error, start);
error.loc = {
source: (node && node.loc && node.loc.source) || '<unknown>',
start,
end
};
return error;
};
;// ./node_modules/css-tree/lib/utils/names.js
const keywords = new Map();
const properties = new Map();
const names_HYPHENMINUS = 45; // '-'.charCodeAt()
const keyword = getKeywordDescriptor;
const names_property = getPropertyDescriptor;
const vendorPrefix = (/* unused pure expression or super */ null && (getVendorPrefix));
function isCustomProperty(str, offset) {
offset = offset || 0;
return str.length - offset >= 2 &&
str.charCodeAt(offset) === names_HYPHENMINUS &&
str.charCodeAt(offset + 1) === names_HYPHENMINUS;
}
function getVendorPrefix(str, offset) {
offset = offset || 0;
// verdor prefix should be at least 3 chars length
if (str.length - offset >= 3) {
// vendor prefix starts with hyper minus following non-hyper minus
if (str.charCodeAt(offset) === names_HYPHENMINUS &&
str.charCodeAt(offset + 1) !== names_HYPHENMINUS) {
// vendor prefix should contain a hyper minus at the ending
const secondDashIndex = str.indexOf('-', offset + 2);
if (secondDashIndex !== -1) {
return str.substring(offset, secondDashIndex + 1);
}
}
}
return '';
}
function getKeywordDescriptor(keyword) {
if (keywords.has(keyword)) {
return keywords.get(keyword);
}
const name = keyword.toLowerCase();
let descriptor = keywords.get(name);
if (descriptor === undefined) {
const custom = isCustomProperty(name, 0);
const vendor = !custom ? getVendorPrefix(name, 0) : '';
descriptor = Object.freeze({
basename: name.substr(vendor.length),
name,
prefix: vendor,
vendor,
custom
});
}
keywords.set(keyword, descriptor);
return descriptor;
}
function getPropertyDescriptor(property) {
if (properties.has(property)) {
return properties.get(property);
}
let name = property;
let hack = property[0];
if (hack === '/') {
hack = property[1] === '/' ? '//' : '/';
} else if (hack !== '_' &&
hack !== '*' &&
hack !== '$' &&
hack !== '#' &&
hack !== '+' &&
hack !== '&') {
hack = '';
}
const custom = isCustomProperty(name, hack.length);
// re-use result when possible (the same as for lower case)
if (!custom) {
name = name.toLowerCase();
if (properties.has(name)) {
const descriptor = properties.get(name);
properties.set(property, descriptor);
return descriptor;
}
}
const vendor = !custom ? getVendorPrefix(name, hack.length) : '';
const prefix = name.substr(0, hack.length + vendor.length);
const descriptor = Object.freeze({
basename: name.substr(prefix.length),
name: name.substr(hack.length),
hack,
vendor,
prefix,
custom
});
properties.set(property, descriptor);
return descriptor;
}
;// ./node_modules/css-tree/lib/lexer/generic-const.js
// https://drafts.csswg.org/css-cascade-5/
const cssWideKeywords = [
'initial',
'inherit',
'unset',
'revert',
'revert-layer'
];
;// ./node_modules/css-tree/lib/lexer/generic-an-plus-b.js
const generic_an_plus_b_PLUSSIGN = 0x002B; // U+002B PLUS SIGN (+)
const generic_an_plus_b_HYPHENMINUS = 0x002D; // U+002D HYPHEN-MINUS (-)
const generic_an_plus_b_N = 0x006E; // U+006E LATIN SMALL LETTER N (n)
const DISALLOW_SIGN = true;
const ALLOW_SIGN = false;
function isDelim(token, code) {
return token !== null && token.type === Delim && token.value.charCodeAt(0) === code;
}
function skipSC(token, offset, getNextToken) {
while (token !== null && (token.type === WhiteSpace || token.type === Comment)) {
token = getNextToken(++offset);
}
return offset;
}
function checkInteger(token, valueOffset, disallowSign, offset) {
if (!token) {
return 0;
}
const code = token.value.charCodeAt(valueOffset);
if (code === generic_an_plus_b_PLUSSIGN || code === generic_an_plus_b_HYPHENMINUS) {
if (disallowSign) {
// Number sign is not allowed
return 0;
}
valueOffset++;
}
for (; valueOffset < token.value.length; valueOffset++) {
if (!isDigit(token.value.charCodeAt(valueOffset))) {
// Integer is expected
return 0;
}
}
return offset + 1;
}
// ... <signed-integer>
// ... ['+' | '-'] <signless-integer>
function consumeB(token, offset_, getNextToken) {
let sign = false;
let offset = skipSC(token, offset_, getNextToken);
token = getNextToken(offset);
if (token === null) {
return offset_;
}
if (token.type !== types_Number) {
if (isDelim(token, generic_an_plus_b_PLUSSIGN) || isDelim(token, generic_an_plus_b_HYPHENMINUS)) {
sign = true;
offset = skipSC(getNextToken(++offset), offset, getNextToken);
token = getNextToken(offset);
if (token === null || token.type !== types_Number) {
return 0;
}
} else {
return offset_;
}
}
if (!sign) {
const code = token.value.charCodeAt(0);
if (code !== generic_an_plus_b_PLUSSIGN && code !== generic_an_plus_b_HYPHENMINUS) {
// Number sign is expected
return 0;
}
}
return checkInteger(token, sign ? 0 : 1, sign, offset);
}
// An+B microsyntax https://www.w3.org/TR/css-syntax-3/#anb
function anPlusB(token, getNextToken) {
/* eslint-disable brace-style*/
let offset = 0;
if (!token) {
return 0;
}
// <integer>
if (token.type === types_Number) {
return checkInteger(token, 0, ALLOW_SIGN, offset); // b
}
// -n
// -n <signed-integer>
// -n ['+' | '-'] <signless-integer>
// -n- <signless-integer>
// <dashndashdigit-ident>
else if (token.type === Ident && token.value.charCodeAt(0) === generic_an_plus_b_HYPHENMINUS) {
// expect 1st char is N
if (!cmpChar(token.value, 1, generic_an_plus_b_N)) {
return 0;
}
switch (token.value.length) {
// -n
// -n <signed-integer>
// -n ['+' | '-'] <signless-integer>
case 2:
return consumeB(getNextToken(++offset), offset, getNextToken);
// -n- <signless-integer>
case 3:
if (token.value.charCodeAt(2) !== generic_an_plus_b_HYPHENMINUS) {
return 0;
}
offset = skipSC(getNextToken(++offset), offset, getNextToken);
token = getNextToken(offset);
return checkInteger(token, 0, DISALLOW_SIGN, offset);
// <dashndashdigit-ident>
default:
if (token.value.charCodeAt(2) !== generic_an_plus_b_HYPHENMINUS) {
return 0;
}
return checkInteger(token, 3, DISALLOW_SIGN, offset);
}
}
// '+'? n
// '+'? n <signed-integer>
// '+'? n ['+' | '-'] <signless-integer>
// '+'? n- <signless-integer>
// '+'? <ndashdigit-ident>
else if (token.type === Ident || (isDelim(token, generic_an_plus_b_PLUSSIGN) && getNextToken(offset + 1).type === Ident)) {
// just ignore a plus
if (token.type !== Ident) {
token = getNextToken(++offset);
}
if (token === null || !cmpChar(token.value, 0, generic_an_plus_b_N)) {
return 0;
}
switch (token.value.length) {
// '+'? n
// '+'? n <signed-integer>
// '+'? n ['+' | '-'] <signless-integer>
case 1:
return consumeB(getNextToken(++offset), offset, getNextToken);
// '+'? n- <signless-integer>
case 2:
if (token.value.charCodeAt(1) !== generic_an_plus_b_HYPHENMINUS) {
return 0;
}
offset = skipSC(getNextToken(++offset), offset, getNextToken);
token = getNextToken(offset);
return checkInteger(token, 0, DISALLOW_SIGN, offset);
// '+'? <ndashdigit-ident>
default:
if (token.value.charCodeAt(1) !== generic_an_plus_b_HYPHENMINUS) {
return 0;
}
return checkInteger(token, 2, DISALLOW_SIGN, offset);
}
}
// <ndashdigit-dimension>
// <ndash-dimension> <signless-integer>
// <n-dimension>
// <n-dimension> <signed-integer>
// <n-dimension> ['+' | '-'] <signless-integer>
else if (token.type === Dimension) {
let code = token.value.charCodeAt(0);
let sign = code === generic_an_plus_b_PLUSSIGN || code === generic_an_plus_b_HYPHENMINUS ? 1 : 0;
let i = sign;
for (; i < token.value.length; i++) {
if (!isDigit(token.value.charCodeAt(i))) {
break;
}
}
if (i === sign) {
// Integer is expected
return 0;
}
if (!cmpChar(token.value, i, generic_an_plus_b_N)) {
return 0;
}
// <n-dimension>
// <n-dimension> <signed-integer>
// <n-dimension> ['+' | '-'] <signless-integer>
if (i + 1 === token.value.length) {
return consumeB(getNextToken(++offset), offset, getNextToken);
} else {
if (token.value.charCodeAt(i + 1) !== generic_an_plus_b_HYPHENMINUS) {
return 0;
}
// <ndash-dimension> <signless-integer>
if (i + 2 === token.value.length) {
offset = skipSC(getNextToken(++offset), offset, getNextToken);
token = getNextToken(offset);
return checkInteger(token, 0, DISALLOW_SIGN, offset);
}
// <ndashdigit-dimension>
else {
return checkInteger(token, i + 2, DISALLOW_SIGN, offset);
}
}
}
return 0;
};
;// ./node_modules/css-tree/lib/lexer/generic-urange.js
const generic_urange_PLUSSIGN = 0x002B; // U+002B PLUS SIGN (+)
const generic_urange_HYPHENMINUS = 0x002D; // U+002D HYPHEN-MINUS (-)
const QUESTIONMARK = 0x003F; // U+003F QUESTION MARK (?)
const U = 0x0075; // U+0075 LATIN SMALL LETTER U (u)
function generic_urange_isDelim(token, code) {
return token !== null && token.type === Delim && token.value.charCodeAt(0) === code;
}
function startsWith(token, code) {
return token.value.charCodeAt(0) === code;
}
function hexSequence(token, offset, allowDash) {
let hexlen = 0;
for (let pos = offset; pos < token.value.length; pos++) {
const code = token.value.charCodeAt(pos);
if (code === generic_urange_HYPHENMINUS && allowDash && hexlen !== 0) {
hexSequence(token, offset + hexlen + 1, false);
return 6; // dissallow following question marks
}
if (!isHexDigit(code)) {
return 0; // not a hex digit
}
if (++hexlen > 6) {
return 0; // too many hex digits
};
}
return hexlen;
}
function withQuestionMarkSequence(consumed, length, getNextToken) {
if (!consumed) {
return 0; // nothing consumed
}
while (generic_urange_isDelim(getNextToken(length), QUESTIONMARK)) {
if (++consumed > 6) {
return 0; // too many question marks
}
length++;
}
return length;
}
// https://drafts.csswg.org/css-syntax/#urange
// Informally, the <urange> production has three forms:
// U+0001
// Defines a range consisting of a single code point, in this case the code point "1".
// U+0001-00ff
// Defines a range of codepoints between the first and the second value, in this case
// the range between "1" and "ff" (255 in decimal) inclusive.
// U+00??
// Defines a range of codepoints where the "?" characters range over all hex digits,
// in this case defining the same as the value U+0000-00ff.
// In each form, a maximum of 6 digits is allowed for each hexadecimal number (if you treat "?" as a hexadecimal digit).
//
// <urange> =
// u '+' <ident-token> '?'* |
// u <dimension-token> '?'* |
// u <number-token> '?'* |
// u <number-token> <dimension-token> |
// u <number-token> <number-token> |
// u '+' '?'+
function urange(token, getNextToken) {
let length = 0;
// should start with `u` or `U`
if (token === null || token.type !== Ident || !cmpChar(token.value, 0, U)) {
return 0;
}
token = getNextToken(++length);
if (token === null) {
return 0;
}
// u '+' <ident-token> '?'*
// u '+' '?'+
if (generic_urange_isDelim(token, generic_urange_PLUSSIGN)) {
token = getNextToken(++length);
if (token === null) {
return 0;
}
if (token.type === Ident) {
// u '+' <ident-token> '?'*
return withQuestionMarkSequence(hexSequence(token, 0, true), ++length, getNextToken);
}
if (generic_urange_isDelim(token, QUESTIONMARK)) {
// u '+' '?'+
return withQuestionMarkSequence(1, ++length, getNextToken);
}
// Hex digit or question mark is expected
return 0;
}
// u <number-token> '?'*
// u <number-token> <dimension-token>
// u <number-token> <number-token>
if (token.type === types_Number) {
const consumedHexLength = hexSequence(token, 1, true);
if (consumedHexLength === 0) {
return 0;
}
token = getNextToken(++length);
if (token === null) {
// u <number-token> <eof>
return length;
}
if (token.type === Dimension || token.type === types_Number) {
// u <number-token> <dimension-token>
// u <number-token> <number-token>
if (!startsWith(token, generic_urange_HYPHENMINUS) || !hexSequence(token, 1, false)) {
return 0;
}
return length + 1;
}
// u <number-token> '?'*
return withQuestionMarkSequence(consumedHexLength, length, getNextToken);
}
// u <dimension-token> '?'*
if (token.type === Dimension) {
return withQuestionMarkSequence(hexSequence(token, 1, true), ++length, getNextToken);
}
return 0;
};
;// ./node_modules/css-tree/lib/lexer/generic.js
const calcFunctionNames = ['calc(', '-moz-calc(', '-webkit-calc('];
const generic_balancePair = new Map([
[Function, RightParenthesis],
[LeftParenthesis, RightParenthesis],
[LeftSquareBracket, RightSquareBracket],
[LeftCurlyBracket, RightCurlyBracket]
]);
// safe char code getter
function charCodeAt(str, index) {
return index < str.length ? str.charCodeAt(index) : 0;
}
function eqStr(actual, expected) {
return cmpStr(actual, 0, actual.length, expected);
}
function eqStrAny(actual, expected) {
for (let i = 0; i < expected.length; i++) {
if (eqStr(actual, expected[i])) {
return true;
}
}
return false;
}
// IE postfix hack, i.e. 123\0 or 123px\9
function isPostfixIeHack(str, offset) {
if (offset !== str.length - 2) {
return false;
}
return (
charCodeAt(str, offset) === 0x005C && // U+005C REVERSE SOLIDUS (\)
isDigit(charCodeAt(str, offset + 1))
);
}
function outOfRange(opts, value, numEnd) {
if (opts && opts.type === 'Range') {
const num = Number(
numEnd !== undefined && numEnd !== value.length
? value.substr(0, numEnd)
: value
);
if (isNaN(num)) {
return true;
}
// FIXME: when opts.min is a string it's a dimension, skip a range validation
// for now since it requires a type covertation which is not implmented yet
if (opts.min !== null && num < opts.min && typeof opts.min !== 'string') {
return true;
}
// FIXME: when opts.max is a string it's a dimension, skip a range validation
// for now since it requires a type covertation which is not implmented yet
if (opts.max !== null && num > opts.max && typeof opts.max !== 'string') {
return true;
}
}
return false;
}
function consumeFunction(token, getNextToken) {
let balanceCloseType = 0;
let balanceStash = [];
let length = 0;
// balanced token consuming
scan:
do {
switch (token.type) {
case RightCurlyBracket:
case RightParenthesis:
case RightSquareBracket:
if (token.type !== balanceCloseType) {
break scan;
}
balanceCloseType = balanceStash.pop();
if (balanceStash.length === 0) {
length++;
break scan;
}
break;
case Function:
case LeftParenthesis:
case LeftSquareBracket:
case LeftCurlyBracket:
balanceStash.push(balanceCloseType);
balanceCloseType = generic_balancePair.get(token.type);
break;
}
length++;
} while (token = getNextToken(length));
return length;
}
// TODO: implement
// can be used wherever <length>, <frequency>, <angle>, <time>, <percentage>, <number>, or <integer> values are allowed
// https://drafts.csswg.org/css-values/#calc-notation
function calc(next) {
return function(token, getNextToken, opts) {
if (token === null) {
return 0;
}
if (token.type === Function && eqStrAny(token.value, calcFunctionNames)) {
return consumeFunction(token, getNextToken);
}
return next(token, getNextToken, opts);
};
}
function tokenType(expectedTokenType) {
return function(token) {
if (token === null || token.type !== expectedTokenType) {
return 0;
}
return 1;
};
}
// =========================
// Complex types
//
// https://drafts.csswg.org/css-values-4/#custom-idents
// 4.2. Author-defined Identifiers: the <custom-ident> type
// Some properties accept arbitrary author-defined identifiers as a component value.
// This generic data type is denoted by <custom-ident>, and represents any valid CSS identifier
// that would not be misinterpreted as a pre-defined keyword in that property’s value definition.
//
// See also: https://developer.mozilla.org/en-US/docs/Web/CSS/custom-ident
function customIdent(token) {
if (token === null || token.type !== Ident) {
return 0;
}
const name = token.value.toLowerCase();
// The CSS-wide keywords are not valid <custom-ident>s
if (eqStrAny(name, cssWideKeywords)) {
return 0;
}
// The default keyword is reserved and is also not a valid <custom-ident>
if (eqStr(name, 'default')) {
return 0;
}
// TODO: ignore property specific keywords (as described https://developer.mozilla.org/en-US/docs/Web/CSS/custom-ident)
// Specifications using <custom-ident> must specify clearly what other keywords
// are excluded from <custom-ident>, if any—for example by saying that any pre-defined keywords
// in that property’s value definition are excluded. Excluded keywords are excluded
// in all ASCII case permutations.
return 1;
}
// https://drafts.csswg.org/css-variables/#typedef-custom-property-name
// A custom property is any property whose name starts with two dashes (U+002D HYPHEN-MINUS), like --foo.
// The <custom-property-name> production corresponds to this: it’s defined as any valid identifier
// that starts with two dashes, except -- itself, which is reserved for future use by CSS.
// NOTE: Current implementation treat `--` as a valid name since most (all?) major browsers treat it as valid.
function customPropertyName(token) {
// ... defined as any valid identifier
if (token === null || token.type !== Ident) {
return 0;
}
// ... that starts with two dashes (U+002D HYPHEN-MINUS)
if (charCodeAt(token.value, 0) !== 0x002D || charCodeAt(token.value, 1) !== 0x002D) {
return 0;
}
return 1;
}
// https://drafts.csswg.org/css-color-4/#hex-notation
// The syntax of a <hex-color> is a <hash-token> token whose value consists of 3, 4, 6, or 8 hexadecimal digits.
// In other words, a hex color is written as a hash character, "#", followed by some number of digits 0-9 or
// letters a-f (the case of the letters doesn’t matter - #00ff00 is identical to #00FF00).
function hexColor(token) {
if (token === null || token.type !== Hash) {
return 0;
}
const length = token.value.length;
// valid values (length): #rgb (4), #rgba (5), #rrggbb (7), #rrggbbaa (9)
if (length !== 4 && length !== 5 && length !== 7 && length !== 9) {
return 0;
}
for (let i = 1; i < length; i++) {
if (!isHexDigit(charCodeAt(token.value, i))) {
return 0;
}
}
return 1;
}
function idSelector(token) {
if (token === null || token.type !== Hash) {
return 0;
}
if (!isIdentifierStart(charCodeAt(token.value, 1), charCodeAt(token.value, 2), charCodeAt(token.value, 3))) {
return 0;
}
return 1;
}
// https://drafts.csswg.org/css-syntax/#any-value
// It represents the entirety of what a valid declaration can have as its value.
function declarationValue(token, getNextToken) {
if (!token) {
return 0;
}
let balanceCloseType = 0;
let balanceStash = [];
let length = 0;
// The <declaration-value> production matches any sequence of one or more tokens,
// so long as the sequence does not contain ...
scan:
do {
switch (token.type) {
// ... <bad-string-token>, <bad-url-token>,
case BadString:
case BadUrl:
break scan;
// ... unmatched <)-token>, <]-token>, or <}-token>,
case RightCurlyBracket:
case RightParenthesis:
case RightSquareBracket:
if (token.type !== balanceCloseType) {
break scan;
}
balanceCloseType = balanceStash.pop();
break;
// ... or top-level <semicolon-token> tokens
case Semicolon:
if (balanceCloseType === 0) {
break scan;
}
break;
// ... or <delim-token> tokens with a value of "!"
case Delim:
if (balanceCloseType === 0 && token.value === '!') {
break scan;
}
break;
case Function:
case LeftParenthesis:
case LeftSquareBracket:
case LeftCurlyBracket:
balanceStash.push(balanceCloseType);
balanceCloseType = generic_balancePair.get(token.type);
break;
}
length++;
} while (token = getNextToken(length));
return length;
}
// https://drafts.csswg.org/css-syntax/#any-value
// The <any-value> production is identical to <declaration-value>, but also
// allows top-level <semicolon-token> tokens and <delim-token> tokens
// with a value of "!". It represents the entirety of what valid CSS can be in any context.
function anyValue(token, getNextToken) {
if (!token) {
return 0;
}
let balanceCloseType = 0;
let balanceStash = [];
let length = 0;
// The <any-value> production matches any sequence of one or more tokens,
// so long as the sequence ...
scan:
do {
switch (token.type) {
// ... does not contain <bad-string-token>, <bad-url-token>,
case BadString:
case BadUrl:
break scan;
// ... unmatched <)-token>, <]-token>, or <}-token>,
case RightCurlyBracket:
case RightParenthesis:
case RightSquareBracket:
if (token.type !== balanceCloseType) {
break scan;
}
balanceCloseType = balanceStash.pop();
break;
case Function:
case LeftParenthesis:
case LeftSquareBracket:
case LeftCurlyBracket:
balanceStash.push(balanceCloseType);
balanceCloseType = generic_balancePair.get(token.type);
break;
}
length++;
} while (token = getNextToken(length));
return length;
}
// =========================
// Dimensions
//
function dimension(type) {
if (type) {
type = new Set(type);
}
return function(token, getNextToken, opts) {
if (token === null || token.type !== Dimension) {
return 0;
}
const numberEnd = consumeNumber(token.value, 0);
// check unit
if (type !== null) {
// check for IE postfix hack, i.e. 123px\0 or 123px\9
const reverseSolidusOffset = token.value.indexOf('\\', numberEnd);
const unit = reverseSolidusOffset === -1 || !isPostfixIeHack(token.value, reverseSolidusOffset)
? token.value.substr(numberEnd)
: token.value.substring(numberEnd, reverseSolidusOffset);
if (type.has(unit.toLowerCase()) === false) {
return 0;
}
}
// check range if specified
if (outOfRange(opts, token.value, numberEnd)) {
return 0;
}
return 1;
};
}
// =========================
// Percentage
//
// §5.5. Percentages: the <percentage> type
// https://drafts.csswg.org/css-values-4/#percentages
function percentage(token, getNextToken, opts) {
// ... corresponds to the <percentage-token> production
if (token === null || token.type !== Percentage) {
return 0;
}
// check range if specified
if (outOfRange(opts, token.value, token.value.length - 1)) {
return 0;
}
return 1;
}
// =========================
// Numeric
//
// https://drafts.csswg.org/css-values-4/#numbers
// The value <zero> represents a literal number with the value 0. Expressions that merely
// evaluate to a <number> with the value 0 (for example, calc(0)) do not match <zero>;
// only literal <number-token>s do.
function zero(next) {
if (typeof next !== 'function') {
next = function() {
return 0;
};
}
return function(token, getNextToken, opts) {
if (token !== null && token.type === types_Number) {
if (Number(token.value) === 0) {
return 1;
}
}
return next(token, getNextToken, opts);
};
}
// § 5.3. Real Numbers: the <number> type
// https://drafts.csswg.org/css-values-4/#numbers
// Number values are denoted by <number>, and represent real numbers, possibly with a fractional component.
// ... It corresponds to the <number-token> production
function number(token, getNextToken, opts) {
if (token === null) {
return 0;
}
const numberEnd = consumeNumber(token.value, 0);
const isNumber = numberEnd === token.value.length;
if (!isNumber && !isPostfixIeHack(token.value, numberEnd)) {
return 0;
}
// check range if specified
if (outOfRange(opts, token.value, numberEnd)) {
return 0;
}
return 1;
}
// §5.2. Integers: the <integer> type
// https://drafts.csswg.org/css-values-4/#integers
function integer(token, getNextToken, opts) {
// ... corresponds to a subset of the <number-token> production
if (token === null || token.type !== types_Number) {
return 0;
}
// The first digit of an integer may be immediately preceded by `-` or `+` to indicate the integer’s sign.
let i = charCodeAt(token.value, 0) === 0x002B || // U+002B PLUS SIGN (+)
charCodeAt(token.value, 0) === 0x002D ? 1 : 0; // U+002D HYPHEN-MINUS (-)
// When written literally, an integer is one or more decimal digits 0 through 9 ...
for (; i < token.value.length; i++) {
if (!isDigit(charCodeAt(token.value, i))) {
return 0;
}
}
// check range if specified
if (outOfRange(opts, token.value, i)) {
return 0;
}
return 1;
}
// token types
const tokenTypes = {
'ident-token': tokenType(Ident),
'function-token': tokenType(Function),
'at-keyword-token': tokenType(AtKeyword),
'hash-token': tokenType(Hash),
'string-token': tokenType(types_String),
'bad-string-token': tokenType(BadString),
'url-token': tokenType(Url),
'bad-url-token': tokenType(BadUrl),
'delim-token': tokenType(Delim),
'number-token': tokenType(types_Number),
'percentage-token': tokenType(Percentage),
'dimension-token': tokenType(Dimension),
'whitespace-token': tokenType(WhiteSpace),
'CDO-token': tokenType(CDO),
'CDC-token': tokenType(CDC),
'colon-token': tokenType(Colon),
'semicolon-token': tokenType(Semicolon),
'comma-token': tokenType(Comma),
'[-token': tokenType(LeftSquareBracket),
']-token': tokenType(RightSquareBracket),
'(-token': tokenType(LeftParenthesis),
')-token': tokenType(RightParenthesis),
'{-token': tokenType(LeftCurlyBracket),
'}-token': tokenType(RightCurlyBracket)
};
// token production types
const productionTypes = {
// token type aliases
'string': tokenType(types_String),
'ident': tokenType(Ident),
// percentage
'percentage': calc(percentage),
// numeric
'zero': zero(),
'number': calc(number),
'integer': calc(integer),
// complex types
'custom-ident': customIdent,
'custom-property-name': customPropertyName,
'hex-color': hexColor,
'id-selector': idSelector, // element( <id-selector> )
'an-plus-b': anPlusB,
'urange': urange,
'declaration-value': declarationValue,
'any-value': anyValue
};
const unitGroups = (/* unused pure expression or super */ null && ([
'length',
'angle',
'time',
'frequency',
'resolution',
'flex',
'decibel',
'semitones'
]));
// dimensions types depend on units set
function createDemensionTypes(units) {
const {
angle,
decibel,
frequency,
flex,
length,
resolution,
semitones,
time
} = units || {};
return {
'dimension': calc(dimension(null)),
'angle': calc(dimension(angle)),
'decibel': calc(dimension(decibel)),
'frequency': calc(dimension(frequency)),
'flex': calc(dimension(flex)),
'length': calc(zero(dimension(length))),
'resolution': calc(dimension(resolution)),
'semitones': calc(dimension(semitones)),
'time': calc(dimension(time))
};
}
function createGenericTypes(units) {
return {
...tokenTypes,
...productionTypes,
...createDemensionTypes(units)
};
};
;// ./node_modules/css-tree/lib/lexer/units.js
const units_length = [
// absolute length units https://www.w3.org/TR/css-values-3/#lengths
'cm', 'mm', 'q', 'in', 'pt', 'pc', 'px',
// font-relative length units https://drafts.csswg.org/css-values-4/#font-relative-lengths
'em', 'rem',
'ex', 'rex',
'cap', 'rcap',
'ch', 'rch',
'ic', 'ric',
'lh', 'rlh',
// viewport-percentage lengths https://drafts.csswg.org/css-values-4/#viewport-relative-lengths
'vw', 'svw', 'lvw', 'dvw',
'vh', 'svh', 'lvh', 'dvh',
'vi', 'svi', 'lvi', 'dvi',
'vb', 'svb', 'lvb', 'dvb',
'vmin', 'svmin', 'lvmin', 'dvmin',
'vmax', 'svmax', 'lvmax', 'dvmax',
// container relative lengths https://drafts.csswg.org/css-contain-3/#container-lengths
'cqw', 'cqh', 'cqi', 'cqb', 'cqmin', 'cqmax'
];
const angle = ['deg', 'grad', 'rad', 'turn']; // https://www.w3.org/TR/css-values-3/#angles
const time = ['s', 'ms']; // https://www.w3.org/TR/css-values-3/#time
const frequency = ['hz', 'khz']; // https://www.w3.org/TR/css-values-3/#frequency
const resolution = ['dpi', 'dpcm', 'dppx', 'x']; // https://www.w3.org/TR/css-values-3/#resolution
const flex = ['fr']; // https://drafts.csswg.org/css-grid/#fr-unit
const decibel = ['db']; // https://www.w3.org/TR/css3-speech/#mixing-props-voice-volume
const semitones = ['st']; // https://www.w3.org/TR/css3-speech/#voice-props-voice-pitch
;// ./node_modules/css-tree/lib/definition-syntax/SyntaxError.js
function definition_syntax_SyntaxError_SyntaxError(message, input, offset) {
return Object.assign(createCustomError('SyntaxError', message), {
input,
offset,
rawMessage: message,
message: message + '\n' +
' ' + input + '\n' +
'--' + new Array((offset || input.length) + 1).join('-') + '^'
});
};
;// ./node_modules/css-tree/lib/definition-syntax/tokenizer.js
const TAB = 9;
const tokenizer_N = 10;
const tokenizer_F = 12;
const tokenizer_R = 13;
const SPACE = 32;
class Tokenizer {
constructor(str) {
this.str = str;
this.pos = 0;
}
charCodeAt(pos) {
return pos < this.str.length ? this.str.charCodeAt(pos) : 0;
}
charCode() {
return this.charCodeAt(this.pos);
}
nextCharCode() {
return this.charCodeAt(this.pos + 1);
}
nextNonWsCode(pos) {
return this.charCodeAt(this.findWsEnd(pos));
}
findWsEnd(pos) {
for (; pos < this.str.length; pos++) {
const code = this.str.charCodeAt(pos);
if (code !== tokenizer_R && code !== tokenizer_N && code !== tokenizer_F && code !== SPACE && code !== TAB) {
break;
}
}
return pos;
}
substringToPos(end) {
return this.str.substring(this.pos, this.pos = end);
}
eat(code) {
if (this.charCode() !== code) {
this.error('Expect `' + String.fromCharCode(code) + '`');
}
this.pos++;
}
peek() {
return this.pos < this.str.length ? this.str.charAt(this.pos++) : '';
}
error(message) {
throw new definition_syntax_SyntaxError_SyntaxError(message, this.str, this.pos);
}
};
;// ./node_modules/css-tree/lib/definition-syntax/parse.js
const parse_TAB = 9;
const parse_N = 10;
const parse_F = 12;
const parse_R = 13;
const parse_SPACE = 32;
const parse_EXCLAMATIONMARK = 33; // !
const parse_NUMBERSIGN = 35; // #
const AMPERSAND = 38; // &
const APOSTROPHE = 39; // '
const LEFTPARENTHESIS = 40; // (
const RIGHTPARENTHESIS = 41; // )
const ASTERISK = 42; // *
const parse_PLUSSIGN = 43; // +
const COMMA = 44; // ,
const HYPERMINUS = 45; // -
const LESSTHANSIGN = 60; // <
const GREATERTHANSIGN = 62; // >
const parse_QUESTIONMARK = 63; // ?
const COMMERCIALAT = 64; // @
const LEFTSQUAREBRACKET = 91; // [
const RIGHTSQUAREBRACKET = 93; // ]
const parse_LEFTCURLYBRACKET = 123; // {
const VERTICALLINE = 124; // |
const RIGHTCURLYBRACKET = 125; // }
const INFINITY = 8734; // ∞
const NAME_CHAR = new Uint8Array(128).map((_, idx) =>
/[a-zA-Z0-9\-]/.test(String.fromCharCode(idx)) ? 1 : 0
);
const COMBINATOR_PRECEDENCE = {
' ': 1,
'&&': 2,
'||': 3,
'|': 4
};
function scanSpaces(tokenizer) {
return tokenizer.substringToPos(
tokenizer.findWsEnd(tokenizer.pos)
);
}
function scanWord(tokenizer) {
let end = tokenizer.pos;
for (; end < tokenizer.str.length; end++) {
const code = tokenizer.str.charCodeAt(end);
if (code >= 128 || NAME_CHAR[code] === 0) {
break;
}
}
if (tokenizer.pos === end) {
tokenizer.error('Expect a keyword');
}
return tokenizer.substringToPos(end);
}
function scanNumber(tokenizer) {
let end = tokenizer.pos;
for (; end < tokenizer.str.length; end++) {
const code = tokenizer.str.charCodeAt(end);
if (code < 48 || code > 57) {
break;
}
}
if (tokenizer.pos === end) {
tokenizer.error('Expect a number');
}
return tokenizer.substringToPos(end);
}
function scanString(tokenizer) {
const end = tokenizer.str.indexOf('\'', tokenizer.pos + 1);
if (end === -1) {
tokenizer.pos = tokenizer.str.length;
tokenizer.error('Expect an apostrophe');
}
return tokenizer.substringToPos(end + 1);
}
function readMultiplierRange(tokenizer) {
let min = null;
let max = null;
tokenizer.eat(parse_LEFTCURLYBRACKET);
min = scanNumber(tokenizer);
if (tokenizer.charCode() === COMMA) {
tokenizer.pos++;
if (tokenizer.charCode() !== RIGHTCURLYBRACKET) {
max = scanNumber(tokenizer);
}
} else {
max = min;
}
tokenizer.eat(RIGHTCURLYBRACKET);
return {
min: Number(min),
max: max ? Number(max) : 0
};
}
function readMultiplier(tokenizer) {
let range = null;
let comma = false;
switch (tokenizer.charCode()) {
case ASTERISK:
tokenizer.pos++;
range = {
min: 0,
max: 0
};
break;
case parse_PLUSSIGN:
tokenizer.pos++;
range = {
min: 1,
max: 0
};
break;
case parse_QUESTIONMARK:
tokenizer.pos++;
range = {
min: 0,
max: 1
};
break;
case parse_NUMBERSIGN:
tokenizer.pos++;
comma = true;
if (tokenizer.charCode() === parse_LEFTCURLYBRACKET) {
range = readMultiplierRange(tokenizer);
} else if (tokenizer.charCode() === parse_QUESTIONMARK) {
// https://www.w3.org/TR/css-values-4/#component-multipliers
// > the # and ? multipliers may be stacked as #?
// In this case just treat "#?" as a single multiplier
// { min: 0, max: 0, comma: true }
tokenizer.pos++;
range = {
min: 0,
max: 0
};
} else {
range = {
min: 1,
max: 0
};
}
break;
case parse_LEFTCURLYBRACKET:
range = readMultiplierRange(tokenizer);
break;
default:
return null;
}
return {
type: 'Multiplier',
comma,
min: range.min,
max: range.max,
term: null
};
}
function maybeMultiplied(tokenizer, node) {
const multiplier = readMultiplier(tokenizer);
if (multiplier !== null) {
multiplier.term = node;
// https://www.w3.org/TR/css-values-4/#component-multipliers
// > The + and # multipliers may be stacked as +#;
// Represent "+#" as nested multipliers:
// { ...<multiplier #>,
// term: {
// ...<multipler +>,
// term: node
// }
// }
if (tokenizer.charCode() === parse_NUMBERSIGN &&
tokenizer.charCodeAt(tokenizer.pos - 1) === parse_PLUSSIGN) {
return maybeMultiplied(tokenizer, multiplier);
}
return multiplier;
}
return node;
}
function maybeToken(tokenizer) {
const ch = tokenizer.peek();
if (ch === '') {
return null;
}
return {
type: 'Token',
value: ch
};
}
function readProperty(tokenizer) {
let name;
tokenizer.eat(LESSTHANSIGN);
tokenizer.eat(APOSTROPHE);
name = scanWord(tokenizer);
tokenizer.eat(APOSTROPHE);
tokenizer.eat(GREATERTHANSIGN);
return maybeMultiplied(tokenizer, {
type: 'Property',
name
});
}
// https://drafts.csswg.org/css-values-3/#numeric-ranges
// 4.1. Range Restrictions and Range Definition Notation
//
// Range restrictions can be annotated in the numeric type notation using CSS bracketed
// range notation—[min,max]—within the angle brackets, after the identifying keyword,
// indicating a closed range between (and including) min and max.
// For example, <integer [0, 10]> indicates an integer between 0 and 10, inclusive.
function readTypeRange(tokenizer) {
// use null for Infinity to make AST format JSON serializable/deserializable
let min = null; // -Infinity
let max = null; // Infinity
let sign = 1;
tokenizer.eat(LEFTSQUAREBRACKET);
if (tokenizer.charCode() === HYPERMINUS) {
tokenizer.peek();
sign = -1;
}
if (sign == -1 && tokenizer.charCode() === INFINITY) {
tokenizer.peek();
} else {
min = sign * Number(scanNumber(tokenizer));
if (NAME_CHAR[tokenizer.charCode()] !== 0) {
min += scanWord(tokenizer);
}
}
scanSpaces(tokenizer);
tokenizer.eat(COMMA);
scanSpaces(tokenizer);
if (tokenizer.charCode() === INFINITY) {
tokenizer.peek();
} else {
sign = 1;
if (tokenizer.charCode() === HYPERMINUS) {
tokenizer.peek();
sign = -1;
}
max = sign * Number(scanNumber(tokenizer));
if (NAME_CHAR[tokenizer.charCode()] !== 0) {
max += scanWord(tokenizer);
}
}
tokenizer.eat(RIGHTSQUAREBRACKET);
return {
type: 'Range',
min,
max
};
}
function readType(tokenizer) {
let name;
let opts = null;
tokenizer.eat(LESSTHANSIGN);
name = scanWord(tokenizer);
if (tokenizer.charCode() === LEFTPARENTHESIS &&
tokenizer.nextCharCode() === RIGHTPARENTHESIS) {
tokenizer.pos += 2;
name += '()';
}
if (tokenizer.charCodeAt(tokenizer.findWsEnd(tokenizer.pos)) === LEFTSQUAREBRACKET) {
scanSpaces(tokenizer);
opts = readTypeRange(tokenizer);
}
tokenizer.eat(GREATERTHANSIGN);
return maybeMultiplied(tokenizer, {
type: 'Type',
name,
opts
});
}
function readKeywordOrFunction(tokenizer) {
const name = scanWord(tokenizer);
if (tokenizer.charCode() === LEFTPARENTHESIS) {
tokenizer.pos++;
return {
type: 'Function',
name
};
}
return maybeMultiplied(tokenizer, {
type: 'Keyword',
name
});
}
function regroupTerms(terms, combinators) {
function createGroup(terms, combinator) {
return {
type: 'Group',
terms,
combinator,
disallowEmpty: false,
explicit: false
};
}
let combinator;
combinators = Object.keys(combinators)
.sort((a, b) => COMBINATOR_PRECEDENCE[a] - COMBINATOR_PRECEDENCE[b]);
while (combinators.length > 0) {
combinator = combinators.shift();
let i = 0;
let subgroupStart = 0;
for (; i < terms.length; i++) {
const term = terms[i];
if (term.type === 'Combinator') {
if (term.value === combinator) {
if (subgroupStart === -1) {
subgroupStart = i - 1;
}
terms.splice(i, 1);
i--;
} else {
if (subgroupStart !== -1 && i - subgroupStart > 1) {
terms.splice(
subgroupStart,
i - subgroupStart,
createGroup(terms.slice(subgroupStart, i), combinator)
);
i = subgroupStart + 1;
}
subgroupStart = -1;
}
}
}
if (subgroupStart !== -1 && combinators.length) {
terms.splice(
subgroupStart,
i - subgroupStart,
createGroup(terms.slice(subgroupStart, i), combinator)
);
}
}
return combinator;
}
function readImplicitGroup(tokenizer) {
const terms = [];
const combinators = {};
let token;
let prevToken = null;
let prevTokenPos = tokenizer.pos;
while (token = peek(tokenizer)) {
if (token.type !== 'Spaces') {
if (token.type === 'Combinator') {
// check for combinator in group beginning and double combinator sequence
if (prevToken === null || prevToken.type === 'Combinator') {
tokenizer.pos = prevTokenPos;
tokenizer.error('Unexpected combinator');
}
combinators[token.value] = true;
} else if (prevToken !== null && prevToken.type !== 'Combinator') {
combinators[' '] = true; // a b
terms.push({
type: 'Combinator',
value: ' '
});
}
terms.push(token);
prevToken = token;
prevTokenPos = tokenizer.pos;
}
}
// check for combinator in group ending
if (prevToken !== null && prevToken.type === 'Combinator') {
tokenizer.pos -= prevTokenPos;
tokenizer.error('Unexpected combinator');
}
return {
type: 'Group',
terms,
combinator: regroupTerms(terms, combinators) || ' ',
disallowEmpty: false,
explicit: false
};
}
function readGroup(tokenizer) {
let result;
tokenizer.eat(LEFTSQUAREBRACKET);
result = readImplicitGroup(tokenizer);
tokenizer.eat(RIGHTSQUAREBRACKET);
result.explicit = true;
if (tokenizer.charCode() === parse_EXCLAMATIONMARK) {
tokenizer.pos++;
result.disallowEmpty = true;
}
return result;
}
function peek(tokenizer) {
let code = tokenizer.charCode();
if (code < 128 && NAME_CHAR[code] === 1) {
return readKeywordOrFunction(tokenizer);
}
switch (code) {
case RIGHTSQUAREBRACKET:
// don't eat, stop scan a group
break;
case LEFTSQUAREBRACKET:
return maybeMultiplied(tokenizer, readGroup(tokenizer));
case LESSTHANSIGN:
return tokenizer.nextCharCode() === APOSTROPHE
? readProperty(tokenizer)
: readType(tokenizer);
case VERTICALLINE:
return {
type: 'Combinator',
value: tokenizer.substringToPos(
tokenizer.pos + (tokenizer.nextCharCode() === VERTICALLINE ? 2 : 1)
)
};
case AMPERSAND:
tokenizer.pos++;
tokenizer.eat(AMPERSAND);
return {
type: 'Combinator',
value: '&&'
};
case COMMA:
tokenizer.pos++;
return {
type: 'Comma'
};
case APOSTROPHE:
return maybeMultiplied(tokenizer, {
type: 'String',
value: scanString(tokenizer)
});
case parse_SPACE:
case parse_TAB:
case parse_N:
case parse_R:
case parse_F:
return {
type: 'Spaces',
value: scanSpaces(tokenizer)
};
case COMMERCIALAT:
code = tokenizer.nextCharCode();
if (code < 128 && NAME_CHAR[code] === 1) {
tokenizer.pos++;
return {
type: 'AtKeyword',
name: scanWord(tokenizer)
};
}
return maybeToken(tokenizer);
case ASTERISK:
case parse_PLUSSIGN:
case parse_QUESTIONMARK:
case parse_NUMBERSIGN:
case parse_EXCLAMATIONMARK:
// prohibited tokens (used as a multiplier start)
break;
case parse_LEFTCURLYBRACKET:
// LEFTCURLYBRACKET is allowed since mdn/data uses it w/o quoting
// check next char isn't a number, because it's likely a disjoined multiplier
code = tokenizer.nextCharCode();
if (code < 48 || code > 57) {
return maybeToken(tokenizer);
}
break;
default:
return maybeToken(tokenizer);
}
}
function parse(source) {
const tokenizer = new Tokenizer(source);
const result = readImplicitGroup(tokenizer);
if (tokenizer.pos !== source.length) {
tokenizer.error('Unexpected input');
}
// reduce redundant groups with single group term
if (result.terms.length === 1 && result.terms[0].type === 'Group') {
return result.terms[0];
}
return result;
};
;// ./node_modules/css-tree/lib/definition-syntax/walk.js
const walk_noop = function() {};
function walk_ensureFunction(value) {
return typeof value === 'function' ? value : walk_noop;
}
function walk(node, options, context) {
function walk(node) {
enter.call(context, node);
switch (node.type) {
case 'Group':
node.terms.forEach(walk);
break;
case 'Multiplier':
walk(node.term);
break;
case 'Type':
case 'Property':
case 'Keyword':
case 'AtKeyword':
case 'Function':
case 'String':
case 'Token':
case 'Comma':
break;
default:
throw new Error('Unknown type: ' + node.type);
}
leave.call(context, node);
}
let enter = walk_noop;
let leave = walk_noop;
if (typeof options === 'function') {
enter = options;
} else if (options) {
enter = walk_ensureFunction(options.enter);
leave = walk_ensureFunction(options.leave);
}
if (enter === walk_noop && leave === walk_noop) {
throw new Error('Neither `enter` nor `leave` walker handler is set or both aren\'t a function');
}
walk(node, context);
};
;// ./node_modules/css-tree/lib/definition-syntax/index.js
;// ./node_modules/css-tree/lib/lexer/prepare-tokens.js
const astToTokens = {
decorator(handlers) {
const tokens = [];
let curNode = null;
return {
...handlers,
node(node) {
const tmp = curNode;
curNode = node;
handlers.node.call(this, node);
curNode = tmp;
},
emit(value, type, auto) {
tokens.push({
type,
value,
node: auto ? null : curNode
});
},
result() {
return tokens;
}
};
}
};
function stringToTokens(str) {
const tokens = [];
tokenize(str, (type, start, end) =>
tokens.push({
type,
value: str.slice(start, end),
node: null
})
);
return tokens;
}
/* harmony default export */ function prepare_tokens(value, syntax) {
if (typeof value === 'string') {
return stringToTokens(value);
}
return syntax.generate(value, astToTokens);
};
;// ./node_modules/css-tree/lib/lexer/match-graph.js
const MATCH = { type: 'Match' };
const MISMATCH = { type: 'Mismatch' };
const DISALLOW_EMPTY = { type: 'DisallowEmpty' };
const match_graph_LEFTPARENTHESIS = 40; // (
const match_graph_RIGHTPARENTHESIS = 41; // )
function createCondition(match, thenBranch, elseBranch) {
// reduce node count
if (thenBranch === MATCH && elseBranch === MISMATCH) {
return match;
}
if (match === MATCH && thenBranch === MATCH && elseBranch === MATCH) {
return match;
}
if (match.type === 'If' && match.else === MISMATCH && thenBranch === MATCH) {
thenBranch = match.then;
match = match.match;
}
return {
type: 'If',
match,
then: thenBranch,
else: elseBranch
};
}
function isFunctionType(name) {
return (
name.length > 2 &&
name.charCodeAt(name.length - 2) === match_graph_LEFTPARENTHESIS &&
name.charCodeAt(name.length - 1) === match_graph_RIGHTPARENTHESIS
);
}
function isEnumCapatible(term) {
return (
term.type === 'Keyword' ||
term.type === 'AtKeyword' ||
term.type === 'Function' ||
term.type === 'Type' && isFunctionType(term.name)
);
}
function buildGroupMatchGraph(combinator, terms, atLeastOneTermMatched) {
switch (combinator) {
case ' ': {
// Juxtaposing components means that all of them must occur, in the given order.
//
// a b c
// =
// match a
// then match b
// then match c
// then MATCH
// else MISMATCH
// else MISMATCH
// else MISMATCH
let result = MATCH;
for (let i = terms.length - 1; i >= 0; i--) {
const term = terms[i];
result = createCondition(
term,
result,
MISMATCH
);
};
return result;
}
case '|': {
// A bar (|) separates two or more alternatives: exactly one of them must occur.
//
// a | b | c
// =
// match a
// then MATCH
// else match b
// then MATCH
// else match c
// then MATCH
// else MISMATCH
let result = MISMATCH;
let map = null;
for (let i = terms.length - 1; i >= 0; i--) {
let term = terms[i];
// reduce sequence of keywords into a Enum
if (isEnumCapatible(term)) {
if (map === null && i > 0 && isEnumCapatible(terms[i - 1])) {
map = Object.create(null);
result = createCondition(
{
type: 'Enum',
map
},
MATCH,
result
);
}
if (map !== null) {
const key = (isFunctionType(term.name) ? term.name.slice(0, -1) : term.name).toLowerCase();
if (key in map === false) {
map[key] = term;
continue;
}
}
}
map = null;
// create a new conditonal node
result = createCondition(
term,
MATCH,
result
);
};
return result;
}
case '&&': {
// A double ampersand (&&) separates two or more components,
// all of which must occur, in any order.
// Use MatchOnce for groups with a large number of terms,
// since &&-groups produces at least N!-node trees
if (terms.length > 5) {
return {
type: 'MatchOnce',
terms,
all: true
};
}
// Use a combination tree for groups with small number of terms
//
// a && b && c
// =
// match a
// then [b && c]
// else match b
// then [a && c]
// else match c
// then [a && b]
// else MISMATCH
//
// a && b
// =
// match a
// then match b
// then MATCH
// else MISMATCH
// else match b
// then match a
// then MATCH
// else MISMATCH
// else MISMATCH
let result = MISMATCH;
for (let i = terms.length - 1; i >= 0; i--) {
const term = terms[i];
let thenClause;
if (terms.length > 1) {
thenClause = buildGroupMatchGraph(
combinator,
terms.filter(function(newGroupTerm) {
return newGroupTerm !== term;
}),
false
);
} else {
thenClause = MATCH;
}
result = createCondition(
term,
thenClause,
result
);
};
return result;
}
case '||': {
// A double bar (||) separates two or more options:
// one or more of them must occur, in any order.
// Use MatchOnce for groups with a large number of terms,
// since ||-groups produces at least N!-node trees
if (terms.length > 5) {
return {
type: 'MatchOnce',
terms,
all: false
};
}
// Use a combination tree for groups with small number of terms
//
// a || b || c
// =
// match a
// then [b || c]
// else match b
// then [a || c]
// else match c
// then [a || b]
// else MISMATCH
//
// a || b
// =
// match a
// then match b
// then MATCH
// else MATCH
// else match b
// then match a
// then MATCH
// else MATCH
// else MISMATCH
let result = atLeastOneTermMatched ? MATCH : MISMATCH;
for (let i = terms.length - 1; i >= 0; i--) {
const term = terms[i];
let thenClause;
if (terms.length > 1) {
thenClause = buildGroupMatchGraph(
combinator,
terms.filter(function(newGroupTerm) {
return newGroupTerm !== term;
}),
true
);
} else {
thenClause = MATCH;
}
result = createCondition(
term,
thenClause,
result
);
};
return result;
}
}
}
function buildMultiplierMatchGraph(node) {
let result = MATCH;
let matchTerm = buildMatchGraphInternal(node.term);
if (node.max === 0) {
// disable repeating of empty match to prevent infinite loop
matchTerm = createCondition(
matchTerm,
DISALLOW_EMPTY,
MISMATCH
);
// an occurrence count is not limited, make a cycle;
// to collect more terms on each following matching mismatch
result = createCondition(
matchTerm,
null, // will be a loop
MISMATCH
);
result.then = createCondition(
MATCH,
MATCH,
result // make a loop
);
if (node.comma) {
result.then.else = createCondition(
{ type: 'Comma', syntax: node },
result,
MISMATCH
);
}
} else {
// create a match node chain for [min .. max] interval with optional matches
for (let i = node.min || 1; i <= node.max; i++) {
if (node.comma && result !== MATCH) {
result = createCondition(
{ type: 'Comma', syntax: node },
result,
MISMATCH
);
}
result = createCondition(
matchTerm,
createCondition(
MATCH,
MATCH,
result
),
MISMATCH
);
}
}
if (node.min === 0) {
// allow zero match
result = createCondition(
MATCH,
MATCH,
result
);
} else {
// create a match node chain to collect [0 ... min - 1] required matches
for (let i = 0; i < node.min - 1; i++) {
if (node.comma && result !== MATCH) {
result = createCondition(
{ type: 'Comma', syntax: node },
result,
MISMATCH
);
}
result = createCondition(
matchTerm,
result,
MISMATCH
);
}
}
return result;
}
function buildMatchGraphInternal(node) {
if (typeof node === 'function') {
return {
type: 'Generic',
fn: node
};
}
switch (node.type) {
case 'Group': {
let result = buildGroupMatchGraph(
node.combinator,
node.terms.map(buildMatchGraphInternal),
false
);
if (node.disallowEmpty) {
result = createCondition(
result,
DISALLOW_EMPTY,
MISMATCH
);
}
return result;
}
case 'Multiplier':
return buildMultiplierMatchGraph(node);
case 'Type':
case 'Property':
return {
type: node.type,
name: node.name,
syntax: node
};
case 'Keyword':
return {
type: node.type,
name: node.name.toLowerCase(),
syntax: node
};
case 'AtKeyword':
return {
type: node.type,
name: '@' + node.name.toLowerCase(),
syntax: node
};
case 'Function':
return {
type: node.type,
name: node.name.toLowerCase() + '(',
syntax: node
};
case 'String':
// convert a one char length String to a Token
if (node.value.length === 3) {
return {
type: 'Token',
value: node.value.charAt(1),
syntax: node
};
}
// otherwise use it as is
return {
type: node.type,
value: node.value.substr(1, node.value.length - 2).replace(/\\'/g, '\''),
syntax: node
};
case 'Token':
return {
type: node.type,
value: node.value,
syntax: node
};
case 'Comma':
return {
type: node.type,
syntax: node
};
default:
throw new Error('Unknown node type:', node.type);
}
}
function buildMatchGraph(syntaxTree, ref) {
if (typeof syntaxTree === 'string') {
syntaxTree = parse(syntaxTree);
}
return {
type: 'MatchGraph',
match: buildMatchGraphInternal(syntaxTree),
syntax: ref || null,
source: syntaxTree
};
}
;// ./node_modules/css-tree/lib/lexer/match.js
const { hasOwnProperty: match_hasOwnProperty } = Object.prototype;
const STUB = 0;
const TOKEN = 1;
const OPEN_SYNTAX = 2;
const CLOSE_SYNTAX = 3;
const EXIT_REASON_MATCH = 'Match';
const EXIT_REASON_MISMATCH = 'Mismatch';
const EXIT_REASON_ITERATION_LIMIT = 'Maximum iteration number exceeded (please fill an issue on https://github.com/csstree/csstree/issues)';
const ITERATION_LIMIT = 15000;
let totalIterationCount = 0;
function reverseList(list) {
let prev = null;
let next = null;
let item = list;
while (item !== null) {
next = item.prev;
item.prev = prev;
prev = item;
item = next;
}
return prev;
}
function areStringsEqualCaseInsensitive(testStr, referenceStr) {
if (testStr.length !== referenceStr.length) {
return false;
}
for (let i = 0; i < testStr.length; i++) {
const referenceCode = referenceStr.charCodeAt(i);
let testCode = testStr.charCodeAt(i);
// testCode.toLowerCase() for U+0041 LATIN CAPITAL LETTER A (A) .. U+005A LATIN CAPITAL LETTER Z (Z).
if (testCode >= 0x0041 && testCode <= 0x005A) {
testCode = testCode | 32;
}
if (testCode !== referenceCode) {
return false;
}
}
return true;
}
function isContextEdgeDelim(token) {
if (token.type !== Delim) {
return false;
}
// Fix matching for unicode-range: U+30??, U+FF00-FF9F
// Probably we need to check out previous match instead
return token.value !== '?';
}
function isCommaContextStart(token) {
if (token === null) {
return true;
}
return (
token.type === Comma ||
token.type === Function ||
token.type === LeftParenthesis ||
token.type === LeftSquareBracket ||
token.type === LeftCurlyBracket ||
isContextEdgeDelim(token)
);
}
function isCommaContextEnd(token) {
if (token === null) {
return true;
}
return (
token.type === RightParenthesis ||
token.type === RightSquareBracket ||
token.type === RightCurlyBracket ||
(token.type === Delim && token.value === '/')
);
}
function internalMatch(tokens, state, syntaxes) {
function moveToNextToken() {
do {
tokenIndex++;
token = tokenIndex < tokens.length ? tokens[tokenIndex] : null;
} while (token !== null && (token.type === WhiteSpace || token.type === Comment));
}
function getNextToken(offset) {
const nextIndex = tokenIndex + offset;
return nextIndex < tokens.length ? tokens[nextIndex] : null;
}
function stateSnapshotFromSyntax(nextState, prev) {
return {
nextState,
matchStack,
syntaxStack,
thenStack,
tokenIndex,
prev
};
}
function pushThenStack(nextState) {
thenStack = {
nextState,
matchStack,
syntaxStack,
prev: thenStack
};
}
function pushElseStack(nextState) {
elseStack = stateSnapshotFromSyntax(nextState, elseStack);
}
function addTokenToMatch() {
matchStack = {
type: TOKEN,
syntax: state.syntax,
token,
prev: matchStack
};
moveToNextToken();
syntaxStash = null;
if (tokenIndex > longestMatch) {
longestMatch = tokenIndex;
}
}
function openSyntax() {
syntaxStack = {
syntax: state.syntax,
opts: state.syntax.opts || (syntaxStack !== null && syntaxStack.opts) || null,
prev: syntaxStack
};
matchStack = {
type: OPEN_SYNTAX,
syntax: state.syntax,
token: matchStack.token,
prev: matchStack
};
}
function closeSyntax() {
if (matchStack.type === OPEN_SYNTAX) {
matchStack = matchStack.prev;
} else {
matchStack = {
type: CLOSE_SYNTAX,
syntax: syntaxStack.syntax,
token: matchStack.token,
prev: matchStack
};
}
syntaxStack = syntaxStack.prev;
}
let syntaxStack = null;
let thenStack = null;
let elseStack = null;
// null – stashing allowed, nothing stashed
// false – stashing disabled, nothing stashed
// anithing else – fail stashable syntaxes, some syntax stashed
let syntaxStash = null;
let iterationCount = 0; // count iterations and prevent infinite loop
let exitReason = null;
let token = null;
let tokenIndex = -1;
let longestMatch = 0;
let matchStack = {
type: STUB,
syntax: null,
token: null,
prev: null
};
moveToNextToken();
while (exitReason === null && ++iterationCount < ITERATION_LIMIT) {
// function mapList(list, fn) {
// const result = [];
// while (list) {
// result.unshift(fn(list));
// list = list.prev;
// }
// return result;
// }
// console.log('--\n',
// '#' + iterationCount,
// require('util').inspect({
// match: mapList(matchStack, x => x.type === TOKEN ? x.token && x.token.value : x.syntax ? ({ [OPEN_SYNTAX]: '<', [CLOSE_SYNTAX]: '</' }[x.type] || x.type) + '!' + x.syntax.name : null),
// token: token && token.value,
// tokenIndex,
// syntax: syntax.type + (syntax.id ? ' #' + syntax.id : '')
// }, { depth: null })
// );
switch (state.type) {
case 'Match':
if (thenStack === null) {
// turn to MISMATCH when some tokens left unmatched
if (token !== null) {
// doesn't mismatch if just one token left and it's an IE hack
if (tokenIndex !== tokens.length - 1 || (token.value !== '\\0' && token.value !== '\\9')) {
state = MISMATCH;
break;
}
}
// break the main loop, return a result - MATCH
exitReason = EXIT_REASON_MATCH;
break;
}
// go to next syntax (`then` branch)
state = thenStack.nextState;
// check match is not empty
if (state === DISALLOW_EMPTY) {
if (thenStack.matchStack === matchStack) {
state = MISMATCH;
break;
} else {
state = MATCH;
}
}
// close syntax if needed
while (thenStack.syntaxStack !== syntaxStack) {
closeSyntax();
}
// pop stack
thenStack = thenStack.prev;
break;
case 'Mismatch':
// when some syntax is stashed
if (syntaxStash !== null && syntaxStash !== false) {
// there is no else branches or a branch reduce match stack
if (elseStack === null || tokenIndex > elseStack.tokenIndex) {
// restore state from the stash
elseStack = syntaxStash;
syntaxStash = false; // disable stashing
}
} else if (elseStack === null) {
// no else branches -> break the main loop
// return a result - MISMATCH
exitReason = EXIT_REASON_MISMATCH;
break;
}
// go to next syntax (`else` branch)
state = elseStack.nextState;
// restore all the rest stack states
thenStack = elseStack.thenStack;
syntaxStack = elseStack.syntaxStack;
matchStack = elseStack.matchStack;
tokenIndex = elseStack.tokenIndex;
token = tokenIndex < tokens.length ? tokens[tokenIndex] : null;
// pop stack
elseStack = elseStack.prev;
break;
case 'MatchGraph':
state = state.match;
break;
case 'If':
// IMPORTANT: else stack push must go first,
// since it stores the state of thenStack before changes
if (state.else !== MISMATCH) {
pushElseStack(state.else);
}
if (state.then !== MATCH) {
pushThenStack(state.then);
}
state = state.match;
break;
case 'MatchOnce':
state = {
type: 'MatchOnceBuffer',
syntax: state,
index: 0,
mask: 0
};
break;
case 'MatchOnceBuffer': {
const terms = state.syntax.terms;
if (state.index === terms.length) {
// no matches at all or it's required all terms to be matched
if (state.mask === 0 || state.syntax.all) {
state = MISMATCH;
break;
}
// a partial match is ok
state = MATCH;
break;
}
// all terms are matched
if (state.mask === (1 << terms.length) - 1) {
state = MATCH;
break;
}
for (; state.index < terms.length; state.index++) {
const matchFlag = 1 << state.index;
if ((state.mask & matchFlag) === 0) {
// IMPORTANT: else stack push must go first,
// since it stores the state of thenStack before changes
pushElseStack(state);
pushThenStack({
type: 'AddMatchOnce',
syntax: state.syntax,
mask: state.mask | matchFlag
});
// match
state = terms[state.index++];
break;
}
}
break;
}
case 'AddMatchOnce':
state = {
type: 'MatchOnceBuffer',
syntax: state.syntax,
index: 0,
mask: state.mask
};
break;
case 'Enum':
if (token !== null) {
let name = token.value.toLowerCase();
// drop \0 and \9 hack from keyword name
if (name.indexOf('\\') !== -1) {
name = name.replace(/\\[09].*$/, '');
}
if (match_hasOwnProperty.call(state.map, name)) {
state = state.map[name];
break;
}
}
state = MISMATCH;
break;
case 'Generic': {
const opts = syntaxStack !== null ? syntaxStack.opts : null;
const lastTokenIndex = tokenIndex + Math.floor(state.fn(token, getNextToken, opts));
if (!isNaN(lastTokenIndex) && lastTokenIndex > tokenIndex) {
while (tokenIndex < lastTokenIndex) {
addTokenToMatch();
}
state = MATCH;
} else {
state = MISMATCH;
}
break;
}
case 'Type':
case 'Property': {
const syntaxDict = state.type === 'Type' ? 'types' : 'properties';
const dictSyntax = match_hasOwnProperty.call(syntaxes, syntaxDict) ? syntaxes[syntaxDict][state.name] : null;
if (!dictSyntax || !dictSyntax.match) {
throw new Error(
'Bad syntax reference: ' +
(state.type === 'Type'
? '<' + state.name + '>'
: '<\'' + state.name + '\'>')
);
}
// stash a syntax for types with low priority
if (syntaxStash !== false && token !== null && state.type === 'Type') {
const lowPriorityMatching =
// https://drafts.csswg.org/css-values-4/#custom-idents
// When parsing positionally-ambiguous keywords in a property value, a <custom-ident> production
// can only claim the keyword if no other unfulfilled production can claim it.
(state.name === 'custom-ident' && token.type === Ident) ||
// https://drafts.csswg.org/css-values-4/#lengths
// ... if a `0` could be parsed as either a <number> or a <length> in a property (such as line-height),
// it must parse as a <number>
(state.name === 'length' && token.value === '0');
if (lowPriorityMatching) {
if (syntaxStash === null) {
syntaxStash = stateSnapshotFromSyntax(state, elseStack);
}
state = MISMATCH;
break;
}
}
openSyntax();
state = dictSyntax.match;
break;
}
case 'Keyword': {
const name = state.name;
if (token !== null) {
let keywordName = token.value;
// drop \0 and \9 hack from keyword name
if (keywordName.indexOf('\\') !== -1) {
keywordName = keywordName.replace(/\\[09].*$/, '');
}
if (areStringsEqualCaseInsensitive(keywordName, name)) {
addTokenToMatch();
state = MATCH;
break;
}
}
state = MISMATCH;
break;
}
case 'AtKeyword':
case 'Function':
if (token !== null && areStringsEqualCaseInsensitive(token.value, state.name)) {
addTokenToMatch();
state = MATCH;
break;
}
state = MISMATCH;
break;
case 'Token':
if (token !== null && token.value === state.value) {
addTokenToMatch();
state = MATCH;
break;
}
state = MISMATCH;
break;
case 'Comma':
if (token !== null && token.type === Comma) {
if (isCommaContextStart(matchStack.token)) {
state = MISMATCH;
} else {
addTokenToMatch();
state = isCommaContextEnd(token) ? MISMATCH : MATCH;
}
} else {
state = isCommaContextStart(matchStack.token) || isCommaContextEnd(token) ? MATCH : MISMATCH;
}
break;
case 'String':
let string = '';
let lastTokenIndex = tokenIndex;
for (; lastTokenIndex < tokens.length && string.length < state.value.length; lastTokenIndex++) {
string += tokens[lastTokenIndex].value;
}
if (areStringsEqualCaseInsensitive(string, state.value)) {
while (tokenIndex < lastTokenIndex) {
addTokenToMatch();
}
state = MATCH;
} else {
state = MISMATCH;
}
break;
default:
throw new Error('Unknown node type: ' + state.type);
}
}
totalIterationCount += iterationCount;
switch (exitReason) {
case null:
console.warn('[csstree-match] BREAK after ' + ITERATION_LIMIT + ' iterations');
exitReason = EXIT_REASON_ITERATION_LIMIT;
matchStack = null;
break;
case EXIT_REASON_MATCH:
while (syntaxStack !== null) {
closeSyntax();
}
break;
default:
matchStack = null;
}
return {
tokens,
reason: exitReason,
iterations: iterationCount,
match: matchStack,
longestMatch
};
}
function matchAsList(tokens, matchGraph, syntaxes) {
const matchResult = internalMatch(tokens, matchGraph, syntaxes || {});
if (matchResult.match !== null) {
let item = reverseList(matchResult.match).prev;
matchResult.match = [];
while (item !== null) {
switch (item.type) {
case OPEN_SYNTAX:
case CLOSE_SYNTAX:
matchResult.match.push({
type: item.type,
syntax: item.syntax
});
break;
default:
matchResult.match.push({
token: item.token.value,
node: item.token.node
});
break;
}
item = item.prev;
}
}
return matchResult;
}
function matchAsTree(tokens, matchGraph, syntaxes) {
const matchResult = internalMatch(tokens, matchGraph, syntaxes || {});
if (matchResult.match === null) {
return matchResult;
}
let item = matchResult.match;
let host = matchResult.match = {
syntax: matchGraph.syntax || null,
match: []
};
const hostStack = [host];
// revert a list and start with 2nd item since 1st is a stub item
item = reverseList(item).prev;
// build a tree
while (item !== null) {
switch (item.type) {
case OPEN_SYNTAX:
host.match.push(host = {
syntax: item.syntax,
match: []
});
hostStack.push(host);
break;
case CLOSE_SYNTAX:
hostStack.pop();
host = hostStack[hostStack.length - 1];
break;
default:
host.match.push({
syntax: item.syntax || null,
token: item.token.value,
node: item.token.node
});
}
item = item.prev;
}
return matchResult;
}
;// ./node_modules/css-tree/lib/lexer/trace.js
function getTrace(node) {
function shouldPutToTrace(syntax) {
if (syntax === null) {
return false;
}
return (
syntax.type === 'Type' ||
syntax.type === 'Property' ||
syntax.type === 'Keyword'
);
}
function hasMatch(matchNode) {
if (Array.isArray(matchNode.match)) {
// use for-loop for better perfomance
for (let i = 0; i < matchNode.match.length; i++) {
if (hasMatch(matchNode.match[i])) {
if (shouldPutToTrace(matchNode.syntax)) {
result.unshift(matchNode.syntax);
}
return true;
}
}
} else if (matchNode.node === node) {
result = shouldPutToTrace(matchNode.syntax)
? [matchNode.syntax]
: [];
return true;
}
return false;
}
let result = null;
if (this.matched !== null) {
hasMatch(this.matched);
}
return result;
}
function isType(node, type) {
return testNode(this, node, match => match.type === 'Type' && match.name === type);
}
function isProperty(node, property) {
return testNode(this, node, match => match.type === 'Property' && match.name === property);
}
function isKeyword(node) {
return testNode(this, node, match => match.type === 'Keyword');
}
function testNode(match, node, fn) {
const trace = getTrace.call(match, node);
if (trace === null) {
return false;
}
return trace.some(fn);
}
;// ./node_modules/css-tree/lib/lexer/search.js
function getFirstMatchNode(matchNode) {
if ('node' in matchNode) {
return matchNode.node;
}
return getFirstMatchNode(matchNode.match[0]);
}
function getLastMatchNode(matchNode) {
if ('node' in matchNode) {
return matchNode.node;
}
return getLastMatchNode(matchNode.match[matchNode.match.length - 1]);
}
function matchFragments(lexer, ast, match, type, name) {
function findFragments(matchNode) {
if (matchNode.syntax !== null &&
matchNode.syntax.type === type &&
matchNode.syntax.name === name) {
const start = getFirstMatchNode(matchNode);
const end = getLastMatchNode(matchNode);
lexer.syntax.walk(ast, function(node, item, list) {
if (node === start) {
const nodes = new List_List();
do {
nodes.appendData(item.data);
if (item.data === end) {
break;
}
item = item.next;
} while (item !== null);
fragments.push({
parent: list,
nodes
});
}
});
}
if (Array.isArray(matchNode.match)) {
matchNode.match.forEach(findFragments);
}
}
const fragments = [];
if (match.matched !== null) {
findFragments(match.matched);
}
return fragments;
}
;// ./node_modules/css-tree/lib/lexer/structure.js
const { hasOwnProperty: structure_hasOwnProperty } = Object.prototype;
function isValidNumber(value) {
// Number.isInteger(value) && value >= 0
return (
typeof value === 'number' &&
isFinite(value) &&
Math.floor(value) === value &&
value >= 0
);
}
function isValidLocation(loc) {
return (
Boolean(loc) &&
isValidNumber(loc.offset) &&
isValidNumber(loc.line) &&
isValidNumber(loc.column)
);
}
function createNodeStructureChecker(type, fields) {
return function checkNode(node, warn) {
if (!node || node.constructor !== Object) {
return warn(node, 'Type of node should be an Object');
}
for (let key in node) {
let valid = true;
if (structure_hasOwnProperty.call(node, key) === false) {
continue;
}
if (key === 'type') {
if (node.type !== type) {
warn(node, 'Wrong node type `' + node.type + '`, expected `' + type + '`');
}
} else if (key === 'loc') {
if (node.loc === null) {
continue;
} else if (node.loc && node.loc.constructor === Object) {
if (typeof node.loc.source !== 'string') {
key += '.source';
} else if (!isValidLocation(node.loc.start)) {
key += '.start';
} else if (!isValidLocation(node.loc.end)) {
key += '.end';
} else {
continue;
}
}
valid = false;
} else if (fields.hasOwnProperty(key)) {
valid = false;
for (let i = 0; !valid && i < fields[key].length; i++) {
const fieldType = fields[key][i];
switch (fieldType) {
case String:
valid = typeof node[key] === 'string';
break;
case Boolean:
valid = typeof node[key] === 'boolean';
break;
case null:
valid = node[key] === null;
break;
default:
if (typeof fieldType === 'string') {
valid = node[key] && node[key].type === fieldType;
} else if (Array.isArray(fieldType)) {
valid = node[key] instanceof List_List;
}
}
}
} else {
warn(node, 'Unknown field `' + key + '` for ' + type + ' node type');
}
if (!valid) {
warn(node, 'Bad value for `' + type + '.' + key + '`');
}
}
for (const key in fields) {
if (structure_hasOwnProperty.call(fields, key) &&
structure_hasOwnProperty.call(node, key) === false) {
warn(node, 'Field `' + type + '.' + key + '` is missed');
}
}
};
}
function processStructure(name, nodeType) {
const structure = nodeType.structure;
const fields = {
type: String,
loc: true
};
const docs = {
type: '"' + name + '"'
};
for (const key in structure) {
if (structure_hasOwnProperty.call(structure, key) === false) {
continue;
}
const docsTypes = [];
const fieldTypes = fields[key] = Array.isArray(structure[key])
? structure[key].slice()
: [structure[key]];
for (let i = 0; i < fieldTypes.length; i++) {
const fieldType = fieldTypes[i];
if (fieldType === String || fieldType === Boolean) {
docsTypes.push(fieldType.name);
} else if (fieldType === null) {
docsTypes.push('null');
} else if (typeof fieldType === 'string') {
docsTypes.push('<' + fieldType + '>');
} else if (Array.isArray(fieldType)) {
docsTypes.push('List'); // TODO: use type enum
} else {
throw new Error('Wrong value `' + fieldType + '` in `' + name + '.' + key + '` structure definition');
}
}
docs[key] = docsTypes.join(' | ');
}
return {
docs,
check: createNodeStructureChecker(name, fields)
};
}
function getStructureFromConfig(config) {
const structure = {};
if (config.node) {
for (const name in config.node) {
if (structure_hasOwnProperty.call(config.node, name)) {
const nodeType = config.node[name];
if (nodeType.structure) {
structure[name] = processStructure(name, nodeType);
} else {
throw new Error('Missed `structure` field in `' + name + '` node type definition');
}
}
}
}
return structure;
};
;// ./node_modules/css-tree/lib/lexer/Lexer.js
const cssWideKeywordsSyntax = buildMatchGraph(cssWideKeywords.join(' | '));
function dumpMapSyntax(map, compact, syntaxAsAst) {
const result = {};
for (const name in map) {
if (map[name].syntax) {
result[name] = syntaxAsAst
? map[name].syntax
: generate(map[name].syntax, { compact });
}
}
return result;
}
function dumpAtruleMapSyntax(map, compact, syntaxAsAst) {
const result = {};
for (const [name, atrule] of Object.entries(map)) {
result[name] = {
prelude: atrule.prelude && (
syntaxAsAst
? atrule.prelude.syntax
: generate(atrule.prelude.syntax, { compact })
),
descriptors: atrule.descriptors && dumpMapSyntax(atrule.descriptors, compact, syntaxAsAst)
};
}
return result;
}
function valueHasVar(tokens) {
for (let i = 0; i < tokens.length; i++) {
if (tokens[i].value.toLowerCase() === 'var(') {
return true;
}
}
return false;
}
function buildMatchResult(matched, error, iterations) {
return {
matched,
iterations,
error,
...trace_namespaceObject
};
}
function matchSyntax(lexer, syntax, value, useCssWideKeywords) {
const tokens = prepare_tokens(value, lexer.syntax);
let result;
if (valueHasVar(tokens)) {
return buildMatchResult(null, new Error('Matching for a tree with var() is not supported'));
}
if (useCssWideKeywords) {
result = matchAsTree(tokens, lexer.cssWideKeywordsSyntax, lexer);
}
if (!useCssWideKeywords || !result.match) {
result = matchAsTree(tokens, syntax.match, lexer);
if (!result.match) {
return buildMatchResult(
null,
new SyntaxMatchError(result.reason, syntax.syntax, value, result),
result.iterations
);
}
}
return buildMatchResult(result.match, null, result.iterations);
}
class Lexer {
constructor(config, syntax, structure) {
this.cssWideKeywordsSyntax = cssWideKeywordsSyntax;
this.syntax = syntax;
this.generic = false;
this.units = { ...units_namespaceObject };
this.atrules = Object.create(null);
this.properties = Object.create(null);
this.types = Object.create(null);
this.structure = structure || getStructureFromConfig(config);
if (config) {
if (config.units) {
for (const group of Object.keys(units_namespaceObject)) {
if (Array.isArray(config.units[group])) {
this.units[group] = config.units[group];
}
}
}
if (config.types) {
for (const name in config.types) {
this.addType_(name, config.types[name]);
}
}
if (config.generic) {
this.generic = true;
for (const [name, value] of Object.entries(createGenericTypes(this.units))) {
this.addType_(name, value);
}
}
if (config.atrules) {
for (const name in config.atrules) {
this.addAtrule_(name, config.atrules[name]);
}
}
if (config.properties) {
for (const name in config.properties) {
this.addProperty_(name, config.properties[name]);
}
}
}
}
checkStructure(ast) {
function collectWarning(node, message) {
warns.push({ node, message });
}
const structure = this.structure;
const warns = [];
this.syntax.walk(ast, function(node) {
if (structure.hasOwnProperty(node.type)) {
structure[node.type].check(node, collectWarning);
} else {
collectWarning(node, 'Unknown node type `' + node.type + '`');
}
});
return warns.length ? warns : false;
}
createDescriptor(syntax, type, name, parent = null) {
const ref = {
type,
name
};
const descriptor = {
type,
name,
parent,
serializable: typeof syntax === 'string' || (syntax && typeof syntax.type === 'string'),
syntax: null,
match: null
};
if (typeof syntax === 'function') {
descriptor.match = buildMatchGraph(syntax, ref);
} else {
if (typeof syntax === 'string') {
// lazy parsing on first access
Object.defineProperty(descriptor, 'syntax', {
get() {
Object.defineProperty(descriptor, 'syntax', {
value: parse(syntax)
});
return descriptor.syntax;
}
});
} else {
descriptor.syntax = syntax;
}
// lazy graph build on first access
Object.defineProperty(descriptor, 'match', {
get() {
Object.defineProperty(descriptor, 'match', {
value: buildMatchGraph(descriptor.syntax, ref)
});
return descriptor.match;
}
});
}
return descriptor;
}
addAtrule_(name, syntax) {
if (!syntax) {
return;
}
this.atrules[name] = {
type: 'Atrule',
name: name,
prelude: syntax.prelude ? this.createDescriptor(syntax.prelude, 'AtrulePrelude', name) : null,
descriptors: syntax.descriptors
? Object.keys(syntax.descriptors).reduce(
(map, descName) => {
map[descName] = this.createDescriptor(syntax.descriptors[descName], 'AtruleDescriptor', descName, name);
return map;
},
Object.create(null)
)
: null
};
}
addProperty_(name, syntax) {
if (!syntax) {
return;
}
this.properties[name] = this.createDescriptor(syntax, 'Property', name);
}
addType_(name, syntax) {
if (!syntax) {
return;
}
this.types[name] = this.createDescriptor(syntax, 'Type', name);
}
checkAtruleName(atruleName) {
if (!this.getAtrule(atruleName)) {
return new SyntaxReferenceError('Unknown at-rule', '@' + atruleName);
}
}
checkAtrulePrelude(atruleName, prelude) {
const error = this.checkAtruleName(atruleName);
if (error) {
return error;
}
const atrule = this.getAtrule(atruleName);
if (!atrule.prelude && prelude) {
return new SyntaxError('At-rule `@' + atruleName + '` should not contain a prelude');
}
if (atrule.prelude && !prelude) {
if (!matchSyntax(this, atrule.prelude, '', false).matched) {
return new SyntaxError('At-rule `@' + atruleName + '` should contain a prelude');
}
}
}
checkAtruleDescriptorName(atruleName, descriptorName) {
const error = this.checkAtruleName(atruleName);
if (error) {
return error;
}
const atrule = this.getAtrule(atruleName);
const descriptor = keyword(descriptorName);
if (!atrule.descriptors) {
return new SyntaxError('At-rule `@' + atruleName + '` has no known descriptors');
}
if (!atrule.descriptors[descriptor.name] &&
!atrule.descriptors[descriptor.basename]) {
return new SyntaxReferenceError('Unknown at-rule descriptor', descriptorName);
}
}
checkPropertyName(propertyName) {
if (!this.getProperty(propertyName)) {
return new SyntaxReferenceError('Unknown property', propertyName);
}
}
matchAtrulePrelude(atruleName, prelude) {
const error = this.checkAtrulePrelude(atruleName, prelude);
if (error) {
return buildMatchResult(null, error);
}
const atrule = this.getAtrule(atruleName);
if (!atrule.prelude) {
return buildMatchResult(null, null);
}
return matchSyntax(this, atrule.prelude, prelude || '', false);
}
matchAtruleDescriptor(atruleName, descriptorName, value) {
const error = this.checkAtruleDescriptorName(atruleName, descriptorName);
if (error) {
return buildMatchResult(null, error);
}
const atrule = this.getAtrule(atruleName);
const descriptor = keyword(descriptorName);
return matchSyntax(this, atrule.descriptors[descriptor.name] || atrule.descriptors[descriptor.basename], value, false);
}
matchDeclaration(node) {
if (node.type !== 'Declaration') {
return buildMatchResult(null, new Error('Not a Declaration node'));
}
return this.matchProperty(node.property, node.value);
}
matchProperty(propertyName, value) {
// don't match syntax for a custom property at the moment
if (names_property(propertyName).custom) {
return buildMatchResult(null, new Error('Lexer matching doesn\'t applicable for custom properties'));
}
const error = this.checkPropertyName(propertyName);
if (error) {
return buildMatchResult(null, error);
}
return matchSyntax(this, this.getProperty(propertyName), value, true);
}
matchType(typeName, value) {
const typeSyntax = this.getType(typeName);
if (!typeSyntax) {
return buildMatchResult(null, new SyntaxReferenceError('Unknown type', typeName));
}
return matchSyntax(this, typeSyntax, value, false);
}
match(syntax, value) {
if (typeof syntax !== 'string' && (!syntax || !syntax.type)) {
return buildMatchResult(null, new SyntaxReferenceError('Bad syntax'));
}
if (typeof syntax === 'string' || !syntax.match) {
syntax = this.createDescriptor(syntax, 'Type', 'anonymous');
}
return matchSyntax(this, syntax, value, false);
}
findValueFragments(propertyName, value, type, name) {
return matchFragments(this, value, this.matchProperty(propertyName, value), type, name);
}
findDeclarationValueFragments(declaration, type, name) {
return matchFragments(this, declaration.value, this.matchDeclaration(declaration), type, name);
}
findAllFragments(ast, type, name) {
const result = [];
this.syntax.walk(ast, {
visit: 'Declaration',
enter: (declaration) => {
result.push.apply(result, this.findDeclarationValueFragments(declaration, type, name));
}
});
return result;
}
getAtrule(atruleName, fallbackBasename = true) {
const atrule = keyword(atruleName);
const atruleEntry = atrule.vendor && fallbackBasename
? this.atrules[atrule.name] || this.atrules[atrule.basename]
: this.atrules[atrule.name];
return atruleEntry || null;
}
getAtrulePrelude(atruleName, fallbackBasename = true) {
const atrule = this.getAtrule(atruleName, fallbackBasename);
return atrule && atrule.prelude || null;
}
getAtruleDescriptor(atruleName, name) {
return this.atrules.hasOwnProperty(atruleName) && this.atrules.declarators
? this.atrules[atruleName].declarators[name] || null
: null;
}
getProperty(propertyName, fallbackBasename = true) {
const property = names_property(propertyName);
const propertyEntry = property.vendor && fallbackBasename
? this.properties[property.name] || this.properties[property.basename]
: this.properties[property.name];
return propertyEntry || null;
}
getType(name) {
return hasOwnProperty.call(this.types, name) ? this.types[name] : null;
}
validate() {
function validate(syntax, name, broken, descriptor) {
if (broken.has(name)) {
return broken.get(name);
}
broken.set(name, false);
if (descriptor.syntax !== null) {
walk(descriptor.syntax, function(node) {
if (node.type !== 'Type' && node.type !== 'Property') {
return;
}
const map = node.type === 'Type' ? syntax.types : syntax.properties;
const brokenMap = node.type === 'Type' ? brokenTypes : brokenProperties;
if (!hasOwnProperty.call(map, node.name) || validate(syntax, node.name, brokenMap, map[node.name])) {
broken.set(name, true);
}
}, this);
}
}
let brokenTypes = new Map();
let brokenProperties = new Map();
for (const key in this.types) {
validate(this, key, brokenTypes, this.types[key]);
}
for (const key in this.properties) {
validate(this, key, brokenProperties, this.properties[key]);
}
brokenTypes = [...brokenTypes.keys()].filter(name => brokenTypes.get(name));
brokenProperties = [...brokenProperties.keys()].filter(name => brokenProperties.get(name));
if (brokenTypes.length || brokenProperties.length) {
return {
types: brokenTypes,
properties: brokenProperties
};
}
return null;
}
dump(syntaxAsAst, pretty) {
return {
generic: this.generic,
units: this.units,
types: dumpMapSyntax(this.types, !pretty, syntaxAsAst),
properties: dumpMapSyntax(this.properties, !pretty, syntaxAsAst),
atrules: dumpAtruleMapSyntax(this.atrules, !pretty, syntaxAsAst)
};
}
toString() {
return JSON.stringify(this.dump());
}
};
;// ./node_modules/css-tree/lib/syntax/config/mix.js
function appendOrSet(a, b) {
if (typeof b === 'string' && /^\s*\|/.test(b)) {
return typeof a === 'string'
? a + b
: b.replace(/^\s*\|\s*/, '');
}
return b || null;
}
function sliceProps(obj, props) {
const result = Object.create(null);
for (const [key, value] of Object.entries(obj)) {
if (value) {
result[key] = {};
for (const prop of Object.keys(value)) {
if (props.includes(prop)) {
result[key][prop] = value[prop];
}
}
}
}
return result;
}
function mix(dest, src) {
const result = { ...dest };
for (const [prop, value] of Object.entries(src)) {
switch (prop) {
case 'generic':
result[prop] = Boolean(value);
break;
case 'units':
result[prop] = { ...dest[prop] };
for (const [name, patch] of Object.entries(value)) {
result[prop][name] = Array.isArray(patch) ? patch : [];
}
break;
case 'atrules':
result[prop] = { ...dest[prop] };
for (const [name, atrule] of Object.entries(value)) {
const exists = result[prop][name] || {};
const current = result[prop][name] = {
prelude: exists.prelude || null,
descriptors: {
...exists.descriptors
}
};
if (!atrule) {
continue;
}
current.prelude = atrule.prelude
? appendOrSet(current.prelude, atrule.prelude)
: current.prelude || null;
for (const [descriptorName, descriptorValue] of Object.entries(atrule.descriptors || {})) {
current.descriptors[descriptorName] = descriptorValue
? appendOrSet(current.descriptors[descriptorName], descriptorValue)
: null;
}
if (!Object.keys(current.descriptors).length) {
current.descriptors = null;
}
}
break;
case 'types':
case 'properties':
result[prop] = { ...dest[prop] };
for (const [name, syntax] of Object.entries(value)) {
result[prop][name] = appendOrSet(result[prop][name], syntax);
}
break;
case 'scope':
result[prop] = { ...dest[prop] };
for (const [name, props] of Object.entries(value)) {
result[prop][name] = { ...result[prop][name], ...props };
}
break;
case 'parseContext':
result[prop] = {
...dest[prop],
...value
};
break;
case 'atrule':
case 'pseudo':
result[prop] = {
...dest[prop],
...sliceProps(value, ['parse']) };
break;
case 'node':
result[prop] = {
...dest[prop],
...sliceProps(value, ['name', 'structure', 'parse', 'generate', 'walkContext'])
};
break;
}
}
return result;
}
;// ./node_modules/css-tree/lib/syntax/create.js
function createSyntax(config) {
const parse = createParser(config);
const walk = createWalker(config);
const generate = createGenerator(config);
const { fromPlainObject, toPlainObject } = createConvertor(walk);
const syntax = {
lexer: null,
createLexer: config => new Lexer(config, syntax, syntax.lexer.structure),
tokenize: tokenize,
parse,
generate,
walk,
find: walk.find,
findLast: walk.findLast,
findAll: walk.findAll,
fromPlainObject,
toPlainObject,
fork(extension) {
const base = mix({}, config); // copy of config
return createSyntax(
typeof extension === 'function'
? extension(base, Object.assign)
: mix(base, extension)
);
}
};
syntax.lexer = new Lexer({
generic: true,
units: config.units,
types: config.types,
atrules: config.atrules,
properties: config.properties,
node: config.node
}, syntax);
return syntax;
};
/* harmony default export */ const create = (config => createSyntax(mix({}, config)));
;// ./node_modules/css-tree/dist/data.js
/* harmony default export */ const data = ({
"generic": true,
"units": {
"angle": [
"deg",
"grad",
"rad",
"turn"
],
"decibel": [
"db"
],
"flex": [
"fr"
],
"frequency": [
"hz",
"khz"
],
"length": [
"cm",
"mm",
"q",
"in",
"pt",
"pc",
"px",
"em",
"rem",
"ex",
"rex",
"cap",
"rcap",
"ch",
"rch",
"ic",
"ric",
"lh",
"rlh",
"vw",
"svw",
"lvw",
"dvw",
"vh",
"svh",
"lvh",
"dvh",
"vi",
"svi",
"lvi",
"dvi",
"vb",
"svb",
"lvb",
"dvb",
"vmin",
"svmin",
"lvmin",
"dvmin",
"vmax",
"svmax",
"lvmax",
"dvmax",
"cqw",
"cqh",
"cqi",
"cqb",
"cqmin",
"cqmax"
],
"resolution": [
"dpi",
"dpcm",
"dppx",
"x"
],
"semitones": [
"st"
],
"time": [
"s",
"ms"
]
},
"types": {
"abs()": "abs( <calc-sum> )",
"absolute-size": "xx-small|x-small|small|medium|large|x-large|xx-large|xxx-large",
"acos()": "acos( <calc-sum> )",
"alpha-value": "<number>|<percentage>",
"angle-percentage": "<angle>|<percentage>",
"angular-color-hint": "<angle-percentage>",
"angular-color-stop": "<color>&&<color-stop-angle>?",
"angular-color-stop-list": "[<angular-color-stop> [, <angular-color-hint>]?]# , <angular-color-stop>",
"animateable-feature": "scroll-position|contents|<custom-ident>",
"asin()": "asin( <calc-sum> )",
"atan()": "atan( <calc-sum> )",
"atan2()": "atan2( <calc-sum> , <calc-sum> )",
"attachment": "scroll|fixed|local",
"attr()": "attr( <attr-name> <type-or-unit>? [, <attr-fallback>]? )",
"attr-matcher": "['~'|'|'|'^'|'$'|'*']? '='",
"attr-modifier": "i|s",
"attribute-selector": "'[' <wq-name> ']'|'[' <wq-name> <attr-matcher> [<string-token>|<ident-token>] <attr-modifier>? ']'",
"auto-repeat": "repeat( [auto-fill|auto-fit] , [<line-names>? <fixed-size>]+ <line-names>? )",
"auto-track-list": "[<line-names>? [<fixed-size>|<fixed-repeat>]]* <line-names>? <auto-repeat> [<line-names>? [<fixed-size>|<fixed-repeat>]]* <line-names>?",
"axis": "block|inline|vertical|horizontal",
"baseline-position": "[first|last]? baseline",
"basic-shape": "<inset()>|<circle()>|<ellipse()>|<polygon()>|<path()>",
"bg-image": "none|<image>",
"bg-layer": "<bg-image>||<bg-position> [/ <bg-size>]?||<repeat-style>||<attachment>||<box>||<box>",
"bg-position": "[[left|center|right|top|bottom|<length-percentage>]|[left|center|right|<length-percentage>] [top|center|bottom|<length-percentage>]|[center|[left|right] <length-percentage>?]&&[center|[top|bottom] <length-percentage>?]]",
"bg-size": "[<length-percentage>|auto]{1,2}|cover|contain",
"blur()": "blur( <length> )",
"blend-mode": "normal|multiply|screen|overlay|darken|lighten|color-dodge|color-burn|hard-light|soft-light|difference|exclusion|hue|saturation|color|luminosity",
"box": "border-box|padding-box|content-box",
"brightness()": "brightness( <number-percentage> )",
"calc()": "calc( <calc-sum> )",
"calc-sum": "<calc-product> [['+'|'-'] <calc-product>]*",
"calc-product": "<calc-value> ['*' <calc-value>|'/' <number>]*",
"calc-value": "<number>|<dimension>|<percentage>|<calc-constant>|( <calc-sum> )",
"calc-constant": "e|pi|infinity|-infinity|NaN",
"cf-final-image": "<image>|<color>",
"cf-mixing-image": "<percentage>?&&<image>",
"circle()": "circle( [<shape-radius>]? [at <position>]? )",
"clamp()": "clamp( <calc-sum>#{3} )",
"class-selector": "'.' <ident-token>",
"clip-source": "<url>",
"color": "<rgb()>|<rgba()>|<hsl()>|<hsla()>|<hwb()>|<lab()>|<lch()>|<hex-color>|<named-color>|currentcolor|<deprecated-system-color>",
"color-stop": "<color-stop-length>|<color-stop-angle>",
"color-stop-angle": "<angle-percentage>{1,2}",
"color-stop-length": "<length-percentage>{1,2}",
"color-stop-list": "[<linear-color-stop> [, <linear-color-hint>]?]# , <linear-color-stop>",
"combinator": "'>'|'+'|'~'|['||']",
"common-lig-values": "[common-ligatures|no-common-ligatures]",
"compat-auto": "searchfield|textarea|push-button|slider-horizontal|checkbox|radio|square-button|menulist|listbox|meter|progress-bar|button",
"composite-style": "clear|copy|source-over|source-in|source-out|source-atop|destination-over|destination-in|destination-out|destination-atop|xor",
"compositing-operator": "add|subtract|intersect|exclude",
"compound-selector": "[<type-selector>? <subclass-selector>* [<pseudo-element-selector> <pseudo-class-selector>*]*]!",
"compound-selector-list": "<compound-selector>#",
"complex-selector": "<compound-selector> [<combinator>? <compound-selector>]*",
"complex-selector-list": "<complex-selector>#",
"conic-gradient()": "conic-gradient( [from <angle>]? [at <position>]? , <angular-color-stop-list> )",
"contextual-alt-values": "[contextual|no-contextual]",
"content-distribution": "space-between|space-around|space-evenly|stretch",
"content-list": "[<string>|contents|<image>|<counter>|<quote>|<target>|<leader()>|<attr()>]+",
"content-position": "center|start|end|flex-start|flex-end",
"content-replacement": "<image>",
"contrast()": "contrast( [<number-percentage>] )",
"cos()": "cos( <calc-sum> )",
"counter": "<counter()>|<counters()>",
"counter()": "counter( <counter-name> , <counter-style>? )",
"counter-name": "<custom-ident>",
"counter-style": "<counter-style-name>|symbols( )",
"counter-style-name": "<custom-ident>",
"counters()": "counters( <counter-name> , <string> , <counter-style>? )",
"cross-fade()": "cross-fade( <cf-mixing-image> , <cf-final-image>? )",
"cubic-bezier-timing-function": "ease|ease-in|ease-out|ease-in-out|cubic-bezier( <number [0,1]> , <number> , <number [0,1]> , <number> )",
"deprecated-system-color": "ActiveBorder|ActiveCaption|AppWorkspace|Background|ButtonFace|ButtonHighlight|ButtonShadow|ButtonText|CaptionText|GrayText|Highlight|HighlightText|InactiveBorder|InactiveCaption|InactiveCaptionText|InfoBackground|InfoText|Menu|MenuText|Scrollbar|ThreeDDarkShadow|ThreeDFace|ThreeDHighlight|ThreeDLightShadow|ThreeDShadow|Window|WindowFrame|WindowText",
"discretionary-lig-values": "[discretionary-ligatures|no-discretionary-ligatures]",
"display-box": "contents|none",
"display-inside": "flow|flow-root|table|flex|grid|ruby",
"display-internal": "table-row-group|table-header-group|table-footer-group|table-row|table-cell|table-column-group|table-column|table-caption|ruby-base|ruby-text|ruby-base-container|ruby-text-container",
"display-legacy": "inline-block|inline-list-item|inline-table|inline-flex|inline-grid",
"display-listitem": "<display-outside>?&&[flow|flow-root]?&&list-item",
"display-outside": "block|inline|run-in",
"drop-shadow()": "drop-shadow( <length>{2,3} <color>? )",
"east-asian-variant-values": "[jis78|jis83|jis90|jis04|simplified|traditional]",
"east-asian-width-values": "[full-width|proportional-width]",
"element()": "element( <custom-ident> , [first|start|last|first-except]? )|element( <id-selector> )",
"ellipse()": "ellipse( [<shape-radius>{2}]? [at <position>]? )",
"ending-shape": "circle|ellipse",
"env()": "env( <custom-ident> , <declaration-value>? )",
"exp()": "exp( <calc-sum> )",
"explicit-track-list": "[<line-names>? <track-size>]+ <line-names>?",
"family-name": "<string>|<custom-ident>+",
"feature-tag-value": "<string> [<integer>|on|off]?",
"feature-type": "@stylistic|@historical-forms|@styleset|@character-variant|@swash|@ornaments|@annotation",
"feature-value-block": "<feature-type> '{' <feature-value-declaration-list> '}'",
"feature-value-block-list": "<feature-value-block>+",
"feature-value-declaration": "<custom-ident> : <integer>+ ;",
"feature-value-declaration-list": "<feature-value-declaration>",
"feature-value-name": "<custom-ident>",
"fill-rule": "nonzero|evenodd",
"filter-function": "<blur()>|<brightness()>|<contrast()>|<drop-shadow()>|<grayscale()>|<hue-rotate()>|<invert()>|<opacity()>|<saturate()>|<sepia()>",
"filter-function-list": "[<filter-function>|<url>]+",
"final-bg-layer": "<'background-color'>||<bg-image>||<bg-position> [/ <bg-size>]?||<repeat-style>||<attachment>||<box>||<box>",
"fixed-breadth": "<length-percentage>",
"fixed-repeat": "repeat( [<integer [1,∞]>] , [<line-names>? <fixed-size>]+ <line-names>? )",
"fixed-size": "<fixed-breadth>|minmax( <fixed-breadth> , <track-breadth> )|minmax( <inflexible-breadth> , <fixed-breadth> )",
"font-stretch-absolute": "normal|ultra-condensed|extra-condensed|condensed|semi-condensed|semi-expanded|expanded|extra-expanded|ultra-expanded|<percentage>",
"font-variant-css21": "[normal|small-caps]",
"font-weight-absolute": "normal|bold|<number [1,1000]>",
"frequency-percentage": "<frequency>|<percentage>",
"general-enclosed": "[<function-token> <any-value> )]|( <ident> <any-value> )",
"generic-family": "serif|sans-serif|cursive|fantasy|monospace|-apple-system",
"generic-name": "serif|sans-serif|cursive|fantasy|monospace",
"geometry-box": "<shape-box>|fill-box|stroke-box|view-box",
"gradient": "<linear-gradient()>|<repeating-linear-gradient()>|<radial-gradient()>|<repeating-radial-gradient()>|<conic-gradient()>|<repeating-conic-gradient()>|<-legacy-gradient>",
"grayscale()": "grayscale( <number-percentage> )",
"grid-line": "auto|<custom-ident>|[<integer>&&<custom-ident>?]|[span&&[<integer>||<custom-ident>]]",
"historical-lig-values": "[historical-ligatures|no-historical-ligatures]",
"hsl()": "hsl( <hue> <percentage> <percentage> [/ <alpha-value>]? )|hsl( <hue> , <percentage> , <percentage> , <alpha-value>? )",
"hsla()": "hsla( <hue> <percentage> <percentage> [/ <alpha-value>]? )|hsla( <hue> , <percentage> , <percentage> , <alpha-value>? )",
"hue": "<number>|<angle>",
"hue-rotate()": "hue-rotate( <angle> )",
"hwb()": "hwb( [<hue>|none] [<percentage>|none] [<percentage>|none] [/ [<alpha-value>|none]]? )",
"hypot()": "hypot( <calc-sum># )",
"image": "<url>|<image()>|<image-set()>|<element()>|<paint()>|<cross-fade()>|<gradient>",
"image()": "image( <image-tags>? [<image-src>? , <color>?]! )",
"image-set()": "image-set( <image-set-option># )",
"image-set-option": "[<image>|<string>] [<resolution>||type( <string> )]",
"image-src": "<url>|<string>",
"image-tags": "ltr|rtl",
"inflexible-breadth": "<length-percentage>|min-content|max-content|auto",
"inset()": "inset( <length-percentage>{1,4} [round <'border-radius'>]? )",
"invert()": "invert( <number-percentage> )",
"keyframes-name": "<custom-ident>|<string>",
"keyframe-block": "<keyframe-selector># { <declaration-list> }",
"keyframe-block-list": "<keyframe-block>+",
"keyframe-selector": "from|to|<percentage>",
"lab()": "lab( [<percentage>|<number>|none] [<percentage>|<number>|none] [<percentage>|<number>|none] [/ [<alpha-value>|none]]? )",
"layer()": "layer( <layer-name> )",
"layer-name": "<ident> ['.' <ident>]*",
"lch()": "lch( [<percentage>|<number>|none] [<percentage>|<number>|none] [<hue>|none] [/ [<alpha-value>|none]]? )",
"leader()": "leader( <leader-type> )",
"leader-type": "dotted|solid|space|<string>",
"length-percentage": "<length>|<percentage>",
"line-names": "'[' <custom-ident>* ']'",
"line-name-list": "[<line-names>|<name-repeat>]+",
"line-style": "none|hidden|dotted|dashed|solid|double|groove|ridge|inset|outset",
"line-width": "<length>|thin|medium|thick",
"linear-color-hint": "<length-percentage>",
"linear-color-stop": "<color> <color-stop-length>?",
"linear-gradient()": "linear-gradient( [<angle>|to <side-or-corner>]? , <color-stop-list> )",
"log()": "log( <calc-sum> , <calc-sum>? )",
"mask-layer": "<mask-reference>||<position> [/ <bg-size>]?||<repeat-style>||<geometry-box>||[<geometry-box>|no-clip]||<compositing-operator>||<masking-mode>",
"mask-position": "[<length-percentage>|left|center|right] [<length-percentage>|top|center|bottom]?",
"mask-reference": "none|<image>|<mask-source>",
"mask-source": "<url>",
"masking-mode": "alpha|luminance|match-source",
"matrix()": "matrix( <number>#{6} )",
"matrix3d()": "matrix3d( <number>#{16} )",
"max()": "max( <calc-sum># )",
"media-and": "<media-in-parens> [and <media-in-parens>]+",
"media-condition": "<media-not>|<media-and>|<media-or>|<media-in-parens>",
"media-condition-without-or": "<media-not>|<media-and>|<media-in-parens>",
"media-feature": "( [<mf-plain>|<mf-boolean>|<mf-range>] )",
"media-in-parens": "( <media-condition> )|<media-feature>|<general-enclosed>",
"media-not": "not <media-in-parens>",
"media-or": "<media-in-parens> [or <media-in-parens>]+",
"media-query": "<media-condition>|[not|only]? <media-type> [and <media-condition-without-or>]?",
"media-query-list": "<media-query>#",
"media-type": "<ident>",
"mf-boolean": "<mf-name>",
"mf-name": "<ident>",
"mf-plain": "<mf-name> : <mf-value>",
"mf-range": "<mf-name> ['<'|'>']? '='? <mf-value>|<mf-value> ['<'|'>']? '='? <mf-name>|<mf-value> '<' '='? <mf-name> '<' '='? <mf-value>|<mf-value> '>' '='? <mf-name> '>' '='? <mf-value>",
"mf-value": "<number>|<dimension>|<ident>|<ratio>",
"min()": "min( <calc-sum># )",
"minmax()": "minmax( [<length-percentage>|min-content|max-content|auto] , [<length-percentage>|<flex>|min-content|max-content|auto] )",
"mod()": "mod( <calc-sum> , <calc-sum> )",
"name-repeat": "repeat( [<integer [1,∞]>|auto-fill] , <line-names>+ )",
"named-color": "transparent|aliceblue|antiquewhite|aqua|aquamarine|azure|beige|bisque|black|blanchedalmond|blue|blueviolet|brown|burlywood|cadetblue|chartreuse|chocolate|coral|cornflowerblue|cornsilk|crimson|cyan|darkblue|darkcyan|darkgoldenrod|darkgray|darkgreen|darkgrey|darkkhaki|darkmagenta|darkolivegreen|darkorange|darkorchid|darkred|darksalmon|darkseagreen|darkslateblue|darkslategray|darkslategrey|darkturquoise|darkviolet|deeppink|deepskyblue|dimgray|dimgrey|dodgerblue|firebrick|floralwhite|forestgreen|fuchsia|gainsboro|ghostwhite|gold|goldenrod|gray|green|greenyellow|grey|honeydew|hotpink|indianred|indigo|ivory|khaki|lavender|lavenderblush|lawngreen|lemonchiffon|lightblue|lightcoral|lightcyan|lightgoldenrodyellow|lightgray|lightgreen|lightgrey|lightpink|lightsalmon|lightseagreen|lightskyblue|lightslategray|lightslategrey|lightsteelblue|lightyellow|lime|limegreen|linen|magenta|maroon|mediumaquamarine|mediumblue|mediumorchid|mediumpurple|mediumseagreen|mediumslateblue|mediumspringgreen|mediumturquoise|mediumvioletred|midnightblue|mintcream|mistyrose|moccasin|navajowhite|navy|oldlace|olive|olivedrab|orange|orangered|orchid|palegoldenrod|palegreen|paleturquoise|palevioletred|papayawhip|peachpuff|peru|pink|plum|powderblue|purple|rebeccapurple|red|rosybrown|royalblue|saddlebrown|salmon|sandybrown|seagreen|seashell|sienna|silver|skyblue|slateblue|slategray|slategrey|snow|springgreen|steelblue|tan|teal|thistle|tomato|turquoise|violet|wheat|white|whitesmoke|yellow|yellowgreen|<-non-standard-color>",
"namespace-prefix": "<ident>",
"ns-prefix": "[<ident-token>|'*']? '|'",
"number-percentage": "<number>|<percentage>",
"numeric-figure-values": "[lining-nums|oldstyle-nums]",
"numeric-fraction-values": "[diagonal-fractions|stacked-fractions]",
"numeric-spacing-values": "[proportional-nums|tabular-nums]",
"nth": "<an-plus-b>|even|odd",
"opacity()": "opacity( [<number-percentage>] )",
"overflow-position": "unsafe|safe",
"outline-radius": "<length>|<percentage>",
"page-body": "<declaration>? [; <page-body>]?|<page-margin-box> <page-body>",
"page-margin-box": "<page-margin-box-type> '{' <declaration-list> '}'",
"page-margin-box-type": "@top-left-corner|@top-left|@top-center|@top-right|@top-right-corner|@bottom-left-corner|@bottom-left|@bottom-center|@bottom-right|@bottom-right-corner|@left-top|@left-middle|@left-bottom|@right-top|@right-middle|@right-bottom",
"page-selector-list": "[<page-selector>#]?",
"page-selector": "<pseudo-page>+|<ident> <pseudo-page>*",
"page-size": "A5|A4|A3|B5|B4|JIS-B5|JIS-B4|letter|legal|ledger",
"path()": "path( [<fill-rule> ,]? <string> )",
"paint()": "paint( <ident> , <declaration-value>? )",
"perspective()": "perspective( [<length [0,∞]>|none] )",
"polygon()": "polygon( <fill-rule>? , [<length-percentage> <length-percentage>]# )",
"position": "[[left|center|right]||[top|center|bottom]|[left|center|right|<length-percentage>] [top|center|bottom|<length-percentage>]?|[[left|right] <length-percentage>]&&[[top|bottom] <length-percentage>]]",
"pow()": "pow( <calc-sum> , <calc-sum> )",
"pseudo-class-selector": "':' <ident-token>|':' <function-token> <any-value> ')'",
"pseudo-element-selector": "':' <pseudo-class-selector>",
"pseudo-page": ": [left|right|first|blank]",
"quote": "open-quote|close-quote|no-open-quote|no-close-quote",
"radial-gradient()": "radial-gradient( [<ending-shape>||<size>]? [at <position>]? , <color-stop-list> )",
"ratio": "<number [0,∞]> [/ <number [0,∞]>]?",
"relative-selector": "<combinator>? <complex-selector>",
"relative-selector-list": "<relative-selector>#",
"relative-size": "larger|smaller",
"rem()": "rem( <calc-sum> , <calc-sum> )",
"repeat-style": "repeat-x|repeat-y|[repeat|space|round|no-repeat]{1,2}",
"repeating-conic-gradient()": "repeating-conic-gradient( [from <angle>]? [at <position>]? , <angular-color-stop-list> )",
"repeating-linear-gradient()": "repeating-linear-gradient( [<angle>|to <side-or-corner>]? , <color-stop-list> )",
"repeating-radial-gradient()": "repeating-radial-gradient( [<ending-shape>||<size>]? [at <position>]? , <color-stop-list> )",
"reversed-counter-name": "reversed( <counter-name> )",
"rgb()": "rgb( <percentage>{3} [/ <alpha-value>]? )|rgb( <number>{3} [/ <alpha-value>]? )|rgb( <percentage>#{3} , <alpha-value>? )|rgb( <number>#{3} , <alpha-value>? )",
"rgba()": "rgba( <percentage>{3} [/ <alpha-value>]? )|rgba( <number>{3} [/ <alpha-value>]? )|rgba( <percentage>#{3} , <alpha-value>? )|rgba( <number>#{3} , <alpha-value>? )",
"rotate()": "rotate( [<angle>|<zero>] )",
"rotate3d()": "rotate3d( <number> , <number> , <number> , [<angle>|<zero>] )",
"rotateX()": "rotateX( [<angle>|<zero>] )",
"rotateY()": "rotateY( [<angle>|<zero>] )",
"rotateZ()": "rotateZ( [<angle>|<zero>] )",
"round()": "round( <rounding-strategy>? , <calc-sum> , <calc-sum> )",
"rounding-strategy": "nearest|up|down|to-zero",
"saturate()": "saturate( <number-percentage> )",
"scale()": "scale( [<number>|<percentage>]#{1,2} )",
"scale3d()": "scale3d( [<number>|<percentage>]#{3} )",
"scaleX()": "scaleX( [<number>|<percentage>] )",
"scaleY()": "scaleY( [<number>|<percentage>] )",
"scaleZ()": "scaleZ( [<number>|<percentage>] )",
"scroller": "root|nearest",
"self-position": "center|start|end|self-start|self-end|flex-start|flex-end",
"shape-radius": "<length-percentage>|closest-side|farthest-side",
"sign()": "sign( <calc-sum> )",
"skew()": "skew( [<angle>|<zero>] , [<angle>|<zero>]? )",
"skewX()": "skewX( [<angle>|<zero>] )",
"skewY()": "skewY( [<angle>|<zero>] )",
"sepia()": "sepia( <number-percentage> )",
"shadow": "inset?&&<length>{2,4}&&<color>?",
"shadow-t": "[<length>{2,3}&&<color>?]",
"shape": "rect( <top> , <right> , <bottom> , <left> )|rect( <top> <right> <bottom> <left> )",
"shape-box": "<box>|margin-box",
"side-or-corner": "[left|right]||[top|bottom]",
"sin()": "sin( <calc-sum> )",
"single-animation": "<time>||<easing-function>||<time>||<single-animation-iteration-count>||<single-animation-direction>||<single-animation-fill-mode>||<single-animation-play-state>||[none|<keyframes-name>]",
"single-animation-direction": "normal|reverse|alternate|alternate-reverse",
"single-animation-fill-mode": "none|forwards|backwards|both",
"single-animation-iteration-count": "infinite|<number>",
"single-animation-play-state": "running|paused",
"single-animation-timeline": "auto|none|<timeline-name>|scroll( <axis>? <scroller>? )",
"single-transition": "[none|<single-transition-property>]||<time>||<easing-function>||<time>",
"single-transition-property": "all|<custom-ident>",
"size": "closest-side|farthest-side|closest-corner|farthest-corner|<length>|<length-percentage>{2}",
"sqrt()": "sqrt( <calc-sum> )",
"step-position": "jump-start|jump-end|jump-none|jump-both|start|end",
"step-timing-function": "step-start|step-end|steps( <integer> [, <step-position>]? )",
"subclass-selector": "<id-selector>|<class-selector>|<attribute-selector>|<pseudo-class-selector>",
"supports-condition": "not <supports-in-parens>|<supports-in-parens> [and <supports-in-parens>]*|<supports-in-parens> [or <supports-in-parens>]*",
"supports-in-parens": "( <supports-condition> )|<supports-feature>|<general-enclosed>",
"supports-feature": "<supports-decl>|<supports-selector-fn>",
"supports-decl": "( <declaration> )",
"supports-selector-fn": "selector( <complex-selector> )",
"symbol": "<string>|<image>|<custom-ident>",
"tan()": "tan( <calc-sum> )",
"target": "<target-counter()>|<target-counters()>|<target-text()>",
"target-counter()": "target-counter( [<string>|<url>] , <custom-ident> , <counter-style>? )",
"target-counters()": "target-counters( [<string>|<url>] , <custom-ident> , <string> , <counter-style>? )",
"target-text()": "target-text( [<string>|<url>] , [content|before|after|first-letter]? )",
"time-percentage": "<time>|<percentage>",
"timeline-name": "<custom-ident>|<string>",
"easing-function": "linear|<cubic-bezier-timing-function>|<step-timing-function>",
"track-breadth": "<length-percentage>|<flex>|min-content|max-content|auto",
"track-list": "[<line-names>? [<track-size>|<track-repeat>]]+ <line-names>?",
"track-repeat": "repeat( [<integer [1,∞]>] , [<line-names>? <track-size>]+ <line-names>? )",
"track-size": "<track-breadth>|minmax( <inflexible-breadth> , <track-breadth> )|fit-content( <length-percentage> )",
"transform-function": "<matrix()>|<translate()>|<translateX()>|<translateY()>|<scale()>|<scaleX()>|<scaleY()>|<rotate()>|<skew()>|<skewX()>|<skewY()>|<matrix3d()>|<translate3d()>|<translateZ()>|<scale3d()>|<scaleZ()>|<rotate3d()>|<rotateX()>|<rotateY()>|<rotateZ()>|<perspective()>",
"transform-list": "<transform-function>+",
"translate()": "translate( <length-percentage> , <length-percentage>? )",
"translate3d()": "translate3d( <length-percentage> , <length-percentage> , <length> )",
"translateX()": "translateX( <length-percentage> )",
"translateY()": "translateY( <length-percentage> )",
"translateZ()": "translateZ( <length> )",
"type-or-unit": "string|color|url|integer|number|length|angle|time|frequency|cap|ch|em|ex|ic|lh|rlh|rem|vb|vi|vw|vh|vmin|vmax|mm|Q|cm|in|pt|pc|px|deg|grad|rad|turn|ms|s|Hz|kHz|%",
"type-selector": "<wq-name>|<ns-prefix>? '*'",
"var()": "var( <custom-property-name> , <declaration-value>? )",
"viewport-length": "auto|<length-percentage>",
"visual-box": "content-box|padding-box|border-box",
"wq-name": "<ns-prefix>? <ident-token>",
"-legacy-gradient": "<-webkit-gradient()>|<-legacy-linear-gradient>|<-legacy-repeating-linear-gradient>|<-legacy-radial-gradient>|<-legacy-repeating-radial-gradient>",
"-legacy-linear-gradient": "-moz-linear-gradient( <-legacy-linear-gradient-arguments> )|-webkit-linear-gradient( <-legacy-linear-gradient-arguments> )|-o-linear-gradient( <-legacy-linear-gradient-arguments> )",
"-legacy-repeating-linear-gradient": "-moz-repeating-linear-gradient( <-legacy-linear-gradient-arguments> )|-webkit-repeating-linear-gradient( <-legacy-linear-gradient-arguments> )|-o-repeating-linear-gradient( <-legacy-linear-gradient-arguments> )",
"-legacy-linear-gradient-arguments": "[<angle>|<side-or-corner>]? , <color-stop-list>",
"-legacy-radial-gradient": "-moz-radial-gradient( <-legacy-radial-gradient-arguments> )|-webkit-radial-gradient( <-legacy-radial-gradient-arguments> )|-o-radial-gradient( <-legacy-radial-gradient-arguments> )",
"-legacy-repeating-radial-gradient": "-moz-repeating-radial-gradient( <-legacy-radial-gradient-arguments> )|-webkit-repeating-radial-gradient( <-legacy-radial-gradient-arguments> )|-o-repeating-radial-gradient( <-legacy-radial-gradient-arguments> )",
"-legacy-radial-gradient-arguments": "[<position> ,]? [[[<-legacy-radial-gradient-shape>||<-legacy-radial-gradient-size>]|[<length>|<percentage>]{2}] ,]? <color-stop-list>",
"-legacy-radial-gradient-size": "closest-side|closest-corner|farthest-side|farthest-corner|contain|cover",
"-legacy-radial-gradient-shape": "circle|ellipse",
"-non-standard-font": "-apple-system-body|-apple-system-headline|-apple-system-subheadline|-apple-system-caption1|-apple-system-caption2|-apple-system-footnote|-apple-system-short-body|-apple-system-short-headline|-apple-system-short-subheadline|-apple-system-short-caption1|-apple-system-short-footnote|-apple-system-tall-body",
"-non-standard-color": "-moz-ButtonDefault|-moz-ButtonHoverFace|-moz-ButtonHoverText|-moz-CellHighlight|-moz-CellHighlightText|-moz-Combobox|-moz-ComboboxText|-moz-Dialog|-moz-DialogText|-moz-dragtargetzone|-moz-EvenTreeRow|-moz-Field|-moz-FieldText|-moz-html-CellHighlight|-moz-html-CellHighlightText|-moz-mac-accentdarkestshadow|-moz-mac-accentdarkshadow|-moz-mac-accentface|-moz-mac-accentlightesthighlight|-moz-mac-accentlightshadow|-moz-mac-accentregularhighlight|-moz-mac-accentregularshadow|-moz-mac-chrome-active|-moz-mac-chrome-inactive|-moz-mac-focusring|-moz-mac-menuselect|-moz-mac-menushadow|-moz-mac-menutextselect|-moz-MenuHover|-moz-MenuHoverText|-moz-MenuBarText|-moz-MenuBarHoverText|-moz-nativehyperlinktext|-moz-OddTreeRow|-moz-win-communicationstext|-moz-win-mediatext|-moz-activehyperlinktext|-moz-default-background-color|-moz-default-color|-moz-hyperlinktext|-moz-visitedhyperlinktext|-webkit-activelink|-webkit-focus-ring-color|-webkit-link|-webkit-text",
"-non-standard-image-rendering": "optimize-contrast|-moz-crisp-edges|-o-crisp-edges|-webkit-optimize-contrast",
"-non-standard-overflow": "-moz-scrollbars-none|-moz-scrollbars-horizontal|-moz-scrollbars-vertical|-moz-hidden-unscrollable",
"-non-standard-width": "fill-available|min-intrinsic|intrinsic|-moz-available|-moz-fit-content|-moz-min-content|-moz-max-content|-webkit-min-content|-webkit-max-content",
"-webkit-gradient()": "-webkit-gradient( <-webkit-gradient-type> , <-webkit-gradient-point> [, <-webkit-gradient-point>|, <-webkit-gradient-radius> , <-webkit-gradient-point>] [, <-webkit-gradient-radius>]? [, <-webkit-gradient-color-stop>]* )",
"-webkit-gradient-color-stop": "from( <color> )|color-stop( [<number-zero-one>|<percentage>] , <color> )|to( <color> )",
"-webkit-gradient-point": "[left|center|right|<length-percentage>] [top|center|bottom|<length-percentage>]",
"-webkit-gradient-radius": "<length>|<percentage>",
"-webkit-gradient-type": "linear|radial",
"-webkit-mask-box-repeat": "repeat|stretch|round",
"-webkit-mask-clip-style": "border|border-box|padding|padding-box|content|content-box|text",
"-ms-filter-function-list": "<-ms-filter-function>+",
"-ms-filter-function": "<-ms-filter-function-progid>|<-ms-filter-function-legacy>",
"-ms-filter-function-progid": "'progid:' [<ident-token> '.']* [<ident-token>|<function-token> <any-value>? )]",
"-ms-filter-function-legacy": "<ident-token>|<function-token> <any-value>? )",
"-ms-filter": "<string>",
"age": "child|young|old",
"attr-name": "<wq-name>",
"attr-fallback": "<any-value>",
"bg-clip": "<box>|border|text",
"bottom": "<length>|auto",
"generic-voice": "[<age>? <gender> <integer>?]",
"gender": "male|female|neutral",
"left": "<length>|auto",
"mask-image": "<mask-reference>#",
"paint": "none|<color>|<url> [none|<color>]?|context-fill|context-stroke",
"right": "<length>|auto",
"scroll-timeline-axis": "block|inline|vertical|horizontal",
"scroll-timeline-name": "none|<custom-ident>",
"single-animation-composition": "replace|add|accumulate",
"svg-length": "<percentage>|<length>|<number>",
"svg-writing-mode": "lr-tb|rl-tb|tb-rl|lr|rl|tb",
"top": "<length>|auto",
"x": "<number>",
"y": "<number>",
"declaration": "<ident-token> : <declaration-value>? ['!' important]?",
"declaration-list": "[<declaration>? ';']* <declaration>?",
"url": "url( <string> <url-modifier>* )|<url-token>",
"url-modifier": "<ident>|<function-token> <any-value> )",
"number-zero-one": "<number [0,1]>",
"number-one-or-greater": "<number [1,∞]>",
"-non-standard-display": "-ms-inline-flexbox|-ms-grid|-ms-inline-grid|-webkit-flex|-webkit-inline-flex|-webkit-box|-webkit-inline-box|-moz-inline-stack|-moz-box|-moz-inline-box"
},
"properties": {
"--*": "<declaration-value>",
"-ms-accelerator": "false|true",
"-ms-block-progression": "tb|rl|bt|lr",
"-ms-content-zoom-chaining": "none|chained",
"-ms-content-zooming": "none|zoom",
"-ms-content-zoom-limit": "<'-ms-content-zoom-limit-min'> <'-ms-content-zoom-limit-max'>",
"-ms-content-zoom-limit-max": "<percentage>",
"-ms-content-zoom-limit-min": "<percentage>",
"-ms-content-zoom-snap": "<'-ms-content-zoom-snap-type'>||<'-ms-content-zoom-snap-points'>",
"-ms-content-zoom-snap-points": "snapInterval( <percentage> , <percentage> )|snapList( <percentage># )",
"-ms-content-zoom-snap-type": "none|proximity|mandatory",
"-ms-filter": "<string>",
"-ms-flow-from": "[none|<custom-ident>]#",
"-ms-flow-into": "[none|<custom-ident>]#",
"-ms-grid-columns": "none|<track-list>|<auto-track-list>",
"-ms-grid-rows": "none|<track-list>|<auto-track-list>",
"-ms-high-contrast-adjust": "auto|none",
"-ms-hyphenate-limit-chars": "auto|<integer>{1,3}",
"-ms-hyphenate-limit-lines": "no-limit|<integer>",
"-ms-hyphenate-limit-zone": "<percentage>|<length>",
"-ms-ime-align": "auto|after",
"-ms-overflow-style": "auto|none|scrollbar|-ms-autohiding-scrollbar",
"-ms-scrollbar-3dlight-color": "<color>",
"-ms-scrollbar-arrow-color": "<color>",
"-ms-scrollbar-base-color": "<color>",
"-ms-scrollbar-darkshadow-color": "<color>",
"-ms-scrollbar-face-color": "<color>",
"-ms-scrollbar-highlight-color": "<color>",
"-ms-scrollbar-shadow-color": "<color>",
"-ms-scrollbar-track-color": "<color>",
"-ms-scroll-chaining": "chained|none",
"-ms-scroll-limit": "<'-ms-scroll-limit-x-min'> <'-ms-scroll-limit-y-min'> <'-ms-scroll-limit-x-max'> <'-ms-scroll-limit-y-max'>",
"-ms-scroll-limit-x-max": "auto|<length>",
"-ms-scroll-limit-x-min": "<length>",
"-ms-scroll-limit-y-max": "auto|<length>",
"-ms-scroll-limit-y-min": "<length>",
"-ms-scroll-rails": "none|railed",
"-ms-scroll-snap-points-x": "snapInterval( <length-percentage> , <length-percentage> )|snapList( <length-percentage># )",
"-ms-scroll-snap-points-y": "snapInterval( <length-percentage> , <length-percentage> )|snapList( <length-percentage># )",
"-ms-scroll-snap-type": "none|proximity|mandatory",
"-ms-scroll-snap-x": "<'-ms-scroll-snap-type'> <'-ms-scroll-snap-points-x'>",
"-ms-scroll-snap-y": "<'-ms-scroll-snap-type'> <'-ms-scroll-snap-points-y'>",
"-ms-scroll-translation": "none|vertical-to-horizontal",
"-ms-text-autospace": "none|ideograph-alpha|ideograph-numeric|ideograph-parenthesis|ideograph-space",
"-ms-touch-select": "grippers|none",
"-ms-user-select": "none|element|text",
"-ms-wrap-flow": "auto|both|start|end|maximum|clear",
"-ms-wrap-margin": "<length>",
"-ms-wrap-through": "wrap|none",
"-moz-appearance": "none|button|button-arrow-down|button-arrow-next|button-arrow-previous|button-arrow-up|button-bevel|button-focus|caret|checkbox|checkbox-container|checkbox-label|checkmenuitem|dualbutton|groupbox|listbox|listitem|menuarrow|menubar|menucheckbox|menuimage|menuitem|menuitemtext|menulist|menulist-button|menulist-text|menulist-textfield|menupopup|menuradio|menuseparator|meterbar|meterchunk|progressbar|progressbar-vertical|progresschunk|progresschunk-vertical|radio|radio-container|radio-label|radiomenuitem|range|range-thumb|resizer|resizerpanel|scale-horizontal|scalethumbend|scalethumb-horizontal|scalethumbstart|scalethumbtick|scalethumb-vertical|scale-vertical|scrollbarbutton-down|scrollbarbutton-left|scrollbarbutton-right|scrollbarbutton-up|scrollbarthumb-horizontal|scrollbarthumb-vertical|scrollbartrack-horizontal|scrollbartrack-vertical|searchfield|separator|sheet|spinner|spinner-downbutton|spinner-textfield|spinner-upbutton|splitter|statusbar|statusbarpanel|tab|tabpanel|tabpanels|tab-scroll-arrow-back|tab-scroll-arrow-forward|textfield|textfield-multiline|toolbar|toolbarbutton|toolbarbutton-dropdown|toolbargripper|toolbox|tooltip|treeheader|treeheadercell|treeheadersortarrow|treeitem|treeline|treetwisty|treetwistyopen|treeview|-moz-mac-unified-toolbar|-moz-win-borderless-glass|-moz-win-browsertabbar-toolbox|-moz-win-communicationstext|-moz-win-communications-toolbox|-moz-win-exclude-glass|-moz-win-glass|-moz-win-mediatext|-moz-win-media-toolbox|-moz-window-button-box|-moz-window-button-box-maximized|-moz-window-button-close|-moz-window-button-maximize|-moz-window-button-minimize|-moz-window-button-restore|-moz-window-frame-bottom|-moz-window-frame-left|-moz-window-frame-right|-moz-window-titlebar|-moz-window-titlebar-maximized",
"-moz-binding": "<url>|none",
"-moz-border-bottom-colors": "<color>+|none",
"-moz-border-left-colors": "<color>+|none",
"-moz-border-right-colors": "<color>+|none",
"-moz-border-top-colors": "<color>+|none",
"-moz-context-properties": "none|[fill|fill-opacity|stroke|stroke-opacity]#",
"-moz-float-edge": "border-box|content-box|margin-box|padding-box",
"-moz-force-broken-image-icon": "0|1",
"-moz-image-region": "<shape>|auto",
"-moz-orient": "inline|block|horizontal|vertical",
"-moz-outline-radius": "<outline-radius>{1,4} [/ <outline-radius>{1,4}]?",
"-moz-outline-radius-bottomleft": "<outline-radius>",
"-moz-outline-radius-bottomright": "<outline-radius>",
"-moz-outline-radius-topleft": "<outline-radius>",
"-moz-outline-radius-topright": "<outline-radius>",
"-moz-stack-sizing": "ignore|stretch-to-fit",
"-moz-text-blink": "none|blink",
"-moz-user-focus": "ignore|normal|select-after|select-before|select-menu|select-same|select-all|none",
"-moz-user-input": "auto|none|enabled|disabled",
"-moz-user-modify": "read-only|read-write|write-only",
"-moz-window-dragging": "drag|no-drag",
"-moz-window-shadow": "default|menu|tooltip|sheet|none",
"-webkit-appearance": "none|button|button-bevel|caps-lock-indicator|caret|checkbox|default-button|inner-spin-button|listbox|listitem|media-controls-background|media-controls-fullscreen-background|media-current-time-display|media-enter-fullscreen-button|media-exit-fullscreen-button|media-fullscreen-button|media-mute-button|media-overlay-play-button|media-play-button|media-seek-back-button|media-seek-forward-button|media-slider|media-sliderthumb|media-time-remaining-display|media-toggle-closed-captions-button|media-volume-slider|media-volume-slider-container|media-volume-sliderthumb|menulist|menulist-button|menulist-text|menulist-textfield|meter|progress-bar|progress-bar-value|push-button|radio|scrollbarbutton-down|scrollbarbutton-left|scrollbarbutton-right|scrollbarbutton-up|scrollbargripper-horizontal|scrollbargripper-vertical|scrollbarthumb-horizontal|scrollbarthumb-vertical|scrollbartrack-horizontal|scrollbartrack-vertical|searchfield|searchfield-cancel-button|searchfield-decoration|searchfield-results-button|searchfield-results-decoration|slider-horizontal|slider-vertical|sliderthumb-horizontal|sliderthumb-vertical|square-button|textarea|textfield|-apple-pay-button",
"-webkit-border-before": "<'border-width'>||<'border-style'>||<color>",
"-webkit-border-before-color": "<color>",
"-webkit-border-before-style": "<'border-style'>",
"-webkit-border-before-width": "<'border-width'>",
"-webkit-box-reflect": "[above|below|right|left]? <length>? <image>?",
"-webkit-line-clamp": "none|<integer>",
"-webkit-mask": "[<mask-reference>||<position> [/ <bg-size>]?||<repeat-style>||[<box>|border|padding|content|text]||[<box>|border|padding|content]]#",
"-webkit-mask-attachment": "<attachment>#",
"-webkit-mask-clip": "[<box>|border|padding|content|text]#",
"-webkit-mask-composite": "<composite-style>#",
"-webkit-mask-image": "<mask-reference>#",
"-webkit-mask-origin": "[<box>|border|padding|content]#",
"-webkit-mask-position": "<position>#",
"-webkit-mask-position-x": "[<length-percentage>|left|center|right]#",
"-webkit-mask-position-y": "[<length-percentage>|top|center|bottom]#",
"-webkit-mask-repeat": "<repeat-style>#",
"-webkit-mask-repeat-x": "repeat|no-repeat|space|round",
"-webkit-mask-repeat-y": "repeat|no-repeat|space|round",
"-webkit-mask-size": "<bg-size>#",
"-webkit-overflow-scrolling": "auto|touch",
"-webkit-tap-highlight-color": "<color>",
"-webkit-text-fill-color": "<color>",
"-webkit-text-stroke": "<length>||<color>",
"-webkit-text-stroke-color": "<color>",
"-webkit-text-stroke-width": "<length>",
"-webkit-touch-callout": "default|none",
"-webkit-user-modify": "read-only|read-write|read-write-plaintext-only",
"accent-color": "auto|<color>",
"align-content": "normal|<baseline-position>|<content-distribution>|<overflow-position>? <content-position>",
"align-items": "normal|stretch|<baseline-position>|[<overflow-position>? <self-position>]",
"align-self": "auto|normal|stretch|<baseline-position>|<overflow-position>? <self-position>",
"align-tracks": "[normal|<baseline-position>|<content-distribution>|<overflow-position>? <content-position>]#",
"all": "initial|inherit|unset|revert|revert-layer",
"animation": "<single-animation>#",
"animation-composition": "<single-animation-composition>#",
"animation-delay": "<time>#",
"animation-direction": "<single-animation-direction>#",
"animation-duration": "<time>#",
"animation-fill-mode": "<single-animation-fill-mode>#",
"animation-iteration-count": "<single-animation-iteration-count>#",
"animation-name": "[none|<keyframes-name>]#",
"animation-play-state": "<single-animation-play-state>#",
"animation-timing-function": "<easing-function>#",
"animation-timeline": "<single-animation-timeline>#",
"appearance": "none|auto|textfield|menulist-button|<compat-auto>",
"aspect-ratio": "auto|<ratio>",
"azimuth": "<angle>|[[left-side|far-left|left|center-left|center|center-right|right|far-right|right-side]||behind]|leftwards|rightwards",
"backdrop-filter": "none|<filter-function-list>",
"backface-visibility": "visible|hidden",
"background": "[<bg-layer> ,]* <final-bg-layer>",
"background-attachment": "<attachment>#",
"background-blend-mode": "<blend-mode>#",
"background-clip": "<bg-clip>#",
"background-color": "<color>",
"background-image": "<bg-image>#",
"background-origin": "<box>#",
"background-position": "<bg-position>#",
"background-position-x": "[center|[[left|right|x-start|x-end]? <length-percentage>?]!]#",
"background-position-y": "[center|[[top|bottom|y-start|y-end]? <length-percentage>?]!]#",
"background-repeat": "<repeat-style>#",
"background-size": "<bg-size>#",
"block-overflow": "clip|ellipsis|<string>",
"block-size": "<'width'>",
"border": "<line-width>||<line-style>||<color>",
"border-block": "<'border-top-width'>||<'border-top-style'>||<color>",
"border-block-color": "<'border-top-color'>{1,2}",
"border-block-style": "<'border-top-style'>",
"border-block-width": "<'border-top-width'>",
"border-block-end": "<'border-top-width'>||<'border-top-style'>||<color>",
"border-block-end-color": "<'border-top-color'>",
"border-block-end-style": "<'border-top-style'>",
"border-block-end-width": "<'border-top-width'>",
"border-block-start": "<'border-top-width'>||<'border-top-style'>||<color>",
"border-block-start-color": "<'border-top-color'>",
"border-block-start-style": "<'border-top-style'>",
"border-block-start-width": "<'border-top-width'>",
"border-bottom": "<line-width>||<line-style>||<color>",
"border-bottom-color": "<'border-top-color'>",
"border-bottom-left-radius": "<length-percentage>{1,2}",
"border-bottom-right-radius": "<length-percentage>{1,2}",
"border-bottom-style": "<line-style>",
"border-bottom-width": "<line-width>",
"border-collapse": "collapse|separate",
"border-color": "<color>{1,4}",
"border-end-end-radius": "<length-percentage>{1,2}",
"border-end-start-radius": "<length-percentage>{1,2}",
"border-image": "<'border-image-source'>||<'border-image-slice'> [/ <'border-image-width'>|/ <'border-image-width'>? / <'border-image-outset'>]?||<'border-image-repeat'>",
"border-image-outset": "[<length>|<number>]{1,4}",
"border-image-repeat": "[stretch|repeat|round|space]{1,2}",
"border-image-slice": "<number-percentage>{1,4}&&fill?",
"border-image-source": "none|<image>",
"border-image-width": "[<length-percentage>|<number>|auto]{1,4}",
"border-inline": "<'border-top-width'>||<'border-top-style'>||<color>",
"border-inline-end": "<'border-top-width'>||<'border-top-style'>||<color>",
"border-inline-color": "<'border-top-color'>{1,2}",
"border-inline-style": "<'border-top-style'>",
"border-inline-width": "<'border-top-width'>",
"border-inline-end-color": "<'border-top-color'>",
"border-inline-end-style": "<'border-top-style'>",
"border-inline-end-width": "<'border-top-width'>",
"border-inline-start": "<'border-top-width'>||<'border-top-style'>||<color>",
"border-inline-start-color": "<'border-top-color'>",
"border-inline-start-style": "<'border-top-style'>",
"border-inline-start-width": "<'border-top-width'>",
"border-left": "<line-width>||<line-style>||<color>",
"border-left-color": "<color>",
"border-left-style": "<line-style>",
"border-left-width": "<line-width>",
"border-radius": "<length-percentage>{1,4} [/ <length-percentage>{1,4}]?",
"border-right": "<line-width>||<line-style>||<color>",
"border-right-color": "<color>",
"border-right-style": "<line-style>",
"border-right-width": "<line-width>",
"border-spacing": "<length> <length>?",
"border-start-end-radius": "<length-percentage>{1,2}",
"border-start-start-radius": "<length-percentage>{1,2}",
"border-style": "<line-style>{1,4}",
"border-top": "<line-width>||<line-style>||<color>",
"border-top-color": "<color>",
"border-top-left-radius": "<length-percentage>{1,2}",
"border-top-right-radius": "<length-percentage>{1,2}",
"border-top-style": "<line-style>",
"border-top-width": "<line-width>",
"border-width": "<line-width>{1,4}",
"bottom": "<length>|<percentage>|auto",
"box-align": "start|center|end|baseline|stretch",
"box-decoration-break": "slice|clone",
"box-direction": "normal|reverse|inherit",
"box-flex": "<number>",
"box-flex-group": "<integer>",
"box-lines": "single|multiple",
"box-ordinal-group": "<integer>",
"box-orient": "horizontal|vertical|inline-axis|block-axis|inherit",
"box-pack": "start|center|end|justify",
"box-shadow": "none|<shadow>#",
"box-sizing": "content-box|border-box",
"break-after": "auto|avoid|always|all|avoid-page|page|left|right|recto|verso|avoid-column|column|avoid-region|region",
"break-before": "auto|avoid|always|all|avoid-page|page|left|right|recto|verso|avoid-column|column|avoid-region|region",
"break-inside": "auto|avoid|avoid-page|avoid-column|avoid-region",
"caption-side": "top|bottom|block-start|block-end|inline-start|inline-end",
"caret": "<'caret-color'>||<'caret-shape'>",
"caret-color": "auto|<color>",
"caret-shape": "auto|bar|block|underscore",
"clear": "none|left|right|both|inline-start|inline-end",
"clip": "<shape>|auto",
"clip-path": "<clip-source>|[<basic-shape>||<geometry-box>]|none",
"color": "<color>",
"print-color-adjust": "economy|exact",
"color-scheme": "normal|[light|dark|<custom-ident>]+&&only?",
"column-count": "<integer>|auto",
"column-fill": "auto|balance|balance-all",
"column-gap": "normal|<length-percentage>",
"column-rule": "<'column-rule-width'>||<'column-rule-style'>||<'column-rule-color'>",
"column-rule-color": "<color>",
"column-rule-style": "<'border-style'>",
"column-rule-width": "<'border-width'>",
"column-span": "none|all",
"column-width": "<length>|auto",
"columns": "<'column-width'>||<'column-count'>",
"contain": "none|strict|content|[[size||inline-size]||layout||style||paint]",
"contain-intrinsic-size": "[none|<length>|auto <length>]{1,2}",
"contain-intrinsic-block-size": "none|<length>|auto <length>",
"contain-intrinsic-height": "none|<length>|auto <length>",
"contain-intrinsic-inline-size": "none|<length>|auto <length>",
"contain-intrinsic-width": "none|<length>|auto <length>",
"content": "normal|none|[<content-replacement>|<content-list>] [/ [<string>|<counter>]+]?",
"content-visibility": "visible|auto|hidden",
"counter-increment": "[<counter-name> <integer>?]+|none",
"counter-reset": "[<counter-name> <integer>?|<reversed-counter-name> <integer>?]+|none",
"counter-set": "[<counter-name> <integer>?]+|none",
"cursor": "[[<url> [<x> <y>]? ,]* [auto|default|none|context-menu|help|pointer|progress|wait|cell|crosshair|text|vertical-text|alias|copy|move|no-drop|not-allowed|e-resize|n-resize|ne-resize|nw-resize|s-resize|se-resize|sw-resize|w-resize|ew-resize|ns-resize|nesw-resize|nwse-resize|col-resize|row-resize|all-scroll|zoom-in|zoom-out|grab|grabbing|hand|-webkit-grab|-webkit-grabbing|-webkit-zoom-in|-webkit-zoom-out|-moz-grab|-moz-grabbing|-moz-zoom-in|-moz-zoom-out]]",
"direction": "ltr|rtl",
"display": "[<display-outside>||<display-inside>]|<display-listitem>|<display-internal>|<display-box>|<display-legacy>|<-non-standard-display>",
"empty-cells": "show|hide",
"filter": "none|<filter-function-list>|<-ms-filter-function-list>",
"flex": "none|[<'flex-grow'> <'flex-shrink'>?||<'flex-basis'>]",
"flex-basis": "content|<'width'>",
"flex-direction": "row|row-reverse|column|column-reverse",
"flex-flow": "<'flex-direction'>||<'flex-wrap'>",
"flex-grow": "<number>",
"flex-shrink": "<number>",
"flex-wrap": "nowrap|wrap|wrap-reverse",
"float": "left|right|none|inline-start|inline-end",
"font": "[[<'font-style'>||<font-variant-css21>||<'font-weight'>||<'font-stretch'>]? <'font-size'> [/ <'line-height'>]? <'font-family'>]|caption|icon|menu|message-box|small-caption|status-bar",
"font-family": "[<family-name>|<generic-family>]#",
"font-feature-settings": "normal|<feature-tag-value>#",
"font-kerning": "auto|normal|none",
"font-language-override": "normal|<string>",
"font-optical-sizing": "auto|none",
"font-variation-settings": "normal|[<string> <number>]#",
"font-size": "<absolute-size>|<relative-size>|<length-percentage>",
"font-size-adjust": "none|[ex-height|cap-height|ch-width|ic-width|ic-height]? [from-font|<number>]",
"font-smooth": "auto|never|always|<absolute-size>|<length>",
"font-stretch": "<font-stretch-absolute>",
"font-style": "normal|italic|oblique <angle>?",
"font-synthesis": "none|[weight||style||small-caps]",
"font-variant": "normal|none|[<common-lig-values>||<discretionary-lig-values>||<historical-lig-values>||<contextual-alt-values>||stylistic( <feature-value-name> )||historical-forms||styleset( <feature-value-name># )||character-variant( <feature-value-name># )||swash( <feature-value-name> )||ornaments( <feature-value-name> )||annotation( <feature-value-name> )||[small-caps|all-small-caps|petite-caps|all-petite-caps|unicase|titling-caps]||<numeric-figure-values>||<numeric-spacing-values>||<numeric-fraction-values>||ordinal||slashed-zero||<east-asian-variant-values>||<east-asian-width-values>||ruby]",
"font-variant-alternates": "normal|[stylistic( <feature-value-name> )||historical-forms||styleset( <feature-value-name># )||character-variant( <feature-value-name># )||swash( <feature-value-name> )||ornaments( <feature-value-name> )||annotation( <feature-value-name> )]",
"font-variant-caps": "normal|small-caps|all-small-caps|petite-caps|all-petite-caps|unicase|titling-caps",
"font-variant-east-asian": "normal|[<east-asian-variant-values>||<east-asian-width-values>||ruby]",
"font-variant-ligatures": "normal|none|[<common-lig-values>||<discretionary-lig-values>||<historical-lig-values>||<contextual-alt-values>]",
"font-variant-numeric": "normal|[<numeric-figure-values>||<numeric-spacing-values>||<numeric-fraction-values>||ordinal||slashed-zero]",
"font-variant-position": "normal|sub|super",
"font-weight": "<font-weight-absolute>|bolder|lighter",
"forced-color-adjust": "auto|none",
"gap": "<'row-gap'> <'column-gap'>?",
"grid": "<'grid-template'>|<'grid-template-rows'> / [auto-flow&&dense?] <'grid-auto-columns'>?|[auto-flow&&dense?] <'grid-auto-rows'>? / <'grid-template-columns'>",
"grid-area": "<grid-line> [/ <grid-line>]{0,3}",
"grid-auto-columns": "<track-size>+",
"grid-auto-flow": "[row|column]||dense",
"grid-auto-rows": "<track-size>+",
"grid-column": "<grid-line> [/ <grid-line>]?",
"grid-column-end": "<grid-line>",
"grid-column-gap": "<length-percentage>",
"grid-column-start": "<grid-line>",
"grid-gap": "<'grid-row-gap'> <'grid-column-gap'>?",
"grid-row": "<grid-line> [/ <grid-line>]?",
"grid-row-end": "<grid-line>",
"grid-row-gap": "<length-percentage>",
"grid-row-start": "<grid-line>",
"grid-template": "none|[<'grid-template-rows'> / <'grid-template-columns'>]|[<line-names>? <string> <track-size>? <line-names>?]+ [/ <explicit-track-list>]?",
"grid-template-areas": "none|<string>+",
"grid-template-columns": "none|<track-list>|<auto-track-list>|subgrid <line-name-list>?",
"grid-template-rows": "none|<track-list>|<auto-track-list>|subgrid <line-name-list>?",
"hanging-punctuation": "none|[first||[force-end|allow-end]||last]",
"height": "auto|<length>|<percentage>|min-content|max-content|fit-content|fit-content( <length-percentage> )",
"hyphenate-character": "auto|<string>",
"hyphens": "none|manual|auto",
"image-orientation": "from-image|<angle>|[<angle>? flip]",
"image-rendering": "auto|crisp-edges|pixelated|optimizeSpeed|optimizeQuality|<-non-standard-image-rendering>",
"image-resolution": "[from-image||<resolution>]&&snap?",
"ime-mode": "auto|normal|active|inactive|disabled",
"initial-letter": "normal|[<number> <integer>?]",
"initial-letter-align": "[auto|alphabetic|hanging|ideographic]",
"inline-size": "<'width'>",
"input-security": "auto|none",
"inset": "<'top'>{1,4}",
"inset-block": "<'top'>{1,2}",
"inset-block-end": "<'top'>",
"inset-block-start": "<'top'>",
"inset-inline": "<'top'>{1,2}",
"inset-inline-end": "<'top'>",
"inset-inline-start": "<'top'>",
"isolation": "auto|isolate",
"justify-content": "normal|<content-distribution>|<overflow-position>? [<content-position>|left|right]",
"justify-items": "normal|stretch|<baseline-position>|<overflow-position>? [<self-position>|left|right]|legacy|legacy&&[left|right|center]",
"justify-self": "auto|normal|stretch|<baseline-position>|<overflow-position>? [<self-position>|left|right]",
"justify-tracks": "[normal|<content-distribution>|<overflow-position>? [<content-position>|left|right]]#",
"left": "<length>|<percentage>|auto",
"letter-spacing": "normal|<length-percentage>",
"line-break": "auto|loose|normal|strict|anywhere",
"line-clamp": "none|<integer>",
"line-height": "normal|<number>|<length>|<percentage>",
"line-height-step": "<length>",
"list-style": "<'list-style-type'>||<'list-style-position'>||<'list-style-image'>",
"list-style-image": "<image>|none",
"list-style-position": "inside|outside",
"list-style-type": "<counter-style>|<string>|none",
"margin": "[<length>|<percentage>|auto]{1,4}",
"margin-block": "<'margin-left'>{1,2}",
"margin-block-end": "<'margin-left'>",
"margin-block-start": "<'margin-left'>",
"margin-bottom": "<length>|<percentage>|auto",
"margin-inline": "<'margin-left'>{1,2}",
"margin-inline-end": "<'margin-left'>",
"margin-inline-start": "<'margin-left'>",
"margin-left": "<length>|<percentage>|auto",
"margin-right": "<length>|<percentage>|auto",
"margin-top": "<length>|<percentage>|auto",
"margin-trim": "none|in-flow|all",
"mask": "<mask-layer>#",
"mask-border": "<'mask-border-source'>||<'mask-border-slice'> [/ <'mask-border-width'>? [/ <'mask-border-outset'>]?]?||<'mask-border-repeat'>||<'mask-border-mode'>",
"mask-border-mode": "luminance|alpha",
"mask-border-outset": "[<length>|<number>]{1,4}",
"mask-border-repeat": "[stretch|repeat|round|space]{1,2}",
"mask-border-slice": "<number-percentage>{1,4} fill?",
"mask-border-source": "none|<image>",
"mask-border-width": "[<length-percentage>|<number>|auto]{1,4}",
"mask-clip": "[<geometry-box>|no-clip]#",
"mask-composite": "<compositing-operator>#",
"mask-image": "<mask-reference>#",
"mask-mode": "<masking-mode>#",
"mask-origin": "<geometry-box>#",
"mask-position": "<position>#",
"mask-repeat": "<repeat-style>#",
"mask-size": "<bg-size>#",
"mask-type": "luminance|alpha",
"masonry-auto-flow": "[pack|next]||[definite-first|ordered]",
"math-depth": "auto-add|add( <integer> )|<integer>",
"math-shift": "normal|compact",
"math-style": "normal|compact",
"max-block-size": "<'max-width'>",
"max-height": "none|<length-percentage>|min-content|max-content|fit-content|fit-content( <length-percentage> )",
"max-inline-size": "<'max-width'>",
"max-lines": "none|<integer>",
"max-width": "none|<length-percentage>|min-content|max-content|fit-content|fit-content( <length-percentage> )|<-non-standard-width>",
"min-block-size": "<'min-width'>",
"min-height": "auto|<length>|<percentage>|min-content|max-content|fit-content|fit-content( <length-percentage> )",
"min-inline-size": "<'min-width'>",
"min-width": "auto|<length>|<percentage>|min-content|max-content|fit-content|fit-content( <length-percentage> )|<-non-standard-width>",
"mix-blend-mode": "<blend-mode>|plus-lighter",
"object-fit": "fill|contain|cover|none|scale-down",
"object-position": "<position>",
"offset": "[<'offset-position'>? [<'offset-path'> [<'offset-distance'>||<'offset-rotate'>]?]?]! [/ <'offset-anchor'>]?",
"offset-anchor": "auto|<position>",
"offset-distance": "<length-percentage>",
"offset-path": "none|ray( [<angle>&&<size>&&contain?] )|<path()>|<url>|[<basic-shape>||<geometry-box>]",
"offset-position": "auto|<position>",
"offset-rotate": "[auto|reverse]||<angle>",
"opacity": "<alpha-value>",
"order": "<integer>",
"orphans": "<integer>",
"outline": "[<'outline-color'>||<'outline-style'>||<'outline-width'>]",
"outline-color": "<color>|invert",
"outline-offset": "<length>",
"outline-style": "auto|<'border-style'>",
"outline-width": "<line-width>",
"overflow": "[visible|hidden|clip|scroll|auto]{1,2}|<-non-standard-overflow>",
"overflow-anchor": "auto|none",
"overflow-block": "visible|hidden|clip|scroll|auto",
"overflow-clip-box": "padding-box|content-box",
"overflow-clip-margin": "<visual-box>||<length [0,∞]>",
"overflow-inline": "visible|hidden|clip|scroll|auto",
"overflow-wrap": "normal|break-word|anywhere",
"overflow-x": "visible|hidden|clip|scroll|auto",
"overflow-y": "visible|hidden|clip|scroll|auto",
"overscroll-behavior": "[contain|none|auto]{1,2}",
"overscroll-behavior-block": "contain|none|auto",
"overscroll-behavior-inline": "contain|none|auto",
"overscroll-behavior-x": "contain|none|auto",
"overscroll-behavior-y": "contain|none|auto",
"padding": "[<length>|<percentage>]{1,4}",
"padding-block": "<'padding-left'>{1,2}",
"padding-block-end": "<'padding-left'>",
"padding-block-start": "<'padding-left'>",
"padding-bottom": "<length>|<percentage>",
"padding-inline": "<'padding-left'>{1,2}",
"padding-inline-end": "<'padding-left'>",
"padding-inline-start": "<'padding-left'>",
"padding-left": "<length>|<percentage>",
"padding-right": "<length>|<percentage>",
"padding-top": "<length>|<percentage>",
"page-break-after": "auto|always|avoid|left|right|recto|verso",
"page-break-before": "auto|always|avoid|left|right|recto|verso",
"page-break-inside": "auto|avoid",
"paint-order": "normal|[fill||stroke||markers]",
"perspective": "none|<length>",
"perspective-origin": "<position>",
"place-content": "<'align-content'> <'justify-content'>?",
"place-items": "<'align-items'> <'justify-items'>?",
"place-self": "<'align-self'> <'justify-self'>?",
"pointer-events": "auto|none|visiblePainted|visibleFill|visibleStroke|visible|painted|fill|stroke|all|inherit",
"position": "static|relative|absolute|sticky|fixed|-webkit-sticky",
"quotes": "none|auto|[<string> <string>]+",
"resize": "none|both|horizontal|vertical|block|inline",
"right": "<length>|<percentage>|auto",
"rotate": "none|<angle>|[x|y|z|<number>{3}]&&<angle>",
"row-gap": "normal|<length-percentage>",
"ruby-align": "start|center|space-between|space-around",
"ruby-merge": "separate|collapse|auto",
"ruby-position": "[alternate||[over|under]]|inter-character",
"scale": "none|<number>{1,3}",
"scrollbar-color": "auto|<color>{2}",
"scrollbar-gutter": "auto|stable&&both-edges?",
"scrollbar-width": "auto|thin|none",
"scroll-behavior": "auto|smooth",
"scroll-margin": "<length>{1,4}",
"scroll-margin-block": "<length>{1,2}",
"scroll-margin-block-start": "<length>",
"scroll-margin-block-end": "<length>",
"scroll-margin-bottom": "<length>",
"scroll-margin-inline": "<length>{1,2}",
"scroll-margin-inline-start": "<length>",
"scroll-margin-inline-end": "<length>",
"scroll-margin-left": "<length>",
"scroll-margin-right": "<length>",
"scroll-margin-top": "<length>",
"scroll-padding": "[auto|<length-percentage>]{1,4}",
"scroll-padding-block": "[auto|<length-percentage>]{1,2}",
"scroll-padding-block-start": "auto|<length-percentage>",
"scroll-padding-block-end": "auto|<length-percentage>",
"scroll-padding-bottom": "auto|<length-percentage>",
"scroll-padding-inline": "[auto|<length-percentage>]{1,2}",
"scroll-padding-inline-start": "auto|<length-percentage>",
"scroll-padding-inline-end": "auto|<length-percentage>",
"scroll-padding-left": "auto|<length-percentage>",
"scroll-padding-right": "auto|<length-percentage>",
"scroll-padding-top": "auto|<length-percentage>",
"scroll-snap-align": "[none|start|end|center]{1,2}",
"scroll-snap-coordinate": "none|<position>#",
"scroll-snap-destination": "<position>",
"scroll-snap-points-x": "none|repeat( <length-percentage> )",
"scroll-snap-points-y": "none|repeat( <length-percentage> )",
"scroll-snap-stop": "normal|always",
"scroll-snap-type": "none|[x|y|block|inline|both] [mandatory|proximity]?",
"scroll-snap-type-x": "none|mandatory|proximity",
"scroll-snap-type-y": "none|mandatory|proximity",
"scroll-timeline": "<scroll-timeline-name>||<scroll-timeline-axis>",
"scroll-timeline-axis": "block|inline|vertical|horizontal",
"scroll-timeline-name": "none|<custom-ident>",
"shape-image-threshold": "<alpha-value>",
"shape-margin": "<length-percentage>",
"shape-outside": "none|[<shape-box>||<basic-shape>]|<image>",
"tab-size": "<integer>|<length>",
"table-layout": "auto|fixed",
"text-align": "start|end|left|right|center|justify|match-parent",
"text-align-last": "auto|start|end|left|right|center|justify",
"text-combine-upright": "none|all|[digits <integer>?]",
"text-decoration": "<'text-decoration-line'>||<'text-decoration-style'>||<'text-decoration-color'>||<'text-decoration-thickness'>",
"text-decoration-color": "<color>",
"text-decoration-line": "none|[underline||overline||line-through||blink]|spelling-error|grammar-error",
"text-decoration-skip": "none|[objects||[spaces|[leading-spaces||trailing-spaces]]||edges||box-decoration]",
"text-decoration-skip-ink": "auto|all|none",
"text-decoration-style": "solid|double|dotted|dashed|wavy",
"text-decoration-thickness": "auto|from-font|<length>|<percentage>",
"text-emphasis": "<'text-emphasis-style'>||<'text-emphasis-color'>",
"text-emphasis-color": "<color>",
"text-emphasis-position": "[over|under]&&[right|left]",
"text-emphasis-style": "none|[[filled|open]||[dot|circle|double-circle|triangle|sesame]]|<string>",
"text-indent": "<length-percentage>&&hanging?&&each-line?",
"text-justify": "auto|inter-character|inter-word|none",
"text-orientation": "mixed|upright|sideways",
"text-overflow": "[clip|ellipsis|<string>]{1,2}",
"text-rendering": "auto|optimizeSpeed|optimizeLegibility|geometricPrecision",
"text-shadow": "none|<shadow-t>#",
"text-size-adjust": "none|auto|<percentage>",
"text-transform": "none|capitalize|uppercase|lowercase|full-width|full-size-kana",
"text-underline-offset": "auto|<length>|<percentage>",
"text-underline-position": "auto|from-font|[under||[left|right]]",
"top": "<length>|<percentage>|auto",
"touch-action": "auto|none|[[pan-x|pan-left|pan-right]||[pan-y|pan-up|pan-down]||pinch-zoom]|manipulation",
"transform": "none|<transform-list>",
"transform-box": "content-box|border-box|fill-box|stroke-box|view-box",
"transform-origin": "[<length-percentage>|left|center|right|top|bottom]|[[<length-percentage>|left|center|right]&&[<length-percentage>|top|center|bottom]] <length>?",
"transform-style": "flat|preserve-3d",
"transition": "<single-transition>#",
"transition-delay": "<time>#",
"transition-duration": "<time>#",
"transition-property": "none|<single-transition-property>#",
"transition-timing-function": "<easing-function>#",
"translate": "none|<length-percentage> [<length-percentage> <length>?]?",
"unicode-bidi": "normal|embed|isolate|bidi-override|isolate-override|plaintext|-moz-isolate|-moz-isolate-override|-moz-plaintext|-webkit-isolate|-webkit-isolate-override|-webkit-plaintext",
"user-select": "auto|text|none|contain|all",
"vertical-align": "baseline|sub|super|text-top|text-bottom|middle|top|bottom|<percentage>|<length>",
"visibility": "visible|hidden|collapse",
"white-space": "normal|pre|nowrap|pre-wrap|pre-line|break-spaces",
"widows": "<integer>",
"width": "auto|<length>|<percentage>|min-content|max-content|fit-content|fit-content( <length-percentage> )|fill|stretch|intrinsic|-moz-max-content|-webkit-max-content|-moz-fit-content|-webkit-fit-content",
"will-change": "auto|<animateable-feature>#",
"word-break": "normal|break-all|keep-all|break-word",
"word-spacing": "normal|<length>",
"word-wrap": "normal|break-word",
"writing-mode": "horizontal-tb|vertical-rl|vertical-lr|sideways-rl|sideways-lr|<svg-writing-mode>",
"z-index": "auto|<integer>",
"zoom": "normal|reset|<number>|<percentage>",
"-moz-background-clip": "padding|border",
"-moz-border-radius-bottomleft": "<'border-bottom-left-radius'>",
"-moz-border-radius-bottomright": "<'border-bottom-right-radius'>",
"-moz-border-radius-topleft": "<'border-top-left-radius'>",
"-moz-border-radius-topright": "<'border-bottom-right-radius'>",
"-moz-control-character-visibility": "visible|hidden",
"-moz-osx-font-smoothing": "auto|grayscale",
"-moz-user-select": "none|text|all|-moz-none",
"-ms-flex-align": "start|end|center|baseline|stretch",
"-ms-flex-item-align": "auto|start|end|center|baseline|stretch",
"-ms-flex-line-pack": "start|end|center|justify|distribute|stretch",
"-ms-flex-negative": "<'flex-shrink'>",
"-ms-flex-pack": "start|end|center|justify|distribute",
"-ms-flex-order": "<integer>",
"-ms-flex-positive": "<'flex-grow'>",
"-ms-flex-preferred-size": "<'flex-basis'>",
"-ms-interpolation-mode": "nearest-neighbor|bicubic",
"-ms-grid-column-align": "start|end|center|stretch",
"-ms-grid-row-align": "start|end|center|stretch",
"-ms-hyphenate-limit-last": "none|always|column|page|spread",
"-webkit-background-clip": "[<box>|border|padding|content|text]#",
"-webkit-column-break-after": "always|auto|avoid",
"-webkit-column-break-before": "always|auto|avoid",
"-webkit-column-break-inside": "always|auto|avoid",
"-webkit-font-smoothing": "auto|none|antialiased|subpixel-antialiased",
"-webkit-mask-box-image": "[<url>|<gradient>|none] [<length-percentage>{4} <-webkit-mask-box-repeat>{2}]?",
"-webkit-print-color-adjust": "economy|exact",
"-webkit-text-security": "none|circle|disc|square",
"-webkit-user-drag": "none|element|auto",
"-webkit-user-select": "auto|none|text|all",
"alignment-baseline": "auto|baseline|before-edge|text-before-edge|middle|central|after-edge|text-after-edge|ideographic|alphabetic|hanging|mathematical",
"baseline-shift": "baseline|sub|super|<svg-length>",
"behavior": "<url>+",
"clip-rule": "nonzero|evenodd",
"cue": "<'cue-before'> <'cue-after'>?",
"cue-after": "<url> <decibel>?|none",
"cue-before": "<url> <decibel>?|none",
"dominant-baseline": "auto|use-script|no-change|reset-size|ideographic|alphabetic|hanging|mathematical|central|middle|text-after-edge|text-before-edge",
"fill": "<paint>",
"fill-opacity": "<number-zero-one>",
"fill-rule": "nonzero|evenodd",
"glyph-orientation-horizontal": "<angle>",
"glyph-orientation-vertical": "<angle>",
"kerning": "auto|<svg-length>",
"marker": "none|<url>",
"marker-end": "none|<url>",
"marker-mid": "none|<url>",
"marker-start": "none|<url>",
"pause": "<'pause-before'> <'pause-after'>?",
"pause-after": "<time>|none|x-weak|weak|medium|strong|x-strong",
"pause-before": "<time>|none|x-weak|weak|medium|strong|x-strong",
"rest": "<'rest-before'> <'rest-after'>?",
"rest-after": "<time>|none|x-weak|weak|medium|strong|x-strong",
"rest-before": "<time>|none|x-weak|weak|medium|strong|x-strong",
"shape-rendering": "auto|optimizeSpeed|crispEdges|geometricPrecision",
"src": "[<url> [format( <string># )]?|local( <family-name> )]#",
"speak": "auto|none|normal",
"speak-as": "normal|spell-out||digits||[literal-punctuation|no-punctuation]",
"stroke": "<paint>",
"stroke-dasharray": "none|[<svg-length>+]#",
"stroke-dashoffset": "<svg-length>",
"stroke-linecap": "butt|round|square",
"stroke-linejoin": "miter|round|bevel",
"stroke-miterlimit": "<number-one-or-greater>",
"stroke-opacity": "<number-zero-one>",
"stroke-width": "<svg-length>",
"text-anchor": "start|middle|end",
"unicode-range": "<urange>#",
"voice-balance": "<number>|left|center|right|leftwards|rightwards",
"voice-duration": "auto|<time>",
"voice-family": "[[<family-name>|<generic-voice>] ,]* [<family-name>|<generic-voice>]|preserve",
"voice-pitch": "<frequency>&&absolute|[[x-low|low|medium|high|x-high]||[<frequency>|<semitones>|<percentage>]]",
"voice-range": "<frequency>&&absolute|[[x-low|low|medium|high|x-high]||[<frequency>|<semitones>|<percentage>]]",
"voice-rate": "[normal|x-slow|slow|medium|fast|x-fast]||<percentage>",
"voice-stress": "normal|strong|moderate|none|reduced",
"voice-volume": "silent|[[x-soft|soft|medium|loud|x-loud]||<decibel>]"
},
"atrules": {
"charset": {
"prelude": "<string>",
"descriptors": null
},
"counter-style": {
"prelude": "<counter-style-name>",
"descriptors": {
"additive-symbols": "[<integer>&&<symbol>]#",
"fallback": "<counter-style-name>",
"negative": "<symbol> <symbol>?",
"pad": "<integer>&&<symbol>",
"prefix": "<symbol>",
"range": "[[<integer>|infinite]{2}]#|auto",
"speak-as": "auto|bullets|numbers|words|spell-out|<counter-style-name>",
"suffix": "<symbol>",
"symbols": "<symbol>+",
"system": "cyclic|numeric|alphabetic|symbolic|additive|[fixed <integer>?]|[extends <counter-style-name>]"
}
},
"document": {
"prelude": "[<url>|url-prefix( <string> )|domain( <string> )|media-document( <string> )|regexp( <string> )]#",
"descriptors": null
},
"font-face": {
"prelude": null,
"descriptors": {
"ascent-override": "normal|<percentage>",
"descent-override": "normal|<percentage>",
"font-display": "[auto|block|swap|fallback|optional]",
"font-family": "<family-name>",
"font-feature-settings": "normal|<feature-tag-value>#",
"font-variation-settings": "normal|[<string> <number>]#",
"font-stretch": "<font-stretch-absolute>{1,2}",
"font-style": "normal|italic|oblique <angle>{0,2}",
"font-weight": "<font-weight-absolute>{1,2}",
"font-variant": "normal|none|[<common-lig-values>||<discretionary-lig-values>||<historical-lig-values>||<contextual-alt-values>||stylistic( <feature-value-name> )||historical-forms||styleset( <feature-value-name># )||character-variant( <feature-value-name># )||swash( <feature-value-name> )||ornaments( <feature-value-name> )||annotation( <feature-value-name> )||[small-caps|all-small-caps|petite-caps|all-petite-caps|unicase|titling-caps]||<numeric-figure-values>||<numeric-spacing-values>||<numeric-fraction-values>||ordinal||slashed-zero||<east-asian-variant-values>||<east-asian-width-values>||ruby]",
"line-gap-override": "normal|<percentage>",
"size-adjust": "<percentage>",
"src": "[<url> [format( <string># )]?|local( <family-name> )]#",
"unicode-range": "<urange>#"
}
},
"font-feature-values": {
"prelude": "<family-name>#",
"descriptors": null
},
"import": {
"prelude": "[<string>|<url>] [layer|layer( <layer-name> )]? [supports( [<supports-condition>|<declaration>] )]? <media-query-list>?",
"descriptors": null
},
"keyframes": {
"prelude": "<keyframes-name>",
"descriptors": null
},
"layer": {
"prelude": "[<layer-name>#|<layer-name>?]",
"descriptors": null
},
"media": {
"prelude": "<media-query-list>",
"descriptors": null
},
"namespace": {
"prelude": "<namespace-prefix>? [<string>|<url>]",
"descriptors": null
},
"page": {
"prelude": "<page-selector-list>",
"descriptors": {
"bleed": "auto|<length>",
"marks": "none|[crop||cross]",
"size": "<length>{1,2}|auto|[<page-size>||[portrait|landscape]]"
}
},
"property": {
"prelude": "<custom-property-name>",
"descriptors": {
"syntax": "<string>",
"inherits": "true|false",
"initial-value": "<string>"
}
},
"scroll-timeline": {
"prelude": "<timeline-name>",
"descriptors": null
},
"supports": {
"prelude": "<supports-condition>",
"descriptors": null
},
"viewport": {
"prelude": null,
"descriptors": {
"height": "<viewport-length>{1,2}",
"max-height": "<viewport-length>",
"max-width": "<viewport-length>",
"max-zoom": "auto|<number>|<percentage>",
"min-height": "<viewport-length>",
"min-width": "<viewport-length>",
"min-zoom": "auto|<number>|<percentage>",
"orientation": "auto|portrait|landscape",
"user-zoom": "zoom|fixed",
"viewport-fit": "auto|contain|cover",
"width": "<viewport-length>{1,2}",
"zoom": "auto|<number>|<percentage>"
}
},
"nest": {
"prelude": "<complex-selector-list>",
"descriptors": null
}
}
});
;// ./node_modules/css-tree/lib/syntax/node/AnPlusB.js
const AnPlusB_PLUSSIGN = 0x002B; // U+002B PLUS SIGN (+)
const AnPlusB_HYPHENMINUS = 0x002D; // U+002D HYPHEN-MINUS (-)
const AnPlusB_N = 0x006E; // U+006E LATIN SMALL LETTER N (n)
const AnPlusB_DISALLOW_SIGN = true;
const AnPlusB_ALLOW_SIGN = false;
function AnPlusB_checkInteger(offset, disallowSign) {
let pos = this.tokenStart + offset;
const code = this.charCodeAt(pos);
if (code === AnPlusB_PLUSSIGN || code === AnPlusB_HYPHENMINUS) {
if (disallowSign) {
this.error('Number sign is not allowed');
}
pos++;
}
for (; pos < this.tokenEnd; pos++) {
if (!isDigit(this.charCodeAt(pos))) {
this.error('Integer is expected', pos);
}
}
}
function checkTokenIsInteger(disallowSign) {
return AnPlusB_checkInteger.call(this, 0, disallowSign);
}
function expectCharCode(offset, code) {
if (!this.cmpChar(this.tokenStart + offset, code)) {
let msg = '';
switch (code) {
case AnPlusB_N:
msg = 'N is expected';
break;
case AnPlusB_HYPHENMINUS:
msg = 'HyphenMinus is expected';
break;
}
this.error(msg, this.tokenStart + offset);
}
}
// ... <signed-integer>
// ... ['+' | '-'] <signless-integer>
function AnPlusB_consumeB() {
let offset = 0;
let sign = 0;
let type = this.tokenType;
while (type === WhiteSpace || type === Comment) {
type = this.lookupType(++offset);
}
if (type !== types_Number) {
if (this.isDelim(AnPlusB_PLUSSIGN, offset) ||
this.isDelim(AnPlusB_HYPHENMINUS, offset)) {
sign = this.isDelim(AnPlusB_PLUSSIGN, offset) ? AnPlusB_PLUSSIGN : AnPlusB_HYPHENMINUS;
do {
type = this.lookupType(++offset);
} while (type === WhiteSpace || type === Comment);
if (type !== types_Number) {
this.skip(offset);
checkTokenIsInteger.call(this, AnPlusB_DISALLOW_SIGN);
}
} else {
return null;
}
}
if (offset > 0) {
this.skip(offset);
}
if (sign === 0) {
type = this.charCodeAt(this.tokenStart);
if (type !== AnPlusB_PLUSSIGN && type !== AnPlusB_HYPHENMINUS) {
this.error('Number sign is expected');
}
}
checkTokenIsInteger.call(this, sign !== 0);
return sign === AnPlusB_HYPHENMINUS ? '-' + this.consume(types_Number) : this.consume(types_Number);
}
// An+B microsyntax https://www.w3.org/TR/css-syntax-3/#anb
const AnPlusB_name = 'AnPlusB';
const structure = {
a: [String, null],
b: [String, null]
};
function AnPlusB_parse() {
/* eslint-disable brace-style*/
const start = this.tokenStart;
let a = null;
let b = null;
// <integer>
if (this.tokenType === types_Number) {
checkTokenIsInteger.call(this, AnPlusB_ALLOW_SIGN);
b = this.consume(types_Number);
}
// -n
// -n <signed-integer>
// -n ['+' | '-'] <signless-integer>
// -n- <signless-integer>
// <dashndashdigit-ident>
else if (this.tokenType === Ident && this.cmpChar(this.tokenStart, AnPlusB_HYPHENMINUS)) {
a = '-1';
expectCharCode.call(this, 1, AnPlusB_N);
switch (this.tokenEnd - this.tokenStart) {
// -n
// -n <signed-integer>
// -n ['+' | '-'] <signless-integer>
case 2:
this.next();
b = AnPlusB_consumeB.call(this);
break;
// -n- <signless-integer>
case 3:
expectCharCode.call(this, 2, AnPlusB_HYPHENMINUS);
this.next();
this.skipSC();
checkTokenIsInteger.call(this, AnPlusB_DISALLOW_SIGN);
b = '-' + this.consume(types_Number);
break;
// <dashndashdigit-ident>
default:
expectCharCode.call(this, 2, AnPlusB_HYPHENMINUS);
AnPlusB_checkInteger.call(this, 3, AnPlusB_DISALLOW_SIGN);
this.next();
b = this.substrToCursor(start + 2);
}
}
// '+'? n
// '+'? n <signed-integer>
// '+'? n ['+' | '-'] <signless-integer>
// '+'? n- <signless-integer>
// '+'? <ndashdigit-ident>
else if (this.tokenType === Ident || (this.isDelim(AnPlusB_PLUSSIGN) && this.lookupType(1) === Ident)) {
let sign = 0;
a = '1';
// just ignore a plus
if (this.isDelim(AnPlusB_PLUSSIGN)) {
sign = 1;
this.next();
}
expectCharCode.call(this, 0, AnPlusB_N);
switch (this.tokenEnd - this.tokenStart) {
// '+'? n
// '+'? n <signed-integer>
// '+'? n ['+' | '-'] <signless-integer>
case 1:
this.next();
b = AnPlusB_consumeB.call(this);
break;
// '+'? n- <signless-integer>
case 2:
expectCharCode.call(this, 1, AnPlusB_HYPHENMINUS);
this.next();
this.skipSC();
checkTokenIsInteger.call(this, AnPlusB_DISALLOW_SIGN);
b = '-' + this.consume(types_Number);
break;
// '+'? <ndashdigit-ident>
default:
expectCharCode.call(this, 1, AnPlusB_HYPHENMINUS);
AnPlusB_checkInteger.call(this, 2, AnPlusB_DISALLOW_SIGN);
this.next();
b = this.substrToCursor(start + sign + 1);
}
}
// <ndashdigit-dimension>
// <ndash-dimension> <signless-integer>
// <n-dimension>
// <n-dimension> <signed-integer>
// <n-dimension> ['+' | '-'] <signless-integer>
else if (this.tokenType === Dimension) {
const code = this.charCodeAt(this.tokenStart);
const sign = code === AnPlusB_PLUSSIGN || code === AnPlusB_HYPHENMINUS;
let i = this.tokenStart + sign;
for (; i < this.tokenEnd; i++) {
if (!isDigit(this.charCodeAt(i))) {
break;
}
}
if (i === this.tokenStart + sign) {
this.error('Integer is expected', this.tokenStart + sign);
}
expectCharCode.call(this, i - this.tokenStart, AnPlusB_N);
a = this.substring(start, i);
// <n-dimension>
// <n-dimension> <signed-integer>
// <n-dimension> ['+' | '-'] <signless-integer>
if (i + 1 === this.tokenEnd) {
this.next();
b = AnPlusB_consumeB.call(this);
} else {
expectCharCode.call(this, i - this.tokenStart + 1, AnPlusB_HYPHENMINUS);
// <ndash-dimension> <signless-integer>
if (i + 2 === this.tokenEnd) {
this.next();
this.skipSC();
checkTokenIsInteger.call(this, AnPlusB_DISALLOW_SIGN);
b = '-' + this.consume(types_Number);
}
// <ndashdigit-dimension>
else {
AnPlusB_checkInteger.call(this, i - this.tokenStart + 2, AnPlusB_DISALLOW_SIGN);
this.next();
b = this.substrToCursor(i + 1);
}
}
} else {
this.error();
}
if (a !== null && a.charCodeAt(0) === AnPlusB_PLUSSIGN) {
a = a.substr(1);
}
if (b !== null && b.charCodeAt(0) === AnPlusB_PLUSSIGN) {
b = b.substr(1);
}
return {
type: 'AnPlusB',
loc: this.getLocation(start, this.tokenStart),
a,
b
};
}
function AnPlusB_generate(node) {
if (node.a) {
const a =
node.a === '+1' && 'n' ||
node.a === '1' && 'n' ||
node.a === '-1' && '-n' ||
node.a + 'n';
if (node.b) {
const b = node.b[0] === '-' || node.b[0] === '+'
? node.b
: '+' + node.b;
this.tokenize(a + b);
} else {
this.tokenize(a);
}
} else {
this.tokenize(node.b);
}
}
;// ./node_modules/css-tree/lib/syntax/node/Atrule.js
function consumeRaw(startToken) {
return this.Raw(startToken, this.consumeUntilLeftCurlyBracketOrSemicolon, true);
}
function isDeclarationBlockAtrule() {
for (let offset = 1, type; type = this.lookupType(offset); offset++) {
if (type === RightCurlyBracket) {
return true;
}
if (type === LeftCurlyBracket ||
type === AtKeyword) {
return false;
}
}
return false;
}
const Atrule_name = 'Atrule';
const walkContext = 'atrule';
const Atrule_structure = {
name: String,
prelude: ['AtrulePrelude', 'Raw', null],
block: ['Block', null]
};
function Atrule_parse(isDeclaration = false) {
const start = this.tokenStart;
let name;
let nameLowerCase;
let prelude = null;
let block = null;
this.eat(AtKeyword);
name = this.substrToCursor(start + 1);
nameLowerCase = name.toLowerCase();
this.skipSC();
// parse prelude
if (this.eof === false &&
this.tokenType !== LeftCurlyBracket &&
this.tokenType !== Semicolon) {
if (this.parseAtrulePrelude) {
prelude = this.parseWithFallback(this.AtrulePrelude.bind(this, name, isDeclaration), consumeRaw);
} else {
prelude = consumeRaw.call(this, this.tokenIndex);
}
this.skipSC();
}
switch (this.tokenType) {
case Semicolon:
this.next();
break;
case LeftCurlyBracket:
if (hasOwnProperty.call(this.atrule, nameLowerCase) &&
typeof this.atrule[nameLowerCase].block === 'function') {
block = this.atrule[nameLowerCase].block.call(this, isDeclaration);
} else {
// TODO: should consume block content as Raw?
block = this.Block(isDeclarationBlockAtrule.call(this));
}
break;
}
return {
type: 'Atrule',
loc: this.getLocation(start, this.tokenStart),
name,
prelude,
block
};
}
function Atrule_generate(node) {
this.token(AtKeyword, '@' + node.name);
if (node.prelude !== null) {
this.node(node.prelude);
}
if (node.block) {
this.node(node.block);
} else {
this.token(Semicolon, ';');
}
}
;// ./node_modules/css-tree/lib/syntax/node/AtrulePrelude.js
const AtrulePrelude_name = 'AtrulePrelude';
const AtrulePrelude_walkContext = 'atrulePrelude';
const AtrulePrelude_structure = {
children: [[]]
};
function AtrulePrelude_parse(name) {
let children = null;
if (name !== null) {
name = name.toLowerCase();
}
this.skipSC();
if (hasOwnProperty.call(this.atrule, name) &&
typeof this.atrule[name].prelude === 'function') {
// custom consumer
children = this.atrule[name].prelude.call(this);
} else {
// default consumer
children = this.readSequence(this.scope.AtrulePrelude);
}
this.skipSC();
if (this.eof !== true &&
this.tokenType !== LeftCurlyBracket &&
this.tokenType !== Semicolon) {
this.error('Semicolon or block is expected');
}
return {
type: 'AtrulePrelude',
loc: this.getLocationFromList(children),
children
};
}
function AtrulePrelude_generate(node) {
this.children(node);
}
;// ./node_modules/css-tree/lib/syntax/node/AttributeSelector.js
const DOLLARSIGN = 0x0024; // U+0024 DOLLAR SIGN ($)
const AttributeSelector_ASTERISK = 0x002A; // U+002A ASTERISK (*)
const EQUALSSIGN = 0x003D; // U+003D EQUALS SIGN (=)
const CIRCUMFLEXACCENT = 0x005E; // U+005E (^)
const AttributeSelector_VERTICALLINE = 0x007C; // U+007C VERTICAL LINE (|)
const TILDE = 0x007E; // U+007E TILDE (~)
function getAttributeName() {
if (this.eof) {
this.error('Unexpected end of input');
}
const start = this.tokenStart;
let expectIdent = false;
if (this.isDelim(AttributeSelector_ASTERISK)) {
expectIdent = true;
this.next();
} else if (!this.isDelim(AttributeSelector_VERTICALLINE)) {
this.eat(Ident);
}
if (this.isDelim(AttributeSelector_VERTICALLINE)) {
if (this.charCodeAt(this.tokenStart + 1) !== EQUALSSIGN) {
this.next();
this.eat(Ident);
} else if (expectIdent) {
this.error('Identifier is expected', this.tokenEnd);
}
} else if (expectIdent) {
this.error('Vertical line is expected');
}
return {
type: 'Identifier',
loc: this.getLocation(start, this.tokenStart),
name: this.substrToCursor(start)
};
}
function getOperator() {
const start = this.tokenStart;
const code = this.charCodeAt(start);
if (code !== EQUALSSIGN && // =
code !== TILDE && // ~=
code !== CIRCUMFLEXACCENT && // ^=
code !== DOLLARSIGN && // $=
code !== AttributeSelector_ASTERISK && // *=
code !== AttributeSelector_VERTICALLINE // |=
) {
this.error('Attribute selector (=, ~=, ^=, $=, *=, |=) is expected');
}
this.next();
if (code !== EQUALSSIGN) {
if (!this.isDelim(EQUALSSIGN)) {
this.error('Equal sign is expected');
}
this.next();
}
return this.substrToCursor(start);
}
// '[' <wq-name> ']'
// '[' <wq-name> <attr-matcher> [ <string-token> | <ident-token> ] <attr-modifier>? ']'
const AttributeSelector_name = 'AttributeSelector';
const AttributeSelector_structure = {
name: 'Identifier',
matcher: [String, null],
value: ['String', 'Identifier', null],
flags: [String, null]
};
function AttributeSelector_parse() {
const start = this.tokenStart;
let name;
let matcher = null;
let value = null;
let flags = null;
this.eat(LeftSquareBracket);
this.skipSC();
name = getAttributeName.call(this);
this.skipSC();
if (this.tokenType !== RightSquareBracket) {
// avoid case `[name i]`
if (this.tokenType !== Ident) {
matcher = getOperator.call(this);
this.skipSC();
value = this.tokenType === types_String
? this.String()
: this.Identifier();
this.skipSC();
}
// attribute flags
if (this.tokenType === Ident) {
flags = this.consume(Ident);
this.skipSC();
}
}
this.eat(RightSquareBracket);
return {
type: 'AttributeSelector',
loc: this.getLocation(start, this.tokenStart),
name,
matcher,
value,
flags
};
}
function AttributeSelector_generate(node) {
this.token(Delim, '[');
this.node(node.name);
if (node.matcher !== null) {
this.tokenize(node.matcher);
this.node(node.value);
}
if (node.flags !== null) {
this.token(Ident, node.flags);
}
this.token(Delim, ']');
}
;// ./node_modules/css-tree/lib/syntax/node/Block.js
const Block_AMPERSAND = 0x0026; // U+0026 AMPERSAND (&)
function Block_consumeRaw(startToken) {
return this.Raw(startToken, null, true);
}
function consumeRule() {
return this.parseWithFallback(this.Rule, Block_consumeRaw);
}
function consumeRawDeclaration(startToken) {
return this.Raw(startToken, this.consumeUntilSemicolonIncluded, true);
}
function consumeDeclaration() {
if (this.tokenType === Semicolon) {
return consumeRawDeclaration.call(this, this.tokenIndex);
}
const node = this.parseWithFallback(this.Declaration, consumeRawDeclaration);
if (this.tokenType === Semicolon) {
this.next();
}
return node;
}
const Block_name = 'Block';
const Block_walkContext = 'block';
const Block_structure = {
children: [[
'Atrule',
'Rule',
'Declaration'
]]
};
function Block_parse(isStyleBlock) {
const consumer = isStyleBlock ? consumeDeclaration : consumeRule;
const start = this.tokenStart;
let children = this.createList();
this.eat(LeftCurlyBracket);
scan:
while (!this.eof) {
switch (this.tokenType) {
case RightCurlyBracket:
break scan;
case WhiteSpace:
case Comment:
this.next();
break;
case AtKeyword:
children.push(this.parseWithFallback(this.Atrule.bind(this, isStyleBlock), Block_consumeRaw));
break;
default:
if (isStyleBlock && this.isDelim(Block_AMPERSAND)) {
children.push(consumeRule.call(this));
} else {
children.push(consumer.call(this));
}
}
}
if (!this.eof) {
this.eat(RightCurlyBracket);
}
return {
type: 'Block',
loc: this.getLocation(start, this.tokenStart),
children
};
}
function Block_generate(node) {
this.token(LeftCurlyBracket, '{');
this.children(node, prev => {
if (prev.type === 'Declaration') {
this.token(Semicolon, ';');
}
});
this.token(RightCurlyBracket, '}');
}
;// ./node_modules/css-tree/lib/syntax/node/Brackets.js
const Brackets_name = 'Brackets';
const Brackets_structure = {
children: [[]]
};
function Brackets_parse(readSequence, recognizer) {
const start = this.tokenStart;
let children = null;
this.eat(LeftSquareBracket);
children = readSequence.call(this, recognizer);
if (!this.eof) {
this.eat(RightSquareBracket);
}
return {
type: 'Brackets',
loc: this.getLocation(start, this.tokenStart),
children
};
}
function Brackets_generate(node) {
this.token(Delim, '[');
this.children(node);
this.token(Delim, ']');
}
;// ./node_modules/css-tree/lib/syntax/node/CDC.js
const CDC_name = 'CDC';
const CDC_structure = [];
function CDC_parse() {
const start = this.tokenStart;
this.eat(CDC); // -->
return {
type: 'CDC',
loc: this.getLocation(start, this.tokenStart)
};
}
function CDC_generate() {
this.token(CDC, '-->');
}
;// ./node_modules/css-tree/lib/syntax/node/CDO.js
const CDO_name = 'CDO';
const CDO_structure = [];
function CDO_parse() {
const start = this.tokenStart;
this.eat(CDO); // <!--
return {
type: 'CDO',
loc: this.getLocation(start, this.tokenStart)
};
}
function CDO_generate() {
this.token(CDO, '<!--');
}
;// ./node_modules/css-tree/lib/syntax/node/ClassSelector.js
const FULLSTOP = 0x002E; // U+002E FULL STOP (.)
// '.' ident
const ClassSelector_name = 'ClassSelector';
const ClassSelector_structure = {
name: String
};
function ClassSelector_parse() {
this.eatDelim(FULLSTOP);
return {
type: 'ClassSelector',
loc: this.getLocation(this.tokenStart - 1, this.tokenEnd),
name: this.consume(Ident)
};
}
function ClassSelector_generate(node) {
this.token(Delim, '.');
this.token(Ident, node.name);
}
;// ./node_modules/css-tree/lib/syntax/node/Combinator.js
const Combinator_PLUSSIGN = 0x002B; // U+002B PLUS SIGN (+)
const SOLIDUS = 0x002F; // U+002F SOLIDUS (/)
const Combinator_GREATERTHANSIGN = 0x003E; // U+003E GREATER-THAN SIGN (>)
const Combinator_TILDE = 0x007E; // U+007E TILDE (~)
const Combinator_name = 'Combinator';
const Combinator_structure = {
name: String
};
// + | > | ~ | /deep/
function Combinator_parse() {
const start = this.tokenStart;
let name;
switch (this.tokenType) {
case WhiteSpace:
name = ' ';
break;
case Delim:
switch (this.charCodeAt(this.tokenStart)) {
case Combinator_GREATERTHANSIGN:
case Combinator_PLUSSIGN:
case Combinator_TILDE:
this.next();
break;
case SOLIDUS:
this.next();
this.eatIdent('deep');
this.eatDelim(SOLIDUS);
break;
default:
this.error('Combinator is expected');
}
name = this.substrToCursor(start);
break;
}
return {
type: 'Combinator',
loc: this.getLocation(start, this.tokenStart),
name
};
}
function Combinator_generate(node) {
this.tokenize(node.name);
}
;// ./node_modules/css-tree/lib/syntax/node/Comment.js
const Comment_ASTERISK = 0x002A; // U+002A ASTERISK (*)
const Comment_SOLIDUS = 0x002F; // U+002F SOLIDUS (/)
const Comment_name = 'Comment';
const Comment_structure = {
value: String
};
function Comment_parse() {
const start = this.tokenStart;
let end = this.tokenEnd;
this.eat(Comment);
if ((end - start + 2) >= 2 &&
this.charCodeAt(end - 2) === Comment_ASTERISK &&
this.charCodeAt(end - 1) === Comment_SOLIDUS) {
end -= 2;
}
return {
type: 'Comment',
loc: this.getLocation(start, this.tokenStart),
value: this.substring(start + 2, end)
};
}
function Comment_generate(node) {
this.token(Comment, '/*' + node.value + '*/');
}
;// ./node_modules/css-tree/lib/syntax/node/Declaration.js
const Declaration_EXCLAMATIONMARK = 0x0021; // U+0021 EXCLAMATION MARK (!)
const Declaration_NUMBERSIGN = 0x0023; // U+0023 NUMBER SIGN (#)
const Declaration_DOLLARSIGN = 0x0024; // U+0024 DOLLAR SIGN ($)
const Declaration_AMPERSAND = 0x0026; // U+0026 AMPERSAND (&)
const Declaration_ASTERISK = 0x002A; // U+002A ASTERISK (*)
const Declaration_PLUSSIGN = 0x002B; // U+002B PLUS SIGN (+)
const Declaration_SOLIDUS = 0x002F; // U+002F SOLIDUS (/)
function consumeValueRaw(startToken) {
return this.Raw(startToken, this.consumeUntilExclamationMarkOrSemicolon, true);
}
function consumeCustomPropertyRaw(startToken) {
return this.Raw(startToken, this.consumeUntilExclamationMarkOrSemicolon, false);
}
function consumeValue() {
const startValueToken = this.tokenIndex;
const value = this.Value();
if (value.type !== 'Raw' &&
this.eof === false &&
this.tokenType !== Semicolon &&
this.isDelim(Declaration_EXCLAMATIONMARK) === false &&
this.isBalanceEdge(startValueToken) === false) {
this.error();
}
return value;
}
const Declaration_name = 'Declaration';
const Declaration_walkContext = 'declaration';
const Declaration_structure = {
important: [Boolean, String],
property: String,
value: ['Value', 'Raw']
};
function Declaration_parse() {
const start = this.tokenStart;
const startToken = this.tokenIndex;
const property = Declaration_readProperty.call(this);
const customProperty = isCustomProperty(property);
const parseValue = customProperty ? this.parseCustomProperty : this.parseValue;
const consumeRaw = customProperty ? consumeCustomPropertyRaw : consumeValueRaw;
let important = false;
let value;
this.skipSC();
this.eat(Colon);
const valueStart = this.tokenIndex;
if (!customProperty) {
this.skipSC();
}
if (parseValue) {
value = this.parseWithFallback(consumeValue, consumeRaw);
} else {
value = consumeRaw.call(this, this.tokenIndex);
}
if (customProperty && value.type === 'Value' && value.children.isEmpty) {
for (let offset = valueStart - this.tokenIndex; offset <= 0; offset++) {
if (this.lookupType(offset) === WhiteSpace) {
value.children.appendData({
type: 'WhiteSpace',
loc: null,
value: ' '
});
break;
}
}
}
if (this.isDelim(Declaration_EXCLAMATIONMARK)) {
important = getImportant.call(this);
this.skipSC();
}
// Do not include semicolon to range per spec
// https://drafts.csswg.org/css-syntax/#declaration-diagram
if (this.eof === false &&
this.tokenType !== Semicolon &&
this.isBalanceEdge(startToken) === false) {
this.error();
}
return {
type: 'Declaration',
loc: this.getLocation(start, this.tokenStart),
important,
property,
value
};
}
function Declaration_generate(node) {
this.token(Ident, node.property);
this.token(Colon, ':');
this.node(node.value);
if (node.important) {
this.token(Delim, '!');
this.token(Ident, node.important === true ? 'important' : node.important);
}
}
function Declaration_readProperty() {
const start = this.tokenStart;
// hacks
if (this.tokenType === Delim) {
switch (this.charCodeAt(this.tokenStart)) {
case Declaration_ASTERISK:
case Declaration_DOLLARSIGN:
case Declaration_PLUSSIGN:
case Declaration_NUMBERSIGN:
case Declaration_AMPERSAND:
this.next();
break;
// TODO: not sure we should support this hack
case Declaration_SOLIDUS:
this.next();
if (this.isDelim(Declaration_SOLIDUS)) {
this.next();
}
break;
}
}
if (this.tokenType === Hash) {
this.eat(Hash);
} else {
this.eat(Ident);
}
return this.substrToCursor(start);
}
// ! ws* important
function getImportant() {
this.eat(Delim);
this.skipSC();
const important = this.consume(Ident);
// store original value in case it differ from `important`
// for better original source restoring and hacks like `!ie` support
return important === 'important' ? true : important;
}
;// ./node_modules/css-tree/lib/syntax/node/DeclarationList.js
const DeclarationList_AMPERSAND = 0x0026; // U+0026 AMPERSAND (&)
function DeclarationList_consumeRaw(startToken) {
return this.Raw(startToken, this.consumeUntilSemicolonIncluded, true);
}
const DeclarationList_name = 'DeclarationList';
const DeclarationList_structure = {
children: [[
'Declaration',
'Atrule',
'Rule'
]]
};
function DeclarationList_parse() {
const children = this.createList();
scan:
while (!this.eof) {
switch (this.tokenType) {
case WhiteSpace:
case Comment:
case Semicolon:
this.next();
break;
case AtKeyword:
children.push(this.parseWithFallback(this.Atrule.bind(this, true), DeclarationList_consumeRaw));
break;
default:
if (this.isDelim(DeclarationList_AMPERSAND)) {
children.push(this.parseWithFallback(this.Rule, DeclarationList_consumeRaw));
} else {
children.push(this.parseWithFallback(this.Declaration, DeclarationList_consumeRaw));
}
}
}
return {
type: 'DeclarationList',
loc: this.getLocationFromList(children),
children
};
}
function DeclarationList_generate(node) {
this.children(node, prev => {
if (prev.type === 'Declaration') {
this.token(Semicolon, ';');
}
});
}
;// ./node_modules/css-tree/lib/syntax/node/Dimension.js
const Dimension_name = 'Dimension';
const Dimension_structure = {
value: String,
unit: String
};
function Dimension_parse() {
const start = this.tokenStart;
const value = this.consumeNumber(Dimension);
return {
type: 'Dimension',
loc: this.getLocation(start, this.tokenStart),
value,
unit: this.substring(start + value.length, this.tokenStart)
};
}
function Dimension_generate(node) {
this.token(Dimension, node.value + node.unit);
}
;// ./node_modules/css-tree/lib/syntax/node/Function.js
const Function_name = 'Function';
const Function_walkContext = 'function';
const Function_structure = {
name: String,
children: [[]]
};
// <function-token> <sequence> )
function Function_parse(readSequence, recognizer) {
const start = this.tokenStart;
const name = this.consumeFunctionName();
const nameLowerCase = name.toLowerCase();
let children;
children = recognizer.hasOwnProperty(nameLowerCase)
? recognizer[nameLowerCase].call(this, recognizer)
: readSequence.call(this, recognizer);
if (!this.eof) {
this.eat(RightParenthesis);
}
return {
type: 'Function',
loc: this.getLocation(start, this.tokenStart),
name,
children
};
}
function Function_generate(node) {
this.token(Function, node.name + '(');
this.children(node);
this.token(RightParenthesis, ')');
}
;// ./node_modules/css-tree/lib/syntax/node/Hash.js
// '#' ident
const xxx = 'XXX';
const Hash_name = 'Hash';
const Hash_structure = {
value: String
};
function Hash_parse() {
const start = this.tokenStart;
this.eat(Hash);
return {
type: 'Hash',
loc: this.getLocation(start, this.tokenStart),
value: this.substrToCursor(start + 1)
};
}
function Hash_generate(node) {
this.token(Hash, '#' + node.value);
}
;// ./node_modules/css-tree/lib/syntax/node/Identifier.js
const Identifier_name = 'Identifier';
const Identifier_structure = {
name: String
};
function Identifier_parse() {
return {
type: 'Identifier',
loc: this.getLocation(this.tokenStart, this.tokenEnd),
name: this.consume(Ident)
};
}
function Identifier_generate(node) {
this.token(Ident, node.name);
}
;// ./node_modules/css-tree/lib/syntax/node/IdSelector.js
const IdSelector_name = 'IdSelector';
const IdSelector_structure = {
name: String
};
function IdSelector_parse() {
const start = this.tokenStart;
// TODO: check value is an ident
this.eat(Hash);
return {
type: 'IdSelector',
loc: this.getLocation(start, this.tokenStart),
name: this.substrToCursor(start + 1)
};
}
function IdSelector_generate(node) {
// Using Delim instead of Hash is a hack to avoid for a whitespace between ident and id-selector
// in safe mode (e.g. "a#id"), because IE11 doesn't allow a sequence <ident-token> <hash-token>
// without a whitespace in values (e.g. "1px solid#000")
this.token(Delim, '#' + node.name);
}
;// ./node_modules/css-tree/lib/syntax/node/MediaFeature.js
const MediaFeature_name = 'MediaFeature';
const MediaFeature_structure = {
name: String,
value: ['Identifier', 'Number', 'Dimension', 'Ratio', null]
};
function MediaFeature_parse() {
const start = this.tokenStart;
let name;
let value = null;
this.eat(LeftParenthesis);
this.skipSC();
name = this.consume(Ident);
this.skipSC();
if (this.tokenType !== RightParenthesis) {
this.eat(Colon);
this.skipSC();
switch (this.tokenType) {
case types_Number:
if (this.lookupNonWSType(1) === Delim) {
value = this.Ratio();
} else {
value = this.Number();
}
break;
case Dimension:
value = this.Dimension();
break;
case Ident:
value = this.Identifier();
break;
default:
this.error('Number, dimension, ratio or identifier is expected');
}
this.skipSC();
}
this.eat(RightParenthesis);
return {
type: 'MediaFeature',
loc: this.getLocation(start, this.tokenStart),
name,
value
};
}
function MediaFeature_generate(node) {
this.token(LeftParenthesis, '(');
this.token(Ident, node.name);
if (node.value !== null) {
this.token(Colon, ':');
this.node(node.value);
}
this.token(RightParenthesis, ')');
}
;// ./node_modules/css-tree/lib/syntax/node/MediaQuery.js
const MediaQuery_name = 'MediaQuery';
const MediaQuery_structure = {
children: [[
'Identifier',
'MediaFeature',
'WhiteSpace'
]]
};
function MediaQuery_parse() {
const children = this.createList();
let child = null;
this.skipSC();
scan:
while (!this.eof) {
switch (this.tokenType) {
case Comment:
case WhiteSpace:
this.next();
continue;
case Ident:
child = this.Identifier();
break;
case LeftParenthesis:
child = this.MediaFeature();
break;
default:
break scan;
}
children.push(child);
}
if (child === null) {
this.error('Identifier or parenthesis is expected');
}
return {
type: 'MediaQuery',
loc: this.getLocationFromList(children),
children
};
}
function MediaQuery_generate(node) {
this.children(node);
}
;// ./node_modules/css-tree/lib/syntax/node/MediaQueryList.js
const MediaQueryList_name = 'MediaQueryList';
const MediaQueryList_structure = {
children: [[
'MediaQuery'
]]
};
function MediaQueryList_parse() {
const children = this.createList();
this.skipSC();
while (!this.eof) {
children.push(this.MediaQuery());
if (this.tokenType !== Comma) {
break;
}
this.next();
}
return {
type: 'MediaQueryList',
loc: this.getLocationFromList(children),
children
};
}
function MediaQueryList_generate(node) {
this.children(node, () => this.token(Comma, ','));
}
;// ./node_modules/css-tree/lib/syntax/node/NestingSelector.js
const NestingSelector_AMPERSAND = 0x0026; // U+0026 AMPERSAND (&)
const NestingSelector_name = 'NestingSelector';
const NestingSelector_structure = {
};
function NestingSelector_parse() {
const start = this.tokenStart;
this.eatDelim(NestingSelector_AMPERSAND);
return {
type: 'NestingSelector',
loc: this.getLocation(start, this.tokenStart)
};
}
function NestingSelector_generate() {
this.token(Delim, '&');
}
;// ./node_modules/css-tree/lib/syntax/node/Nth.js
const Nth_name = 'Nth';
const Nth_structure = {
nth: ['AnPlusB', 'Identifier'],
selector: ['SelectorList', null]
};
function Nth_parse() {
this.skipSC();
const start = this.tokenStart;
let end = start;
let selector = null;
let nth;
if (this.lookupValue(0, 'odd') || this.lookupValue(0, 'even')) {
nth = this.Identifier();
} else {
nth = this.AnPlusB();
}
end = this.tokenStart;
this.skipSC();
if (this.lookupValue(0, 'of')) {
this.next();
selector = this.SelectorList();
end = this.tokenStart;
}
return {
type: 'Nth',
loc: this.getLocation(start, end),
nth,
selector
};
}
function Nth_generate(node) {
this.node(node.nth);
if (node.selector !== null) {
this.token(Ident, 'of');
this.node(node.selector);
}
}
;// ./node_modules/css-tree/lib/syntax/node/Number.js
const Number_name = 'Number';
const Number_structure = {
value: String
};
function Number_parse() {
return {
type: 'Number',
loc: this.getLocation(this.tokenStart, this.tokenEnd),
value: this.consume(types_Number)
};
}
function Number_generate(node) {
this.token(types_Number, node.value);
}
;// ./node_modules/css-tree/lib/syntax/node/Operator.js
// '/' | '*' | ',' | ':' | '+' | '-'
const Operator_name = 'Operator';
const Operator_structure = {
value: String
};
function Operator_parse() {
const start = this.tokenStart;
this.next();
return {
type: 'Operator',
loc: this.getLocation(start, this.tokenStart),
value: this.substrToCursor(start)
};
}
function Operator_generate(node) {
this.tokenize(node.value);
}
;// ./node_modules/css-tree/lib/syntax/node/Parentheses.js
const Parentheses_name = 'Parentheses';
const Parentheses_structure = {
children: [[]]
};
function Parentheses_parse(readSequence, recognizer) {
const start = this.tokenStart;
let children = null;
this.eat(LeftParenthesis);
children = readSequence.call(this, recognizer);
if (!this.eof) {
this.eat(RightParenthesis);
}
return {
type: 'Parentheses',
loc: this.getLocation(start, this.tokenStart),
children
};
}
function Parentheses_generate(node) {
this.token(LeftParenthesis, '(');
this.children(node);
this.token(RightParenthesis, ')');
}
;// ./node_modules/css-tree/lib/syntax/node/Percentage.js
const Percentage_name = 'Percentage';
const Percentage_structure = {
value: String
};
function Percentage_parse() {
return {
type: 'Percentage',
loc: this.getLocation(this.tokenStart, this.tokenEnd),
value: this.consumeNumber(Percentage)
};
}
function Percentage_generate(node) {
this.token(Percentage, node.value + '%');
}
;// ./node_modules/css-tree/lib/syntax/node/PseudoClassSelector.js
const PseudoClassSelector_name = 'PseudoClassSelector';
const PseudoClassSelector_walkContext = 'function';
const PseudoClassSelector_structure = {
name: String,
children: [['Raw'], null]
};
// : [ <ident> | <function-token> <any-value>? ) ]
function PseudoClassSelector_parse() {
const start = this.tokenStart;
let children = null;
let name;
let nameLowerCase;
this.eat(Colon);
if (this.tokenType === Function) {
name = this.consumeFunctionName();
nameLowerCase = name.toLowerCase();
if (hasOwnProperty.call(this.pseudo, nameLowerCase)) {
this.skipSC();
children = this.pseudo[nameLowerCase].call(this);
this.skipSC();
} else {
children = this.createList();
children.push(
this.Raw(this.tokenIndex, null, false)
);
}
this.eat(RightParenthesis);
} else {
name = this.consume(Ident);
}
return {
type: 'PseudoClassSelector',
loc: this.getLocation(start, this.tokenStart),
name,
children
};
}
function PseudoClassSelector_generate(node) {
this.token(Colon, ':');
if (node.children === null) {
this.token(Ident, node.name);
} else {
this.token(Function, node.name + '(');
this.children(node);
this.token(RightParenthesis, ')');
}
}
;// ./node_modules/css-tree/lib/syntax/node/PseudoElementSelector.js
const PseudoElementSelector_name = 'PseudoElementSelector';
const PseudoElementSelector_walkContext = 'function';
const PseudoElementSelector_structure = {
name: String,
children: [['Raw'], null]
};
// :: [ <ident> | <function-token> <any-value>? ) ]
function PseudoElementSelector_parse() {
const start = this.tokenStart;
let children = null;
let name;
let nameLowerCase;
this.eat(Colon);
this.eat(Colon);
if (this.tokenType === Function) {
name = this.consumeFunctionName();
nameLowerCase = name.toLowerCase();
if (hasOwnProperty.call(this.pseudo, nameLowerCase)) {
this.skipSC();
children = this.pseudo[nameLowerCase].call(this);
this.skipSC();
} else {
children = this.createList();
children.push(
this.Raw(this.tokenIndex, null, false)
);
}
this.eat(RightParenthesis);
} else {
name = this.consume(Ident);
}
return {
type: 'PseudoElementSelector',
loc: this.getLocation(start, this.tokenStart),
name,
children
};
}
function PseudoElementSelector_generate(node) {
this.token(Colon, ':');
this.token(Colon, ':');
if (node.children === null) {
this.token(Ident, node.name);
} else {
this.token(Function, node.name + '(');
this.children(node);
this.token(RightParenthesis, ')');
}
}
;// ./node_modules/css-tree/lib/syntax/node/Ratio.js
const Ratio_SOLIDUS = 0x002F; // U+002F SOLIDUS (/)
const Ratio_FULLSTOP = 0x002E; // U+002E FULL STOP (.)
// Terms of <ratio> should be a positive numbers (not zero or negative)
// (see https://drafts.csswg.org/mediaqueries-3/#values)
// However, -o-min-device-pixel-ratio takes fractional values as a ratio's term
// and this is using by various sites. Therefore we relax checking on parse
// to test a term is unsigned number without an exponent part.
// Additional checking may be applied on lexer validation.
function Ratio_consumeNumber() {
this.skipSC();
const value = this.consume(types_Number);
for (let i = 0; i < value.length; i++) {
const code = value.charCodeAt(i);
if (!isDigit(code) && code !== Ratio_FULLSTOP) {
this.error('Unsigned number is expected', this.tokenStart - value.length + i);
}
}
if (Number(value) === 0) {
this.error('Zero number is not allowed', this.tokenStart - value.length);
}
return value;
}
const Ratio_name = 'Ratio';
const Ratio_structure = {
left: String,
right: String
};
// <positive-integer> S* '/' S* <positive-integer>
function Ratio_parse() {
const start = this.tokenStart;
const left = Ratio_consumeNumber.call(this);
let right;
this.skipSC();
this.eatDelim(Ratio_SOLIDUS);
right = Ratio_consumeNumber.call(this);
return {
type: 'Ratio',
loc: this.getLocation(start, this.tokenStart),
left,
right
};
}
function Ratio_generate(node) {
this.token(types_Number, node.left);
this.token(Delim, '/');
this.token(types_Number, node.right);
}
;// ./node_modules/css-tree/lib/syntax/node/Raw.js
function getOffsetExcludeWS() {
if (this.tokenIndex > 0) {
if (this.lookupType(-1) === WhiteSpace) {
return this.tokenIndex > 1
? this.getTokenStart(this.tokenIndex - 1)
: this.firstCharOffset;
}
}
return this.tokenStart;
}
const Raw_name = 'Raw';
const Raw_structure = {
value: String
};
function Raw_parse(startToken, consumeUntil, excludeWhiteSpace) {
const startOffset = this.getTokenStart(startToken);
let endOffset;
this.skipUntilBalanced(startToken, consumeUntil || this.consumeUntilBalanceEnd);
if (excludeWhiteSpace && this.tokenStart > startOffset) {
endOffset = getOffsetExcludeWS.call(this);
} else {
endOffset = this.tokenStart;
}
return {
type: 'Raw',
loc: this.getLocation(startOffset, endOffset),
value: this.substring(startOffset, endOffset)
};
}
function Raw_generate(node) {
this.tokenize(node.value);
}
;// ./node_modules/css-tree/lib/syntax/node/Rule.js
function Rule_consumeRaw(startToken) {
return this.Raw(startToken, this.consumeUntilLeftCurlyBracket, true);
}
function consumePrelude() {
const prelude = this.SelectorList();
if (prelude.type !== 'Raw' &&
this.eof === false &&
this.tokenType !== LeftCurlyBracket) {
this.error();
}
return prelude;
}
const Rule_name = 'Rule';
const Rule_walkContext = 'rule';
const Rule_structure = {
prelude: ['SelectorList', 'Raw'],
block: ['Block']
};
function Rule_parse() {
const startToken = this.tokenIndex;
const startOffset = this.tokenStart;
let prelude;
let block;
if (this.parseRulePrelude) {
prelude = this.parseWithFallback(consumePrelude, Rule_consumeRaw);
} else {
prelude = Rule_consumeRaw.call(this, startToken);
}
block = this.Block(true);
return {
type: 'Rule',
loc: this.getLocation(startOffset, this.tokenStart),
prelude,
block
};
}
function Rule_generate(node) {
this.node(node.prelude);
this.node(node.block);
}
;// ./node_modules/css-tree/lib/syntax/node/Selector.js
const Selector_name = 'Selector';
const Selector_structure = {
children: [[
'TypeSelector',
'IdSelector',
'ClassSelector',
'AttributeSelector',
'PseudoClassSelector',
'PseudoElementSelector',
'Combinator',
'WhiteSpace'
]]
};
function Selector_parse() {
const children = this.readSequence(this.scope.Selector);
// nothing were consumed
if (this.getFirstListNode(children) === null) {
this.error('Selector is expected');
}
return {
type: 'Selector',
loc: this.getLocationFromList(children),
children
};
}
function Selector_generate(node) {
this.children(node);
}
;// ./node_modules/css-tree/lib/syntax/node/SelectorList.js
const SelectorList_name = 'SelectorList';
const SelectorList_walkContext = 'selector';
const SelectorList_structure = {
children: [[
'Selector',
'Raw'
]]
};
function SelectorList_parse() {
const children = this.createList();
while (!this.eof) {
children.push(this.Selector());
if (this.tokenType === Comma) {
this.next();
continue;
}
break;
}
return {
type: 'SelectorList',
loc: this.getLocationFromList(children),
children
};
}
function SelectorList_generate(node) {
this.children(node, () => this.token(Comma, ','));
}
;// ./node_modules/css-tree/lib/utils/string.js
const REVERSE_SOLIDUS = 0x005c; // U+005C REVERSE SOLIDUS (\)
const QUOTATION_MARK = 0x0022; // "
const string_APOSTROPHE = 0x0027; // '
function decode(str) {
const len = str.length;
const firstChar = str.charCodeAt(0);
const start = firstChar === QUOTATION_MARK || firstChar === string_APOSTROPHE ? 1 : 0;
const end = start === 1 && len > 1 && str.charCodeAt(len - 1) === firstChar ? len - 2 : len - 1;
let decoded = '';
for (let i = start; i <= end; i++) {
let code = str.charCodeAt(i);
if (code === REVERSE_SOLIDUS) {
// special case at the ending
if (i === end) {
// if the next input code point is EOF, do nothing
// otherwise include last quote as escaped
if (i !== len - 1) {
decoded = str.substr(i + 1);
}
break;
}
code = str.charCodeAt(++i);
// consume escaped
if (char_code_definitions_isValidEscape(REVERSE_SOLIDUS, code)) {
const escapeStart = i - 1;
const escapeEnd = utils_consumeEscaped(str, escapeStart);
i = escapeEnd - 1;
decoded += utils_decodeEscaped(str.substring(escapeStart + 1, escapeEnd));
} else {
// \r\n
if (code === 0x000d && str.charCodeAt(i + 1) === 0x000a) {
i++;
}
}
} else {
decoded += str[i];
}
}
return decoded;
}
// https://drafts.csswg.org/cssom/#serialize-a-string
// § 2.1. Common Serializing Idioms
function encode(str, apostrophe) {
const quote = apostrophe ? '\'' : '"';
const quoteCode = apostrophe ? string_APOSTROPHE : QUOTATION_MARK;
let encoded = '';
let wsBeforeHexIsNeeded = false;
for (let i = 0; i < str.length; i++) {
const code = str.charCodeAt(i);
// If the character is NULL (U+0000), then the REPLACEMENT CHARACTER (U+FFFD).
if (code === 0x0000) {
encoded += '\uFFFD';
continue;
}
// If the character is in the range [\1-\1f] (U+0001 to U+001F) or is U+007F,
// the character escaped as code point.
// Note: Do not compare with 0x0001 since 0x0000 is precessed before
if (code <= 0x001f || code === 0x007F) {
encoded += '\\' + code.toString(16);
wsBeforeHexIsNeeded = true;
continue;
}
// If the character is '"' (U+0022) or "\" (U+005C), the escaped character.
if (code === quoteCode || code === REVERSE_SOLIDUS) {
encoded += '\\' + str.charAt(i);
wsBeforeHexIsNeeded = false;
} else {
if (wsBeforeHexIsNeeded && (isHexDigit(code) || isWhiteSpace(code))) {
encoded += ' ';
}
// Otherwise, the character itself.
encoded += str.charAt(i);
wsBeforeHexIsNeeded = false;
}
}
return quote + encoded + quote;
}
;// ./node_modules/css-tree/lib/syntax/node/String.js
const String_name = 'String';
const String_structure = {
value: String
};
function String_parse() {
return {
type: 'String',
loc: this.getLocation(this.tokenStart, this.tokenEnd),
value: decode(this.consume(types_String))
};
}
function String_generate(node) {
this.token(types_String, encode(node.value));
}
;// ./node_modules/css-tree/lib/syntax/node/StyleSheet.js
const StyleSheet_EXCLAMATIONMARK = 0x0021; // U+0021 EXCLAMATION MARK (!)
function StyleSheet_consumeRaw(startToken) {
return this.Raw(startToken, null, false);
}
const StyleSheet_name = 'StyleSheet';
const StyleSheet_walkContext = 'stylesheet';
const StyleSheet_structure = {
children: [[
'Comment',
'CDO',
'CDC',
'Atrule',
'Rule',
'Raw'
]]
};
function StyleSheet_parse() {
const start = this.tokenStart;
const children = this.createList();
let child;
scan:
while (!this.eof) {
switch (this.tokenType) {
case WhiteSpace:
this.next();
continue;
case Comment:
// ignore comments except exclamation comments (i.e. /*! .. */) on top level
if (this.charCodeAt(this.tokenStart + 2) !== StyleSheet_EXCLAMATIONMARK) {
this.next();
continue;
}
child = this.Comment();
break;
case CDO: // <!--
child = this.CDO();
break;
case CDC: // -->
child = this.CDC();
break;
// CSS Syntax Module Level 3
// §2.2 Error handling
// At the "top level" of a stylesheet, an <at-keyword-token> starts an at-rule.
case AtKeyword:
child = this.parseWithFallback(this.Atrule, StyleSheet_consumeRaw);
break;
// Anything else starts a qualified rule ...
default:
child = this.parseWithFallback(this.Rule, StyleSheet_consumeRaw);
}
children.push(child);
}
return {
type: 'StyleSheet',
loc: this.getLocation(start, this.tokenStart),
children
};
}
function StyleSheet_generate(node) {
this.children(node);
}
;// ./node_modules/css-tree/lib/syntax/node/TypeSelector.js
const TypeSelector_ASTERISK = 0x002A; // U+002A ASTERISK (*)
const TypeSelector_VERTICALLINE = 0x007C; // U+007C VERTICAL LINE (|)
function eatIdentifierOrAsterisk() {
if (this.tokenType !== Ident &&
this.isDelim(TypeSelector_ASTERISK) === false) {
this.error('Identifier or asterisk is expected');
}
this.next();
}
const TypeSelector_name = 'TypeSelector';
const TypeSelector_structure = {
name: String
};
// ident
// ident|ident
// ident|*
// *
// *|ident
// *|*
// |ident
// |*
function TypeSelector_parse() {
const start = this.tokenStart;
if (this.isDelim(TypeSelector_VERTICALLINE)) {
this.next();
eatIdentifierOrAsterisk.call(this);
} else {
eatIdentifierOrAsterisk.call(this);
if (this.isDelim(TypeSelector_VERTICALLINE)) {
this.next();
eatIdentifierOrAsterisk.call(this);
}
}
return {
type: 'TypeSelector',
loc: this.getLocation(start, this.tokenStart),
name: this.substrToCursor(start)
};
}
function TypeSelector_generate(node) {
this.tokenize(node.name);
}
;// ./node_modules/css-tree/lib/syntax/node/UnicodeRange.js
const UnicodeRange_PLUSSIGN = 0x002B; // U+002B PLUS SIGN (+)
const UnicodeRange_HYPHENMINUS = 0x002D; // U+002D HYPHEN-MINUS (-)
const UnicodeRange_QUESTIONMARK = 0x003F; // U+003F QUESTION MARK (?)
function eatHexSequence(offset, allowDash) {
let len = 0;
for (let pos = this.tokenStart + offset; pos < this.tokenEnd; pos++) {
const code = this.charCodeAt(pos);
if (code === UnicodeRange_HYPHENMINUS && allowDash && len !== 0) {
eatHexSequence.call(this, offset + len + 1, false);
return -1;
}
if (!isHexDigit(code)) {
this.error(
allowDash && len !== 0
? 'Hyphen minus' + (len < 6 ? ' or hex digit' : '') + ' is expected'
: (len < 6 ? 'Hex digit is expected' : 'Unexpected input'),
pos
);
}
if (++len > 6) {
this.error('Too many hex digits', pos);
};
}
this.next();
return len;
}
function eatQuestionMarkSequence(max) {
let count = 0;
while (this.isDelim(UnicodeRange_QUESTIONMARK)) {
if (++count > max) {
this.error('Too many question marks');
}
this.next();
}
}
function UnicodeRange_startsWith(code) {
if (this.charCodeAt(this.tokenStart) !== code) {
this.error((code === UnicodeRange_PLUSSIGN ? 'Plus sign' : 'Hyphen minus') + ' is expected');
}
}
// https://drafts.csswg.org/css-syntax/#urange
// Informally, the <urange> production has three forms:
// U+0001
// Defines a range consisting of a single code point, in this case the code point "1".
// U+0001-00ff
// Defines a range of codepoints between the first and the second value, in this case
// the range between "1" and "ff" (255 in decimal) inclusive.
// U+00??
// Defines a range of codepoints where the "?" characters range over all hex digits,
// in this case defining the same as the value U+0000-00ff.
// In each form, a maximum of 6 digits is allowed for each hexadecimal number (if you treat "?" as a hexadecimal digit).
//
// <urange> =
// u '+' <ident-token> '?'* |
// u <dimension-token> '?'* |
// u <number-token> '?'* |
// u <number-token> <dimension-token> |
// u <number-token> <number-token> |
// u '+' '?'+
function scanUnicodeRange() {
let hexLength = 0;
switch (this.tokenType) {
case types_Number:
// u <number-token> '?'*
// u <number-token> <dimension-token>
// u <number-token> <number-token>
hexLength = eatHexSequence.call(this, 1, true);
if (this.isDelim(UnicodeRange_QUESTIONMARK)) {
eatQuestionMarkSequence.call(this, 6 - hexLength);
break;
}
if (this.tokenType === Dimension ||
this.tokenType === types_Number) {
UnicodeRange_startsWith.call(this, UnicodeRange_HYPHENMINUS);
eatHexSequence.call(this, 1, false);
break;
}
break;
case Dimension:
// u <dimension-token> '?'*
hexLength = eatHexSequence.call(this, 1, true);
if (hexLength > 0) {
eatQuestionMarkSequence.call(this, 6 - hexLength);
}
break;
default:
// u '+' <ident-token> '?'*
// u '+' '?'+
this.eatDelim(UnicodeRange_PLUSSIGN);
if (this.tokenType === Ident) {
hexLength = eatHexSequence.call(this, 0, true);
if (hexLength > 0) {
eatQuestionMarkSequence.call(this, 6 - hexLength);
}
break;
}
if (this.isDelim(UnicodeRange_QUESTIONMARK)) {
this.next();
eatQuestionMarkSequence.call(this, 5);
break;
}
this.error('Hex digit or question mark is expected');
}
}
const UnicodeRange_name = 'UnicodeRange';
const UnicodeRange_structure = {
value: String
};
function UnicodeRange_parse() {
const start = this.tokenStart;
// U or u
this.eatIdent('u');
scanUnicodeRange.call(this);
return {
type: 'UnicodeRange',
loc: this.getLocation(start, this.tokenStart),
value: this.substrToCursor(start)
};
}
function UnicodeRange_generate(node) {
this.tokenize(node.value);
}
;// ./node_modules/css-tree/lib/utils/url.js
const url_SPACE = 0x0020; // U+0020 SPACE
const url_REVERSE_SOLIDUS = 0x005c; // U+005C REVERSE SOLIDUS (\)
const url_QUOTATION_MARK = 0x0022; // "
const url_APOSTROPHE = 0x0027; // '
const url_LEFTPARENTHESIS = 0x0028; // U+0028 LEFT PARENTHESIS (()
const url_RIGHTPARENTHESIS = 0x0029; // U+0029 RIGHT PARENTHESIS ())
function url_decode(str) {
const len = str.length;
let start = 4; // length of "url("
let end = str.charCodeAt(len - 1) === url_RIGHTPARENTHESIS ? len - 2 : len - 1;
let decoded = '';
while (start < end && isWhiteSpace(str.charCodeAt(start))) {
start++;
}
while (start < end && isWhiteSpace(str.charCodeAt(end))) {
end--;
}
for (let i = start; i <= end; i++) {
let code = str.charCodeAt(i);
if (code === url_REVERSE_SOLIDUS) {
// special case at the ending
if (i === end) {
// if the next input code point is EOF, do nothing
// otherwise include last left parenthesis as escaped
if (i !== len - 1) {
decoded = str.substr(i + 1);
}
break;
}
code = str.charCodeAt(++i);
// consume escaped
if (char_code_definitions_isValidEscape(url_REVERSE_SOLIDUS, code)) {
const escapeStart = i - 1;
const escapeEnd = utils_consumeEscaped(str, escapeStart);
i = escapeEnd - 1;
decoded += utils_decodeEscaped(str.substring(escapeStart + 1, escapeEnd));
} else {
// \r\n
if (code === 0x000d && str.charCodeAt(i + 1) === 0x000a) {
i++;
}
}
} else {
decoded += str[i];
}
}
return decoded;
}
function url_encode(str) {
let encoded = '';
let wsBeforeHexIsNeeded = false;
for (let i = 0; i < str.length; i++) {
const code = str.charCodeAt(i);
// If the character is NULL (U+0000), then the REPLACEMENT CHARACTER (U+FFFD).
if (code === 0x0000) {
encoded += '\uFFFD';
continue;
}
// If the character is in the range [\1-\1f] (U+0001 to U+001F) or is U+007F,
// the character escaped as code point.
// Note: Do not compare with 0x0001 since 0x0000 is precessed before
if (code <= 0x001f || code === 0x007F) {
encoded += '\\' + code.toString(16);
wsBeforeHexIsNeeded = true;
continue;
}
if (code === url_SPACE ||
code === url_REVERSE_SOLIDUS ||
code === url_QUOTATION_MARK ||
code === url_APOSTROPHE ||
code === url_LEFTPARENTHESIS ||
code === url_RIGHTPARENTHESIS) {
encoded += '\\' + str.charAt(i);
wsBeforeHexIsNeeded = false;
} else {
if (wsBeforeHexIsNeeded && isHexDigit(code)) {
encoded += ' ';
}
encoded += str.charAt(i);
wsBeforeHexIsNeeded = false;
}
}
return 'url(' + encoded + ')';
}
;// ./node_modules/css-tree/lib/syntax/node/Url.js
const Url_name = 'Url';
const Url_structure = {
value: String
};
// <url-token> | <function-token> <string> )
function Url_parse() {
const start = this.tokenStart;
let value;
switch (this.tokenType) {
case Url:
value = url_decode(this.consume(Url));
break;
case Function:
if (!this.cmpStr(this.tokenStart, this.tokenEnd, 'url(')) {
this.error('Function name must be `url`');
}
this.eat(Function);
this.skipSC();
value = decode(this.consume(types_String));
this.skipSC();
if (!this.eof) {
this.eat(RightParenthesis);
}
break;
default:
this.error('Url or Function is expected');
}
return {
type: 'Url',
loc: this.getLocation(start, this.tokenStart),
value
};
}
function Url_generate(node) {
this.token(Url, url_encode(node.value));
}
;// ./node_modules/css-tree/lib/syntax/node/Value.js
const Value_name = 'Value';
const Value_structure = {
children: [[]]
};
function Value_parse() {
const start = this.tokenStart;
const children = this.readSequence(this.scope.Value);
return {
type: 'Value',
loc: this.getLocation(start, this.tokenStart),
children
};
}
function Value_generate(node) {
this.children(node);
}
;// ./node_modules/css-tree/lib/syntax/node/WhiteSpace.js
const WhiteSpace_SPACE = Object.freeze({
type: 'WhiteSpace',
loc: null,
value: ' '
});
const WhiteSpace_name = 'WhiteSpace';
const WhiteSpace_structure = {
value: String
};
function WhiteSpace_parse() {
this.eat(WhiteSpace);
return WhiteSpace_SPACE;
// return {
// type: 'WhiteSpace',
// loc: this.getLocation(this.tokenStart, this.tokenEnd),
// value: this.consume(WHITESPACE)
// };
}
function WhiteSpace_generate(node) {
this.token(WhiteSpace, node.value);
}
;// ./node_modules/css-tree/lib/syntax/node/index.js
;// ./node_modules/css-tree/lib/syntax/config/lexer.js
/* harmony default export */ const lexer = ({
generic: true,
...data,
node: node_namespaceObject
});
;// ./node_modules/css-tree/lib/syntax/scope/default.js
const default_NUMBERSIGN = 0x0023; // U+0023 NUMBER SIGN (#)
const default_ASTERISK = 0x002A; // U+002A ASTERISK (*)
const default_PLUSSIGN = 0x002B; // U+002B PLUS SIGN (+)
const default_HYPHENMINUS = 0x002D; // U+002D HYPHEN-MINUS (-)
const default_SOLIDUS = 0x002F; // U+002F SOLIDUS (/)
const default_U = 0x0075; // U+0075 LATIN SMALL LETTER U (u)
function defaultRecognizer(context) {
switch (this.tokenType) {
case Hash:
return this.Hash();
case Comma:
return this.Operator();
case LeftParenthesis:
return this.Parentheses(this.readSequence, context.recognizer);
case LeftSquareBracket:
return this.Brackets(this.readSequence, context.recognizer);
case types_String:
return this.String();
case Dimension:
return this.Dimension();
case Percentage:
return this.Percentage();
case types_Number:
return this.Number();
case Function:
return this.cmpStr(this.tokenStart, this.tokenEnd, 'url(')
? this.Url()
: this.Function(this.readSequence, context.recognizer);
case Url:
return this.Url();
case Ident:
// check for unicode range, it should start with u+ or U+
if (this.cmpChar(this.tokenStart, default_U) &&
this.cmpChar(this.tokenStart + 1, default_PLUSSIGN)) {
return this.UnicodeRange();
} else {
return this.Identifier();
}
case Delim: {
const code = this.charCodeAt(this.tokenStart);
if (code === default_SOLIDUS ||
code === default_ASTERISK ||
code === default_PLUSSIGN ||
code === default_HYPHENMINUS) {
return this.Operator(); // TODO: replace with Delim
}
// TODO: produce a node with Delim node type
if (code === default_NUMBERSIGN) {
this.error('Hex or identifier is expected', this.tokenStart + 1);
}
break;
}
}
};
;// ./node_modules/css-tree/lib/syntax/scope/atrulePrelude.js
/* harmony default export */ const atrulePrelude = ({
getNode: defaultRecognizer
});
;// ./node_modules/css-tree/lib/syntax/scope/selector.js
const selector_NUMBERSIGN = 0x0023; // U+0023 NUMBER SIGN (#)
const selector_AMPERSAND = 0x0026; // U+0026 AMPERSAND (&)
const selector_ASTERISK = 0x002A; // U+002A ASTERISK (*)
const selector_PLUSSIGN = 0x002B; // U+002B PLUS SIGN (+)
const selector_SOLIDUS = 0x002F; // U+002F SOLIDUS (/)
const selector_FULLSTOP = 0x002E; // U+002E FULL STOP (.)
const selector_GREATERTHANSIGN = 0x003E; // U+003E GREATER-THAN SIGN (>)
const selector_VERTICALLINE = 0x007C; // U+007C VERTICAL LINE (|)
const selector_TILDE = 0x007E; // U+007E TILDE (~)
function onWhiteSpace(next, children) {
if (children.last !== null && children.last.type !== 'Combinator' &&
next !== null && next.type !== 'Combinator') {
children.push({ // FIXME: this.Combinator() should be used instead
type: 'Combinator',
loc: null,
name: ' '
});
}
}
function getNode() {
switch (this.tokenType) {
case LeftSquareBracket:
return this.AttributeSelector();
case Hash:
return this.IdSelector();
case Colon:
if (this.lookupType(1) === Colon) {
return this.PseudoElementSelector();
} else {
return this.PseudoClassSelector();
}
case Ident:
return this.TypeSelector();
case types_Number:
case Percentage:
return this.Percentage();
case Dimension:
// throws when .123ident
if (this.charCodeAt(this.tokenStart) === selector_FULLSTOP) {
this.error('Identifier is expected', this.tokenStart + 1);
}
break;
case Delim: {
const code = this.charCodeAt(this.tokenStart);
switch (code) {
case selector_PLUSSIGN:
case selector_GREATERTHANSIGN:
case selector_TILDE:
case selector_SOLIDUS: // /deep/
return this.Combinator();
case selector_FULLSTOP:
return this.ClassSelector();
case selector_ASTERISK:
case selector_VERTICALLINE:
return this.TypeSelector();
case selector_NUMBERSIGN:
return this.IdSelector();
case selector_AMPERSAND:
return this.NestingSelector();
}
break;
}
}
};
/* harmony default export */ const selector = ({
onWhiteSpace,
getNode
});
;// ./node_modules/css-tree/lib/syntax/function/expression.js
// legacy IE function
// expression( <any-value> )
/* harmony default export */ function expression() {
return this.createSingleNodeList(
this.Raw(this.tokenIndex, null, false)
);
}
;// ./node_modules/css-tree/lib/syntax/function/var.js
// var( <ident> , <value>? )
/* harmony default export */ function function_var() {
const children = this.createList();
this.skipSC();
// NOTE: Don't check more than a first argument is an ident, rest checks are for lexer
children.push(this.Identifier());
this.skipSC();
if (this.tokenType === Comma) {
children.push(this.Operator());
const startIndex = this.tokenIndex;
const value = this.parseCustomProperty
? this.Value(null)
: this.Raw(this.tokenIndex, this.consumeUntilExclamationMarkOrSemicolon, false);
if (value.type === 'Value' && value.children.isEmpty) {
for (let offset = startIndex - this.tokenIndex; offset <= 0; offset++) {
if (this.lookupType(offset) === WhiteSpace) {
value.children.appendData({
type: 'WhiteSpace',
loc: null,
value: ' '
});
break;
}
}
}
children.push(value);
}
return children;
};
;// ./node_modules/css-tree/lib/syntax/scope/value.js
function isPlusMinusOperator(node) {
return (
node !== null &&
node.type === 'Operator' &&
(node.value[node.value.length - 1] === '-' || node.value[node.value.length - 1] === '+')
);
}
/* harmony default export */ const value = ({
getNode: defaultRecognizer,
onWhiteSpace(next, children) {
if (isPlusMinusOperator(next)) {
next.value = ' ' + next.value;
}
if (isPlusMinusOperator(children.last)) {
children.last.value += ' ';
}
},
'expression': expression,
'var': function_var
});
;// ./node_modules/css-tree/lib/syntax/scope/index.js
;// ./node_modules/css-tree/lib/syntax/atrule/font-face.js
/* harmony default export */ const font_face = ({
parse: {
prelude: null,
block() {
return this.Block(true);
}
}
});
;// ./node_modules/css-tree/lib/syntax/atrule/import.js
/* harmony default export */ const atrule_import = ({
parse: {
prelude() {
const children = this.createList();
this.skipSC();
switch (this.tokenType) {
case types_String:
children.push(this.String());
break;
case Url:
case Function:
children.push(this.Url());
break;
default:
this.error('String or url() is expected');
}
if (this.lookupNonWSType(0) === Ident ||
this.lookupNonWSType(0) === LeftParenthesis) {
children.push(this.MediaQueryList());
}
return children;
},
block: null
}
});
;// ./node_modules/css-tree/lib/syntax/atrule/media.js
/* harmony default export */ const media = ({
parse: {
prelude() {
return this.createSingleNodeList(
this.MediaQueryList()
);
},
block(isStyleBlock = false) {
return this.Block(isStyleBlock);
}
}
});
;// ./node_modules/css-tree/lib/syntax/atrule/nest.js
/* harmony default export */ const nest = ({
parse: {
prelude() {
return this.createSingleNodeList(
this.SelectorList()
);
},
block() {
return this.Block(true);
}
}
});
;// ./node_modules/css-tree/lib/syntax/atrule/page.js
/* harmony default export */ const page = ({
parse: {
prelude() {
return this.createSingleNodeList(
this.SelectorList()
);
},
block() {
return this.Block(true);
}
}
});
;// ./node_modules/css-tree/lib/syntax/atrule/supports.js
function supports_consumeRaw() {
return this.createSingleNodeList(
this.Raw(this.tokenIndex, null, false)
);
}
function parentheses() {
this.skipSC();
if (this.tokenType === Ident &&
this.lookupNonWSType(1) === Colon) {
return this.createSingleNodeList(
this.Declaration()
);
}
return supports_readSequence.call(this);
}
function supports_readSequence() {
const children = this.createList();
let child;
this.skipSC();
scan:
while (!this.eof) {
switch (this.tokenType) {
case Comment:
case WhiteSpace:
this.next();
continue;
case Function:
child = this.Function(supports_consumeRaw, this.scope.AtrulePrelude);
break;
case Ident:
child = this.Identifier();
break;
case LeftParenthesis:
child = this.Parentheses(parentheses, this.scope.AtrulePrelude);
break;
default:
break scan;
}
children.push(child);
}
return children;
}
/* harmony default export */ const supports = ({
parse: {
prelude() {
const children = supports_readSequence.call(this);
if (this.getFirstListNode(children) === null) {
this.error('Condition is expected');
}
return children;
},
block(isStyleBlock = false) {
return this.Block(isStyleBlock);
}
}
});
;// ./node_modules/css-tree/lib/syntax/atrule/index.js
/* harmony default export */ const atrule = ({
'font-face': font_face,
'import': atrule_import,
media: media,
nest: nest,
page: page,
supports: supports
});
;// ./node_modules/css-tree/lib/syntax/pseudo/index.js
const selectorList = {
parse() {
return this.createSingleNodeList(
this.SelectorList()
);
}
};
const pseudo_selector = {
parse() {
return this.createSingleNodeList(
this.Selector()
);
}
};
const identList = {
parse() {
return this.createSingleNodeList(
this.Identifier()
);
}
};
const nth = {
parse() {
return this.createSingleNodeList(
this.Nth()
);
}
};
/* harmony default export */ const pseudo = ({
'dir': identList,
'has': selectorList,
'lang': identList,
'matches': selectorList,
'is': selectorList,
'-moz-any': selectorList,
'-webkit-any': selectorList,
'where': selectorList,
'not': selectorList,
'nth-child': nth,
'nth-last-child': nth,
'nth-last-of-type': nth,
'nth-of-type': nth,
'slotted': pseudo_selector,
'host': pseudo_selector,
'host-context': pseudo_selector
});
;// ./node_modules/css-tree/lib/syntax/node/index-parse.js
;// ./node_modules/css-tree/lib/syntax/config/parser.js
/* harmony default export */ const parser = ({
parseContext: {
default: 'StyleSheet',
stylesheet: 'StyleSheet',
atrule: 'Atrule',
atrulePrelude(options) {
return this.AtrulePrelude(options.atrule ? String(options.atrule) : null);
},
mediaQueryList: 'MediaQueryList',
mediaQuery: 'MediaQuery',
rule: 'Rule',
selectorList: 'SelectorList',
selector: 'Selector',
block() {
return this.Block(true);
},
declarationList: 'DeclarationList',
declaration: 'Declaration',
value: 'Value'
},
scope: scope_namespaceObject,
atrule: atrule,
pseudo: pseudo,
node: index_parse_namespaceObject
});
;// ./node_modules/css-tree/lib/syntax/config/walker.js
/* harmony default export */ const walker = ({
node: node_namespaceObject
});
;// ./node_modules/css-tree/lib/syntax/index.js
/* harmony default export */ const syntax = (create({
...lexer,
...parser,
...walker
}));
;// ./node_modules/css-tree/lib/utils/clone.js
function clone(node) {
const result = {};
for (const key in node) {
let value = node[key];
if (value) {
if (Array.isArray(value) || value instanceof List) {
value = value.map(clone);
} else if (value.constructor === Object) {
value = clone(value);
}
}
result[key] = value;
}
return result;
}
;// ./node_modules/css-tree/lib/utils/ident.js
const ident_REVERSE_SOLIDUS = 0x005c; // U+005C REVERSE SOLIDUS (\)
function ident_decode(str) {
const end = str.length - 1;
let decoded = '';
for (let i = 0; i < str.length; i++) {
let code = str.charCodeAt(i);
if (code === ident_REVERSE_SOLIDUS) {
// special case at the ending
if (i === end) {
// if the next input code point is EOF, do nothing
break;
}
code = str.charCodeAt(++i);
// consume escaped
if (isValidEscape(ident_REVERSE_SOLIDUS, code)) {
const escapeStart = i - 1;
const escapeEnd = consumeEscaped(str, escapeStart);
i = escapeEnd - 1;
decoded += decodeEscaped(str.substring(escapeStart + 1, escapeEnd));
} else {
// \r\n
if (code === 0x000d && str.charCodeAt(i + 1) === 0x000a) {
i++;
}
}
} else {
decoded += str[i];
}
}
return decoded;
}
// https://drafts.csswg.org/cssom/#serialize-an-identifier
// § 2.1. Common Serializing Idioms
function ident_encode(str) {
let encoded = '';
// If the character is the first character and is a "-" (U+002D),
// and there is no second character, then the escaped character.
// Note: That's means a single dash string "-" return as escaped dash,
// so move the condition out of the main loop
if (str.length === 1 && str.charCodeAt(0) === 0x002D) {
return '\\-';
}
// To serialize an identifier means to create a string represented
// by the concatenation of, for each character of the identifier:
for (let i = 0; i < str.length; i++) {
const code = str.charCodeAt(i);
// If the character is NULL (U+0000), then the REPLACEMENT CHARACTER (U+FFFD).
if (code === 0x0000) {
encoded += '\uFFFD';
continue;
}
if (
// If the character is in the range [\1-\1f] (U+0001 to U+001F) or is U+007F ...
// Note: Do not compare with 0x0001 since 0x0000 is precessed before
code <= 0x001F || code === 0x007F ||
// [or] ... is in the range [0-9] (U+0030 to U+0039),
(code >= 0x0030 && code <= 0x0039 && (
// If the character is the first character ...
i === 0 ||
// If the character is the second character ... and the first character is a "-" (U+002D)
i === 1 && str.charCodeAt(0) === 0x002D
))
) {
// ... then the character escaped as code point.
encoded += '\\' + code.toString(16) + ' ';
continue;
}
// If the character is not handled by one of the above rules and is greater
// than or equal to U+0080, is "-" (U+002D) or "_" (U+005F), or is in one
// of the ranges [0-9] (U+0030 to U+0039), [A-Z] (U+0041 to U+005A),
// or \[a-z] (U+0061 to U+007A), then the character itself.
if (isName(code)) {
encoded += str.charAt(i);
} else {
// Otherwise, the escaped character.
encoded += '\\' + str.charAt(i);
}
}
return encoded;
}
;// ./node_modules/css-tree/lib/index.js
const {
tokenize: lib_tokenize,
parse: lib_parse,
generate: lib_generate,
lexer: lib_lexer,
createLexer,
walk: lib_walk,
find,
findLast,
findAll,
toPlainObject,
fromPlainObject,
fork
} = syntax;
// EXTERNAL MODULE: external "CryptoJS"
var external_CryptoJS_ = __webpack_require__("crypto-js");
;// ./src/rules/special/original/jjwxc.ts
class Jjwxc extends rules/* BaseRuleClass */.Q {
constructor() {
super();
this.attachmentMode = "TM";
this.concurrencyLimit = 1;
this.charset = "GB18030";
const firstChild = document.querySelector('#nd-setting-tab-1')?.firstElementChild;
const button = document.createElement('button');
button.innerText = '获取token';
button.style.marginLeft = '10px';
firstChild?.parentNode?.insertBefore(button, firstChild.nextSibling);
function encode(data) {
const key = external_CryptoJS_.enc.Utf8.parse("KW8Dvm2N");
const iv = external_CryptoJS_.enc.Utf8.parse("1ae2c94b");
const encrypted = external_CryptoJS_.DES.encrypt(data, key, {
iv: iv,
padding: external_CryptoJS_.pad.Pkcs7,
mode: external_CryptoJS_.mode.CBC
});
return encrypted.toString();
}
function rd() {
const n = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9];
let s = "";
for (let i = 0; i < 20; i++) {
const r = Math.floor(Math.random() * 10);
s += n[r];
}
return s;
}
function generateAndroidId() {
const chars = '0123456789abcdef';
let androidId = '';
for (let i = 0; i < 16; i++) {
const r = Math.floor(Math.random() * 16);
androidId += chars[r];
}
return androidId;
}
function checkLogin(account, password, verificationCode) {
if (account === "" || password === "") {
alert("账号或密码不能为空");
return 0;
}
else if (verificationCode === "") {
return 1;
}
else {
return 2;
}
}
async function login() {
const account = document.getElementById("nd-jj-account")?.value;
const password = document.getElementById("nd-jj-password")?.value;
const verificationCode = document.getElementById("nd-jj-verificationCode")?.value;
const CheckLogin = checkLogin(account, password, verificationCode);
let t = 'phone';
if (account.indexOf("@") !== -1) {
t = 'email';
}
if (CheckLogin != 0) {
const en = encode(password);
const id = rd() + ":" + generateAndroidId() + "d4:";
const sign = encode(Date.now() + "_" + id + "_");
let loginUrl = `https://app.jjwxc.org/androidapi/login?versionCode=402&loginName=${encodeURIComponent(account)}&encode=1&loginPassword=${encodeURIComponent(en)}&sign=${encodeURIComponent(sign)}&identifiers=${encodeURIComponent(id)}&autologin=1`;
const headers = {
Host: "app.jjwxc.org",
'User-Agent': `Mobile ${Date.now()}`,
'Accept-Encoding': 'gzip',
'Keep-Alive': '300',
'Content-Type': '',
'Accept': '',
'Sec-Fetch-Site': '',
'Sec-Fetch-Mode': '',
'Sec-Fetch-Dest': '',
'Accept-Language': '',
};
if (CheckLogin === 1) {
const resJson = await new Promise((resolve) => {
(0,GM/* _GM_xmlhttpRequest */.nV)({
url: loginUrl,
headers: headers,
method: "GET",
anonymous: true,
fetch: true,
responseType: "json",
onload: function (response) {
const resultI = JSON.parse(response.responseText);
loglevel_default().debug(`LoginResponse url ${loginUrl}`);
if (response.status === 200) {
resolve(resultI);
}
else {
loglevel_default().error(`LoginResponse url ${loginUrl} response status = ${response.status}`);
resolve(resultI);
}
},
});
});
if (resJson.code == "221003") {
const verifyUrl = "https://app.jjwxc.org//appDevicesecurityAndroid/getDeviceSecurityCode";
const body = `versionCode=402&username=${encodeURIComponent(account)}&checktype=${t}`;
const responseJson = await new Promise((resolve) => {
(0,GM/* _GM_xmlhttpRequest */.nV)({
url: verifyUrl,
headers: headers,
method: "POST",
data: body,
anonymous: true,
responseType: "json",
onload: function (response) {
const resultI = JSON.parse(response.responseText);
loglevel_default().debug(`CodeResponse url ${verifyUrl}`);
loglevel_default().debug(`${response.responseText}`);
loglevel_default().debug(`${body}`);
if (response.status === 200) {
resolve(resultI);
}
else {
loglevel_default().error(`CodeResponse url ${verifyUrl} response status = ${response.status}`);
resolve(resultI);
}
},
});
});
let msg = responseJson.data.message;
if (!msg)
msg = responseJson.message;
alert(msg);
}
else {
alert(resJson.message);
}
}
else if (CheckLogin === 2) {
loginUrl = loginUrl + "&checktype=" + t + "&checkdevicecode=" + verificationCode;
const tokenJson = await new Promise((resolve) => {
(0,GM/* _GM_xmlhttpRequest */.nV)({
url: loginUrl,
headers: headers,
method: "GET",
anonymous: true,
responseType: "json",
fetch: true,
onload: function (response) {
const resultI = JSON.parse(response.responseText);
loglevel_default().debug(`LoginResponse url ${loginUrl}`);
if (response.status === 200) {
resolve(resultI);
}
else {
loglevel_default().error(`LoginResponse url ${loginUrl} response status = ${response.status}`);
resolve(resultI);
}
},
});
});
const token = tokenJson.token;
const tokenelement = document.getElementById("nd-jj-token");
if (tokenelement) {
tokenelement.textContent = token;
}
}
}
}
button.addEventListener('click', () => {
const page = document.createElement('div');
page.innerHTML = `
<h1 class="center-align">JJ获取token</h1>
<div>
<div class="row">
<div class="input-field">
<label for="account">账号</label>
<input type="text" id="nd-jj-account" name="account" required>
</div>
</div>
<div class="row">
<div class="input-field">
<label for="password">密码</label>
<input type="password" id="nd-jj-password" name="password" required>
</div>
</div>
<div class="row">
<div class="input-field">
<label for="verificationCode">验证码</label>
<input type="text" id="nd-jj-verificationCode" name="verificationCode">
</div>
</div>
<div class="row">
<button type="click" id="nd-jj-login">登录</button>
</div>
</div>
<h2 class="center-align">生成的Token:</h2>
<p id="nd-jj-token" class="center-align"></p>
`;
page.style.position = 'fixed';
page.style.top = '50%';
page.style.left = '50%';
page.style.transform = 'translate(-50%, -50%)';
page.style.padding = '20px';
page.style.backgroundColor = 'white';
page.style.border = '1px solid black';
page.style.zIndex = '1000';
const closeButton = document.createElement('button');
closeButton.innerText = '关闭';
closeButton.style.display = 'block';
closeButton.style.marginTop = '10px';
closeButton.addEventListener('click', () => {
document.body.removeChild(page);
});
page.appendChild(closeButton);
document.body.appendChild(page);
document.getElementById("nd-jj-login")?.addEventListener('click', () => login());
});
}
async bookParse() {
const bookUrl = document.location.href;
const getInformationBlocked = () => {
const fl = Array.from(document.querySelectorAll(".smallreadbody")).filter((div) => div.innerText.includes("文案信息审核未通过,等待作者修改后重新审核"));
return fl.length !== 0;
};
let bookname;
const additionalMetadate = {};
let author = "";
let introduction = null;
let introductionHTML = null;
let introCleanimages = null;
if (!getInformationBlocked()) {
bookname = document.querySelector('#oneboolt .bigtext').innerText.trim();
author = document.querySelector("#oneboolt h2 > a")?.innerText ?? document.querySelector('#oneboolt > .noveltitle > span > a')?.innerText;
const introDom = document.querySelector("#novelintro");
[introduction, introductionHTML, introCleanimages] = await (0,rule/* introDomHandle */.HV)(introDom);
if (introCleanimages) {
additionalMetadate.attachments = [...introCleanimages];
}
const coverUrl = document.querySelector(".noveldefaultimage").src;
if (coverUrl) {
(0,attachments/* getAttachment */["if"])(coverUrl, this.attachmentMode, "cover-", false, (0,attachments/* getRandomName */.VJ)(), { referrerMode: main/* ReferrerMode */.ls.none })
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => loglevel_default().error(error));
}
let tags = document.querySelector("table > tbody > tr > td.readtd > div.righttd > ul.rightul > li:nth-child(1) > span:nth-child(2)").innerText.split("-");
tags = tags.concat(Array.from(document.querySelectorAll("div.smallreadbody:nth-child(3) > span > a")).map((a) => a.innerText));
const perspective = document.querySelector("table > tbody > tr > td.readtd > div.righttd > ul.rightul > li:nth-child(2)").innerText.replace("\n", "");
const workStyle = document.querySelector("table > tbody > tr > td.readtd > div.righttd > ul.rightul > li:nth-child(3)").innerText.replace("\n", "");
tags.push(perspective);
tags.push(workStyle);
additionalMetadate.tags = tags;
}
else {
window.scrollTo(0, document.body.scrollHeight);
await (0,misc/* sleep */.yy)(3000);
bookname = document.querySelector("td[id^=comment_] span.coltext > a")?.innerText
.trim()
.replace(/[《》]/g, "");
window.scrollTo(0, 0);
if (!bookname) {
throw new Error("抓取书名出错");
}
const authorPageUrl = document.querySelector("#oneboolt > tbody > tr:nth-child(1) > td > div > h2 > a")?.href;
if (authorPageUrl) {
const authorPage = await (0,http/* getHtmlDOM */.wA)(authorPageUrl, this.charset);
author =
authorPage.querySelector('span[itemprop="name"]')
?.innerText ?? author;
}
}
const chapters = [];
const trList = document.querySelectorAll("#oneboolt > tbody > tr");
let chapterNumber = 0;
let sectionNumber = 0;
let sectionName = null;
let sectionChapterNumber = 0;
if (trList.length === 0) {
const tr = document.querySelector("div#oneboolt");
if (tr) {
const chapterName = tr.querySelector("h2")?.innerText.trim() ?? "全一章";
const chapterUrl = bookUrl + "&chapterid=1";
chapterNumber++;
const chapter = new Chapter/* Chapter */.I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP: false,
isPaid: null,
sectionName,
sectionNumber,
sectionChapterNumber,
chapterParse: this.chapterParse,
charset: this.charset,
options: {},
});
chapters.push(chapter);
}
}
for (const tr of Array.from(trList)) {
if (tr.getAttribute("bgcolor")) {
sectionNumber++;
sectionChapterNumber = 0;
sectionName = tr.querySelector("b.volumnfont")?.innerText.trim();
}
else if (tr.getAttribute("itemprop")) {
chapterNumber++;
sectionChapterNumber++;
const td = tr.querySelector("td:nth-child(2)");
const a = td?.querySelector("a:nth-child(1)");
const isLocked = () => {
return td?.innerText.trim() === "[锁]";
};
const isVIP = () => {
return !!a?.getAttribute("onclick");
};
if (!isLocked()) {
if (isVIP()) {
const chapterName = a.innerText.trim();
const chapterUrl = a.getAttribute("rel");
if (chapterUrl) {
const chapter = new Chapter/* Chapter */.I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP: isVIP(),
isPaid: null,
sectionName,
sectionNumber,
sectionChapterNumber,
chapterParse: this.chapterParse,
charset: this.charset,
options: {},
});
const isLogin = () => {
if (typeof unsafeWindow.tokenOptions === "object")
return true;
return !document.getElementById("jj_login");
};
if (isVIP() && !isLogin()) {
chapter.status = main/* Status */.nW.aborted;
}
chapters.push(chapter);
}
}
else {
const chapterName = a.innerText.trim();
const chapterUrl = a.href;
const chapter = new Chapter/* Chapter */.I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP: isVIP(),
isPaid: null,
sectionName,
sectionNumber,
sectionChapterNumber,
chapterParse: this.chapterParse,
charset: this.charset,
options: {},
});
const isLogin = () => {
if (typeof unsafeWindow.tokenOptions === "object")
return true;
return !document.getElementById("jj_login");
};
if (isVIP() && !isLogin()) {
chapter.status = main/* Status */.nW.aborted;
}
chapters.push(chapter);
}
}
else {
const chapterName = "[锁]";
const chapterUrl = "";
const chapter = new Chapter/* Chapter */.I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP: false,
isPaid: null,
sectionName,
sectionNumber,
sectionChapterNumber,
chapterParse: this.chapterParse,
charset: this.charset,
options: {},
});
chapter.status = main/* Status */.nW.aborted;
chapters.push(chapter);
}
}
}
return new Book/* Book */.E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
async function publicChapter() {
const doc = await (0,http/* getHtmlDOM */.wA)(chapterUrl, charset);
chapterName = doc.querySelector("div.noveltext h2").innerText.trim();
const content = doc.querySelector("div.noveltext");
if (content) {
(0,lib_dom.rm)("hr", true, content);
const rawAuthorSayDom = content.querySelector(".readsmall");
let authorSayDom;
let authorSayText;
if (rawAuthorSayDom) {
const { dom: adom, text: atext } = await (0,cleanDOM/* cleanDOM */.an)(rawAuthorSayDom, "TM");
[authorSayDom, authorSayText] = [adom, atext];
}
(0,lib_dom.rm)("div", true, content);
(0,lib_dom/* rms */.j3)(["@无限好文,尽在晋江文学城"], content);
let { dom, text, images } = await (0,cleanDOM/* cleanDOM */.an)(content, "TM");
if (rawAuthorSayDom && authorSayDom && authorSayText) {
const hr = document.createElement("hr");
authorSayDom.className = "authorSay";
dom.appendChild(hr);
dom.appendChild(authorSayDom);
text = text + "\n\n" + "-".repeat(20) + "\n\n" + authorSayText;
}
return {
chapterName,
contentRaw: content,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: null,
};
}
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
async function vipChapter() {
async function getFont(dom) {
function getFontInfo() {
const s = dom.querySelectorAll("body > style")[1];
let fontNameI = "";
let fontUrlI = "";
if (s.sheet) {
const f = s.sheet.cssRules[s.sheet.cssRules.length - 2];
const m1 = f.cssText.match(/jjwxcfont_[\d\w]+/);
const m2 = f.cssText.match(/{(.*)}/);
if (m1 && m2) {
fontNameI = m1[0];
const ft = m2[1];
for (const k of ft.split(",")) {
if (k.includes('format("woff2")')) {
const m3 = k.match(/url\("(.*)"\)\s/);
if (m3) {
fontUrlI = document.location.protocol + m3[1];
return [fontNameI, fontUrlI];
}
}
}
}
}
if (fontNameI !== "") {
fontUrlI = `${document.location.protocol}//static.jjwxc.net/tmp/fonts/${fontNameI}.woff2?h=my.jjwxc.net`;
return [fontNameI, fontUrlI];
}
else {
const css = dom.querySelector("div.noveltext")?.classList;
if (css) {
fontNameI = Array.from(css).filter((cn) => cn.startsWith("jjwxcfont_"))[0];
if (fontNameI) {
fontUrlI = `${document.location.protocol}//static.jjwxc.net/tmp/fonts/${fontNameI}.woff2?h=my.jjwxc.net`;
return [fontNameI, fontUrlI];
}
}
}
return [null, null];
}
let retryTime = 0;
function fetchFont(fontUrlI) {
loglevel_default().debug(`[Chapter]请求 ${fontUrlI} Referer ${chapterUrl} 重试次数 ${retryTime}`);
return (0,http/* gfetch */._V)(fontUrlI, {
headers: {
accept: "*/*",
Referer: chapterUrl,
},
responseType: "blob",
})
.then((response) => {
if (response.status >= 200 && response.status <= 299) {
return response.response;
}
else {
loglevel_default().error(`[Chapter]请求 ${fontUrlI} 失败 Referer ${chapterUrl}`);
if (retryTime < setting/* retryLimit */.Iz) {
retryTime++;
return fetchFont(fontUrlI);
}
else {
return null;
}
}
})
.catch((error) => loglevel_default().error(error));
}
const [fontName, fontUrl] = getFontInfo();
if (fontName && fontUrl) {
const fontFileName = `${fontName}.woff2`;
let fontClassObj;
const fontClassObjCache = (0,attachments/* getAttachmentClassCache */._s)(fontUrl);
if (fontClassObjCache) {
fontClassObj = fontClassObjCache;
}
else {
const fontBlob = await fetchFont(fontUrl);
fontClassObj = new Attachment/* AttachmentClass */.q(fontUrl, fontFileName, "TM");
fontClassObj.Blob = fontBlob;
fontClassObj.status = main/* Status */.nW.finished;
(0,attachments/* putAttachmentClassCache */.Ld)(fontClassObj);
}
const fontStyleDom = document.createElement("style");
fontStyleDom.innerHTML = `.${fontName} {
font-family: ${fontName}, 'Microsoft YaHei', PingFangSC-Regular, HelveticaNeue-Light, 'Helvetica Neue Light', sans-serif !important;
}
@font-face {
font-family: ${fontName};
src: url('${fontFileName}') format('woff2');
}
.hide {
display: none;
}`;
return [fontName, fontClassObj, fontStyleDom];
}
return [null, null, null];
}
function decrypt(doc) {
function getDecryptContent() {
function getCookie(name) {
let cookies = "";
const dc = document.cookie;
const prefix = name + "=";
let begin = dc.indexOf("; " + prefix);
if (begin == -1) {
begin = dc.indexOf(prefix);
if (begin != 0)
cookies = null;
}
else {
begin += 2;
}
let end = document.cookie.indexOf(";", begin);
if (end == -1) {
end = dc.length;
}
if (cookies != null) {
cookies = unescape(dc.substring(begin + prefix.length, end));
}
if (cookies == null && name != "token" && name != "managertoken") {
const tokenKey = [
"readerid",
"ubuntu",
"ptid",
"email",
"authorid",
"cookietime",
"islocaluser",
"authorname",
"newwindow",
"showname",
"examineright",
"logintype",
"certification",
"userclosecomment",
"shareweibo",
"commentfilterversion",
];
const managerKey = [
"managerid",
"managertoken",
"moderatorName",
"isAdmin",
"managername",
"loginSource",
"commentSearch",
];
if (tokenKey.indexOf(name) > -1) {
let token = getCookie("token");
const index = tokenKey.indexOf(name);
if (token != null) {
token = strdecode(token);
token = token.split("|");
return token[index];
}
}
else if (managerKey.indexOf(name) > -1) {
let token = getCookie("managertoken");
const index = managerKey.indexOf(name);
if (token != null) {
token = strdecode(token);
token = token.split("|");
return token[index];
}
}
return null;
}
return cookies;
}
function strdecode(str) {
return utf8to16(decode64(str));
}
const base64DecodeChars = [
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, 62, -1, -1, -1, 63, 52, 53, 54,
55, 56, 57, 58, 59, 60, 61, -1, -1, -1, -1, -1, -1, -1, 0, 1, 2, 3,
4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21,
22, 23, 24, 25, -1, -1, -1, -1, -1, -1, 26, 27, 28, 29, 30, 31, 32,
33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49,
50, 51, -1, -1, -1, -1, -1,
];
function decode64(str) {
let c1, c2, c3, c4;
let i, out;
const len = str.length;
i = 0;
out = "";
while (i < len) {
do {
c1 = base64DecodeChars[str.charCodeAt(i++) & 0xff];
} while (i < len && c1 == -1);
if (c1 == -1)
break;
do {
c2 = base64DecodeChars[str.charCodeAt(i++) & 0xff];
} while (i < len && c2 == -1);
if (c2 == -1)
break;
out += String.fromCharCode((c1 << 2) | ((c2 & 0x30) >> 4));
do {
c3 = str.charCodeAt(i++) & 0xff;
if (c3 == 61)
return out;
c3 = base64DecodeChars[c3];
} while (i < len && c3 == -1);
if (c3 == -1)
break;
out += String.fromCharCode(((c2 & 0xf) << 4) | ((c3 & 0x3c) >> 2));
do {
c4 = str.charCodeAt(i++) & 0xff;
if (c4 == 61)
return out;
c4 = base64DecodeChars[c4];
} while (i < len && c4 == -1);
if (c4 == -1)
break;
out += String.fromCharCode(((c3 & 0x03) << 6) | c4);
}
return out;
}
function utf8to16(str) {
let out, i, c;
let char2, char3;
out = "";
const len = str.length;
i = 0;
while (i < len) {
c = str.charCodeAt(i++);
switch (c >> 4) {
case 0:
case 1:
case 2:
case 3:
case 4:
case 5:
case 6:
case 7:
out += str.charAt(i - 1);
break;
case 12:
case 13:
char2 = str.charCodeAt(i++);
out += String.fromCharCode(((c & 0x1f) << 6) | (char2 & 0x3f));
break;
case 14:
char2 = str.charCodeAt(i++);
char3 = str.charCodeAt(i++);
out += String.fromCharCode(((c & 0x0f) << 12) |
((char2 & 0x3f) << 6) |
((char3 & 0x3f) << 0));
break;
}
}
return out;
}
const children = doc.querySelector("#contentlets, #contentvars")?.children;
if (!children) {
throw new Error("获取章节失败");
}
const data = {};
Array.from(children).forEach((item) => (data[item.getAttribute("name")] = item.getAttribute("value")));
const novelid = parseInt(data["novelid"]);
const chapterid = parseInt(data["chapterid"]);
const _readerid = getCookie("readerid");
if (!_readerid) {
throw new Error("无法获取客户号");
}
const readerid = parseInt(_readerid);
const accessKey = data["accessKey"];
const _hash = novelid + "." + chapterid + "." + readerid + "." + accessKey;
const hash = external_CryptoJS_.MD5(_hash).toString();
const convert = (input) => {
let out = 0;
for (let i = 0; i < input.length; i++) {
out += input.charCodeAt(i);
}
return out;
};
const accessKeyConvert = convert(accessKey);
const hashSlice = hash.slice(accessKeyConvert % hash.length) +
hash.slice(0, accessKeyConvert % hash.length);
let hashSlice16 = hashSlice.slice(0, 16);
let hashSlice_16 = hashSlice.slice(-16);
if (hash.charCodeAt(0)) {
[hashSlice16, hashSlice_16] = [hashSlice_16, hashSlice16];
}
const cryptInfo = data["cryptInfo"];
const _decrypedtCryptInfo = external_CryptoJS_.DES.decrypt(cryptInfo, external_CryptoJS_.enc.Utf8.parse(hashSlice16), {
iv: external_CryptoJS_.enc.Utf8.parse(hashSlice_16),
}).toString(external_CryptoJS_.enc.Utf8);
const decrypedtCryptInfo = JSON.parse(atob(_decrypedtCryptInfo));
const verifyTime = (obj) => {
if (new Date()["getTime"]() / 1000 - obj["time"] > 86400) {
throw new Error("章节内容解码失败,内容生成时间与当前设备时间相差过大,请刷新页面或校准当前设备时间。内容生成时间为:" +
new Date(obj["time"] * 100).toLocaleString());
}
};
verifyTime(decrypedtCryptInfo);
const md5sum = external_CryptoJS_.MD5(decrypedtCryptInfo["key"] + decrypedtCryptInfo["time"] + readerid).toString();
const t = md5sum["slice"](accessKeyConvert % md5sum["length"]) +
md5sum["slice"](0, accessKeyConvert % md5sum["length"]);
const key = t.slice(0, 16);
const iv = t.slice(-16);
const decryptContent = external_CryptoJS_.DES.decrypt(data["content"], external_CryptoJS_.enc.Utf8.parse(key), { iv: external_CryptoJS_.enc.Utf8.parse(iv) }).toString(external_CryptoJS_.enc.Utf8);
return decryptContent;
}
const decryptContent = getDecryptContent();
const decryptContentDoc = new DOMParser().parseFromString(decryptContent, "text/html");
function decryptCssEncrypt() {
const cssText = Array.from(doc.querySelectorAll("style"))
.map((s) => s.innerText)
.join("\n");
const ast = lib_parse(cssText);
lib_walk(ast, function (node) {
if (node.type === "Declaration" && node.property === "content") {
const value = (node.value.children.toArray()?.[0]).value;
const selectorList = (this.rule?.prelude).children.toArray();
for (const s of selectorList) {
const _selector = s.children.toArray();
const selector = new Map(_selector.map((sc) => [
sc.type,
sc.name,
]));
const classSelector = selector.get("ClassSelector");
const pseudoClassSelector = selector.get("PseudoClassSelector");
if (classSelector && pseudoClassSelector && value) {
const sNode = decryptContentDoc.querySelector(`.${classSelector}`);
if (sNode) {
const pNode = sNode.parentNode;
const iNode = decryptContentDoc.createElement("span");
iNode.id = `${classSelector}-${pseudoClassSelector}`;
iNode.innerText = value;
if (pseudoClassSelector === "before") {
pNode?.insertBefore(iNode, sNode);
}
else if (pseudoClassSelector === "after") {
pNode?.insertBefore(iNode, sNode.nextSibling);
}
}
}
}
}
});
lib_walk(ast, function (node) {
if (node.type === "Declaration" && node.property === "display") {
const value = (node.value.children.toArray()?.[0]).name;
const selectorList = (this.rule?.prelude).children.toArray();
for (const s of selectorList) {
const _selector = s.children.toArray();
const selector = new Map(_selector.map((sc) => [
sc.type,
sc.name,
]));
const classSelector = selector.get("ClassSelector");
const pseudoClassSelector = selector.get("PseudoClassSelector");
if (classSelector && pseudoClassSelector && value === "none") {
decryptContentDoc
.querySelector(`#${classSelector}-${pseudoClassSelector}`)
?.remove();
}
}
}
});
}
decryptCssEncrypt();
return decryptContentDoc.body.innerHTML;
}
const doc = await (0,http/* ggetHtmlDOM */.pG)(chapterUrl, charset);
const isPaidF = () => {
return !!(!doc.querySelector("#buy_content") &&
doc.querySelector("div.noveltext"));
};
if (isPaidF()) {
const ChapterName = doc.querySelector("div.noveltext h2").innerText.trim();
const content = document.createElement("div");
content.innerHTML = decrypt(doc);
(0,lib_dom.rm)("hr", true, content);
const rawAuthorSayDom = doc.querySelector(".readsmall");
let authorSayDom;
let authorSayText;
if (rawAuthorSayDom) {
(0,lib_dom.rm)("hr", true, rawAuthorSayDom);
const { dom: adom, text: atext } = await (0,cleanDOM/* cleanDOM */.an)(rawAuthorSayDom, "TM");
[authorSayDom, authorSayText] = [adom, atext];
}
(0,lib_dom.rm)("div", true, content);
(0,lib_dom/* rms */.j3)(["@无限好文,尽在晋江文学城"], content);
let { dom: rawDom, text: rawText, images, } = await (0,cleanDOM/* cleanDOM */.an)(content, "TM");
if (rawAuthorSayDom && authorSayDom && authorSayText) {
const hr = document.createElement("hr");
authorSayDom.className = "authorSay";
rawDom.appendChild(hr);
rawDom.appendChild(authorSayDom);
rawText = rawText + "\n\n" + "-".repeat(20) + "\n\n" + authorSayText;
}
let finalDom = rawDom;
let finalText = rawText;
const [fontName, fontClassObj, fontStyleDom] = await getFont(doc);
if (fontName && fontClassObj && fontStyleDom) {
finalText = await replaceJjwxcCharacter(fontName, rawText);
images.push(fontClassObj);
finalDom = document.createElement("div");
const replacedDom = document.createElement("div");
replacedDom.innerHTML = await replaceJjwxcCharacter(fontName, rawDom.innerHTML);
finalDom.appendChild(fontStyleDom);
rawDom.className = `${fontName} hide`;
finalDom.appendChild(rawDom);
finalDom.appendChild(replacedDom);
}
return {
chapterName: ChapterName,
contentRaw: content,
contentText: finalText,
contentHTML: finalDom,
contentImages: images,
additionalMetadate: null,
};
}
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
let retryTime = 0;
function extractKeys(responseHeader) {
const accessKeyMatch = responseHeader.match(/accesskey:([^\r\n]+)/);
const keyStringMatch = responseHeader.match(/keystring:([^\r\n]+)/);
const accessKey = accessKeyMatch ? accessKeyMatch[1].trim() : "accesskey";
const keyString = keyStringMatch ? keyStringMatch[1].trim() : "keystring";
return { accessKey, keyString };
}
function decodeVIPResopnce(responseHeader, responseText) {
let v43, v38, dest;
let accessKey = "accesskey", keyString = "keystring";
const keys = extractKeys(responseHeader);
accessKey = keys.accessKey;
keyString = keys.keyString;
const content = String(responseText);
const accesskeyLen = accessKey.length;
let v9 = 0;
const v6 = String(accessKey[accesskeyLen - 1]).charCodeAt(0);
for (let i = 0; i < accesskeyLen; i++) {
v9 += accessKey[i].charCodeAt(0);
}
const v15 = v9 % keyString.length;
const v17 = v9 / 65;
const v18 = keyString.length;
if (v17 + v15 > v18) {
v43 = keyString.substring(v15, (v18 - v15) + v15);
}
else {
v43 = keyString.substring(v15, v17 + v15);
}
const v32 = content.length;
if ((v6 & 1) != 0) {
v38 = content.substring(v32 - 12, v32);
dest = content.substring(0, v32 - 12);
}
else {
v38 = content.substring(0, 12);
dest = content.substring(12, content.length);
}
const key = external_CryptoJS_.MD5(v43 + v38).toString().substring(0, 8);
const iv = external_CryptoJS_.MD5(v38).toString().substring(0, 8);
const keyHex = external_CryptoJS_.enc.Utf8.parse(key);
const ivHex = external_CryptoJS_.enc.Utf8.parse(iv);
let result = '{"message":"try again!"}';
try {
const decrypted = external_CryptoJS_.DES.decrypt(dest, keyHex, {
iv: ivHex,
mode: external_CryptoJS_.mode.CBC,
padding: external_CryptoJS_.pad.Pkcs7,
});
result = decrypted.toString(external_CryptoJS_.enc.Utf8);
}
catch (e) {
loglevel_default().debug(`decodeVIPResopnce error, 即VIP章节解密失败:${e}`);
result = '{"message":"try again!"}';
}
return result;
}
function decodeVIPText(text) {
const keyHex = external_CryptoJS_.enc.Utf8.parse("KW8Dvm2N");
const ivHex = external_CryptoJS_.enc.Utf8.parse("1ae2c94b");
const decrypted = external_CryptoJS_.DES.decrypt(text, keyHex, {
iv: ivHex,
mode: external_CryptoJS_.mode.CBC,
padding: external_CryptoJS_.pad.Pkcs7,
});
return decrypted.toString(external_CryptoJS_.enc.Utf8);
}
async function getChapterByApi() {
let chapterGetInfoUrl = chapterUrl.replaceAll("id", "Id");
chapterGetInfoUrl = chapterGetInfoUrl.replace("http://www.jjwxc.net/onebook.php?", "https://app.jjwxc.net/androidapi/chapterContent?");
chapterGetInfoUrl = chapterGetInfoUrl.replace("https://www.jjwxc.net/onebook.php?", "https://app.jjwxc.net/androidapi/chapterContent?");
chapterGetInfoUrl = chapterGetInfoUrl.replace("http://my.jjwxc.net/onebook_vip.php?", "https://app.jjwxc.net/androidapi/chapterContent?");
chapterGetInfoUrl = chapterGetInfoUrl.replace("https://my.jjwxc.net/onebook_vip.php?", "https://app.jjwxc.net/androidapi/chapterContent?");
if (isVIP) {
let sid = unsafeWindow.tokenOptions?.Jjwxc;
if (sid) {
if (typeof sid !== "string") {
sid = sid;
if (sid.user_key)
sid = sid.token + "&user_key=" + sid.user_key;
else
sid = sid.token;
}
chapterGetInfoUrl +=
"&versionCode=402&token=" + sid;
}
else {
throw new Error(`当前需要手动捕获android版app token,详见github主页说明`);
}
}
async function getChapterInfo(url) {
loglevel_default().debug(`请求地址: ${url}, Referrer: ${chapterUrl}, 重试次数: ${retryTime}`);
const user_agent = "Mobile " + Date.now();
return new Promise((resolve) => {
(0,GM/* _GM_xmlhttpRequest */.nV)({
url: url,
headers: {
referer: "http://android.jjwxc.net?v=402",
"user-agent": user_agent,
},
method: "GET",
onload: function (response) {
if (response.status === 200) {
if (isVIP) {
let decodeResponseText = String(response.responseText);
let resultI = JSON.parse('{"message":"try again!"}');
try {
resultI = JSON.parse(decodeResponseText);
}
catch (e) {
decodeResponseText = decodeVIPResopnce(response.responseHeaders, decodeResponseText);
}
try {
resultI = JSON.parse(decodeResponseText);
}
catch (e) {
loglevel_default().debug(`json:${decodeResponseText}`);
resultI = JSON.parse('{"message":"try again!"}');
}
resolve(resultI);
}
else {
const resultI = JSON.parse(response.responseText);
resolve(resultI);
}
}
else {
loglevel_default().error(`response status = ${response.status}`);
const resultI = JSON.parse('{"message":"try again!"}');
resolve(resultI);
}
},
});
});
}
let result = await getChapterInfo(chapterGetInfoUrl.toString());
while ("message" in result && result.message == "try again!") {
retryTime++;
if (retryTime > setting/* retryLimit */.Iz) {
retryTime = 0;
loglevel_default().error(`请求${chapterGetInfoUrl.toString()}$失败`);
throw new Error(`请求${chapterGetInfoUrl.toString()}$失败`);
}
result = await getChapterInfo(chapterGetInfoUrl.toString());
}
loglevel_default().debug(`本章请求结果如下: response code ${result?.code}, info ${result.message}`);
retryTime = 0;
if ("content" in result) {
let content = result.content;
if (isVIP)
content = decodeVIPText(content);
let postscript = result.sayBody;
if (isVIP)
postscript;
if (result.sayBody == null)
postscript = " ";
const contentRaw = document.createElement("pre");
contentRaw.innerHTML = content;
let contentText = content
.split("\n")
.map((p) => p.trim())
.join("\n\n");
const _contentHTML = document.createElement("div");
_contentHTML.innerHTML = content
.split("\n")
.map((p) => p.trim())
.map((p) => {
if (p.length === 0) {
return "<p><br/></p>";
}
else {
return `<p>${p}</p>`;
}
})
.join("\n");
const contentHTML = document.createElement("div");
contentHTML.className = "main";
const hr = document.createElement("hr");
const authorSayDom = document.createElement("div");
authorSayDom.innerHTML = postscript
?.split("\n")
?.map((p) => {
if (p.length === 0) {
return "<p><br/></p>";
}
else {
return `<p>${p}</p>`;
}
})
?.join("\n") ?? "";
contentHTML.appendChild(_contentHTML);
contentHTML.appendChild(hr);
contentHTML.appendChild(authorSayDom);
contentRaw.innerHTML = [
contentRaw.innerHTML,
"-".repeat(20),
postscript,
].join("\n\n");
contentText = [contentText, "-".repeat(20), postscript].join("\n\n");
await (0,misc/* sleep */.yy)(2000 + Math.round(Math.random() * 2000));
return {
chapterName,
contentRaw,
contentText,
contentHTML,
contentImages: null,
additionalMetadate: null,
};
}
else {
await (0,misc/* sleep */.yy)(1000 + Math.round(Math.random() * 1000));
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
}
if (isVIP) {
if (typeof unsafeWindow.tokenOptions === "object") {
return getChapterByApi();
}
else {
loglevel_default().error(`当前需要手动捕获android版app token以下载VIP章节,详见github主页说明,脚本将继续尝试使用远程字体下载,但可能会失败`);
return vipChapter();
}
}
else {
return getChapterByApi();
}
}
}
/***/ }),
/***/ "./src/rules/special/original/linovel.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Linovel: () => (/* binding */ Linovel)
/* harmony export */ });
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _main_main__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/main/main.ts");
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules.ts");
class Linovel extends _rules__WEBPACK_IMPORTED_MODULE_0__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
this.concurrencyLimit = 5;
}
async bookParse() {
const bookUrl = document.location.href;
const bookname = document.querySelector(".book-title").innerText.trim();
const author = document.querySelector(".author-frame > .novelist > div:nth-child(3) > a").innerText.trim();
const introDom = document.querySelector(".about-text");
const [introduction, introductionHTML] = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_1__/* .introDomHandle */ .HV)(introDom);
const additionalMetadate = {};
const attachmentsUrlList = [];
const coverUrl = document.querySelector(".book-cover > a").href;
if (coverUrl) {
attachmentsUrlList.push(coverUrl);
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_2__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_3___default().error(error));
}
additionalMetadate.attachments = [];
const volumeCoverUrlList = Array.from(document.querySelectorAll(".section-list > .section > .volume-info > .volume-cover a")).map((a) => a.href);
for (const volumeCoverUrl of volumeCoverUrlList) {
if (!attachmentsUrlList.includes(volumeCoverUrl)) {
attachmentsUrlList.push(volumeCoverUrl);
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_2__/* .getAttachment */ ["if"])(volumeCoverUrl, this.attachmentMode, "volumeCover-")
.then((volumeCoverObj) => {
additionalMetadate.attachments?.push(volumeCoverObj);
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_3___default().error(error));
}
}
additionalMetadate.tags = Array.from(document.querySelectorAll("div.meta-info > div.book-cats.clearfix > a")).map((a) => a.innerText.trim());
const chapters = [];
const sections = document.querySelectorAll(".section-list > .section");
let chapterNumber = 0;
for (let i = 0; i < sections.length; i++) {
const s = sections[i];
const sectionNumber = i + 1;
const sectionName = s.querySelector(".volume-info > h2.volume-title > a").innerText.trim();
let sectionChapterNumber = 0;
const cs = s.querySelectorAll(".chapter-list > .text-content-actual div.chapter");
for (const div of Array.from(cs)) {
const a = div.firstElementChild;
chapterNumber++;
sectionChapterNumber++;
const chapterName = a.innerText.trim();
const chapterUrl = a.href;
const isVIP = () => {
if (div.className.includes("lock")) {
return !div.className.includes("unlock");
}
return false;
};
const isPaid = () => {
return false;
};
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_4__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP: isVIP(),
isPaid: isPaid(),
sectionName,
sectionNumber,
sectionChapterNumber,
chapterParse: this.chapterParse,
charset: this.charset,
options: {},
});
const isLogin = () => {
return false;
};
if (isVIP() && !(isLogin() && chapter.isPaid)) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_5__/* .Status */ .nW.aborted;
}
chapters.push(chapter);
}
}
return new _main_Book__WEBPACK_IMPORTED_MODULE_6__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
async function publicChapter() {
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_7__/* .getHtmlDOM */ .wA)(chapterUrl, charset);
const ChapterName = doc.querySelector(".article-title").innerText.trim();
const content = doc.querySelector(".article-text");
if (content) {
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_8__/* .cleanDOM */ .an)(content, "TM");
return {
chapterName: ChapterName,
contentRaw: content,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: null,
};
}
else {
return {
chapterName: ChapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
}
async function vipChapter() {
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
if (isVIP) {
return vipChapter();
}
else {
return publicChapter();
}
}
}
/***/ }),
/***/ "./src/rules/special/original/lofter.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Lofter: () => (/* binding */ Lofter)
/* harmony export */ });
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _lib_readability__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/lib/readability.ts");
class Lofter extends _rules__WEBPACK_IMPORTED_MODULE_0__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
this.concurrencyLimit = 1;
this.streamZip = true;
}
async bookParse() {
const bookUrl = document.location.origin;
const author = document.title;
const bookname = author + "的Lofter";
const introduction = document
.querySelector('meta[name="Description"]')
?.getAttribute("content")
?.replace(new RegExp(`^${author} - `), "") ?? null;
let introductionHTML = null;
if (introduction) {
introductionHTML = document.createElement("p");
introductionHTML.innerText = introduction;
}
const additionalMetadate = {};
const _avatar = document
.querySelector('link[rel="shortcut icon"]')
?.getAttribute("href");
if (_avatar) {
const avatar = new URL(_avatar);
avatar.search = "";
const avatarUrl = avatar.toString();
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_1__/* .getAttachment */ ["if"])(avatarUrl, this.attachmentMode, "avatar-")
.then((avatarClass) => {
additionalMetadate.cover = avatarClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_2___default().error(error));
}
const chapters = [];
const pageUrlSet = new Set();
const indexPageUrls = [];
const getPageUrl = async (url) => {
_log__WEBPACK_IMPORTED_MODULE_2___default().info(`[chapter]正在抓取目录页:${url}`);
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_3__/* .getHtmlDOM */ .wA)(url, undefined);
const selector = `a[href^="${[document.location.origin, "post"].join("/")}"]`;
const urlSet = new Set(Array.from(doc.querySelectorAll(selector)).map((a) => a.href));
urlSet.forEach((item) => pageUrlSet.add(item));
const selectorl = `a[href^="https://www.lofter.com/lpost"]`;
const urlSetl = new Set(Array.from(doc.querySelectorAll(selectorl)).map((a) => a.href));
urlSetl.forEach((item) => pageUrlSet.add(item));
const getIndexPageNumber = (urlI) => {
const _pageNumber = new URL(urlI).searchParams.get("page") ?? "1";
return parseInt(_pageNumber);
};
const nowIndexPageNumber = getIndexPageNumber(url);
const indexPages = doc.querySelectorAll('a[href^="?page"]');
for (const indexPage of Array.from(indexPages)) {
const indexPageUrl = indexPage.href;
const _indexPageUrlFormat = new URL(indexPageUrl);
_indexPageUrlFormat.searchParams.delete("t");
const indexPageUrlFormat = _indexPageUrlFormat.toString();
const indexPageNumber = getIndexPageNumber(indexPageUrl);
if (indexPageNumber !== nowIndexPageNumber) {
if (!indexPageUrls.includes(indexPageUrlFormat)) {
indexPageUrls.push(indexPageUrlFormat);
await getPageUrl(indexPageUrl);
}
}
}
};
await getPageUrl(document.location.href);
let i = 0;
for (const pageUrl of Array.from(pageUrlSet)) {
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_4__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl: pageUrl,
chapterNumber: i,
chapterName: null,
isVIP: false,
isPaid: false,
sectionName: null,
sectionNumber: null,
sectionChapterNumber: null,
chapterParse: this.chapterParse,
charset: this.charset,
options: { author },
});
chapters.push(chapter);
i++;
}
return new _main_Book__WEBPACK_IMPORTED_MODULE_5__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
async function post() {
_log__WEBPACK_IMPORTED_MODULE_2___default().debug(`[chapter]请求页面:${chapterUrl}`);
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_3__/* .getHtmlDOM */ .wA)(chapterUrl, charset);
chapterName =
doc
.querySelector("title")
?.innerText.replace(new RegExp(`-${options.author}$`), "")
.replaceAll("\n", "")
.trim() ?? null;
const selectors = [
".ct .ctc",
".main .content",
".m-post .text",
".content",
];
let content;
for (const selector of selectors) {
const _content = doc.querySelector(selector);
if (_content !== null && !(0,_lib_dom__WEBPACK_IMPORTED_MODULE_6__/* .isHidden */ .dK)(_content)) {
content = _content;
break;
}
}
if (!content) {
const obj = (0,_lib_readability__WEBPACK_IMPORTED_MODULE_7__.parse)(doc);
if (obj?.content) {
content = obj.content;
}
}
if (content) {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_6__.rm)(".otherinfo", true, content);
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_8__/* .cleanDOM */ .an)(content, "TM");
return {
chapterName,
contentRaw: content,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: null,
};
}
else {
throw new Error(`[chapter]未发现内容,url:${chapterUrl}`);
}
}
async function lpost() {
_log__WEBPACK_IMPORTED_MODULE_2___default().debug(`[chapter]请求页面:${chapterUrl}`);
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_3__/* .ggetHtmlDOM */ .pG)(chapterUrl, charset);
chapterName = doc.querySelector("#title")?.innerText.trim();
const content = doc.querySelector("#m-cnt .long-text");
if (content) {
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_8__/* .cleanDOM */ .an)(content, "TM");
return {
chapterName,
contentRaw: content,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: null,
};
}
else {
throw new Error(`[chapter]未发现内容,url:${chapterUrl}`);
}
}
if (new URL(chapterUrl).pathname.startsWith("/lpost/")) {
return lpost();
}
else {
return post();
}
}
}
/***/ }),
/***/ "./src/rules/special/original/longmabook.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Longmabook: () => (/* binding */ Longmabook)
/* harmony export */ });
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_misc__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/lib/misc.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_5__);
/* harmony import */ var _main_main__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/main/main.ts");
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules.ts");
class Longmabook extends _rules__WEBPACK_IMPORTED_MODULE_0__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
this.concurrencyLimit = 5;
this.nsfw = true;
}
async bookParse() {
const isLogin = Boolean(document.querySelector('a[href="/?act=signinlst"]'));
if (!isLogin) {
alert("小说下载器:海棠文化线上文学城需登录后方可下载!请登录帐号。");
throw new _main_main__WEBPACK_IMPORTED_MODULE_1__/* .ExpectError */ .K5("海棠文化线上文学城需登录后方可浏览!");
}
const self = this;
const bookUrl = document.location.href;
const bookname = document.querySelector("#mypages > div:nth-child(8) > div:nth-child(1) > h4").innerText;
const author = document.querySelector("#writerinfos a").innerText;
const _urlSearch = new URLSearchParams(document.location.search);
const bookId = _urlSearch.get("bookid");
if (!bookId) {
throw new Error("获取 bookid 出错");
}
const bookwritercode = _urlSearch.get("bookwritercode");
const introDom = document
.querySelector("#mypages > div:nth-child(8) > div:nth-child(1)")
?.cloneNode(true);
let [introduction, introductionHTML] = [null, null, null];
if (introDom) {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__.rm)("div", true, introDom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__.rm)("textarea", true, introDom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__.rm)("font", true, introDom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__.rm)("b", true, introDom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__.rm)("span", true, introDom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__.rm)("h4", true, introDom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__.rm)("img", true, introDom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__/* .rms */ .j3)([/【作品编号:\d+】|【作品編號:\d+】/, "\n)\n"], introDom);
[introduction, introductionHTML] = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_3__/* .introDomHandle */ .HV)(introDom, undefined);
}
const additionalMetadate = {};
const coverUrl = document.querySelector("#mypages > div:nth-child(8) > div:nth-child(1) > img")?.src.replace("_s.", "_b.");
if (coverUrl) {
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_4__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_5___default().error(error));
}
additionalMetadate.tags =
document.querySelector('#mypages > div:nth-child(8) > div:nth-child(1) > font[color="#800080"]')?.innerText
.split("/")
.map((item) => item.trim()) ?? [];
const showbooklistAPIUrl = document.location.origin + "/showbooklist.php";
const initShowbooklistParams = {
ebookid: bookId,
pages: "1",
showbooklisttype: "1",
};
const getInitObj = (showbooklistParams) => ({
headers: {
"content-type": "application/x-www-form-urlencoded; charset=UTF-8",
"x-requested-with": "XMLHttpRequest",
},
body: new URLSearchParams(showbooklistParams).toString(),
method: "POST",
mode: "cors",
credentials: "include",
});
const getPages = (doc) => {
const aList = doc.querySelectorAll("a[onclick^=showbooklist]");
const getPageNumber = (a) => {
const s = a.getAttribute("onclick");
if (s) {
const n = /'(\d+)'\)/.exec(s)?.slice(-1)[0];
if (n) {
return parseInt(n, 10);
}
}
};
const _ns = Array.from(aList)
.map(getPageNumber)
.filter((n) => n !== undefined);
return Array.from(new Set(_ns)).sort();
};
const getChapters = (doc) => doc.querySelectorAll('span[uk-icon="file-text"] + a');
const getSections = (doc) => doc.querySelectorAll('span[uk-icon="folder"] + b > font');
const getSName = (sElem) => sElem.innerText.trim();
const getIsVip = (a) => a.parentElement?.innerText.includes("$") ?? false;
const getIsPaid = (a) => a.parentElement?.innerText.includes("已購買,三年內可直接閱讀") ?? false;
const getChapterObjs = (doc) => {
const chapterAList = getChapters(doc);
const sections = getSections(doc);
return Array.from(chapterAList).map((a) => {
const chapterName = a.innerText;
const chapterUrl = a.href;
const _sectionName = (0,_lib_rule__WEBPACK_IMPORTED_MODULE_3__/* .getSectionName */ .lq)(a, sections, getSName);
const isVip = getIsVip(a);
let isPaid = false;
if (isVip) {
isPaid = getIsPaid(a);
}
return {
chapterName,
chapterUrl,
_sectionName,
isVip,
isPaid,
};
});
};
const chapterObjs = [];
const initDoc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_6__/* .getHtmlDomWithRetry */ .kP)(showbooklistAPIUrl, self.charset, getInitObj(initShowbooklistParams));
if (initDoc) {
chapterObjs.push(...getChapterObjs(initDoc));
const pages = getPages(initDoc);
if (pages.length !== 0) {
for (const page of pages) {
const showbooklistParams = (0,_lib_misc__WEBPACK_IMPORTED_MODULE_7__/* .deepcopy */ .OJ)(initShowbooklistParams);
showbooklistParams.pages = page.toString();
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_6__/* .getHtmlDomWithRetry */ .kP)(showbooklistAPIUrl, self.charset, getInitObj(showbooklistParams));
if (doc) {
chapterObjs.push(...getChapterObjs(doc));
}
}
}
}
const chapters = [];
let chapterNumber = 0;
let sectionNumber = 0;
let sectionName = null;
let sectionChapterNumber = 0;
for (const { chapterName, chapterUrl, _sectionName, isVip: isVIP, isPaid, } of chapterObjs) {
if (_sectionName !== sectionName) {
sectionName = _sectionName;
sectionNumber++;
sectionChapterNumber = 0;
}
chapterNumber++;
sectionChapterNumber++;
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_8__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP,
isPaid,
sectionName,
sectionNumber,
sectionChapterNumber,
chapterParse: this.chapterParse,
charset: this.charset,
options: { bookId, bookwritercode },
});
if (chapter.isVIP && !chapter.isPaid) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_1__/* .Status */ .nW.aborted;
}
chapters.push(chapter);
}
return new _main_Book__WEBPACK_IMPORTED_MODULE_9__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
const self = this;
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_6__/* .getHtmlDOM */ .wA)(chapterUrl, charset);
if (doc.body.innerHTML.includes("您目前正在海棠清水區,只能觀看清水認證文章。")) {
if (!window.stopFlag) {
alert("您目前正在海棠清水區,只能觀看清水認證文章。請使用海棠其他網址進入。");
window.stopController.abort();
}
throw new Error("您目前正在海棠清水區,只能觀看清水認證文章。請使用海棠其他網址進入。");
}
const getPaperidAndVercodechk = () => {
const ss = Array.from(doc.querySelectorAll("script")).filter((s) => s.innerText.includes("vercodechk"))[0];
const m = ss.innerText.match(/{\spaperid:\s'(\d+)',\svercodechk:\s'(\w+)'}/);
if (m?.length === 3) {
const [paperidInner, vercodechkInner] = m.slice(1);
return [paperidInner, vercodechkInner];
}
throw new Error("获取 paperid, vercodechk 失败!");
};
const [paperid, vercodechk] = getPaperidAndVercodechk();
const nullObj = {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
if (doc.querySelector("#paperbuybtm")) {
_log__WEBPACK_IMPORTED_MODULE_5___default().info(`[chapter]付费章节 ${chapterName} 未购买。`);
return nullObj;
}
const content = document.createElement("div");
let contentText = "";
let contentImages = [];
const [imagesDom, imagesText, imagesImages] = await getImages();
const [mainDom, mainText, mainImages] = await getMainContent();
const [authorDom, authorText, authorImages] = await getAuthorSay();
const [eggDom, eggText, eggImages] = await getEgg();
if (imagesDom) {
content.appendChild(imagesDom);
contentText += imagesText + "\n\n";
if (imagesImages) {
contentImages = contentImages.concat(imagesImages);
}
}
content.appendChild(mainDom);
contentText += mainText;
if (mainImages) {
contentImages = contentImages.concat(mainImages);
}
if (authorDom) {
const hr = document.createElement("hr");
authorDom.className = "authorSay";
content.appendChild(hr);
content.appendChild(authorDom);
contentText += "\n\n" + "-".repeat(20) + "\n\n" + authorText;
if (authorImages) {
contentImages = contentImages.concat(authorImages);
}
}
if (eggDom) {
const hr = document.createElement("hr");
eggDom.className = "egg";
content.appendChild(hr);
content.appendChild(eggDom);
contentText += "\n\n" + "-".repeat(20) + "\n\n" + eggText;
if (eggImages) {
contentImages = contentImages.concat(eggImages);
}
}
return {
chapterName,
contentRaw: content,
contentText,
contentHTML: content,
contentImages,
additionalMetadate: null,
};
async function getImages() {
const imageDom = document.createElement("div");
Array.from(doc.querySelectorAll("#mypages > div:nth-child(10) > div:nth-child(2) > div:nth-child(6) > ul > li:nth-child(14) > img")).forEach((img) => imageDom.appendChild(img.cloneNode(true)));
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_10__/* .cleanDOM */ .an)(imageDom, self.attachmentMode);
return [dom, text, images];
}
async function getMainContent() {
const showpapercolorUrl = document.location.origin + "/showpapercolor.php";
_log__WEBPACK_IMPORTED_MODULE_5___default().debug(`[chapter]正在请求${showpapercolorUrl}`);
const resp = await fetch(showpapercolorUrl, {
credentials: "include",
headers: {
"Content-Type": "application/x-www-form-urlencoded; charset=UTF-8",
"X-Requested-With": "XMLHttpRequest",
"Cache-Control": "max-age=0",
},
referrer: chapterUrl,
body: new URLSearchParams({
paperid,
vercodechk,
}).toString(),
method: "POST",
mode: "cors",
});
const contentMain = document.createElement("div");
contentMain.innerHTML = await resp.text();
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__.rm)('img[src="/images/fullcolor.png"]', true, contentMain);
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_10__/* .cleanDOM */ .an)(contentMain, self.attachmentMode);
return [dom, text, images];
}
async function getAuthorSay() {
const authorSayDom = doc.querySelector("#colorpanelwritersay");
if (authorSayDom) {
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_10__/* .cleanDOM */ .an)(authorSayDom, self.attachmentMode);
return [dom, text, images];
}
else {
return [null, null, null];
}
}
async function getEgg() {
const hasEgg = Array.from(doc.querySelectorAll('a[href="#gopapergbook"]'))
.map((node) => node.innerText.trim())
.some((text) => text === "發表心得留言");
if (hasEgg) {
const resp = await fetch(document.location.origin + "/showpapereggs.php", {
credentials: "include",
headers: {
Accept: "*/*",
"Content-Type": "application/x-www-form-urlencoded; charset=UTF-8",
"X-Requested-With": "XMLHttpRequest",
},
referrer: chapterUrl,
body: new URLSearchParams({
paperid,
bookwritercode: options.bookwritercode,
}).toString(),
method: "POST",
mode: "cors",
});
const eggHTML = await resp.text();
if (eggHTML.includes("<img src='/images/fullcolor.png' class='fullimg'><a href='#gopapergbook' uk-icon='commenting'>下方留下評論後可完成敲蛋!</a>")) {
const text = "本章含有彩蛋,但并未敲开。";
const dom = document.createElement("div");
dom.innerText = text;
return [dom, text, []];
}
else {
const eggDom = document.createElement("div");
eggDom.innerHTML = eggHTML;
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__.rm)('img[src="/images/fullcolor.png"]', true, eggDom);
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_10__/* .cleanDOM */ .an)(eggDom, self.attachmentMode);
return [dom, text, images];
}
}
else {
return [null, null, null];
}
}
}
}
/***/ }),
/***/ "./src/rules/special/original/myrics.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Myrics: () => (/* binding */ Myrics)
/* harmony export */ });
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/rules.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _lib_misc__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/lib/misc.ts");
/* harmony import */ var p_limit__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./node_modules/p-limit/index.js");
/* harmony import */ var _main_main__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/main/main.ts");
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__("./src/lib/cleanDOM.ts");
class Myrics extends _rules__WEBPACK_IMPORTED_MODULE_1__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
this.concurrencyLimit = 5;
}
async bookParse() {
const bookId = document.location.href.split("/").slice(-1)[0];
const csrf_token = document
.querySelector('meta[name="csrf-token"]')
?.getAttribute("content");
if (!(bookId && csrf_token)) {
throw new Error("初始化失败!找不到 bookId 或 csrf-token");
}
const novelDetailUrl = `https://www.myrics.com/authors/api_novel_detailed/${bookId}`;
const authorDetailUrl = `https://www.myrics.com/novels/api_author_detailed/${bookId}`;
const menuUrl = "https://www.myrics.com/novels/menu";
const headers = {
Accept: "application/json",
"Content-Type": "application/json",
"X-CSRFToken": csrf_token,
};
const novelDetailResp = await fetch(novelDetailUrl, {
credentials: "include",
headers,
body: "null",
method: "POST",
mode: "cors",
});
const _novelDetail = (await novelDetailResp.json());
if (!_novelDetail.isSuccess) {
throw new Error("请求书籍详情失败!");
}
const novelDetail = _novelDetail.data;
const authorDetailResp = await fetch(authorDetailUrl, {
credentials: "include",
headers,
method: "POST",
mode: "cors",
});
const _authroDetail = (await authorDetailResp.json());
if (!_authroDetail.isSuccess) {
throw new Error("请求作者详情失败!");
}
const authroDetail = _authroDetail.data;
const bookUrl = document.location.href;
const tocUrl = document.location.href + "/menu";
const bookname = novelDetail.title;
const author = authroDetail.pen_name;
const introduction = novelDetail.long_summary;
const introductionHTML = document.createElement("div");
introductionHTML.innerText = introduction;
const additionalMetadate = {
tags: [...novelDetail.geners, novelDetail.type],
ids: bookId,
language: "zh",
};
const coverUrl = novelDetail.image;
if (coverUrl) {
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_2__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((img) => {
additionalMetadate.cover = img;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_3___default().error(error));
}
const isLogin = () => {
return (Array.from(document.querySelectorAll("a")).filter((a) => a.getAttribute("@click") === "checkin").length !== 0);
};
const getMenuRequestInit = (page) => ({
credentials: "include",
headers: headers,
referrer: "https://www.myrics.com/novels/6747/menu",
body: JSON.stringify({
page_limit: 12,
id: bookId,
sort: "asc",
page,
}),
method: "POST",
mode: "cors",
});
const getMenu = async (page) => {
const resp = await fetch(menuUrl, getMenuRequestInit(page));
const _menu = (await resp.json());
if (!_menu.isSuccess) {
throw new Error(`获取第${page}页目录失败!`);
}
return _menu.data;
};
const limit = (0,p_limit__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .A)(this.concurrencyLimit);
const getChapters = async () => {
const loginStatus = isLogin();
const { total_page } = await getMenu(1);
const _menus = (0,_lib_misc__WEBPACK_IMPORTED_MODULE_4__/* .range */ .y1)(total_page, 1).map((page) => {
return limit(() => getMenu(page));
});
const menus = await Promise.all(_menus);
const chapters = menus
.map((m) => {
return m.list.map((item) => {
const chapterId = item.id;
const chapterUrl = `https://www.myrics.com/chapters/${chapterId}`;
const chapterNumber = parseInt(item.id);
const chapterName = `${item.sort}. ${item.title}`;
const isVIP = item.coin !== 0;
const isPaid = item?.had_paid ?? false;
const sectionNumber = item.part;
const sectionName = `卷${sectionNumber}`;
const sectionChapterNumber = item.part;
const isAdult = item.is_adult;
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_5__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP,
isPaid,
sectionName,
sectionNumber,
sectionChapterNumber,
chapterParse: this.chapterParse,
charset: this.charset,
options: { bookId, chapterId, created_at: item.created_at },
});
if (chapter.isVIP && !chapter.isPaid) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_6__/* .Status */ .nW.aborted;
}
if (!loginStatus && isAdult) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_6__/* .Status */ .nW.aborted;
}
return chapter;
});
})
.reduce((arr, cur) => {
arr.push(...cur);
return arr;
}, []);
return chapters;
};
const chapters = await getChapters();
let i = 0;
for (const chapter of chapters) {
chapter.chapterNumber = i;
i++;
}
const book = new _main_Book__WEBPACK_IMPORTED_MODULE_7__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
book.ToCUrl = tocUrl;
return book;
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_8__/* .getHtmlDOM */ .wA)(chapterUrl, charset);
const _chapterName = doc.querySelector(".container > h1")?.innerText;
if (_chapterName) {
chapterName = _chapterName;
}
const content = doc.querySelector(".container > .wysiwyg");
if (content) {
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_9__/* .cleanDOM */ .an)(content, "TM");
return {
chapterName,
contentRaw: content,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: {
lastModified: new Date(options.created_at).getTime(),
},
};
}
else {
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
}
}
/***/ }),
/***/ "./src/rules/special/original/pixiv.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Pixiv: () => (/* binding */ Pixiv)
/* harmony export */ });
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _main_main__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/main/main.ts");
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules.ts");
class Pixiv extends _rules__WEBPACK_IMPORTED_MODULE_0__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
this.needLogin = true;
this.concurrencyLimit = 3;
}
async bookParse() {
const self = this;
const meta = {
lang: getLang(),
version: "0e6ff4f1fa77cd8630159156c6ca02363ac6e1a8",
};
if (document.location.pathname.startsWith("/novel/series")) {
const seriesID = /(\d+)\/?$/.exec(document.location.pathname)?.[0];
if (!seriesID) {
throw Error("not found seriesID!");
}
return doSeries(seriesID);
}
else {
const novelID = new URL(document.location.href).searchParams.get("id");
if (!novelID) {
throw Error("not found novelID");
}
const novel = await getNovel(novelID, meta.lang, meta.version);
if (novel.seriesID) {
return doSeries(novel.seriesID);
}
else {
const bookUrl = `https://www.pixiv.net/novel/show.php?id=${novelID}`;
const bookname = novel.title;
const author = novel.userName;
const introductionHTML = document.createElement("div");
introductionHTML.innerHTML = novel.description;
const introduction = introductionHTML.innerText;
const additionalMetadate = {};
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_1__/* .getAttachment */ ["if"])(novel.coverUrl, self.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_2___default().error(error));
additionalMetadate.lastModified = new Date(novel.uploadDate).getTime();
additionalMetadate.tags = novel.tags;
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_3__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl: bookUrl,
chapterNumber: 0,
chapterName: bookname,
isVIP: false,
isPaid: false,
charset: self.charset,
sectionName: null,
sectionNumber: null,
sectionChapterNumber: null,
chapterParse: self.chapterParse,
options: {
id: novelID,
lang: meta.lang,
version: meta.version,
},
});
return new _main_Book__WEBPACK_IMPORTED_MODULE_4__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters: [chapter],
});
}
}
async function doSeries(seriesID) {
const series = await getSeries(seriesID, meta.lang, meta.version);
const bookUrl = `https://www.pixiv.net/novel/series/${seriesID}`;
const bookname = series.bookname;
const author = series.author;
const introduction = series.introduction;
const introductionHTML = document.createElement("div");
introductionHTML.innerText = introduction;
const additionalMetadate = {};
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_1__/* .getAttachment */ ["if"])(series.coverURL, self.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_2___default().error(error));
additionalMetadate.lastModified = series.lastModified;
additionalMetadate.tags = series.tags;
return new _main_Book__WEBPACK_IMPORTED_MODULE_4__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters: series.chapterObjList.map((c) => {
const { viewableType, ...cp } = c;
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_3__/* .Chapter */ .I({
bookUrl,
bookname,
isVIP: false,
isPaid: false,
charset: self.charset,
sectionName: null,
sectionNumber: null,
sectionChapterNumber: null,
chapterParse: self.chapterParse,
...cp,
});
if (viewableType !== 0) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_5__/* .Status */ .nW.aborted;
}
return chapter;
}),
});
}
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
const novel = await getNovel(options.id, options.lang, options.version);
const contentRaw = document.createElement("div");
contentRaw.innerText = novel.content;
await loadPixivimage({
dom: contentRaw,
nid: options.id,
textEmbeddedImages: novel.textEmbeddedImages,
});
replaceMark(contentRaw);
if (novel.coverUrl) {
const novelCover = document.createElement("img");
novelCover.src = novel.coverUrl;
contentRaw.prepend(novelCover);
}
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_6__/* .cleanDOM */ .an)(contentRaw, "TM");
const additionalMetadate = {
lastModified: new Date(novel.uploadDate).getTime(),
tags: novel.tags,
};
return {
chapterName,
contentRaw,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate,
};
async function loadPixivimage({ dom, nid, textEmbeddedImages, }) {
const pixivImages = dom.innerHTML.matchAll(/\[pixivimage:(\d+)]/g);
for (const match of pixivImages) {
await mapperPixivImage(match);
}
const uploadedImages = dom.innerHTML.matchAll(/\[uploadedimage:(\d+)]/g);
for (const match of uploadedImages) {
mapperUploadedImage(match);
}
return dom;
async function mapperPixivImage([str, id]) {
const imgSrc = await getPixivImage(id);
const img = document.createElement("img");
img.src = imgSrc;
const a = document.createElement("a");
a.href = `https://www.pixiv.net/artworks/${id}`;
a.appendChild(img);
dom.innerHTML = dom.innerHTML.replaceAll(str, a.outerHTML);
}
async function getPixivImage(id) {
const url = new URL(`https://www.pixiv.net/ajax/novel/${nid}/insert_illusts`);
url.searchParams.append("id[]", `${id}-1`);
url.searchParams.append("lang", options.lang);
url.searchParams.append("version", options.version);
const resp = await fetch(url.href, {
credentials: "include",
headers: {
Accept: "application/json",
},
method: "GET",
mode: "cors",
});
const illusts = (await resp.json());
if (!illusts.error) {
return illusts.body[`${id}-1`].illust.images.original;
}
else {
throw new Error(`获取插图失败: pixivimage:${id}`);
}
}
function mapperUploadedImage([str, id]) {
const imgSrc = textEmbeddedImages?.[id].urls.original;
if (imgSrc) {
const img = document.createElement("img");
img.src = imgSrc;
dom.innerHTML = dom.innerHTML.replaceAll(str, img.outerHTML);
}
}
}
function replaceMark(dom) {
const chapterMatchs = dom.innerHTML.matchAll(/\[chapter:(.*?)]/g);
for (const match of chapterMatchs) {
const [str, heading] = match;
const strong = document.createElement("strong");
strong.innerText = heading.trim();
dom.innerHTML = dom.innerHTML.replace(str, strong.outerHTML);
}
const newpageMatchs = dom.innerHTML.matchAll(/\[newpage]/g);
let page = 1;
for (const match of newpageMatchs) {
const [str] = match;
page++;
dom.innerHTML = dom.innerHTML.replace(str, `<hr/><a id="page${page}" data-keep="id" href="#"></a>`);
}
const jumpMatchs = dom.innerHTML.matchAll(/\[jump:(\d+)]/g);
for (const match of jumpMatchs) {
const [str, page] = match;
const a = document.createElement("a");
a.innerText = `To page ${page.trim()}`;
a.href = `#page${page.trim()}`;
dom.innerHTML = dom.innerHTML.replace(str, a.outerHTML);
}
const jumpuriMatchs = dom.innerHTML.matchAll(/\[\[jumpuri:(.*?) (>|>) (.*?)]]/gm);
for (const match of jumpuriMatchs) {
const [str, text, , href] = match;
const a = document.createElement("a");
a.innerText = text.trim();
a.href = href.trim();
dom.innerHTML = dom.innerHTML.replace(str, a.outerHTML);
}
const rbMatchs = dom.innerHTML.matchAll(/\[\[rb:(.*?) (>|>) (.*?)]]/g);
for (const match of rbMatchs) {
const [str, rb, , rt] = match;
const ruby = document.createElement("ruby");
const rbElem = document.createElement("rb");
rbElem.innerText = rb.trim();
ruby.appendChild(rbElem);
const rpL = document.createElement("rp");
rpL.innerText = "(";
ruby.appendChild(rpL);
const rtElem = document.createElement("rt");
rtElem.innerText = rt.trim();
ruby.appendChild(rtElem);
const rpR = document.createElement("rp");
rpR.innerText = ")";
ruby.appendChild(rpR);
dom.innerHTML = dom.innerHTML.replace(str, ruby.outerHTML);
}
}
}
}
function getLang() {
return document.querySelector("html")?.getAttribute("lang") ?? "en";
}
async function getSeries(seriesID, lang, version) {
const url = new URL(`https://www.pixiv.net/ajax/novel/series/${seriesID}`);
url.searchParams.append("lang", lang);
url.searchParams.append("version", version);
const resp = await fetch(url, {
credentials: "include",
headers: {
Accept: "application/json",
},
method: "GET",
mode: "cors",
});
const data = (await resp.json());
const seriesTotal = data.body.total;
const chapterObjList = [];
const limit = 30;
let lastOrder = 0;
while (lastOrder < seriesTotal) {
const url2 = new URL(`https://www.pixiv.net/ajax/novel/series_content/${seriesID}`);
url2.searchParams.append("limit", limit.toString());
url2.searchParams.append("last_order", lastOrder.toString());
url2.searchParams.append("order_by", "asc");
url2.searchParams.append("lang", lang);
url2.searchParams.append("version", version);
const resp2 = await fetch(url2, {
credentials: "include",
headers: {
Accept: "application/json",
},
method: "GET",
mode: "cors",
});
const data2 = (await resp2.json());
const seriesContents = data2.body.page.seriesContents;
const chapterObjs = seriesContents.map((s) => {
const id = s.id;
return {
chapterUrl: `https://www.pixiv.net/novel/show.php?id=${id}`,
chapterName: s.title,
chapterNumber: s.series.contentOrder,
options: {
id,
lang,
version,
},
viewableType: s.series.viewableType,
};
});
chapterObjList.push(...chapterObjs);
lastOrder = lastOrder + limit;
}
return {
seriesID,
seriesTotal,
chapterObjList,
bookname: data.body.title,
author: data.body.userName,
introduction: data.body.caption,
coverURL: data.body.cover.urls.original,
language: data.body.language,
tags: data.body.tags,
lastModified: data.body.updatedTimestamp,
};
}
async function getNovel(novelID, lang, version) {
const url = new URL(`https://www.pixiv.net/ajax/novel/${novelID}`);
url.searchParams.append("lang", lang);
url.searchParams.append("version", version);
const resp = await fetch(url, {
credentials: "include",
headers: {
Accept: "application/json",
},
method: "GET",
mode: "cors",
});
const data = (await resp.json());
return {
title: data.body.title,
userName: data.body.userName,
content: data.body.content,
description: data.body.description,
uploadDate: data.body.uploadDate,
coverUrl: data.body.coverUrl,
tags: data.body.tags.tags.map((t) => t.tag),
seriesID: data.body.seriesNavData?.seriesId.toString() ?? null,
textEmbeddedImages: data.body.textEmbeddedImages,
};
}
/***/ }),
/***/ "./src/rules/special/original/qidian.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Qidian: () => (/* binding */ Qidian)
/* harmony export */ });
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_misc__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/lib/misc.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _main_main__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/main/main.ts");
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules.ts");
class Qidian extends _rules__WEBPACK_IMPORTED_MODULE_0__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
this.concurrencyLimit = 1;
}
async bookParse() {
const bookUrl = document.location.href;
if (bookUrl.match("www.qidian.com/book/")) {
return this.bookParse_www();
}
else
return this.bookParse_book();
}
async bookParse_www() {
const _csrfTokenMatch = document.cookie.match(/(?:^|; )_csrfToken=([^;]*)/);
const _csrfToken = _csrfTokenMatch ? decodeURIComponent(_csrfTokenMatch[1]) : null;
if (!_csrfToken) {
throw new Error("未发现 _csrfToken");
}
const bookUrl = document.location.href;
const bookIdMatch = bookUrl.match(/www\.qidian\.com\/book\/(\d+)/);
const bookId = bookIdMatch ? bookIdMatch[1] : null;
const newurl = "https://book.qidian.com/info/" + bookId?.toString();
const author = document.querySelector(".author")?.innerText;
const authorId = document
.getElementById("authorId")
?.getAttribute("data-authorid");
const bookname = document.querySelector("#bookName")?.innerText;
const introDom = document.querySelector("#book-intro-detail");
const [introduction, introductionHTML] = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_1__/* .introDomHandle */ .HV)(introDom);
const additionalMetadate = {};
const coverUrl = document.querySelector("#bookImg > img").src.slice(0, -5);
if (coverUrl) {
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_2__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_3___default().error(error));
}
additionalMetadate.tags = Array.from(document.querySelectorAll("#all-label > a")).map((a) => a.innerText.trim());
const limitFree = Boolean(document.querySelector(".book-information .flag"));
_log__WEBPACK_IMPORTED_MODULE_3___default().info(`[Book]限免书籍 ${limitFree}`);
const sections = document.querySelectorAll(".catalog-volume");
let chapterNumber = 0;
const chapters = [];
for (let i = 0; i < sections.length; i++) {
const s = sections[i];
const sectionNumber = i + 1;
const sectionName = s.querySelector(".volume-name").innerText
.trim()
.split("\n")
.slice(-1)[0]
.split("·")[0]
.trim();
let sectionChapterNumber = 0;
const cs = s.querySelectorAll("ul.volume-chapters > li");
for (const c of Array.from(cs)) {
const a = c.querySelector("a");
chapterNumber++;
sectionChapterNumber++;
const chapterName = a.innerText.trim();
const chapterUrl = a.href;
const isVIP = () => {
const host = new URL(chapterUrl).host;
return host === "vipreader.qidian.com";
};
const isPaid = () => {
if (isVIP()) {
return c.childElementCount !== 2;
}
return false;
};
let chapterId;
if (isVIP()) {
chapterId = /(\d+)\/?$/.exec(chapterUrl)?.slice(-1)[0] ?? null;
}
else {
chapterId = null;
}
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_4__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP: isVIP(),
isPaid: isPaid(),
sectionName,
sectionNumber,
sectionChapterNumber,
chapterParse: this.chapterParse,
charset: this.charset,
options: {
_csrfToken,
bookId,
authorId,
chapterId,
limitFree,
},
});
const isLogin = () => {
const signInDom = document.querySelector(".sign-in");
const signOutDom = document.querySelector(".sign-out");
if (signInDom && signOutDom) {
if (Array.from(signOutDom.classList).includes("hidden")) {
return true;
}
}
return false;
};
if (isVIP()) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_5__/* .Status */ .nW.aborted;
if (limitFree) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_5__/* .Status */ .nW.pending;
}
if (chapter.isPaid) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_5__/* .Status */ .nW.pending;
}
}
chapters.push(chapter);
}
}
return new _main_Book__WEBPACK_IMPORTED_MODULE_6__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async bookParse_book() {
let bookId = document.getElementById("bookImg");
if (bookId) {
bookId = bookId.getAttribute("data-bid");
}
else {
throw new Error("未发现 bookId");
}
const authorId = document
.getElementById("authorId")
?.getAttribute("data-authorid");
const _csrfTokenMatch = document.cookie.match(/(?:^|; )_csrfToken=([^;]*)/);
const _csrfToken = _csrfTokenMatch ? decodeURIComponent(_csrfTokenMatch[1]) : null;
if (!_csrfToken) {
throw new Error("未发现 _csrfToken");
}
const bookUrl = document.location.href;
const bookname = document.querySelector(".book-info > h1 > em").innerText.trim();
const author = document.querySelector(".book-info .writer, .book-info > h1:nth-child(1) > span:nth-child(2)").innerText
.replace(/作\s+者:/, "")
.replace(/\s+著$/, "")
.trim();
const introDom = document.querySelector(".book-info-detail .book-intro");
const [introduction, introductionHTML] = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_1__/* .introDomHandle */ .HV)(introDom);
const additionalMetadate = {};
const coverUrl = document.querySelector("#bookImg > img").src.slice(0, -5);
if (coverUrl) {
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_2__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_3___default().error(error));
}
additionalMetadate.tags = Array.from(document.querySelectorAll(".book-info > .tag > a, .tag-wrap > .tags")).map((a) => a.innerText.trim());
const limitFree = Boolean(document.querySelector(".book-information .flag"));
_log__WEBPACK_IMPORTED_MODULE_3___default().info(`[Book]限免书籍 ${limitFree}`);
const chapters = [];
const liLength = document.querySelectorAll("#j-catalogWrap li").length;
const getChapterTotalNumber = () => {
const span = document.querySelector("#J-catalogCount").innerText.match(/\d+/);
if (span) {
return parseInt(span[0]);
}
};
if (!(liLength && getChapterTotalNumber() === liLength)) {
await (0,_lib_misc__WEBPACK_IMPORTED_MODULE_7__/* .sleep */ .yy)(3000);
}
const sections = document.querySelectorAll("#j-catalogWrap > .volume-wrap > .volume");
let chapterNumber = 0;
for (let i = 0; i < sections.length; i++) {
const s = sections[i];
const sectionNumber = i + 1;
const sectionName = s.querySelector("h3").innerText
.trim()
.split("\n")
.slice(-1)[0]
.split("·")[0]
.trim();
let sectionChapterNumber = 0;
const cs = s.querySelectorAll("ul.cf > li");
for (const c of Array.from(cs)) {
const a = c.querySelector("a");
chapterNumber++;
sectionChapterNumber++;
const chapterName = a.innerText.trim();
const chapterUrl = a.href;
const isVIP = () => {
const host = new URL(chapterUrl).host;
return host === "vipreader.qidian.com";
};
const isPaid = () => {
if (isVIP()) {
return c.childElementCount !== 2;
}
return false;
};
let chapterId;
if (isVIP()) {
chapterId = /(\d+)\/?$/.exec(chapterUrl)?.slice(-1)[0] ?? null;
}
else {
chapterId = null;
}
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_4__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP: isVIP(),
isPaid: isPaid(),
sectionName,
sectionNumber,
sectionChapterNumber,
chapterParse: this.chapterParse,
charset: this.charset,
options: {
_csrfToken,
bookId,
authorId,
chapterId,
limitFree,
},
});
const isLogin = () => {
const signInDom = document.querySelector(".sign-in");
const signOutDom = document.querySelector(".sign-out");
if (signInDom && signOutDom) {
if (Array.from(signOutDom.classList).includes("hidden")) {
return true;
}
}
return false;
};
if (isVIP()) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_5__/* .Status */ .nW.aborted;
if (limitFree) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_5__/* .Status */ .nW.pending;
}
if (chapter.isPaid) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_5__/* .Status */ .nW.pending;
}
}
chapters.push(chapter);
}
}
return new _main_Book__WEBPACK_IMPORTED_MODULE_6__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
const nullObj = {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
async function getChapter() {
let doc;
if (isVIP) {
doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_8__/* .ggetHtmlDOM */ .pG)(chapterUrl, charset);
if (!doc.querySelector(".read-content") ||
(doc.querySelector(".read-content")?.childElementCount ?? 0) < 10) {
doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_8__/* .getFrameContentCondition */ .eF)(chapterUrl, (frame) => {
const doc = frame.contentWindow?.document ?? null;
if (doc) {
return doc.querySelectorAll(".read-content > p").length !== 0;
}
else {
return false;
}
});
if (doc) {
doc = new DOMParser().parseFromString(doc.documentElement.outerHTML, "text/html");
}
}
}
else {
doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_8__/* .ggetHtmlDOM */ .pG)(chapterUrl, charset);
}
if (doc) {
chapterName = doc.querySelector("h1.title").innerText.trim();
if (doc.querySelector(".vip-limit-wrap")) {
return nullObj;
}
const content = document.createElement("div");
let contentText = "";
const contentMain = doc.querySelector("main");
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_9__.rm)("span.review-count", true, contentMain);
const authorSayWrap = doc.querySelector("#r-authorSay");
if (contentMain) {
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_10__/* .cleanDOM */ .an)(contentMain, "TM");
(0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_10__/* .htmlTrim */ .is)(dom);
content.appendChild(dom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_9__/* .rm2 */ .Sf)([/^谷[\u4e00-\u9fa5]{0,1}$/gm], content);
contentText = contentText + text;
if (authorSayWrap) {
const authorSay = authorSayWrap.querySelector("div");
if (authorSay) {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_9__.rm)("a.avatar", false, authorSay);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_9__.rm)("h4", false, authorSay);
const { dom: authorDom, text: authorText, images: authorImages, } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_10__/* .cleanDOM */ .an)(authorSayWrap, "TM");
(0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_10__/* .htmlTrim */ .is)(authorDom);
authorDom.className = "authorSay";
const hr = document.createElement("hr");
content.appendChild(hr);
content.appendChild(authorSay);
contentText =
contentText + "\n\n" + "-".repeat(10) + "\n\n" + authorText;
images.push(...authorImages);
}
}
return {
chapterName,
contentRaw: content,
contentText,
contentHTML: content,
contentImages: images,
additionalMetadate: null,
};
}
}
return nullObj;
}
return getChapter();
}
}
/***/ }),
/***/ "./src/rules/special/original/qimao.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Qimao: () => (/* binding */ Qimao)
/* harmony export */ });
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _main_main__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/main/main.ts");
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules.ts");
/* harmony import */ var _lib_misc__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__("./src/lib/misc.ts");
class Qimao extends _rules__WEBPACK_IMPORTED_MODULE_0__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
}
async bookParse() {
const bookUrl = document.location.href;
const bookname = document.querySelector("div.title > span.txt").innerText.trim();
const author = document.querySelector("div.sub-title > span.txt > em > a").innerHTML.trim();
const introDom = document.querySelector("head > meta[name='description']");
const introduction = introDom.getAttribute('content') || "";
const introductionHTML = document.createElement("div");
introductionHTML.appendChild(document.createTextNode(introduction));
const additionalMetadate = {};
const coverUrl = document.querySelector("div.wrap-pic > img").src;
if (coverUrl) {
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_1__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_2___default().error(error));
}
additionalMetadate.tags = Array.from(document.querySelectorAll("em.qm-tag > a")).map((a) => a.innerText.trim());
const chapters = [];
const cos = document.querySelectorAll('ul.clearfix > li > a > span.txt');
let chapterNumber = 0;
for (const aElem of Array.from(cos)) {
chapterNumber++;
const chapterName = aElem.innerText;
const chapterUrl = aElem.parentNode.href;
const isVIP = () => {
return !!aElem.previousElementSibling;
};
const isPaid = () => {
return false;
};
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_3__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP: isVIP(),
isPaid: isPaid(),
sectionName: null,
sectionNumber: null,
sectionChapterNumber: null,
chapterParse: this.chapterParse,
charset: this.charset,
options: {},
});
const isLogin = () => {
return false;
};
if (isVIP() && !(isLogin() && chapter.isPaid)) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_4__/* .Status */ .nW.aborted;
}
chapters.push(chapter);
}
return new _main_Book__WEBPACK_IMPORTED_MODULE_5__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
async function publicChapter() {
_log__WEBPACK_IMPORTED_MODULE_2___default().debug(`[Chapter]请求 ${chapterUrl}`);
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_6__/* .getHtmlDOM */ .wA)(chapterUrl, charset);
chapterName = doc.querySelector(".chapter-title").innerText.trim();
const content = doc.querySelector(".article");
if (content) {
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_7__/* .cleanDOM */ .an)(content, "TM");
return {
chapterName,
contentRaw: content,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: null,
};
}
else {
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
}
async function vipChapter() {
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
if (isVIP) {
return vipChapter();
}
else {
await (0,_lib_misc__WEBPACK_IMPORTED_MODULE_8__/* .sleep */ .yy)(3000 + Math.round(Math.random() * 2000));
return publicChapter();
}
}
}
/***/ }),
/***/ "./src/rules/special/original/readmoo.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Readmoo: () => (/* binding */ Readmoo)
/* harmony export */ });
/* harmony import */ var p_limit__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./node_modules/p-limit/index.js");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/rules.ts");
/* harmony import */ var _main_Attachment__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/main/Attachment.ts");
/* harmony import */ var _main_main__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/main/main.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _lib_misc__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/lib/misc.ts");
class Readmoo extends _rules__WEBPACK_IMPORTED_MODULE_1__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.saveType = { txt: false, epub: false, raw: { ext: "epub" } };
this.attachmentMode = "TM";
}
async bookParse() {
const Base = "https://reader.readmoo.com";
const navBase = `${Base}/api/book/`;
const headers = {
Accept: "*/*",
Authorization: "bearer TWBLXfuP-NbtCrjD2PAiFA",
Referer: "https://reader.readmoo.com/reader/index.html",
"X-Requested-With": "XMLHttpRequest",
};
const navInit = {
headers,
responseType: "json",
};
const epubInit = {
headers,
};
const epubFileList = [
{
path: "mimetype",
data: new Blob(["application/epub+zip"]),
nocompress: true,
},
];
const bookId = document.location.pathname.split("/").slice(-1)[0];
const navUrl = `${navBase}${bookId}/nav`;
const navResp = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_2__/* .gfetch */ ._V)(navUrl, navInit);
const navData = navResp.response;
if (navData.message !== "success") {
throw new Error("获取 nav 失败!");
}
const epubBase = `${Base}${navData.base}`;
const container_xml_url = `${epubBase}META-INF/container.xml`;
epubFileList.push({
path: "META-INF/container.xml",
data: container_xml_url,
});
const containerResp = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_2__/* .ggetText */ .bx)(container_xml_url, "UTF-8", epubInit);
if (!containerResp) {
throw new Error("抓取 container.xml 失败!");
}
const containerXML = new DOMParser().parseFromString(containerResp, "application/xml");
const content_opf_path = containerXML
.querySelector("rootfile")
?.getAttribute("full-path");
if (!content_opf_path) {
throw new Error("解析 container.xml 出错!");
}
const content_opf_url = `${epubBase}${content_opf_path}`;
epubFileList.push({ path: content_opf_path, data: content_opf_url });
const content_opf_resp = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_2__/* .ggetText */ .bx)(content_opf_url, "UTF-8", epubInit);
if (!content_opf_resp) {
throw new Error("抓取 content.opf 失败!");
}
const contentOpf = new DOMParser().parseFromString(content_opf_resp, "application/xml");
const bookUrl = `https://readmoo.com/book/${bookId}`;
const bookname = contentOpf.getElementsByTagName("dc:title")[0].textContent ?? "";
const author = contentOpf.getElementsByTagName("dc:creator")[0].textContent ?? "";
const items = contentOpf.querySelectorAll("manifest > item");
if (items.length === 0) {
throw new Error("解析 manifest item 出错!");
}
const itemObjs = Array.from(items).map((item) => {
const href = item.getAttribute("href");
const path = `${content_opf_path
.split("/")
.slice(0, -1)
.join("/")}/${href}`;
return {
path,
data: `${epubBase}${path}`,
};
});
epubFileList.push(...itemObjs);
const limit = (0,p_limit__WEBPACK_IMPORTED_MODULE_0__/* ["default"] */ .A)(this.concurrencyLimit);
const attachmentTasks = epubFileList.map((fobj) => {
return limit(async () => {
const { path, data, nocompress } = fobj;
if (typeof data === "string") {
const attach = new _main_Attachment__WEBPACK_IMPORTED_MODULE_3__/* .AttachmentClass */ .q(data, path, this.attachmentMode, _main_main__WEBPACK_IMPORTED_MODULE_4__/* .ReferrerMode */ .ls.keep, "", { init: (0,_lib_misc__WEBPACK_IMPORTED_MODULE_5__/* .deepcopy */ .OJ)(epubInit), TMinit: (0,_lib_misc__WEBPACK_IMPORTED_MODULE_5__/* .deepcopy */ .OJ)(epubInit) });
await attach.init();
if (fobj.nocompress) {
attach.comments = "nocompress";
}
return attach;
}
else {
const attach = new _main_Attachment__WEBPACK_IMPORTED_MODULE_3__/* .AttachmentClass */ .q("", path, this.attachmentMode);
attach.Blob = data;
attach.status = _main_main__WEBPACK_IMPORTED_MODULE_4__/* .Status */ .nW.finished;
if (fobj.nocompress) {
attach.comments = "nocompress";
}
return attach;
}
});
});
const attachments = await Promise.all(attachmentTasks);
const book = new _main_Book__WEBPACK_IMPORTED_MODULE_6__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction: null,
introductionHTML: null,
additionalMetadate: { attachments },
chapters: [
new _main_Chapter__WEBPACK_IMPORTED_MODULE_7__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl: "",
chapterName: null,
chapterNumber: 0,
isVIP: false,
isPaid: null,
sectionName: null,
sectionNumber: null,
sectionChapterNumber: null,
chapterParse: this.chapterParse,
charset: this.charset,
options: {},
}),
],
});
book.saveType = this.saveType;
return book;
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
}
/***/ }),
/***/ "./src/rules/special/original/sfacg.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Sfacg: () => (/* binding */ Sfacg)
/* harmony export */ });
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_4__);
/* harmony import */ var _main_main__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__("./src/main/main.ts");
/* harmony import */ var _main_Attachment__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/main/Attachment.ts");
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules.ts");
/* harmony import */ var _setting__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__("./src/setting.ts");
class Sfacg extends _rules__WEBPACK_IMPORTED_MODULE_0__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
this.concurrencyLimit = 1;
}
async bookParse() {
const bookUrl = document.location.href.replace("/MainIndex/", "");
const bookname = document.querySelector("h1.story-title").innerText.trim();
const dom = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_1__/* .getHtmlDOM */ .wA)(bookUrl, undefined);
const author = dom.querySelector(".author-name").innerText.trim();
const introDom = dom.querySelector(".introduce");
const [introduction, introductionHTML] = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_2__/* .introDomHandle */ .HV)(introDom);
const additionalMetadate = {};
const coverUrl = dom.querySelector("#hasTicket div.pic img").src;
if (coverUrl) {
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_3__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_4___default().error(error));
}
additionalMetadate.tags = Array.from(dom.querySelectorAll("ul.tag-list > li.tag > a")).map((a) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_5__.rm)("span.icn", false, a);
return a.innerText.trim().replace(/\(\d+\)$/, "");
});
if (dom.querySelector(".d-banner")) {
const _beitouUrl = dom.querySelector(".d-banner")?.style.backgroundImage.split('"');
if (_beitouUrl?.length === 3) {
const beitouUrl = _beitouUrl[1];
const beitou = new _main_Attachment__WEBPACK_IMPORTED_MODULE_6__/* .AttachmentClass */ .q(beitouUrl, `beitou.${beitouUrl.split(".").slice(-1)[0]}`, "TM");
beitou.init();
additionalMetadate.attachments = [beitou];
}
}
const chapters = [];
const sections = document.querySelectorAll(".story-catalog");
const chapterElems = document.querySelectorAll(".catalog-list a");
const getName = (sElem) => sElem.querySelector(".catalog-title").innerText
.replace(`【${bookname}】`, "")
.trim();
let chapterNumber = 0;
let sectionNumber = 0;
let sectionChapterNumber = 0;
let _sectionName = "";
for (const elem of Array.from(chapterElems)) {
const chapterName = elem.getAttribute("title")?.trim() ?? "";
const chapterUrl = elem.href;
const sectionName = (0,_lib_rule__WEBPACK_IMPORTED_MODULE_2__/* .getSectionName */ .lq)(elem, sections, getName);
if (sectionName && _sectionName !== sectionName) {
_sectionName = sectionName;
sectionNumber++;
sectionChapterNumber = 0;
}
chapterNumber++;
sectionChapterNumber++;
const isVip = () => {
return (elem.childElementCount !== 0 &&
elem.firstElementChild?.getAttribute("class") === "icn_vip");
};
const isPaid = null;
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_7__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP: isVip(),
isPaid,
sectionName,
sectionNumber,
sectionChapterNumber,
chapterParse: this.chapterParse,
charset: this.charset,
options: {},
});
const isLogin = !document
.querySelector(".user-bar > .top-link > .normal-link")
?.innerHTML.includes("您好,SF游客");
if (chapter.isVIP && !isLogin) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_8__/* .Status */ .nW.aborted;
}
chapters.push(chapter);
}
const book = new _main_Book__WEBPACK_IMPORTED_MODULE_9__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
book.ToCUrl = document.location.href;
return book;
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
const chapterId = chapterUrl.split("/").slice(-2, -1)[0];
async function publicChapter() {
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_1__/* .getHtmlDOM */ .wA)(chapterUrl, charset);
chapterName = doc.querySelector("h1.article-title").innerText.trim();
const content = doc.querySelector(".article-content");
if (content) {
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_10__/* .cleanDOM */ .an)(content, "TM");
return {
chapterName,
contentRaw: content,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: null,
};
}
else {
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
}
async function vipChapter() {
async function getvipChapterImage(vipChapterImageUrl, vipChapterName) {
let retryTime = 0;
function fetchVipChapterImage(vipChapterImageUrlI) {
_log__WEBPACK_IMPORTED_MODULE_4___default().debug(`[Chapter]请求 ${vipChapterImageUrlI} Referer ${chapterUrl} 重试次数 ${retryTime}`);
return fetch(vipChapterImageUrlI, {
headers: {
accept: "image/avif,image/webp,image/apng,image/svg+xml,image/*,*/*;q=0.8",
},
referrer: chapterUrl,
body: null,
method: "GET",
mode: "cors",
credentials: "include",
})
.then((response) => response.blob())
.then((blob) => {
if (blob.size === 53658 || blob.size === 42356) {
_log__WEBPACK_IMPORTED_MODULE_4___default().error(`[Chapter]请求 ${vipChapterImageUrlI} 失败 Referer ${chapterUrl}`);
if (retryTime < _setting__WEBPACK_IMPORTED_MODULE_11__/* .retryLimit */ .Iz) {
retryTime++;
return fetchVipChapterImage(vipChapterImageUrlI);
}
else {
return null;
}
}
else {
return blob;
}
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_4___default().error(error));
}
const vipChapterImageBlob = await fetchVipChapterImage(vipChapterImageUrl);
const vipChapterImage = new _main_Attachment__WEBPACK_IMPORTED_MODULE_6__/* .AttachmentClass */ .q(vipChapterImageUrl, vipChapterName, "naive");
if (vipChapterImageBlob) {
vipChapterImage.Blob = vipChapterImageBlob;
vipChapterImage.status = _main_main__WEBPACK_IMPORTED_MODULE_8__/* .Status */ .nW.finished;
}
else {
vipChapterImage.status = _main_main__WEBPACK_IMPORTED_MODULE_8__/* .Status */ .nW.failed;
}
return vipChapterImage;
}
const isLogin = document.querySelector(".user-bar > .top-link > .normal-link")
?.childElementCount === 3;
if (isLogin) {
const dom = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_1__/* .getHtmlDOM */ .wA)(chapterUrl, charset);
const chapterNameI = dom.querySelector("h1.article-title").innerText.trim();
isPaid = dom.querySelector(".pay-section") === null;
if (isPaid) {
const vipChapterDom = dom.querySelector(".article-content > #vipImage");
if (vipChapterDom) {
const vipChapterImageUrl = vipChapterDom.src;
const vipChapterName = `vipCHapter${chapterId}.gif`;
const vipChapterImage = await getvipChapterImage(vipChapterImageUrl, vipChapterName);
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_3__/* .putAttachmentClassCache */ .Ld)(vipChapterImage);
const contentImages = [vipChapterImage];
const img = document.createElement("img");
img.setAttribute("data-src-address", vipChapterName);
img.alt = vipChapterImageUrl;
const contentHTML = document.createElement("div");
contentHTML.appendChild(img);
const contentText = `VIP章节,请打开HTML文件查看。\n![${vipChapterImageUrl}](${vipChapterName})`;
return {
chapterName: chapterNameI,
contentRaw: contentHTML,
contentText,
contentHTML,
contentImages,
additionalMetadate: null,
};
}
else {
return publicChapter();
}
}
}
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
if (isVIP) {
return vipChapter();
}
else {
return publicChapter();
}
}
}
/***/ }),
/***/ "./src/rules/special/original/shuhai.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Shuhai: () => (/* binding */ Shuhai)
/* harmony export */ });
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_misc__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/lib/misc.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _main_main__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/main/main.ts");
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules.ts");
class Shuhai extends _rules__WEBPACK_IMPORTED_MODULE_0__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
this.concurrencyLimit = 5;
this.charset = "GBK";
}
async bookParse() {
const bookUrl = document.location.href;
const bookname = document.querySelector("div.book-info-bookname > span:nth-child(1)").innerText.trim();
const author = document.querySelector("div.book-info-bookname > span:nth-child(2)").innerText
.replace("作者: ", "")
.trim();
const introDom = document.querySelector("div.book-info-bookintro") ||
document.querySelector("div.book-info-bookintro-all");
const [introduction, introductionHTML] = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_1__/* .introDomHandle */ .HV)(introDom);
const additionalMetadate = {};
const coverUrl = document.querySelector(".book-cover-wrapper > img").getAttribute("data-original");
if (coverUrl) {
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_2__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_3___default().error(error));
}
additionalMetadate.tags = Array.from(document.querySelectorAll(".book-info-bookstate > .tag")).map((span) => span.innerText.trim());
const chapters = [];
if (document.querySelectorAll("#catalog > .chapter-item").length === 0) {
await (0,_lib_misc__WEBPACK_IMPORTED_MODULE_4__/* .sleep */ .yy)(3000);
}
const dsList = document.querySelectorAll("#catalog > .chapter-item");
let chapterNumber = 0;
let sectionNumber = 0;
let sectionName = null;
let sectionChapterNumber = 0;
for (const node of Array.from(dsList)) {
if (node.nodeName === "SPAN") {
sectionNumber++;
sectionChapterNumber = 0;
sectionName = node?.innerText.trim();
}
else if (node.nodeName === "DIV") {
chapterNumber++;
sectionChapterNumber++;
const a = node.querySelector("a");
const isVIP = () => {
return node.childElementCount === 2;
};
const isPaid = () => {
return false;
};
const chapterName = a.innerText.trim();
const chapterUrl = a.href;
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_5__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP: isVIP(),
isPaid: isPaid(),
sectionName,
sectionNumber,
sectionChapterNumber,
chapterParse: this.chapterParse,
charset: this.charset,
options: {},
});
const isLogin = () => {
return false;
};
if (isVIP() && !(isLogin() && chapter.isPaid)) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_6__/* .Status */ .nW.aborted;
}
chapters.push(chapter);
}
}
return new _main_Book__WEBPACK_IMPORTED_MODULE_7__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
async function publicChapter() {
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_8__/* .ggetHtmlDOM */ .pG)(chapterUrl, charset);
chapterName = doc.querySelector("div.chapter-name").innerText
.replace("正文 ", "")
.trim();
const content = doc.querySelector("#reader-content > div:nth-child(1)");
if (content) {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_9__.rm)("div.chaper-info", false, content);
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_10__/* .cleanDOM */ .an)(content, "TM");
return {
chapterName,
contentRaw: content,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: null,
};
}
else {
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
}
async function vipChapter() {
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
if (isVIP) {
return vipChapter();
}
else {
return publicChapter();
}
}
}
/***/ }),
/***/ "./src/rules/special/original/sosadfun.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Sosadfun: () => (/* binding */ Sosadfun)
/* harmony export */ });
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _main_main__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/main/main.ts");
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules.ts");
class Sosadfun extends _rules__WEBPACK_IMPORTED_MODULE_0__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
}
async bookParse() {
const bookUrl = document.location.origin + document.location.pathname;
const bookname = document.querySelector(".font-1").innerText.trim();
const authorDom = document.querySelector("div.h5:nth-child(1) > div:nth-child(1) > a:nth-child(1)");
let author;
if (authorDom) {
author = authorDom.innerText.trim();
}
else {
author = "匿名咸鱼";
}
const needLogin = () => {
const mainDom = document.querySelector(".col-xs-12 > .main-text.no-selection");
return mainDom.innerText.trim() === "主楼隐藏,请登录后查看";
};
const additionalMetadate = {};
additionalMetadate.tags = Array.from(document.querySelectorAll("div.h5:nth-child(1) > div:nth-child(3) > a")).map((a) => a.innerText.trim());
let introduction;
let introductionHTML;
let introDom;
if (needLogin()) {
alert("本小说需要登录后浏览!");
throw new _main_main__WEBPACK_IMPORTED_MODULE_1__/* .ExpectError */ .K5("本小说需要登录后浏览!");
}
else {
introDom = document.createElement("div");
const shortIntroDom = document.querySelector("div.article-title div.h5");
const longIntroDom = document.querySelector(".col-xs-12 > .main-text.no-selection");
if (shortIntroDom) {
const pElem = document.createElement("p");
pElem.innerText = shortIntroDom.innerText;
introDom.appendChild(pElem);
}
if (longIntroDom) {
for (const elem of Array.from(longIntroDom.cloneNode(true).children)) {
introDom.appendChild(elem);
}
}
}
if (introDom === null) {
introduction = null;
introductionHTML = null;
}
else {
const { dom: introCleanDom, text: introCleantext, images: introCleanimages, } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_2__/* .cleanDOM */ .an)(introDom, "TM");
introduction = introCleantext;
introductionHTML = introCleanDom;
if (introCleanimages) {
additionalMetadate.attachments = [...introCleanimages];
}
}
const chapters = [];
const aList = document.querySelectorAll(".table > tbody:nth-child(2) > tr > th:nth-child(1) > a");
let chapterNumber = 0;
for (const a of Array.from(aList)) {
chapterNumber++;
const chapterName = a.innerText.trim();
const chapterUrl = a.href;
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_3__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP: false,
isPaid: false,
sectionName: null,
sectionNumber: null,
sectionChapterNumber: null,
chapterParse: this.chapterParse,
charset: this.charset,
options: {},
});
chapters.push(chapter);
}
return new _main_Book__WEBPACK_IMPORTED_MODULE_4__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_5__/* .getHtmlDOM */ .wA)(chapterUrl, charset);
chapterName = doc.querySelector("strong.h3").innerText.trim();
const content = document.createElement("div");
const _content = doc.querySelector(".main-text.no-selection > span[id^=full]");
const _authorSay = doc.querySelector(".main-text.no-selection > .grayout");
if (_content) {
for (const elem of Array.from(_content.cloneNode(true).children)) {
content.appendChild(elem);
}
}
if (_content) {
let { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_2__/* .cleanDOM */ .an)(content, "TM");
if (_authorSay) {
const { dom: authorSayDom, text: authorySayText, images: authorSayImages, } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_2__/* .cleanDOM */ .an)(_authorSay, "TM");
const hrElem = document.createElement("hr");
const authorSayDiv = document.createElement("div");
authorSayDiv.className = "authorSay";
for (const elem of Array.from(authorSayDom.cloneNode(true).children)) {
authorSayDiv.appendChild(elem);
}
content.appendChild(hrElem);
content.appendChild(authorSayDiv);
dom.appendChild(hrElem);
dom.appendChild(authorSayDiv);
text = text + "\n\n" + "-".repeat(20) + "\n\n" + authorySayText;
authorSayImages.forEach((aImage) => images.push(aImage));
}
return {
chapterName,
contentRaw: content,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: null,
};
}
else {
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
}
}
/***/ }),
/***/ "./src/rules/special/original/tadu.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Tadu: () => (/* binding */ Tadu)
/* harmony export */ });
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _main_main__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/main/main.ts");
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules.ts");
class Tadu extends _rules__WEBPACK_IMPORTED_MODULE_0__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
this.concurrencyLimit = 5;
}
async bookParse() {
const bookUrl = document.location.href;
const bookname = document.querySelector("div.bookNm > a.bkNm").innerText.trim();
const author = document.querySelector("div.authorInfo > a.author > span").innerText.trim();
const introDom = document.querySelector("div.boxCenter.boxT.clearfix > div.lf.lfO > p.intro");
const [introduction, introductionHTML] = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_1__/* .introDomHandle */ .HV)(introDom);
const additionalMetadate = {};
const coverUrl = document.querySelector("a.bookImg > img").getAttribute("data-src");
if (coverUrl) {
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_2__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_3___default().error(error));
}
const chapters = [];
const cos = document.querySelectorAll("div.lf.lfT > li > div > a");
let chapterNumber = 0;
for (const aElem of Array.from(cos)) {
chapterNumber++;
const chapterName = aElem.innerText;
const chapterUrl = aElem.href;
const isVIP = () => {
return !!aElem.childElementCount;
};
const isPaid = () => {
return false;
};
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_4__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP: isVIP(),
isPaid: isPaid(),
sectionName: null,
sectionNumber: null,
sectionChapterNumber: null,
chapterParse: this.chapterParse,
charset: this.charset,
options: {},
});
const isLogin = () => {
return false;
};
if (isVIP() && !(isLogin() && chapter.isPaid)) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_5__/* .Status */ .nW.aborted;
}
chapters.push(chapter);
}
return new _main_Book__WEBPACK_IMPORTED_MODULE_6__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
async function publicChapter() {
_log__WEBPACK_IMPORTED_MODULE_3___default().debug(`[Chapter]请求 ${chapterUrl}`);
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_7__/* .getHtmlDOM */ .wA)(chapterUrl, charset);
const content = document.createElement("div");
const _bookPartResourceUrl = doc
.getElementById("bookPartResourceUrl")
?.getAttribute("value");
if (_bookPartResourceUrl) {
const currentUrl = new URL(document.location.href);
const rootDomain = `${currentUrl.protocol}//${currentUrl.host}`;
const bookPartResourceUrl = new URL(_bookPartResourceUrl, rootDomain);
bookPartResourceUrl.searchParams.set("callback", "callback");
_log__WEBPACK_IMPORTED_MODULE_3___default().debug(`[Chapter]请求 ${bookPartResourceUrl.toString()}`);
const jsonpText = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_7__/* .gfetch */ ._V)(bookPartResourceUrl.toString(), {
headers: {
accept: "*/*",
Referer: document.location.origin,
},
})
.then((response) => {
if (response.status >= 200 && response.status <= 299) {
return response.responseText;
}
else {
throw new Error(`Bad response! ${bookPartResourceUrl.toString()}`);
}
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_3___default().error(error));
if (!jsonpText) {
throw new Error("jsonp request failed!");
}
const getContentObj = new Function(`function callback(obj) { return obj; } return ${jsonpText};`);
const contentObj = getContentObj();
if (typeof contentObj === "object") {
content.innerHTML = contentObj.content;
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_8__/* .cleanDOM */ .an)(content, "TM");
return {
chapterName,
contentRaw: content,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: null,
};
}
}
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
async function vipChapter() {
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
if (isVIP) {
return vipChapter();
}
else {
return publicChapter();
}
}
}
/***/ }),
/***/ "./src/rules/special/original/xrzww.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Xrzww: () => (/* binding */ Xrzww)
/* harmony export */ });
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/rules.ts");
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_main__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/main/main.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_misc__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__("./src/lib/misc.ts");
/* harmony import */ var _lib_GM__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/lib/GM.ts");
/* harmony import */ var crypto_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("crypto-js");
/* harmony import */ var crypto_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(crypto_js__WEBPACK_IMPORTED_MODULE_0__);
class Xrzww extends _rules__WEBPACK_IMPORTED_MODULE_1__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
this.concurrencyLimit = 1;
}
async bookParse() {
const bookUrl = document.location.href;
const bookId = bookUrl.substring(bookUrl.lastIndexOf("/") + 1);
const apiBase = "https://pre-api.xrzww.com";
const ossBase = "https://oss.xrzww.com";
const token = localStorage.getItem("token")
? localStorage.getItem("token")
: "";
const site = 1;
const baseHeader = {
Accept: "application/json, text/plain, */*",
Authorization: `Bearer ${token}`,
Site: site.toString(),
};
const signIn = token !== "";
const webNovelDetailUrl = new URL(`${apiBase}/api/webNovelDetail`);
webNovelDetailUrl.searchParams.set("novel_id", bookId);
const respW = await fetch(webNovelDetailUrl.href, {
credentials: "include",
headers: {
"Cache-Control": "max-age=0",
...baseHeader,
},
method: "GET",
mode: "cors",
});
const webNovelDetail = (await respW.json());
if (webNovelDetail.code !== 200) {
throw new Error("获取书籍信息出错!");
}
const bookname = webNovelDetail.data.novel_name;
const author = webNovelDetail.data.novel_author;
const introduction = webNovelDetail.data.novel_info;
const introductionHTML = document.createElement("div");
introductionHTML.innerText = introduction;
const additionalMetadate = {};
const coverUrl = `${ossBase}${webNovelDetail.data.novel_cover}`;
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_2__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_3___default().error(error));
additionalMetadate.tags = webNovelDetail.data.novel_tags
.split(",")
.map((t) => t.trim());
additionalMetadate.tags.push(webNovelDetail.data.type_name);
additionalMetadate.lastModified = webNovelDetail.data.novel_uptime;
const directoryListUrl = new URL(`${apiBase}/api/directoryList`);
directoryListUrl.searchParams.set("nid", bookId);
directoryListUrl.searchParams.set("orderBy", "0");
const respD = await fetch(directoryListUrl.href, {
credentials: "include",
headers: baseHeader,
method: "GET",
mode: "cors",
});
const directoryList = (await respD.json());
if (directoryList.code !== 200) {
throw new Error("获取目录信息失败!");
}
const volumes = directoryList.data.volume.reduce((obj, vol) => {
obj[vol.volume_id] = {
name: vol.volume_name,
order: vol.volume_order,
desc: vol.volume_desc,
};
return obj;
}, {});
const chapters = [];
let i = 0;
let tSectionName = null;
let s = 0;
let sc = 0;
for (const c of directoryList.data.data) {
i++;
const chapterUrl = "";
const chapterName = c.chapter_name;
const chapterNumber = i;
const isVIP = c.chapter_ispay === 1;
const isPaid = c.is_subscribe === 1;
const sectionName = volumes[c.chapter_vid].name;
if (tSectionName !== sectionName) {
tSectionName = sectionName;
s++;
sc = 0;
}
const sectionNumber = s;
sc++;
const sectionChapterNumber = sc;
const options = {
nid: c.chapter_nid,
vid: c.chapter_vid,
chapter_id: c.chapter_id,
chapter_order: c.chapter_order,
apiBase,
headers: baseHeader,
};
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_4__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP,
isPaid,
sectionName,
sectionNumber,
sectionChapterNumber,
chapterParse: this.chapterParse,
charset: this.charset,
options,
});
if (signIn) {
if (chapter.isVIP && chapter.isPaid === false) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_5__/* .Status */ .nW.aborted;
}
}
else {
if (chapter.isVIP) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_5__/* .Status */ .nW.aborted;
}
}
chapters.push(chapter);
}
return new _main_Book__WEBPACK_IMPORTED_MODULE_6__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
async function getVIPChapter(url) {
let device = "webh517657567560";
let Authorization = "Bearer 453453453e03ee546456546754756756";
if (typeof unsafeWindow.tokenOptions === "object") {
device = unsafeWindow.tokenOptions?.Xrzww?.deviceIdentify ?? "webh517657567560";
Authorization = unsafeWindow.tokenOptions?.Xrzww?.Authorization ?? "Bearer 453453453e03ee546456546754756756";
}
const key = "9495ef469eb3e7ae8ef3";
const timestamp = Math.round(Date.now() / 1000).toString();
const signature = crypto_js__WEBPACK_IMPORTED_MODULE_0__.MD5(device + timestamp + key).toString();
return new Promise((resolve) => {
(0,_lib_GM__WEBPACK_IMPORTED_MODULE_7__/* ._GM_xmlhttpRequest */ .nV)({
url: url,
headers: {
"Authorization": Authorization,
"appVersion": "4.83",
"deviceType": "android",
"signature": signature,
"site": "1",
"content-type": "application/json",
"headerRequestSource": "xirang",
"Connection": "Keep-Alive",
"User-Agent": "okhttp/4.8.0",
"deviceIdentify": device,
"timestamp": timestamp
},
method: "GET",
onload: function (response) {
if (response.status === 200) {
const resultI = JSON.parse(String(response.responseText));
resolve(resultI);
}
else {
_log__WEBPACK_IMPORTED_MODULE_3___default().error(`response status = ${response.status}`);
resolve(JSON.parse('{"message":"try again!"}'));
}
},
});
});
}
const contentRaw = document.createElement("p");
let last_Modified = 0;
if (!isVIP) {
const readNewUrl = new URL(`${options.apiBase}/api/readNovelByWeb`);
readNewUrl.searchParams.set("nid", options.nid.toString());
readNewUrl.searchParams.set("vid", options.vid.toString());
readNewUrl.searchParams.set("chapter_id", options.chapter_id.toString());
readNewUrl.searchParams.set("chapter_order", options.chapter_order.toString());
readNewUrl.searchParams.set("showpic", false.toString());
const resp = await fetch(readNewUrl.href, {
credentials: "include",
headers: options.headers,
method: "GET",
mode: "cors",
});
const readNew = (await resp.json());
if (readNew.code !== 200) {
throw new Error("获取章节内容失败! " + JSON.stringify(options));
}
contentRaw.innerText = readNew.data.content;
last_Modified = readNew.data.chapter_uptime;
}
else if (isVIP && isPaid) {
const readNewUrl = new URL(`https://android-api.xrzww.com/api/readWithEncrypt`);
readNewUrl.searchParams.set("chapter_id", options.chapter_id.toString());
readNewUrl.searchParams.set("nid", options.nid.toString());
readNewUrl.searchParams.set("preload", "1");
const result = await getVIPChapter(readNewUrl.href);
if (result) {
const readNew = result;
if (readNew.code !== 200) {
throw new Error("获取章节内容失败! " + JSON.stringify(options));
}
let content = readNew.data.content;
try {
const decrypted = crypto_js__WEBPACK_IMPORTED_MODULE_0__.DES.decrypt(content, crypto_js__WEBPACK_IMPORTED_MODULE_0__.enc.Utf8.parse("VT5aj59QCjf2J8F3"), {
iv: crypto_js__WEBPACK_IMPORTED_MODULE_0__.enc.Utf8.parse("259c4e9881b5fe05"),
mode: crypto_js__WEBPACK_IMPORTED_MODULE_0__.mode.CBC,
padding: crypto_js__WEBPACK_IMPORTED_MODULE_0__.pad.Pkcs7,
});
content = decrypted.toString(crypto_js__WEBPACK_IMPORTED_MODULE_0__.enc.Utf8);
}
catch (e) {
_log__WEBPACK_IMPORTED_MODULE_3___default().debug(`VIP章节解密失败:${e}`);
throw new Error("VIP章节解密失败!");
}
contentRaw.innerText = content;
last_Modified = readNew.data.chapter_uptime;
}
else
contentRaw.innerText = "";
}
else {
contentRaw.innerText = "";
}
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_8__/* .cleanDOM */ .an)(contentRaw, "TM");
await (0,_lib_misc__WEBPACK_IMPORTED_MODULE_9__/* .sleep */ .yy)(4200 * Math.random());
return {
chapterName,
contentRaw,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: { lastModified: last_Modified },
};
}
}
/***/ }),
/***/ "./src/rules/special/original/youdubook.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Youdubook: () => (/* binding */ Youdubook)
/* harmony export */ });
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_2__);
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules.ts");
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_main__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/main/main.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_misc__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/lib/misc.ts");
class Youdubook extends _rules__WEBPACK_IMPORTED_MODULE_0__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
this.concurrencyLimit = 1;
}
async bookParse() {
const bookUrl = document.location.href;
const bookId = bookUrl.substring(bookUrl.lastIndexOf("/") + 1);
const apiBase = "https://pre-api.youdubook.com";
const ossBase = "https://oss.youdubook.com";
const token = localStorage.getItem("token")
? localStorage.getItem("token")
: "";
const site = 1;
const baseHeader = {
Accept: "application/json, text/plain, */*",
Authorization: `Bearer ${token}`,
Site: site.toString(),
};
const signIn = token !== "";
const webNovelDetailUrl = new URL(`${apiBase}/api/webNovelDetail`);
webNovelDetailUrl.searchParams.set("novel_id", bookId);
const respW = await fetch(webNovelDetailUrl.href, {
credentials: "include",
headers: {
"Cache-Control": "max-age=0",
...baseHeader,
},
method: "GET",
mode: "cors",
});
const webNovelDetail = (await respW.json());
if (webNovelDetail.code !== 200) {
throw new Error("获取书籍信息出错!");
}
const bookname = webNovelDetail.data.novel_name;
const author = webNovelDetail.data.novel_author;
const introduction = webNovelDetail.data.novel_info;
const introductionHTML = document.createElement("div");
introductionHTML.innerText = introduction;
const additionalMetadate = {};
const coverUrl = `${ossBase}${webNovelDetail.data.novel_cover}`;
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_1__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_2___default().error(error));
additionalMetadate.tags = webNovelDetail.data.novel_tags
.split(",")
.map((t) => t.trim());
additionalMetadate.tags.push(webNovelDetail.data.type_name);
additionalMetadate.lastModified = webNovelDetail.data.novel_uptime;
const directoryListUrl = new URL(`${apiBase}/api/directoryList`);
directoryListUrl.searchParams.set("nid", bookId);
directoryListUrl.searchParams.set("orderBy", "0");
const respD = await fetch(directoryListUrl.href, {
credentials: "include",
headers: baseHeader,
method: "GET",
mode: "cors",
});
const directoryList = (await respD.json());
if (directoryList.code !== 200) {
throw new Error("获取目录信息失败!");
}
const volumes = directoryList.data.volume.reduce((obj, vol) => {
obj[vol.volume_id] = {
name: vol.volume_name,
order: vol.volume_order,
desc: vol.volume_desc,
};
return obj;
}, {});
const chapters = [];
let i = 0;
let tSectionName = null;
let s = 0;
let sc = 0;
for (const c of directoryList.data.data) {
i++;
const chapterUrl = "";
const chapterName = c.chapter_name;
const chapterNumber = i;
const isVIP = c.chapter_ispay === 1;
const isPaid = c.is_subscribe === 1;
const sectionName = volumes[c.chapter_vid].name;
if (tSectionName !== sectionName) {
tSectionName = sectionName;
s++;
sc = 0;
}
const sectionNumber = s;
sc++;
const sectionChapterNumber = sc;
const options = {
nid: c.chapter_nid,
vid: c.chapter_vid,
chapter_id: c.chapter_id,
chapter_order: c.chapter_order,
apiBase,
headers: baseHeader,
};
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_3__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP,
isPaid,
sectionName,
sectionNumber,
sectionChapterNumber,
chapterParse: this.chapterParse,
charset: this.charset,
options,
});
if (signIn) {
if (chapter.isVIP && chapter.isPaid === false) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_4__/* .Status */ .nW.aborted;
}
}
else {
if (chapter.isVIP) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_4__/* .Status */ .nW.aborted;
}
}
chapters.push(chapter);
}
return new _main_Book__WEBPACK_IMPORTED_MODULE_5__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
const readNewUrl = new URL(`${options.apiBase}/api/readNovelByWeb`);
readNewUrl.searchParams.set("nid", options.nid.toString());
readNewUrl.searchParams.set("vid", options.vid.toString());
readNewUrl.searchParams.set("chapter_id", options.chapter_id.toString());
readNewUrl.searchParams.set("chapter_order", options.chapter_order.toString());
readNewUrl.searchParams.set("showpic", false.toString());
const resp = await fetch(readNewUrl.href, {
credentials: "include",
headers: options.headers,
method: "GET",
mode: "cors",
});
const readNew = (await resp.json());
if (readNew.code !== 200) {
throw new Error("获取章节内容失败! " + JSON.stringify(options));
}
const contentRaw = document.createElement("p");
contentRaw.innerText = readNew.data.content;
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_6__/* .cleanDOM */ .an)(contentRaw, "TM");
await (0,_lib_misc__WEBPACK_IMPORTED_MODULE_7__/* .sleep */ .yy)(4200 * Math.random());
return {
chapterName,
contentRaw,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: { lastModified: readNew.data.chapter_uptime },
};
}
}
/***/ }),
/***/ "./src/rules/special/original/zongheng.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Zongheng: () => (/* binding */ Zongheng)
/* harmony export */ });
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_4__);
/* harmony import */ var _main_main__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/main/main.ts");
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules.ts");
/* harmony import */ var _lib_GM__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/lib/GM.ts");
class Zongheng extends _rules__WEBPACK_IMPORTED_MODULE_0__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
this.concurrencyLimit = 5;
}
async bookParse() {
let bookUrl = document.location.href.replace("/showchapter/", "/book/");
bookUrl = document.location.href.replace(/\?tabsName=.*$/, "");
if (bookUrl != document.location.href) {
document.location.href = bookUrl;
return new _main_Book__WEBPACK_IMPORTED_MODULE_1__/* .Book */ .E({
bookUrl,
bookname: "1",
author: "1",
introduction: "1",
introductionHTML: null,
additionalMetadate: {},
chapters: [],
});
}
const match = bookUrl.match(/\/detail\/(\d+)/);
const bookId = match ? match[1] : null;
if (!bookId) {
return new _main_Book__WEBPACK_IMPORTED_MODULE_1__/* .Book */ .E({
bookUrl,
bookname: "1",
author: "1",
introduction: "1",
introductionHTML: null,
additionalMetadate: {},
chapters: [],
});
}
const bookname = document.querySelector(".book-info--title > span").innerText.trim();
const author = document.querySelector("a.author-info--name").innerText.trim();
const introDom = document.querySelector("section.detail-work-info--introduction");
const [introduction, introductionHTML] = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_2__/* .introDomHandle */ .HV)(introDom);
const additionalMetadate = {};
const coverUrl = document.querySelector("img.book-info--coverImage-img").src;
if (coverUrl) {
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_3__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_4___default().error(error));
}
additionalMetadate.tags = Array.from(document.querySelectorAll(".book-info--tags > span")).map((a) => a.innerText.trim());
async function getChapterList(bookId) {
const url = `https://bookapi.zongheng.com/api/chapter/getChapterList`;
const formData = new URLSearchParams();
formData.append("bookId", bookId);
return new Promise((resolve) => {
(0,_lib_GM__WEBPACK_IMPORTED_MODULE_5__/* ._GM_xmlhttpRequest */ .nV)({
url: url,
headers: {
Cookie: document.cookie,
Origin: "https://www.zongheng.com",
Referer: "https://www.zongheng.com/",
"Content-Type": "application/x-www-form-urlencoded",
},
method: "POST",
data: formData.toString(),
onload: function (response) {
if (response.status === 200) {
const resultI = JSON.parse(response.responseText);
resolve(resultI);
}
else {
_log__WEBPACK_IMPORTED_MODULE_4___default().error(`post ${url} response status = ${response.status}`);
const resultI = JSON.parse('{"message":"天塌了"}');
resolve(resultI);
}
},
});
});
}
const chapters = [];
const result = await getChapterList(bookId);
if (result.message && result.message === "成功") {
let sectionNumber = 0;
let chapterNumber = 0;
for (const tome of result.result.chapterList) {
sectionNumber++;
const sectionName = tome.tome.tomeName;
let sectionChapterNumber = 0;
for (const chapterView of tome.chapterViewList) {
sectionChapterNumber++;
const chapterUrl = `https://read.zongheng.com/chapter/${bookId}/${chapterView.chapterId}.html`;
const chapterName = chapterView.chapterName;
chapterNumber++;
const isVIP = chapterView.price > 0;
const isPaid = chapterView.everBuy;
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_6__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP,
isPaid,
sectionName,
sectionNumber,
sectionChapterNumber,
chapterParse: this.chapterParse,
charset: this.charset,
options: {},
});
if (isVIP && !isPaid) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_7__/* .Status */ .nW.aborted;
}
chapters.push(chapter);
}
}
}
else {
_log__WEBPACK_IMPORTED_MODULE_4___default().error(`获取目录失败 ${result.message}`);
}
return new _main_Book__WEBPACK_IMPORTED_MODULE_1__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
async function publicChapter() {
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_8__/* .ggetHtmlDOM */ .pG)(chapterUrl, charset);
const ChapterName = doc.querySelector("div.title_txtbox").innerText.trim();
const content = doc.querySelector("div.content");
if (content) {
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_9__/* .cleanDOM */ .an)(content, "TM");
return {
chapterName: ChapterName,
contentRaw: content,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: null,
};
}
else {
return {
chapterName: ChapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
}
async function vipChapter() {
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
if (isVIP) {
return vipChapter();
}
else {
return publicChapter();
}
}
}
/***/ }),
/***/ "./src/rules/special/reprint/dmzj.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Dmzj: () => (/* binding */ Dmzj)
/* harmony export */ });
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/lib/dom.ts");
class Dmzj extends _rules__WEBPACK_IMPORTED_MODULE_0__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
this.streamZip = true;
this.concurrencyLimit = 1;
this.maxRunLimit = 1;
}
async bookParse() {
const bookUrl = document.location.href;
const isWwwHost = document.location.host === "www.idmzj.com";
const bookDom = isWwwHost
? document.querySelector(".comic_deCon > h1 > a")
: document.querySelector(".anim_title_text > a > h1");
const bookname = bookDom.innerText.trim();
const authorDom = isWwwHost
? document.querySelector(".comic_deCon_liO > li:nth-child(1)")
: document.querySelector(".anim-main_list > table:nth-child(1) > tbody:nth-child(1) > tr:nth-child(3) > td:nth-child(2) > a:nth-child(1)");
const author = authorDom.innerText
.replace("作者:", "")
.trim();
const introDom = isWwwHost
? document.querySelector(".comic_deCon_d")
: document.querySelector(".line_height_content");
const [introduction, introductionHTML] = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_1__/* .introDomHandle */ .HV)(introDom);
const additionalMetadate = {};
const coverDom = isWwwHost
? document.querySelector(".comic_i_img > a > img")
: document.querySelector("#cover_pic");
const coverUrl = coverDom.src;
if (coverUrl) {
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_2__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_3___default().error(error));
}
const chapters = [];
const cos = isWwwHost
? document.querySelectorAll("div.zj_list_con > ul.list_con_li > li")
: document.querySelectorAll(".cartoon_online_border > ul > li");
let chapterNumber = 0;
for (const co of Array.from(cos)) {
chapterNumber++;
const a = co.firstElementChild;
let chapterName;
if (isWwwHost) {
const span = a.lastElementChild;
chapterName = span.innerText;
}
else {
chapterName = a.innerText;
}
const chapterUrl = a.href;
const isVIP = false;
const isPaid = false;
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_4__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP,
isPaid,
sectionName: null,
sectionNumber: null,
sectionChapterNumber: null,
chapterParse: this.chapterParse,
charset: this.charset,
options: {},
});
chapters.push(chapter);
}
return new _main_Book__WEBPACK_IMPORTED_MODULE_5__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
function getpicUrlList(docI) {
const imgPrefix = "https://images.idmzj.com/";
const scriptElement = Array.from(docI.querySelectorAll("head > script")).filter((s) => s.innerHTML.includes("eval("))[0];
let pages = (0,_lib_dom__WEBPACK_IMPORTED_MODULE_6__/* .sandboxed */ .d6)(scriptElement.innerText + ";return pages;");
pages = pages.replace(/\n/g, "");
pages = pages.replace(/\r/g, "|");
const info = (0,_lib_dom__WEBPACK_IMPORTED_MODULE_6__/* .sandboxed */ .d6)("return (" + pages + ")");
if (info) {
let picUrlListI;
if (isWwwHost) {
picUrlListI = info.page_url
.split("|")
.map((pic) => imgPrefix + pic);
}
else {
picUrlListI = info.map((pic) => imgPrefix + pic);
}
return picUrlListI;
}
}
_log__WEBPACK_IMPORTED_MODULE_3___default().debug(`[Chapter]请求 ${chapterUrl}`);
const isWwwHost = document.location.host === "www.idmzj.com";
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_7__/* .getHtmlDOM */ .wA)(chapterUrl, charset);
const picUrlList = getpicUrlList(doc);
if (picUrlList) {
const content = document.createElement("div");
for (const picUrl of picUrlList) {
const pElem = document.createElement("p");
const imgElem = document.createElement("img");
imgElem.src = picUrl;
pElem.appendChild(imgElem);
content.appendChild(pElem);
}
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_8__/* .cleanDOM */ .an)(content, "TM");
return {
chapterName,
contentRaw: content,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: null,
};
}
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
}
/***/ }),
/***/ "./src/rules/special/reprint/fushuwang.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Fushuwang: () => (/* binding */ Fushuwang)
/* harmony export */ });
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules.ts");
class Fushuwang extends _rules__WEBPACK_IMPORTED_MODULE_0__/* .BaseRuleClass */ .Q {
saveOptions;
constructor() {
super();
this.attachmentMode = "TM";
this.charset = "GBK";
this.maxRunLimit = 5;
this.saveOptions = {
genChapterText: (chapterName, contentText) => {
return `${contentText}\n`;
},
};
}
async bookParse() {
const bookUrl = (document.location.origin + document.location.pathname).replace(/(_\d+)\.html$/, ".html");
const [bookname, author] = document.querySelector(".title_info > tbody:nth-child(1) > tr:nth-child(1) > td:nth-child(1) > h1:nth-child(1)").innerText.split("——");
const [introduction, introductionHTML] = [null, null];
const additionalMetadate = {};
const options = document.querySelectorAll("p.pageLink > select > option");
const urls = Array.from(options).map((option) => document.location.origin + option.getAttribute("value"));
const chapters = [];
for (let i = 0; i < urls.length; i++) {
const chapterUrl = urls[i];
const chapterName = `page${i}`;
const isVIP = false;
const isPaid = false;
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_1__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber: i + 1,
chapterName,
isVIP,
isPaid,
sectionName: null,
sectionNumber: null,
sectionChapterNumber: null,
chapterParse: this.chapterParse,
charset: this.charset,
options: {},
});
chapters.push(chapter);
}
const book = new _main_Book__WEBPACK_IMPORTED_MODULE_2__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
book.saveOptions = this.saveOptions;
return book;
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_3__/* .getHtmlDOM */ .wA)(chapterUrl, charset);
const content = doc.querySelector("#text");
if (content) {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_4__.rm)("span", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_4__.rm)("p.pageLink", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_4__.rm)("script", true, content);
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_5__/* .cleanDOM */ .an)(content, "TM");
return {
chapterName,
contentRaw: content,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: null,
};
}
else {
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
}
}
/***/ }),
/***/ "./src/rules/special/reprint/haitangtxt.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
// EXPORTS
__webpack_require__.d(__webpack_exports__, {
haitangtxt: () => (/* binding */ haitangtxt),
yuzhaige: () => (/* binding */ yuzhaige)
});
// EXTERNAL MODULE: ./src/lib/cleanDOM.ts
var cleanDOM = __webpack_require__("./src/lib/cleanDOM.ts");
// EXTERNAL MODULE: ./src/lib/http.ts
var http = __webpack_require__("./src/lib/http.ts");
// EXTERNAL MODULE: ./src/lib/dom.ts
var lib_dom = __webpack_require__("./src/lib/dom.ts");
// EXTERNAL MODULE: ./src/lib/rule.ts
var rule = __webpack_require__("./src/lib/rule.ts");
// EXTERNAL MODULE: ./node_modules/loglevel/lib/loglevel.js
var loglevel = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
var loglevel_default = /*#__PURE__*/__webpack_require__.n(loglevel);
// EXTERNAL MODULE: ./src/main/Chapter.ts
var Chapter = __webpack_require__("./src/main/Chapter.ts");
// EXTERNAL MODULE: ./src/main/Book.ts + 1 modules
var Book = __webpack_require__("./src/main/Book.ts");
// EXTERNAL MODULE: ./src/rules.ts + 12 modules
var rules = __webpack_require__("./src/rules.ts");
;// ./src/rules/lib/haitangtxtImageDecode.ts
function replaceHaitangtxtImage(inputText) {
let outputText = inputText;
for (const imageFilename in imageTable) {
if (Object.prototype.hasOwnProperty.call(imageTable, imageFilename)) {
const normalCharacter = imageTable[imageFilename];
const imageHTML = `<img src="${document.location.origin}/wzbodyimg/${imageFilename}">`;
outputText = outputText.replaceAll(imageHTML, normalCharacter);
}
}
return outputText;
}
const imageTable = {};
;// ./src/rules/lib/yuzhaigeImageDecode.ts
function replaceYuzhaigeImage(inputText) {
let outputText = inputText;
for (const imageFilename in yuzhaigeImageDecode_imageTable) {
if (Object.prototype.hasOwnProperty.call(yuzhaigeImageDecode_imageTable, imageFilename)) {
const normalCharacter = yuzhaigeImageDecode_imageTable[imageFilename];
const imageHTML = `<img src="${document.location.origin}/wzbodyimg/${imageFilename}">`;
outputText = outputText.replaceAll(imageHTML, normalCharacter);
}
}
return outputText;
}
const yuzhaigeImageDecode_imageTable = {
"wc5pDq.png": "\u52c3",
"wEwIpN.png": "\u8404",
"WFOBXF.png": "\u4f26",
"WFuqEG.png": "\u6eda",
"WNTyYB.png": "\u83ca",
"WrI5St.png": "\u6234",
"WSYLdq.png": "\u5ba0",
"wvHBh4.png": "\u5976",
"wWVoto.png": "\u5df4",
"wz2cGb.png": "\u4e73",
"wZicAt.png": "\u9053",
"WzS8He.png": "\u6234",
"X6QTS9.png": "\u80ef",
"XBTII5.png": "\u817f",
"XBv6rP.png": "\u8df3",
"xFVZW9.png": "\u6b96",
"XhuslD.png": "\u9e21",
"xIFlai.png": "\u98df",
"XK7taQ.png": "\u723d",
"xljRqd.png": "\u9876",
"xo18Yq.png": "\u5c3f",
"xOIyuf.png": "\u585e",
"xQ2ZWb.png": "\u80a1",
"XqsaJY.png": "\u8f6f",
"xrbxqL.png": "\u88f8",
"xw7cLW.png": "\u868c",
"xwkwQW.png": "\u7cbe",
"XXlZMA.png": "\u6b96",
"y3FgRm.png": "\u67f1",
"y4Afmt.png": "\u817f",
"Y4aXzR.png": "\u7c97",
"Y7G6Lu.png": "\u547b",
"YGnnuo.png": "\u871c",
"ygqjgt.png": "\u634f",
"yGwSy7.png": "\u9a9a",
"yjX9oi.png": "\u63c9",
"YNmgYJ.png": "\u809b",
"yuo7sA.png": "\u6469",
"yWAu0U.png": "\u50ac",
"yWhRNI.png": "\u5a07",
"YZ4EAh.png": "\u5589",
"yzS8NJ.png": "\u80ef",
"z0DZro.png": "\u542e",
"Z7byDx.png": "\u6da6",
"ZatUU6.png": "\u5974",
"zCtJCx.png": "\u6da6",
"ZDJHkT.png": "\u6ccc",
"ZKDja5.png": "\u9f9f",
"ZqyamF.png": "\u5c44",
"ZzsV7x.png": "\u777e",
"0bErVo.png": "\u6df1",
"0ShNwM.png": "\u5439",
"0uCAgc.png": "\u5f3a",
"1AMfxw.png": "\u5e72",
"1EmzV7.png": "\u6027",
"1RbeKi.png": "\u5934",
"1RIz6c.png": "\u611f",
"1ZkZsI.png": "\u6b32",
"2AXYPX.png": "\u6cc4",
"2gwsiE.png": "\u6e7f",
"2LQHtR.png": "\u6839",
"2wePG6.png": "\u4f53",
"2Xijao.png": "\u634f",
"3ha4Fq.png": "\u6b22",
"3RfcEA.png": "\u9ad8",
"3uNZxG.png": "\u80f8",
"4bu7Gr.png": "\u8482",
"4T4DPM.png": "\u64e6",
"4XjmUQ.png": "\u8fdb",
"5hjo9r.png": "\u4e0b",
"5ueElb.png": "\u5bab",
"5yFlDm.png": "\u5bab",
"6UsGer.png": "\u74e3",
"6w928M.png": "\u633a",
"6YavUk.png": "\u6696",
"7dKm1T.png": "\u8fdb",
"7tzEqy.png": "\u70b9",
"8Q4cTQ.png": "\u90e8",
"9Ns27O.png": "\u9633",
"9pAfcz.png": "\u5934",
"9Xkn86.png": "\u5507",
"62TB7X.png": "\u7d27",
"668QKT.png": "\u4e0b",
"aedVOS.png": "\u9732",
"AI15xh.png": "\u5a07",
"AikKsW.png": "\u80a0",
"AJcH1b.png": "\u51fa",
"ALnkng.png": "\u5598",
"anzcle.png": "\u9053",
"apsw0Z.png": "\u5b50",
"azRZNn.png": "\u6c34",
"B38zEI.png": "\u6c34",
"BAVYZd.png": "\u9634",
"BBioQd.png": "\u6696",
"BBZnCY.png": "\u5507",
"bE6LV6.png": "\u7f8e",
"bF30CY.png": "\u5438",
"bihdjA.png": "\u5507",
"BPQcCZ.png": "\u5177",
"BpYip0.png": "\u7ba1",
"BrY1ZI.png": "\u817f",
"BvbcsW.png": "\u7d27",
"bXRYQt.png": "\u5904",
"Caqk3D.png": "\u773c",
"CBylOX.png": "\u9053",
"ClFBCD.png": "\u5904",
"CLS5cG.png": "\u575a",
"cPjFxZ.png": "\u79cd",
"CUJkGk.png": "\u60c5",
"CZL2OC.png": "\u76ae",
"D3I7u1.png": "\u8482",
"d5KjC5.png": "\u4f53",
"d7fjCZ.png": "\u9732",
"df6AnM.png": "\u51fa",
"dhAaVT.png": "\u575a",
"dkuDIk.png": "\u820c",
"DSiSlL.png": "\u7231",
"dTnQ9K.png": "\u9b54",
"dXMpnD.png": "\u6655",
"DXtzqf.png": "\u8eab",
"DXXixh.png": "\u5957",
"DZYaDR.png": "\u9633",
"e5QAQ1.png": "\u5f3a",
"ECcmqT.png": "\u6625",
"eeYwrN.png": "\u6c34",
"eGWHWT.png": "\u6170",
"eOOKlp.png": "\u89e6",
"EvHzor.png": "\u6b32",
"ewwRMT.png": "\u903c",
"EZW46f.png": "\u6df1",
"FBosfH.png": "\u6027",
"fC5MmR.png": "\u6237",
"ffTW4v.png": "\u62bd",
"ffZqua.png": "\u6027",
"FgN2Tl.png": "\u4e71",
"fHvZK9.png": "\u7f1d",
"fj7veK.png": "\u957f",
"fkPlzo.png": "\u98df",
"fKWetR.png": "\u7ba1",
"FUmeqN.png": "\u25a1",
"Fus88J.png": "\u725b",
"G4uOno.png": "\u55b7",
"g7bVzL.png": "\u9ad8",
"GBmlnw.png": "\u8df3",
"gCWM61.png": "\u7cbe",
"GdAidg.png": "\u7b4b",
"GLZIqA.png": "\u5b50",
"gqDVGg.png": "\u5de8",
"gu5ykL.png": "\u8f6e",
"GULUze.png": "\u9ad8",
"h2FI8R.png": "\u80f8",
"h4WPDX.png": "\u6655",
"hCztH8.png": "\u9732",
"hfI2uM.png": "\u575a",
"hGHijB.png": "\u5668",
"hIhWai.png": "\u9ad8",
"HIUVkJ.png": "\u5c04",
"HkcQea.png": "\u4ea4",
"hm5O6l.png": "\u5957",
"hpFE8s.png": "\u6d41",
"HPxfmS.png": "\u542b",
"hVxPKi.png": "\u89e6",
"Ia3sI1.png": "\u4e71",
"IA8APJ.png": "\u5df4",
"IlUZRn.png": "\u575a",
"iN7Lri.png": "\u98df",
"iQMM3x.png": "\u611f",
"ISfDuf.png": "\u4f53",
"isWxov.png": "\u9a6c",
"ITILdU.png": "\u6267",
"IU731r.png": "\u9876",
"IUanTB.png": "\u878d",
"IUUwWq.png": "\u5165",
"Ixqere.png": "\u6d41",
"J9AEU9.png": "\u5165",
"JBfhPp.png": "\u64cd",
"jDxrrX.png": "\u5b50",
"jE4V2B.png": "\u6df1",
"jF1KPd.png": "\u25a1",
"jFACnh.png": "\u6bdb",
"jiyfGR.png": "\u6839",
"JLkmp8.png": "\u80a1",
"jWwTqU.png": "\u60c5",
"K00hgA.png": "\u5165",
"KaFnqe.png": "\u6eda",
"Kaqaq0.png": "\u9634",
"kDOkxJ.png": "\u957f",
"kSkOOe.png": "\u6309",
"KtjQU3.png": "\u634f",
"kWmDQN.png": "\u5904",
"kZQ8K6.png": "\u4e0b",
"l0kRFF.png": "\u7269",
"L9dqnM.png": "\u6b32",
"Ldo3hW.png": "\u8089",
"ljppnW.png": "\u611f",
"lNGSuh.png": "\u80a0",
"lRfqbE.png": "\u7cbe",
"lUzsIi.png": "\u8f6e",
"LZraJy.png": "\u6625",
"mBpVnV.png": "\u4e71",
"MEM8Wx.png": "\u5e72",
"MO2VKV.png": "\u6db2",
"ModDMS.png": "\u62bd",
"mOZJWk.png": "\u9a6c",
"mpgh5T.png": "\u51fa",
"nj29a6.png": "\u6267",
"NOEnvb.png": "\u8df3",
"nrSIO8.png": "\u6df1",
"o2xN3U.png": "\u82b1",
"O3b3KR.png": "\u6696",
"o5uSeU.png": "\u5bab",
"OaBMS5.png": "\u62d4",
"OB7KzU.png": "\u773c",
"oCH7SV.png": "\u9b54",
"oeeXig.png": "\u9a6c",
"OgBVeb.png": "\u8f6f",
"oHc3dE.png": "\u7269",
"OLHWRr.png": "\u70b9",
"onuRXa.png": "\u8482",
"oqLfcR.png": "\u6ed1",
"oUntUm.png": "\u6d53",
"OXOdsf.png": "\u9053",
"p3ARaM.png": "\u6d41",
"p068ps.png": "\u5bab",
"PLwxDG.png": "\u79cd",
"PmCTBy.png": "\u8272",
"pMlQBk.png": "\u6c41",
"pQypTa.png": "\u8fdb",
"PtUVdN.png": "\u62bd",
"PW1WSi.png": "\u6e7f",
"Pw3ezj.png": "\u914d",
"pXy3UL.png": "\u4ea4",
"Q7jy4x.png": "\u5185",
"q07XV1.png": "\u5668",
"Q9OBtA.png": "\u6f6e",
"QbYFBI.png": "\u9634",
"qEI00x.png": "\u4e0b",
"qewOBk.png": "\u6ed1",
"QfXoIi.png": "\u8089",
"qJIAe3.png": "\u6309",
"QkWjrV.png": "\u8eab",
"QnFF9j.png": "\u6839",
"qNFYq4.png": "\u5e72",
"QU7Lcv.png": "\u25a1",
"qwsVcX.png": "\u62bd",
"qxb6Lz.png": "\u70b9",
"QzP4Nz.png": "\u773c",
"R8uNPt.png": "\u5185",
"R9tjeh.png": "\u51fa",
"rFr75w.png": "\u80f8",
"rGA9Cq.png": "\u4ea4",
"RjCFQu.png": "\u7d27",
"RLNC0G.png": "\u70b9",
"rocNQb.png": "\u505a",
"Rpp7lC.png": "\u8482",
"rUJMTx.png": "\u8272",
"RZZBiZ.png": "\u773c",
"S2Dvd4.png": "\u6cc4",
"s8DZGN.png": "\u60c5",
"s560YT.png": "\u5177",
"SeKcc0.png": "\u8272",
"sFFl4b.png": "\u5ba0",
"SiAa7G.png": "\u5934",
"slAZvO.png": "\u8272",
"sTPB8l.png": "\u89e6",
"sV6OrY.png": "\u957f",
"syPCmu.png": "\u8f6e",
"Sz5U6E.png": "\u5668",
"SZn6xB.png": "\u7269",
"T6sDn9.png": "\u60c5",
"t9WGXQ.png": "\u903c",
"TCRQtC.png": "\u6ed1",
"TGkFFQ.png": "\u903c",
"tNjFEZ.png": "\u82b1",
"tOUYgC.png": "\u9b54",
"TSjC0C.png": "\u5ead",
"TSp4f1.png": "\u62d4",
"TWIhpT.png": "\u7231",
"TxaWbU.png": "\u878d",
"ua2bew.png": "\u9876",
"UbTLa5.png": "\u633a",
"uDN4sP.png": "\u5165",
"ueMquS.png": "\u8eab",
"UEVcqG.png": "\u8eab",
"UIFeaH.png": "\u914d",
"unR6fo.png": "\u9633",
"Upc9Pu.png": "\u4ea4",
"UukBzP.png": "\u6d1e",
"UvCU0f.png": "\u5ba0",
"VAOIqQ.png": "\u7f8e",
"vMf2zS.png": "\u914d",
"VnXHdX.png": "\u505a",
"vpHmyj.png": "\u5185",
"Vql6Ev.png": "\u59d0",
"vrkjXi.png": "\u79cd",
"vtnLR7.png": "\u6c34",
"wkUtOc.png": "\u25a1",
"WOHLvx.png": "\u5976",
"WppxBg.png": "\u7f8e",
"WRtMHz.png": "\u56ca",
"WTAi5O.png": "\u63c9",
"wtwCbu.png": "\u725b",
"WXf8jT.png": "\u5177",
"xpWTjp.png": "\u7269",
"XqFPrk.png": "\u505a",
"XrHw7R.png": "\u4f53",
"XskrJT.png": "\u9633",
"xubhKq.png": "\u6bdb",
"xxqGbU.png": "\u80f8",
"y2rhls.png": "\u505a",
"y8TJ26.png": "\u79cd",
"YbmlHp.png": "\u82b1",
"YpcoIg.png": "\u7f8e",
"yruS8G.png": "\u8650",
"YTWiNM.png": "\u82b1",
"YvzoUL.png": "\u5589",
"YY1gAh.png": "\u878d",
"yYS2XJ.png": "\u8fdb",
"ZaWg8Q.png": "\u6d53",
"zbUsFu.png": "\u70ed",
"zGqroA.png": "\u5b50",
"zhogXd.png": "\u9732",
"zM4vGZ.png": "\u6eda",
"ZMyXfX.png": "\u786c",
"Znemv4.png": "\u9a6c",
"ZnORLb.png": "\u5934",
"zovunx.png": "\u7a74",
"ZpcLFr.png": "\u7231",
"4KLtoP.png": "\u868c",
"k2hzhi.png": "\u854a",
"OpOeoc.png": "\u96cf",
"D6GjNJ.png": "\u90a6",
"nSh1y5.png": "\u90a6",
"ZD1bga.png": "\u819c",
"0JNnRt.png": "\u88c6",
"0laGrG.png": "\u52c3",
"0sEWeF.png": "\u723d",
"0X07Oj.png": "\u957f",
"0ZBaBv.png": "\u7a74",
"1WoJda.png": "\u633a",
"1yUGqq.png": "\u5957",
"2ABT9u.png": "\u7ba1",
"2BcI5e.png": "\u6838",
"2dfEmL.png": "\u808f",
"2LdPZ9.png": "\u5df4",
"2VLZTT.png": "\u5438",
"2WgKu9.png": "\u6625",
"03PhNV.png": "\u6469",
"3preuJ.png": "\u6f6e",
"3tNh88.png": "\u63d2",
"4m7wbi.png": "\u6655",
"4mO3Bj.png": "\u5993",
"4P4bWw.png": "\u70eb",
"4qJrgq.png": "\u50ac",
"4xMdlq.png": "\u6345",
"5aHMLF.png": "\u6d53",
"5caAaX.png": "\u542b",
"5IL1sE.png": "\u817a",
"5qxLLo.png": "\u8404",
"5rXkkk.png": "\u5f04",
"5uAxU4.png": "\u63c9",
"5XAgwu.png": "\u5978",
"6A9MvV.png": "\u52c3",
"6jL6AP.png": "\u8361",
"6ontyx.png": "\u8461",
"6VRwjR.png": "\u7c97",
"6zcWUT.png": "\u6cc4",
"7aWXdF.png": "\u6f6e",
"7Bz8yG.png": "\u68cd",
"7fhmqV.png": "\u88e4",
"7jKFaP.png": "\u5978",
"7lNejO.png": "\u704c",
"7pFdxn.png": "\u64b8",
"7Q7Jrg.png": "\u5c4c",
"8BNYPM.png": "\u6696",
"8J5geS.png": "\u541f",
"8Kf7GD.png": "\u830e",
"8mHmVv.png": "\u830e",
"8N16Hq.png": "\u8650",
"8UniDu.png": "\u6237",
"8w5K9T.png": "\u88f8",
"8wm13p.png": "\u6655",
"8ZNrSv.png": "\u786c",
"9BRV3o.png": "\u5c4c",
"9Nqw8t.png": "\u762b",
"9RBhTJ.png": "\u9a9a",
"9RvnBS.png": "\u8089",
"9TaMmD.png": "\u6ccc",
"9UaEDH.png": "\u6d1e",
"9zWVtd.png": "\u59d0",
"47FrvB.png": "\u4e73",
"76gAv7.png": "\u723d",
"77lL1M.png": "\u541f",
"798jja.png": "\u76ae",
"a0mCeq.png": "\u8f6f",
"ACrPlr.png": "\u98df",
"aFoXhJ.png": "\u75d2",
"Afr6zx.png": "\u6b96",
"aHuUcm.png": "\u83ca",
"AiDkbY.png": "\u809b",
"aOxG78.png": "\u8461",
"AQZ08I.png": "\u809b",
"ARAUs9.png": "\u5c41",
"arEzdS.png": "\u5976",
"axdkbW.png": "\u58c1",
"aYGWo2.png": "\u83ca",
"b1C6Pu.png": "\u75d2",
"bCQ2nL.png": "\u654f",
"BgJzfk.png": "\u6b22",
"BhgFcH.png": "\u56ca",
"bOoL0J.png": "\u6deb",
"BqO1fa.png": "\u820c",
"bqXZDH.png": "\u80a5",
"BsU6ka.png": "\u854a",
"Bu9FZQ.png": "\u6deb",
"bufT6t.png": "\u819c",
"bWdbXA.png": "\u6eda",
"C4UN5R.png": "\u6deb",
"CgqkFG.png": "\u8361",
"CH67yh.png": "\u5a07",
"CM7jpY.png": "\u5b55",
"cNghja.png": "\u8361",
"CnOBoo.png": "\u63d2",
"CNQW3o.png": "\u70eb",
"cow4Kc.png": "\u5f3a",
"CXC9uz.png": "\u8089",
"Cy7Ynb.png": "\u762b",
"czWHZw.png": "\u96cf",
"D0Lwo9.png": "\u871c",
"dB0uJO.png": "\u820c",
"dHuyiO.png": "\u5c4c",
"DQWBph.png": "\u4e38",
"DsEJTV.png": "\u547b",
"dUrJvn.png": "\u819c",
"Ea3lho.png": "\u81c0",
"EboGWZ.png": "\u80a0",
"eifoua.png": "\u5b55",
"EiUhlF.png": "\u5957",
"ENwWoX.png": "\u4e71",
"EQEgJx.png": "\u6469",
"EQiUab.png": "\u88e4",
"er8NJ7.png": "\u542e",
"F0WoiN.png": "\u5177",
"f1YTv0.png": "\u6f6e",
"f2N1vL.png": "\u5978",
"F3nlmb.png": "\u88e4",
"F6lW1R.png": "\u80bf",
"f60BEY.png": "\u5c3f",
"f461mD.png": "\u6839",
"fd6C8F.png": "\u9e21",
"Fdz1Vc.png": "\u58c1",
"FetNxM.png": "\u5c4c",
"FfxOzl.png": "\u88f8",
"Fge27m.png": "\u8404",
"fGpEWq.png": "\u547b",
"Fl20Ip.png": "\u9f9f",
"fNXZyj.png": "\u6234",
"fRmx68.png": "\u90e8",
"fSdsL1.png": "\u88c6",
"FT9nI5.png": "\u83ca",
"FVVqzv.png": "\u86cb",
"FwjZJi.png": "\u5438",
"fX4WIp.png": "\u4f26",
"FXgFwc.png": "\u63d2",
"FXmf8I.png": "\u647a",
"fxPcW3.png": "\u6d1e",
"g2jVxn.png": "\u808f",
"gb3LOX.png": "\u80ef",
"gDVng6.png": "\u5ba0",
"gImiVY.png": "\u5f04",
"gJDFQC.png": "\u8214",
"gJDG8l.png": "\u5b55",
"GJodYn.png": "\u62d4",
"GmLjKa.png": "\u5c09",
"gNlJMc.png": "\u68cd",
"GppocX.png": "\u914d",
"gsRjtr.png": "\u67f1",
"GTOAc4.png": "\u633a",
"GzjpTS.png": "\u7cbe",
"h8zRxr.png": "\u80a1",
"H17DtI.png": "\u5c41",
"ha14XV.png": "\u89e6",
"hatLmR.png": "\u81c0",
"hbrRIS.png": "\u857e",
"hC4NbQ.png": "\u777e",
"hG0SRP.png": "\u64e6",
"HhNUaw.png": "\u854a",
"hKjWPG.png": "\u64b8",
"Hn8Afh.png": "\u74e3",
"hngWaZ.png": "\u5438",
"htV3uv.png": "\u58c1",
"hVaVng.png": "\u6309",
"HVHPCy.png": "\u74e3",
"hVwy7k.png": "\u8214",
"i4tyrQ.png": "\u830e",
"i5s28n.png": "\u4f26",
"IAloq6.png": "\u542e",
"ICHARH.png": "\u6237",
"icI6Ey.png": "\u81c0",
"iCRh88.png": "\u68d2",
"Iej2pu.png": "\u5993",
"IkqJmu.png": "\u8650",
"imVjMj.png": "\u4e73",
"iNIMEL.png": "\u86cb",
"IOjnEP.png": "\u6b22",
"ip6KUM.png": "\u79bd",
"IPC2R8.png": "\u9e21",
"ipVGiA.png": "\u6345",
"IpYNG3.png": "\u5974",
"ITUjFq.png": "\u76ae",
"ixiion.png": "\u90e8",
"IZcCzq.png": "\u871c",
"IzJ4WG.png": "\u830e",
"J1CBtB.png": "\u8df3",
"j9C44i.png": "\u70eb",
"JCQtUs.png": "\u4e73",
"JEcz0E.png": "\u871c",
"JfPEEe.png": "\u4f26",
"jHi6Vu.png": "\u9f9f",
"jjfR6D.png": "\u8461",
"jktdia.png": "\u64e6",
"JlkuRa.png": "\u8404",
"jnAvXp.png": "\u5ead",
"jnCCk9.png": "\u6cc4",
"jvj3DG.png": "\u786c",
"Jy4pAI.png": "\u74e3",
"jZyPEL.png": "\u5b55",
"K2AtMQ.png": "\u9a9a",
"K2jjT6.png": "\u857e",
"k6X0xy.png": "\u80bf",
"k9h8DR.png": "\u903c",
"k9zXwG.png": "\u723d",
"KalRLt.png": "\u6da6",
"kawcM7.png": "\u68cd",
"kdsEv6.png": "\u5f04",
"KdwL4R.png": "\u86cb",
"kPG0vR.png": "\u704c",
"KSqmoM.png": "\u6db2",
"kTCaM9.png": "\u86cb",
"kVLLjB.png": "\u8361",
"kygbuo.png": "\u725b",
"kZDlEj.png": "\u7ba1",
"l0BNLC.png": "\u6ccc",
"l1Dmft.png": "\u725b",
"L1yl45.png": "\u5c04",
"L3a5ft.png": "\u56ca",
"L3LaNQ.png": "\u5439",
"L9F6F8.png": "\u50ac",
"LB1WMg.png": "\u64cd",
"LBPqYj.png": "\u6d1e",
"LDjbfQ.png": "\u5c3f",
"ldo7FB.png": "\u7d27",
"lErO3o.png": "\u67f1",
"LFBZKA.png": "\u59d0",
"lfGqdb.png": "\u68d2",
"lGKjej.png": "\u5993",
"LjemA3.png": "\u809b",
"Ljh7qo.png": "\u63d2",
"LJSiT5.png": "\u5c44",
"Lk5uQy.png": "\u6838",
"lngKEo.png": "\u55b7",
"lOfDdC.png": "\u4e38",
"Lsq92O.png": "\u541f",
"LsyPdc.png": "\u541f",
"lVbZkd.png": "\u634f",
"lVMTQu.png": "\u654f",
"LVmymH.png": "\u80a0",
"lyYo4Y.png": "\u547b",
"lZtabT.png": "\u9634",
"M3VjF9.png": "\u64b8",
"m4yvu3.png": "\u7a74",
"M8bV3k.png": "\u56ca",
"MBhDEi.png": "\u75d2",
"MC5lZn.png": "\u585e",
"Mc8JM6.png": "\u62d4",
"mD7hPS.png": "\u5c41",
"mExNDV.png": "\u704c",
"MKapwC.png": "\u80a5",
"mKxUHv.png": "\u64e6",
"Mo31Ax.png": "\u6bdb",
"mRFQJQ.png": "\u5589",
"MsUFfR.png": "\u6b96",
"mTzxxd.png": "\u7f1d",
"n2ufBJ.png": "\u5978",
"n3oOgA.png": "\u6345",
"n9j6EC.png": "\u5ead",
"n49ZFH.png": "\u88c6",
"nCrl80.png": "\u762b",
"NDlwhm.png": "\u817a",
"nE1Y7y.png": "\u762b",
"neIgqc.png": "\u5439",
"NeKVfz.png": "\u6170",
"NHH9A1.png": "\u777e",
"NKN1rk.png": "\u542e",
"NKUSkP.png": "\u58c1",
"NlfTkc.png": "\u5c44",
"NlZDDQ.png": "\u817f",
"nmoPI2.png": "\u4e38",
"NnfPEJ.png": "\u9f9f",
"NP33MO.png": "\u6c41",
"NQ7oga.png": "\u611f",
"nsDzuq.png": "\u90a6",
"NsIwni.png": "\u5de8",
"oaLZIg.png": "\u777e",
"oC3HDZ.png": "\u7c97",
"OFx7ZU.png": "\u88f8",
"OHU6tX.png": "\u6db2",
"olFcqI.png": "\u5e72",
"OMdbeV.png": "\u819c",
"On4f9C.png": "\u7b4b",
"oncaJq.png": "\u76ae",
"Oo8iWN.png": "\u6309",
"OUWXqz.png": "\u6625",
"OuXWg2.png": "\u4e38",
"ozF5Kr.png": "\u8650",
"p0bqZi.png": "\u5c44",
"p1H9RN.png": "\u5c04",
"p5QCRV.png": "\u6ed1",
"p5zEbo.png": "\u857e",
"P43O6G.png": "\u6234",
"PalsBW.png": "\u5974",
"PcAvOY.png": "\u5ae9",
"pHfPTa.png": "\u5de8",
"pi2z0b.png": "\u7b4b",
"plFlPb.png": "\u68cd",
"pNPlu5.png": "\u704c",
"PnZNBC.png": "\u6deb",
"pQ1W2F.png": "\u88e4",
"PX3jJ6.png": "\u6ccc",
"q14YbK.png": "\u9876",
"Qc9LRh.png": "\u5598",
"qe2YZi.png": "\u63c9",
"qEy1kT.png": "\u90e8",
"Qfs9DA.png": "\u50ac",
"Qg8Qwg.png": "\u857e",
"qJ1X2h.png": "\u59d0",
"qm0ZBO.png": "\u6170",
"QmcP4w.png": "\u654f",
"Qn3xBM.png": "\u5ae9",
"qNGvlk.png": "\u5c3f",
"qPhrVf.png": "\u5904",
"qPX1Ef.png": "\u542b",
"qr8InI.png": "\u80a5",
"QtLIGq.png": "\u6db2",
"QtSnzR.png": "\u5598",
"Qv3JbY.png": "\u7f1d",
"QYF65i.png": "\u7b4b",
"Qz4Txd.png": "\u81c0",
"qzdvCv.png": "\u5df4",
"r7NsvF.png": "\u5f04",
"r8oBsP.png": "\u9e21",
"r9Gw4X.png": "\u6838",
"R65BZO.png": "\u8214",
"Rf7Jf6.png": "\u6469",
"Rho2GL.png": "\u75d2",
"rlVLx7.png": "\u7231",
"Rm3wex.png": "\u55b7",
"RmrhKk.png": "\u8214",
"RMWsBY.png": "\u654f",
"rn9y6F.png": "\u585e",
"RnfJ8h.png": "\u67f1",
"RP5Oud.png": "\u5598",
"Rp5tmA.png": "\u64cd",
"rpSSYK.png": "\u80ef",
"rQKjMD.png": "\u6bdb",
"RrXcE9.png": "\u5668",
"RyL5jk.png": "\u6c41",
"s67RPe.png": "\u70eb",
"s95kq4.png": "\u6e7f",
"sdXZMk.png": "\u52c3",
"SGxBy7.png": "\u5c41",
"smhB8j.png": "\u5c04",
"Srgobp.png": "\u6237",
"srlW2t.png": "\u6d41",
"ST21xu.png": "\u6d53",
"STzFJz.png": "\u7c97",
"sugwEw.png": "\u5976",
"SzADhL.png": "\u80bf",
"T5yzvl.png": "\u6c41",
"t6K8rK.png": "\u6027",
"tAIV6q.png": "\u64cd",
"TCFRca.png": "\u68d2",
"te79V0.png": "\u68d2",
"tjbhCV.png": "\u5ae9",
"tNFwEz.png": "\u5589",
"tPTX1h.png": "\u80a5",
"tsQMiL.png": "\u5439",
"TUZb1W.png": "\u6b32",
"TWFykG.png": "\u5993",
"twLxYU.png": "\u8f6f",
"tXNaZ2.png": "\u878d",
"U3bhkh.png": "\u9a9a",
"u6K6ci.png": "\u6b22",
"u9Tibu.png": "\u5185",
"Ua2WwL.png": "\u5a07",
"Uai2en.png": "\u5f3a",
"UeWULF.png": "\u5ead",
"UfXSsz.png": "\u540e",
"ui0T5v.png": "\u79bd",
"UqClGF.png": "\u80a1",
"Urv1FM.png": "\u80bf",
"uwXRHd.png": "\u55b7",
"v4iqzP.png": "\u7f1d",
"vAdmoL.png": "\u786c",
"VhA8GI.png": "\u5ae9",
"VHsdy1.png": "\u6838",
"vjOssT.png": "\u585e",
"vkYfGf.png": "\u9b54",
"vMmUqq.png": "\u5974",
"VnvOwV.png": "\u6da6",
"VoAjiw.png": "\u6e7f",
"vrtXeW.png": "\u88c6",
"VUbefT.png": "\u8f6e",
"vulCqw.png": "\u6267",
"VYaPfX.png": "\u7a74",
"VyJ2cS.png": "\u90a6",
"W06Vg1.png": "\u5de8",
"W7cCwn.png": "\u6345",
"W9Y9vD.png": "\u820c",
"wa54S5.png": "\u542b",
"FNq1zS.png": "\u868C",
"DDpMPK.png": "\u868C",
"vDbU8w.png": "\u817A",
"SSoXSL.png": "\u8461",
"YB6iOy.png": "\u817A",
"kMqpt6.png": "\u96CF",
"5RwMUT.png": "\u854A",
"b94JXX.png": "\u8114",
"oxFS6J.png": "\u8114",
"H53jMR.png": "\u96CF",
};
;// ./src/rules/special/reprint/haitangtxt.ts
function getClass(replaceFunction) {
return class extends rules/* BaseRuleClass */.Q {
constructor() {
super();
this.attachmentMode = "TM";
this.nsfw = true;
}
async bookParse() {
const bookUrl = document.querySelector("div.currency_head > h1 > a").href;
const bookId = bookUrl.split("/").slice(-2, -1)[0];
loglevel_default().debug(`[chapter]请求 ${bookUrl}`);
const dom = await (0,http/* getHtmlDOM */.wA)(bookUrl, "UTF-8");
const bookname = dom.querySelector("div.cataloginfo > h3").innerText.trim();
const author = dom.querySelector(".infotype > p:nth-child(1) > a:nth-child(1)").innerText.trim();
const introDom = dom.querySelector(".intro");
const [introduction, introductionHTML] = await (0,rule/* introDomHandle */.HV)(introDom, (introDomI) => {
(0,lib_dom.rm)("span:nth-child(1)", false, introDomI);
return introDomI;
});
const additionalMetadate = {};
const chapters = [];
const getMaxPageNumber = () => {
const pageDom = document.querySelector("div.page:nth-child(6)");
if (pageDom) {
const childNodes = Array.from(pageDom.childNodes);
const _maxPageNumber = childNodes
.slice(-1)[0]
.textContent?.match(/第\d+\/(\d+)页/);
if (_maxPageNumber) {
return _maxPageNumber[1];
}
}
};
const getIndexUrls = () => {
const indexUrlsI = [];
const _maxPageNumber = getMaxPageNumber();
if (_maxPageNumber === undefined) {
throw new Error("getMaxPageNumber return null ");
}
const maxPageNumber = parseInt(_maxPageNumber);
for (let i = 1; i <= maxPageNumber; i++) {
const indexUrl = [
document.location.origin,
document.location.pathname.split("/")[1],
`${bookId}_${i}`,
].join("/") + "/";
indexUrlsI.push(indexUrl);
}
return indexUrlsI;
};
const indexUrls = getIndexUrls();
let lis = [];
for (const indexUrl of indexUrls) {
loglevel_default().debug(`[chapter]请求 ${indexUrl}`);
const doc = await (0,http/* getHtmlDOM */.wA)(indexUrl, "UTF-8");
const ul = doc.querySelector("ul.chapters");
if (ul?.childElementCount) {
lis = lis.concat(Array.from(ul.children));
}
}
const chapterList = lis.filter((obj) => obj !== undefined);
let chapterNumber = 0;
for (const node of chapterList) {
chapterNumber++;
const a = node.firstElementChild;
const chapterName = a.innerText;
const chapterUrl = a.href;
const isVIP = false;
const isPaid = false;
const chapter = new Chapter/* Chapter */.I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP,
isPaid,
sectionName: null,
sectionNumber: null,
sectionChapterNumber: null,
chapterParse: this.chapterParse,
charset: this.charset,
options: {},
});
chapters.push(chapter);
}
return new Book/* Book */.E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
function contentAppend() {
function UpWz(m, i) {
let k = Math.ceil((i + 1) % code);
k = Math.ceil(m - k);
return k;
}
const _e = dom.getElementsByTagName("meta")[7].getAttribute("content");
const contentRaw = dom.querySelector("#articlecontent");
let codeurl;
let code;
const _codeurl = dom
.getElementsByTagName("script")[1]
.innerText.trim()
.match(/"(http.+)"/);
if (_codeurl) {
codeurl = _codeurl[1];
const _code = new URL(codeurl).searchParams.get("code");
if (_code) {
code = parseInt(_code);
}
}
if (_e) {
const e = atob(_e)
.split(/[A-Z]+%/)
.map((v) => parseInt(v));
const childNode = [];
if (Array.from(dom.querySelectorAll("script")).filter((s) => s.src.includes("/17mb/js/article.js")).length) {
for (let i = 0; i < e.length; i++) {
const k = UpWz(e[i], i);
childNode[k] = contentRaw.childNodes[i];
}
for (const node of childNode) {
if (node.nodeType !== 1) {
continue;
}
if (!(node.innerText.includes("本章尚未完结,请") ||
node.innerText.includes("本章已阅读完毕"))) {
content.appendChild(node);
}
}
return;
}
}
for (const node of Array.from(contentRaw.childNodes)) {
if (!(node.innerText.includes("本章尚未完结,请") ||
node.innerText.includes("本章已阅读完毕"))) {
content.appendChild(node);
}
}
return;
}
let nowUrl = chapterUrl;
let dom = await (0,http/* getHtmlDOM */.wA)(chapterUrl, charset);
const content = document.createElement("div");
let flag = false;
do {
contentAppend();
const nextLink = dom.querySelector(".novelbutton .p1.p3 > a:nth-child(1)").href;
if (new URL(nextLink).pathname.includes("_")) {
if (nextLink !== nowUrl) {
flag = true;
}
else {
loglevel_default().error("网站页面出错,URL: " + nowUrl);
flag = false;
}
}
else {
flag = false;
}
if (flag) {
nowUrl = nextLink;
dom = await (0,http/* getHtmlDOM */.wA)(nextLink, charset);
}
} while (flag);
if (content) {
const { dom: oldDom, images: finalImages } = await (0,cleanDOM/* cleanDOM */.an)(content, "TM", { keepImageName: true });
const _newDom = document.createElement("div");
_newDom.innerHTML = replaceFunction(content.innerHTML);
const { dom: newDom, text: finalText } = await (0,cleanDOM/* cleanDOM */.an)(_newDom, "TM", {
keepImageName: true,
});
const fontStyleDom = document.createElement("style");
fontStyleDom.innerHTML = `.hide { display: none; }`;
oldDom.className = "hide";
const finalDom = document.createElement("div");
finalDom.appendChild(fontStyleDom);
finalDom.appendChild(oldDom);
finalDom.appendChild(newDom);
return {
chapterName,
contentRaw: content,
contentText: finalText,
contentHTML: finalDom,
contentImages: finalImages,
additionalMetadate: null,
};
}
else {
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
}
};
}
const haitangtxt = () => getClass(replaceHaitangtxtImage);
const yuzhaige = () => getClass(replaceYuzhaigeImage);
/***/ }),
/***/ "./src/rules/special/reprint/hetushu.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Hetushu: () => (/* binding */ Hetushu)
/* harmony export */ });
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules.ts");
class Hetushu extends _rules__WEBPACK_IMPORTED_MODULE_0__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
}
async bookParse() {
const bookUrl = document.location.href;
const bookname = document.querySelector(".book_info > h2").innerText.trim();
const author = document.querySelector(".book_info > div:nth-child(3) > a:nth-child(1)").innerText.trim();
const introDom = document.querySelector(".intro");
const [introduction, introductionHTML] = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_1__/* .introDomHandle */ .HV)(introDom);
const additionalMetadate = {};
const coverUrl = document.querySelector(".book_info > img").src;
if (coverUrl) {
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_2__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_3___default().error(error));
}
const chapters = [];
const chapterList = document.querySelector("#dir")?.childNodes;
if (chapterList && chapterList.length !== 0) {
let chapterNumber = 0;
let sectionNumber = 0;
let sectionName = null;
let sectionChapterNumber = 0;
for (const node of chapterList) {
let a = null;
if (node.nodeName === "DT") {
sectionNumber++;
sectionChapterNumber = 0;
sectionName = node.innerText.trim();
a = node.querySelector("a");
}
else if (node.nodeName === "DD") {
a = node.firstElementChild;
}
if (a) {
chapterNumber++;
sectionChapterNumber++;
const chapterName = a.innerText;
const chapterUrl = a.href;
const isVIP = false;
const isPaid = false;
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_4__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP,
isPaid,
sectionName,
sectionNumber,
sectionChapterNumber,
chapterParse: this.chapterParse,
charset: this.charset,
options: {},
});
chapters.push(chapter);
}
}
}
return new _main_Book__WEBPACK_IMPORTED_MODULE_5__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
async function sorfPage() {
let path;
let bid;
let sid;
if (/\/(book[0-9]?)\/([0-9]+)\/([0-9]+)\.html(\?position=([0-9]+))?$/.test(chapterUrl)) {
path = RegExp.$1;
bid = RegExp.$2;
sid = RegExp.$3;
}
else {
return false;
}
const url = [
document.location.origin,
path,
bid,
"r" + sid + ".json",
].join("/");
_log__WEBPACK_IMPORTED_MODULE_3___default().debug(`[Chapter]请求 ${url} Referer ${chapterUrl}`);
const token = await fetch(url, {
headers: {
accept: "*/*",
"cache-control": "no-cache",
"content-type": "application/x-www-form-urlencoded",
pragma: "no-cache",
"x-requested-with": "XMLHttpRequest",
},
referrer: chapterUrl,
method: "GET",
mode: "cors",
credentials: "include",
})
.then((response) => response.headers.get("token"))
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_3___default().error(error));
if (token) {
const tokenDict = atob(token)
.split(/[A-Z]+%/)
.map((v) => parseInt(v));
const thisBody = doc.querySelector("#content");
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_6__.rm)(".mask.mask2", false, thisBody);
let b = 0;
let star = 0;
for (let i = 0; i < thisBody.childNodes.length; i++) {
if (thisBody.childNodes[i].nodeName === "H2") {
star = i + 1;
}
if (thisBody.childNodes[i].nodeName === "DIV" &&
thisBody.childNodes[i].className !== "chapter") {
break;
}
}
const thisChildNode = [];
for (let i = 0; i < tokenDict.length; i++) {
if (tokenDict[i] < 5) {
thisChildNode[tokenDict[i]] = thisBody.childNodes[i + star];
b++;
}
else {
thisChildNode[tokenDict[i] - b] = thisBody.childNodes[i + star];
}
}
for (const childNode of thisChildNode) {
if (!childNode) {
continue;
}
thisBody.appendChild(childNode);
}
}
}
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_7__/* .getHtmlDOM */ .wA)(chapterUrl, charset);
chapterName = doc.querySelector("#content .h2").innerText.trim();
await sorfPage();
const content = doc.querySelector("#content");
if (content) {
const tagRemoved = "h2, acronym, bdo, big, cite, code, dfn, kbd, q, s, samp, strike, tt, u, var";
tagRemoved.split(", ").forEach((s) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_6__.rm)(s, true, content);
});
Array.from(content.querySelectorAll("div")).map((oldNode) => {
const newNode = document.createElement("p");
newNode.innerHTML = oldNode.innerHTML;
oldNode.parentNode?.replaceChild(newNode, oldNode);
});
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_8__/* .cleanDOM */ .an)(content, "TM");
return {
chapterName,
contentRaw: content,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: null,
};
}
else {
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
}
}
/***/ }),
/***/ "./src/rules/special/reprint/idejian.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Idejian: () => (/* binding */ Idejian)
/* harmony export */ });
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules.ts");
class Idejian extends _rules__WEBPACK_IMPORTED_MODULE_0__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
this.maxRunLimit = 5;
}
async bookParse() {
const bookUrl = document.location.href;
const _bookID = bookUrl.match(/\/(\d+)\/$/);
const bookID = _bookID && _bookID[1];
const bookname = document.querySelector(".detail_bkname > a").innerText.trim();
const _author = document.querySelector(".detail_bkauthor")
.childNodes[0];
let author = "佚名";
if (_author && _author.textContent) {
author = _author.textContent.trim();
}
const introDom = document.querySelector(".brief_con");
const [introduction, introductionHTML] = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_1__/* .introDomHandle */ .HV)(introDom);
const additionalMetadate = {};
const coverUrl = document.querySelector(".book_img > img").src;
if (coverUrl) {
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_2__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_3___default().error(error));
}
additionalMetadate.tags = Array.from(document.querySelectorAll("div.detail_bkgrade > span")).map((span) => span.innerText.trim());
const chapters = [];
const cos = document.querySelectorAll(".catelog_list > li > a");
let chapterNumber = 0;
for (const aElem of Array.from(cos)) {
chapterNumber++;
const chapterName = aElem.innerText;
const chapterUrl = aElem.href;
const isVIP = false;
const isPaid = false;
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_4__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP,
isPaid,
sectionName: null,
sectionNumber: null,
sectionChapterNumber: null,
chapterParse: this.chapterParse,
charset: this.charset,
options: { bookID },
});
chapters.push(chapter);
}
document.cookie = "";
return new _main_Book__WEBPACK_IMPORTED_MODULE_5__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
const _chapterUrl = new URL(chapterUrl);
_chapterUrl.hostname = "m.idejian.com";
chapterUrl = _chapterUrl.toString();
const referBaseUrl = "https://m.idejian.com/catalog";
const _refer = new URL(referBaseUrl);
_refer.searchParams.set("bookId", options.bookID);
const referUrl = _refer.toString();
const fakeUA = "Mozilla/5.0 (iPhone; CPU iPhone OS 13_3_1 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/13.0.5 Mobile/15E148 Snapchat/10.77.5.59 (like Safari/604.1)";
if (document.cookie === "") {
await (0,_lib_http__WEBPACK_IMPORTED_MODULE_6__/* .ggetText */ .bx)(referUrl, charset, { headers: { "User-Agent": fakeUA } });
await (0,_lib_http__WEBPACK_IMPORTED_MODULE_6__/* .ggetText */ .bx)(chapterUrl, charset, {
headers: { "User-Agent": fakeUA, Referer: referUrl },
});
}
_log__WEBPACK_IMPORTED_MODULE_3___default().debug(`[Chapter]请求 ${chapterUrl},Refer:${referUrl}`);
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_6__/* .ggetHtmlDOM */ .pG)(chapterUrl, charset, {
headers: { "User-Agent": fakeUA, Referer: referUrl },
});
chapterName = doc.querySelector(".text-title-1").innerText.trim();
let content;
if (doc.querySelectorAll("div.h5_mainbody").length === 1) {
content = doc.querySelector("div.h5_mainbody");
}
else {
content = doc.querySelectorAll("div.h5_mainbody")[1];
}
if (content) {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_7__.rm)("h1", false, content);
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_8__/* .cleanDOM */ .an)(content, "TM");
return {
chapterName,
contentRaw: content,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: null,
};
}
else {
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
}
}
/***/ }),
/***/ "./src/rules/special/reprint/kanunu8.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Kanunu8: () => (/* binding */ Kanunu8)
/* harmony export */ });
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _lib_readability__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/lib/readability.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_4__);
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules.ts");
class Kanunu8 extends _rules__WEBPACK_IMPORTED_MODULE_0__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
}
async bookParse() {
const bookUrl = document.location.href;
const bookname = document.title.split(" ")[0];
const _authorAList = Array.from(document.querySelectorAll("a")).filter((a) => (a.href.includes("writer") || a.href.includes("/zj/")) &&
a.href.includes(".html"));
const authorElem = _authorAList
.map((a) => [a, a.getBoundingClientRect().top])
.sort(softByValue)?.[0]?.[0];
const author = authorElem?.innerText
.replace("作品集", "")
.replace("→", "")
.trim() ?? "";
const introDom = Array.from(document.body.querySelectorAll("td, p"))
.filter((elem) => elem.innerText.length !== 0)
.map((elem) => [elem, (0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__/* .getNodeTextLength */ .K4)(elem)])
.sort(softByValue)
.slice(-1)?.[0][0];
let introduction = null, introductionHTML = null;
if (introDom) {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)("a", true, introDom);
[introduction, introductionHTML] = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_2__/* .introDomHandle */ .HV)(introDom);
}
let aList = null;
let sections = null;
let getName = null;
function aListFilter(a) {
const filters = ["writer", "/zj/", "index.html"];
for (const f of filters) {
if (a.href.includes(f)) {
return false;
}
}
return true;
}
if (document.querySelector("div.book")) {
aList = Array.from(document.querySelectorAll("div.book a")).filter(aListFilter);
sections = document.querySelectorAll("div.book dl > dt, div.book td > strong");
getName = (sElem) => sElem.innerText;
}
else {
const tables = document.querySelectorAll("table");
const _table = Array.from(tables)
.map((tb) => [tb, (0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__/* .getMaxDepth */ .e_)(tb)])
.filter((ds) => ds[1] === 4)
.filter((ds) => (0,_lib_rule__WEBPACK_IMPORTED_MODULE_2__/* .centerDetct */ .sy)(ds[0])[0])
.map((ds) => [
ds[0],
Array.from(ds[0].querySelectorAll("a")).filter(aListFilter)
.length,
])
.sort(softByValue);
if (_table.length !== 0) {
const table = _table.slice(-1)[0][0];
aList = table.querySelectorAll("a");
sections = table.querySelectorAll('td[align="center"]');
getName = (sElem) => sElem.innerText;
}
}
const additionalMetadate = {};
const _cover = Array.from(document.querySelectorAll("img")).filter((img) => new URL(img.src).host === document.location.host);
if (_cover.length === 1) {
const coverUrl = _cover[0].src;
if (coverUrl) {
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_3__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_4___default().error(error));
}
}
const chapters = [];
let chapterNumber = 0;
let sectionNumber = 0;
let sectionChapterNumber = 0;
let sectionName = "";
if (!aList) {
throw Error("[BookParse]获取章节信息失败!");
}
for (const elem of Array.from(aList)) {
const chapterName = elem.innerText.trim();
const chapterUrl = elem.href;
if (sections && getName) {
const _sectionName = (0,_lib_rule__WEBPACK_IMPORTED_MODULE_2__/* .getSectionName */ .lq)(elem, sections, getName);
if (_sectionName && sectionName !== _sectionName) {
sectionName = _sectionName;
sectionNumber++;
sectionChapterNumber = 0;
}
chapterNumber++;
sectionChapterNumber++;
}
const isVIP = false;
const isPaid = false;
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_5__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP,
isPaid,
sectionName,
sectionNumber,
sectionChapterNumber,
chapterParse: this.chapterParse,
charset: this.charset,
options: {},
});
chapters.push(chapter);
}
return new _main_Book__WEBPACK_IMPORTED_MODULE_6__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
const obj = await (0,_lib_readability__WEBPACK_IMPORTED_MODULE_7__.fetchAndParse)(chapterUrl, this.charset);
if (obj) {
const content = obj.content;
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)("a", true, content);
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_8__/* .cleanDOM */ .an)(content, "TM");
return {
chapterName,
contentRaw: content,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: null,
};
}
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
}
function softByValue(a, b) {
return a[1] - b[1];
}
/***/ }),
/***/ "./src/rules/special/reprint/ttkan.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Ttkan: () => (/* binding */ Ttkan)
/* harmony export */ });
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_3__);
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules.ts");
class Ttkan extends _rules__WEBPACK_IMPORTED_MODULE_0__/* .BaseRuleClass */ .Q {
constructor() {
super();
}
async bookParse() {
const $ = (selector) => document.querySelector(selector);
const host = location.hostname;
const language = host.split(".")[0] === "tw" ? "tw" : "cn";
const bookUrl = location.href;
const novelId = new URL(bookUrl).pathname.split("/")[3];
const bookname = $(".novel_info h1").innerText;
const author = $('meta[name="og:novel:author"]').content;
const intro = $(".description");
const [introduction, introductionHTML] = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_1__/* .introDomHandle */ .HV)(intro);
const genre = $(".novel_info > div:nth-child(2) > ul > li:nth-child(3)").childNodes[1].data;
const additionalMetadate = {
tags: [genre],
};
const coverUrl = $(".novel_info amp-img").getAttribute("src");
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_2__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_3___default().error(error));
const chapters = [];
const tocUrl = `https://${host}/api/nq/amp_novel_chapters?language=${language}&novel_id=${novelId}&__amp_source_origin=https%3A%2F%2Fwww.ttkan.co`;
const res = await fetch(tocUrl, {
headers: {
Accept: "application/json",
"AMP-Same-Origin": "true",
},
method: "GET",
});
const data = (await res.json());
for (const { chapter_id, chapter_name } of data.items) {
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_4__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl: `https://${host}/novel/user/page_direct?novel_id=${novelId}&page=${chapter_id}`,
chapterNumber: chapter_id,
chapterName: chapter_name,
isVIP: false,
isPaid: false,
sectionName: null,
sectionNumber: null,
sectionChapterNumber: null,
chapterParse: this.chapterParse.bind(this),
charset: this.charset,
options: {},
});
chapters.push(chapter);
}
return new _main_Book__WEBPACK_IMPORTED_MODULE_5__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_6__/* .ggetHtmlDOM */ .pG)(chapterUrl, charset, {
headers: {
"Accept-Language": "zh-CN",
},
});
const content = doc.querySelector(".content");
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_7__.rm)("a", true, content);
const ttkanAd = /[wWщшω]{0,3} ?[¸◆⊕●.•_¤☢⊙▲✿★▪]? ?(?:[tTтⓣ] ?){2}[kKκКⓚ] ?[aAǎáдāΛⓐ] ?[nNⓝ] ?[¸◆⊕●.•_¤☢⊙▲✿★▪]? ?[cCС¢℃] ?[oO〇○Ο] ?/gi;
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_7__/* .rms */ .j3)([ttkanAd], content);
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_8__/* .cleanDOM */ .an)(content, "TM");
return {
chapterName,
contentRaw: content,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: null,
};
}
}
/***/ }),
/***/ "./src/rules/special/reprint/xkzw.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ Xkzw: () => (/* binding */ Xkzw)
/* harmony export */ });
/* harmony import */ var crypto_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("crypto-js");
/* harmony import */ var crypto_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(crypto_js__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_4__);
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/rules.ts");
class Xkzw extends _rules__WEBPACK_IMPORTED_MODULE_1__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
}
async bookParse() {
const bookUrl = document.location.href;
const bookname = document.querySelector("#info > h1:nth-child(1)").innerText.trim();
const author = document.querySelector("#info > p:nth-child(2)").innerText
.replace(/作(\s+)?者[::]/, "")
.trim();
const introDom = document.querySelector("#intro");
const [introduction, introductionHTML] = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_2__/* .introDomHandle */ .HV)(introDom);
const additionalMetadate = {};
const coverUrl = document.querySelector("#fmimg > img").src;
if (coverUrl) {
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_3__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_4___default().error(error));
}
const chapters = [];
const bookid = unsafeWindow.bookId;
const apiUrl = [document.location.origin, "action.php"].join("/");
_log__WEBPACK_IMPORTED_MODULE_4___default().debug(`[chapter]正在请求${apiUrl}`);
const siteChapterList = await fetch(apiUrl, {
headers: {
accept: "application/json, text/javascript, */*",
"content-type": "application/x-www-form-urlencoded",
"x-requested-with": "XMLHttpRequest",
},
body: `action=clist&bookid=${bookid}`,
method: "POST",
mode: "cors",
credentials: "include",
})
.then((response) => response.json())
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_4___default().error(error));
const dl1 = document.querySelector("#wrapper > div.box_con:nth-child(7) > div:nth-child(1) > dl:nth-child(1)");
const dl2 = document.querySelector("#wrapper > div.box_con:nth-child(11) > div:nth-child(1) > dl:nth-child(1)");
const mkList = (dl) => {
let tmpColumnName = "";
const ttmpColumnList = [];
let ttmpChapterList = [];
if (dl?.childElementCount) {
const dlc = Array.from(dl.children);
for (let i = 0; i < dl.childElementCount; i++) {
const node = dlc[i];
if (i !== 0) {
if (node.nodeName === "DD") {
const a = node.firstElementChild;
const chapterName = a.innerText;
const chapterUrl = a.href;
const chapterid = chapterUrl
.split("/")
.slice(-1)[0]
.replace(".html", "");
ttmpChapterList.push({
chapterid: parseInt(chapterid) - bookid * 11,
chaptername: chapterName,
isempty: 0,
originalurl: "",
currenturl: "",
});
}
else if (node.nodeName === "DT") {
const tmpColumnObj = {
columnname: tmpColumnName,
columnid: 0,
chapterlist: ttmpChapterList,
};
ttmpColumnList.push(tmpColumnObj);
tmpColumnName = node.innerText
.replace(`《${bookname}》`, "")
.trim();
ttmpChapterList = [];
}
}
else {
tmpColumnName = node.innerText
.replace(`《${bookname}》`, "")
.trim();
}
}
}
return [ttmpColumnList, ttmpChapterList];
};
const [tmpColumnList, tmpChapterList] = mkList(dl1);
const tcl = tmpChapterList.length;
for (let i = 0; i < tcl; i++) {
const tmpChapterObject = tmpChapterList.pop();
if (tmpChapterObject) {
siteChapterList.columnlist[0].chapterlist.unshift(tmpChapterObject);
}
}
if (tmpColumnList.length !== 0) {
const tmpColumnListLenght = tmpColumnList.length;
for (let i = 0; i < tmpColumnListLenght; i++) {
const tmpColumnObject = tmpColumnList.pop();
if (tmpColumnObject) {
siteChapterList.columnlist.unshift(tmpColumnObject);
}
}
}
const [tmpColumnList1, tmpChapterList1] = mkList(dl2);
const tcl1 = tmpChapterList1.length;
const cll = siteChapterList.columnlist.length;
for (let i = 0; i < tcl1; i++) {
const tmpChapterObject = tmpChapterList1.shift();
if (tmpChapterObject) {
siteChapterList.columnlist[cll - 1].chapterlist.push(tmpChapterObject);
}
}
if (tmpColumnList1.length !== 0) {
const tmpColumnListLenght = tmpColumnList1.length;
for (let i = 0; i < tmpColumnListLenght; i++) {
const tmpColumnObject = tmpColumnList1.shift();
if (tmpColumnObject) {
siteChapterList.columnlist.push(tmpColumnObject);
}
}
}
let chapterNumber = 0;
let sectionNumber = 0;
let sectionName = null;
let sectionChapterNumber = 0;
for (const column of siteChapterList.columnlist) {
sectionNumber++;
sectionName = column.columnname;
for (const sitechapter of column.chapterlist) {
chapterNumber++;
sectionChapterNumber++;
const chapterName = sitechapter.chaptername;
const chapterUrl = bookUrl + (sitechapter.chapterid + bookid * 11) + ".html";
const isVIP = false;
const isPaid = false;
const chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_5__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP,
isPaid,
sectionName,
sectionNumber,
sectionChapterNumber,
chapterParse: this.chapterParse,
charset: this.charset,
options: {},
});
chapters.push(chapter);
}
}
return new _main_Book__WEBPACK_IMPORTED_MODULE_6__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
function runEval(CryptoJS) {
function gettt1(str, keyStr, ivStr) {
const key = CryptoJS.enc.Utf8.parse(keyStr);
const iv = CryptoJS.enc.Utf8.parse(ivStr);
const encryptedHexStr = CryptoJS.enc.Hex.parse(str);
const srcs = CryptoJS.enc.Base64.stringify(encryptedHexStr);
const decrypt = CryptoJS.DES.decrypt(srcs, key, {
iv,
mode: CryptoJS.mode.CBC,
padding: CryptoJS.pad.Pkcs7,
});
const decryptedStr = decrypt.toString(CryptoJS.enc.Utf8);
return decryptedStr.toString();
}
function gettt2(str, keyStr, ivStr) {
const key = CryptoJS.enc.Utf8.parse(keyStr);
const iv = CryptoJS.enc.Utf8.parse(ivStr);
const encryptedHexStr = CryptoJS.enc.Hex.parse(str);
const srcs = CryptoJS.enc.Base64.stringify(encryptedHexStr);
const decrypt = CryptoJS.AES.decrypt(srcs, key, {
iv,
mode: CryptoJS.mode.CBC,
padding: CryptoJS.pad.Pkcs7,
});
const decryptedStr = decrypt.toString(CryptoJS.enc.Utf8);
return decryptedStr.toString();
}
function gettt3(str, keyStr, ivStr) {
const key = CryptoJS.enc.Utf8.parse(keyStr);
const iv = CryptoJS.enc.Utf8.parse(ivStr);
const encryptedHexStr = CryptoJS.enc.Hex.parse(str);
const srcs = CryptoJS.enc.Base64.stringify(encryptedHexStr);
const decrypt = CryptoJS.RC4.decrypt(srcs, key, {
iv,
mode: CryptoJS.mode.CBC,
padding: CryptoJS.pad.Pkcs7,
});
const decryptedStr = decrypt.toString(CryptoJS.enc.Utf8);
return decryptedStr.toString();
}
function getttn(str, keyStr, ivStr) {
const key = CryptoJS.enc.Utf8.parse(keyStr);
const iv = CryptoJS.enc.Utf8.parse(ivStr);
const encryptedHexStr = CryptoJS.enc.Hex.parse(str);
const srcs = CryptoJS.enc.Base64.stringify(encryptedHexStr);
const decrypt = CryptoJS.TripleDES.decrypt(srcs, key, {
iv,
mode: CryptoJS.mode.CBC,
padding: CryptoJS.pad.Pkcs7,
});
const decryptedStr = decrypt.toString(CryptoJS.enc.Utf8);
return decryptedStr.toString();
}
function showttt1(dom) {
const obj = dom.getElementById("other");
const objTips = dom.getElementById("contenttips");
if (obj) {
let content = obj.innerHTML.trim();
const type = parseInt(content.substring(0, 1), 10);
let key;
let iv;
if (type === 1) {
key = content.substring(1, 9);
iv = content.substring(9, 17);
content = content.substring(17);
obj.innerHTML = gettt1(content, key, iv);
obj.style.display = "block";
if (objTips) {
objTips.remove();
}
}
else if (type === 2) {
key = content.substring(1, 33);
iv = content.substring(33, 49);
content = content.substring(49);
obj.innerHTML = gettt2(content, key, iv);
obj.style.display = "block";
if (objTips) {
objTips.remove();
}
}
else if (type === 3) {
key = content.substring(1, 9);
iv = content.substring(9, 17);
content = content.substring(17);
obj.innerHTML = gettt3(content, key, iv);
obj.style.display = "block";
if (objTips) {
objTips.remove();
}
}
else {
key = content.substring(1, 25);
iv = content.substring(25, 33);
content = content.substring(33);
obj.innerHTML = getttn(content, key, iv);
obj.style.display = "block";
if (objTips) {
objTips.remove();
}
}
}
}
showttt1(doc);
}
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_7__/* .getHtmlDOM */ .wA)(chapterUrl, charset);
runEval(crypto_js__WEBPACK_IMPORTED_MODULE_0__);
chapterName = doc.querySelector(".bookname > h1:nth-child(1)").innerText.trim();
const contentG = doc.querySelector("#content");
if (contentG) {
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_8__/* .cleanDOM */ .an)(contentG, "TM");
return {
chapterName,
contentRaw: contentG,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: null,
};
}
else {
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
}
}
/***/ }),
/***/ "./src/rules/twoPage/18kanshu.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ c18kanshu: () => (/* binding */ c18kanshu)
/* harmony export */ });
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _tempate__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/twoPage/tempate.ts");
const c18kanshu = () => (0,_tempate__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
anotherPageUrl: document.querySelector("div.menu_more_black > a").href,
getBookname: (doc) => document.querySelector(".in_textone").innerText.trim(),
getAuthor: (doc) => {
const authorElem = document.querySelector("div.in_texttwo:nth-child(2)");
const author = /作者:(.+)$/.exec(authorElem.innerText.trim())?.[1] ?? "";
return author;
},
getIntroDom: (doc) => document.querySelector(".janjie"),
introDomPatch: (dom) => dom,
getCoverUrl: (doc) => document.querySelector(".book_top > div.img > img")
.src,
getAList: (doc) => {
const _aList = doc.querySelectorAll("div.list_main.book_list");
const reducer = (out, div) => {
const onclick = div.getAttribute("onclick");
const href = onclick?.substring(onclick.indexOf("'") + 1, onclick.lastIndexOf("'")) ?? "";
const a = document.createElement("a");
a.href = href;
a.innerHTML = div.innerHTML.trim();
out.push(a);
return out;
};
const aList = Array.from(_aList).reduce(reducer, []);
return aList;
},
getContent: (doc) => doc.querySelector(".readcontent"),
contentPatch: (dom) => {
Array.from(dom.childNodes)
.filter((node) => node instanceof Text)
.forEach((text) => {
if (text.textContent?.includes(" ")) {
text.parentNode?.insertBefore(document.createElement("br"), text);
}
});
if ((0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_1__/* .isFixWidth */ .eu)(dom)) {
(0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_1__/* .convertFixWidth */ .N0)(dom);
}
return dom;
},
nsfw: true,
});
/***/ }),
/***/ "./src/rules/twoPage/1pwx.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ xiaoshuodaquan: () => (/* binding */ xiaoshuodaquan)
/* harmony export */ });
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _tempate__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/twoPage/tempate.ts");
const xiaoshuodaquan = () => (0,_tempate__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
anotherPageUrl: document.querySelector(".viewalllinks").href,
getBookname: (doc) => document.querySelector(".r420 > h1").innerText.trim(),
getAuthor: (doc) => document.querySelector(".author a").innerText.trim(),
getIntroDom: (doc) => doc.querySelector(".bookintro"),
introDomPatch: (introDom) => introDom,
getCoverUrl: (doc) => document.querySelector(".con_limg > img")?.src,
getAList: (doc) => doc.querySelectorAll("div.clearfix li > a"),
getSections: (doc) => doc.querySelectorAll("div.dirtitone > h2"),
getSName: (sElem) => sElem.innerText.trim(),
postHook: (chapter) => {
chapter.sectionName =
chapter.sectionName?.replace(chapter.bookname, "").trim() ?? null;
return chapter;
},
getContent: (doc) => doc.querySelector("#content"),
contentPatch: (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)("div", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)("script", true, content);
const c = document.createElement("div");
c.innerHTML = content.innerHTML.replace(/\n/g, "<br/><br/>");
return c;
},
});
/***/ }),
/***/ "./src/rules/twoPage/jingcaiyuedu6.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ jingcaiyuedu6: () => (/* binding */ jingcaiyuedu6)
/* harmony export */ });
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _tempate__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/twoPage/tempate.ts");
const jingcaiyuedu6 = () => (0,_tempate__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
anotherPageUrl: document.querySelector("a.red-btn:nth-child(3)").href,
getBookname: (doc) => document.querySelector(".book-info > h1 > em").innerText.trim(),
getAuthor: (doc) => document.querySelector(".book-info > h1 > a").innerText.trim(),
getIntroDom: (doc) => document.querySelector(".book-info > p.intro"),
introDomPatch: (dom) => dom,
getCoverUrl: (doc) => document.querySelector(".book-img-cover").src,
getAList: (doc) => doc.querySelectorAll("dd.col-md-4 > a"),
getContent: (doc) => doc.querySelector("#htmlContent"),
contentPatch: (dom) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__/* .rm2 */ .Sf)(["精彩小说网最新地址"], dom);
return dom;
},
});
/***/ }),
/***/ "./src/rules/twoPage/linovelib.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
// EXPORTS
__webpack_require__.d(__webpack_exports__, {
linovelib: () => (/* binding */ linovelib),
wlinovelib: () => (/* binding */ wlinovelib)
});
// EXTERNAL MODULE: ./src/rules/twoPage/tempate.ts
var tempate = __webpack_require__("./src/rules/twoPage/tempate.ts");
// EXTERNAL MODULE: ./src/main/main.ts
var main = __webpack_require__("./src/main/main.ts");
// EXTERNAL MODULE: ./src/lib/rule.ts
var rule = __webpack_require__("./src/lib/rule.ts");
// EXTERNAL MODULE: ./src/lib/dom.ts
var dom = __webpack_require__("./src/lib/dom.ts");
;// ./src/rules/lib/linovelib.ts
const table = {
"\ue800": "\u7684",
"\ue801": "\u4e00",
"\ue802": "\u662f",
"\ue803": "\u4e86",
"\ue804": "\u6211",
"\ue805": "\u4e2a",
"\ue806": "\u4eba",
"\ue807": "\u4ed5",
"\ue808": "\u4ed6",
"\ue809": "\u6709",
"\ue80a": "\u8fd9",
"\ue80b": "\u4e2a",
"\ue80c": "\u4e0a",
"\ue80d": "\u4eec",
"\ue80e": "\u6765",
"\ue80f": "\u5230",
"\ue810": "\u65f6",
"\ue811": "\u5927",
"\ue812": "\u5730",
"\ue813": "\u4e3a",
"\ue814": "\u5b50",
"\ue815": "\u4e2d",
"\ue816": "\u4f60",
"\ue817": "\u8bf4",
"\ue818": "\u751f",
"\ue819": "\u56fd",
"\ue81a": "\u5e74",
"\ue81b": "\u770b",
"\ue81c": "\u5c31",
"\ue81d": "\u90a3",
"\ue81e": "\u548c",
"\ue81f": "\u8981",
"\ue820": "\u5979",
"\ue821": "\u51fa",
"\ue822": "\u4e5f",
"\ue823": "\u5f97",
"\ue824": "\u91cc",
"\ue825": "\u540e",
"\ue826": "\u81ea",
"\ue827": "\u4ee5",
"\ue828": "\u4f1a",
"\ue829": "\u5bb6",
"\ue82a": "\u53ef",
"\ue82b": "\u4e0b",
"\ue82c": "\u800c",
"\ue82d": "\u8fc7",
"\ue82e": "\u5929",
"\ue82f": "\u53bb",
"\ue830": "\u80fd",
"\ue831": "\u5bf9",
"\ue832": "\u5c0f",
"\ue833": "\u591a",
"\ue834": "\u7136",
"\ue835": "\u4e8e",
"\ue836": "\u5fc3",
"\ue837": "\u5b66",
"\ue838": "\u4e48",
"\ue839": "\u4e4b",
"\ue83a": "\u90fd",
"\ue83b": "\u597d",
"\ue83c": "\u770b",
"\ue83d": "\u8d77",
"\ue83e": "\u53d1",
"\ue83f": "\u5f53",
"\ue840": "\u6ca1",
"\ue841": "\u6210",
"\ue842": "\u53ea",
"\ue843": "\u5982",
"\ue844": "\u4e8b",
"\ue845": "\u628a",
"\ue846": "\u8fd8",
"\ue847": "\u7528",
"\ue848": "\u7b2c",
"\ue849": "\u6837",
"\ue84a": "\u9053",
"\ue84b": "\u60f3",
"\ue84c": "\u4f5c",
"\ue84d": "\u79cd",
"\ue84e": "\u5f00",
"\ue84f": "\u7f8e",
"\ue850": "\u4e73",
"\ue851": "\u9634",
"\ue852": "\u6db2",
"\ue853": "\u830e",
"\ue854": "\u6b32",
"\ue855": "\u547b",
"\ue856": "\u8089",
"\ue857": "\u4ea4",
"\ue858": "\u6027",
"\ue859": "\u80f8",
"\ue85a": "\u79c1",
"\ue85b": "\u7a74",
"\ue85c": "\u6deb",
"\ue85d": "\u81c2",
"\ue85e": "\u8214",
"\ue85f": "\u5c04",
"\ue860": "\u8131",
"\ue861": "\u88f8",
"\ue862": "\u9a9a",
"\ue863": "\u5507",
};
;// ./src/rules/twoPage/linovelib.ts
const chapterFixSleepTime = 2000;
const concurrencyLimit = 1;
const sleepTime = 600;
const maxSleepTime = 3000;
const linovelib = () => {
const ToCurl = document.location.href;
const bookUrl = ToCurl.replace(/\/catalog$/, ".html");
return (0,tempate/* mkRuleClass */.N)({
bookUrl,
anotherPageUrl: bookUrl,
ToCUrl: ToCurl,
getBookname: () => document.querySelector(".book-meta > h1").innerText.trim(),
getAuthor: () => document.querySelector(".book-meta > p:nth-child(2) > span:nth-child(1) > a:nth-child(1)").innerText.trim(),
getIntroDom: (doc) => doc.querySelector(".book-dec > p:nth-child(1)"),
introDomPatch: (dom) => dom,
getCoverUrl: (doc) => doc.querySelector(".book-img > img").src,
additionalMetadatePatch: (additionalMetadate, doc) => {
additionalMetadate.tags = Array.from(doc.querySelectorAll(".book-label a")).map((a) => a.innerText.trim());
return additionalMetadate;
},
getAList: () => document.querySelectorAll(".chapter-list li.col-4 > a"),
getSections: () => document.querySelectorAll("#volume-list > div.volume"),
getSName: (sElem) => sElem.querySelector(".volume-info >h2")?.innerText.trim(),
postHook: (chapter) => {
if (chapter.chapterUrl.startsWith("javascript")) {
chapter.status = main/* Status */.nW.aborted;
}
return chapter;
},
overrideConstructor: (classThis) => {
const rawBookParse = classThis.bookParse;
classThis.bookParse = async () => {
const book = (await Reflect.apply(rawBookParse, classThis, []));
const invalidTest = (c) => c.chapterUrl.startsWith("javascript");
const getPrevHref = (doc) => doc.querySelector(".mlfy_page > a:nth-child(1)")
?.href;
await (0,rule/* chapterHiddenFix */.$l)(book, invalidTest, getPrevHref, concurrencyLimit, chapterFixSleepTime);
return book;
};
return classThis;
},
getContentFromUrl: async (chapterUrl, chapterName, charset) => {
const { contentRaw } = await (0,rule/* nextPageParse */.u1)({
chapterName,
chapterUrl,
charset,
selector: "#TextContent",
contentPatch: (_content) => {
(0,dom.rm)(".tp", true, _content);
(0,dom.rm)(".bd", true, _content);
_content.querySelectorAll("img.lazyload").forEach((e) => {
e.src = e.dataset.src || e.src;
return e;
});
return _content;
},
getNextPage: (doc) => doc.querySelector(".mlfy_page > a:nth-child(5)").href,
continueCondition: (_content, nextLink) => new URL(nextLink).pathname.includes("_"),
enableCleanDOM: false,
});
return contentRaw;
},
contentPatch: (content) => {
for (const k in table) {
content.innerHTML = content.innerHTML.replaceAll(k, table[k]);
}
return content;
},
concurrencyLimit: concurrencyLimit,
sleepTime: sleepTime,
maxSleepTime: maxSleepTime,
});
};
const wlinovelib = () => {
const bookUrl = document.location.href;
const tocUrl = bookUrl.replace(/\.html/, "/catalog");
function getReadParams(doc) {
const script = Array.from(doc.querySelectorAll("script")).filter((s) => s.innerHTML.includes("ReadParams"))?.[0];
if (script) {
const ReadParams = (0,dom/* sandboxed */.d6)(`${script.innerHTML}; return ReadParams;`);
return ReadParams;
}
else {
return null;
}
}
return (0,tempate/* mkRuleClass */.N)({
bookUrl,
anotherPageUrl: tocUrl,
ToCUrl: tocUrl,
getBookname: () => document
.querySelector("h1.book-title")
?.innerText.trim() ?? "",
getAuthor: () => document
.querySelector(".book-rand-a > span")
?.innerText.trim() ?? "",
getIntroDom: () => document.querySelector("#bookSummary > content:nth-child(1)"),
introDomPatch: (dom) => dom,
getCoverUrl: () => document.querySelector(".book-cover")?.src ?? null,
additionalMetadatePatch: (additionalMetadate) => {
additionalMetadate.tags = Array.from(document.querySelectorAll(".tag-small")).map((a) => a.innerText.trim());
return additionalMetadate;
},
getAList: (doc) => doc.querySelectorAll(".chapter-li-a "),
getSections: (doc) => doc.querySelectorAll("li.chapter-bar.chapter-li"),
getSName: (sElem) => sElem.innerText.trim(),
postHook: (chapter) => {
if (chapter.chapterUrl.startsWith("javascript")) {
chapter.status = main/* Status */.nW.aborted;
}
return chapter;
},
overrideConstructor: (classThis) => {
const rawBookParse = classThis.bookParse;
classThis.bookParse = async () => {
const book = (await Reflect.apply(rawBookParse, classThis, []));
const invalidTest = (c) => c.chapterUrl.startsWith("javascript");
const getPrevHref = (doc) => {
const ReadParams = getReadParams(doc);
if (ReadParams) {
return document.location.origin + ReadParams.url_previous;
}
else {
return;
}
};
await (0,rule/* chapterHiddenFix */.$l)(book, invalidTest, getPrevHref, concurrencyLimit, chapterFixSleepTime);
return book;
};
return classThis;
},
getContentFromUrl: async (chapterUrl, chapterName, charset) => {
const { contentRaw } = await (0,rule/* nextPageParse */.u1)({
chapterName,
chapterUrl,
charset,
selector: "#acontent",
contentPatch: (_content) => {
(0,dom.rm)(".cgo", true, _content);
(0,dom.rm)("script", true, _content);
return _content;
},
getNextPage: (doc) => {
const ReadParams = getReadParams(doc);
if (ReadParams) {
return document.location.origin + ReadParams.url_next;
}
else {
return "";
}
},
continueCondition: (_content, nextLink) => {
if (nextLink === "") {
return false;
}
return new URL(nextLink).pathname.includes("_");
},
enableCleanDOM: false,
});
return contentRaw;
},
contentPatch: (dom) => dom,
concurrencyLimit: concurrencyLimit,
sleepTime: sleepTime,
maxSleepTime: maxSleepTime,
});
};
/***/ }),
/***/ "./src/rules/twoPage/shencou.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ shencou: () => (/* binding */ shencou)
/* harmony export */ });
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _main_main__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/main/main.ts");
/* harmony import */ var _tempate__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/twoPage/tempate.ts");
const shencou = () => {
const anotherPageUrl = document.querySelector("#content > table:nth-child(2) > tbody:nth-child(1) > tr:nth-child(3) > td:nth-child(1) > table:nth-child(1) > tbody:nth-child(1) > tr:nth-child(1) > td:nth-child(1) > ul:nth-child(1) > li:nth-child(1) > a:nth-child(1)").href;
return (0,_tempate__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
anotherPageUrl,
getBookname: (doc) => document.querySelector("#content > table:nth-child(2) > tbody:nth-child(1) > tr:nth-child(1) > td:nth-child(1) > table:nth-child(1) > tbody:nth-child(1) > tr:nth-child(1) > td:nth-child(1) > table:nth-child(1) > tbody:nth-child(1) > tr:nth-child(1) > td:nth-child(1) > span:nth-child(1) > a:nth-child(1)").innerText.trim(),
getAuthor: (doc) => document.querySelector("#content > table:nth-child(2) > tbody:nth-child(1) > tr:nth-child(1) > td:nth-child(1) > table:nth-child(1) > tbody:nth-child(1) > tr:nth-child(2) > td:nth-child(2)").innerText
.replace("小说作者:", "")
.trim(),
getIntroDom: (doc) => document.querySelector("#content > table:nth-child(2) > tbody:nth-child(1) > tr:nth-child(3) > td:nth-child(1) > table:nth-child(1) > tbody:nth-child(1) > tr:nth-child(1) > td:nth-child(2)"),
introDomPatch: (el) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)("a", true, el);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)(".hottext", true, el);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__/* .rm2 */ .Sf)(["论坛回帖,推荐本书,都可以得积分。每天送50积分"], el);
return el;
},
getCoverUrl: (doc) => document.querySelector("#content > table:nth-child(2) > tbody:nth-child(1) > tr:nth-child(3) > td:nth-child(1) > table:nth-child(1) > tbody:nth-child(1) > tr:nth-child(1) > td:nth-child(2) > a:nth-child(1) > img:nth-child(1)")?.src,
getAList: (doc) => doc.querySelectorAll("div.zjbox ol > li > a"),
getSections: (doc) => doc.querySelectorAll("div.zjbox div.ttname > h2"),
getSName: (s) => s.innerText.trim(),
getContent: (doc) => {
doc.body.innerHTML = doc.body.innerHTML.replace('<script language="javascript">GetFont();</script>', '<div id="content" class="fonts_mesne">');
doc.body.innerHTML = doc.body.innerHTML.replace("<center>", "</div>");
return doc.querySelector("#content");
},
contentPatch: (dom) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)("h1", true, dom);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)("div[id^=BookSee]", true, dom);
return dom;
},
cleanDomOptions: {
referrerMode: _main_main__WEBPACK_IMPORTED_MODULE_2__/* .ReferrerMode */ .ls.custom,
customReferer: "http://www.wenku8.net",
},
});
};
/***/ }),
/***/ "./src/rules/twoPage/tempate.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ N: () => (/* binding */ mkRuleClass)
/* harmony export */ });
/* harmony import */ var _lib_attachments__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/lib/attachments.ts");
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_http__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/http.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
/* harmony import */ var _log__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_log__WEBPACK_IMPORTED_MODULE_4__);
/* harmony import */ var _main_Chapter__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__("./src/main/Chapter.ts");
/* harmony import */ var _main_Book__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__("./src/main/Book.ts");
/* harmony import */ var _rules__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules.ts");
/* harmony import */ var _main_main__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__("./src/main/main.ts");
function mkRuleClass({ bookUrl, anotherPageUrl, ToCUrl, getBookname, getAuthor, getIntroDom, introDomPatch, getCoverUrl, additionalMetadatePatch, getAList, getAName, getIsVIP, getSections, getSName, postHook, getContentFromUrl, getContent, contentPatch, concurrencyLimit, sleepTime, maxSleepTime, needLogin, nsfw, cleanDomOptions, overrideConstructor, language, }) {
return class extends _rules__WEBPACK_IMPORTED_MODULE_0__/* .BaseRuleClass */ .Q {
constructor() {
super();
this.attachmentMode = "TM";
if (concurrencyLimit) {
this.concurrencyLimit = concurrencyLimit;
}
if (sleepTime) {
this.sleepTime = sleepTime;
}
if (maxSleepTime) {
this.maxSleepTime = maxSleepTime;
}
if (needLogin) {
this.needLogin = needLogin;
}
if (nsfw) {
this.nsfw = nsfw;
}
if (overrideConstructor) {
overrideConstructor(this);
}
}
async bookParse() {
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_1__/* .getHtmlDOM */ .wA)(anotherPageUrl, this.charset);
const bookname = getBookname(doc);
const author = getAuthor(doc);
const introDom = getIntroDom(doc);
const [introduction, introductionHTML] = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_2__/* .introDomHandle */ .HV)(introDom, introDomPatch);
const coverUrl = getCoverUrl(doc);
const additionalMetadate = {
language: language ?? "zh",
};
if (coverUrl) {
(0,_lib_attachments__WEBPACK_IMPORTED_MODULE_3__/* .getAttachment */ ["if"])(coverUrl, this.attachmentMode, "cover-")
.then((coverClass) => {
additionalMetadate.cover = coverClass;
})
.catch((error) => _log__WEBPACK_IMPORTED_MODULE_4___default().error(error));
}
if (typeof additionalMetadatePatch === "function") {
Object.assign(additionalMetadate, additionalMetadatePatch(additionalMetadate, doc));
}
let sections;
if (typeof getSections === "function") {
sections = getSections(doc);
}
const chapters = [];
let chapterNumber = 0;
let sectionNumber = 0;
let sectionChapterNumber = 0;
let sectionName = null;
let hasSection = false;
if (sections &&
sections instanceof NodeList &&
typeof getSName === "function") {
hasSection = true;
}
const aList = getAList(doc);
for (const aElem of Array.from(aList)) {
let chapterName;
if (getAName) {
chapterName = getAName(aElem);
}
else {
chapterName = aElem.innerText.trim();
}
const chapterUrl = aElem.href;
if (hasSection && sections && getSName) {
const _sectionName = (0,_lib_rule__WEBPACK_IMPORTED_MODULE_2__/* .getSectionName */ .lq)(aElem, sections, getSName);
if (_sectionName !== sectionName) {
sectionName = _sectionName;
sectionNumber++;
sectionChapterNumber = 0;
}
}
chapterNumber++;
sectionChapterNumber++;
let isVIP = false;
let isPaid = false;
if (getIsVIP) {
({ isVIP, isPaid } = getIsVIP(aElem));
}
let chapter = new _main_Chapter__WEBPACK_IMPORTED_MODULE_5__/* .Chapter */ .I({
bookUrl,
bookname,
chapterUrl,
chapterNumber,
chapterName,
isVIP,
isPaid,
sectionName,
sectionNumber: hasSection ? sectionNumber : null,
sectionChapterNumber: hasSection ? sectionChapterNumber : null,
chapterParse: this.chapterParse,
charset: this.charset,
options: { bookname },
});
if (isVIP && !isPaid) {
chapter.status = _main_main__WEBPACK_IMPORTED_MODULE_6__/* .Status */ .nW.aborted;
}
if (typeof postHook === "function") {
chapter = postHook(chapter);
}
if (chapter) {
chapters.push(chapter);
}
}
const book = new _main_Book__WEBPACK_IMPORTED_MODULE_7__/* .Book */ .E({
bookUrl,
bookname,
author,
introduction,
introductionHTML,
additionalMetadate,
chapters,
});
if (ToCUrl) {
book.ToCUrl = ToCUrl;
}
else if (bookUrl !== anotherPageUrl) {
book.ToCUrl = anotherPageUrl;
}
return book;
}
async chapterParse(chapterUrl, chapterName, isVIP, isPaid, charset, options) {
let content;
if (typeof getContentFromUrl === "function") {
content = await getContentFromUrl(chapterUrl, chapterName, charset);
}
else if (typeof getContent === "function") {
const doc = await (0,_lib_http__WEBPACK_IMPORTED_MODULE_1__/* .getHtmlDOM */ .wA)(chapterUrl, charset);
content = getContent(doc);
}
else {
throw Error("未发现 getContentFromUrl 或 getContent");
}
if (content) {
content = contentPatch(content);
const { dom, text, images } = await (0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_8__/* .cleanDOM */ .an)(content, "TM", cleanDomOptions);
return {
chapterName,
contentRaw: content,
contentText: text,
contentHTML: dom,
contentImages: images,
additionalMetadate: null,
};
}
return {
chapterName,
contentRaw: null,
contentText: null,
contentHTML: null,
contentImages: null,
additionalMetadate: null,
};
}
};
}
/***/ }),
/***/ "./src/rules/twoPage/washuge.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ washuge: () => (/* binding */ washuge)
/* harmony export */ });
/* harmony import */ var _tempate__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/twoPage/tempate.ts");
const washuge = () => {
const bookUrl = document.location.href;
const bookId = /(\d+)\/?$/.exec(bookUrl)?.[1];
if (!bookId) {
throw Error("获取书籍信息出错!");
}
const anotherPageUrl = `${document.location.origin}/books/book${bookId}.html`;
return (0,_tempate__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl,
anotherPageUrl,
getBookname: (doc) => doc.querySelector("#content > dd > h1")?.innerText
.replace("全文阅读", "")
.trim(),
getAuthor: (doc) => doc.querySelector("#at > tbody:nth-child(1) > tr:nth-child(1) > td:nth-child(4)")?.innerText.trim(),
getIntroDom: (doc) => doc.querySelector("#content > dd:nth-child(7) > p:nth-child(3)"),
introDomPatch: (dom) => dom,
getCoverUrl: (doc) => doc.querySelector(".hst > img").src,
getAList: (doc) => document.querySelectorAll("#at > tbody td > a"),
getContent: (doc) => doc.querySelector("#contents > *"),
contentPatch: (dom) => dom,
concurrencyLimit: 1,
});
};
/***/ }),
/***/ "./src/rules/twoPage/wenku8.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ wenku8: () => (/* binding */ wenku8)
/* harmony export */ });
/* harmony import */ var _tempate__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/twoPage/tempate.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/dom.ts");
const wenku8 = () => {
const bookId = document.location.pathname.split("/").slice(-2, -1)[0];
const bookUrl = [document.location.origin, "book", `${bookId}.htm`].join("/");
const tocUrl = document.location.href;
return (0,_tempate__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl,
ToCUrl: tocUrl,
anotherPageUrl: bookUrl,
getBookname: () => document.querySelector("#title").innerText.trim(),
getAuthor: (doc) => doc.querySelector("#content > div:nth-child(1) > table:nth-child(1) > tbody:nth-child(1) > tr:nth-child(2) > td:nth-child(2)").innerText
.replace("小说作者:", "")
.trim(),
getIntroDom: (doc) => doc.querySelector('#content > div:nth-child(1) > table:nth-child(4) > tbody:nth-child(1) > tr:nth-child(1) > td:nth-child(2) > span[style="font-size:14px;"]:nth-last-of-type(1)'),
introDomPatch: (dom) => dom,
getCoverUrl: (doc) => doc.querySelector("#content > div:nth-child(1) > table:nth-child(4) > tbody:nth-child(1) > tr:nth-child(1) > td:nth-child(1) > img:nth-child(1)").src,
getAList: () => document.querySelectorAll("tbody td.ccss > a"),
getSections: () => document.querySelectorAll("tbody td.vcss"),
getSName: (sElem) => sElem.innerText.trim(),
getContent: (doc) => doc.querySelector("#content"),
contentPatch: (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)("#contentdp", true, content);
return content;
},
concurrencyLimit: 1,
sleepTime: 300,
maxSleepTime: 1500,
});
};
/***/ }),
/***/ "./src/rules/twoPage/xiaoshuowu.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ xiaoshuowu: () => (/* binding */ xiaoshuowu)
/* harmony export */ });
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _tempate__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/twoPage/tempate.ts");
const xiaoshuowu = () => {
const href = document.location.href;
const bookId = href.substring(href.lastIndexOf("/", href.lastIndexOf("/") - 1) + 1, href.lastIndexOf("/"));
const bookUrl = document.location.origin + `/book/${bookId}/`;
return (0,_tempate__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl,
ToCUrl: document.location.href,
anotherPageUrl: bookUrl,
getBookname: (doc) => doc.querySelector("div.divbox:nth-child(2) > div:nth-child(2) > div:nth-child(1) > span:nth-child(1)").innerText.trim(),
getAuthor: (doc) => doc.querySelector("div.divbox:nth-child(2) > div:nth-child(2) > div:nth-child(1) > span:nth-child(2) > a").innerText.trim(),
getIntroDom: (doc) => doc.querySelector("div.tabvalue:nth-child(1) > div:nth-child(1)"),
introDomPatch: (dom) => dom,
getCoverUrl: (doc) => doc.querySelector("div.divbox:nth-child(2) > div:nth-child(1) > a:nth-child(1) > img").src,
getAList: (doc) => document.querySelectorAll("li.chapter > a"),
getSections: (doc) => document.querySelectorAll(".volume"),
getSName: (sElem) => sElem.innerText.trim(),
postHook: (chapter) => {
if (chapter.sectionName) {
chapter.sectionName = chapter.sectionName.replace(chapter.bookname, "");
}
return chapter;
},
getContent: (doc) => doc.querySelector("#acontent"),
contentPatch: (content) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)("div[align]", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)(".tishi", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__.rm)("h1", false, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_1__/* .rms */ .j3)(["(小说屋 www.xiaoshuowu.com)", "小说屋 www.xiaoshuowu.com"], content);
return content;
},
concurrencyLimit: 1,
});
};
/***/ }),
/***/ "./src/rules/twoPage/yibige.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ yibige: () => (/* binding */ yibige)
/* harmony export */ });
/* harmony import */ var _lib_cleanDOM__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__("./src/lib/cleanDOM.ts");
/* harmony import */ var _lib_dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__("./src/lib/dom.ts");
/* harmony import */ var _lib_rule__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__("./src/lib/rule.ts");
/* harmony import */ var _tempate__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/rules/twoPage/tempate.ts");
const yibige = () => (0,_tempate__WEBPACK_IMPORTED_MODULE_0__/* .mkRuleClass */ .N)({
bookUrl: document.location.href,
anotherPageUrl: document.location.href + "index.html",
getBookname: (doc) => document.querySelector("#info h1:nth-of-type(1)").innerText.trim(),
getAuthor: (doc) => document.querySelector("#info > p:nth-child(2)").innerText
.replace(/作(\s+)?者[::]/, "")
.trim(),
getIntroDom: (doc) => document.querySelector("#intro > p:nth-child(1)"),
introDomPatch: (introDom) => introDom,
getCoverUrl: (doc) => document.querySelector("#fmimg > img")?.src ?? "",
getAList: (doc) => doc.querySelectorAll("#list dd > a"),
getContent: (doc) => doc.querySelector("#content"),
getContentFromUrl: async (chapterUrl, chapterName, charset) => {
const { contentRaw } = await (0,_lib_rule__WEBPACK_IMPORTED_MODULE_1__/* .nextPageParse */ .u1)({
chapterName,
chapterUrl,
charset,
selector: "#content",
contentPatch: (content, doc) => {
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__.rm)("script", true, content);
(0,_lib_dom__WEBPACK_IMPORTED_MODULE_2__.rm)("div[style]", true, content);
(0,_lib_cleanDOM__WEBPACK_IMPORTED_MODULE_3__/* .htmlTrim */ .is)(content);
return content;
},
getNextPage: (doc) => doc.querySelector(".bottem1 > a:nth-child(4)")
.href,
continueCondition: (_content, nextLink) => {
const pathname = nextLink.split("/").slice(-1)[0];
return pathname.includes("_");
},
enableCleanDOM: false,
});
return contentRaw;
},
contentPatch: (content) => content,
});
/***/ }),
/***/ "./src/save/misc.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ e: () => (/* binding */ getSectionsObj)
/* harmony export */ });
function getSectionsObj(chapters, chapterSort = (a, b) => a.chapterNumber - b.chapterNumber) {
const _sectionsObj = {};
for (const chapter of chapters) {
let sectionNumber = null;
if (chapter.sectionNumber && chapter.sectionName) {
sectionNumber = chapter.sectionNumber;
}
else {
sectionNumber = -99999999;
}
if (_sectionsObj[sectionNumber]) {
_sectionsObj[sectionNumber].chpaters.push(chapter);
}
else {
_sectionsObj[sectionNumber] = {
sectionName: chapter.sectionName,
sectionNumber: chapter.sectionNumber,
chpaters: [chapter],
};
}
}
const sectionsListObj = Object.values(_sectionsObj);
sectionsListObj.sort(sectionListSort);
sectionsListObj.forEach((s) => s.chpaters.sort(chapterSort));
return sectionsListObj;
function sectionListSort(a, b) {
const aChapter = a.chpaters[0];
const bChapter = b.chpaters[0];
return chapterSort(aChapter, bChapter);
}
}
/***/ }),
/***/ "./src/setting.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ BV: () => (/* binding */ getCustomEnableSaveToArchiveOrg),
/* harmony export */ GM: () => (/* binding */ iconJump),
/* harmony export */ HE: () => (/* binding */ iconStart1),
/* harmony export */ Iz: () => (/* binding */ retryLimit),
/* harmony export */ Jv: () => (/* binding */ TxtDownload),
/* harmony export */ KV: () => (/* binding */ enableSaveToArchiveOrg),
/* harmony export */ Nw: () => (/* binding */ enableDebug),
/* harmony export */ Og: () => (/* binding */ iconStart0),
/* harmony export */ U5: () => (/* binding */ enableCustomChapterFilter),
/* harmony export */ Zz: () => (/* binding */ EpubDownload),
/* harmony export */ k8: () => (/* binding */ enableCustomSaveOptions),
/* harmony export */ ts: () => (/* binding */ enableJjwxcRemoteFont),
/* harmony export */ w1: () => (/* binding */ iconSetting),
/* harmony export */ zb: () => (/* binding */ enableCustomFinishCallback)
/* harmony export */ });
/* harmony import */ var _lib_GM__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__("./src/lib/GM.ts");
const retryLimit = 5;
const enableDebug = {
value: false,
};
const TxtDownload = {
value: true,
};
const EpubDownload = {
value: true,
};
const enableCustomFinishCallback = true;
const enableCustomChapterFilter = true;
const enableCustomSaveOptions = true;
const enableJjwxcRemoteFont = true;
const enableSaveToArchiveOrg = true;
const iconStart0 = "";
const iconStart1 = "";
const iconSetting = "";
const iconJump = "";
async function getCustomEnableSaveToArchiveOrg() {
const keyName = "novel-downloader-enableSaveToArchiveOrg";
const value = (await (0,_lib_GM__WEBPACK_IMPORTED_MODULE_0__/* ._GM_getValue */ .er)(keyName));
if (value === undefined) {
const v = confirm(`欢迎使用小说下载器脚本!
本脚本为404小说文库项目的组成部分之一。404小说文库项目致力于存档、保存、恢复因种种原因被删除的网络小说。
您是否同意将当前书页存档至互联网档案馆(archive.org),以备日后(被删除后)查看?
如您同意,小说下载器脚本将会发送当前书籍详情页URL及目录页URL(如果存在)至存档服务后端。
该过程将会搜集并上报您如下信息:IP地址、User-Agent、Referer、当前书籍详情页URL、当前书籍目录页URL(如果存在)、当前小说下载器脚本版本、当前脚本管理器版本。
除上述信息外,不会搜集您任何其他信息。
本存档功能为主体功能以外的附加功能,同意与否并不影响小说下载功能的正常使用。`);
await (0,_lib_GM__WEBPACK_IMPORTED_MODULE_0__/* ._GM_setValue */ .mN)(keyName, JSON.stringify(v));
return v;
}
else {
try {
const v = JSON.parse(value);
if (typeof v !== "boolean") {
throw new Error("value is not boolean");
}
return v;
}
catch (error) {
await (0,_lib_GM__WEBPACK_IMPORTED_MODULE_0__/* ._GM_deleteValue */ .JU)(keyName);
return false;
}
}
}
/***/ }),
/***/ "./src/ui/progress.ts":
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
// EXPORTS
__webpack_require__.d(__webpack_exports__, {
el: () => (/* binding */ el),
i: () => (/* binding */ style),
vm: () => (/* binding */ vm)
});
// EXTERNAL MODULE: external "Vue"
var external_Vue_ = __webpack_require__("vue");
// EXTERNAL MODULE: ./src/lib/dom.ts
var dom = __webpack_require__("./src/lib/dom.ts");
// EXTERNAL MODULE: ./src/ui/progress.css
var progress = __webpack_require__("./src/ui/progress.css");
;// ./src/ui/progress.html
// Module
var code = "<div>\n <div v-if=\"ntProgressSeen\" id=\"nd-progress\">\n <div v-if=\"chapterProgressSeen\" id=\"chapter-progress\" v-bind:style=\"{'--position': chapterPercent+'%'}\" v-bind:title=\"chapterProgressTitle\"></div>\n </div>\n</div>\n";
// Exports
/* harmony default export */ const ui_progress = (code);
;// ./src/ui/progress.ts
const style = (0,dom/* createStyle */._r)(progress/* default */.A);
const el = (0,dom/* createEl */.a_)(`<div id="progress-bar"></div>`);
const vm = (0,external_Vue_.createApp)({
data() {
return {
totalChapterNumber: 0,
finishedChapterNumber: 0,
};
},
computed: {
chapterPercent() {
if (this.totalChapterNumber !== 0 && this.finishedChapterNumber !== 0) {
return (this.finishedChapterNumber / this.totalChapterNumber) * 100;
}
else {
return 0;
}
},
chapterProgressSeen() {
return this.chapterPercent !== 0;
},
ntProgressSeen() {
return !!(this.chapterProgressSeen || this.zipProgressSeen);
},
chapterProgressTitle() {
return `章节:${this.finishedChapterNumber}/${this.totalChapterNumber}`;
},
},
methods: {
reset() {
this.totalChapterNumber = 0;
this.finishedChapterNumber = 0;
},
},
template: ui_progress,
}).mount(el);
/***/ }),
/***/ "crypto-js":
/***/ ((module) => {
"use strict";
module.exports = CryptoJS;
/***/ }),
/***/ "vue":
/***/ ((module) => {
"use strict";
module.exports = Vue;
/***/ }),
/***/ "./node_modules/p-limit/index.js":
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
"use strict";
// EXPORTS
__webpack_require__.d(__webpack_exports__, {
A: () => (/* binding */ pLimit)
});
;// ./node_modules/p-limit/node_modules/yocto-queue/index.js
/*
How it works:
`this.#head` is an instance of `Node` which keeps track of its current value and nests another instance of `Node` that keeps the value that comes after it. When a value is provided to `.enqueue()`, the code needs to iterate through `this.#head`, going deeper and deeper to find the last value. However, iterating through every single item is slow. This problem is solved by saving a reference to the last value as `this.#tail` so that it can reference it to add a new value.
*/
class Node {
value;
next;
constructor(value) {
this.value = value;
}
}
class Queue {
#head;
#tail;
#size;
constructor() {
this.clear();
}
enqueue(value) {
const node = new Node(value);
if (this.#head) {
this.#tail.next = node;
this.#tail = node;
} else {
this.#head = node;
this.#tail = node;
}
this.#size++;
}
dequeue() {
const current = this.#head;
if (!current) {
return;
}
this.#head = this.#head.next;
this.#size--;
return current.value;
}
clear() {
this.#head = undefined;
this.#tail = undefined;
this.#size = 0;
}
get size() {
return this.#size;
}
* [Symbol.iterator]() {
let current = this.#head;
while (current) {
yield current.value;
current = current.next;
}
}
}
;// ./node_modules/p-limit/async-hooks-stub.js
const AsyncResource = {
bind(fn, _type, thisArg) {
return fn.bind(thisArg);
},
};
class AsyncLocalStorage {
getStore() {
return undefined;
}
run(_store, callback) {
return callback();
}
}
;// ./node_modules/p-limit/index.js
function pLimit(concurrency) {
if (!((Number.isInteger(concurrency) || concurrency === Number.POSITIVE_INFINITY) && concurrency > 0)) {
throw new TypeError('Expected `concurrency` to be a number from 1 and up');
}
const queue = new Queue();
let activeCount = 0;
const next = () => {
activeCount--;
if (queue.size > 0) {
queue.dequeue()();
}
};
const run = async (function_, resolve, arguments_) => {
activeCount++;
const result = (async () => function_(...arguments_))();
resolve(result);
try {
await result;
} catch {}
next();
};
const enqueue = (function_, resolve, arguments_) => {
queue.enqueue(
AsyncResource.bind(run.bind(undefined, function_, resolve, arguments_)),
);
(async () => {
// This function needs to wait until the next microtask before comparing
// `activeCount` to `concurrency`, because `activeCount` is updated asynchronously
// when the run function is dequeued and called. The comparison in the if-statement
// needs to happen asynchronously as well to get an up-to-date value for `activeCount`.
await Promise.resolve();
if (activeCount < concurrency && queue.size > 0) {
queue.dequeue()();
}
})();
};
const generator = (function_, ...arguments_) => new Promise(resolve => {
enqueue(function_, resolve, arguments_);
});
Object.defineProperties(generator, {
activeCount: {
get: () => activeCount,
},
pendingCount: {
get: () => queue.size,
},
clearQueue: {
value() {
queue.clear();
},
},
});
return generator;
}
/***/ }),
/***/ "./node_modules/mime-db/db.json":
/***/ ((module) => {
"use strict";
module.exports = /*#__PURE__*/JSON.parse('{"application/1d-interleaved-parityfec":{"source":"iana"},"application/3gpdash-qoe-report+xml":{"source":"iana","charset":"UTF-8","compressible":true},"application/3gpp-ims+xml":{"source":"iana","compressible":true},"application/3gpphal+json":{"source":"iana","compressible":true},"application/3gpphalforms+json":{"source":"iana","compressible":true},"application/a2l":{"source":"iana"},"application/ace+cbor":{"source":"iana"},"application/activemessage":{"source":"iana"},"application/activity+json":{"source":"iana","compressible":true},"application/alto-costmap+json":{"source":"iana","compressible":true},"application/alto-costmapfilter+json":{"source":"iana","compressible":true},"application/alto-directory+json":{"source":"iana","compressible":true},"application/alto-endpointcost+json":{"source":"iana","compressible":true},"application/alto-endpointcostparams+json":{"source":"iana","compressible":true},"application/alto-endpointprop+json":{"source":"iana","compressible":true},"application/alto-endpointpropparams+json":{"source":"iana","compressible":true},"application/alto-error+json":{"source":"iana","compressible":true},"application/alto-networkmap+json":{"source":"iana","compressible":true},"application/alto-networkmapfilter+json":{"source":"iana","compressible":true},"application/alto-updatestreamcontrol+json":{"source":"iana","compressible":true},"application/alto-updatestreamparams+json":{"source":"iana","compressible":true},"application/aml":{"source":"iana"},"application/andrew-inset":{"source":"iana","extensions":["ez"]},"application/applefile":{"source":"iana"},"application/applixware":{"source":"apache","extensions":["aw"]},"application/at+jwt":{"source":"iana"},"application/atf":{"source":"iana"},"application/atfx":{"source":"iana"},"application/atom+xml":{"source":"iana","compressible":true,"extensions":["atom"]},"application/atomcat+xml":{"source":"iana","compressible":true,"extensions":["atomcat"]},"application/atomdeleted+xml":{"source":"iana","compressible":true,"extensions":["atomdeleted"]},"application/atomicmail":{"source":"iana"},"application/atomsvc+xml":{"source":"iana","compressible":true,"extensions":["atomsvc"]},"application/atsc-dwd+xml":{"source":"iana","compressible":true,"extensions":["dwd"]},"application/atsc-dynamic-event-message":{"source":"iana"},"application/atsc-held+xml":{"source":"iana","compressible":true,"extensions":["held"]},"application/atsc-rdt+json":{"source":"iana","compressible":true},"application/atsc-rsat+xml":{"source":"iana","compressible":true,"extensions":["rsat"]},"application/atxml":{"source":"iana"},"application/auth-policy+xml":{"source":"iana","compressible":true},"application/bacnet-xdd+zip":{"source":"iana","compressible":false},"application/batch-smtp":{"source":"iana"},"application/bdoc":{"compressible":false,"extensions":["bdoc"]},"application/beep+xml":{"source":"iana","charset":"UTF-8","compressible":true},"application/calendar+json":{"source":"iana","compressible":true},"application/calendar+xml":{"source":"iana","compressible":true,"extensions":["xcs"]},"application/call-completion":{"source":"iana"},"application/cals-1840":{"source":"iana"},"application/captive+json":{"source":"iana","compressible":true},"application/cbor":{"source":"iana"},"application/cbor-seq":{"source":"iana"},"application/cccex":{"source":"iana"},"application/ccmp+xml":{"source":"iana","compressible":true},"application/ccxml+xml":{"source":"iana","compressible":true,"extensions":["ccxml"]},"application/cdfx+xml":{"source":"iana","compressible":true,"extensions":["cdfx"]},"application/cdmi-capability":{"source":"iana","extensions":["cdmia"]},"application/cdmi-container":{"source":"iana","extensions":["cdmic"]},"application/cdmi-domain":{"source":"iana","extensions":["cdmid"]},"application/cdmi-object":{"source":"iana","extensions":["cdmio"]},"application/cdmi-queue":{"source":"iana","extensions":["cdmiq"]},"application/cdni":{"source":"iana"},"application/cea":{"source":"iana"},"application/cea-2018+xml":{"source":"iana","compressible":true},"application/cellml+xml":{"source":"iana","compressible":true},"application/cfw":{"source":"iana"},"application/city+json":{"source":"iana","compressible":true},"application/clr":{"source":"iana"},"application/clue+xml":{"source":"iana","compressible":true},"application/clue_info+xml":{"source":"iana","compressible":true},"application/cms":{"source":"iana"},"application/cnrp+xml":{"source":"iana","compressible":true},"application/coap-group+json":{"source":"iana","compressible":true},"application/coap-payload":{"source":"iana"},"application/commonground":{"source":"iana"},"application/conference-info+xml":{"source":"iana","compressible":true},"application/cose":{"source":"iana"},"application/cose-key":{"source":"iana"},"application/cose-key-set":{"source":"iana"},"application/cpl+xml":{"source":"iana","compressible":true,"extensions":["cpl"]},"application/csrattrs":{"source":"iana"},"application/csta+xml":{"source":"iana","compressible":true},"application/cstadata+xml":{"source":"iana","compressible":true},"application/csvm+json":{"source":"iana","compressible":true},"application/cu-seeme":{"source":"apache","extensions":["cu"]},"application/cwt":{"source":"iana"},"application/cybercash":{"source":"iana"},"application/dart":{"compressible":true},"application/dash+xml":{"source":"iana","compressible":true,"extensions":["mpd"]},"application/dash-patch+xml":{"source":"iana","compressible":true,"extensions":["mpp"]},"application/dashdelta":{"source":"iana"},"application/davmount+xml":{"source":"iana","compressible":true,"extensions":["davmount"]},"application/dca-rft":{"source":"iana"},"application/dcd":{"source":"iana"},"application/dec-dx":{"source":"iana"},"application/dialog-info+xml":{"source":"iana","compressible":true},"application/dicom":{"source":"iana"},"application/dicom+json":{"source":"iana","compressible":true},"application/dicom+xml":{"source":"iana","compressible":true},"application/dii":{"source":"iana"},"application/dit":{"source":"iana"},"application/dns":{"source":"iana"},"application/dns+json":{"source":"iana","compressible":true},"application/dns-message":{"source":"iana"},"application/docbook+xml":{"source":"apache","compressible":true,"extensions":["dbk"]},"application/dots+cbor":{"source":"iana"},"application/dskpp+xml":{"source":"iana","compressible":true},"application/dssc+der":{"source":"iana","extensions":["dssc"]},"application/dssc+xml":{"source":"iana","compressible":true,"extensions":["xdssc"]},"application/dvcs":{"source":"iana"},"application/ecmascript":{"source":"iana","compressible":true,"extensions":["es","ecma"]},"application/edi-consent":{"source":"iana"},"application/edi-x12":{"source":"iana","compressible":false},"application/edifact":{"source":"iana","compressible":false},"application/efi":{"source":"iana"},"application/elm+json":{"source":"iana","charset":"UTF-8","compressible":true},"application/elm+xml":{"source":"iana","compressible":true},"application/emergencycalldata.cap+xml":{"source":"iana","charset":"UTF-8","compressible":true},"application/emergencycalldata.comment+xml":{"source":"iana","compressible":true},"application/emergencycalldata.control+xml":{"source":"iana","compressible":true},"application/emergencycalldata.deviceinfo+xml":{"source":"iana","compressible":true},"application/emergencycalldata.ecall.msd":{"source":"iana"},"application/emergencycalldata.providerinfo+xml":{"source":"iana","compressible":true},"application/emergencycalldata.serviceinfo+xml":{"source":"iana","compressible":true},"application/emergencycalldata.subscriberinfo+xml":{"source":"iana","compressible":true},"application/emergencycalldata.veds+xml":{"source":"iana","compressible":true},"application/emma+xml":{"source":"iana","compressible":true,"extensions":["emma"]},"application/emotionml+xml":{"source":"iana","compressible":true,"extensions":["emotionml"]},"application/encaprtp":{"source":"iana"},"application/epp+xml":{"source":"iana","compressible":true},"application/epub+zip":{"source":"iana","compressible":false,"extensions":["epub"]},"application/eshop":{"source":"iana"},"application/exi":{"source":"iana","extensions":["exi"]},"application/expect-ct-report+json":{"source":"iana","compressible":true},"application/express":{"source":"iana","extensions":["exp"]},"application/fastinfoset":{"source":"iana"},"application/fastsoap":{"source":"iana"},"application/fdt+xml":{"source":"iana","compressible":true,"extensions":["fdt"]},"application/fhir+json":{"source":"iana","charset":"UTF-8","compressible":true},"application/fhir+xml":{"source":"iana","charset":"UTF-8","compressible":true},"application/fido.trusted-apps+json":{"compressible":true},"application/fits":{"source":"iana"},"application/flexfec":{"source":"iana"},"application/font-sfnt":{"source":"iana"},"application/font-tdpfr":{"source":"iana","extensions":["pfr"]},"application/font-woff":{"source":"iana","compressible":false},"application/framework-attributes+xml":{"source":"iana","compressible":true},"application/geo+json":{"source":"iana","compressible":true,"extensions":["geojson"]},"application/geo+json-seq":{"source":"iana"},"application/geopackage+sqlite3":{"source":"iana"},"application/geoxacml+xml":{"source":"iana","compressible":true},"application/gltf-buffer":{"source":"iana"},"application/gml+xml":{"source":"iana","compressible":true,"extensions":["gml"]},"application/gpx+xml":{"source":"apache","compressible":true,"extensions":["gpx"]},"application/gxf":{"source":"apache","extensions":["gxf"]},"application/gzip":{"source":"iana","compressible":false,"extensions":["gz"]},"application/h224":{"source":"iana"},"application/held+xml":{"source":"iana","compressible":true},"application/hjson":{"extensions":["hjson"]},"application/http":{"source":"iana"},"application/hyperstudio":{"source":"iana","extensions":["stk"]},"application/ibe-key-request+xml":{"source":"iana","compressible":true},"application/ibe-pkg-reply+xml":{"source":"iana","compressible":true},"application/ibe-pp-data":{"source":"iana"},"application/iges":{"source":"iana"},"application/im-iscomposing+xml":{"source":"iana","charset":"UTF-8","compressible":true},"application/index":{"source":"iana"},"application/index.cmd":{"source":"iana"},"application/index.obj":{"source":"iana"},"application/index.response":{"source":"iana"},"application/index.vnd":{"source":"iana"},"application/inkml+xml":{"source":"iana","compressible":true,"extensions":["ink","inkml"]},"application/iotp":{"source":"iana"},"application/ipfix":{"source":"iana","extensions":["ipfix"]},"application/ipp":{"source":"iana"},"application/isup":{"source":"iana"},"application/its+xml":{"source":"iana","compressible":true,"extensions":["its"]},"application/java-archive":{"source":"apache","compressible":false,"extensions":["jar","war","ear"]},"application/java-serialized-object":{"source":"apache","compressible":false,"extensions":["ser"]},"application/java-vm":{"source":"apache","compressible":false,"extensions":["class"]},"application/javascript":{"source":"iana","charset":"UTF-8","compressible":true,"extensions":["js","mjs"]},"application/jf2feed+json":{"source":"iana","compressible":true},"application/jose":{"source":"iana"},"application/jose+json":{"source":"iana","compressible":true},"application/jrd+json":{"source":"iana","compressible":true},"application/jscalendar+json":{"source":"iana","compressible":true},"application/json":{"source":"iana","charset":"UTF-8","compressible":true,"extensions":["json","map"]},"application/json-patch+json":{"source":"iana","compressible":true},"application/json-seq":{"source":"iana"},"application/json5":{"extensions":["json5"]},"application/jsonml+json":{"source":"apache","compressible":true,"extensions":["jsonml"]},"application/jwk+json":{"source":"iana","compressible":true},"application/jwk-set+json":{"source":"iana","compressible":true},"application/jwt":{"source":"iana"},"application/kpml-request+xml":{"source":"iana","compressible":true},"application/kpml-response+xml":{"source":"iana","compressible":true},"application/ld+json":{"source":"iana","compressible":true,"extensions":["jsonld"]},"application/lgr+xml":{"source":"iana","compressible":true,"extensions":["lgr"]},"application/link-format":{"source":"iana"},"application/load-control+xml":{"source":"iana","compressible":true},"application/lost+xml":{"source":"iana","compressible":true,"extensions":["lostxml"]},"application/lostsync+xml":{"source":"iana","compressible":true},"application/lpf+zip":{"source":"iana","compressible":false},"application/lxf":{"source":"iana"},"application/mac-binhex40":{"source":"iana","extensions":["hqx"]},"application/mac-compactpro":{"source":"apache","extensions":["cpt"]},"application/macwriteii":{"source":"iana"},"application/mads+xml":{"source":"iana","compressible":true,"extensions":["mads"]},"application/manifest+json":{"source":"iana","charset":"UTF-8","compressible":true,"extensions":["webmanifest"]},"application/marc":{"source":"iana","extensions":["mrc"]},"application/marcxml+xml":{"source":"iana","compressible":true,"extensions":["mrcx"]},"application/mathematica":{"source":"iana","extensions":["ma","nb","mb"]},"application/mathml+xml":{"source":"iana","compressible":true,"extensions":["mathml"]},"application/mathml-content+xml":{"source":"iana","compressible":true},"application/mathml-presentation+xml":{"source":"iana","compressible":true},"application/mbms-associated-procedure-description+xml":{"source":"iana","compressible":true},"application/mbms-deregister+xml":{"source":"iana","compressible":true},"application/mbms-envelope+xml":{"source":"iana","compressible":true},"application/mbms-msk+xml":{"source":"iana","compressible":true},"application/mbms-msk-response+xml":{"source":"iana","compressible":true},"application/mbms-protection-description+xml":{"source":"iana","compressible":true},"application/mbms-reception-report+xml":{"source":"iana","compressible":true},"application/mbms-register+xml":{"source":"iana","compressible":true},"application/mbms-register-response+xml":{"source":"iana","compressible":true},"application/mbms-schedule+xml":{"source":"iana","compressible":true},"application/mbms-user-service-description+xml":{"source":"iana","compressible":true},"application/mbox":{"source":"iana","extensions":["mbox"]},"application/media-policy-dataset+xml":{"source":"iana","compressible":true,"extensions":["mpf"]},"application/media_control+xml":{"source":"iana","compressible":true},"application/mediaservercontrol+xml":{"source":"iana","compressible":true,"extensions":["mscml"]},"application/merge-patch+json":{"source":"iana","compressible":true},"application/metalink+xml":{"source":"apache","compressible":true,"extensions":["metalink"]},"application/metalink4+xml":{"source":"iana","compressible":true,"extensions":["meta4"]},"application/mets+xml":{"source":"iana","compressible":true,"extensions":["mets"]},"application/mf4":{"source":"iana"},"application/mikey":{"source":"iana"},"application/mipc":{"source":"iana"},"application/missing-blocks+cbor-seq":{"source":"iana"},"application/mmt-aei+xml":{"source":"iana","compressible":true,"extensions":["maei"]},"application/mmt-usd+xml":{"source":"iana","compressible":true,"extensions":["musd"]},"application/mods+xml":{"source":"iana","compressible":true,"extensions":["mods"]},"application/moss-keys":{"source":"iana"},"application/moss-signature":{"source":"iana"},"application/mosskey-data":{"source":"iana"},"application/mosskey-request":{"source":"iana"},"application/mp21":{"source":"iana","extensions":["m21","mp21"]},"application/mp4":{"source":"iana","extensions":["mp4s","m4p"]},"application/mpeg4-generic":{"source":"iana"},"application/mpeg4-iod":{"source":"iana"},"application/mpeg4-iod-xmt":{"source":"iana"},"application/mrb-consumer+xml":{"source":"iana","compressible":true},"application/mrb-publish+xml":{"source":"iana","compressible":true},"application/msc-ivr+xml":{"source":"iana","charset":"UTF-8","compressible":true},"application/msc-mixer+xml":{"source":"iana","charset":"UTF-8","compressible":true},"application/msword":{"source":"iana","compressible":false,"extensions":["doc","dot"]},"application/mud+json":{"source":"iana","compressible":true},"application/multipart-core":{"source":"iana"},"application/mxf":{"source":"iana","extensions":["mxf"]},"application/n-quads":{"source":"iana","extensions":["nq"]},"application/n-triples":{"source":"iana","extensions":["nt"]},"application/nasdata":{"source":"iana"},"application/news-checkgroups":{"source":"iana","charset":"US-ASCII"},"application/news-groupinfo":{"source":"iana","charset":"US-ASCII"},"application/news-transmission":{"source":"iana"},"application/nlsml+xml":{"source":"iana","compressible":true},"application/node":{"source":"iana","extensions":["cjs"]},"application/nss":{"source":"iana"},"application/oauth-authz-req+jwt":{"source":"iana"},"application/oblivious-dns-message":{"source":"iana"},"application/ocsp-request":{"source":"iana"},"application/ocsp-response":{"source":"iana"},"application/octet-stream":{"source":"iana","compressible":false,"extensions":["bin","dms","lrf","mar","so","dist","distz","pkg","bpk","dump","elc","deploy","exe","dll","deb","dmg","iso","img","msi","msp","msm","buffer"]},"application/oda":{"source":"iana","extensions":["oda"]},"application/odm+xml":{"source":"iana","compressible":true},"application/odx":{"source":"iana"},"application/oebps-package+xml":{"source":"iana","compressible":true,"extensions":["opf"]},"application/ogg":{"source":"iana","compressible":false,"extensions":["ogx"]},"application/omdoc+xml":{"source":"apache","compressible":true,"extensions":["omdoc"]},"application/onenote":{"source":"apache","extensions":["onetoc","onetoc2","onetmp","onepkg"]},"application/opc-nodeset+xml":{"source":"iana","compressible":true},"application/oscore":{"source":"iana"},"application/oxps":{"source":"iana","extensions":["oxps"]},"application/p21":{"source":"iana"},"application/p21+zip":{"source":"iana","compressible":false},"application/p2p-overlay+xml":{"source":"iana","compressible":true,"extensions":["relo"]},"application/parityfec":{"source":"iana"},"application/passport":{"source":"iana"},"application/patch-ops-error+xml":{"source":"iana","compressible":true,"extensions":["xer"]},"application/pdf":{"source":"iana","compressible":false,"extensions":["pdf"]},"application/pdx":{"source":"iana"},"application/pem-certificate-chain":{"source":"iana"},"application/pgp-encrypted":{"source":"iana","compressible":false,"extensions":["pgp"]},"application/pgp-keys":{"source":"iana","extensions":["asc"]},"application/pgp-signature":{"source":"iana","extensions":["asc","sig"]},"application/pics-rules":{"source":"apache","extensions":["prf"]},"application/pidf+xml":{"source":"iana","charset":"UTF-8","compressible":true},"application/pidf-diff+xml":{"source":"iana","charset":"UTF-8","compressible":true},"application/pkcs10":{"source":"iana","extensions":["p10"]},"application/pkcs12":{"source":"iana"},"application/pkcs7-mime":{"source":"iana","extensions":["p7m","p7c"]},"application/pkcs7-signature":{"source":"iana","extensions":["p7s"]},"application/pkcs8":{"source":"iana","extensions":["p8"]},"application/pkcs8-encrypted":{"source":"iana"},"application/pkix-attr-cert":{"source":"iana","extensions":["ac"]},"application/pkix-cert":{"source":"iana","extensions":["cer"]},"application/pkix-crl":{"source":"iana","extensions":["crl"]},"application/pkix-pkipath":{"source":"iana","extensions":["pkipath"]},"application/pkixcmp":{"source":"iana","extensions":["pki"]},"application/pls+xml":{"source":"iana","compressible":true,"extensions":["pls"]},"application/poc-settings+xml":{"source":"iana","charset":"UTF-8","compressible":true},"application/postscript":{"source":"iana","compressible":true,"extensions":["ai","eps","ps"]},"application/ppsp-tracker+json":{"source":"iana","compressible":true},"application/problem+json":{"source":"iana","compressible":true},"application/problem+xml":{"source":"iana","compressible":true},"application/provenance+xml":{"source":"iana","compressible":true,"extensions":["provx"]},"application/prs.alvestrand.titrax-sheet":{"source":"iana"},"application/prs.cww":{"source":"iana","extensions":["cww"]},"application/prs.cyn":{"source":"iana","charset":"7-BIT"},"application/prs.hpub+zip":{"source":"iana","compressible":false},"application/prs.nprend":{"source":"iana"},"application/prs.plucker":{"source":"iana"},"application/prs.rdf-xml-crypt":{"source":"iana"},"application/prs.xsf+xml":{"source":"iana","compressible":true},"application/pskc+xml":{"source":"iana","compressible":true,"extensions":["pskcxml"]},"application/pvd+json":{"source":"iana","compressible":true},"application/qsig":{"source":"iana"},"application/raml+yaml":{"compressible":true,"extensions":["raml"]},"application/raptorfec":{"source":"iana"},"application/rdap+json":{"source":"iana","compressible":true},"application/rdf+xml":{"source":"iana","compressible":true,"extensions":["rdf","owl"]},"application/reginfo+xml":{"source":"iana","compressible":true,"extensions":["rif"]},"application/relax-ng-compact-syntax":{"source":"iana","extensions":["rnc"]},"application/remote-printing":{"source":"iana"},"application/reputon+json":{"source":"iana","compressible":true},"application/resource-lists+xml":{"source":"iana","compressible":true,"extensions":["rl"]},"application/resource-lists-diff+xml":{"source":"iana","compressible":true,"extensions":["rld"]},"application/rfc+xml":{"source":"iana","compressible":true},"application/riscos":{"source":"iana"},"application/rlmi+xml":{"source":"iana","compressible":true},"application/rls-services+xml":{"source":"iana","compressible":true,"extensions":["rs"]},"application/route-apd+xml":{"source":"iana","compressible":true,"extensions":["rapd"]},"application/route-s-tsid+xml":{"source":"iana","compressible":true,"extensions":["sls"]},"application/route-usd+xml":{"source":"iana","compressible":true,"extensions":["rusd"]},"application/rpki-ghostbusters":{"source":"iana","extensions":["gbr"]},"application/rpki-manifest":{"source":"iana","extensions":["mft"]},"application/rpki-publication":{"source":"iana"},"application/rpki-roa":{"source":"iana","extensions":["roa"]},"application/rpki-updown":{"source":"iana"},"application/rsd+xml":{"source":"apache","compressible":true,"extensions":["rsd"]},"application/rss+xml":{"source":"apache","compressible":true,"extensions":["rss"]},"application/rtf":{"source":"iana","compressible":true,"extensions":["rtf"]},"application/rtploopback":{"source":"iana"},"application/rtx":{"source":"iana"},"application/samlassertion+xml":{"source":"iana","compressible":true},"application/samlmetadata+xml":{"source":"iana","compressible":true},"application/sarif+json":{"source":"iana","compressible":true},"application/sarif-external-properties+json":{"source":"iana","compressible":true},"application/sbe":{"source":"iana"},"application/sbml+xml":{"source":"iana","compressible":true,"extensions":["sbml"]},"application/scaip+xml":{"source":"iana","compressible":true},"application/scim+json":{"source":"iana","compressible":true},"application/scvp-cv-request":{"source":"iana","extensions":["scq"]},"application/scvp-cv-response":{"source":"iana","extensions":["scs"]},"application/scvp-vp-request":{"source":"iana","extensions":["spq"]},"application/scvp-vp-response":{"source":"iana","extensions":["spp"]},"application/sdp":{"source":"iana","extensions":["sdp"]},"application/secevent+jwt":{"source":"iana"},"application/senml+cbor":{"source":"iana"},"application/senml+json":{"source":"iana","compressible":true},"application/senml+xml":{"source":"iana","compressible":true,"extensions":["senmlx"]},"application/senml-etch+cbor":{"source":"iana"},"application/senml-etch+json":{"source":"iana","compressible":true},"application/senml-exi":{"source":"iana"},"application/sensml+cbor":{"source":"iana"},"application/sensml+json":{"source":"iana","compressible":true},"application/sensml+xml":{"source":"iana","compressible":true,"extensions":["sensmlx"]},"application/sensml-exi":{"source":"iana"},"application/sep+xml":{"source":"iana","compressible":true},"application/sep-exi":{"source":"iana"},"application/session-info":{"source":"iana"},"application/set-payment":{"source":"iana"},"application/set-payment-initiation":{"source":"iana","extensions":["setpay"]},"application/set-registration":{"source":"iana"},"application/set-registration-initiation":{"source":"iana","extensions":["setreg"]},"application/sgml":{"source":"iana"},"application/sgml-open-catalog":{"source":"iana"},"application/shf+xml":{"source":"iana","compressible":true,"extensions":["shf"]},"application/sieve":{"source":"iana","extensions":["siv","sieve"]},"application/simple-filter+xml":{"source":"iana","compressible":true},"application/simple-message-summary":{"source":"iana"},"application/simplesymbolcontainer":{"source":"iana"},"application/sipc":{"source":"iana"},"application/slate":{"source":"iana"},"application/smil":{"source":"iana"},"application/smil+xml":{"source":"iana","compressible":true,"extensions":["smi","smil"]},"application/smpte336m":{"source":"iana"},"application/soap+fastinfoset":{"source":"iana"},"application/soap+xml":{"source":"iana","compressible":true},"application/sparql-query":{"source":"iana","extensions":["rq"]},"application/sparql-results+xml":{"source":"iana","compressible":true,"extensions":["srx"]},"application/spdx+json":{"source":"iana","compressible":true},"application/spirits-event+xml":{"source":"iana","compressible":true},"application/sql":{"source":"iana"},"application/srgs":{"source":"iana","extensions":["gram"]},"application/srgs+xml":{"source":"iana","compressible":true,"extensions":["grxml"]},"application/sru+xml":{"source":"iana","compressible":true,"extensions":["sru"]},"application/ssdl+xml":{"source":"apache","compressible":true,"extensions":["ssdl"]},"application/ssml+xml":{"source":"iana","compressible":true,"extensions":["ssml"]},"application/stix+json":{"source":"iana","compressible":true},"application/swid+xml":{"source":"iana","compressible":true,"extensions":["swidtag"]},"application/tamp-apex-update":{"source":"iana"},"application/tamp-apex-update-confirm":{"source":"iana"},"application/tamp-community-update":{"source":"iana"},"application/tamp-community-update-confirm":{"source":"iana"},"application/tamp-error":{"source":"iana"},"application/tamp-sequence-adjust":{"source":"iana"},"application/tamp-sequence-adjust-confirm":{"source":"iana"},"application/tamp-status-query":{"source":"iana"},"application/tamp-status-response":{"source":"iana"},"application/tamp-update":{"source":"iana"},"application/tamp-update-confirm":{"source":"iana"},"application/tar":{"compressible":true},"application/taxii+json":{"source":"iana","compressible":true},"application/td+json":{"source":"iana","compressible":true},"application/tei+xml":{"source":"iana","compressible":true,"extensions":["tei","teicorpus"]},"application/tetra_isi":{"source":"iana"},"application/thraud+xml":{"source":"iana","compressible":true,"extensions":["tfi"]},"application/timestamp-query":{"source":"iana"},"application/timestamp-reply":{"source":"iana"},"application/timestamped-data":{"source":"iana","extensions":["tsd"]},"application/tlsrpt+gzip":{"source":"iana"},"application/tlsrpt+json":{"source":"iana","compressible":true},"application/tnauthlist":{"source":"iana"},"application/token-introspection+jwt":{"source":"iana"},"application/toml":{"compressible":true,"extensions":["toml"]},"application/trickle-ice-sdpfrag":{"source":"iana"},"application/trig":{"source":"iana","extensions":["trig"]},"application/ttml+xml":{"source":"iana","compressible":true,"extensions":["ttml"]},"application/tve-trigger":{"source":"iana"},"application/tzif":{"source":"iana"},"application/tzif-leap":{"source":"iana"},"application/ubjson":{"compressible":false,"extensions":["ubj"]},"application/ulpfec":{"source":"iana"},"application/urc-grpsheet+xml":{"source":"iana","compressible":true},"application/urc-ressheet+xml":{"source":"iana","compressible":true,"extensions":["rsheet"]},"application/urc-targetdesc+xml":{"source":"iana","compressible":true,"extensions":["td"]},"application/urc-uisocketdesc+xml":{"source":"iana","compressible":true},"application/vcard+json":{"source":"iana","compressible":true},"application/vcard+xml":{"source":"iana","compressible":true},"application/vemmi":{"source":"iana"},"application/vividence.scriptfile":{"source":"apache"},"application/vnd.1000minds.decision-model+xml":{"source":"iana","compressible":true,"extensions":["1km"]},"application/vnd.3gpp-prose+xml":{"source":"iana","compressible":true},"application/vnd.3gpp-prose-pc3ch+xml":{"source":"iana","compressible":true},"application/vnd.3gpp-v2x-local-service-information":{"source":"iana"},"application/vnd.3gpp.5gnas":{"source":"iana"},"application/vnd.3gpp.access-transfer-events+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.bsf+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.gmop+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.gtpc":{"source":"iana"},"application/vnd.3gpp.interworking-data":{"source":"iana"},"application/vnd.3gpp.lpp":{"source":"iana"},"application/vnd.3gpp.mc-signalling-ear":{"source":"iana"},"application/vnd.3gpp.mcdata-affiliation-command+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.mcdata-info+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.mcdata-payload":{"source":"iana"},"application/vnd.3gpp.mcdata-service-config+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.mcdata-signalling":{"source":"iana"},"application/vnd.3gpp.mcdata-ue-config+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.mcdata-user-profile+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.mcptt-affiliation-command+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.mcptt-floor-request+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.mcptt-info+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.mcptt-location-info+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.mcptt-mbms-usage-info+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.mcptt-service-config+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.mcptt-signed+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.mcptt-ue-config+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.mcptt-ue-init-config+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.mcptt-user-profile+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.mcvideo-affiliation-command+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.mcvideo-affiliation-info+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.mcvideo-info+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.mcvideo-location-info+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.mcvideo-mbms-usage-info+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.mcvideo-service-config+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.mcvideo-transmission-request+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.mcvideo-ue-config+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.mcvideo-user-profile+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.mid-call+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.ngap":{"source":"iana"},"application/vnd.3gpp.pfcp":{"source":"iana"},"application/vnd.3gpp.pic-bw-large":{"source":"iana","extensions":["plb"]},"application/vnd.3gpp.pic-bw-small":{"source":"iana","extensions":["psb"]},"application/vnd.3gpp.pic-bw-var":{"source":"iana","extensions":["pvb"]},"application/vnd.3gpp.s1ap":{"source":"iana"},"application/vnd.3gpp.sms":{"source":"iana"},"application/vnd.3gpp.sms+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.srvcc-ext+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.srvcc-info+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.state-and-event-info+xml":{"source":"iana","compressible":true},"application/vnd.3gpp.ussd+xml":{"source":"iana","compressible":true},"application/vnd.3gpp2.bcmcsinfo+xml":{"source":"iana","compressible":true},"application/vnd.3gpp2.sms":{"source":"iana"},"application/vnd.3gpp2.tcap":{"source":"iana","extensions":["tcap"]},"application/vnd.3lightssoftware.imagescal":{"source":"iana"},"application/vnd.3m.post-it-notes":{"source":"iana","extensions":["pwn"]},"application/vnd.accpac.simply.aso":{"source":"iana","extensions":["aso"]},"application/vnd.accpac.simply.imp":{"source":"iana","extensions":["imp"]},"application/vnd.acucobol":{"source":"iana","extensions":["acu"]},"application/vnd.acucorp":{"source":"iana","extensions":["atc","acutc"]},"application/vnd.adobe.air-application-installer-package+zip":{"source":"apache","compressible":false,"extensions":["air"]},"application/vnd.adobe.flash.movie":{"source":"iana"},"application/vnd.adobe.formscentral.fcdt":{"source":"iana","extensions":["fcdt"]},"application/vnd.adobe.fxp":{"source":"iana","extensions":["fxp","fxpl"]},"application/vnd.adobe.partial-upload":{"source":"iana"},"application/vnd.adobe.xdp+xml":{"source":"iana","compressible":true,"extensions":["xdp"]},"application/vnd.adobe.xfdf":{"source":"iana","extensions":["xfdf"]},"application/vnd.aether.imp":{"source":"iana"},"application/vnd.afpc.afplinedata":{"source":"iana"},"application/vnd.afpc.afplinedata-pagedef":{"source":"iana"},"application/vnd.afpc.cmoca-cmresource":{"source":"iana"},"application/vnd.afpc.foca-charset":{"source":"iana"},"application/vnd.afpc.foca-codedfont":{"source":"iana"},"application/vnd.afpc.foca-codepage":{"source":"iana"},"application/vnd.afpc.modca":{"source":"iana"},"application/vnd.afpc.modca-cmtable":{"source":"iana"},"application/vnd.afpc.modca-formdef":{"source":"iana"},"application/vnd.afpc.modca-mediummap":{"source":"iana"},"application/vnd.afpc.modca-objectcontainer":{"source":"iana"},"application/vnd.afpc.modca-overlay":{"source":"iana"},"application/vnd.afpc.modca-pagesegment":{"source":"iana"},"application/vnd.age":{"source":"iana","extensions":["age"]},"application/vnd.ah-barcode":{"source":"iana"},"application/vnd.ahead.space":{"source":"iana","extensions":["ahead"]},"application/vnd.airzip.filesecure.azf":{"source":"iana","extensions":["azf"]},"application/vnd.airzip.filesecure.azs":{"source":"iana","extensions":["azs"]},"application/vnd.amadeus+json":{"source":"iana","compressible":true},"application/vnd.amazon.ebook":{"source":"apache","extensions":["azw"]},"application/vnd.amazon.mobi8-ebook":{"source":"iana"},"application/vnd.americandynamics.acc":{"source":"iana","extensions":["acc"]},"application/vnd.amiga.ami":{"source":"iana","extensions":["ami"]},"application/vnd.amundsen.maze+xml":{"source":"iana","compressible":true},"application/vnd.android.ota":{"source":"iana"},"application/vnd.android.package-archive":{"source":"apache","compressible":false,"extensions":["apk"]},"application/vnd.anki":{"source":"iana"},"application/vnd.anser-web-certificate-issue-initiation":{"source":"iana","extensions":["cii"]},"application/vnd.anser-web-funds-transfer-initiation":{"source":"apache","extensions":["fti"]},"application/vnd.antix.game-component":{"source":"iana","extensions":["atx"]},"application/vnd.apache.arrow.file":{"source":"iana"},"application/vnd.apache.arrow.stream":{"source":"iana"},"application/vnd.apache.thrift.binary":{"source":"iana"},"application/vnd.apache.thrift.compact":{"source":"iana"},"application/vnd.apache.thrift.json":{"source":"iana"},"application/vnd.api+json":{"source":"iana","compressible":true},"application/vnd.aplextor.warrp+json":{"source":"iana","compressible":true},"application/vnd.apothekende.reservation+json":{"source":"iana","compressible":true},"application/vnd.apple.installer+xml":{"source":"iana","compressible":true,"extensions":["mpkg"]},"application/vnd.apple.keynote":{"source":"iana","extensions":["key"]},"application/vnd.apple.mpegurl":{"source":"iana","extensions":["m3u8"]},"application/vnd.apple.numbers":{"source":"iana","extensions":["numbers"]},"application/vnd.apple.pages":{"source":"iana","extensions":["pages"]},"application/vnd.apple.pkpass":{"compressible":false,"extensions":["pkpass"]},"application/vnd.arastra.swi":{"source":"iana"},"application/vnd.aristanetworks.swi":{"source":"iana","extensions":["swi"]},"application/vnd.artisan+json":{"source":"iana","compressible":true},"application/vnd.artsquare":{"source":"iana"},"application/vnd.astraea-software.iota":{"source":"iana","extensions":["iota"]},"application/vnd.audiograph":{"source":"iana","extensions":["aep"]},"application/vnd.autopackage":{"source":"iana"},"application/vnd.avalon+json":{"source":"iana","compressible":true},"application/vnd.avistar+xml":{"source":"iana","compressible":true},"application/vnd.balsamiq.bmml+xml":{"source":"iana","compressible":true,"extensions":["bmml"]},"application/vnd.balsamiq.bmpr":{"source":"iana"},"application/vnd.banana-accounting":{"source":"iana"},"application/vnd.bbf.usp.error":{"source":"iana"},"application/vnd.bbf.usp.msg":{"source":"iana"},"application/vnd.bbf.usp.msg+json":{"source":"iana","compressible":true},"application/vnd.bekitzur-stech+json":{"source":"iana","compressible":true},"application/vnd.bint.med-content":{"source":"iana"},"application/vnd.biopax.rdf+xml":{"source":"iana","compressible":true},"application/vnd.blink-idb-value-wrapper":{"source":"iana"},"application/vnd.blueice.multipass":{"source":"iana","extensions":["mpm"]},"application/vnd.bluetooth.ep.oob":{"source":"iana"},"application/vnd.bluetooth.le.oob":{"source":"iana"},"application/vnd.bmi":{"source":"iana","extensions":["bmi"]},"application/vnd.bpf":{"source":"iana"},"application/vnd.bpf3":{"source":"iana"},"application/vnd.businessobjects":{"source":"iana","extensions":["rep"]},"application/vnd.byu.uapi+json":{"source":"iana","compressible":true},"application/vnd.cab-jscript":{"source":"iana"},"application/vnd.canon-cpdl":{"source":"iana"},"application/vnd.canon-lips":{"source":"iana"},"application/vnd.capasystems-pg+json":{"source":"iana","compressible":true},"application/vnd.cendio.thinlinc.clientconf":{"source":"iana"},"application/vnd.century-systems.tcp_stream":{"source":"iana"},"application/vnd.chemdraw+xml":{"source":"iana","compressible":true,"extensions":["cdxml"]},"application/vnd.chess-pgn":{"source":"iana"},"application/vnd.chipnuts.karaoke-mmd":{"source":"iana","extensions":["mmd"]},"application/vnd.ciedi":{"source":"iana"},"application/vnd.cinderella":{"source":"iana","extensions":["cdy"]},"application/vnd.cirpack.isdn-ext":{"source":"iana"},"application/vnd.citationstyles.style+xml":{"source":"iana","compressible":true,"extensions":["csl"]},"application/vnd.claymore":{"source":"iana","extensions":["cla"]},"application/vnd.cloanto.rp9":{"source":"iana","extensions":["rp9"]},"application/vnd.clonk.c4group":{"source":"iana","extensions":["c4g","c4d","c4f","c4p","c4u"]},"application/vnd.cluetrust.cartomobile-config":{"source":"iana","extensions":["c11amc"]},"application/vnd.cluetrust.cartomobile-config-pkg":{"source":"iana","extensions":["c11amz"]},"application/vnd.coffeescript":{"source":"iana"},"application/vnd.collabio.xodocuments.document":{"source":"iana"},"application/vnd.collabio.xodocuments.document-template":{"source":"iana"},"application/vnd.collabio.xodocuments.presentation":{"source":"iana"},"application/vnd.collabio.xodocuments.presentation-template":{"source":"iana"},"application/vnd.collabio.xodocuments.spreadsheet":{"source":"iana"},"application/vnd.collabio.xodocuments.spreadsheet-template":{"source":"iana"},"application/vnd.collection+json":{"source":"iana","compressible":true},"application/vnd.collection.doc+json":{"source":"iana","compressible":true},"application/vnd.collection.next+json":{"source":"iana","compressible":true},"application/vnd.comicbook+zip":{"source":"iana","compressible":false},"application/vnd.comicbook-rar":{"source":"iana"},"application/vnd.commerce-battelle":{"source":"iana"},"application/vnd.commonspace":{"source":"iana","extensions":["csp"]},"application/vnd.contact.cmsg":{"source":"iana","extensions":["cdbcmsg"]},"application/vnd.coreos.ignition+json":{"source":"iana","compressible":true},"application/vnd.cosmocaller":{"source":"iana","extensions":["cmc"]},"application/vnd.crick.clicker":{"source":"iana","extensions":["clkx"]},"application/vnd.crick.clicker.keyboard":{"source":"iana","extensions":["clkk"]},"application/vnd.crick.clicker.palette":{"source":"iana","extensions":["clkp"]},"application/vnd.crick.clicker.template":{"source":"iana","extensions":["clkt"]},"application/vnd.crick.clicker.wordbank":{"source":"iana","extensions":["clkw"]},"application/vnd.criticaltools.wbs+xml":{"source":"iana","compressible":true,"extensions":["wbs"]},"application/vnd.cryptii.pipe+json":{"source":"iana","compressible":true},"application/vnd.crypto-shade-file":{"source":"iana"},"application/vnd.cryptomator.encrypted":{"source":"iana"},"application/vnd.cryptomator.vault":{"source":"iana"},"application/vnd.ctc-posml":{"source":"iana","extensions":["pml"]},"application/vnd.ctct.ws+xml":{"source":"iana","compressible":true},"application/vnd.cups-pdf":{"source":"iana"},"application/vnd.cups-postscript":{"source":"iana"},"application/vnd.cups-ppd":{"source":"iana","extensions":["ppd"]},"application/vnd.cups-raster":{"source":"iana"},"application/vnd.cups-raw":{"source":"iana"},"application/vnd.curl":{"source":"iana"},"application/vnd.curl.car":{"source":"apache","extensions":["car"]},"application/vnd.curl.pcurl":{"source":"apache","extensions":["pcurl"]},"application/vnd.cyan.dean.root+xml":{"source":"iana","compressible":true},"application/vnd.cybank":{"source":"iana"},"application/vnd.cyclonedx+json":{"source":"iana","compressible":true},"application/vnd.cyclonedx+xml":{"source":"iana","compressible":true},"application/vnd.d2l.coursepackage1p0+zip":{"source":"iana","compressible":false},"application/vnd.d3m-dataset":{"source":"iana"},"application/vnd.d3m-problem":{"source":"iana"},"application/vnd.dart":{"source":"iana","compressible":true,"extensions":["dart"]},"application/vnd.data-vision.rdz":{"source":"iana","extensions":["rdz"]},"application/vnd.datapackage+json":{"source":"iana","compressible":true},"application/vnd.dataresource+json":{"source":"iana","compressible":true},"application/vnd.dbf":{"source":"iana","extensions":["dbf"]},"application/vnd.debian.binary-package":{"source":"iana"},"application/vnd.dece.data":{"source":"iana","extensions":["uvf","uvvf","uvd","uvvd"]},"application/vnd.dece.ttml+xml":{"source":"iana","compressible":true,"extensions":["uvt","uvvt"]},"application/vnd.dece.unspecified":{"source":"iana","extensions":["uvx","uvvx"]},"application/vnd.dece.zip":{"source":"iana","extensions":["uvz","uvvz"]},"application/vnd.denovo.fcselayout-link":{"source":"iana","extensions":["fe_launch"]},"application/vnd.desmume.movie":{"source":"iana"},"application/vnd.dir-bi.plate-dl-nosuffix":{"source":"iana"},"application/vnd.dm.delegation+xml":{"source":"iana","compressible":true},"application/vnd.dna":{"source":"iana","extensions":["dna"]},"application/vnd.document+json":{"source":"iana","compressible":true},"application/vnd.dolby.mlp":{"source":"apache","extensions":["mlp"]},"application/vnd.dolby.mobile.1":{"source":"iana"},"application/vnd.dolby.mobile.2":{"source":"iana"},"application/vnd.doremir.scorecloud-binary-document":{"source":"iana"},"application/vnd.dpgraph":{"source":"iana","extensions":["dpg"]},"application/vnd.dreamfactory":{"source":"iana","extensions":["dfac"]},"application/vnd.drive+json":{"source":"iana","compressible":true},"application/vnd.ds-keypoint":{"source":"apache","extensions":["kpxx"]},"application/vnd.dtg.local":{"source":"iana"},"application/vnd.dtg.local.flash":{"source":"iana"},"application/vnd.dtg.local.html":{"source":"iana"},"application/vnd.dvb.ait":{"source":"iana","extensions":["ait"]},"application/vnd.dvb.dvbisl+xml":{"source":"iana","compressible":true},"application/vnd.dvb.dvbj":{"source":"iana"},"application/vnd.dvb.esgcontainer":{"source":"iana"},"application/vnd.dvb.ipdcdftnotifaccess":{"source":"iana"},"application/vnd.dvb.ipdcesgaccess":{"source":"iana"},"application/vnd.dvb.ipdcesgaccess2":{"source":"iana"},"application/vnd.dvb.ipdcesgpdd":{"source":"iana"},"application/vnd.dvb.ipdcroaming":{"source":"iana"},"application/vnd.dvb.iptv.alfec-base":{"source":"iana"},"application/vnd.dvb.iptv.alfec-enhancement":{"source":"iana"},"application/vnd.dvb.notif-aggregate-root+xml":{"source":"iana","compressible":true},"application/vnd.dvb.notif-container+xml":{"source":"iana","compressible":true},"application/vnd.dvb.notif-generic+xml":{"source":"iana","compressible":true},"application/vnd.dvb.notif-ia-msglist+xml":{"source":"iana","compressible":true},"application/vnd.dvb.notif-ia-registration-request+xml":{"source":"iana","compressible":true},"application/vnd.dvb.notif-ia-registration-response+xml":{"source":"iana","compressible":true},"application/vnd.dvb.notif-init+xml":{"source":"iana","compressible":true},"application/vnd.dvb.pfr":{"source":"iana"},"application/vnd.dvb.service":{"source":"iana","extensions":["svc"]},"application/vnd.dxr":{"source":"iana"},"application/vnd.dynageo":{"source":"iana","extensions":["geo"]},"application/vnd.dzr":{"source":"iana"},"application/vnd.easykaraoke.cdgdownload":{"source":"iana"},"application/vnd.ecdis-update":{"source":"iana"},"application/vnd.ecip.rlp":{"source":"iana"},"application/vnd.eclipse.ditto+json":{"source":"iana","compressible":true},"application/vnd.ecowin.chart":{"source":"iana","extensions":["mag"]},"application/vnd.ecowin.filerequest":{"source":"iana"},"application/vnd.ecowin.fileupdate":{"source":"iana"},"application/vnd.ecowin.series":{"source":"iana"},"application/vnd.ecowin.seriesrequest":{"source":"iana"},"application/vnd.ecowin.seriesupdate":{"source":"iana"},"application/vnd.efi.img":{"source":"iana"},"application/vnd.efi.iso":{"source":"iana"},"application/vnd.emclient.accessrequest+xml":{"source":"iana","compressible":true},"application/vnd.enliven":{"source":"iana","extensions":["nml"]},"application/vnd.enphase.envoy":{"source":"iana"},"application/vnd.eprints.data+xml":{"source":"iana","compressible":true},"application/vnd.epson.esf":{"source":"iana","extensions":["esf"]},"application/vnd.epson.msf":{"source":"iana","extensions":["msf"]},"application/vnd.epson.quickanime":{"source":"iana","extensions":["qam"]},"application/vnd.epson.salt":{"source":"iana","extensions":["slt"]},"application/vnd.epson.ssf":{"source":"iana","extensions":["ssf"]},"application/vnd.ericsson.quickcall":{"source":"iana"},"application/vnd.espass-espass+zip":{"source":"iana","compressible":false},"application/vnd.eszigno3+xml":{"source":"iana","compressible":true,"extensions":["es3","et3"]},"application/vnd.etsi.aoc+xml":{"source":"iana","compressible":true},"application/vnd.etsi.asic-e+zip":{"source":"iana","compressible":false},"application/vnd.etsi.asic-s+zip":{"source":"iana","compressible":false},"application/vnd.etsi.cug+xml":{"source":"iana","compressible":true},"application/vnd.etsi.iptvcommand+xml":{"source":"iana","compressible":true},"application/vnd.etsi.iptvdiscovery+xml":{"source":"iana","compressible":true},"application/vnd.etsi.iptvprofile+xml":{"source":"iana","compressible":true},"application/vnd.etsi.iptvsad-bc+xml":{"source":"iana","compressible":true},"application/vnd.etsi.iptvsad-cod+xml":{"source":"iana","compressible":true},"application/vnd.etsi.iptvsad-npvr+xml":{"source":"iana","compressible":true},"application/vnd.etsi.iptvservice+xml":{"source":"iana","compressible":true},"application/vnd.etsi.iptvsync+xml":{"source":"iana","compressible":true},"application/vnd.etsi.iptvueprofile+xml":{"source":"iana","compressible":true},"application/vnd.etsi.mcid+xml":{"source":"iana","compressible":true},"application/vnd.etsi.mheg5":{"source":"iana"},"application/vnd.etsi.overload-control-policy-dataset+xml":{"source":"iana","compressible":true},"application/vnd.etsi.pstn+xml":{"source":"iana","compressible":true},"application/vnd.etsi.sci+xml":{"source":"iana","compressible":true},"application/vnd.etsi.simservs+xml":{"source":"iana","compressible":true},"application/vnd.etsi.timestamp-token":{"source":"iana"},"application/vnd.etsi.tsl+xml":{"source":"iana","compressible":true},"application/vnd.etsi.tsl.der":{"source":"iana"},"application/vnd.eu.kasparian.car+json":{"source":"iana","compressible":true},"application/vnd.eudora.data":{"source":"iana"},"application/vnd.evolv.ecig.profile":{"source":"iana"},"application/vnd.evolv.ecig.settings":{"source":"iana"},"application/vnd.evolv.ecig.theme":{"source":"iana"},"application/vnd.exstream-empower+zip":{"source":"iana","compressible":false},"application/vnd.exstream-package":{"source":"iana"},"application/vnd.ezpix-album":{"source":"iana","extensions":["ez2"]},"application/vnd.ezpix-package":{"source":"iana","extensions":["ez3"]},"application/vnd.f-secure.mobile":{"source":"iana"},"application/vnd.familysearch.gedcom+zip":{"source":"iana","compressible":false},"application/vnd.fastcopy-disk-image":{"source":"iana"},"application/vnd.fdf":{"source":"iana","extensions":["fdf"]},"application/vnd.fdsn.mseed":{"source":"iana","extensions":["mseed"]},"application/vnd.fdsn.seed":{"source":"iana","extensions":["seed","dataless"]},"application/vnd.ffsns":{"source":"iana"},"application/vnd.ficlab.flb+zip":{"source":"iana","compressible":false},"application/vnd.filmit.zfc":{"source":"iana"},"application/vnd.fints":{"source":"iana"},"application/vnd.firemonkeys.cloudcell":{"source":"iana"},"application/vnd.flographit":{"source":"iana","extensions":["gph"]},"application/vnd.fluxtime.clip":{"source":"iana","extensions":["ftc"]},"application/vnd.font-fontforge-sfd":{"source":"iana"},"application/vnd.framemaker":{"source":"iana","extensions":["fm","frame","maker","book"]},"application/vnd.frogans.fnc":{"source":"iana","extensions":["fnc"]},"application/vnd.frogans.ltf":{"source":"iana","extensions":["ltf"]},"application/vnd.fsc.weblaunch":{"source":"iana","extensions":["fsc"]},"application/vnd.fujifilm.fb.docuworks":{"source":"iana"},"application/vnd.fujifilm.fb.docuworks.binder":{"source":"iana"},"application/vnd.fujifilm.fb.docuworks.container":{"source":"iana"},"application/vnd.fujifilm.fb.jfi+xml":{"source":"iana","compressible":true},"application/vnd.fujitsu.oasys":{"source":"iana","extensions":["oas"]},"application/vnd.fujitsu.oasys2":{"source":"iana","extensions":["oa2"]},"application/vnd.fujitsu.oasys3":{"source":"iana","extensions":["oa3"]},"application/vnd.fujitsu.oasysgp":{"source":"iana","extensions":["fg5"]},"application/vnd.fujitsu.oasysprs":{"source":"iana","extensions":["bh2"]},"application/vnd.fujixerox.art-ex":{"source":"iana"},"application/vnd.fujixerox.art4":{"source":"iana"},"application/vnd.fujixerox.ddd":{"source":"iana","extensions":["ddd"]},"application/vnd.fujixerox.docuworks":{"source":"iana","extensions":["xdw"]},"application/vnd.fujixerox.docuworks.binder":{"source":"iana","extensions":["xbd"]},"application/vnd.fujixerox.docuworks.container":{"source":"iana"},"application/vnd.fujixerox.hbpl":{"source":"iana"},"application/vnd.fut-misnet":{"source":"iana"},"application/vnd.futoin+cbor":{"source":"iana"},"application/vnd.futoin+json":{"source":"iana","compressible":true},"application/vnd.fuzzysheet":{"source":"iana","extensions":["fzs"]},"application/vnd.genomatix.tuxedo":{"source":"iana","extensions":["txd"]},"application/vnd.gentics.grd+json":{"source":"iana","compressible":true},"application/vnd.geo+json":{"source":"iana","compressible":true},"application/vnd.geocube+xml":{"source":"iana","compressible":true},"application/vnd.geogebra.file":{"source":"iana","extensions":["ggb"]},"application/vnd.geogebra.slides":{"source":"iana"},"application/vnd.geogebra.tool":{"source":"iana","extensions":["ggt"]},"application/vnd.geometry-explorer":{"source":"iana","extensions":["gex","gre"]},"application/vnd.geonext":{"source":"iana","extensions":["gxt"]},"application/vnd.geoplan":{"source":"iana","extensions":["g2w"]},"application/vnd.geospace":{"source":"iana","extensions":["g3w"]},"application/vnd.gerber":{"source":"iana"},"application/vnd.globalplatform.card-content-mgt":{"source":"iana"},"application/vnd.globalplatform.card-content-mgt-response":{"source":"iana"},"application/vnd.gmx":{"source":"iana","extensions":["gmx"]},"application/vnd.google-apps.document":{"compressible":false,"extensions":["gdoc"]},"application/vnd.google-apps.presentation":{"compressible":false,"extensions":["gslides"]},"application/vnd.google-apps.spreadsheet":{"compressible":false,"extensions":["gsheet"]},"application/vnd.google-earth.kml+xml":{"source":"iana","compressible":true,"extensions":["kml"]},"application/vnd.google-earth.kmz":{"source":"iana","compressible":false,"extensions":["kmz"]},"application/vnd.gov.sk.e-form+xml":{"source":"iana","compressible":true},"application/vnd.gov.sk.e-form+zip":{"source":"iana","compressible":false},"application/vnd.gov.sk.xmldatacontainer+xml":{"source":"iana","compressible":true},"application/vnd.grafeq":{"source":"iana","extensions":["gqf","gqs"]},"application/vnd.gridmp":{"source":"iana"},"application/vnd.groove-account":{"source":"iana","extensions":["gac"]},"application/vnd.groove-help":{"source":"iana","extensions":["ghf"]},"application/vnd.groove-identity-message":{"source":"iana","extensions":["gim"]},"application/vnd.groove-injector":{"source":"iana","extensions":["grv"]},"application/vnd.groove-tool-message":{"source":"iana","extensions":["gtm"]},"application/vnd.groove-tool-template":{"source":"iana","extensions":["tpl"]},"application/vnd.groove-vcard":{"source":"iana","extensions":["vcg"]},"application/vnd.hal+json":{"source":"iana","compressible":true},"application/vnd.hal+xml":{"source":"iana","compressible":true,"extensions":["hal"]},"application/vnd.handheld-entertainment+xml":{"source":"iana","compressible":true,"extensions":["zmm"]},"application/vnd.hbci":{"source":"iana","extensions":["hbci"]},"application/vnd.hc+json":{"source":"iana","compressible":true},"application/vnd.hcl-bireports":{"source":"iana"},"application/vnd.hdt":{"source":"iana"},"application/vnd.heroku+json":{"source":"iana","compressible":true},"application/vnd.hhe.lesson-player":{"source":"iana","extensions":["les"]},"application/vnd.hl7cda+xml":{"source":"iana","charset":"UTF-8","compressible":true},"application/vnd.hl7v2+xml":{"source":"iana","charset":"UTF-8","compressible":true},"application/vnd.hp-hpgl":{"source":"iana","extensions":["hpgl"]},"application/vnd.hp-hpid":{"source":"iana","extensions":["hpid"]},"application/vnd.hp-hps":{"source":"iana","extensions":["hps"]},"application/vnd.hp-jlyt":{"source":"iana","extensions":["jlt"]},"application/vnd.hp-pcl":{"source":"iana","extensions":["pcl"]},"application/vnd.hp-pclxl":{"source":"iana","extensions":["pclxl"]},"application/vnd.httphone":{"source":"iana"},"application/vnd.hydrostatix.sof-data":{"source":"iana","extensions":["sfd-hdstx"]},"application/vnd.hyper+json":{"source":"iana","compressible":true},"application/vnd.hyper-item+json":{"source":"iana","compressible":true},"application/vnd.hyperdrive+json":{"source":"iana","compressible":true},"application/vnd.hzn-3d-crossword":{"source":"iana"},"application/vnd.ibm.afplinedata":{"source":"iana"},"application/vnd.ibm.electronic-media":{"source":"iana"},"application/vnd.ibm.minipay":{"source":"iana","extensions":["mpy"]},"application/vnd.ibm.modcap":{"source":"iana","extensions":["afp","listafp","list3820"]},"application/vnd.ibm.rights-management":{"source":"iana","extensions":["irm"]},"application/vnd.ibm.secure-container":{"source":"iana","extensions":["sc"]},"application/vnd.iccprofile":{"source":"iana","extensions":["icc","icm"]},"application/vnd.ieee.1905":{"source":"iana"},"application/vnd.igloader":{"source":"iana","extensions":["igl"]},"application/vnd.imagemeter.folder+zip":{"source":"iana","compressible":false},"application/vnd.imagemeter.image+zip":{"source":"iana","compressible":false},"application/vnd.immervision-ivp":{"source":"iana","extensions":["ivp"]},"application/vnd.immervision-ivu":{"source":"iana","extensions":["ivu"]},"application/vnd.ims.imsccv1p1":{"source":"iana"},"application/vnd.ims.imsccv1p2":{"source":"iana"},"application/vnd.ims.imsccv1p3":{"source":"iana"},"application/vnd.ims.lis.v2.result+json":{"source":"iana","compressible":true},"application/vnd.ims.lti.v2.toolconsumerprofile+json":{"source":"iana","compressible":true},"application/vnd.ims.lti.v2.toolproxy+json":{"source":"iana","compressible":true},"application/vnd.ims.lti.v2.toolproxy.id+json":{"source":"iana","compressible":true},"application/vnd.ims.lti.v2.toolsettings+json":{"source":"iana","compressible":true},"application/vnd.ims.lti.v2.toolsettings.simple+json":{"source":"iana","compressible":true},"application/vnd.informedcontrol.rms+xml":{"source":"iana","compressible":true},"application/vnd.informix-visionary":{"source":"iana"},"application/vnd.infotech.project":{"source":"iana"},"application/vnd.infotech.project+xml":{"source":"iana","compressible":true},"application/vnd.innopath.wamp.notification":{"source":"iana"},"application/vnd.insors.igm":{"source":"iana","extensions":["igm"]},"application/vnd.intercon.formnet":{"source":"iana","extensions":["xpw","xpx"]},"application/vnd.intergeo":{"source":"iana","extensions":["i2g"]},"application/vnd.intertrust.digibox":{"source":"iana"},"application/vnd.intertrust.nncp":{"source":"iana"},"application/vnd.intu.qbo":{"source":"iana","extensions":["qbo"]},"application/vnd.intu.qfx":{"source":"iana","extensions":["qfx"]},"application/vnd.iptc.g2.catalogitem+xml":{"source":"iana","compressible":true},"application/vnd.iptc.g2.conceptitem+xml":{"source":"iana","compressible":true},"application/vnd.iptc.g2.knowledgeitem+xml":{"source":"iana","compressible":true},"application/vnd.iptc.g2.newsitem+xml":{"source":"iana","compressible":true},"application/vnd.iptc.g2.newsmessage+xml":{"source":"iana","compressible":true},"application/vnd.iptc.g2.packageitem+xml":{"source":"iana","compressible":true},"application/vnd.iptc.g2.planningitem+xml":{"source":"iana","compressible":true},"application/vnd.ipunplugged.rcprofile":{"source":"iana","extensions":["rcprofile"]},"application/vnd.irepository.package+xml":{"source":"iana","compressible":true,"extensions":["irp"]},"application/vnd.is-xpr":{"source":"iana","extensions":["xpr"]},"application/vnd.isac.fcs":{"source":"iana","extensions":["fcs"]},"application/vnd.iso11783-10+zip":{"source":"iana","compressible":false},"application/vnd.jam":{"source":"iana","extensions":["jam"]},"application/vnd.japannet-directory-service":{"source":"iana"},"application/vnd.japannet-jpnstore-wakeup":{"source":"iana"},"application/vnd.japannet-payment-wakeup":{"source":"iana"},"application/vnd.japannet-registration":{"source":"iana"},"application/vnd.japannet-registration-wakeup":{"source":"iana"},"application/vnd.japannet-setstore-wakeup":{"source":"iana"},"application/vnd.japannet-verification":{"source":"iana"},"application/vnd.japannet-verification-wakeup":{"source":"iana"},"application/vnd.jcp.javame.midlet-rms":{"source":"iana","extensions":["rms"]},"application/vnd.jisp":{"source":"iana","extensions":["jisp"]},"application/vnd.joost.joda-archive":{"source":"iana","extensions":["joda"]},"application/vnd.jsk.isdn-ngn":{"source":"iana"},"application/vnd.kahootz":{"source":"iana","extensions":["ktz","ktr"]},"application/vnd.kde.karbon":{"source":"iana","extensions":["karbon"]},"application/vnd.kde.kchart":{"source":"iana","extensions":["chrt"]},"application/vnd.kde.kformula":{"source":"iana","extensions":["kfo"]},"application/vnd.kde.kivio":{"source":"iana","extensions":["flw"]},"application/vnd.kde.kontour":{"source":"iana","extensions":["kon"]},"application/vnd.kde.kpresenter":{"source":"iana","extensions":["kpr","kpt"]},"application/vnd.kde.kspread":{"source":"iana","extensions":["ksp"]},"application/vnd.kde.kword":{"source":"iana","extensions":["kwd","kwt"]},"application/vnd.kenameaapp":{"source":"iana","extensions":["htke"]},"application/vnd.kidspiration":{"source":"iana","extensions":["kia"]},"application/vnd.kinar":{"source":"iana","extensions":["kne","knp"]},"application/vnd.koan":{"source":"iana","extensions":["skp","skd","skt","skm"]},"application/vnd.kodak-descriptor":{"source":"iana","extensions":["sse"]},"application/vnd.las":{"source":"iana"},"application/vnd.las.las+json":{"source":"iana","compressible":true},"application/vnd.las.las+xml":{"source":"iana","compressible":true,"extensions":["lasxml"]},"application/vnd.laszip":{"source":"iana"},"application/vnd.leap+json":{"source":"iana","compressible":true},"application/vnd.liberty-request+xml":{"source":"iana","compressible":true},"application/vnd.llamagraphics.life-balance.desktop":{"source":"iana","extensions":["lbd"]},"application/vnd.llamagraphics.life-balance.exchange+xml":{"source":"iana","compressible":true,"extensions":["lbe"]},"application/vnd.logipipe.circuit+zip":{"source":"iana","compressible":false},"application/vnd.loom":{"source":"iana"},"application/vnd.lotus-1-2-3":{"source":"iana","extensions":["123"]},"application/vnd.lotus-approach":{"source":"iana","extensions":["apr"]},"application/vnd.lotus-freelance":{"source":"iana","extensions":["pre"]},"application/vnd.lotus-notes":{"source":"iana","extensions":["nsf"]},"application/vnd.lotus-organizer":{"source":"iana","extensions":["org"]},"application/vnd.lotus-screencam":{"source":"iana","extensions":["scm"]},"application/vnd.lotus-wordpro":{"source":"iana","extensions":["lwp"]},"application/vnd.macports.portpkg":{"source":"iana","extensions":["portpkg"]},"application/vnd.mapbox-vector-tile":{"source":"iana","extensions":["mvt"]},"application/vnd.marlin.drm.actiontoken+xml":{"source":"iana","compressible":true},"application/vnd.marlin.drm.conftoken+xml":{"source":"iana","compressible":true},"application/vnd.marlin.drm.license+xml":{"source":"iana","compressible":true},"application/vnd.marlin.drm.mdcf":{"source":"iana"},"application/vnd.mason+json":{"source":"iana","compressible":true},"application/vnd.maxar.archive.3tz+zip":{"source":"iana","compressible":false},"application/vnd.maxmind.maxmind-db":{"source":"iana"},"application/vnd.mcd":{"source":"iana","extensions":["mcd"]},"application/vnd.medcalcdata":{"source":"iana","extensions":["mc1"]},"application/vnd.mediastation.cdkey":{"source":"iana","extensions":["cdkey"]},"application/vnd.meridian-slingshot":{"source":"iana"},"application/vnd.mfer":{"source":"iana","extensions":["mwf"]},"application/vnd.mfmp":{"source":"iana","extensions":["mfm"]},"application/vnd.micro+json":{"source":"iana","compressible":true},"application/vnd.micrografx.flo":{"source":"iana","extensions":["flo"]},"application/vnd.micrografx.igx":{"source":"iana","extensions":["igx"]},"application/vnd.microsoft.portable-executable":{"source":"iana"},"application/vnd.microsoft.windows.thumbnail-cache":{"source":"iana"},"application/vnd.miele+json":{"source":"iana","compressible":true},"application/vnd.mif":{"source":"iana","extensions":["mif"]},"application/vnd.minisoft-hp3000-save":{"source":"iana"},"application/vnd.mitsubishi.misty-guard.trustweb":{"source":"iana"},"application/vnd.mobius.daf":{"source":"iana","extensions":["daf"]},"application/vnd.mobius.dis":{"source":"iana","extensions":["dis"]},"application/vnd.mobius.mbk":{"source":"iana","extensions":["mbk"]},"application/vnd.mobius.mqy":{"source":"iana","extensions":["mqy"]},"application/vnd.mobius.msl":{"source":"iana","extensions":["msl"]},"application/vnd.mobius.plc":{"source":"iana","extensions":["plc"]},"application/vnd.mobius.txf":{"source":"iana","extensions":["txf"]},"application/vnd.mophun.application":{"source":"iana","extensions":["mpn"]},"application/vnd.mophun.certificate":{"source":"iana","extensions":["mpc"]},"application/vnd.motorola.flexsuite":{"source":"iana"},"application/vnd.motorola.flexsuite.adsi":{"source":"iana"},"application/vnd.motorola.flexsuite.fis":{"source":"iana"},"application/vnd.motorola.flexsuite.gotap":{"source":"iana"},"application/vnd.motorola.flexsuite.kmr":{"source":"iana"},"application/vnd.motorola.flexsuite.ttc":{"source":"iana"},"application/vnd.motorola.flexsuite.wem":{"source":"iana"},"application/vnd.motorola.iprm":{"source":"iana"},"application/vnd.mozilla.xul+xml":{"source":"iana","compressible":true,"extensions":["xul"]},"application/vnd.ms-3mfdocument":{"source":"iana"},"application/vnd.ms-artgalry":{"source":"iana","extensions":["cil"]},"application/vnd.ms-asf":{"source":"iana"},"application/vnd.ms-cab-compressed":{"source":"iana","extensions":["cab"]},"application/vnd.ms-color.iccprofile":{"source":"apache"},"application/vnd.ms-excel":{"source":"iana","compressible":false,"extensions":["xls","xlm","xla","xlc","xlt","xlw"]},"application/vnd.ms-excel.addin.macroenabled.12":{"source":"iana","extensions":["xlam"]},"application/vnd.ms-excel.sheet.binary.macroenabled.12":{"source":"iana","extensions":["xlsb"]},"application/vnd.ms-excel.sheet.macroenabled.12":{"source":"iana","extensions":["xlsm"]},"application/vnd.ms-excel.template.macroenabled.12":{"source":"iana","extensions":["xltm"]},"application/vnd.ms-fontobject":{"source":"iana","compressible":true,"extensions":["eot"]},"application/vnd.ms-htmlhelp":{"source":"iana","extensions":["chm"]},"application/vnd.ms-ims":{"source":"iana","extensions":["ims"]},"application/vnd.ms-lrm":{"source":"iana","extensions":["lrm"]},"application/vnd.ms-office.activex+xml":{"source":"iana","compressible":true},"application/vnd.ms-officetheme":{"source":"iana","extensions":["thmx"]},"application/vnd.ms-opentype":{"source":"apache","compressible":true},"application/vnd.ms-outlook":{"compressible":false,"extensions":["msg"]},"application/vnd.ms-package.obfuscated-opentype":{"source":"apache"},"application/vnd.ms-pki.seccat":{"source":"apache","extensions":["cat"]},"application/vnd.ms-pki.stl":{"source":"apache","extensions":["stl"]},"application/vnd.ms-playready.initiator+xml":{"source":"iana","compressible":true},"application/vnd.ms-powerpoint":{"source":"iana","compressible":false,"extensions":["ppt","pps","pot"]},"application/vnd.ms-powerpoint.addin.macroenabled.12":{"source":"iana","extensions":["ppam"]},"application/vnd.ms-powerpoint.presentation.macroenabled.12":{"source":"iana","extensions":["pptm"]},"application/vnd.ms-powerpoint.slide.macroenabled.12":{"source":"iana","extensions":["sldm"]},"application/vnd.ms-powerpoint.slideshow.macroenabled.12":{"source":"iana","extensions":["ppsm"]},"application/vnd.ms-powerpoint.template.macroenabled.12":{"source":"iana","extensions":["potm"]},"application/vnd.ms-printdevicecapabilities+xml":{"source":"iana","compressible":true},"application/vnd.ms-printing.printticket+xml":{"source":"apache","compressible":true},"application/vnd.ms-printschematicket+xml":{"source":"iana","compressible":true},"application/vnd.ms-project":{"source":"iana","extensions":["mpp","mpt"]},"application/vnd.ms-tnef":{"source":"iana"},"application/vnd.ms-windows.devicepairing":{"source":"iana"},"application/vnd.ms-windows.nwprinting.oob":{"source":"iana"},"application/vnd.ms-windows.printerpairing":{"source":"iana"},"application/vnd.ms-windows.wsd.oob":{"source":"iana"},"application/vnd.ms-wmdrm.lic-chlg-req":{"source":"iana"},"application/vnd.ms-wmdrm.lic-resp":{"source":"iana"},"application/vnd.ms-wmdrm.meter-chlg-req":{"source":"iana"},"application/vnd.ms-wmdrm.meter-resp":{"source":"iana"},"application/vnd.ms-word.document.macroenabled.12":{"source":"iana","extensions":["docm"]},"application/vnd.ms-word.template.macroenabled.12":{"source":"iana","extensions":["dotm"]},"application/vnd.ms-works":{"source":"iana","extensions":["wps","wks","wcm","wdb"]},"application/vnd.ms-wpl":{"source":"iana","extensions":["wpl"]},"application/vnd.ms-xpsdocument":{"source":"iana","compressible":false,"extensions":["xps"]},"application/vnd.msa-disk-image":{"source":"iana"},"application/vnd.mseq":{"source":"iana","extensions":["mseq"]},"application/vnd.msign":{"source":"iana"},"application/vnd.multiad.creator":{"source":"iana"},"application/vnd.multiad.creator.cif":{"source":"iana"},"application/vnd.music-niff":{"source":"iana"},"application/vnd.musician":{"source":"iana","extensions":["mus"]},"application/vnd.muvee.style":{"source":"iana","extensions":["msty"]},"application/vnd.mynfc":{"source":"iana","extensions":["taglet"]},"application/vnd.nacamar.ybrid+json":{"source":"iana","compressible":true},"application/vnd.ncd.control":{"source":"iana"},"application/vnd.ncd.reference":{"source":"iana"},"application/vnd.nearst.inv+json":{"source":"iana","compressible":true},"application/vnd.nebumind.line":{"source":"iana"},"application/vnd.nervana":{"source":"iana"},"application/vnd.netfpx":{"source":"iana"},"application/vnd.neurolanguage.nlu":{"source":"iana","extensions":["nlu"]},"application/vnd.nimn":{"source":"iana"},"application/vnd.nintendo.nitro.rom":{"source":"iana"},"application/vnd.nintendo.snes.rom":{"source":"iana"},"application/vnd.nitf":{"source":"iana","extensions":["ntf","nitf"]},"application/vnd.noblenet-directory":{"source":"iana","extensions":["nnd"]},"application/vnd.noblenet-sealer":{"source":"iana","extensions":["nns"]},"application/vnd.noblenet-web":{"source":"iana","extensions":["nnw"]},"application/vnd.nokia.catalogs":{"source":"iana"},"application/vnd.nokia.conml+wbxml":{"source":"iana"},"application/vnd.nokia.conml+xml":{"source":"iana","compressible":true},"application/vnd.nokia.iptv.config+xml":{"source":"iana","compressible":true},"application/vnd.nokia.isds-radio-presets":{"source":"iana"},"application/vnd.nokia.landmark+wbxml":{"source":"iana"},"application/vnd.nokia.landmark+xml":{"source":"iana","compressible":true},"application/vnd.nokia.landmarkcollection+xml":{"source":"iana","compressible":true},"application/vnd.nokia.n-gage.ac+xml":{"source":"iana","compressible":true,"extensions":["ac"]},"application/vnd.nokia.n-gage.data":{"source":"iana","extensions":["ngdat"]},"application/vnd.nokia.n-gage.symbian.install":{"source":"iana","extensions":["n-gage"]},"application/vnd.nokia.ncd":{"source":"iana"},"application/vnd.nokia.pcd+wbxml":{"source":"iana"},"application/vnd.nokia.pcd+xml":{"source":"iana","compressible":true},"application/vnd.nokia.radio-preset":{"source":"iana","extensions":["rpst"]},"application/vnd.nokia.radio-presets":{"source":"iana","extensions":["rpss"]},"application/vnd.novadigm.edm":{"source":"iana","extensions":["edm"]},"application/vnd.novadigm.edx":{"source":"iana","extensions":["edx"]},"application/vnd.novadigm.ext":{"source":"iana","extensions":["ext"]},"application/vnd.ntt-local.content-share":{"source":"iana"},"application/vnd.ntt-local.file-transfer":{"source":"iana"},"application/vnd.ntt-local.ogw_remote-access":{"source":"iana"},"application/vnd.ntt-local.sip-ta_remote":{"source":"iana"},"application/vnd.ntt-local.sip-ta_tcp_stream":{"source":"iana"},"application/vnd.oasis.opendocument.chart":{"source":"iana","extensions":["odc"]},"application/vnd.oasis.opendocument.chart-template":{"source":"iana","extensions":["otc"]},"application/vnd.oasis.opendocument.database":{"source":"iana","extensions":["odb"]},"application/vnd.oasis.opendocument.formula":{"source":"iana","extensions":["odf"]},"application/vnd.oasis.opendocument.formula-template":{"source":"iana","extensions":["odft"]},"application/vnd.oasis.opendocument.graphics":{"source":"iana","compressible":false,"extensions":["odg"]},"application/vnd.oasis.opendocument.graphics-template":{"source":"iana","extensions":["otg"]},"application/vnd.oasis.opendocument.image":{"source":"iana","extensions":["odi"]},"application/vnd.oasis.opendocument.image-template":{"source":"iana","extensions":["oti"]},"application/vnd.oasis.opendocument.presentation":{"source":"iana","compressible":false,"extensions":["odp"]},"application/vnd.oasis.opendocument.presentation-template":{"source":"iana","extensions":["otp"]},"application/vnd.oasis.opendocument.spreadsheet":{"source":"iana","compressible":false,"extensions":["ods"]},"application/vnd.oasis.opendocument.spreadsheet-template":{"source":"iana","extensions":["ots"]},"application/vnd.oasis.opendocument.text":{"source":"iana","compressible":false,"extensions":["odt"]},"application/vnd.oasis.opendocument.text-master":{"source":"iana","extensions":["odm"]},"application/vnd.oasis.opendocument.text-template":{"source":"iana","extensions":["ott"]},"application/vnd.oasis.opendocument.text-web":{"source":"iana","extensions":["oth"]},"application/vnd.obn":{"source":"iana"},"application/vnd.ocf+cbor":{"source":"iana"},"application/vnd.oci.image.manifest.v1+json":{"source":"iana","compressible":true},"application/vnd.oftn.l10n+json":{"source":"iana","compressible":true},"application/vnd.oipf.contentaccessdownload+xml":{"source":"iana","compressible":true},"application/vnd.oipf.contentaccessstreaming+xml":{"source":"iana","compressible":true},"application/vnd.oipf.cspg-hexbinary":{"source":"iana"},"application/vnd.oipf.dae.svg+xml":{"source":"iana","compressible":true},"application/vnd.oipf.dae.xhtml+xml":{"source":"iana","compressible":true},"application/vnd.oipf.mippvcontrolmessage+xml":{"source":"iana","compressible":true},"application/vnd.oipf.pae.gem":{"source":"iana"},"application/vnd.oipf.spdiscovery+xml":{"source":"iana","compressible":true},"application/vnd.oipf.spdlist+xml":{"source":"iana","compressible":true},"application/vnd.oipf.ueprofile+xml":{"source":"iana","compressible":true},"application/vnd.oipf.userprofile+xml":{"source":"iana","compressible":true},"application/vnd.olpc-sugar":{"source":"iana","extensions":["xo"]},"application/vnd.oma-scws-config":{"source":"iana"},"application/vnd.oma-scws-http-request":{"source":"iana"},"application/vnd.oma-scws-http-response":{"source":"iana"},"application/vnd.oma.bcast.associated-procedure-parameter+xml":{"source":"iana","compressible":true},"application/vnd.oma.bcast.drm-trigger+xml":{"source":"iana","compressible":true},"application/vnd.oma.bcast.imd+xml":{"source":"iana","compressible":true},"application/vnd.oma.bcast.ltkm":{"source":"iana"},"application/vnd.oma.bcast.notification+xml":{"source":"iana","compressible":true},"application/vnd.oma.bcast.provisioningtrigger":{"source":"iana"},"application/vnd.oma.bcast.sgboot":{"source":"iana"},"application/vnd.oma.bcast.sgdd+xml":{"source":"iana","compressible":true},"application/vnd.oma.bcast.sgdu":{"source":"iana"},"application/vnd.oma.bcast.simple-symbol-container":{"source":"iana"},"application/vnd.oma.bcast.smartcard-trigger+xml":{"source":"iana","compressible":true},"application/vnd.oma.bcast.sprov+xml":{"source":"iana","compressible":true},"application/vnd.oma.bcast.stkm":{"source":"iana"},"application/vnd.oma.cab-address-book+xml":{"source":"iana","compressible":true},"application/vnd.oma.cab-feature-handler+xml":{"source":"iana","compressible":true},"application/vnd.oma.cab-pcc+xml":{"source":"iana","compressible":true},"application/vnd.oma.cab-subs-invite+xml":{"source":"iana","compressible":true},"application/vnd.oma.cab-user-prefs+xml":{"source":"iana","compressible":true},"application/vnd.oma.dcd":{"source":"iana"},"application/vnd.oma.dcdc":{"source":"iana"},"application/vnd.oma.dd2+xml":{"source":"iana","compressible":true,"extensions":["dd2"]},"application/vnd.oma.drm.risd+xml":{"source":"iana","compressible":true},"application/vnd.oma.group-usage-list+xml":{"source":"iana","compressible":true},"application/vnd.oma.lwm2m+cbor":{"source":"iana"},"application/vnd.oma.lwm2m+json":{"source":"iana","compressible":true},"application/vnd.oma.lwm2m+tlv":{"source":"iana"},"application/vnd.oma.pal+xml":{"source":"iana","compressible":true},"application/vnd.oma.poc.detailed-progress-report+xml":{"source":"iana","compressible":true},"application/vnd.oma.poc.final-report+xml":{"source":"iana","compressible":true},"application/vnd.oma.poc.groups+xml":{"source":"iana","compressible":true},"application/vnd.oma.poc.invocation-descriptor+xml":{"source":"iana","compressible":true},"application/vnd.oma.poc.optimized-progress-report+xml":{"source":"iana","compressible":true},"application/vnd.oma.push":{"source":"iana"},"application/vnd.oma.scidm.messages+xml":{"source":"iana","compressible":true},"application/vnd.oma.xcap-directory+xml":{"source":"iana","compressible":true},"application/vnd.omads-email+xml":{"source":"iana","charset":"UTF-8","compressible":true},"application/vnd.omads-file+xml":{"source":"iana","charset":"UTF-8","compressible":true},"application/vnd.omads-folder+xml":{"source":"iana","charset":"UTF-8","compressible":true},"application/vnd.omaloc-supl-init":{"source":"iana"},"application/vnd.onepager":{"source":"iana"},"application/vnd.onepagertamp":{"source":"iana"},"application/vnd.onepagertamx":{"source":"iana"},"application/vnd.onepagertat":{"source":"iana"},"application/vnd.onepagertatp":{"source":"iana"},"application/vnd.onepagertatx":{"source":"iana"},"application/vnd.openblox.game+xml":{"source":"iana","compressible":true,"extensions":["obgx"]},"application/vnd.openblox.game-binary":{"source":"iana"},"application/vnd.openeye.oeb":{"source":"iana"},"application/vnd.openofficeorg.extension":{"source":"apache","extensions":["oxt"]},"application/vnd.openstreetmap.data+xml":{"source":"iana","compressible":true,"extensions":["osm"]},"application/vnd.opentimestamps.ots":{"source":"iana"},"application/vnd.openxmlformats-officedocument.custom-properties+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.customxmlproperties+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.drawing+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.drawingml.chart+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.drawingml.chartshapes+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.drawingml.diagramcolors+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.drawingml.diagramdata+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.drawingml.diagramlayout+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.drawingml.diagramstyle+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.extended-properties+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.presentationml.commentauthors+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.presentationml.comments+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.presentationml.handoutmaster+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.presentationml.notesmaster+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.presentationml.notesslide+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.presentationml.presentation":{"source":"iana","compressible":false,"extensions":["pptx"]},"application/vnd.openxmlformats-officedocument.presentationml.presentation.main+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.presentationml.presprops+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.presentationml.slide":{"source":"iana","extensions":["sldx"]},"application/vnd.openxmlformats-officedocument.presentationml.slide+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.presentationml.slidelayout+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.presentationml.slidemaster+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.presentationml.slideshow":{"source":"iana","extensions":["ppsx"]},"application/vnd.openxmlformats-officedocument.presentationml.slideshow.main+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.presentationml.slideupdateinfo+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.presentationml.tablestyles+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.presentationml.tags+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.presentationml.template":{"source":"iana","extensions":["potx"]},"application/vnd.openxmlformats-officedocument.presentationml.template.main+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.presentationml.viewprops+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.spreadsheetml.calcchain+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.spreadsheetml.chartsheet+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.spreadsheetml.comments+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.spreadsheetml.connections+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.spreadsheetml.dialogsheet+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.spreadsheetml.externallink+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.spreadsheetml.pivotcachedefinition+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.spreadsheetml.pivotcacherecords+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.spreadsheetml.pivottable+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.spreadsheetml.querytable+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.spreadsheetml.revisionheaders+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.spreadsheetml.revisionlog+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.spreadsheetml.sharedstrings+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet":{"source":"iana","compressible":false,"extensions":["xlsx"]},"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet.main+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.spreadsheetml.sheetmetadata+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.spreadsheetml.styles+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.spreadsheetml.table+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.spreadsheetml.tablesinglecells+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.spreadsheetml.template":{"source":"iana","extensions":["xltx"]},"application/vnd.openxmlformats-officedocument.spreadsheetml.template.main+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.spreadsheetml.usernames+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.spreadsheetml.volatiledependencies+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.spreadsheetml.worksheet+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.theme+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.themeoverride+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.vmldrawing":{"source":"iana"},"application/vnd.openxmlformats-officedocument.wordprocessingml.comments+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.wordprocessingml.document":{"source":"iana","compressible":false,"extensions":["docx"]},"application/vnd.openxmlformats-officedocument.wordprocessingml.document.glossary+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.wordprocessingml.document.main+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.wordprocessingml.endnotes+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.wordprocessingml.fonttable+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.wordprocessingml.footer+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.wordprocessingml.footnotes+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.wordprocessingml.numbering+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.wordprocessingml.settings+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.wordprocessingml.styles+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.wordprocessingml.template":{"source":"iana","extensions":["dotx"]},"application/vnd.openxmlformats-officedocument.wordprocessingml.template.main+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-officedocument.wordprocessingml.websettings+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-package.core-properties+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-package.digital-signature-xmlsignature+xml":{"source":"iana","compressible":true},"application/vnd.openxmlformats-package.relationships+xml":{"source":"iana","compressible":true},"application/vnd.oracle.resource+json":{"source":"iana","compressible":true},"application/vnd.orange.indata":{"source":"iana"},"application/vnd.osa.netdeploy":{"source":"iana"},"application/vnd.osgeo.mapguide.package":{"source":"iana","extensions":["mgp"]},"application/vnd.osgi.bundle":{"source":"iana"},"application/vnd.osgi.dp":{"source":"iana","extensions":["dp"]},"application/vnd.osgi.subsystem":{"source":"iana","extensions":["esa"]},"application/vnd.otps.ct-kip+xml":{"source":"iana","compressible":true},"application/vnd.oxli.countgraph":{"source":"iana"},"application/vnd.pagerduty+json":{"source":"iana","compressible":true},"application/vnd.palm":{"source":"iana","extensions":["pdb","pqa","oprc"]},"application/vnd.panoply":{"source":"iana"},"application/vnd.paos.xml":{"source":"iana"},"application/vnd.patentdive":{"source":"iana"},"application/vnd.patientecommsdoc":{"source":"iana"},"application/vnd.pawaafile":{"source":"iana","extensions":["paw"]},"application/vnd.pcos":{"source":"iana"},"application/vnd.pg.format":{"source":"iana","extensions":["str"]},"application/vnd.pg.osasli":{"source":"iana","extensions":["ei6"]},"application/vnd.piaccess.application-licence":{"source":"iana"},"application/vnd.picsel":{"source":"iana","extensions":["efif"]},"application/vnd.pmi.widget":{"source":"iana","extensions":["wg"]},"application/vnd.poc.group-advertisement+xml":{"source":"iana","compressible":true},"application/vnd.pocketlearn":{"source":"iana","extensions":["plf"]},"application/vnd.powerbuilder6":{"source":"iana","extensions":["pbd"]},"application/vnd.powerbuilder6-s":{"source":"iana"},"application/vnd.powerbuilder7":{"source":"iana"},"application/vnd.powerbuilder7-s":{"source":"iana"},"application/vnd.powerbuilder75":{"source":"iana"},"application/vnd.powerbuilder75-s":{"source":"iana"},"application/vnd.preminet":{"source":"iana"},"application/vnd.previewsystems.box":{"source":"iana","extensions":["box"]},"application/vnd.proteus.magazine":{"source":"iana","extensions":["mgz"]},"application/vnd.psfs":{"source":"iana"},"application/vnd.publishare-delta-tree":{"source":"iana","extensions":["qps"]},"application/vnd.pvi.ptid1":{"source":"iana","extensions":["ptid"]},"application/vnd.pwg-multiplexed":{"source":"iana"},"application/vnd.pwg-xhtml-print+xml":{"source":"iana","compressible":true},"application/vnd.qualcomm.brew-app-res":{"source":"iana"},"application/vnd.quarantainenet":{"source":"iana"},"application/vnd.quark.quarkxpress":{"source":"iana","extensions":["qxd","qxt","qwd","qwt","qxl","qxb"]},"application/vnd.quobject-quoxdocument":{"source":"iana"},"application/vnd.radisys.moml+xml":{"source":"iana","compressible":true},"application/vnd.radisys.msml+xml":{"source":"iana","compressible":true},"application/vnd.radisys.msml-audit+xml":{"source":"iana","compressible":true},"application/vnd.radisys.msml-audit-conf+xml":{"source":"iana","compressible":true},"application/vnd.radisys.msml-audit-conn+xml":{"source":"iana","compressible":true},"application/vnd.radisys.msml-audit-dialog+xml":{"source":"iana","compressible":true},"application/vnd.radisys.msml-audit-stream+xml":{"source":"iana","compressible":true},"application/vnd.radisys.msml-conf+xml":{"source":"iana","compressible":true},"application/vnd.radisys.msml-dialog+xml":{"source":"iana","compressible":true},"application/vnd.radisys.msml-dialog-base+xml":{"source":"iana","compressible":true},"application/vnd.radisys.msml-dialog-fax-detect+xml":{"source":"iana","compressible":true},"application/vnd.radisys.msml-dialog-fax-sendrecv+xml":{"source":"iana","compressible":true},"application/vnd.radisys.msml-dialog-group+xml":{"source":"iana","compressible":true},"application/vnd.radisys.msml-dialog-speech+xml":{"source":"iana","compressible":true},"application/vnd.radisys.msml-dialog-transform+xml":{"source":"iana","compressible":true},"application/vnd.rainstor.data":{"source":"iana"},"application/vnd.rapid":{"source":"iana"},"application/vnd.rar":{"source":"iana","extensions":["rar"]},"application/vnd.realvnc.bed":{"source":"iana","extensions":["bed"]},"application/vnd.recordare.musicxml":{"source":"iana","extensions":["mxl"]},"application/vnd.recordare.musicxml+xml":{"source":"iana","compressible":true,"extensions":["musicxml"]},"application/vnd.renlearn.rlprint":{"source":"iana"},"application/vnd.resilient.logic":{"source":"iana"},"application/vnd.restful+json":{"source":"iana","compressible":true},"application/vnd.rig.cryptonote":{"source":"iana","extensions":["cryptonote"]},"application/vnd.rim.cod":{"source":"apache","extensions":["cod"]},"application/vnd.rn-realmedia":{"source":"apache","extensions":["rm"]},"application/vnd.rn-realmedia-vbr":{"source":"apache","extensions":["rmvb"]},"application/vnd.route66.link66+xml":{"source":"iana","compressible":true,"extensions":["link66"]},"application/vnd.rs-274x":{"source":"iana"},"application/vnd.ruckus.download":{"source":"iana"},"application/vnd.s3sms":{"source":"iana"},"application/vnd.sailingtracker.track":{"source":"iana","extensions":["st"]},"application/vnd.sar":{"source":"iana"},"application/vnd.sbm.cid":{"source":"iana"},"application/vnd.sbm.mid2":{"source":"iana"},"application/vnd.scribus":{"source":"iana"},"application/vnd.sealed.3df":{"source":"iana"},"application/vnd.sealed.csf":{"source":"iana"},"application/vnd.sealed.doc":{"source":"iana"},"application/vnd.sealed.eml":{"source":"iana"},"application/vnd.sealed.mht":{"source":"iana"},"application/vnd.sealed.net":{"source":"iana"},"application/vnd.sealed.ppt":{"source":"iana"},"application/vnd.sealed.tiff":{"source":"iana"},"application/vnd.sealed.xls":{"source":"iana"},"application/vnd.sealedmedia.softseal.html":{"source":"iana"},"application/vnd.sealedmedia.softseal.pdf":{"source":"iana"},"application/vnd.seemail":{"source":"iana","extensions":["see"]},"application/vnd.seis+json":{"source":"iana","compressible":true},"application/vnd.sema":{"source":"iana","extensions":["sema"]},"application/vnd.semd":{"source":"iana","extensions":["semd"]},"application/vnd.semf":{"source":"iana","extensions":["semf"]},"application/vnd.shade-save-file":{"source":"iana"},"application/vnd.shana.informed.formdata":{"source":"iana","extensions":["ifm"]},"application/vnd.shana.informed.formtemplate":{"source":"iana","extensions":["itp"]},"application/vnd.shana.informed.interchange":{"source":"iana","extensions":["iif"]},"application/vnd.shana.informed.package":{"source":"iana","extensions":["ipk"]},"application/vnd.shootproof+json":{"source":"iana","compressible":true},"application/vnd.shopkick+json":{"source":"iana","compressible":true},"application/vnd.shp":{"source":"iana"},"application/vnd.shx":{"source":"iana"},"application/vnd.sigrok.session":{"source":"iana"},"application/vnd.simtech-mindmapper":{"source":"iana","extensions":["twd","twds"]},"application/vnd.siren+json":{"source":"iana","compressible":true},"application/vnd.smaf":{"source":"iana","extensions":["mmf"]},"application/vnd.smart.notebook":{"source":"iana"},"application/vnd.smart.teacher":{"source":"iana","extensions":["teacher"]},"application/vnd.snesdev-page-table":{"source":"iana"},"application/vnd.software602.filler.form+xml":{"source":"iana","compressible":true,"extensions":["fo"]},"application/vnd.software602.filler.form-xml-zip":{"source":"iana"},"application/vnd.solent.sdkm+xml":{"source":"iana","compressible":true,"extensions":["sdkm","sdkd"]},"application/vnd.spotfire.dxp":{"source":"iana","extensions":["dxp"]},"application/vnd.spotfire.sfs":{"source":"iana","extensions":["sfs"]},"application/vnd.sqlite3":{"source":"iana"},"application/vnd.sss-cod":{"source":"iana"},"application/vnd.sss-dtf":{"source":"iana"},"application/vnd.sss-ntf":{"source":"iana"},"application/vnd.stardivision.calc":{"source":"apache","extensions":["sdc"]},"application/vnd.stardivision.draw":{"source":"apache","extensions":["sda"]},"application/vnd.stardivision.impress":{"source":"apache","extensions":["sdd"]},"application/vnd.stardivision.math":{"source":"apache","extensions":["smf"]},"application/vnd.stardivision.writer":{"source":"apache","extensions":["sdw","vor"]},"application/vnd.stardivision.writer-global":{"source":"apache","extensions":["sgl"]},"application/vnd.stepmania.package":{"source":"iana","extensions":["smzip"]},"application/vnd.stepmania.stepchart":{"source":"iana","extensions":["sm"]},"application/vnd.street-stream":{"source":"iana"},"application/vnd.sun.wadl+xml":{"source":"iana","compressible":true,"extensions":["wadl"]},"application/vnd.sun.xml.calc":{"source":"apache","extensions":["sxc"]},"application/vnd.sun.xml.calc.template":{"source":"apache","extensions":["stc"]},"application/vnd.sun.xml.draw":{"source":"apache","extensions":["sxd"]},"application/vnd.sun.xml.draw.template":{"source":"apache","extensions":["std"]},"application/vnd.sun.xml.impress":{"source":"apache","extensions":["sxi"]},"application/vnd.sun.xml.impress.template":{"source":"apache","extensions":["sti"]},"application/vnd.sun.xml.math":{"source":"apache","extensions":["sxm"]},"application/vnd.sun.xml.writer":{"source":"apache","extensions":["sxw"]},"application/vnd.sun.xml.writer.global":{"source":"apache","extensions":["sxg"]},"application/vnd.sun.xml.writer.template":{"source":"apache","extensions":["stw"]},"application/vnd.sus-calendar":{"source":"iana","extensions":["sus","susp"]},"application/vnd.svd":{"source":"iana","extensions":["svd"]},"application/vnd.swiftview-ics":{"source":"iana"},"application/vnd.sycle+xml":{"source":"iana","compressible":true},"application/vnd.syft+json":{"source":"iana","compressible":true},"application/vnd.symbian.install":{"source":"apache","extensions":["sis","sisx"]},"application/vnd.syncml+xml":{"source":"iana","charset":"UTF-8","compressible":true,"extensions":["xsm"]},"application/vnd.syncml.dm+wbxml":{"source":"iana","charset":"UTF-8","extensions":["bdm"]},"application/vnd.syncml.dm+xml":{"source":"iana","charset":"UTF-8","compressible":true,"extensions":["xdm"]},"application/vnd.syncml.dm.notification":{"source":"iana"},"application/vnd.syncml.dmddf+wbxml":{"source":"iana"},"application/vnd.syncml.dmddf+xml":{"source":"iana","charset":"UTF-8","compressible":true,"extensions":["ddf"]},"application/vnd.syncml.dmtnds+wbxml":{"source":"iana"},"application/vnd.syncml.dmtnds+xml":{"source":"iana","charset":"UTF-8","compressible":true},"application/vnd.syncml.ds.notification":{"source":"iana"},"application/vnd.tableschema+json":{"source":"iana","compressible":true},"application/vnd.tao.intent-module-archive":{"source":"iana","extensions":["tao"]},"application/vnd.tcpdump.pcap":{"source":"iana","extensions":["pcap","cap","dmp"]},"application/vnd.think-cell.ppttc+json":{"source":"iana","compressible":true},"application/vnd.tmd.mediaflex.api+xml":{"source":"iana","compressible":true},"application/vnd.tml":{"source":"iana"},"application/vnd.tmobile-livetv":{"source":"iana","extensions":["tmo"]},"application/vnd.tri.onesource":{"source":"iana"},"application/vnd.trid.tpt":{"source":"iana","extensions":["tpt"]},"application/vnd.triscape.mxs":{"source":"iana","extensions":["mxs"]},"application/vnd.trueapp":{"source":"iana","extensions":["tra"]},"application/vnd.truedoc":{"source":"iana"},"application/vnd.ubisoft.webplayer":{"source":"iana"},"application/vnd.ufdl":{"source":"iana","extensions":["ufd","ufdl"]},"application/vnd.uiq.theme":{"source":"iana","extensions":["utz"]},"application/vnd.umajin":{"source":"iana","extensions":["umj"]},"application/vnd.unity":{"source":"iana","extensions":["unityweb"]},"application/vnd.uoml+xml":{"source":"iana","compressible":true,"extensions":["uoml"]},"application/vnd.uplanet.alert":{"source":"iana"},"application/vnd.uplanet.alert-wbxml":{"source":"iana"},"application/vnd.uplanet.bearer-choice":{"source":"iana"},"application/vnd.uplanet.bearer-choice-wbxml":{"source":"iana"},"application/vnd.uplanet.cacheop":{"source":"iana"},"application/vnd.uplanet.cacheop-wbxml":{"source":"iana"},"application/vnd.uplanet.channel":{"source":"iana"},"application/vnd.uplanet.channel-wbxml":{"source":"iana"},"application/vnd.uplanet.list":{"source":"iana"},"application/vnd.uplanet.list-wbxml":{"source":"iana"},"application/vnd.uplanet.listcmd":{"source":"iana"},"application/vnd.uplanet.listcmd-wbxml":{"source":"iana"},"application/vnd.uplanet.signal":{"source":"iana"},"application/vnd.uri-map":{"source":"iana"},"application/vnd.valve.source.material":{"source":"iana"},"application/vnd.vcx":{"source":"iana","extensions":["vcx"]},"application/vnd.vd-study":{"source":"iana"},"application/vnd.vectorworks":{"source":"iana"},"application/vnd.vel+json":{"source":"iana","compressible":true},"application/vnd.verimatrix.vcas":{"source":"iana"},"application/vnd.veritone.aion+json":{"source":"iana","compressible":true},"application/vnd.veryant.thin":{"source":"iana"},"application/vnd.ves.encrypted":{"source":"iana"},"application/vnd.vidsoft.vidconference":{"source":"iana"},"application/vnd.visio":{"source":"iana","extensions":["vsd","vst","vss","vsw"]},"application/vnd.visionary":{"source":"iana","extensions":["vis"]},"application/vnd.vividence.scriptfile":{"source":"iana"},"application/vnd.vsf":{"source":"iana","extensions":["vsf"]},"application/vnd.wap.sic":{"source":"iana"},"application/vnd.wap.slc":{"source":"iana"},"application/vnd.wap.wbxml":{"source":"iana","charset":"UTF-8","extensions":["wbxml"]},"application/vnd.wap.wmlc":{"source":"iana","extensions":["wmlc"]},"application/vnd.wap.wmlscriptc":{"source":"iana","extensions":["wmlsc"]},"application/vnd.webturbo":{"source":"iana","extensions":["wtb"]},"application/vnd.wfa.dpp":{"source":"iana"},"application/vnd.wfa.p2p":{"source":"iana"},"application/vnd.wfa.wsc":{"source":"iana"},"application/vnd.windows.devicepairing":{"source":"iana"},"application/vnd.wmc":{"source":"iana"},"application/vnd.wmf.bootstrap":{"source":"iana"},"application/vnd.wolfram.mathematica":{"source":"iana"},"application/vnd.wolfram.mathematica.package":{"source":"iana"},"application/vnd.wolfram.player":{"source":"iana","extensions":["nbp"]},"application/vnd.wordperfect":{"source":"iana","extensions":["wpd"]},"application/vnd.wqd":{"source":"iana","extensions":["wqd"]},"application/vnd.wrq-hp3000-labelled":{"source":"iana"},"application/vnd.wt.stf":{"source":"iana","extensions":["stf"]},"application/vnd.wv.csp+wbxml":{"source":"iana"},"application/vnd.wv.csp+xml":{"source":"iana","compressible":true},"application/vnd.wv.ssp+xml":{"source":"iana","compressible":true},"application/vnd.xacml+json":{"source":"iana","compressible":true},"application/vnd.xara":{"source":"iana","extensions":["xar"]},"application/vnd.xfdl":{"source":"iana","extensions":["xfdl"]},"application/vnd.xfdl.webform":{"source":"iana"},"application/vnd.xmi+xml":{"source":"iana","compressible":true},"application/vnd.xmpie.cpkg":{"source":"iana"},"application/vnd.xmpie.dpkg":{"source":"iana"},"application/vnd.xmpie.plan":{"source":"iana"},"application/vnd.xmpie.ppkg":{"source":"iana"},"application/vnd.xmpie.xlim":{"source":"iana"},"application/vnd.yamaha.hv-dic":{"source":"iana","extensions":["hvd"]},"application/vnd.yamaha.hv-script":{"source":"iana","extensions":["hvs"]},"application/vnd.yamaha.hv-voice":{"source":"iana","extensions":["hvp"]},"application/vnd.yamaha.openscoreformat":{"source":"iana","extensions":["osf"]},"application/vnd.yamaha.openscoreformat.osfpvg+xml":{"source":"iana","compressible":true,"extensions":["osfpvg"]},"application/vnd.yamaha.remote-setup":{"source":"iana"},"application/vnd.yamaha.smaf-audio":{"source":"iana","extensions":["saf"]},"application/vnd.yamaha.smaf-phrase":{"source":"iana","extensions":["spf"]},"application/vnd.yamaha.through-ngn":{"source":"iana"},"application/vnd.yamaha.tunnel-udpencap":{"source":"iana"},"application/vnd.yaoweme":{"source":"iana"},"application/vnd.yellowriver-custom-menu":{"source":"iana","extensions":["cmp"]},"application/vnd.youtube.yt":{"source":"iana"},"application/vnd.zul":{"source":"iana","extensions":["zir","zirz"]},"application/vnd.zzazz.deck+xml":{"source":"iana","compressible":true,"extensions":["zaz"]},"application/voicexml+xml":{"source":"iana","compressible":true,"extensions":["vxml"]},"application/voucher-cms+json":{"source":"iana","compressible":true},"application/vq-rtcpxr":{"source":"iana"},"application/wasm":{"source":"iana","compressible":true,"extensions":["wasm"]},"application/watcherinfo+xml":{"source":"iana","compressible":true,"extensions":["wif"]},"application/webpush-options+json":{"source":"iana","compressible":true},"application/whoispp-query":{"source":"iana"},"application/whoispp-response":{"source":"iana"},"application/widget":{"source":"iana","extensions":["wgt"]},"application/winhlp":{"source":"apache","extensions":["hlp"]},"application/wita":{"source":"iana"},"application/wordperfect5.1":{"source":"iana"},"application/wsdl+xml":{"source":"iana","compressible":true,"extensions":["wsdl"]},"application/wspolicy+xml":{"source":"iana","compressible":true,"extensions":["wspolicy"]},"application/x-7z-compressed":{"source":"apache","compressible":false,"extensions":["7z"]},"application/x-abiword":{"source":"apache","extensions":["abw"]},"application/x-ace-compressed":{"source":"apache","extensions":["ace"]},"application/x-amf":{"source":"apache"},"application/x-apple-diskimage":{"source":"apache","extensions":["dmg"]},"application/x-arj":{"compressible":false,"extensions":["arj"]},"application/x-authorware-bin":{"source":"apache","extensions":["aab","x32","u32","vox"]},"application/x-authorware-map":{"source":"apache","extensions":["aam"]},"application/x-authorware-seg":{"source":"apache","extensions":["aas"]},"application/x-bcpio":{"source":"apache","extensions":["bcpio"]},"application/x-bdoc":{"compressible":false,"extensions":["bdoc"]},"application/x-bittorrent":{"source":"apache","extensions":["torrent"]},"application/x-blorb":{"source":"apache","extensions":["blb","blorb"]},"application/x-bzip":{"source":"apache","compressible":false,"extensions":["bz"]},"application/x-bzip2":{"source":"apache","compressible":false,"extensions":["bz2","boz"]},"application/x-cbr":{"source":"apache","extensions":["cbr","cba","cbt","cbz","cb7"]},"application/x-cdlink":{"source":"apache","extensions":["vcd"]},"application/x-cfs-compressed":{"source":"apache","extensions":["cfs"]},"application/x-chat":{"source":"apache","extensions":["chat"]},"application/x-chess-pgn":{"source":"apache","extensions":["pgn"]},"application/x-chrome-extension":{"extensions":["crx"]},"application/x-cocoa":{"source":"nginx","extensions":["cco"]},"application/x-compress":{"source":"apache"},"application/x-conference":{"source":"apache","extensions":["nsc"]},"application/x-cpio":{"source":"apache","extensions":["cpio"]},"application/x-csh":{"source":"apache","extensions":["csh"]},"application/x-deb":{"compressible":false},"application/x-debian-package":{"source":"apache","extensions":["deb","udeb"]},"application/x-dgc-compressed":{"source":"apache","extensions":["dgc"]},"application/x-director":{"source":"apache","extensions":["dir","dcr","dxr","cst","cct","cxt","w3d","fgd","swa"]},"application/x-doom":{"source":"apache","extensions":["wad"]},"application/x-dtbncx+xml":{"source":"apache","compressible":true,"extensions":["ncx"]},"application/x-dtbook+xml":{"source":"apache","compressible":true,"extensions":["dtb"]},"application/x-dtbresource+xml":{"source":"apache","compressible":true,"extensions":["res"]},"application/x-dvi":{"source":"apache","compressible":false,"extensions":["dvi"]},"application/x-envoy":{"source":"apache","extensions":["evy"]},"application/x-eva":{"source":"apache","extensions":["eva"]},"application/x-font-bdf":{"source":"apache","extensions":["bdf"]},"application/x-font-dos":{"source":"apache"},"application/x-font-framemaker":{"source":"apache"},"application/x-font-ghostscript":{"source":"apache","extensions":["gsf"]},"application/x-font-libgrx":{"source":"apache"},"application/x-font-linux-psf":{"source":"apache","extensions":["psf"]},"application/x-font-pcf":{"source":"apache","extensions":["pcf"]},"application/x-font-snf":{"source":"apache","extensions":["snf"]},"application/x-font-speedo":{"source":"apache"},"application/x-font-sunos-news":{"source":"apache"},"application/x-font-type1":{"source":"apache","extensions":["pfa","pfb","pfm","afm"]},"application/x-font-vfont":{"source":"apache"},"application/x-freearc":{"source":"apache","extensions":["arc"]},"application/x-futuresplash":{"source":"apache","extensions":["spl"]},"application/x-gca-compressed":{"source":"apache","extensions":["gca"]},"application/x-glulx":{"source":"apache","extensions":["ulx"]},"application/x-gnumeric":{"source":"apache","extensions":["gnumeric"]},"application/x-gramps-xml":{"source":"apache","extensions":["gramps"]},"application/x-gtar":{"source":"apache","extensions":["gtar"]},"application/x-gzip":{"source":"apache"},"application/x-hdf":{"source":"apache","extensions":["hdf"]},"application/x-httpd-php":{"compressible":true,"extensions":["php"]},"application/x-install-instructions":{"source":"apache","extensions":["install"]},"application/x-iso9660-image":{"source":"apache","extensions":["iso"]},"application/x-iwork-keynote-sffkey":{"extensions":["key"]},"application/x-iwork-numbers-sffnumbers":{"extensions":["numbers"]},"application/x-iwork-pages-sffpages":{"extensions":["pages"]},"application/x-java-archive-diff":{"source":"nginx","extensions":["jardiff"]},"application/x-java-jnlp-file":{"source":"apache","compressible":false,"extensions":["jnlp"]},"application/x-javascript":{"compressible":true},"application/x-keepass2":{"extensions":["kdbx"]},"application/x-latex":{"source":"apache","compressible":false,"extensions":["latex"]},"application/x-lua-bytecode":{"extensions":["luac"]},"application/x-lzh-compressed":{"source":"apache","extensions":["lzh","lha"]},"application/x-makeself":{"source":"nginx","extensions":["run"]},"application/x-mie":{"source":"apache","extensions":["mie"]},"application/x-mobipocket-ebook":{"source":"apache","extensions":["prc","mobi"]},"application/x-mpegurl":{"compressible":false},"application/x-ms-application":{"source":"apache","extensions":["application"]},"application/x-ms-shortcut":{"source":"apache","extensions":["lnk"]},"application/x-ms-wmd":{"source":"apache","extensions":["wmd"]},"application/x-ms-wmz":{"source":"apache","extensions":["wmz"]},"application/x-ms-xbap":{"source":"apache","extensions":["xbap"]},"application/x-msaccess":{"source":"apache","extensions":["mdb"]},"application/x-msbinder":{"source":"apache","extensions":["obd"]},"application/x-mscardfile":{"source":"apache","extensions":["crd"]},"application/x-msclip":{"source":"apache","extensions":["clp"]},"application/x-msdos-program":{"extensions":["exe"]},"application/x-msdownload":{"source":"apache","extensions":["exe","dll","com","bat","msi"]},"application/x-msmediaview":{"source":"apache","extensions":["mvb","m13","m14"]},"application/x-msmetafile":{"source":"apache","extensions":["wmf","wmz","emf","emz"]},"application/x-msmoney":{"source":"apache","extensions":["mny"]},"application/x-mspublisher":{"source":"apache","extensions":["pub"]},"application/x-msschedule":{"source":"apache","extensions":["scd"]},"application/x-msterminal":{"source":"apache","extensions":["trm"]},"application/x-mswrite":{"source":"apache","extensions":["wri"]},"application/x-netcdf":{"source":"apache","extensions":["nc","cdf"]},"application/x-ns-proxy-autoconfig":{"compressible":true,"extensions":["pac"]},"application/x-nzb":{"source":"apache","extensions":["nzb"]},"application/x-perl":{"source":"nginx","extensions":["pl","pm"]},"application/x-pilot":{"source":"nginx","extensions":["prc","pdb"]},"application/x-pkcs12":{"source":"apache","compressible":false,"extensions":["p12","pfx"]},"application/x-pkcs7-certificates":{"source":"apache","extensions":["p7b","spc"]},"application/x-pkcs7-certreqresp":{"source":"apache","extensions":["p7r"]},"application/x-pki-message":{"source":"iana"},"application/x-rar-compressed":{"source":"apache","compressible":false,"extensions":["rar"]},"application/x-redhat-package-manager":{"source":"nginx","extensions":["rpm"]},"application/x-research-info-systems":{"source":"apache","extensions":["ris"]},"application/x-sea":{"source":"nginx","extensions":["sea"]},"application/x-sh":{"source":"apache","compressible":true,"extensions":["sh"]},"application/x-shar":{"source":"apache","extensions":["shar"]},"application/x-shockwave-flash":{"source":"apache","compressible":false,"extensions":["swf"]},"application/x-silverlight-app":{"source":"apache","extensions":["xap"]},"application/x-sql":{"source":"apache","extensions":["sql"]},"application/x-stuffit":{"source":"apache","compressible":false,"extensions":["sit"]},"application/x-stuffitx":{"source":"apache","extensions":["sitx"]},"application/x-subrip":{"source":"apache","extensions":["srt"]},"application/x-sv4cpio":{"source":"apache","extensions":["sv4cpio"]},"application/x-sv4crc":{"source":"apache","extensions":["sv4crc"]},"application/x-t3vm-image":{"source":"apache","extensions":["t3"]},"application/x-tads":{"source":"apache","extensions":["gam"]},"application/x-tar":{"source":"apache","compressible":true,"extensions":["tar"]},"application/x-tcl":{"source":"apache","extensions":["tcl","tk"]},"application/x-tex":{"source":"apache","extensions":["tex"]},"application/x-tex-tfm":{"source":"apache","extensions":["tfm"]},"application/x-texinfo":{"source":"apache","extensions":["texinfo","texi"]},"application/x-tgif":{"source":"apache","extensions":["obj"]},"application/x-ustar":{"source":"apache","extensions":["ustar"]},"application/x-virtualbox-hdd":{"compressible":true,"extensions":["hdd"]},"application/x-virtualbox-ova":{"compressible":true,"extensions":["ova"]},"application/x-virtualbox-ovf":{"compressible":true,"extensions":["ovf"]},"application/x-virtualbox-vbox":{"compressible":true,"extensions":["vbox"]},"application/x-virtualbox-vbox-extpack":{"compressible":false,"extensions":["vbox-extpack"]},"application/x-virtualbox-vdi":{"compressible":true,"extensions":["vdi"]},"application/x-virtualbox-vhd":{"compressible":true,"extensions":["vhd"]},"application/x-virtualbox-vmdk":{"compressible":true,"extensions":["vmdk"]},"application/x-wais-source":{"source":"apache","extensions":["src"]},"application/x-web-app-manifest+json":{"compressible":true,"extensions":["webapp"]},"application/x-www-form-urlencoded":{"source":"iana","compressible":true},"application/x-x509-ca-cert":{"source":"iana","extensions":["der","crt","pem"]},"application/x-x509-ca-ra-cert":{"source":"iana"},"application/x-x509-next-ca-cert":{"source":"iana"},"application/x-xfig":{"source":"apache","extensions":["fig"]},"application/x-xliff+xml":{"source":"apache","compressible":true,"extensions":["xlf"]},"application/x-xpinstall":{"source":"apache","compressible":false,"extensions":["xpi"]},"application/x-xz":{"source":"apache","extensions":["xz"]},"application/x-zmachine":{"source":"apache","extensions":["z1","z2","z3","z4","z5","z6","z7","z8"]},"application/x400-bp":{"source":"iana"},"application/xacml+xml":{"source":"iana","compressible":true},"application/xaml+xml":{"source":"apache","compressible":true,"extensions":["xaml"]},"application/xcap-att+xml":{"source":"iana","compressible":true,"extensions":["xav"]},"application/xcap-caps+xml":{"source":"iana","compressible":true,"extensions":["xca"]},"application/xcap-diff+xml":{"source":"iana","compressible":true,"extensions":["xdf"]},"application/xcap-el+xml":{"source":"iana","compressible":true,"extensions":["xel"]},"application/xcap-error+xml":{"source":"iana","compressible":true},"application/xcap-ns+xml":{"source":"iana","compressible":true,"extensions":["xns"]},"application/xcon-conference-info+xml":{"source":"iana","compressible":true},"application/xcon-conference-info-diff+xml":{"source":"iana","compressible":true},"application/xenc+xml":{"source":"iana","compressible":true,"extensions":["xenc"]},"application/xhtml+xml":{"source":"iana","compressible":true,"extensions":["xhtml","xht"]},"application/xhtml-voice+xml":{"source":"apache","compressible":true},"application/xliff+xml":{"source":"iana","compressible":true,"extensions":["xlf"]},"application/xml":{"source":"iana","compressible":true,"extensions":["xml","xsl","xsd","rng"]},"application/xml-dtd":{"source":"iana","compressible":true,"extensions":["dtd"]},"application/xml-external-parsed-entity":{"source":"iana"},"application/xml-patch+xml":{"source":"iana","compressible":true},"application/xmpp+xml":{"source":"iana","compressible":true},"application/xop+xml":{"source":"iana","compressible":true,"extensions":["xop"]},"application/xproc+xml":{"source":"apache","compressible":true,"extensions":["xpl"]},"application/xslt+xml":{"source":"iana","compressible":true,"extensions":["xsl","xslt"]},"application/xspf+xml":{"source":"apache","compressible":true,"extensions":["xspf"]},"application/xv+xml":{"source":"iana","compressible":true,"extensions":["mxml","xhvml","xvml","xvm"]},"application/yang":{"source":"iana","extensions":["yang"]},"application/yang-data+json":{"source":"iana","compressible":true},"application/yang-data+xml":{"source":"iana","compressible":true},"application/yang-patch+json":{"source":"iana","compressible":true},"application/yang-patch+xml":{"source":"iana","compressible":true},"application/yin+xml":{"source":"iana","compressible":true,"extensions":["yin"]},"application/zip":{"source":"iana","compressible":false,"extensions":["zip"]},"application/zlib":{"source":"iana"},"application/zstd":{"source":"iana"},"audio/1d-interleaved-parityfec":{"source":"iana"},"audio/32kadpcm":{"source":"iana"},"audio/3gpp":{"source":"iana","compressible":false,"extensions":["3gpp"]},"audio/3gpp2":{"source":"iana"},"audio/aac":{"source":"iana"},"audio/ac3":{"source":"iana"},"audio/adpcm":{"source":"apache","extensions":["adp"]},"audio/amr":{"source":"iana","extensions":["amr"]},"audio/amr-wb":{"source":"iana"},"audio/amr-wb+":{"source":"iana"},"audio/aptx":{"source":"iana"},"audio/asc":{"source":"iana"},"audio/atrac-advanced-lossless":{"source":"iana"},"audio/atrac-x":{"source":"iana"},"audio/atrac3":{"source":"iana"},"audio/basic":{"source":"iana","compressible":false,"extensions":["au","snd"]},"audio/bv16":{"source":"iana"},"audio/bv32":{"source":"iana"},"audio/clearmode":{"source":"iana"},"audio/cn":{"source":"iana"},"audio/dat12":{"source":"iana"},"audio/dls":{"source":"iana"},"audio/dsr-es201108":{"source":"iana"},"audio/dsr-es202050":{"source":"iana"},"audio/dsr-es202211":{"source":"iana"},"audio/dsr-es202212":{"source":"iana"},"audio/dv":{"source":"iana"},"audio/dvi4":{"source":"iana"},"audio/eac3":{"source":"iana"},"audio/encaprtp":{"source":"iana"},"audio/evrc":{"source":"iana"},"audio/evrc-qcp":{"source":"iana"},"audio/evrc0":{"source":"iana"},"audio/evrc1":{"source":"iana"},"audio/evrcb":{"source":"iana"},"audio/evrcb0":{"source":"iana"},"audio/evrcb1":{"source":"iana"},"audio/evrcnw":{"source":"iana"},"audio/evrcnw0":{"source":"iana"},"audio/evrcnw1":{"source":"iana"},"audio/evrcwb":{"source":"iana"},"audio/evrcwb0":{"source":"iana"},"audio/evrcwb1":{"source":"iana"},"audio/evs":{"source":"iana"},"audio/flexfec":{"source":"iana"},"audio/fwdred":{"source":"iana"},"audio/g711-0":{"source":"iana"},"audio/g719":{"source":"iana"},"audio/g722":{"source":"iana"},"audio/g7221":{"source":"iana"},"audio/g723":{"source":"iana"},"audio/g726-16":{"source":"iana"},"audio/g726-24":{"source":"iana"},"audio/g726-32":{"source":"iana"},"audio/g726-40":{"source":"iana"},"audio/g728":{"source":"iana"},"audio/g729":{"source":"iana"},"audio/g7291":{"source":"iana"},"audio/g729d":{"source":"iana"},"audio/g729e":{"source":"iana"},"audio/gsm":{"source":"iana"},"audio/gsm-efr":{"source":"iana"},"audio/gsm-hr-08":{"source":"iana"},"audio/ilbc":{"source":"iana"},"audio/ip-mr_v2.5":{"source":"iana"},"audio/isac":{"source":"apache"},"audio/l16":{"source":"iana"},"audio/l20":{"source":"iana"},"audio/l24":{"source":"iana","compressible":false},"audio/l8":{"source":"iana"},"audio/lpc":{"source":"iana"},"audio/melp":{"source":"iana"},"audio/melp1200":{"source":"iana"},"audio/melp2400":{"source":"iana"},"audio/melp600":{"source":"iana"},"audio/mhas":{"source":"iana"},"audio/midi":{"source":"apache","extensions":["mid","midi","kar","rmi"]},"audio/mobile-xmf":{"source":"iana","extensions":["mxmf"]},"audio/mp3":{"compressible":false,"extensions":["mp3"]},"audio/mp4":{"source":"iana","compressible":false,"extensions":["m4a","mp4a"]},"audio/mp4a-latm":{"source":"iana"},"audio/mpa":{"source":"iana"},"audio/mpa-robust":{"source":"iana"},"audio/mpeg":{"source":"iana","compressible":false,"extensions":["mpga","mp2","mp2a","mp3","m2a","m3a"]},"audio/mpeg4-generic":{"source":"iana"},"audio/musepack":{"source":"apache"},"audio/ogg":{"source":"iana","compressible":false,"extensions":["oga","ogg","spx","opus"]},"audio/opus":{"source":"iana"},"audio/parityfec":{"source":"iana"},"audio/pcma":{"source":"iana"},"audio/pcma-wb":{"source":"iana"},"audio/pcmu":{"source":"iana"},"audio/pcmu-wb":{"source":"iana"},"audio/prs.sid":{"source":"iana"},"audio/qcelp":{"source":"iana"},"audio/raptorfec":{"source":"iana"},"audio/red":{"source":"iana"},"audio/rtp-enc-aescm128":{"source":"iana"},"audio/rtp-midi":{"source":"iana"},"audio/rtploopback":{"source":"iana"},"audio/rtx":{"source":"iana"},"audio/s3m":{"source":"apache","extensions":["s3m"]},"audio/scip":{"source":"iana"},"audio/silk":{"source":"apache","extensions":["sil"]},"audio/smv":{"source":"iana"},"audio/smv-qcp":{"source":"iana"},"audio/smv0":{"source":"iana"},"audio/sofa":{"source":"iana"},"audio/sp-midi":{"source":"iana"},"audio/speex":{"source":"iana"},"audio/t140c":{"source":"iana"},"audio/t38":{"source":"iana"},"audio/telephone-event":{"source":"iana"},"audio/tetra_acelp":{"source":"iana"},"audio/tetra_acelp_bb":{"source":"iana"},"audio/tone":{"source":"iana"},"audio/tsvcis":{"source":"iana"},"audio/uemclip":{"source":"iana"},"audio/ulpfec":{"source":"iana"},"audio/usac":{"source":"iana"},"audio/vdvi":{"source":"iana"},"audio/vmr-wb":{"source":"iana"},"audio/vnd.3gpp.iufp":{"source":"iana"},"audio/vnd.4sb":{"source":"iana"},"audio/vnd.audiokoz":{"source":"iana"},"audio/vnd.celp":{"source":"iana"},"audio/vnd.cisco.nse":{"source":"iana"},"audio/vnd.cmles.radio-events":{"source":"iana"},"audio/vnd.cns.anp1":{"source":"iana"},"audio/vnd.cns.inf1":{"source":"iana"},"audio/vnd.dece.audio":{"source":"iana","extensions":["uva","uvva"]},"audio/vnd.digital-winds":{"source":"iana","extensions":["eol"]},"audio/vnd.dlna.adts":{"source":"iana"},"audio/vnd.dolby.heaac.1":{"source":"iana"},"audio/vnd.dolby.heaac.2":{"source":"iana"},"audio/vnd.dolby.mlp":{"source":"iana"},"audio/vnd.dolby.mps":{"source":"iana"},"audio/vnd.dolby.pl2":{"source":"iana"},"audio/vnd.dolby.pl2x":{"source":"iana"},"audio/vnd.dolby.pl2z":{"source":"iana"},"audio/vnd.dolby.pulse.1":{"source":"iana"},"audio/vnd.dra":{"source":"iana","extensions":["dra"]},"audio/vnd.dts":{"source":"iana","extensions":["dts"]},"audio/vnd.dts.hd":{"source":"iana","extensions":["dtshd"]},"audio/vnd.dts.uhd":{"source":"iana"},"audio/vnd.dvb.file":{"source":"iana"},"audio/vnd.everad.plj":{"source":"iana"},"audio/vnd.hns.audio":{"source":"iana"},"audio/vnd.lucent.voice":{"source":"iana","extensions":["lvp"]},"audio/vnd.ms-playready.media.pya":{"source":"iana","extensions":["pya"]},"audio/vnd.nokia.mobile-xmf":{"source":"iana"},"audio/vnd.nortel.vbk":{"source":"iana"},"audio/vnd.nuera.ecelp4800":{"source":"iana","extensions":["ecelp4800"]},"audio/vnd.nuera.ecelp7470":{"source":"iana","extensions":["ecelp7470"]},"audio/vnd.nuera.ecelp9600":{"source":"iana","extensions":["ecelp9600"]},"audio/vnd.octel.sbc":{"source":"iana"},"audio/vnd.presonus.multitrack":{"source":"iana"},"audio/vnd.qcelp":{"source":"iana"},"audio/vnd.rhetorex.32kadpcm":{"source":"iana"},"audio/vnd.rip":{"source":"iana","extensions":["rip"]},"audio/vnd.rn-realaudio":{"compressible":false},"audio/vnd.sealedmedia.softseal.mpeg":{"source":"iana"},"audio/vnd.vmx.cvsd":{"source":"iana"},"audio/vnd.wave":{"compressible":false},"audio/vorbis":{"source":"iana","compressible":false},"audio/vorbis-config":{"source":"iana"},"audio/wav":{"compressible":false,"extensions":["wav"]},"audio/wave":{"compressible":false,"extensions":["wav"]},"audio/webm":{"source":"apache","compressible":false,"extensions":["weba"]},"audio/x-aac":{"source":"apache","compressible":false,"extensions":["aac"]},"audio/x-aiff":{"source":"apache","extensions":["aif","aiff","aifc"]},"audio/x-caf":{"source":"apache","compressible":false,"extensions":["caf"]},"audio/x-flac":{"source":"apache","extensions":["flac"]},"audio/x-m4a":{"source":"nginx","extensions":["m4a"]},"audio/x-matroska":{"source":"apache","extensions":["mka"]},"audio/x-mpegurl":{"source":"apache","extensions":["m3u"]},"audio/x-ms-wax":{"source":"apache","extensions":["wax"]},"audio/x-ms-wma":{"source":"apache","extensions":["wma"]},"audio/x-pn-realaudio":{"source":"apache","extensions":["ram","ra"]},"audio/x-pn-realaudio-plugin":{"source":"apache","extensions":["rmp"]},"audio/x-realaudio":{"source":"nginx","extensions":["ra"]},"audio/x-tta":{"source":"apache"},"audio/x-wav":{"source":"apache","extensions":["wav"]},"audio/xm":{"source":"apache","extensions":["xm"]},"chemical/x-cdx":{"source":"apache","extensions":["cdx"]},"chemical/x-cif":{"source":"apache","extensions":["cif"]},"chemical/x-cmdf":{"source":"apache","extensions":["cmdf"]},"chemical/x-cml":{"source":"apache","extensions":["cml"]},"chemical/x-csml":{"source":"apache","extensions":["csml"]},"chemical/x-pdb":{"source":"apache"},"chemical/x-xyz":{"source":"apache","extensions":["xyz"]},"font/collection":{"source":"iana","extensions":["ttc"]},"font/otf":{"source":"iana","compressible":true,"extensions":["otf"]},"font/sfnt":{"source":"iana"},"font/ttf":{"source":"iana","compressible":true,"extensions":["ttf"]},"font/woff":{"source":"iana","extensions":["woff"]},"font/woff2":{"source":"iana","extensions":["woff2"]},"image/aces":{"source":"iana","extensions":["exr"]},"image/apng":{"compressible":false,"extensions":["apng"]},"image/avci":{"source":"iana","extensions":["avci"]},"image/avcs":{"source":"iana","extensions":["avcs"]},"image/avif":{"source":"iana","compressible":false,"extensions":["avif"]},"image/bmp":{"source":"iana","compressible":true,"extensions":["bmp"]},"image/cgm":{"source":"iana","extensions":["cgm"]},"image/dicom-rle":{"source":"iana","extensions":["drle"]},"image/emf":{"source":"iana","extensions":["emf"]},"image/fits":{"source":"iana","extensions":["fits"]},"image/g3fax":{"source":"iana","extensions":["g3"]},"image/gif":{"source":"iana","compressible":false,"extensions":["gif"]},"image/heic":{"source":"iana","extensions":["heic"]},"image/heic-sequence":{"source":"iana","extensions":["heics"]},"image/heif":{"source":"iana","extensions":["heif"]},"image/heif-sequence":{"source":"iana","extensions":["heifs"]},"image/hej2k":{"source":"iana","extensions":["hej2"]},"image/hsj2":{"source":"iana","extensions":["hsj2"]},"image/ief":{"source":"iana","extensions":["ief"]},"image/jls":{"source":"iana","extensions":["jls"]},"image/jp2":{"source":"iana","compressible":false,"extensions":["jp2","jpg2"]},"image/jpeg":{"source":"iana","compressible":false,"extensions":["jpeg","jpg","jpe"]},"image/jph":{"source":"iana","extensions":["jph"]},"image/jphc":{"source":"iana","extensions":["jhc"]},"image/jpm":{"source":"iana","compressible":false,"extensions":["jpm"]},"image/jpx":{"source":"iana","compressible":false,"extensions":["jpx","jpf"]},"image/jxr":{"source":"iana","extensions":["jxr"]},"image/jxra":{"source":"iana","extensions":["jxra"]},"image/jxrs":{"source":"iana","extensions":["jxrs"]},"image/jxs":{"source":"iana","extensions":["jxs"]},"image/jxsc":{"source":"iana","extensions":["jxsc"]},"image/jxsi":{"source":"iana","extensions":["jxsi"]},"image/jxss":{"source":"iana","extensions":["jxss"]},"image/ktx":{"source":"iana","extensions":["ktx"]},"image/ktx2":{"source":"iana","extensions":["ktx2"]},"image/naplps":{"source":"iana"},"image/pjpeg":{"compressible":false},"image/png":{"source":"iana","compressible":false,"extensions":["png"]},"image/prs.btif":{"source":"iana","extensions":["btif"]},"image/prs.pti":{"source":"iana","extensions":["pti"]},"image/pwg-raster":{"source":"iana"},"image/sgi":{"source":"apache","extensions":["sgi"]},"image/svg+xml":{"source":"iana","compressible":true,"extensions":["svg","svgz"]},"image/t38":{"source":"iana","extensions":["t38"]},"image/tiff":{"source":"iana","compressible":false,"extensions":["tif","tiff"]},"image/tiff-fx":{"source":"iana","extensions":["tfx"]},"image/vnd.adobe.photoshop":{"source":"iana","compressible":true,"extensions":["psd"]},"image/vnd.airzip.accelerator.azv":{"source":"iana","extensions":["azv"]},"image/vnd.cns.inf2":{"source":"iana"},"image/vnd.dece.graphic":{"source":"iana","extensions":["uvi","uvvi","uvg","uvvg"]},"image/vnd.djvu":{"source":"iana","extensions":["djvu","djv"]},"image/vnd.dvb.subtitle":{"source":"iana","extensions":["sub"]},"image/vnd.dwg":{"source":"iana","extensions":["dwg"]},"image/vnd.dxf":{"source":"iana","extensions":["dxf"]},"image/vnd.fastbidsheet":{"source":"iana","extensions":["fbs"]},"image/vnd.fpx":{"source":"iana","extensions":["fpx"]},"image/vnd.fst":{"source":"iana","extensions":["fst"]},"image/vnd.fujixerox.edmics-mmr":{"source":"iana","extensions":["mmr"]},"image/vnd.fujixerox.edmics-rlc":{"source":"iana","extensions":["rlc"]},"image/vnd.globalgraphics.pgb":{"source":"iana"},"image/vnd.microsoft.icon":{"source":"iana","compressible":true,"extensions":["ico"]},"image/vnd.mix":{"source":"iana"},"image/vnd.mozilla.apng":{"source":"iana"},"image/vnd.ms-dds":{"compressible":true,"extensions":["dds"]},"image/vnd.ms-modi":{"source":"iana","extensions":["mdi"]},"image/vnd.ms-photo":{"source":"apache","extensions":["wdp"]},"image/vnd.net-fpx":{"source":"iana","extensions":["npx"]},"image/vnd.pco.b16":{"source":"iana","extensions":["b16"]},"image/vnd.radiance":{"source":"iana"},"image/vnd.sealed.png":{"source":"iana"},"image/vnd.sealedmedia.softseal.gif":{"source":"iana"},"image/vnd.sealedmedia.softseal.jpg":{"source":"iana"},"image/vnd.svf":{"source":"iana"},"image/vnd.tencent.tap":{"source":"iana","extensions":["tap"]},"image/vnd.valve.source.texture":{"source":"iana","extensions":["vtf"]},"image/vnd.wap.wbmp":{"source":"iana","extensions":["wbmp"]},"image/vnd.xiff":{"source":"iana","extensions":["xif"]},"image/vnd.zbrush.pcx":{"source":"iana","extensions":["pcx"]},"image/webp":{"source":"apache","extensions":["webp"]},"image/wmf":{"source":"iana","extensions":["wmf"]},"image/x-3ds":{"source":"apache","extensions":["3ds"]},"image/x-cmu-raster":{"source":"apache","extensions":["ras"]},"image/x-cmx":{"source":"apache","extensions":["cmx"]},"image/x-freehand":{"source":"apache","extensions":["fh","fhc","fh4","fh5","fh7"]},"image/x-icon":{"source":"apache","compressible":true,"extensions":["ico"]},"image/x-jng":{"source":"nginx","extensions":["jng"]},"image/x-mrsid-image":{"source":"apache","extensions":["sid"]},"image/x-ms-bmp":{"source":"nginx","compressible":true,"extensions":["bmp"]},"image/x-pcx":{"source":"apache","extensions":["pcx"]},"image/x-pict":{"source":"apache","extensions":["pic","pct"]},"image/x-portable-anymap":{"source":"apache","extensions":["pnm"]},"image/x-portable-bitmap":{"source":"apache","extensions":["pbm"]},"image/x-portable-graymap":{"source":"apache","extensions":["pgm"]},"image/x-portable-pixmap":{"source":"apache","extensions":["ppm"]},"image/x-rgb":{"source":"apache","extensions":["rgb"]},"image/x-tga":{"source":"apache","extensions":["tga"]},"image/x-xbitmap":{"source":"apache","extensions":["xbm"]},"image/x-xcf":{"compressible":false},"image/x-xpixmap":{"source":"apache","extensions":["xpm"]},"image/x-xwindowdump":{"source":"apache","extensions":["xwd"]},"message/cpim":{"source":"iana"},"message/delivery-status":{"source":"iana"},"message/disposition-notification":{"source":"iana","extensions":["disposition-notification"]},"message/external-body":{"source":"iana"},"message/feedback-report":{"source":"iana"},"message/global":{"source":"iana","extensions":["u8msg"]},"message/global-delivery-status":{"source":"iana","extensions":["u8dsn"]},"message/global-disposition-notification":{"source":"iana","extensions":["u8mdn"]},"message/global-headers":{"source":"iana","extensions":["u8hdr"]},"message/http":{"source":"iana","compressible":false},"message/imdn+xml":{"source":"iana","compressible":true},"message/news":{"source":"iana"},"message/partial":{"source":"iana","compressible":false},"message/rfc822":{"source":"iana","compressible":true,"extensions":["eml","mime"]},"message/s-http":{"source":"iana"},"message/sip":{"source":"iana"},"message/sipfrag":{"source":"iana"},"message/tracking-status":{"source":"iana"},"message/vnd.si.simp":{"source":"iana"},"message/vnd.wfa.wsc":{"source":"iana","extensions":["wsc"]},"model/3mf":{"source":"iana","extensions":["3mf"]},"model/e57":{"source":"iana"},"model/gltf+json":{"source":"iana","compressible":true,"extensions":["gltf"]},"model/gltf-binary":{"source":"iana","compressible":true,"extensions":["glb"]},"model/iges":{"source":"iana","compressible":false,"extensions":["igs","iges"]},"model/mesh":{"source":"iana","compressible":false,"extensions":["msh","mesh","silo"]},"model/mtl":{"source":"iana","extensions":["mtl"]},"model/obj":{"source":"iana","extensions":["obj"]},"model/step":{"source":"iana"},"model/step+xml":{"source":"iana","compressible":true,"extensions":["stpx"]},"model/step+zip":{"source":"iana","compressible":false,"extensions":["stpz"]},"model/step-xml+zip":{"source":"iana","compressible":false,"extensions":["stpxz"]},"model/stl":{"source":"iana","extensions":["stl"]},"model/vnd.collada+xml":{"source":"iana","compressible":true,"extensions":["dae"]},"model/vnd.dwf":{"source":"iana","extensions":["dwf"]},"model/vnd.flatland.3dml":{"source":"iana"},"model/vnd.gdl":{"source":"iana","extensions":["gdl"]},"model/vnd.gs-gdl":{"source":"apache"},"model/vnd.gs.gdl":{"source":"iana"},"model/vnd.gtw":{"source":"iana","extensions":["gtw"]},"model/vnd.moml+xml":{"source":"iana","compressible":true},"model/vnd.mts":{"source":"iana","extensions":["mts"]},"model/vnd.opengex":{"source":"iana","extensions":["ogex"]},"model/vnd.parasolid.transmit.binary":{"source":"iana","extensions":["x_b"]},"model/vnd.parasolid.transmit.text":{"source":"iana","extensions":["x_t"]},"model/vnd.pytha.pyox":{"source":"iana"},"model/vnd.rosette.annotated-data-model":{"source":"iana"},"model/vnd.sap.vds":{"source":"iana","extensions":["vds"]},"model/vnd.usdz+zip":{"source":"iana","compressible":false,"extensions":["usdz"]},"model/vnd.valve.source.compiled-map":{"source":"iana","extensions":["bsp"]},"model/vnd.vtu":{"source":"iana","extensions":["vtu"]},"model/vrml":{"source":"iana","compressible":false,"extensions":["wrl","vrml"]},"model/x3d+binary":{"source":"apache","compressible":false,"extensions":["x3db","x3dbz"]},"model/x3d+fastinfoset":{"source":"iana","extensions":["x3db"]},"model/x3d+vrml":{"source":"apache","compressible":false,"extensions":["x3dv","x3dvz"]},"model/x3d+xml":{"source":"iana","compressible":true,"extensions":["x3d","x3dz"]},"model/x3d-vrml":{"source":"iana","extensions":["x3dv"]},"multipart/alternative":{"source":"iana","compressible":false},"multipart/appledouble":{"source":"iana"},"multipart/byteranges":{"source":"iana"},"multipart/digest":{"source":"iana"},"multipart/encrypted":{"source":"iana","compressible":false},"multipart/form-data":{"source":"iana","compressible":false},"multipart/header-set":{"source":"iana"},"multipart/mixed":{"source":"iana"},"multipart/multilingual":{"source":"iana"},"multipart/parallel":{"source":"iana"},"multipart/related":{"source":"iana","compressible":false},"multipart/report":{"source":"iana"},"multipart/signed":{"source":"iana","compressible":false},"multipart/vnd.bint.med-plus":{"source":"iana"},"multipart/voice-message":{"source":"iana"},"multipart/x-mixed-replace":{"source":"iana"},"text/1d-interleaved-parityfec":{"source":"iana"},"text/cache-manifest":{"source":"iana","compressible":true,"extensions":["appcache","manifest"]},"text/calendar":{"source":"iana","extensions":["ics","ifb"]},"text/calender":{"compressible":true},"text/cmd":{"compressible":true},"text/coffeescript":{"extensions":["coffee","litcoffee"]},"text/cql":{"source":"iana"},"text/cql-expression":{"source":"iana"},"text/cql-identifier":{"source":"iana"},"text/css":{"source":"iana","charset":"UTF-8","compressible":true,"extensions":["css"]},"text/csv":{"source":"iana","compressible":true,"extensions":["csv"]},"text/csv-schema":{"source":"iana"},"text/directory":{"source":"iana"},"text/dns":{"source":"iana"},"text/ecmascript":{"source":"iana"},"text/encaprtp":{"source":"iana"},"text/enriched":{"source":"iana"},"text/fhirpath":{"source":"iana"},"text/flexfec":{"source":"iana"},"text/fwdred":{"source":"iana"},"text/gff3":{"source":"iana"},"text/grammar-ref-list":{"source":"iana"},"text/html":{"source":"iana","compressible":true,"extensions":["html","htm","shtml"]},"text/jade":{"extensions":["jade"]},"text/javascript":{"source":"iana","compressible":true},"text/jcr-cnd":{"source":"iana"},"text/jsx":{"compressible":true,"extensions":["jsx"]},"text/less":{"compressible":true,"extensions":["less"]},"text/markdown":{"source":"iana","compressible":true,"extensions":["markdown","md"]},"text/mathml":{"source":"nginx","extensions":["mml"]},"text/mdx":{"compressible":true,"extensions":["mdx"]},"text/mizar":{"source":"iana"},"text/n3":{"source":"iana","charset":"UTF-8","compressible":true,"extensions":["n3"]},"text/parameters":{"source":"iana","charset":"UTF-8"},"text/parityfec":{"source":"iana"},"text/plain":{"source":"iana","compressible":true,"extensions":["txt","text","conf","def","list","log","in","ini"]},"text/provenance-notation":{"source":"iana","charset":"UTF-8"},"text/prs.fallenstein.rst":{"source":"iana"},"text/prs.lines.tag":{"source":"iana","extensions":["dsc"]},"text/prs.prop.logic":{"source":"iana"},"text/raptorfec":{"source":"iana"},"text/red":{"source":"iana"},"text/rfc822-headers":{"source":"iana"},"text/richtext":{"source":"iana","compressible":true,"extensions":["rtx"]},"text/rtf":{"source":"iana","compressible":true,"extensions":["rtf"]},"text/rtp-enc-aescm128":{"source":"iana"},"text/rtploopback":{"source":"iana"},"text/rtx":{"source":"iana"},"text/sgml":{"source":"iana","extensions":["sgml","sgm"]},"text/shaclc":{"source":"iana"},"text/shex":{"source":"iana","extensions":["shex"]},"text/slim":{"extensions":["slim","slm"]},"text/spdx":{"source":"iana","extensions":["spdx"]},"text/strings":{"source":"iana"},"text/stylus":{"extensions":["stylus","styl"]},"text/t140":{"source":"iana"},"text/tab-separated-values":{"source":"iana","compressible":true,"extensions":["tsv"]},"text/troff":{"source":"iana","extensions":["t","tr","roff","man","me","ms"]},"text/turtle":{"source":"iana","charset":"UTF-8","extensions":["ttl"]},"text/ulpfec":{"source":"iana"},"text/uri-list":{"source":"iana","compressible":true,"extensions":["uri","uris","urls"]},"text/vcard":{"source":"iana","compressible":true,"extensions":["vcard"]},"text/vnd.a":{"source":"iana"},"text/vnd.abc":{"source":"iana"},"text/vnd.ascii-art":{"source":"iana"},"text/vnd.curl":{"source":"iana","extensions":["curl"]},"text/vnd.curl.dcurl":{"source":"apache","extensions":["dcurl"]},"text/vnd.curl.mcurl":{"source":"apache","extensions":["mcurl"]},"text/vnd.curl.scurl":{"source":"apache","extensions":["scurl"]},"text/vnd.debian.copyright":{"source":"iana","charset":"UTF-8"},"text/vnd.dmclientscript":{"source":"iana"},"text/vnd.dvb.subtitle":{"source":"iana","extensions":["sub"]},"text/vnd.esmertec.theme-descriptor":{"source":"iana","charset":"UTF-8"},"text/vnd.familysearch.gedcom":{"source":"iana","extensions":["ged"]},"text/vnd.ficlab.flt":{"source":"iana"},"text/vnd.fly":{"source":"iana","extensions":["fly"]},"text/vnd.fmi.flexstor":{"source":"iana","extensions":["flx"]},"text/vnd.gml":{"source":"iana"},"text/vnd.graphviz":{"source":"iana","extensions":["gv"]},"text/vnd.hans":{"source":"iana"},"text/vnd.hgl":{"source":"iana"},"text/vnd.in3d.3dml":{"source":"iana","extensions":["3dml"]},"text/vnd.in3d.spot":{"source":"iana","extensions":["spot"]},"text/vnd.iptc.newsml":{"source":"iana"},"text/vnd.iptc.nitf":{"source":"iana"},"text/vnd.latex-z":{"source":"iana"},"text/vnd.motorola.reflex":{"source":"iana"},"text/vnd.ms-mediapackage":{"source":"iana"},"text/vnd.net2phone.commcenter.command":{"source":"iana"},"text/vnd.radisys.msml-basic-layout":{"source":"iana"},"text/vnd.senx.warpscript":{"source":"iana"},"text/vnd.si.uricatalogue":{"source":"iana"},"text/vnd.sosi":{"source":"iana"},"text/vnd.sun.j2me.app-descriptor":{"source":"iana","charset":"UTF-8","extensions":["jad"]},"text/vnd.trolltech.linguist":{"source":"iana","charset":"UTF-8"},"text/vnd.wap.si":{"source":"iana"},"text/vnd.wap.sl":{"source":"iana"},"text/vnd.wap.wml":{"source":"iana","extensions":["wml"]},"text/vnd.wap.wmlscript":{"source":"iana","extensions":["wmls"]},"text/vtt":{"source":"iana","charset":"UTF-8","compressible":true,"extensions":["vtt"]},"text/x-asm":{"source":"apache","extensions":["s","asm"]},"text/x-c":{"source":"apache","extensions":["c","cc","cxx","cpp","h","hh","dic"]},"text/x-component":{"source":"nginx","extensions":["htc"]},"text/x-fortran":{"source":"apache","extensions":["f","for","f77","f90"]},"text/x-gwt-rpc":{"compressible":true},"text/x-handlebars-template":{"extensions":["hbs"]},"text/x-java-source":{"source":"apache","extensions":["java"]},"text/x-jquery-tmpl":{"compressible":true},"text/x-lua":{"extensions":["lua"]},"text/x-markdown":{"compressible":true,"extensions":["mkd"]},"text/x-nfo":{"source":"apache","extensions":["nfo"]},"text/x-opml":{"source":"apache","extensions":["opml"]},"text/x-org":{"compressible":true,"extensions":["org"]},"text/x-pascal":{"source":"apache","extensions":["p","pas"]},"text/x-processing":{"compressible":true,"extensions":["pde"]},"text/x-sass":{"extensions":["sass"]},"text/x-scss":{"extensions":["scss"]},"text/x-setext":{"source":"apache","extensions":["etx"]},"text/x-sfv":{"source":"apache","extensions":["sfv"]},"text/x-suse-ymp":{"compressible":true,"extensions":["ymp"]},"text/x-uuencode":{"source":"apache","extensions":["uu"]},"text/x-vcalendar":{"source":"apache","extensions":["vcs"]},"text/x-vcard":{"source":"apache","extensions":["vcf"]},"text/xml":{"source":"iana","compressible":true,"extensions":["xml"]},"text/xml-external-parsed-entity":{"source":"iana"},"text/yaml":{"compressible":true,"extensions":["yaml","yml"]},"video/1d-interleaved-parityfec":{"source":"iana"},"video/3gpp":{"source":"iana","extensions":["3gp","3gpp"]},"video/3gpp-tt":{"source":"iana"},"video/3gpp2":{"source":"iana","extensions":["3g2"]},"video/av1":{"source":"iana"},"video/bmpeg":{"source":"iana"},"video/bt656":{"source":"iana"},"video/celb":{"source":"iana"},"video/dv":{"source":"iana"},"video/encaprtp":{"source":"iana"},"video/ffv1":{"source":"iana"},"video/flexfec":{"source":"iana"},"video/h261":{"source":"iana","extensions":["h261"]},"video/h263":{"source":"iana","extensions":["h263"]},"video/h263-1998":{"source":"iana"},"video/h263-2000":{"source":"iana"},"video/h264":{"source":"iana","extensions":["h264"]},"video/h264-rcdo":{"source":"iana"},"video/h264-svc":{"source":"iana"},"video/h265":{"source":"iana"},"video/iso.segment":{"source":"iana","extensions":["m4s"]},"video/jpeg":{"source":"iana","extensions":["jpgv"]},"video/jpeg2000":{"source":"iana"},"video/jpm":{"source":"apache","extensions":["jpm","jpgm"]},"video/jxsv":{"source":"iana"},"video/mj2":{"source":"iana","extensions":["mj2","mjp2"]},"video/mp1s":{"source":"iana"},"video/mp2p":{"source":"iana"},"video/mp2t":{"source":"iana","extensions":["ts"]},"video/mp4":{"source":"iana","compressible":false,"extensions":["mp4","mp4v","mpg4"]},"video/mp4v-es":{"source":"iana"},"video/mpeg":{"source":"iana","compressible":false,"extensions":["mpeg","mpg","mpe","m1v","m2v"]},"video/mpeg4-generic":{"source":"iana"},"video/mpv":{"source":"iana"},"video/nv":{"source":"iana"},"video/ogg":{"source":"iana","compressible":false,"extensions":["ogv"]},"video/parityfec":{"source":"iana"},"video/pointer":{"source":"iana"},"video/quicktime":{"source":"iana","compressible":false,"extensions":["qt","mov"]},"video/raptorfec":{"source":"iana"},"video/raw":{"source":"iana"},"video/rtp-enc-aescm128":{"source":"iana"},"video/rtploopback":{"source":"iana"},"video/rtx":{"source":"iana"},"video/scip":{"source":"iana"},"video/smpte291":{"source":"iana"},"video/smpte292m":{"source":"iana"},"video/ulpfec":{"source":"iana"},"video/vc1":{"source":"iana"},"video/vc2":{"source":"iana"},"video/vnd.cctv":{"source":"iana"},"video/vnd.dece.hd":{"source":"iana","extensions":["uvh","uvvh"]},"video/vnd.dece.mobile":{"source":"iana","extensions":["uvm","uvvm"]},"video/vnd.dece.mp4":{"source":"iana"},"video/vnd.dece.pd":{"source":"iana","extensions":["uvp","uvvp"]},"video/vnd.dece.sd":{"source":"iana","extensions":["uvs","uvvs"]},"video/vnd.dece.video":{"source":"iana","extensions":["uvv","uvvv"]},"video/vnd.directv.mpeg":{"source":"iana"},"video/vnd.directv.mpeg-tts":{"source":"iana"},"video/vnd.dlna.mpeg-tts":{"source":"iana"},"video/vnd.dvb.file":{"source":"iana","extensions":["dvb"]},"video/vnd.fvt":{"source":"iana","extensions":["fvt"]},"video/vnd.hns.video":{"source":"iana"},"video/vnd.iptvforum.1dparityfec-1010":{"source":"iana"},"video/vnd.iptvforum.1dparityfec-2005":{"source":"iana"},"video/vnd.iptvforum.2dparityfec-1010":{"source":"iana"},"video/vnd.iptvforum.2dparityfec-2005":{"source":"iana"},"video/vnd.iptvforum.ttsavc":{"source":"iana"},"video/vnd.iptvforum.ttsmpeg2":{"source":"iana"},"video/vnd.motorola.video":{"source":"iana"},"video/vnd.motorola.videop":{"source":"iana"},"video/vnd.mpegurl":{"source":"iana","extensions":["mxu","m4u"]},"video/vnd.ms-playready.media.pyv":{"source":"iana","extensions":["pyv"]},"video/vnd.nokia.interleaved-multimedia":{"source":"iana"},"video/vnd.nokia.mp4vr":{"source":"iana"},"video/vnd.nokia.videovoip":{"source":"iana"},"video/vnd.objectvideo":{"source":"iana"},"video/vnd.radgamettools.bink":{"source":"iana"},"video/vnd.radgamettools.smacker":{"source":"iana"},"video/vnd.sealed.mpeg1":{"source":"iana"},"video/vnd.sealed.mpeg4":{"source":"iana"},"video/vnd.sealed.swf":{"source":"iana"},"video/vnd.sealedmedia.softseal.mov":{"source":"iana"},"video/vnd.uvvu.mp4":{"source":"iana","extensions":["uvu","uvvu"]},"video/vnd.vivo":{"source":"iana","extensions":["viv"]},"video/vnd.youtube.yt":{"source":"iana"},"video/vp8":{"source":"iana"},"video/vp9":{"source":"iana"},"video/webm":{"source":"apache","compressible":false,"extensions":["webm"]},"video/x-f4v":{"source":"apache","extensions":["f4v"]},"video/x-fli":{"source":"apache","extensions":["fli"]},"video/x-flv":{"source":"apache","compressible":false,"extensions":["flv"]},"video/x-m4v":{"source":"apache","extensions":["m4v"]},"video/x-matroska":{"source":"apache","compressible":false,"extensions":["mkv","mk3d","mks"]},"video/x-mng":{"source":"apache","extensions":["mng"]},"video/x-ms-asf":{"source":"apache","extensions":["asf","asx"]},"video/x-ms-vob":{"source":"apache","extensions":["vob"]},"video/x-ms-wm":{"source":"apache","extensions":["wm"]},"video/x-ms-wmv":{"source":"apache","compressible":false,"extensions":["wmv"]},"video/x-ms-wmx":{"source":"apache","extensions":["wmx"]},"video/x-ms-wvx":{"source":"apache","extensions":["wvx"]},"video/x-msvideo":{"source":"apache","extensions":["avi"]},"video/x-sgi-movie":{"source":"apache","extensions":["movie"]},"video/x-smv":{"source":"apache","extensions":["smv"]},"x-conference/x-cooltalk":{"source":"apache","extensions":["ice"]},"x-shader/x-fragment":{"compressible":true},"x-shader/x-vertex":{"compressible":true}}');
/***/ })
/******/ });
/************************************************************************/
/******/ // The module cache
/******/ var __webpack_module_cache__ = {};
/******/
/******/ // The require function
/******/ function __webpack_require__(moduleId) {
/******/ // Check if module is in cache
/******/ var cachedModule = __webpack_module_cache__[moduleId];
/******/ if (cachedModule !== undefined) {
/******/ return cachedModule.exports;
/******/ }
/******/ // Create a new module (and put it into the cache)
/******/ var module = __webpack_module_cache__[moduleId] = {
/******/ id: moduleId,
/******/ // no module.loaded needed
/******/ exports: {}
/******/ };
/******/
/******/ // Execute the module function
/******/ __webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);
/******/
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/
/************************************************************************/
/******/ /* webpack/runtime/async module */
/******/ (() => {
/******/ var webpackQueues = typeof Symbol === "function" ? Symbol("webpack queues") : "__webpack_queues__";
/******/ var webpackExports = typeof Symbol === "function" ? Symbol("webpack exports") : "__webpack_exports__";
/******/ var webpackError = typeof Symbol === "function" ? Symbol("webpack error") : "__webpack_error__";
/******/ var resolveQueue = (queue) => {
/******/ if(queue && queue.d < 1) {
/******/ queue.d = 1;
/******/ queue.forEach((fn) => (fn.r--));
/******/ queue.forEach((fn) => (fn.r-- ? fn.r++ : fn()));
/******/ }
/******/ }
/******/ var wrapDeps = (deps) => (deps.map((dep) => {
/******/ if(dep !== null && typeof dep === "object") {
/******/ if(dep[webpackQueues]) return dep;
/******/ if(dep.then) {
/******/ var queue = [];
/******/ queue.d = 0;
/******/ dep.then((r) => {
/******/ obj[webpackExports] = r;
/******/ resolveQueue(queue);
/******/ }, (e) => {
/******/ obj[webpackError] = e;
/******/ resolveQueue(queue);
/******/ });
/******/ var obj = {};
/******/ obj[webpackQueues] = (fn) => (fn(queue));
/******/ return obj;
/******/ }
/******/ }
/******/ var ret = {};
/******/ ret[webpackQueues] = x => {};
/******/ ret[webpackExports] = dep;
/******/ return ret;
/******/ }));
/******/ __webpack_require__.a = (module, body, hasAwait) => {
/******/ var queue;
/******/ hasAwait && ((queue = []).d = -1);
/******/ var depQueues = new Set();
/******/ var exports = module.exports;
/******/ var currentDeps;
/******/ var outerResolve;
/******/ var reject;
/******/ var promise = new Promise((resolve, rej) => {
/******/ reject = rej;
/******/ outerResolve = resolve;
/******/ });
/******/ promise[webpackExports] = exports;
/******/ promise[webpackQueues] = (fn) => (queue && fn(queue), depQueues.forEach(fn), promise["catch"](x => {}));
/******/ module.exports = promise;
/******/ body((deps) => {
/******/ currentDeps = wrapDeps(deps);
/******/ var fn;
/******/ var getResult = () => (currentDeps.map((d) => {
/******/ if(d[webpackError]) throw d[webpackError];
/******/ return d[webpackExports];
/******/ }))
/******/ var promise = new Promise((resolve) => {
/******/ fn = () => (resolve(getResult));
/******/ fn.r = 0;
/******/ var fnQueue = (q) => (q !== queue && !depQueues.has(q) && (depQueues.add(q), q && !q.d && (fn.r++, q.push(fn))));
/******/ currentDeps.map((dep) => (dep[webpackQueues](fnQueue)));
/******/ });
/******/ return fn.r ? promise : getResult();
/******/ }, (err) => ((err ? reject(promise[webpackError] = err) : outerResolve(exports)), resolveQueue(queue)));
/******/ queue && queue.d < 0 && (queue.d = 0);
/******/ };
/******/ })();
/******/
/******/ /* webpack/runtime/compat get default export */
/******/ (() => {
/******/ // getDefaultExport function for compatibility with non-harmony modules
/******/ __webpack_require__.n = (module) => {
/******/ var getter = module && module.__esModule ?
/******/ () => (module['default']) :
/******/ () => (module);
/******/ __webpack_require__.d(getter, { a: getter });
/******/ return getter;
/******/ };
/******/ })();
/******/
/******/ /* webpack/runtime/define property getters */
/******/ (() => {
/******/ // define getter functions for harmony exports
/******/ __webpack_require__.d = (exports, definition) => {
/******/ for(var key in definition) {
/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
/******/ }
/******/ }
/******/ };
/******/ })();
/******/
/******/ /* webpack/runtime/global */
/******/ (() => {
/******/ __webpack_require__.g = (function() {
/******/ if (typeof globalThis === 'object') return globalThis;
/******/ try {
/******/ return this || new Function('return this')();
/******/ } catch (e) {
/******/ if (typeof window === 'object') return window;
/******/ }
/******/ })();
/******/ })();
/******/
/******/ /* webpack/runtime/hasOwnProperty shorthand */
/******/ (() => {
/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
/******/ })();
/******/
/******/ /* webpack/runtime/make namespace object */
/******/ (() => {
/******/ // define __esModule on exports
/******/ __webpack_require__.r = (exports) => {
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
/******/ }
/******/ Object.defineProperty(exports, '__esModule', { value: true });
/******/ };
/******/ })();
/******/
/************************************************************************/
var __webpack_exports__ = {};
// This entry need to be wrapped in an IIFE because it need to be in strict mode.
(() => {
"use strict";
// EXTERNAL MODULE: ./src/lib/GM.ts
var src_GM = __webpack_require__("./src/lib/GM.ts");
// EXTERNAL MODULE: ./node_modules/loglevel/lib/loglevel.js
var loglevel = __webpack_require__("./node_modules/loglevel/lib/loglevel.js");
var loglevel_default = /*#__PURE__*/__webpack_require__.n(loglevel);
;// ./src/lib/localStorageExpired.ts
function storageAvailable(type) {
let storage;
try {
storage = window[type];
const x = "__storage_test__";
storage.setItem(x, x);
storage.removeItem(x);
return true;
}
catch (e) {
return (e instanceof DOMException &&
(e.code === 22 ||
e.code === 1014 ||
e.name === "QuotaExceededError" ||
e.name === "NS_ERROR_DOM_QUOTA_REACHED") &&
storage &&
storage.length !== 0);
}
}
class LocalStorageExpired {
storage;
constructor() {
if (storageAvailable("localStorage")) {
this.storage = window.localStorage;
this.init();
}
else {
throw new Error("当前浏览器不支持 localStorage");
}
}
set(key, value, expired) {
const storage = this.storage;
try {
storage[key] = JSON.stringify(value);
if (expired) {
storage[`${key}__expires__`] = Date.now() + 1000 * expired;
}
}
catch (error) {
loglevel_default().error(error);
}
}
get(key) {
const storage = this.storage;
const expired = storage[`${key}__expires__`] ?? false;
const now = Date.now();
if (expired && now >= expired) {
this.remove(key);
return;
}
if (expired) {
try {
return JSON.parse(storage[key]);
}
catch (error) {
return storage[key];
}
}
else {
return storage[key];
}
}
remove(key) {
const storage = this.storage;
if (storage[key]) {
delete storage[key];
if (storage[`${key}__expires__`]) {
delete storage[`${key}__expires__`];
}
}
}
init() {
const reg = new RegExp("__expires__$");
const storage = this.storage;
const keys = Object.keys(storage);
keys.forEach((key) => {
if (!reg.test(key)) {
this.get(key);
}
});
}
}
// EXTERNAL MODULE: ./src/setting.ts
var src_setting = __webpack_require__("./src/setting.ts");
;// ./src/detect.ts
function checkObjct(name) {
const target = window[name];
const targetLength = target.toString().length;
const targetPrototype = target.prototype;
const nativeFunctionRe = /function \w+\(\) {\n?(\s+)?\[native code]\n?(\s+)?}/;
try {
if (targetPrototype === undefined ||
Boolean(target.toString().match(nativeFunctionRe))) {
return [true, targetLength].join(", ");
}
}
catch {
return [true, targetLength].join(", ");
}
return [false, targetLength].join(", ");
}
function src_streamSupport() {
return (typeof ReadableStream !== "undefined" &&
typeof WritableStream !== "undefined" &&
typeof TransformStream !== "undefined");
}
function src_mitmPageAvailability(url) {
return new Promise((resolve, reject) => {
fetchWithTimeout(url, {}, 2500)
.then((resp) => resolve(true))
.catch((error) => resolve(false));
});
}
async function TM_4_14_bug_Detect() {
if (src_GM/* _GM_info */.JX.scriptHandler === "Tampermonkey" &&
src_GM/* _GM_info */.JX.version?.startsWith("4.14")) {
const blob = new Blob(["test"]);
const arrayBuffer = await blob.arrayBuffer();
if (arrayBuffer === undefined) {
alert(`检测到您当前使用的脚本管理器为 Tampermonkey 4.14。
Tampermonkey 4.14 因存在 Bug 将导致小说下载器脚本无法正常运行,详情可参见:https://github.com/Tampermonkey/tampermonkey/issues/1418 。
如您想继续使用小说下载器脚本,请您更换 Tampermonkey 版本,或使用 Violentmonkey 脚本管理器。
如果您不欲降级或更换脚本管理器,同时不想再看到本提示,您可以暂时禁用小说下载器脚本。`);
throw new Error("Tampermonkey 4.14 Bug Detect");
}
}
}
const environments = async () => {
await TM_4_14_bug_Detect();
return {
当前时间: new Date().toISOString(),
当前页URL: document.location.href,
workerId: window.workerId,
当前页Referrer: document.referrer,
浏览器UA: navigator.userAgent,
浏览器语言: navigator.languages,
设备运行平台: navigator.platform,
设备内存: navigator.deviceMemory ?? "",
CPU核心数: navigator.hardwareConcurrency,
eval: checkObjct("eval"),
fetch: checkObjct("fetch"),
XMLHttpRequest: checkObjct("XMLHttpRequest"),
streamSupport: src_streamSupport(),
window: Object.keys(window).length,
localStorage: storageAvailable("localStorage"),
sessionStorage: storageAvailable("sessionStorage"),
Cookie: navigator.cookieEnabled,
doNotTrack: navigator.doNotTrack ?? 0,
enableDebug: src_setting/* enableDebug */.Nw.value,
TxtDownload: src_setting/* TxtDownload */.Jv.value,
EpubDownload: src_setting/* EpubDownload */.Zz.value,
ScriptHandler: src_GM/* _GM_info */.JX.scriptHandler,
"ScriptHandler version": src_GM/* _GM_info */.JX.version,
"Novel-downloader version": src_GM/* _GM_info */.JX.script.version,
};
};
// EXTERNAL MODULE: ./src/lib/misc.ts
var misc = __webpack_require__("./src/lib/misc.ts");
;// ./src/global.ts
function init() {
window.workerId = (0,misc/* randomUUID */.N4)();
window.downloading = false;
window.localStorageExpired = new LocalStorageExpired();
const stopController = new AbortController();
const stopFlag = stopController.signal;
window.stopController = stopController;
window.stopFlag = stopFlag;
window.failedCount = 0;
}
// EXTERNAL MODULE: external "Vue"
var external_Vue_ = __webpack_require__("vue");
;// ./src/ui/fixVue.ts
globalThis.Function = new Proxy(Function, {
construct(target, args) {
const code = args[args.length - 1];
if (code.includes("Vue") && code.includes("_Vue")) {
loglevel_default().debug("Function hook:" + code);
return hookVue();
}
else {
return new target(...args);
}
function hookVue() {
args[args.length - 1] = "with (Vue) {" + code + "}";
return new Proxy(new target(...["Vue", ...args]), {
apply(targetI, thisArg, argumentsList) {
const newArgumentsList = [external_Vue_, ...argumentsList];
return Reflect.apply(targetI, thisArg, newArgumentsList);
},
});
}
},
});
// EXTERNAL MODULE: ./src/lib/dom.ts
var dom = __webpack_require__("./src/lib/dom.ts");
;// ./src/router/download.ts
async function getRule() {
const host = document.location.host;
let ruleClass;
switch (host) {
case "www.biquge66.com":
case "www.xkzw.org": {
const { Xkzw } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/reprint/xkzw.ts"));
ruleClass = Xkzw;
break;
}
case "book.sfacg.com": {
const { Sfacg } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/original/sfacg.ts"));
ruleClass = Sfacg;
break;
}
case "www.hetushu.com":
case "hetushu.com": {
const { Hetushu } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/reprint/hetushu.ts"));
ruleClass = Hetushu;
break;
}
case "book.qidian.com":
case "www.qidian.com": {
const { Qidian } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/original/qidian.ts"));
ruleClass = Qidian;
break;
}
case "www.jjwxc.net": {
const { Jjwxc } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/original/jjwxc.ts"));
ruleClass = Jjwxc;
break;
}
case "www.zongheng.com":
case "book.zongheng.com":
case "huayu.zongheng.com": {
const { Zongheng } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/original/zongheng.ts"));
ruleClass = Zongheng;
break;
}
case "www.17k.com": {
const { C17k } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/original/17k.ts"));
ruleClass = C17k;
break;
}
case "www.shuhai.com":
case "mm.shuhai.com": {
const { Shuhai } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/original/shuhai.ts"));
ruleClass = Shuhai;
break;
}
case "gongzicp.com":
case "www.gongzicp.com":
case "m.gongzicp.com": {
const { Gongzicp } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/original/gongzicp.ts"));
ruleClass = Gongzicp;
break;
}
case "www.linovel.net": {
const { Linovel } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/original/linovel.ts"));
ruleClass = Linovel;
break;
}
case "www.tadu.com": {
const { Tadu } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/original/tadu.ts"));
ruleClass = Tadu;
break;
}
case "www.idejian.com": {
const { Idejian } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/reprint/idejian.ts"));
ruleClass = Idejian;
break;
}
case "www.qimao.com": {
const { Qimao } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/original/qimao.ts"));
ruleClass = Qimao;
break;
}
case "manhua.idmzj.com":
case "www.idmzj.com": {
const { Dmzj } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/reprint/dmzj.ts"));
ruleClass = Dmzj;
break;
}
case "sosad.fun":
case "www.sosad.fun":
case "wenzhan.org":
case "www.wenzhan.org":
case "sosadfun.com":
case "www.sosadfun.com":
case "xn--pxtr7m5ny.com":
case "www.xn--pxtr7m5ny.com":
case "xn--pxtr7m.com":
case "www.xn--pxtr7m.com":
case "xn--pxtr7m5ny.net":
case "www.xn--pxtr7m5ny.net":
case "xn--pxtr7m.net":
case "www.xn--pxtr7m.net":
case "sosadfun.link":
case "www.sosadfun.link": {
const { Sosadfun } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/original/sosadfun.ts"));
ruleClass = Sosadfun;
break;
}
case "www.fushuwang.org": {
const { Fushuwang } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/reprint/fushuwang.ts"));
ruleClass = Fushuwang;
break;
}
case regExpMatch(/lofter\.com$/): {
const { Lofter } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/original/lofter.ts"));
ruleClass = Lofter;
break;
}
case "www.shubl.com": {
const { Shubl } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/original/ciweimao.ts"));
ruleClass = Shubl;
break;
}
case "m.haitangtxt.net": {
const { haitangtxt } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/reprint/haitangtxt.ts"));
ruleClass = haitangtxt();
break;
}
case "m.yushuge123.com": {
const { yuzhaige } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/reprint/haitangtxt.ts"));
ruleClass = yuzhaige();
break;
}
case "ebook.longmabook.com":
case "www.longmabookcn.com":
case "ebook.lmbooks.com":
case "www.lmebooks.com":
case "www.haitbook.com":
case "www.htwhbook.com":
case "www.myhtebook.com":
case "www.lovehtbooks.com":
case "www.myhtebooks.com":
case "www.myhtlmebook.com":
case "jp.myhtebook.com":
case "jp.myhtlmebook.com":
case "ebook.urhtbooks.com":
case "www.urhtbooks.com":
case "www.newhtbook.com":
case "www.lvhtebook.com":
case "jp.lvhtebook.com":
case "www.haitangbook.com":
case "www.htlvbooks.com": {
const { Longmabook } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/original/longmabook.ts"));
ruleClass = Longmabook;
break;
}
case "www.kanunu8.com": {
const { Kanunu8 } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/reprint/kanunu8.ts"));
ruleClass = Kanunu8;
break;
}
case "www.ciyuanji.com": {
const { Ciyuanji } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/original/ciyuanji.ts"));
ruleClass = Ciyuanji;
break;
}
case "www.pixiv.net": {
const { Pixiv } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/original/pixiv.ts"));
ruleClass = Pixiv;
break;
}
case "www.myrics.com": {
const { Myrics } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/original/myrics.ts"));
ruleClass = Myrics;
break;
}
case "www.hanwujinian.com": {
const { Hanwujinian } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/original/hanwujinian.ts"));
ruleClass = Hanwujinian;
break;
}
case "manga.bilibili.com": {
const { MangaBilibili } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/original/bilibili.ts"));
ruleClass = MangaBilibili;
break;
}
case "www.cool18.com": {
const { Cool18 } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/original/cool18.ts"));
ruleClass = Cool18;
break;
}
case "www.xrzww.com":
case "xrzww.com": {
const { Xrzww } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/original/xrzww.ts"));
ruleClass = Xrzww;
break;
}
case "www.youdubook.com":
case "youdubook.com": {
const { Youdubook } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/original/youdubook.ts"));
ruleClass = Youdubook;
break;
}
case "new-read.readmoo.com": {
const { Readmoo } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/original/readmoo.ts"));
ruleClass = Readmoo;
break;
}
case "www.iqingguo.com": {
const { Iqingguo } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/original/iqingguo.ts"));
ruleClass = Iqingguo;
break;
}
case "www.duread.cn": {
const { Duread } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/original/ciweimao.ts"));
ruleClass = Duread;
break;
}
case "www.ttkan.co":
case "cn.ttkan.co":
case "tw.ttkan.co": {
const { Ttkan } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/special/reprint/ttkan.ts"));
ruleClass = Ttkan;
break;
}
case "www.uukanshu.com": {
const { uukanshu } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePage/uukanshu.ts"));
ruleClass = uukanshu();
break;
}
case "www.westnovel.com": {
const { westnovel } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePage/westnovel.ts"));
ruleClass = westnovel();
break;
}
case "www.soxscc.net":
case "www.soxscc.org":
case "www.soxs.cc":
case "www.soxscc.cc":
case "www.soshuwu.com": {
const { soxscc } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePage/soxscc.ts"));
ruleClass = soxscc();
break;
}
case "www.630shu.net": {
const { c630shu } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePage/630shu.ts"));
ruleClass = c630shu;
break;
}
case "www.trxs.cc":
case "www.trxs.me":
case "www.trxs123.com":
case "www.jpxs123.com":
case "www.tongrenquan.org":
case "www.tongrenquan.me":
case "trxs.cc":
case "trxs.me":
case "trxs123.com":
case "jpxs123.com":
case "tongrenquan.me":
case "tongrenquan.org": {
const { trxs } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePage/trxs.ts"));
ruleClass = trxs();
break;
}
case "www.256wenku.com": {
const { c256wxc } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePage/256wxc.ts"));
ruleClass = c256wxc;
break;
}
case "www.xiaoshuowanben.com": {
const { wanben } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePage/wanben.ts"));
ruleClass = wanben();
break;
}
case "masiro.me": {
const { masiro } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePage/original/masiro.ts"));
ruleClass = masiro();
break;
}
case "kakuyomu.jp": {
const { kakuyomu } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePage/original/kakuyomu.ts"));
ruleClass = kakuyomu();
break;
}
case "ncode.syosetu.com":
case "novel18.syosetu.com": {
const { syosetu } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePage/original/syosetu.ts"));
ruleClass = syosetu();
break;
}
case "syosetu.org": {
const { syosetuOrg } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePage/original/syosetu.ts"));
ruleClass = syosetuOrg();
break;
}
case "zhaoze.vip":
case "houhuayuan.vip": {
const { houhuayuan } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePage/original/houhuayuan.ts"));
ruleClass = houhuayuan();
break;
}
case "www.tianyabooks.com": {
const { tianyabooks } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePage/tianyabooks.ts"));
ruleClass = tianyabooks();
break;
}
case "www.aixdzs.com": {
const { aixdzs } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePage/aixdzs.ts"));
ruleClass = aixdzs();
break;
}
case "colorful-fantasybooks.com": {
const { fantasybooks } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePage/colorful-fantasybooks.ts"));
ruleClass = fantasybooks();
break;
}
case "www.dizishu.com": {
const { dizishu } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePage/dizishu.ts"));
ruleClass = dizishu();
break;
}
case "www.akatsuki-novels.com": {
const { akatsuki } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePage/original/akatsuki.ts"));
ruleClass = akatsuki();
break;
}
case "www.alphapolis.co.jp": {
const { alphapolis } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePage/original/alphapolis.ts"));
ruleClass = alphapolis();
break;
}
case "hongxiuzhao.me": {
const { hongxiuzhao } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePage/hongxiuzhao.ts"));
ruleClass = hongxiuzhao();
break;
}
case "www.xbyuan.com": {
const { xbyuan } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePage/xbyuan.ts"));
ruleClass = xbyuan();
break;
}
case "www.quanzhifashi.com": {
const { qzxsw } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePage/qzxsw.ts"));
ruleClass = qzxsw();
break;
}
case "www.boqugew.com": {
const { boqugew } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePage/boqugew.ts"));
ruleClass = boqugew();
break;
}
case "www.qbtr.cc": {
const { qbtrcc } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePage/qbtrcc.ts"));
ruleClass = qbtrcc();
break;
}
case "b.guidaye.com": {
const { guidaye } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePage/guidaye.ts"));
ruleClass = await guidaye();
break;
}
case "m.baihexs.com": {
const { baihexs } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePageWithMultiIndexPage/baihexs.ts"));
ruleClass = baihexs();
break;
}
case "novelup.plus": {
const { novelup } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePageWithMultiIndexPage/original/novelup.ts"));
ruleClass = novelup();
break;
}
case "www.piaotia.com": {
const { ptwxz } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePage/original/ptwxz.ts"));
ruleClass = ptwxz();
break;
}
case "m.xiaoshuowanben.com": {
const { wanben } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePageWithMultiIndexPage/wanben.ts"));
ruleClass = wanben();
break;
}
case "www.1pwx.com": {
const { xiaoshuodaquan } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/twoPage/1pwx.ts"));
ruleClass = xiaoshuodaquan();
break;
}
case "www.wenku8.net": {
const { wenku8 } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/twoPage/wenku8.ts"));
ruleClass = wenku8();
break;
}
case "www.linovelib.com": {
const { linovelib } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/twoPage/linovelib.ts"));
ruleClass = linovelib();
break;
}
case "www.bilinovel.com": {
const { wlinovelib } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/twoPage/linovelib.ts"));
ruleClass = wlinovelib();
break;
}
case "www.yibige.cc": {
const { yibige } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/twoPage/yibige.ts"));
ruleClass = yibige();
break;
}
case "www.wangshugu.org": {
const { washuge } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/twoPage/washuge.ts"));
ruleClass = washuge();
break;
}
case "www.shencou.com": {
const { shencou } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/twoPage/shencou.ts"));
ruleClass = shencou();
break;
}
case "jingcaiyuedu6.com": {
const { jingcaiyuedu6 } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/twoPage/jingcaiyuedu6.ts"));
ruleClass = jingcaiyuedu6();
break;
}
case "www.18kanshu.com": {
const { c18kanshu } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/twoPage/18kanshu.ts"));
ruleClass = c18kanshu();
break;
}
case "www.xiaoshuowu.com": {
const { xiaoshuowu } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/twoPage/xiaoshuowu.ts"));
ruleClass = xiaoshuowu();
break;
}
case "69shuba.cx": {
const { c69shu } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePageWithMultiIndexPage/69shu.ts"));
ruleClass = c69shu();
break;
}
case "book.xbookcn.net": {
const { xbookcn } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePageWithMultiIndexPage/xbookcn.ts"));
ruleClass = xbookcn();
break;
}
case "www.quanshuzhai.com": {
const { quanshuzhai } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/mbtxt/quanshuzhai.ts"));
ruleClass = quanshuzhai();
break;
}
case "www.mbtxt.la": {
const { mbtxt } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/mbtxt/mbtxt.ts"));
ruleClass = mbtxt();
break;
}
case "www.81book.com":
case "www.81zw.com":
case "www.fuguoduxs.com":
case "www.shubaowa.org":
case "www.aixiaxs.net":
case "www.banzhuer.org":
case "www.007zw.com": {
const { common } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/biquge/onePage.ts"));
ruleClass = common();
break;
}
case "www.mht99.com": {
const { mht } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/biquge/mht.ts"));
ruleClass = mht();
break;
}
case "www.xsbiquge.la":
case "www.xbiquge.tw": {
const { xbiquge } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/biquge/onePage.ts"));
ruleClass = xbiquge();
break;
}
case "www.luoqiuzw.com": {
const { luoqiuzw } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/biquge/onePage.ts"));
ruleClass = luoqiuzw();
break;
}
case "dijiuben.com": {
const { dijiubook } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/biquge/onePage.ts"));
ruleClass = dijiubook();
break;
}
case "www.biquzw.la": {
const { biquwx } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/biquge/onePage.ts"));
ruleClass = biquwx();
break;
}
case "www.i25zw.com": {
const { c25zw } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/biquge/onePage.ts"));
ruleClass = c25zw();
break;
}
case "www.tycqzw.com": {
const { tycqxs } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/biquge/onePage.ts"));
ruleClass = tycqxs();
break;
}
case "www.ranwen.la": {
const { ranwen } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/biquge/onePage.ts"));
ruleClass = ranwen();
break;
}
case "www.lvsewx.com": {
const { lusetxt } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/biquge/onePage.ts"));
ruleClass = lusetxt();
break;
}
case "www.b5200.net": {
const { b5200 } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/biquge/onePage.ts"));
ruleClass = b5200();
break;
}
case "www.yqxsge.cc": {
const { yqxs } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/biquge/onePage.ts"));
ruleClass = yqxs();
break;
}
case "www.bixia3.com": {
const { bxwx333 } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/biquge/onePage.ts"));
ruleClass = bxwx333();
break;
}
case "www.ibiquge.la": {
const { xbiqugeLa } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/biquge/onePage.ts"));
ruleClass = xbiqugeLa();
break;
}
case "www.yiruan.la": {
const { yruan } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/biquge/onePage.ts"));
ruleClass = yruan();
break;
}
case "www.ishuquge.org": {
const { shuquge } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/biquge/onePage.ts"));
ruleClass = shuquge();
break;
}
case "www.gashuw.com": {
const { gebiqu } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/biquge/onePage.ts"));
ruleClass = gebiqu();
break;
}
case "www.lewenn.net": {
const { lewenn } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/biquge/onePage.ts"));
ruleClass = lewenn();
break;
}
case "www.xyb3.net": {
const { xyb3 } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/biquge/onePage.ts"));
ruleClass = xyb3();
break;
}
case "www.wanben.info": {
const { xinwanben } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/biquge/nextPage.ts"));
ruleClass = xinwanben();
break;
}
case "www.ywggzy.com": {
const { ywggzy } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/biquge/nextPage.ts"));
ruleClass = ywggzy();
break;
}
case "www.mijiashe.com": {
const { mijiashe } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/biquge/nextPage.ts"));
ruleClass = mijiashe();
break;
}
case "m.kuangguwenhua.com": {
const { znlzd } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/biquge/multiIndexNextPage.ts"));
ruleClass = znlzd();
break;
}
case "www.266ks.com": {
const { c226ks } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/biquge/multiIndexNextPage.ts"));
ruleClass = c226ks();
break;
}
case "www.42zw.la": {
const { la42zw } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/biquge/onePage.ts"));
ruleClass = la42zw();
break;
}
case "www.esjzone.cc":
case "www.esjzone.me": {
const { esjzone } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/rules/onePage/original/esjzone.ts"));
ruleClass = esjzone();
break;
}
default: {
throw new Error("Not Found Rule!");
}
}
return new ruleClass();
function regExpMatch(regexp) {
if (regexp.test(host)) {
return host;
}
}
}
;// ./src/lib/adBlocker.ts
function floatBuster() {
if (window !== window.top) {
return;
}
let tstart;
const ttl = 30000;
let delay = 0;
const delayStep = 50;
const buster = () => {
const button = document.querySelector("#button-div");
if (button) {
getFixNearby(button).forEach((node) => node.remove());
tstart = Date.now();
}
const progress = document.querySelector("#nd-progress");
if (progress) {
getFixNearby(progress).forEach((node) => node.remove());
tstart = Date.now();
}
const setting = document.querySelector("#nd-setting");
if (setting) {
getFixNearby(setting).forEach((node) => node.remove());
tstart = Date.now();
}
if (Date.now() - tstart < ttl) {
delay = Math.min(delay + delayStep, 1000);
setTimeout(buster, delay);
}
};
const domReady = (ev) => {
if (ev) {
document.removeEventListener(ev.type, domReady);
}
tstart = Date.now();
setTimeout(buster, delay);
};
if (document.readyState === "loading") {
document.addEventListener("DOMContentLoaded", domReady);
}
else {
domReady();
}
function getFixNearby(elem) {
return Array.from(document.querySelectorAll("body *")).filter((node) => {
const { position, visibility, zIndex } = window.getComputedStyle(node);
return (node !== elem &&
!(node.compareDocumentPosition(elem) &
Node.DOCUMENT_POSITION_CONTAINS ||
node.compareDocumentPosition(elem) &
Node.DOCUMENT_POSITION_CONTAINED_BY) &&
!["button-div", "nd-progress", "nd-setting"].includes(node.id) &&
visibility === "visible" &&
(position === "fixed" || parseInt(zIndex, 10) >= 1000) &&
(nearTest(node, elem) || parseInt(zIndex, 10) > 10 ** 9));
});
function nearTest(node, element) {
if (isOverlap(getVertex(node), getVertex(element))) {
return true;
}
else {
return isNearby(getVertex(node), getVertex(element));
}
function getVertex(ele) {
const { left, top, right, bottom } = ele.getBoundingClientRect();
return [
[left, top],
[right, top],
[left, bottom],
[right, bottom],
];
}
function isOverlap(rec1, rec2) {
const [left1, top1] = rec1[0];
const [right1, bottom1] = rec1[3];
const [left2, top2] = rec2[0];
const [right2, bottom2] = rec2[3];
return (!(right1 < left2 || right2 < left1) &&
!(bottom1 < top2 || bottom2 < top1));
}
function isNearby(rec1, rec2) {
const docEl = document.documentElement;
const vw = Math.min(docEl.clientWidth, window.innerWidth);
const vh = Math.min(docEl.clientHeight, window.innerHeight);
const diagonal = Math.sqrt(vw ** 2 + vh ** 2);
for (const [x1, y1] of rec1) {
for (const [x2, y2] of rec2) {
const distance = Math.sqrt((x1 - x2) ** 2 + (y1 - y2) ** 2);
if (distance < diagonal * 0.1) {
return true;
}
}
}
return false;
}
}
}
}
;// ./src/router/ui.ts
const defaultObject = {
type: "download",
};
const errorObject = {
type: "error",
};
function getUI() {
const host = document.location.host;
switch (host) {
case "wap.ishuquge.org": {
return () => {
const id = /(\d+)\.html$/.exec(document.location.pathname)?.[1];
if (!id) {
return errorObject;
}
return {
type: "jump",
jumpFunction() {
document.location.href = `https://www.ishuquge.org/txt/${id}/index.html`;
},
};
};
}
case "m.wanben.info": {
return () => ({
type: "jump",
jumpFunction() {
document.location.host = "www.wanben.info";
},
});
}
case "www.tadu.com": {
return () => {
const re = /^\/book\/\d+\/?$/;
if (re.test(document.location.pathname)) {
return defaultObject;
}
else {
return errorObject;
}
};
}
case "www.kanunu8.com": {
return () => {
if (document.body.innerHTML.includes("作者:") ||
document.body.innerHTML.includes("作者:") ||
document.body.innerHTML.includes("内容简介")) {
return defaultObject;
}
else {
return errorObject;
}
};
}
case "www.ciyuanji.com": {
return () => {
if (document.location.pathname.startsWith("/bookDetails/info")) {
return {
type: "jump",
jumpFunction: () => (document.location.pathname = document.location.pathname.replace("/bookDetails/info", "/bookDetails/catalog")),
};
}
else {
return defaultObject;
}
};
}
case "m.jjwxc.com":
case "m.jjwxc.net": {
return () => {
return {
type: "jump",
jumpFunction: () => {
const regex = /https:\/\/m\.jjwxc\.(com|net)\/book2\/(\d+)/;
document.location.href = document.location.href.replace(regex, 'https://www.jjwxc.net/onebook.php?novelid=$2');
},
};
};
}
case "ebook.longmabook.com":
case "www.longmabookcn.com":
case "ebook.lmbooks.com":
case "www.lmebooks.com":
case "www.haitbook.com":
case "www.htwhbook.com":
case "www.myhtebook.com":
case "www.lovehtbooks.com":
case "www.myhtebooks.com":
case "www.myhtlmebook.com":
case "jp.myhtebook.com":
case "jp.myhtlmebook.com":
case "ebook.urhtbooks.com":
case "www.urhtbooks.com":
case "www.newhtbook.com":
case "www.lvhtebook.com":
case "jp.lvhtebook.com":
case "www.haitangbook.com":
case "www.htlvbooks.com": {
return () => {
const params = new URLSearchParams(document.location.search);
if (params.get("act") === "showinfo" &&
params.has("bookwritercode") &&
params.has("bookid")) {
return defaultObject;
}
return errorObject;
};
}
case "m.sfacg.com": {
return () => {
const bookId = /(\d+)\/?$/.exec(document.location.pathname)?.[1];
if (bookId) {
return {
type: "jump",
jumpFunction: () => (document.location.href = `https://book.sfacg.com/Novel/${bookId}/MainIndex/`),
};
}
else {
return errorObject;
}
};
}
case "book.sfacg.com": {
return () => {
const jump = /^\/Novel\/\d+\/?$/.test(document.location.pathname);
if (jump) {
const bookId = /(\d+)\/?$/.exec(document.location.pathname)?.[1];
if (bookId) {
return {
type: "jump",
jumpFunction: () => (document.location.href = `https://book.sfacg.com/Novel/${bookId}/MainIndex/`),
};
}
else {
return errorObject;
}
}
else {
return defaultObject;
}
};
}
case "m.lvsewx.com": {
return () => ({
type: "jump",
jumpFunction: () => (document.location.host = "www.lvsewx.com"),
});
}
case "www.cool18.com": {
return () => {
const url = new URL(document.location.href);
if (url.searchParams.get("act") === "threadview" &&
url.searchParams.has("tid")) {
return defaultObject;
}
else {
return errorObject;
}
};
}
case "www.zongheng.com":
case "book.zongheng.com":
case "huayu.zongheng.com": {
const style = document.createElement("style");
style.innerHTML = `
img {
font-size: 1em;
}
`;
document.head.appendChild(style);
return () => {
if (document.location.pathname.startsWith("/book/")) {
return {
type: "jump",
jumpFunction: () => (document.location.pathname = document.location.pathname.replace(/^\/book\//, "/showchapter/")),
};
}
else {
return defaultObject;
}
};
}
case "www.17k.com": {
return () => {
if (document.location.pathname.startsWith("/book/")) {
return {
type: "jump",
jumpFunction: () => (document.location.pathname = document.location.pathname.replace(/^\/book\//, "/list/")),
};
}
else {
return defaultObject;
}
};
}
case "www.linovelib.com": {
return () => {
if (document.location.pathname.endsWith(".html")) {
return {
type: "jump",
jumpFunction: () => (document.location.pathname = document.location.pathname.replace(/\.html$/, "/catalog")),
};
}
else {
return defaultObject;
}
};
}
case "www.bilinovel.com": {
return () => {
if (document.location.pathname.endsWith("/catalog")) {
return {
type: "jump",
jumpFunction: () => (document.location.pathname = document.location.pathname.replace(/\/catalog$/, ".html")),
};
}
else {
return defaultObject;
}
};
}
case "masiro.me": {
return () => {
if (document.querySelector(".error-box")) {
return errorObject;
}
else {
return defaultObject;
}
};
}
case "www.ywggzy.com":
case "www.yiruan.la":
case "www.ishuquge.org":
case "www.gashuw.com":
case "www.81book.com":
case "www.81zw.com":
case "www.fuguoduxs.com":
case "www.shubaowa.org":
case "www.aixiaxs.net":
case "www.banzhuer.org":
case "www.007zw.com":
case "www.wanben.info":
case "www.mht99.com":
case "www.xbiquge.tw":
case "www.xsbiquge.la":
case "www.luoqiuzw.com":
case "dijiuben.com":
case "www.biquzw.la":
case "www.i25zw.com":
case "www.tycqzw.com":
case "www.ranwen.la":
case "www.b5200.net":
case "www.yqxsge.cc":
case "www.bixia3.com":
case "www.quanshuzhai.com":
case "www.ibiquge.la": {
return () => {
floatBuster();
return defaultObject;
};
}
case "new-read.readmoo.com": {
return () => ({ type: "download", isSettingSeen: false });
}
case "www.myrics.com": {
return () => {
if (document.location.pathname.endsWith("/menu")) {
return {
type: "jump",
jumpFunction: () => {
document.location.pathname = document.location.pathname.replace(/\/menu$/, "");
},
};
}
else {
return defaultObject;
}
};
}
case "www.piaotia.com": {
return () => {
if (document.location.pathname.startsWith("/list/")) {
return {
type: "jump",
jumpFunction: () => {
const p = document.location.pathname.match(/\/list\/(\w+)\//)?.[1];
if (!p) {
return errorObject;
}
document.location.pathname = `/${p}/`;
},
};
}
else {
return defaultObject;
}
};
}
case "www.soxscc.net":
case "www.soxscc.org":
case "www.soxs.cc":
case "www.soxscc.cc":
case "www.soshuwu.com": {
return () => {
if (document.location.pathname.startsWith("/book/")) {
return {
type: "jump",
jumpFunction: () => {
document.location.pathname = document.location.pathname
.replace(/^\/book/, "")
.replace(/\.html/, "/");
},
};
}
else {
return defaultObject;
}
};
}
case "www.wenku8.net": {
return () => {
if (document.location.pathname.startsWith("/book/")) {
return {
type: "jump",
jumpFunction: () => {
const href = document.querySelector("#content > div:nth-child(1) > div:nth-child(6) > div:nth-child(1) > span:nth-child(1) > fieldset:nth-child(1) > div:nth-child(2) > a:nth-child(1)")?.href;
if (href) {
document.location.href = href;
}
else {
return errorObject;
}
},
};
}
else {
return defaultObject;
}
};
}
case "hongxiuzhao.me": {
return () => {
if (document.querySelector(".cover")) {
return defaultObject;
}
else {
return errorObject;
}
};
}
case "www.quanzhifashi.com":
case "www.42zw.la":
case "www.boqugew.com":
case "www.qbtr.cc":
case "b.guidaye.com":
case "www.qimao.com": {
return () => {
document.querySelector("li.qm-tab-list-item:nth-child(2) > div")?.dispatchEvent(new MouseEvent('click'));
return defaultObject;
};
}
default: {
return () => {
return defaultObject;
};
}
}
}
;// ./src/ui/button.html
// Module
var code = "<div id=\"button-div\" class=\"button-div\">\n <div v-if=\"uiObj.type !== 'error'\">\n <div v-if=\"uiObj.type === 'jump'\" class=\"jump\">\n <button class=\"jump\">\n <img alt=\"jump\" class=\"jump\" v-bind:src=\"imgJump\" v-on:click=\"jumpButtonClick\">\n </button>\n </div>\n <div v-if=\"uiObj.type === 'download'\" class=\"download\">\n <button class=\"start\">\n <img alt=\"start\" class=\"start\" v-bind:src=\"imgStart\" v-on:click=\"startButtonClick\">\n </button>\n <button v-if=\"isSettingSeen\" class=\"setting\">\n <img alt=\"setting\" class=\"setting\" v-bind:src=\"imgSetting\" v-on:click=\"settingButtonClick\">\n </button>\n </div>\n </div>\n</div>\n";
// Exports
/* harmony default export */ const ui_button = (code);
// EXTERNAL MODULE: ./src/ui/button.less
var src_ui_button = __webpack_require__("./src/ui/button.less");
// EXTERNAL MODULE: ./node_modules/file-saver/dist/FileSaver.min.js
var FileSaver_min = __webpack_require__("./node_modules/file-saver/dist/FileSaver.min.js");
;// ./src/debug.ts
async function debug() {
const rule = await getRule();
let book;
if (typeof window._book !== "undefined") {
book = window._book;
}
else {
book = await rule.bookParse();
}
unsafeWindow.rule = rule;
unsafeWindow.book = book;
window._book = book;
unsafeWindow.saveAs = FileSaver_min.saveAs;
const { parse, fetchAndParse, gfetchAndParse } = await Promise.resolve(/* import() */).then(__webpack_require__.bind(__webpack_require__, "./src/lib/readability.ts"));
unsafeWindow.readability = {
parse,
fetchAndParse,
gfetchAndParse,
};
unsafeWindow.stopController = window.stopController;
return;
}
// EXTERNAL MODULE: ./src/main/main.ts
var main = __webpack_require__("./src/main/main.ts");
// EXTERNAL MODULE: ./src/save/misc.ts
var save_misc = __webpack_require__("./src/save/misc.ts");
;// ./src/ui/ChapterList.html
// Module
var ChapterList_code = "<div>\n <div v-if=\"loading\">\n <div class=\"chapter-list-loading\">\n <h2 v-if=\"failed\">加载章节失败!</h2>\n <h2 v-else>正在载入章节列表中,请耐心等待……</h2>\n </div>\n </div>\n <div v-else class=\"chapter-list\">\n <div v-for=\"sectionObj in sectionsObj\" v-show=\"isSectionSeen(sectionObj)\" v-bind:key=\"sectionObj.sectionNumber\" class=\"section\">\n <h3 v-if=\"sectionObj.sectionName\" class=\"section-label\">\n {{ sectionObj.sectionName }}\n </h3>\n <div v-for=\"chapter in sectionObj.chpaters\" v-show=\"isChapterSeen(chapter)\" v-bind:key=\"chapter.chapterNumber\" class=\"chapter\" v-bind:class=\"{\n good: this.filter(chapter),\n bad: !this.filter(chapter),\n warning: this.warningFilter(chapter)\n }\" v-bind:title=\"chapter.chapterNumber\">\n <a rel=\"noopener noreferrer\" target=\"_blank\" v-bind:class=\"{\n disabled: this.isChapterDisabled(chapter),\n }\" v-bind:href=\"chapter.chapterUrl\">{{ chapter.chapterName }}</a>\n </div>\n </div>\n </div>\n</div>\n";
// Exports
/* harmony default export */ const ChapterList = (ChapterList_code);
// EXTERNAL MODULE: ./src/ui/ChapterList.less
var ui_ChapterList = __webpack_require__("./src/ui/ChapterList.less");
;// ./src/ui/ChapterList.ts
async function getSections() {
if (window._sections &&
window._url === document.location.href) {
return window._sections;
}
else {
const rule = await getRule();
const book = await rule.bookParse();
window._book = book;
window._url = document.location.href;
if (unsafeWindow.saveOptions?.chapterSort) {
window._sections = (0,save_misc/* getSectionsObj */.e)(book.chapters, unsafeWindow.saveOptions?.chapterSort);
}
else {
window._sections = (0,save_misc/* getSectionsObj */.e)(book.chapters);
}
return window._sections;
}
}
const style = (0,dom/* createStyle */._r)(ui_ChapterList/* default */.A);
/* harmony default export */ const src_ui_ChapterList = ((0,external_Vue_.defineComponent)({
name: "ChapterList",
setup() {
const sectionsObj = (0,external_Vue_.reactive)([]);
const loading = (0,external_Vue_.ref)(true);
const failed = (0,external_Vue_.ref)(false);
(0,external_Vue_.onMounted)(async () => {
if (sectionsObj.length === 0) {
try {
const _sectionsObj = await getSections();
Object.assign(sectionsObj, _sectionsObj);
loading.value = false;
}
catch (error) {
loglevel_default().error(error);
failed.value = true;
}
}
});
const filterSetting = (0,external_Vue_.inject)("filterSetting");
const filter = (chapter) => {
if (chapter.status === main/* Status */.nW.aborted) {
return false;
}
if (filterSetting.value) {
const filterFunction = getFilterFunction(filterSetting.value.arg, filterSetting.value.functionBody);
if (typeof filterFunction === "function") {
return filterFunction(chapter);
}
}
return true;
};
const warningFilter = (chapter) => {
return chapter.isVIP && chapter.isPaid !== true;
};
const isChapterDisabled = (chapter) => {
return !chapter?.chapterUrl;
};
const isChapterSeen = (chapter) => {
return !(filterSetting.value.hiddenBad && !filter(chapter));
};
const isSectionSeen = (sectionObj) => {
const chapters = sectionObj.chpaters;
return chapters.some((chapter) => isChapterSeen(chapter));
};
return {
sectionsObj,
loading,
failed,
filter,
warningFilter,
isChapterDisabled,
isChapterSeen,
isSectionSeen,
};
},
template: ChapterList,
}));
// EXTERNAL MODULE: ./src/ui/FilterTab.css
var FilterTab = __webpack_require__("./src/ui/FilterTab.css");
;// ./src/ui/FilterTab.html
// Module
var FilterTab_code = "<div>\n <div class=\"filter-setting\">\n <div v-if=\"filterType !== 'null'\" class=\"filter-input\">\n <p>请输入过滤的条件:<input v-model=\"arg\" type=\"text\"></p>\n </div>\n <div class=\"filter-setter\">\n <div>\n <span>当前过滤方法:</span>\n <select v-model=\"filterType\">\n <option v-for=\"filterOption in filterOptionList\" v-bind:value=\"filterOption[0]\">\n {{ filterOption[1][\"abbreviation\"] }}\n </option>\n </select>\n </div>\n <input id=\"hiddenBad\" v-model=\"hiddenBad\" type=\"checkbox\">\n <label for=\"hiddenBad\">只显示符合条件章节</label>\n <div class=\"filter-description\" v-html=\"filterDescription\"></div>\n <div v-if=\"false\">\n <span class=\"good\"></span>\n <span class=\"warning\"></span>\n <span class=\"bad\"></span>\n </div>\n </div>\n </div>\n <chapter-list>\n</div>\n";
// Exports
/* harmony default export */ const ui_FilterTab = (FilterTab_code);
;// ./src/ui/FilterTab.ts
const filterOptionDict = {
null: {
raw: () => {
return () => true;
},
description: "<p>不应用任何过滤器(默认)</p>",
abbreviation: "无",
},
number: {
raw: (arg) => {
function characterCheck() {
return /^[\s\d\-,,]+$/.test(arg);
}
function match(s, n) {
switch (true) {
case /^\d+$/.test(s): {
const _m = s.match(/^(\d+)$/);
if (_m?.length === 2) {
const m = parseInt(_m[1]);
if (m === n) {
return true;
}
}
return false;
}
case /^\d+-\d+$/.test(s): {
const _m = s.match(/^(\d+)-(\d+)$/);
if (_m?.length === 3) {
const m = _m.map((_s) => Number(_s));
if (n >= m[1] && n <= m[2]) {
return true;
}
}
return false;
}
case /^\d+-$/.test(s): {
const _m = s.match(/^(\d+)-$/);
if (_m?.length === 2) {
const m = parseInt(_m[1]);
if (n >= m) {
return true;
}
}
return false;
}
case /^-\d+$/.test(s): {
const _m = s.match(/^-(\d+)$/);
if (_m?.length === 2) {
const m = parseInt(_m[1]);
if (n <= m) {
return true;
}
}
return false;
}
default: {
return false;
}
}
}
if (!characterCheck()) {
return;
}
return (chapter) => {
const n = chapter.chapterNumber;
const ss = arg.split(/[,,]/).map((s) => s.replace(/\s/g, "").trim());
return ss.map((s) => match(s, n)).some((b) => b);
};
},
description: "<p>基于章节序号过滤,章节序号可通过章节标题悬停查看。</p><p>支持以下格式:13, 1-5, 2-, -89。可通过分号(,)使用多个表达式。</p>",
abbreviation: "章节序号",
},
baseOnString: {
raw: (arg) => {
return (chapter) => {
return (chapter && chapter.chapterName?.includes(arg)) || false;
};
},
description: "<p>过滤出所有包含过滤条件字符的章节</p>",
abbreviation: "章节标题",
},
};
function getFunctionBody(fn) {
return `return (${fn.toString()})(arg)`;
}
function getFilterFunction(arg, functionBody) {
const filterFunctionFactor = new Function("arg", functionBody);
const filterFunction = filterFunctionFactor(arg);
if (typeof filterFunction === "function") {
return filterFunction;
}
else {
return undefined;
}
}
/* harmony default export */ const src_ui_FilterTab = ((0,external_Vue_.defineComponent)({
components: { "chapter-list": src_ui_ChapterList },
emits: ["filterupdate"],
setup(props, { emit }) {
const arg = (0,external_Vue_.ref)("");
const hiddenBad = (0,external_Vue_.ref)(true);
const filterType = (0,external_Vue_.ref)("null");
const filterOptionList = Object.entries(filterOptionDict);
const functionBody = (0,external_Vue_.computed)(() => getFunctionBody(filterOptionDict[filterType.value].raw));
const filterDescription = (0,external_Vue_.computed)(() => filterOptionDict[filterType.value].description);
const filterSetting = (0,external_Vue_.computed)(() => ({
arg: arg.value,
hiddenBad: hiddenBad.value,
filterType: filterType.value,
functionBody: functionBody.value,
}));
(0,external_Vue_.provide)("filterSetting", filterSetting);
(0,external_Vue_.watch)(filterSetting, () => {
emit("filterupdate", filterSetting.value);
}, {
deep: true,
});
const getFilterSetting = (0,external_Vue_.inject)("getFilterSetting");
(0,external_Vue_.onMounted)(() => {
const faterFilterSetting = getFilterSetting();
if (faterFilterSetting) {
arg.value = faterFilterSetting.arg;
hiddenBad.value = faterFilterSetting.hiddenBad;
filterType.value = faterFilterSetting.filterType;
}
});
return {
arg,
hiddenBad,
filterType,
filterOptionList,
filterDescription,
};
},
template: ui_FilterTab,
}));
const FilterTab_style = (0,dom/* createStyle */._r)(FilterTab/* default */.A);
// EXTERNAL MODULE: ./src/log.ts
var src_log = __webpack_require__("./src/log.ts");
;// ./src/ui/LogUI.ts
/* harmony default export */ const LogUI = ((0,external_Vue_.defineComponent)({
name: "LogUI",
setup(props, context) {
const logText = (0,external_Vue_.ref)("");
let requestID;
(0,external_Vue_.onMounted)(() => {
logText.value = (0,src_log/* getLogText */.gh)();
function step() {
logText.value = (0,src_log/* getLogText */.gh)();
requestID = globalThis.requestAnimationFrame(step);
}
requestID = globalThis.requestAnimationFrame(step);
});
(0,external_Vue_.onUnmounted)(() => {
if (requestID) {
globalThis.cancelAnimationFrame(requestID);
}
});
return { logText };
},
template: `
<div class="log">
<pre v-html="logText" id="novel-downloader-log"></pre>
</div>`,
}));
;// ./src/ui/setting.html
// Module
var setting_code = "<div>\n <dialog-ui v-if=\"openStatus === 'true'\" dialog-title=\"设置\" v-bind:status=\"openStatus\" v-on:dialogclose=\"closeSetting\">\n <div id=\"nd-setting\" class=\"nd-setting\">\n <div class=\"nd-setting-tab\">\n <button v-bind:class=\"['tab-button', { active: setting.currentTab === 'tab-1'}]\" v-on:click=\"setting.currentTab = 'tab-1'\">\n 基本设置\n </button>\n <button v-bind:class=\"['tab-button', { active: setting.currentTab === 'tab-2'}]\" v-on:click=\"setting.currentTab = 'tab-2'\">\n 自定义筛选条件\n </button>\n <button v-if=\"setting.enableTestPage\" v-bind:class=\"['tab-button', { active: setting.currentTab === 'tab-3'}]\" v-on:click=\"setting.currentTab = 'tab-3'\">\n 抓取测试\n </button>\n <button v-if=\"setting.enableTestPage\" v-bind:class=\"['tab-button', { active: setting.currentTab === 'tab-4'}]\" v-on:click=\"setting.currentTab = 'tab-4'\">\n 日志\n </button>\n </div>\n <div class=\"nd-setting-body\">\n <div v-show=\"setting.currentTab === 'tab-1'\" id=\"nd-setting-tab-1\" class=\"tab-page\">\n <div>\n <input id=\"debug\" v-model=\"setting.enableDebug\" type=\"checkbox\">\n <label for=\"debug\">启用调试模式。(输出更详细日志)</label>\n <input id=\"txtDownload\" v-model=\"setting.TxtDownload\" type=\"checkbox\">\n <label for=\"txtDownload\">下载Txt文件</label>\n <input id=\"EpubDownload\" v-model=\"setting.EpubDownload\" type=\"checkbox\">\n <label for=\"EpubDownload\">下载Epub文件</label>\n <input id=\"test-page\" v-model=\"setting.enableTestPage\" type=\"checkbox\">\n <label for=\"test-page\">启用测试视图</label>\n </div>\n <hr class=\"hr-twill-colorful\">\n <div>\n <h3>自定义保存参数</h3>\n <ul>\n <li v-for=\"item of saveOptions\">\n <input v-bind:id=\"item.key\" v-model=\"setting.chooseSaveOption\" type=\"radio\" v-bind:value=\"item.key\">\n <label v-bind:for=\"item.key\">{{ item.value }}</label>\n </li>\n </ul>\n </div>\n </div>\n <div v-show=\"setting.currentTab === 'tab-2'\" id=\"nd-setting-tab-2\" class=\"tab-page\">\n <filter-tab v-on:filterupdate=\"saveFilter\">\n </div>\n <div v-if=\"setting.enableTestPage\" v-show=\"setting.currentTab === 'tab-3'\" id=\"nd-setting-tab-3\" class=\"tab-page\">\n <test-ui></test-ui>\n </div>\n <div v-if=\"setting.enableTestPage\" v-show=\"setting.currentTab === 'tab-4'\" id=\"nd-setting-tab-4\" class=\"tab-page\">\n <log-ui></log-ui>\n </div>\n </div>\n <div class=\"nd-setting-footer\">\n <button v-on:click=\"closeAndSaveSetting\">Save</button>\n <button v-on:click=\"closeSetting\">Cancel</button>\n </div>\n </div>\n </dialog-ui>\n</div>\n";
// Exports
/* harmony default export */ const setting = (setting_code);
// EXTERNAL MODULE: ./src/ui/setting.less
var ui_setting = __webpack_require__("./src/ui/setting.less");
// EXTERNAL MODULE: ./src/lib/attachments.ts
var attachments = __webpack_require__("./src/lib/attachments.ts");
;// ./src/ui/TestUI.html
// Module
var TestUI_code = "<div>\n <div id=\"test-page-div\">\n <h2>元数据</h2>\n <table>\n <tbody>\n <tr v-for=\"(value, key) in metaData\">\n <td>{{ key }}</td>\n <td v-html=\"getData(key, value)\"></td>\n </tr>\n </tbody>\n </table>\n <hr class=\"hr-edge-weak\">\n <h2>章节测试</h2>\n <div class=\"preview-chapter-setting\">\n <label for=\"chapterNumber\">预览章节序号:</label>\n <input id=\"chapterNumber\" v-model=\"chapterNumber\" type=\"text\">\n </div>\n <div v-if=\"this.isSeenChapter(chapter)\">\n <h4>\n <a rel=\"noopener noreferrer\" target=\"_blank\" v-bind:href=\"chapter.chapterUrl\">{{ chapter.chapterName }}</a>\n </h4>\n <div class=\"chapter\" v-html=\"getChapterHtml(chapter)\"></div>\n </div>\n <div v-else>\n <p v-if=\"this.isChapterFailed(chapter)\">章节加载失败!</p>\n <p v-else>正在加载章节中……</p>\n </div>\n </div>\n</div>\n";
// Exports
/* harmony default export */ const TestUI = (TestUI_code);
// EXTERNAL MODULE: ./src/ui/TestUI.less
var ui_TestUI = __webpack_require__("./src/ui/TestUI.less");
;// ./src/ui/TestUI.ts
/* harmony default export */ const src_ui_TestUI = ((0,external_Vue_.defineComponent)({
name: "TestUI",
setup() {
const book = (0,external_Vue_.reactive)({});
async function waitBook() {
while (true) {
await (0,misc/* sleep */.yy)(500);
if (window._book) {
return window._book;
}
}
}
const metaData = (0,external_Vue_.reactive)({});
function getData(key, value) {
if (key === "封面") {
return `<img src="${value[0]}" alt="${value[1]}">`;
}
if (key === "简介" && value instanceof HTMLElement) {
return value.outerHTML;
}
if (key === "网址" && typeof value === "string") {
return `<a href="${value}">${value}</a>`;
}
return value;
}
const chapter = (0,external_Vue_.reactive)({});
const chapterNumber = (0,external_Vue_.ref)(-99);
function getInitChapterNumber() {
if (book) {
const chapters = book.chapters;
const cns = chapters
.filter((c) => {
if (c.status === main/* Status */.nW.aborted) {
return false;
}
if (c.isVIP && c.isPaid !== true) {
return false;
}
return true;
})
.map((c) => c.chapterNumber);
cns.sort();
return cns.slice(-3)[0];
}
}
async function initChapter(n) {
const chapters = book.chapters;
const _chapter = chapters.filter((c) => c.chapterNumber === n)[0];
if (_chapter) {
if (_chapter.status === main/* Status */.nW.pending) {
await _chapter.init();
Object.assign(chapter, _chapter);
}
else {
Object.assign(chapter, _chapter);
}
}
}
(0,external_Vue_.watch)(chapterNumber, (value, oldValue) => {
if (typeof value === "string") {
value = parseInt(value, 10);
}
if (typeof oldValue === "string") {
oldValue = parseInt(oldValue, 10);
}
if (oldValue !== value) {
if (value !== -99) {
initChapter(value);
}
}
});
function isSeenChapter(_chapter) {
return _chapter.status === main/* Status */.nW.finished;
}
function isChapterFailed(_chapter) {
return (_chapter.status === main/* Status */.nW.failed || _chapter.status === main/* Status */.nW.aborted);
}
function getChapterHtml(_chapter) {
const html = _chapter.contentHTML?.cloneNode(true);
const nodes = html?.querySelectorAll("img, audio");
if (nodes) {
Array.from(nodes).forEach((node) => {
const url = node.title || node.alt;
node.src = getObjectUrl(url);
});
}
return html?.outerHTML;
}
(0,external_Vue_.onMounted)(async () => {
const _book = await waitBook();
Object.assign(book, _book);
const coverUrl = _book?.additionalMetadate?.cover?.url ?? "";
const coverSrc = coverUrl ? getObjectUrl(coverUrl) : "";
const _metaData = {
封面: [coverSrc, coverUrl],
题名: _book?.bookname ?? "None",
作者: _book?.author ?? "None",
网址: _book?.bookUrl,
简介: _book?.introductionHTML ?? "",
};
Object.assign(metaData, _metaData);
const cn = getInitChapterNumber();
if (cn) {
chapterNumber.value = cn;
}
});
function getObjectUrl(url) {
const attachment = (0,attachments/* getAttachmentClassCache */._s)(url);
if (attachment?.Blob) {
const blob = attachment.Blob;
const src = URL.createObjectURL(blob);
return src;
}
return "";
}
return {
metaData,
getData,
chapter,
isSeenChapter,
isChapterFailed,
getChapterHtml,
chapterNumber,
};
},
template: TestUI,
}));
const TestUI_style = (0,dom/* createStyle */._r)(ui_TestUI/* default */.A);
;// ./src/ui/setting.ts
const setting_style = (0,dom/* createStyle */._r)(ui_setting/* default */.A);
const el = (0,dom/* createEl */.a_)(`<div id="setting"></div>`);
const vm = (0,external_Vue_.createApp)({
name: "nd-setting",
components: { "filter-tab": src_ui_FilterTab, "log-ui": LogUI, "test-ui": src_ui_TestUI },
setup() {
const setting = (0,external_Vue_.reactive)({});
let settingBackup = {};
const saveOptions = [
{ key: "null", value: "不使用自定义保存参数", options: {} },
{
key: "chapter_name",
value: "将章节名称格式修改为 第xx章 xxxx",
options: {
getchapterName: (chapter) => {
if (chapter.chapterName) {
return `第${chapter.chapterNumber.toString()}章 ${chapter.chapterName}`;
}
else {
return `第${chapter.chapterNumber.toString()}章`;
}
},
},
},
{
key: "txt_space",
value: "txt文档每个自然段前加两个空格",
options: {
genChapterText: (chapterName, contentText) => {
contentText = contentText
.split("\n")
.map((line) => {
if (line.trim() === "") {
return line;
}
else {
return line.replace(/^/, " ");
}
})
.join("\n");
return `## ${chapterName}\n\n${contentText}\n\n`;
},
},
},
{
key: "reverse_chapters",
value: "保存章节时倒序排列",
options: {
chapterSort: (a, b) => {
if (a.chapterNumber > b.chapterNumber) {
return -1;
}
if (a.chapterNumber === b.chapterNumber) {
return 0;
}
if (a.chapterNumber < b.chapterNumber) {
return 1;
}
return 0;
},
},
},
];
setting.enableDebug = GM_getValue('enableDebug', src_setting/* enableDebug */.Nw.value);
src_setting/* enableDebug */.Nw.value = setting.enableDebug ?? src_setting/* enableDebug */.Nw.value;
src_setting/* enableDebug */.Nw.value ? loglevel_default().setLevel("trace") : loglevel_default().setLevel("info");
if (src_setting/* enableDebug */.Nw.value) {
debug();
}
setting.TxtDownload = GM_getValue('TxtDownload', src_setting/* TxtDownload */.Jv.value);
src_setting/* TxtDownload */.Jv.value = setting.TxtDownload ?? src_setting/* TxtDownload */.Jv.value;
setting.EpubDownload = GM_getValue('EpubDownload', src_setting/* EpubDownload */.Zz.value);
src_setting/* EpubDownload */.Zz.value = setting.EpubDownload ?? src_setting/* EpubDownload */.Zz.value;
setting.enableTestPage = GM_getValue('enableTestPage', false);
setting.chooseSaveOption = GM_getValue('chooseSaveOption', 'null');
setting.filterSetting = GM_getValue('filterSetting', undefined);
setting.currentTab = GM_getValue('currentTab', 'tab-1');
const curSaveOption = () => {
const _s = saveOptions.find((s) => s.key === setting.chooseSaveOption);
if (_s) {
return _s.options;
}
else {
return saveOptions[0].options;
}
};
unsafeWindow.saveOptions = curSaveOption();
const saveFilter = (filterSetting) => {
setting.filterSetting = (0,misc/* deepcopy */.OJ)(filterSetting);
GM_setValue('filterSetting', setting.filterSetting);
};
const getFilterSetting = () => {
if (setting.filterSetting) {
return setting.filterSetting;
}
else {
return;
}
};
(0,external_Vue_.provide)("getFilterSetting", getFilterSetting);
const setConfig = (config) => {
setEnableDebug();
setTxtDownload();
setEpubDownload();
setCustomSaveOption();
setCustomFilter();
saveAllSettings();
function setEnableDebug() {
if (typeof config.enableDebug === "boolean") {
config.enableDebug ? loglevel_default().setLevel("trace") : loglevel_default().setLevel("info");
src_setting/* enableDebug */.Nw.value = config.enableDebug;
if (config.enableDebug) {
debug();
}
loglevel_default().info(`[Init]enableDebug: ${src_setting/* enableDebug */.Nw.value}`);
}
}
function setTxtDownload() {
if (typeof config.TxtDownload === "boolean") {
src_setting/* TxtDownload */.Jv.value = config.TxtDownload;
loglevel_default().info(`[Init]TxtDownload: ${src_setting/* TxtDownload */.Jv.value}`);
}
}
function setEpubDownload() {
if (typeof config.EpubDownload === "boolean") {
src_setting/* EpubDownload */.Zz.value = config.EpubDownload;
loglevel_default().info(`[Init]EpubDownload: ${src_setting/* EpubDownload */.Zz.value}`);
}
}
function setCustomSaveOption() {
unsafeWindow.saveOptions = curSaveOption();
}
function setCustomFilter() {
if (config.filterSetting) {
if (config.filterSetting.filterType === "null") {
unsafeWindow.chapterFilter = undefined;
}
else {
const filterFunction = getFilterFunction(config.filterSetting.arg, config.filterSetting.functionBody);
if (filterFunction) {
unsafeWindow.chapterFilter = (chapter) => {
if (chapter.status === main/* Status */.nW.aborted) {
return false;
}
return filterFunction(chapter);
};
}
}
}
}
function saveAllSettings() {
GM_setValue('enableDebug', config.enableDebug);
GM_setValue('TxtDownload', config.TxtDownload);
GM_setValue('EpubDownload', config.EpubDownload);
GM_setValue('enableTestPage', config.enableTestPage);
GM_setValue('chooseSaveOption', config.chooseSaveOption);
GM_setValue('filterSetting', config.filterSetting);
GM_setValue('currentTab', config.currentTab);
}
};
const openStatus = (0,external_Vue_.ref)("false");
const openSetting = () => {
settingBackup = (0,misc/* deepcopy */.OJ)(setting);
openStatus.value = "true";
};
const closeSetting = (keep) => {
if (keep === true) {
settingBackup = (0,misc/* deepcopy */.OJ)(setting);
}
else {
Object.assign(setting, settingBackup);
}
openStatus.value = "false";
};
const closeAndSaveSetting = async () => {
closeSetting(true);
await (0,misc/* sleep */.yy)(30);
setConfig((0,misc/* deepcopy */.OJ)(setting));
loglevel_default().info("[Init]自定义设置:" + JSON.stringify(setting));
};
return {
openStatus,
openSetting,
closeSetting,
closeAndSaveSetting,
saveFilter,
setting,
saveOptions,
};
},
template: setting,
}).mount(el);
;// ./src/ui/button.ts
const button_style = (0,dom/* createStyle */._r)(src_ui_button/* default */.A, "button-div-style");
const button_el = (0,dom/* createEl */.a_)('<div id="nd-button"></div>');
const button_vm = (0,external_Vue_.createApp)({
data() {
return {
imgStart: src_setting/* iconStart0 */.Og,
imgSetting: src_setting/* iconSetting */.w1,
imgJump: src_setting/* iconJump */.GM,
isSettingSeen: src_GM/* _GM_info */.JX.scriptHandler !== "Greasemonkey",
uiObj: { type: "download" },
};
},
methods: {
startButtonClick() {
if (window.downloading) {
alert("正在下载中,请耐心等待……");
return;
}
const self = this;
self.imgStart = src_setting/* iconStart1 */.HE;
async function run() {
const ruleClass = await getRule();
await ruleClass.run();
}
run()
.then(() => {
self.imgStart = src_setting/* iconStart0 */.Og;
})
.catch((error) => loglevel_default().error(error));
},
settingButtonClick() {
vm.openSetting();
},
jumpButtonClick() {
this.uiObj.jumpFunction();
},
},
mounted() {
Object.assign(this.uiObj, getUI()());
if (typeof this.uiObj.isSettingSeen !== "undefined") {
this.isSettingSeen = this.uiObj.isSettingSeen;
}
},
template: ui_button,
});
// EXTERNAL MODULE: ./src/ui/dialog.css
var dialog = __webpack_require__("./src/ui/dialog.css");
;// ./src/ui/dialog.html
// Module
var dialog_code = "<div v-if=\"myPrivateStatus\" class=\"overlay\" v-bind:class=\"{ open: myPrivateStatus }\"></div>\n<div v-if=\"myPrivateStatus\" class=\"out\">\n <div id=\"dialog\" class=\"dialog\" v-bind:class=\"{ open: myPrivateStatus }\">\n <div class=\"titlebar\">\n <h1 class=\"dialog-title\">{{ dialogTitle }}</h1>\n <button class=\"dialog-close\" v-on:click=\"dialogClose\">❌</button>\n </div>\n <div class=\"body\">\n <slot></slot>\n </div>\n </div>\n</div>\n";
// Exports
/* harmony default export */ const ui_dialog = (dialog_code);
;// ./src/ui/dialog.ts
/* harmony default export */ const src_ui_dialog = ((0,external_Vue_.defineCustomElement)({
name: "Dialog",
props: {
dialogTitle: String,
status: String,
},
emits: ["dialogclose"],
data() {
return {
myPrivateStatus: this.status === "true",
};
},
methods: {
dialogClose() {
this.myPrivateStatus = false;
this.$emit("dialogclose");
},
},
mounted() {
this.myPrivateStatus = this.status === "true";
},
watch: {
status() {
this.myPrivateStatus = this.status === "true";
},
},
template: ui_dialog,
styles: [dialog/* default */.A],
}));
// EXTERNAL MODULE: ./src/ui/progress.ts + 1 modules
var progress = __webpack_require__("./src/ui/progress.ts");
;// ./src/ui/ui.ts
function register() {
customElements.define("dialog-ui", src_ui_dialog);
}
function ui_init() {
register();
button_vm.mount(button_el);
document.body.appendChild(button_el);
document.body.appendChild(progress.el);
document.body.appendChild(el);
document.head.appendChild(button_style);
document.head.appendChild(progress/* style */.i);
document.head.appendChild(setting_style);
document.head.appendChild(FilterTab_style);
document.head.appendChild(style);
document.head.appendChild(TestUI_style);
}
;// ./src/index.ts
async function printEnvironments() {
loglevel_default().info("[Init]开始载入小说下载器……");
Object.entries(await environments()).forEach((kv) => loglevel_default().info("[Init]" + kv.join(":")));
}
async function src_main(ev) {
if (ev) {
document.removeEventListener(ev.type, src_main);
}
init();
await printEnvironments();
ui_init();
}
if (document.readyState === "loading") {
document.addEventListener("DOMContentLoaded", src_main);
}
else {
src_main();
}
})();
/******/ })()
;