Advertisement
xiaomianao666

邀您一起看:模板.Q小白教程

Dec 12th, 2021
88
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
  1. 海阔视界规则分享,当前分享的是:二级页面详情¥page_detail¥模板.Q小白教程@@{"data":"{\"associatedModelsMapForJoinTable\":{},\"associatedModelsMapWithFK\":{},\"associatedModelsMapWithoutFK\":{},\"fieldsToSetToDefault\":[],\"id\":0,\"last_chapter_rule\":\"\",\"listToClearAssociatedFK\":[],\"listToClearSelfFK\":[],\"pageList\":[],\"saved\":false,\"title\":\"视界论坛R\",\"version\":0,\"url\":\"https://haikuoshijie.cn/topic/8440#fypage#noHistory#;get;UTF-8;{User-Agent@Android&&Cookie@userToken=2d7ef669dfc94da4b470128c2784af41}\",\"col_type\":\"text_1\",\"find_rule\":\"js:\\nvar res = {};\\nvar d = [];\\nvar urlSplits = MY_URL.split(\\\"#\\\");\\nvar mUrl = urlSplits[0];\\nvar page = urlSplits[1];\\nvar colType = 'rich_text';\\n\\n// 是否显示帖子分类，显示/1 不显示/0\\nvar showMeta = 1;\\n// 帖子分类字体大小 big/大 span/中 small/小\\nvar metaSize = 'small';\\n// 帖子分类颜色\\nvar nodeColor = \\\"#2979FF\\\";\\n// 是否显示正文，显示/1 不显示/0\\nvar showContent = 1;\\n// 是否显示评论，显示/1 不显示/0\\nvar showComment = 1;\\n// 是否隐藏图片，隐藏/1 不隐藏/0\\nvar hideImg = 0;\\n// 使用 emoji 图标替换文本，使用/1 不使用/0\\nvar useEmoji = 1;\\n// 评论用户颜色\\nvar userColor = \\\"#2979FF\\\";\\n// 评论回复引用用户颜色\\nvar quoteUserColor = \\\"black\\\";\\n\\n/**\\n * 用户 Token (需要先登录才能获取)\\n *\\n * 抓包 Cookie 中的 userToken= 后面那串东西\\n * 或\\n * 不填写固定值 则需配合专用插件自动获取\\n * 但每次运行视界都需打开一次论坛\\n */\\nvar token = '';\\n\\n/**\\n * 是否使用插件自动获取 Token 的方式\\n *\\n * 是/1 否/0\\n */\\nvar autoToken = 0;\\n\\n/**\\n * 通过插件自动获取 Token 到文件中然后自动读取\\n *\\n * 注意：以上方的 token 为主\\n */\\nvar fileToken = getVar('hiker_token');\\nif (fileToken === '') {\\ntry {\\n    fileToken = fetch ('hiker://files/rules/js/hikerbbs_token.js', {});\\n    if (fileToken == null) fileToken = '';\\n} catch (e) {\\n    fileToken = '';\\n}\\n}\\ntoken = token === '' ? fileToken : token;\\nvar showToken = token === '' ? getVar(\\\"hikerbbs\\\") : token;\\nif (autoToken) token = showToken;\\n// if (token === '' && showToken !== '') setError(showToken);\\n\\n// 是否显示填写 Token 提示，显示/1 不显示/0\\nvar showInputTokenTips = 1;\\n// 是否开启收藏/点赞结果提示，是/1 否/0\\nvar resultTips = 1;\\n// 第几套图标，-1为随机，从下面三个数组挑选\\nvar iconIndex = -1;\\n// 收藏图标\\nvar starIcons = [ 'https://www.easyicon.net/api/resizeApi.php?id=1286217&size=128',\\n];\\n// 点赞图标\\nvar likeIcons = [ 'https://www.easyicon.net/api/resizeApi.php?id=1288217&size=128',\\n    /*'https://www.easyicon.net/api/resizeApi.php?id=1211507&size=128',\\n    'https://www.easyicon.net/api/resizeApi.php?id=1239511&size=128'*/\\n];\\n// 回复图标\\nvar commentIcons = [ 'https://www.easyicon.net/api/resizeApi.php?id=1239495&size=128',\\n];\\n// 原文章图标\\n/*var articleIcons = [ 'https://www.easyicon.net/api/resizeApi.php?id=1238522&size=128',\\n];*/\\n\\nlet imgError = '<p><font color=\\\"grey\\\">图片暂时无法显示，若要查看请<a href=\\\"' + MY_URL + '\\\">访问原文</a></font></p>';\\nString.prototype.replaceWithConfirm = function (confirmValue, searchValue, replaceValue) {\\n    let returnValue = this;\\n    if (confirmValue) {\\n        returnValue = this.replace(searchValue, replaceValue)\\n    }\\n    return returnValue;\\n};\\nString.prototype.replaceWithCallback = function (searchValue, replaceValue, callback) {\\n    let returnValue = this;\\n    if (callback != null) {\\n        returnValue = callback(this, searchValue, replaceValue);\\n    }\\n    return returnValue;\\n};\\nfunction imgTag(context, imgUrl) {\\n    let replaceString = imgUrl === '' ? imgError : '<p><showimg src=\\\"' + (imgUrl + '@Referer=https://haikuoshijie.cn') + '\\\"></p>';\\n    if (hideImg) {\\n        replaceString = imgUrl === '' ? imgError : '<p><a href=\\\"' + imgUrl + '\\\">[点击查看大图]</a></p>';\\n    }\\n    return context.replace(/<img data-v>/g, replaceString);\\n}\\nfunction imgTagReplacement2(context, searchValue, replaceValue) {\\n    let matchArray = context.match(searchValue);\\n    let returnValue = context;\\n    if (matchArray != null) {\\n        for (let i = 0; i < matchArray.length; i++) {\\n            let item = matchArray[i];\\n            /<img (src|data-src)=\\\"(.*?)\\\"([\\\\s\\\\S]*?)>/.test(item);\\n            let imgUrl = RegExp.$2;\\n            if (imgUrl !== '') {\\n                returnValue = returnValue.replace(item, replaceValue);\\n                returnValue = imgTag(returnValue, imgUrl);\\n            }\\n        }\\n    }\\n    return returnValue;\\n}\\nfunction abbreviateReplyText(context, textArray) {\\n    let content = context;\\n    for (let i = 0; i < textArray.length; i++) {\\n        let text = parseDomForHtml(textArray[i], \\\"p&&Text\\\");\\n        if (text.length > 30) {\\n            content = content.replace(text, text.substring(0, 30) + \\\"......\\\");\\n        }\\n    }\\n    return content;\\n}\\n\\nif (page > 1) {\\n\\n    let cursor = getVar(\\\"cursor\\\");\\n    if (page === '2') cursor = getVar(\\\"first_page_cursor\\\");\\n    cursor = cursor === '' ? '0' : cursor;\\n\\n    let urlTemplate = \\\"http://haikuoshijie.cn/api/comment/list?entityType=topic&entityId={entityId}&cursor={cursor}\\\";\\n    if (/topic\\\\/(\\\\d+)/.test(MY_URL) === true) {\\n        let entityId = RegExp.$1;\\n        if (entityId != null && entityId !== \\\"\\\") {\\n            let noMore = getVar(\\\"noMore\\\" + entityId);\\n            noMore = noMore === '' ? '0' : noMore;\\n            urlTemplate = urlTemplate.replace(\\\"{entityId}\\\", entityId);\\n            url = urlTemplate.replace(\\\"{cursor}\\\", cursor);\\n            // url = \\\"http://haikuoshijie.cn/api/comment/list?entityType=topic&entityId=398&cursor=9183\\\";\\n            let json = {};\\n            try {\\n                json = JSON.parse(fetch(url, {}));\\n                let data = json.data;\\n                let results = data.results;\\n                if (results != null) {\\n                    let nowTime = new Date().getTime();\\n                    putVar({key: 'cursor', value: data.cursor});\\n\\n                    function timeDiff(nowTime, createTime) {\\n                        Date.prototype.format = function (fmt) {\\n                            let o = {\\n                                \\\"M+\\\": this.getMonth() + 1,                 //月份\\n                                \\\"d+\\\": this.getDate(),                    //日\\n                                \\\"h+\\\": this.getHours(),                   //小时\\n                                \\\"m+\\\": this.getMinutes(),                 //分\\n                                \\\"s+\\\": this.getSeconds(),                 //秒\\n                                \\\"q+\\\": Math.floor((this.getMonth() + 3) / 3), //季度\\n                                \\\"S\\\": this.getMilliseconds()             //毫秒\\n                            };\\n                            if (/(y+)/.test(fmt)) {\\n                                fmt = fmt.replace(RegExp.$1, (this.getFullYear() + \\\"\\\").substr(4 - RegExp.$1.length));\\n                            }\\n                            for (let k in o) {\\n                                if (new RegExp(\\\"(\\\" + k + \\\")\\\").test(fmt)) {\\n                                    fmt = fmt.replace(RegExp.$1, (RegExp.$1.length === 1) ? (o[k]) : ((\\\"00\\\" + o[k]).substr((\\\"\\\" + o[k]).length)));\\n                                }\\n                            }\\n                            return fmt;\\n                        };\\n                        let time = new Date(createTime).format(\\\"yyyy-MM-dd hh:mm:ss\\\");\\n                        let timeDiff = nowTime - createTime;\\n                        let days = Math.floor(timeDiff / (24 * 3600 * 1000)); // 计算出天数\\n                        let dayLeave = timeDiff % (24 * 3600 * 1000); // 计算天数后剩余的时间\\n                        let hours = Math.floor(dayLeave / (3600 * 1000)); // 计算天数后剩余的小时数\\n                        let hourLeave = timeDiff % (3600 * 1000); // 计算剩余小时后剩余的毫秒数\\n                        let minutes = Math.floor(hourLeave / (60 * 1000)); // 计算剩余的分钟数\\n                        if (0 < days && days < 31) {\\n                            time = days + \\\"天前\\\"\\n                        } else if (days < 0) {\\n                            if (hours > 0) {\\n                                time = hours + \\\"小时前\\\";\\n                            } else {\\n                                time = minutes + \\\"分钟前\\\";\\n                            }\\n                        }\\n                        return time;\\n                    }\\n\\n                    for (let i = 0; i < results.length; i++) {\\n                        let result = results[i];\\n                        let quoteContent = '';\\n                        if (result.quote != null) {\\n                            let quote = result.quote;\\n                            let content = parseDomForHtml(quote.content, 'body&&Html');\\n                            let nickname = quote.user.nickname;\\n\\n                            // https://blog.csdn.net/GrootBaby/article/details/99980395\\n                            let createTime = quote.user.createTime;\\n                            let time = timeDiff(nowTime, createTime);\\n\\n                            try {\\n                                content = content\\n                                    .replace(/<a[\\\\s\\\\S].*?<\\\\/a>/g, '');\\n                                let commentReplyTextArray = content.match(/<p[\\\\s\\\\S].*?<\\\\/p>/g);\\n                                content = abbreviateReplyText(content, commentReplyTextArray);\\n                            } catch (e) {\\n                            }\\n                            quoteContent = '<blockquote class=\\\"comment-quote\\\"><div class=\\\"comment-quote-user\\\"><a class=\\\"quote-nickname\\\"><font color=\\\"' + quoteUserColor + '\\\">'\\n                                + nickname\\n                                + '</font></a><span class=\\\"quote-time\\\"><font color=\\\"grey\\\">'\\n                                + '\\\\t\\\\t'\\n                                + time\\n                                + '</font></span></div><div itemprop=\\\"text\\\">'\\n                                + content\\n                                + '</div></blockquote>';\\n                        }\\n                        let content = '<p>' + result.content + '</p>';\\n                        let meta = '<br><small><font color=\\\"' + userColor + '\\\">'\\n                            + result.user.nickname\\n                            + '</font>\\\\t\\\\t<font color=\\\"grey\\\">'\\n                            + timeDiff(nowTime, result.createTime)\\n                            + '\\\\t\\\\t回复'\\n                            + '</font></small>';\\n                        let commentContent = quoteContent + content + meta;\\n                        let title = commentContent\\n                            .replace(/<img class=\\\"avatar([\\\\s\\\\S]*?)>/g, '')\\n                            .replace(/(<(p)([\\\\s\\\\S]*?)>)|<p>|<\\\\/p>/g, '')\\n                            .replaceWithCallback(/<img (src|data-src)=\\\"(.*?)\\\"([\\\\s\\\\S]*?)>/g, \\\"<img data-v>\\\", imgTagReplacement2)\\n                            .replace(/<img([\\\\s\\\\S]*?)>/g, imgError)\\n                            .replace(/<showimg/g, '<img');\\n                        d.push({\\n                            title: title,\\n                            desc: '',\\n                            url: MY_URL,\\n                            col_type: colType\\n                        });\\n                        d.push({\\n                            col_type: 'line'\\n                        });\\n                    }\\n                } else {\\n                    if (noMore) {\\n                        d.push({\\n                            title: \\\"<p></p>\\\" + '<center><font color=\\\"grey\\\">已无更多评论</font></center>',\\n                            col_type: colType\\n                        });\\n                        putVar({key: 'noMore' + entityId, value: 1});\\n                    }\\n                }\\n            } catch (e) {\\n            }\\n        }\\n    }\\n} else {\\n    var html = getResCode();\\ntry {\\n    var js = parseDom(html, '.main-content&&Html');\\n    var hasRule = 0;\\n\\n    // setError(html);\\n\\n    try {\\n\\n        let title = '<p></p><big style=\\\"padding-left: 15px\\\"><strong>' + parseDomForHtml(html, '.topic-header-center&&h1&&Html') + \\\"</strong></big>\\\";\\n        let meta = '';\\n        // parseDomForHtml(html,'.topic-header-center&&.topic-meta&&Html')\\n        let count = '<span style=\\\"color: grey\\\">' + parseDomForHtml(html, '.topic-header-center&&.topic-header-right&&Text') + \\\"</span>\\\";\\n\\n        if (showMeta) {\\n            let metaItems = parseDomForArray(html, '.topic-meta&&.meta-item');\\n            // setError(JSON.stringify(metaItems));\\n            let metaNode = parseDomForHtml(metaItems[2], 'Text');\\n            meta = '<font color=\\\"grey\\\">' + parseDomForHtml(metaItems[0], 'Text')\\n                + '  '\\n                + parseDomForHtml(metaItems[1], 'Text')\\n                + '  '\\n                + '</font><font color=\\\"' + nodeColor + '\\\">' + metaNode + '</font><font color=\\\"grey\\\">';\\n            let metaTags = parseDomForArray('<div>' + metaItems[3] + '</div>', 'div&&.tag');\\n            // setError(JSON.stringify(metaTags));\\n            let metaTag = '';\\n            for (let i = 0; i < metaTags.length; i++) {\\n                metaTag = (metaTag === '' ? metaTag : (metaTag + '  '))\\n                    + parseDomForHtml(metaTags[i], 'Text')\\n            }\\n            // metaTag = metaTag.replace('置顶', '““置顶””');\\n            metaSize = metaSize === '' ? 'small' : metaSize;\\n            meta = '<' + metaSize + '>' + meta + '  ' + metaTag + '</font></' + metaSize + '>' + '<br>';\\n            // setError(meta);\\n        }\\n\\n        // 👍🏻❤️🧡♡♥💬👁️➿𓁺\\n        if (useEmoji)\\n            count = count.replace(\\\"获赞：\\\", \\\"❤️ \\\")\\n                .replace(\\\"评论：\\\", \\\"💬 \\\")\\n                .replace(\\\"查看：\\\", \\\"👁️ \\\");\\n\\n        let header = \\\"\\\" + title + '\\\\t<small><font color=\\\"grey\\\"><a href=\\\"' + MY_URL + '\\\">[查看原文]</a></font></small>' + \\\"<br>\\\" + meta + count + '';\\n\\n        d.push({\\n            title: header,\\n            col_type: colType\\n        });\\n\\n        for (let i = 0; i < 2; i++)\\n            d.push({\\n                col_type: 'line'\\n            });\\n\\n        if (showContent) {\\n            let title = parseDomForHtml(html, '.content&&Html')\\n                .replaceWithCallback(/<img (src|data-src)=\\\"(.*?)\\\"([\\\\s\\\\S]*?)>/g, \\\"<img data-v>\\\", imgTagReplacement2)\\n                .replace(/<img([\\\\s\\\\S]*?)>/g, imgError)\\n                .replace(/<showimg/g, '<img')\\n                .replace(/(<(div)([\\\\s\\\\S]*?)>)|<div>|<\\\\/div>/g, '');\\n            d.push({\\n                title: \\\"<p></p>\\\" + title\\n                ,\\n                desc: '',\\n                url: '',\\n                col_type: colType\\n            });\\n\\n        }\\n\\n        var regExp = /(.*?)￥(.*?)￥(.*)/;\\n        if (js.indexOf('>海阔') !== -1) {\\n\\n            /*if (showContent) {\\n            for(var i = 0; i < 2; i++)\\n            d.push({\\n                   col_type: 'line'\\n              });\\n            }*/\\n\\n            let col = \\\"text_1\\\";\\n            let list = js.match(/>海阔[\\\\s\\\\S]*?<\\\\//g);\\n            if (list != null && list.length !== 0) hasRule = 1;\\n            if (list != null && list.length > 1) {\\n                d.push({\\n                    title: \\\"<p></p>\\\" + \\\"<big><b>本文所有规则一键导入</b></big>\\\",\\n                    col_type: colType\\n                });\\n            }\\n            for (let j = 0; j < list.length; j++) {\\n                let title = list[j].split('>')[1].split('</')[0];\\n                let mTitle = title;\\n\\n                if (regExp.test(title) === true) {\\n                    col = \\\"text_3\\\";\\n                    if (list.length === 1) mTitle = \\\"一键导入\\\";\\n                    if (list.length > 1) {\\n                        // var regExp1 = /(title\\\":\\\"(.*?)\\\")|(base64:\\\\/\\\\/@(.*?)@)|((.*?)@)/;\\n                        // setError (RegExp.$2)\\n                        mTitle = RegExp.$3;\\n                        mTitle = (mTitle != null && mTitle !== '') ? mTitle : title;\\n                        switch (RegExp.$2) {\\n                            case \\\"home_rule\\\":\\n                                /title\\\":\\\"(.*?)\\\"/.test(mTitle);\\n                                mTitle = RegExp.$1;\\n                                break;\\n                            case \\\"home_rule_v2\\\":\\n                                /base64:\\\\/\\\\/@(.*?)@/.test(mTitle);\\n                                mTitle = RegExp.$1;\\n                                break;\\n                            case \\\"js_url\\\":\\n                                /(.*?)@/.test(mTitle);\\n                                mTitle = RegExp.$1;\\n                                break;\\n                            case \\\"home_rule_url\\\":\\n                                mTitle = \\\"首页合集\\\";\\n                                break;\\n                            case \\\"bookmark_url\\\":\\n                                mTitle = \\\"书签合集\\\";\\n                                break;\\n                        }\\n                    }\\n                }\\n                title = (mTitle != null && mTitle !== '') ? mTitle : title;\\n                if (title.length > 14) col = \\\"text_2\\\";\\n\\n                d.push({\\n                    title: title,\\n                    desc: '🔔‘‘’’<b> 点击导入 </b>🔔',\\n                    url: 'rule://' + base64Encode(decodeURIComponent(list[j].split('>')[1].split('</')[0].replace(/amp;/g, '')\\n                        .replace(/&lt;/g, '<')\\n                        .replace(/&gt;/g, '>'))),\\n                    col_type: col\\n                });\\n            }\\n        } else\\n        if (js.indexOf('<code>方圆') !== -1) {\\n\\n            /*if (showContent) {\\n            for(var i = 0; i < 2; i++)\\n            d.push({\\n                   col_type: 'line'\\n              });\\n            }*/\\n\\n            let list = js.match(/<code>方圆[\\\\s\\\\S]*?<\\\\/code/g);\\n\\n            if (list != null && list.length !== 0) hasRule = 1;\\n            if (list != null && list.length > 1) {\\n                d.push({\\n                    title: \\\"<p></p>\\\" + \\\"<big><b>本文所有规则一键导入</b></big>\\\",\\n                    col_type: colType\\n                });\\n            }\\n\\n            for (let j = 0; j < list.length; j++) {\\n                let title = parseDomForHtml(list[j], 'code&&Text');\\n                let mTitle = title;\\n\\n                if (regExp.test(title) === true) {\\n                    col = \\\"text_3\\\";\\n                    if (list.length === 1) mTitle = \\\"一键导入\\\";\\n                    if (list.length > 1) {\\n                        mTitle = RegExp.$3;\\n                        mTitle = (mTitle != null && mTitle !== '') ? mTitle : title;\\n                        switch (RegExp.$2) {\\n                            case \\\"source\\\":\\n                                /title\\\":\\\"(.*?)\\\"/.test(mTitle);\\n                                mTitle = RegExp.$1;\\n                                break;\\n                        }\\n                    }\\n                }\\n                title = (mTitle != null && mTitle !== '') ? mTitle : title;\\n\\n                d.push({\\n                    title: title,\\n                    desc: '点击导入',\\n                    url: 'rule://' + base64Encode(decodeURIComponent(list[j].split('>')[1].split('</')[0].replace(/amp;/g, '')\\n                        .replace(/&lt;/g, '<')\\n                        .replace(/&gt;/g, '>'))),\\n                    col_type: col\\n                });\\n            }\\n        } else {\\n\\n        }\\n\\n        if (token !== '') {\\n            let starIcon = starIcons[0];\\n            let likeIcon = likeIcons[0];\\n            let commentIcon = commentIcons[0];\\n            // let articleIcon = articleIcons[0];\\n            let starIconMax = starIcons.length-1;\\n            let likeIconMax = likeIcons.length-1;\\n            let commentIconMax = commentIcons.length-1;\\n            // let articleIconMax = articleIcons.length-1;\\n            if (iconIndex === -1) {\\n                let maxLen = Math.max(starIconMax, likeIconMax, commentIconMax/*, articleIconMax*/);\\n                iconIndex = Math.floor((Math.random() * (maxLen + 1)));\\n            }\\n            starIcon = starIcons[iconIndex > starIconMax ? starIconMax : iconIndex];\\n            likeIcon = likeIcons[iconIndex > likeIconMax ? likeIconMax : iconIndex];\\n            commentIcon = commentIcons[iconIndex > commentIconMax ? commentIconMax : iconIndex];\\n            // articleIcon = articleIcons[iconIndex > articleIconMax ? articleIconMax : iconIndex];\\n            let isStarred = 0;\\n            let starStatus = '';\\n            try {\\n                starStatus = parseDomForHtml(html, \\\".favorite.active&&Html\\\");\\n            } catch (e) {\\n                starStatus = ''\\n            }\\n            if (starStatus !== '') isStarred = 1;\\n            // setError(starStatus);\\n            d.push({\\n                col_type: 'line',\\n            });\\n            d.push({ //  text_center_1 icon_small_3\\n                title: isStarred === 0 ? '收藏' : '已收藏',\\n                pic_url: starIcon,\\n                col_type: 'icon_small_3',\\n                url: mUrl + '#' + token + '#' + resultTips + '#' + isStarred + `@lazyRule=.js: var urlSplits=input.split('#');var mUrl=urlSplits[0]; var token=urlSplits[1];var resultTips=parseInt(urlSplits[2]);var isStarred=parseInt(urlSplits[3]);let message = '';if (\\\\/topic\\\\\\\\/(\\\\\\\\d+)/.test(mUrl) === true){let entityId = RegExp.$1;if (entityId != null && entityId !== \\\"\\\") {let starUrl='https:\\\\/\\\\/haikuoshijie.cn\\\\/api\\\\/topic\\\\/favorite\\\\/'+entityId;if(isStarred){starUrl='https:\\\\/\\\\/haikuoshijie.cn\\\\/api\\\\/favorite\\\\/delete?entityType=topic&entityId='+entityId;} let options={headers:{'X-User-Token': token},body: '', method: 'GET'};/*setError (options);*/let starResult=fetch(starUrl, options);/*setError (starResult);*/if(resultTips){starResult=JSON.parse(starResult);message=starResult.message;if(starResult.message===''){if(starResult.success===true){message=isStarred===1?'已取消收藏':'收藏成功'; refreshPage(false);}} else if (starResult.message === '请先登录') {let tokenFile = 'hiker:\\\\/\\\\/files\\\\/rules\\\\/js\\\\/hikerbbs_token.js';writeFile(tokenFile, '');message = '请重新访问一次论坛网页获取登录信息';} message='toast:\\\\/\\\\/'+message;}}}message`\\n            });\\n            d.push({ //  text_center_1 icon_small_3\\n                title: '点赞',\\n                pic_url: likeIcon,\\n                col_type: 'icon_small_3',\\n                url: mUrl + '#' + token + '#' + resultTips + `@lazyRule=.js: var urlSplits=input.split('#');var mUrl=urlSplits[0]; var token=urlSplits[1];var resultTips=parseInt(urlSplits[2]);let message = '';if (\\\\/topic\\\\\\\\/(\\\\\\\\d+)/.test(mUrl) === true){let entityId = RegExp.$1;if (entityId != null && entityId !== \\\"\\\") {let likeUrl='https:\\\\/\\\\/haikuoshijie.cn\\\\/api\\\\/topic\\\\/like\\\\/'+entityId; let options={headers:{'X-User-Token': token},body: '', method: 'POST'};/*setError (options);*/let likeResult=fetch(likeUrl, options);/*setError (likeResult);*/if(resultTips){likeResult=JSON.parse(likeResult);message=likeResult.message;if(likeResult.message===''){if(likeResult.success===true)message='点赞成功';refreshPage(false);} else if (likeResult.message === '请先登录') {let tokenFile = 'hiker:\\\\/\\\\/files\\\\/rules\\\\/js\\\\/hikerbbs_token.js';writeFile(tokenFile, '');message = '请重新访问一次论坛网页获取登录信息';} message='toast:\\\\/\\\\/'+message;}}}message`\\n            });\\n            d.push({\\n                title: '回复',\\n                pic_url: commentIcon,\\n                col_type: 'icon_small_3',\\n                url: mUrl\\n            });\\n            /*d.push({\\n                title: '原文',\\n                pic_url: articleIcon,\\n                col_type: 'icon_small_3',\\n                url: mUrl\\n            });*/\\n            d.push({\\n                col_type: 'line',\\n            });\\n        } else {\\n            if (showInputTokenTips) {\\n                let pluginLatest = '海阔视界规则分享，当前分享的是：网页插件，Reborn￥js_url￥haikuoshijie.cn_获取用户Token@base64://KGZ1bmN0aW9uICgpIHsKICAgIC8v5LuO5LiL6Z2i5LiA6KGM5byA5aeL5YaZ5Luj56CBCgogICAgL3VzZXJUb2tlbj0oW2EtekEtWjAtOV0qKTsqLy50ZXN0KGRvY3VtZW50LmNvb2tpZSk7CiAgICAvL2FsZXJ0KGRvY3VtZW50LmNvb2tpZSsi4oCmIitSZWdFeHAuJDEpOwoKICAgIC8vIGZ5X2JyaWRnZV9hcHAucHV0VmFyKCJoaWtlcmJic190b2tlbiIsUmVnRXhwLiQxKTsKICAgIGZ5X2JyaWRnZV9hcHAud3JpdGVGaWxlKCdoaWtlcjovL2ZpbGVzL3J1bGVzL2pzL2hpa2VyYmJzX3Rva2VuLmpzJywgUmVnRXhwLiQxKTsKCn0pKCk7';\\n                let pluginUrl = 'hiker://files/rules/js/haikuoshijie.cn_获取用户Token.js';\\n                let plugin = '';\\n                try {\\n                    plugin = fetch(pluginUrl, {});\\n                    if (plugin == null) plugin = '';\\n                } catch (e) {\\n                    plugin ='';\\n                }\\n                let pluginUpdate = 0;\\n                if (plugin !== '') {\\n                    if (pluginLatest.split('base64:\\\\/\\\\/')[1] !== base64Encode(plugin).replace(/\\\\n/g, '')) pluginUpdate = 1;\\n                }\\n                d.push({\\n                    title: \\\"<p></p>\\\" + '<small><font color=\\\"grey\\\">' +  '如需收藏或点赞功能，需登录论坛后执行以下步骤获取 Token：<br>[本提示可编辑规则关闭]<br>1. ' + ((plugin === '' || pluginUpdate === 1) ? '点击下方口令代码' + (pluginUpdate === 1 ? '<b>更新插件</b>' : '导入专用插件') + '，然后' : '你已导入最新专用插件，只需') + '<a href=\\\"' + MY_URL + '\\\">[查看原文]</a>一次再返回刷新' + ((plugin === '' || pluginUpdate === 1) ? '<br><pre><code>' + pluginLatest + '</code></pre>' : '') + \\\"</font></small>\\\",\\n                    col_type: colType\\n                });\\n            }\\n        }\\n\\n        if (showComment) {\\n            /*if (hasRule) {\\n            for(var i = 0; i < 2; i++)\\n            d.push({\\n                   col_type: 'line'\\n              });\\n            }*/\\n\\n            /cursor:\\\"(.*?)\\\"/.test(html);\\n            let cursorTemp = RegExp.$1;\\n            let cursor = (cursorTemp != null && cursorTemp !== '') ? cursorTemp : '0';\\n            putVar({key: 'cursor', value: cursor});\\n            putVar({key: 'first_page_cursor', value: cursor});\\n\\n            d.push({\\n                title: \\\"<p></p>\\\" + \\\"<big><b>\\\" + parseDomForHtml(html, '.comment-title&&Html') + \\\"</b></big>\\\",\\n                col_type: colType\\n            });\\n            var pl = parseDom(html, '.comments&&Html')\\n                .match(/<li[\\\\s\\\\S]*?<\\\\/li/g);\\n            if (pl == null || pl.length === 0) {\\n                d.push({\\n                    title: \\\"<p></p>\\\" + '<font color=\\\"grey\\\">暂无评论</font>',\\n                    col_type: colType\\n                });\\n            } else {\\n                for (let j = 0; j < pl.length; j++) {\\n                    // /(<(div|p)([\\\\s\\\\S]*?)>)|<div>|<p>|<\\\\/div>|<\\\\/p>/g\\n                    let commentContent = parseDomForHtml(pl[j], '.comment-content&&Html')\\n                        .replace(/<img class=\\\"avatar([\\\\s\\\\S]*?)>/g, '')\\n                        .replace(/(<(p)([\\\\s\\\\S]*?)>)|<p>|<\\\\/p>/g, '')\\n                        .replaceWithCallback(/<img (src|data-src)=\\\"(.*?)\\\"([\\\\s\\\\S]*?)>/g, \\\"<img data-v>\\\", imgTagReplacement2)\\n                        .replace(/<img([\\\\s\\\\S]*?)>/g, imgError)\\n                        .replace(/<showimg/g, '<img');\\n                    try {\\n                        let commentReplyText = parseDomForHtml(pl[j], '.comment-quote&&Html');\\n                        let commentQuoteUsername = parseDomForHtml(commentReplyText, \\\".quote-nickname&&Html\\\");\\n                        let commentQuoteTime = parseDomForHtml(commentReplyText, \\\".quote-time&&Html\\\");\\n                        commentReplyText = commentReplyText\\n                            .replace(/<a[\\\\s\\\\S].*?<\\\\/a>/g, '');\\n                        let commentReplyTextArray = commentReplyText.match(/<p[\\\\s\\\\S].*?<\\\\/p>/g);\\n                        commentContent = abbreviateReplyText(commentContent, commentReplyTextArray)\\n                            .replace(commentQuoteUsername, '<font color=\\\"' + quoteUserColor + '\\\">' + commentQuoteUsername + '</font>')\\n                            .replace(commentQuoteTime, '<font color=\\\"grey\\\">' + commentQuoteTime + '</font>');\\n                    } catch (e) {\\n                    }\\n                    d.push({ // p,-2\\n                        title: \\\"<p></p>\\\" + commentContent + '<br><small>' + parseDomForHtml(pl[j], '.comment-nickname&&Html').replace(/<a[\\\\s\\\\S].*?>/g, '<font color=\\\"' + userColor + '\\\">').replace(/<\\\\/a>/g, \\\"</font>\\\") + '\\\\t\\\\t<font color=\\\"grey\\\">' + parseDomForHtml(pl[j], '.comment-meta--span&&Text') + '</font></small>',\\n                        desc: '',\\n                        url: MY_URL,\\n                        col_type: colType\\n                    });\\n                    d.push({\\n                        col_type: 'line'\\n                    });\\n                }\\n            }\\n        }\\n    } catch (e) {}\\n} catch (e) {\\nd.push({\\ntitle: '<p style=\\\"text-align: center;\\\">该页面无法解析或话题不存在</p><p style=\\\"text-align: center;\\\"><a href=\\\"' + MY_URL +'\\\">查看原文</a></p>',\\ncol_type: 'rich_text'\\n})\\n}\\n}\\n\\nres.data = d;\\nsetHomeResult(res);\",\"group\":\"①推荐\",\"ua\":\"mobile\",\"preRule\":\"/**\\n * 通过插件自动获取 Token 到文件中然后自动读取\\n *\\n * 注意：以上方的 token 为主\\n */\\nvar fileToken = '';\\ntry {\\n    fileToken = fetch ('hiker://files/rules/js/hikerbbs_token.js', {});\\n    if (fileToken == null) fileToken = '';\\n} catch (e) {\\n    fileToken = '';\\n}\\nputVar2('hiker_token', fileToken);\",\"pages\":\"[]\"}","title":"模板.Q小白教程"}
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement