forked from hoothin/UserScripts
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpagetual.user.js
7643 lines (7445 loc) · 370 KB
/
pagetual.user.js
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
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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
// ==UserScript==
// @name Pagetual
// @name:zh-CN 东方永页机
// @name:zh-TW 東方永頁機
// @name:ja 東方永頁機
// @name:ko 東方永頁機
// @name:ru Pagetual
// @name:de Pagetual
// @name:es Pagetual
// @name:fr Pagetual
// @name:it Pagetual
// @namespace hoothin
// @version 1.9.36.41
// @description Perpetual pages - powerful auto-pager script. Auto loading next paginated web pages and inserting into current page. Support thousands of web sites without any rule.
// @description:zh-CN 终极自动翻页 - 加载并拼接下一分页内容至当前页尾,智能适配任意网页
// @description:zh-TW 終極自動翻頁 - 加載並拼接下一分頁內容至當前頁尾,智能適配任意網頁
// @description:ja Webページを自動で読み込み継ぎ足し表示を行うブラウザ拡張です、次のページ付けされた Web ページの自動読み込みと現在のページへの挿入 ルールなしで何千もの Web サイトをサポートします。
// @description:ko 페이지가 매겨진 다음 웹 페이지를 자동으로 로드하고 현재 페이지에 삽입합니다. 규칙 없이 수천 개의 웹 사이트를 지원합니다.
// @description:ru Автоматическая подгрузка следующих страниц и вставка их содержимого в текущую страницу. Поддерживает тысячи сайтов даже с настройками по умолчанию.
// @description:de Automatisches Laden der nächsten paginierten Webseiten und Einfügen in die aktuelle Seite. Unterstützen Sie Tausende von Websites ohne Regeln.
// @description:es Carga automática de las siguientes páginas web paginadas e inserción en la página actual. Admite miles de sitios web sin ninguna regla.
// @description:fr Chargement automatique des pages Web paginées suivantes et insertion dans la page en cours. Prend en charge des milliers de sites Web sans aucune règle.
// @description:it Caricamento automatico delle pagine Web impaginate successive e inserimento nella pagina corrente. Supporta migliaia di siti web senza alcuna regola.
// @author hoothin
// @license MPL-2.0
// @match *://*/*
// @icon 
// @grant GM_xmlhttpRequest
// @grant GM_registerMenuCommand
// @grant GM_notification
// @grant GM_getValue
// @grant GM_setValue
// @grant GM_addStyle
// @grant GM_openInTab
// @grant GM_deleteValue
// @grant GM_info
// @grant GM_setClipboard
// @grant GM.xmlHttpRequest
// @grant GM.registerMenuCommand
// @grant GM.notification
// @grant GM.getValue
// @grant GM.setValue
// @grant GM.addStyle
// @grant GM.openInTab
// @grant GM.deleteValue
// @grant GM.info
// @grant GM.setClipboard
// @downloadURL https://greasyfork.org/scripts/438684-pagetual/code/Pagetual.user.js
// @updateURL https://greasyfork.org/scripts/438684-pagetual/code/Pagetual.user.js
// @supportURL https://github.com/hoothin/UserScripts/issues
// @connect wedata.net
// @connect githubusercontent.com
// @connect ghproxy.com
// @connect hoothin.github.io
// @run-at document-idle
// @connect *
// ==/UserScript==
(function() {
'use strict';
if (window.name === 'pagetual-iframe' || (window.frameElement && window.frameElement.name === 'pagetual-iframe')) {
var domloaded = function() {
window.parent.postMessage('pagetual-iframe:DOMLoaded', '*');
};
if (window.opera) {
document.addEventListener('DOMContentLoaded', domloaded, false);
} else {
domloaded();
}
if (getComputedStyle(document.documentElement).display == 'none') document.documentElement.style.display = 'block';
if (document.body && getComputedStyle(document.body).display == 'none') document.body.style.display = 'block';
return;
}
if (window.top != window.self) {
try {
if (window.self.innerWidth < 300 || window.self.innerHeight < 300) {
return;
}
} catch(e) {
return;
}
}
const noRuleTest = false;
const lang = navigator.appName == "Netscape" ? navigator.language : navigator.userLanguage;
let config = {};
switch (lang) {
case "zh-CN":
case "zh-SG":
config = {
enableDebug: "调试模式,输出信息至控制台",
disable: "暂时禁用",
disableSite: "站点禁用开关",
disableSiteTips: "已在此站禁用",
enableSiteTips: "已在此站启用",
enable: "启用自动翻页",
toTop: "回到顶部",
toBottom: "前往页尾",
current: "当前页",
forceIframe: "强制拼接",
cancelForceIframe: "取消强制拼接",
configure: "打开配置页面",
firstUpdate: "点击此处初始化规则",
update: "更新在线规则",
click2update: "点击立即更新规则",
loadNow: "立即翻页",
loadConfirm: "要翻几页?(0为不间断)",
noNext: "没有找到下一页,请新建规则",
passSec: "更新于 #t# 秒前",
passMin: "更新于 #t# 分钟前",
passHour: "更新于 #t# 小时前",
passDay: "更新于 #t# 天前",
cantDel: "无法删除内置规则",
confirmDel: "是否确认要删除此规则?",
updateSucc: "更新成功",
beginUpdate: "正在更新,请耐心等待,不要关闭页面",
customUrls: "导入 Pagetual 或 AutoPagerize 规则 url,一行一条",
customRules: "输入【东方永页机】格式的自定义规则 <a href='#t#'>贡献规则</a>",
save: "保存设置",
loadingText: "少女祈祷中...",
opacity: "不透明值",
opacityPlaceholder: "0: 隐藏分隔条",
hideBar: "隐藏分页隔条",
hideBarButNoStop: "隐藏但不停止",
dbClick2Stop: "空白处双击暂停翻页",
sortTitle: "排序在下次更新规则后生效",
autoRun: "自动启用,否则为白名单模式",
autoLoadNum: "自动加载指定页数",
turnRate: "距离页尾【X】倍页面高度时就开始翻页",
inputPageNum: "输入页码跳转",
enableHistory: "翻页后写入历史记录",
enableHistoryAfterInsert: "拼接后立即写入历史记录,否则浏览完毕后再行写入",
contentVisibility: "自动切换 contentVisibility,提升渲染性能",
initRun: "打开页面后立即尝试翻页,否则滚动至页尾再翻页",
preload: "翻页前预读下一页,加速浏览",
click2ImportRule: "点击下方添加特殊规则库,并静待更新成功:",
forceAllBody: "是否拼接整个页面?",
openInNewTab: "使拼接页面的内容在新页面打开",
importSucc: "导入成功",
import: "导入",
editCurrent: "编辑此站规则",
editBlacklist: "编辑黑名单网址,一行一条,支持? *通配符与正则",
upBtnImg: "回到页首图标",
downBtnImg: "前往页尾图标",
sideControllerIcon: "侧边栏图标",
loadingTextTitle: "加载中文字",
dbClick2StopCtrl: "Ctrl 键",
dbClick2StopAlt: "Alt 键",
dbClick2StopShift: "Shift 键",
dbClick2StopMeta: "Meta 键",
dbClick2StopKey: "快捷键",
pageElementCss: "页面主体框架的样式",
customCss: "自定义 css",
firstAlert: "你还未导入规则库,请选择合适的规则库导入哦",
picker: "东方永页机主体元素抓取器",
closePicker: "关闭东方永页机抓取器",
pickerPlaceholder: "元素选择器,没想法建议留空",
pickerCheck: "检查你编辑的选择器并复制",
switchSelector: "点击切换元素",
gotoEdit: "使用当前的选择器前往编辑规则",
manualMode: "禁用拼接,手动用右方向键翻页,可使用左方向键返回",
clickMode: "禁用拼接,滚动至页尾时自动点击下一页",
pageBarMenu: "点击分隔条中间弹出菜单",
nextSwitch: "切换其他页码",
arrowToScroll: "左方向键滚动至上一页,右方向键滚动至下一页",
sideController: "在侧边显示翻页控制栏",
hideLoadingIcon: "隐藏加载动画",
hideBarArrow: "隐藏分隔条定位箭头",
duplicate: "检测到永页机重复安装,请删除其他脚本管理器中的永页机!",
forceStateIframe: "以 iframe 嵌入整页",
forceStateDynamic: "通过 iframe 加载动态内容后取出",
forceStateDisable: "在此站禁用",
autoScrollRate: "滚动速度(1~1000)",
disableAutoScroll: "停止自动滚动",
enableAutoScroll: "开启自动滚动",
toggleAutoScroll: "自动滚动开关",
page: "Page ",
prevPage: "上一页",
nextPage: "下一页",
errorRulesMustBeArray: "规则必须为数组形式!",
errorJson: "JSON 格式有错,请重新检查!",
editSuccess: "编辑成功",
errorWrongUrl: "URL 错误, 请重新检查!",
errorAlreadyExists: "已经存在!",
settingsSaved: "设置已保存,刷新后生效",
iframe: "强制拼接",
dynamic: "动态加载",
reloadPage: "编辑完成,是否立即刷新页面?",
copied: "已复制",
noValidContent: "没有检测到有效内容,点击查看",
outOfDate: "脚本已过时,请及时更新到最新版本!",
hideBarTips: "隐藏分页隔条,沉浸式体验",
setConfigPage: "将当前页面设为默认配置页",
wedata2github: "将 wedata 地址更改为 github 仓库内的镜像地址",
addOtherProp: "添加规则属性",
addNextSelector: "添加选择器内容为 nextLink",
addPageSelector: "添加选择器内容为 pageElement",
propName: "输入规则属性名",
propValue: "输入规则属性值",
customFirst: "为本地自定义规则忽略缓存"
};
break;
case "zh-TW":
case "zh-HK":
config = {
enableDebug: "調試模式,輸出信息至控制台",
disable: "暫時禁用",
disableSite: "站點禁用開關",
disableSiteTips: "已在此站禁用",
enableSiteTips: "已在此站啟用",
enable: "啟用自動翻頁",
toTop: "回到頂部",
toBottom: "前往頁尾",
current: "當前頁",
forceIframe: "強制拼接",
cancelForceIframe: "取消强制拼接",
configure: "打開配置頁面",
firstUpdate: "點擊此處初始化規則",
update: "更新在綫規則",
click2update: "點擊立即更新規則",
loadNow: "立即翻頁",
loadConfirm: "要翻几頁?(0為不間斷)",
noNext: "沒有找到下一頁,請新建規則",
passSec: "更新于 #t# 秒前",
passMin: "更新于 #t# 分鐘前",
passHour: "更新于 #t# 小時前",
passDay: "更新于 #t# 天前",
cantDel: "無法刪除内置規則",
confirmDel: "是否確認要刪除此規則?",
updateSucc: "更新成功",
beginUpdate: "正在更新,請稍候",
customUrls: "導入 Pagetual 或 AutoPagerize 規則 url,一行一條",
customRules: "輸入【東方永頁機】格式的自定義規則 <a href='#t#'>貢獻規則</a>",
save: "存儲設置",
loadingText: "少女祈禱中...",
opacity: "不透明值",
opacityPlaceholder: "0: 隱藏分隔條",
hideBar: "隱藏分頁隔條",
hideBarButNoStop: "隱藏但不停止",
dbClick2Stop: "空白處雙擊暫停翻頁",
sortTitle: "排序在下次更新規則後生效",
autoRun: "自動啓用,否則為白名單模式",
autoLoadNum: "自動加載指定頁數",
turnRate: "距離頁尾【X】倍頁面高度時就開始翻頁",
inputPageNum: "輸入頁碼跳轉",
enableHistory: "翻頁后寫入歷史記錄",
enableHistoryAfterInsert: "拼接後立即寫入歷史記錄,否則瀏覽完畢後再行寫入",
contentVisibility: "自動切換 contentVisibility,提升渲染性能",
initRun: "打開頁面后立即嘗試翻頁,否則滾動至頁尾再翻頁",
preload: "翻頁前預讀下一頁,加速瀏覽",
click2ImportRule: "點擊下方添加特殊規則庫,并靜待更新成功:",
forceAllBody: "是否拼接整個頁面?",
openInNewTab: "使拼接頁面的内容在新頁面打開",
importSucc: "導入成功",
import: "導入",
editCurrent: "編輯此站規則",
editBlacklist: "編輯黑名單網址,一行一條,支持? *通配符與正則",
upBtnImg: "回到頁首圖標",
downBtnImg: "前往頁尾圖標",
sideControllerIcon: "側邊欄圖標",
loadingTextTitle: "加載中文字",
dbClick2StopCtrl: "Ctrl 鍵",
dbClick2StopAlt: "Alt 鍵",
dbClick2StopShift: "Shift 鍵",
dbClick2StopMeta: "Meta 鍵",
dbClick2StopKey: "快捷鍵",
pageElementCss: "頁面主體框架的樣式",
customCss: "自定義 css",
firstAlert: "你還未導入規則庫,請選擇合適的規則庫導入哦",
picker: "東方永頁機主體元素抓取器",
closePicker: "關閉東方永頁機抓取器",
pickerPlaceholder: "元素選擇器,沒想法建議留空",
pickerCheck: "檢查你編輯的選擇器並複製",
switchSelector: "點擊切換元素",
gotoEdit: "使用當前的選擇器前往編輯規則",
manualMode: "禁用拼接,手動用右方向鍵翻頁,左方向鍵返回",
clickMode: "禁用拼接,滾動至頁尾時自動點擊下一頁",
pageBarMenu: "點擊分隔條中間彈出菜單",
nextSwitch: "切換其他頁碼",
arrowToScroll: "左方向鍵滾動至上一頁,右方向鍵滾動至下一頁",
sideController: "在側邊顯示翻頁控制欄",
hideLoadingIcon: "隱藏加載動畫",
hideBarArrow: "隱藏分隔條定位箭頭",
duplicate: "檢測到永頁機重複安裝,請刪除其他腳本管理器中的永頁機!",
forceStateIframe: "以 iframe 嵌入整頁",
forceStateDynamic: "通過 iframe 加載動態內容後取出",
forceStateDisable: "在此站禁用",
autoScrollRate: "滾動速度(1~1000)",
disableAutoScroll: "停止自動滾動",
enableAutoScroll: "開啟自動滾動",
toggleAutoScroll: "自動滾動開關",
page: "Page ",
prevPage: "上一頁",
nextPage: "下一頁",
errorRulesMustBeArray: "規則必須為陣列形式!",
errorJson: "JSON 格式有錯,請重新檢查!",
editSuccess: "編輯成功",
errorWrongUrl: "URL 錯誤, 請重新檢查!",
errorAlreadyExists: "已經存在!",
settingsSaved: "設置已保存,刷新後生效",
iframe: "強制拼接",
dynamic: "動態加載",
reloadPage: "編輯完成,是否立即刷新頁面?",
copied: "已復制",
noValidContent: "沒有檢測到有效内容,點擊查看",
outOfDate: "脚本已過時,請及時更新到最新版本!",
hideBarTips: "隱藏分頁隔條,沉浸式體驗",
setConfigPage: "將當前頁面設為默認配置頁",
wedata2github: "將 wedata 地址更改為 github 倉庫內的鏡像地址",
addOtherProp: "添加規則屬性",
addNextSelector: "添加選擇器內容為 nextLink",
addPageSelector: "添加選擇器內容為 pageElement",
propName: "輸入規則屬性名",
propValue: "輸入規則屬性值",
customFirst: "為本地自定義規則忽略緩存"
};
break;
case "ja":
config = {
enableDebug: "デバッグモード",
disable: "一時的に無効",
disableSite: "無効状態の切り替え",
disableSiteTips: "このサイトで既に無効になっています",
enableSiteTips: "このサイトで既に有効になっています",
enable: "ページめくりを有効にする",
toTop: "トップに戻る",
toBottom: "ページの下部に移動",
current: "現在のページ",
forceIframe: "強制ステッチ",
cancelForceIframe: "強制ステッチをキャンセル",
configure: "設定ページを開く",
firstUpdate: "ここをクリックしてルールを初期化します",
update: "更新ルール",
click2update: "今すぐルールを更新してください",
loadNow: "今すぐページをめくる",
loadConfirm: "数ページめくりたいですか?(0は途切れない)",
noNext: "次のページが見つかりません、新しいルールを作成してください",
passSec: "#t#秒前に更新",
passMin: "#t#分前に更新",
passHour: "#t#時間前に更新",
passDay: "#t#日前に更新",
cantDel: "組み込みルールを削除できません",
confirmDel: "このルールを削除してもよろしいですか?",
updateSucc: "更新に成功しました",
beginUpdate: "更新中、お待ちください",
customUrls: "インポートルールのURL、1行に1つ",
customRules: "【東方永頁機】の形式でカスタムルールを入力してください <a href='#t#'>寄稿ルール</a>",
save: "設定を保存",
loadingText: "少女祈祷中...",
opacity: "不透明値",
opacityPlaceholder: "0: 隠す",
hideBar: "ページ区切り文字を非表示にします",
hideBarButNoStop: "非表示にするが停止しない",
dbClick2Stop: "空白部分をダブルクリックしてページめくりを一時停止します",
sortTitle: "並べ替えは、次のルールの更新後に有効になります",
autoRun: "自動的に有効",
autoLoadNum: "指定したページ数を自動的に読み込みます",
turnRate: "ページの端からページの高さの【X】倍になったらページをめくる",
inputPageNum: "ジャンプするページ番号を入力",
enableHistory: "ページめくり後の履歴を書く",
enableHistoryAfterInsert: "スプライシングの直後に履歴レコードを書き込みます。それ以外の場合は、閲覧後に書き込みます",
contentVisibility: "contentVisibility を自動的に切り替えてレンダリング パフォーマンスを向上させる",
initRun: "Webページを開いた直後にページをめくる",
preload: "事前に次のページを読む",
click2ImportRule: "以下をクリックして、ルールベースを追加します:",
forceAllBody: "フルページ埋め込み?",
openInNewTab: "スプライスされたページのコンテンツを新しいページで開きます",
importSucc: "インポート完了",
import: "インポート",
editCurrent: "現在のルールの編集",
editBlacklist: "ブラックリストのURLを編集し、1行ずつ、サポート? *ワイルドカード",
upBtnImg: "トップアイコンに戻る",
downBtnImg: "フッターアイコンに移動",
sideControllerIcon: "サイドバー アイコン",
loadingTextTitle: "テキストをロード",
dbClick2StopCtrl: "Ctrlキー",
dbClick2StopAlt: "Altキー",
dbClick2StopShift: "Shiftキー",
dbClick2StopMeta: "Metaキー",
dbClick2StopKey: "Shortcutキー",
pageElementCss: "ページ本文フレームの STYLE",
customCss: "カスタム css",
firstAlert: "ルールベースをインポートしていないため、インポートする適切なルールベースを選択してください",
picker: "Pagetualページ要素ピッカー",
closePicker: "Pagetualピッカーを閉じる",
pickerPlaceholder: "わからない場合は空のままにしてください",
pickerCheck: "セレクターをチェックしてコピー",
switchSelector: "クリックして要素を切り替えます",
gotoEdit: "現在のセレクターでルールを編集する",
manualMode: "スプライシングを無効にします。手動で右の矢印キーを使用してページをめくります",
clickMode: "スティッチングを無効にします。ページの最後までスクロールすると、次のページが自動的にクリックされます",
pageBarMenu: "ページバーの中央をクリックしてメニューをポップアップ表示",
nextSwitch: "次のページに切り替え",
arrowToScroll: "左矢印キーで前へ、右矢印キーで次へ",
sideController: "サイドバーにページング コントロール バーを表示する",
hideLoadingIcon: "読み込み中のアニメーションを隠す",
hideBarArrow: "分割線の位置矢印を隠す",
duplicate: "Pagetual の重複インストールが検出されました。他のスクリプト マネージャで永続的なページ マシンを削除してください!",
forceStateIframe: "iframe にページ全体を埋め込む",
forceStateDynamic: "iframe 経由で動的コンテンツを読み込む",
forceStateDisable: "このステーションでのページめくりを無効にする",
autoScrollRate: "スクロール速度 (1~1000)",
disableAutoScroll: "自動スクロールを停止します",
EnableAutoScroll: "自動スクロールを有効にする",
toggleAutoScroll: "自動スクロールの切り替え",
page: "Page ",
prevPage: "Prev page",
nextPage: "Next page",
errorRulesMustBeArray: "Rules must be a Array!",
errorJson: "JSON error, check again!",
editSuccess: "Edit successfully",
errorWrongUrl: "Wrong url, check again!",
errorAlreadyExists: "Already exists!",
settingsSaved: "The settings are saved, refresh to view",
iframe: "Iframe",
dynamic: "Dynamic",
reloadPage: "Edit completed, reload page now?",
copied: "Copied",
noValidContent: "有効なコンテンツが検出されませんでした。クリックして表示",
outOfDate: "スクリプトが古くなっています。最新バージョンに更新してください。",
hideBarTips: "ページネーション バーを非表示にします。没入型エクスペリエンス",
setConfigPage: "現在のページをデフォルト設定ページとして設定",
wedata2github: "wedata アドレスを github ウェアハウスのミラー アドレスに変更",
addOtherProp: "ルールプロパティを追加",
addNextSelector: "セレクターのコンテンツを nextLink として追加",
addPageSelector: "セレクタ コンテンツを pageElement として追加",
propName: "ルールのプロパティ名を入力してください",
propValue: "ルールのプロパティ値を入力してください",
customFirst: "ローカルカスタムルールのキャッシュを無視する"
};
break;
case "ru":
case "ru-RU":
config = {
enableDebug: "Включить отладку",
disable: "Выключить",
disableSite: "Включить/выключить на сайте",
disableSiteTips: "Выключено для этого сайта",
enableSiteTips: "Включено для этого сайта",
enable: "Включить",
toTop: "Наверх",
toBottom: "Вниз",
current: "Текущая страница",
forceIframe: "Подгрузить ещё страницу",
cancelForceIframe: "Отменить подгрузку",
configure: "Настройки",
firstUpdate: "Нажмите здесь, чтобы инициализировать правила",
update: "Обновить правила",
click2update: "Нажмите, чтобы обновить правила",
loadNow: "Загрузить следующую страницу",
loadConfirm: "Сколько страниц вы хотите загрузить? (0 означает бесконечность)",
noNext: "Ссылка на следующую страницу не найдена. Пожалуйста, создайте новое правило",
passSec: "Обновлено #t# секунд назад",
passMin: "Обновлено #t# минут назад",
passHour: "Обновлено #t# часов назад",
passDay: "Обновлено #t# дней назад",
cantDel: "Нельзя удалить правила по умолчанию",
confirmDel: "Вы уверены, что хотите удалить эту ссылку?",
updateSucc: "Правила обновлены",
beginUpdate: "Обновление. Пожалуйста, немного подождите",
customUrls: "Ссылки с правилами для импорта. Одна ссылка на строку",
customRules: "Введите пользовательские правила в формате Pagetual. <a href='#t#'>Улучшить встроенные правила</a>",
save: "Сохранить настройки",
loadingText: "Следующая страница подгружается…",
opacity: "Прозрачность",
opacityPlaceholder: "0 - скрыть",
hideBar: "Скрыть разделитель страниц",
hideBarButNoStop: "Скрыть, но не останавливать",
dbClick2Stop: "Двойной клик на странице для выключения",
sortTitle: "Правило сортировки применится после следующего обновления правил",
autoRun: "Автозапуск (режим черного списка)",
autoLoadNum: "Количество страниц для предзагрузки",
turnRate: "Подгрузить страницу, когда она будет в 【X】 раз больше высоты страницы от конца страницы",
inputPageNum: "Введите номер страницы для перехода",
enableHistory: "Записать историю после переключения страниц",
enableHistoryAfterInsert: "Записать запись истории сразу после вставки, иначе записать после просмотра",
contentVisibility: "Автоматически переключать contentVisibility для повышения производительности рендеринга",
initRun: "Подгружать страницы сразу после открытия",
preload: "Предзагрузка следующей страницы",
click2ImportRule: "Нажмите, чтобы импортировать базовые правила: ",
forceAllBody: "Присоединить страницу целиком?",
openInNewTab: "Открыть дополнительные ссылки в новой вкладке",
importSucc: "Импорт завершен",
import: "Импорт",
editCurrent: "Изменить правило для текущего сайта",
editBlacklist: "Изменить черный список. Одна ссылка на строку. Поддерживаются метасимволы: ? и *",
upBtnImg: "Иконка перехода к началу",
downBtnImg: "Иконка перехода к концу",
sideControllerIcon: "Значок боковой панели",
loadingTextTitle: "Текст во время загрузки",
dbClick2StopCtrl: "Ctrl",
dbClick2StopAlt: "Alt",
dbClick2StopShift: "Shift",
dbClick2StopMeta: "Meta",
dbClick2StopKey: "Клавиша",
pageElementCss: "Пользовательский стиль для основных элементов страницы",
customCss: "Полный пользовательский CSS",
firstAlert: "Вы не импортировали базовое правило. Пожалуйста, выберите соответствующее правило для импорта",
picker: "Pagetual: выбор элемента страницы",
closePicker: "Закрыть окно Pagetual",
pickerPlaceholder: "Если не знаете, что тут писать — оставьте поле пустым",
pickerCheck: "Проверить и скопировать селектор",
switchSelector: "Нажмите для выбора элемента",
gotoEdit: "Перейти к редактированию правила с текущим селектором",
manualMode: "Отключить автоматическую загрузку страниц. Загружать вручную с помощью стрелки вправо (или вызова события 'pagetual.next')",
clickMode: "Отключить \"сшивание\" страниц. При прокрутке до конца автоматически переходить на следующую страницу",
pageBarMenu: "Открывать меню кликом на середину панели страниц",
nextSwitch: "Переключить ссылку на следующую страницу",
arrowToScroll: "Листать страницы клавишами со стрелками влево и вправо",
sideController: "Показать справа панель перемещения по вкладке",
hideLoadingIcon: "Скрыть анимацию загрузки",
hideBarArrow: "Скрыть кнопки перемещения на разделителе",
duplicate: "Похоже, Pagetual установлен несколько раз. Пожалуйста, удалите Pagetual из других менеджеров скриптов!",
forceStateIframe: "Вставить полную страницу как iframe",
forceStateDynamic: "Загружать динамический контент через iframe",
forceStateDisable: "Отключить перелистывание страниц на этой станции",
autoScrollRate: "Скорость прокрутки (1~1000)",
disableAutoScroll: "Остановить автоматическую прокрутку",
enableAutoScroll: "Включить автопрокрутку",
toggleAutoScroll: "Переключить автопрокрутку",
page: "Страница ",
prevPage: "Предыдущая страница",
nextPage: "Следующая страница",
errorRulesMustBeArray: "Правила должны быть массивом!",
errorJson: "Ошибка разбора JSON. Пожалуйста, исправьте его",
editSuccess: "Редактирование успешно",
errorWrongUrl: "Ссылка некорректна. Пожалуйста, исправьте её",
errorAlreadyExists: "Уже существует!",
settingsSaved: "Настройки сохранены. Обновите страницы",
iframe: "iframe",
dynamic: "Динамически",
reloadPage: "Редактирование завершено. Обновить страницу?",
copied: "Скопировано",
noValidContent: "Действительный контент не обнаружен, нажмите для просмотра",
outOfDate: "Скрипт устарел, своевременно обновляйте до последней версии!",
hideBarTips: "Скрыть панель разбиения на страницы, иммерсивный опыт",
setConfigPage: "Установить текущую страницу в качестве страницы конфигурации по умолчанию",
wedata2github: "Изменить адрес wedata на зеркальный адрес на складе github",
addOtherProp: "Добавить свойство правила",
addNextSelector: "Добавить содержимое селектора как nextLink",
addPageSelector: "Добавить содержимое селектора как pageElement",
propName: "Введите имя свойства правила",
propValue: "Введите значение свойства правила",
customFirst: "Игнорировать кеш для локальных пользовательских правил"
};
break;
default:
config = {
enableDebug: "Enable debug output",
disable: "Disable",
disableSite: "Toggle disabled state",
disableSiteTips: "Disabled on this site",
enableSiteTips: "Enabled on this site",
enable: "Enable",
toTop: "To Top",
toBottom: "To Bottom",
current: "Current Page",
forceIframe: "Force to join next page",
cancelForceIframe: "Cancel Force join",
configure: "Configure",
firstUpdate: "Click here to initialize the rules",
update: "Update online rules",
click2update: "Click to update rules from url now",
loadNow: "Load next page manually",
loadConfirm: "How much pages do you want to load? (0 means infinite)",
noNext: "No next link found, please create a new rule",
passSec: "Updated #t# seconds ago",
passMin: "Updated #t# minutes ago",
passHour: "Updated #t# hours ago",
passDay: "Updated #t# days ago",
cantDel: "Can't delete buildin rules",
confirmDel: "Are you sure you want to delete this rule?",
updateSucc: "Update succeeded",
beginUpdate: "Begin update, wait a minute please",
customUrls: "Import Pagetual or AutoPagerize rule url, One url per line",
customRules: "Input custom rules with [Pagetual] format. <a href='#t#'>Contribute rules</a>",
save: "Save",
loadingText: "Shojo Now Loading...",
opacity: "Opacity",
opacityPlaceholder: "0: hide spacer",
hideBar: "Hide the paging spacer",
hideBarButNoStop: "Hide but not stop",
dbClick2Stop: "Double-click on the blank space to pause",
sortTitle: "Sorting takes effect after the next rule update",
autoRun: "Auto run (black list mode)",
autoLoadNum: "Amount for preload pages",
turnRate: "Turn the next page when it's less than 【X】 times page height from the footer",
inputPageNum: "Enter page number to jump",
enableHistory: "Write history after page turning",
enableHistoryAfterInsert: "Write history immediately after splicing, otherwise write after browsing",
contentVisibility: "Automatically switch contentVisibility to improve rendering performance",
initRun: "Turn pages immediately after opening",
preload: "Preload next page for speeding up",
click2ImportRule: "Click to import base rules link, then wait until the update is complete: ",
forceAllBody: "Join full body of page?",
openInNewTab: "Open urls of additions in new tab",
importSucc: "Import completed",
import: "Import",
editCurrent: "Edit rule for current",
editBlacklist: "Edit the blacklist urls, line by line, Support ? * for wildcard",
upBtnImg: "Icon of back to top",
downBtnImg: "Icon of go to footer",
sideControllerIcon: "Icon of sidebar",
loadingTextTitle: "Loading text",
dbClick2StopCtrl: "Ctrl key",
dbClick2StopAlt: "Alt key",
dbClick2StopShift: "Shift key",
dbClick2StopMeta: "Meta key",
dbClick2StopKey: "Shortcut key",
pageElementCss: "Custom style for main page elements",
customCss: "Custom complete css",
firstAlert: "You have not imported the base rule, please select the appropriate rule to import",
picker: "Pagetual page element picker",
closePicker: "Close Pagetual picker",
pickerPlaceholder: "Element selector, Leave empty if you have no idea",
pickerCheck: "Check selector and copy",
switchSelector: "Click to switch element",
gotoEdit: "Go to edit rule with current selector",
manualMode: "Disable splicing, manually turn pages with the right arrow keys (or dispatch event 'pagetual.next')",
clickMode: "Disable splicing, automatically click the next page when scrolling to the end of the page",
pageBarMenu: "Click the middle of the page bar to open the menu",
nextSwitch: "Switch next link",
arrowToScroll: "Press left arrow key to scroll prev and right arrow key to scroll next",
sideController: "Display the paging control bar in the sidebar",
hideLoadingIcon: "Hide loading animation",
hideBarArrow: "Hide arrow for page bar",
duplicate: "Duplicate Pagetual have been installed, check your script manager!",
forceStateIframe: "Embed full page as iframe",
forceStateDynamic: "Load dynamic content via iframe",
forceStateDisable: "Disable page turning on this site",
autoScrollRate: "Scroll speed (1~1000)",
disableAutoScroll: "Stop Auto Scroll",
enableAutoScroll: "Enable Auto Scroll",
toggleAutoScroll: "Toggle Auto Scroll",
page: "Page ",
prevPage: "Prev page",
nextPage: "Next page",
errorRulesMustBeArray: "Rules must be a Array!",
errorJson: "JSON error, check again!",
editSuccess: "Edit successfully",
errorWrongUrl: "Wrong url, check again!",
errorAlreadyExists: "Already exists!",
settingsSaved: "The settings are saved, refresh to view",
iframe: "Iframe",
dynamic: "Dynamic",
reloadPage: "Edit completed, reload page now?",
copied: "Copied",
noValidContent: "No valid content detected, click to view",
outOfDate: "The script is outdated, update to the latest version in time!",
hideBarTips: "Hide the pagination bar, toggle immersive experience",
setConfigPage: "Set current page as the default configuration page",
wedata2github: "Change the wedate address to the mirror address in the github repository",
addOtherProp: "Add rule property",
addNextSelector: "Add selector content as nextLink",
addPageSelector: "Add selector content as pageElement",
propName: "Enter rule property name",
propValue: "Enter rule property value",
customFirst: "Ignore cache for local custom rules"
};
break;
}
var enableDebug = true;
function i18n(name, param) {
return config[name] ? config[name].replace("#t#", param) : name;
};
function debug(str, title) {
if (enableDebug) {
console.log(
`%c【Pagetual v.${_GM_info.script.version}】 ${title ? title : 'debug'}:`,
'color: yellow;font-size: large;font-weight: bold;background-color: darkblue;',
str
);
}
};
var _GM_xmlhttpRequest, _GM_registerMenuCommand, _GM_notification, _GM_addStyle, _GM_openInTab, _GM_info, _GM_setClipboard;
if (typeof GM_xmlhttpRequest != 'undefined') {
_GM_xmlhttpRequest = GM_xmlhttpRequest;
} else if (typeof GM != 'undefined' && typeof GM.xmlHttpRequest != 'undefined') {
_GM_xmlhttpRequest = GM.xmlHttpRequest;
} else {
_GM_xmlhttpRequest = (f) => {fetch(f.url).then(response => response.text()).then(data => {let res = {response:data}; f.onload(res)}).catch(e => f.onerror(e))};
}
if (typeof GM_registerMenuCommand != 'undefined') {
_GM_registerMenuCommand = GM_registerMenuCommand;
} else if (typeof GM != 'undefined' && typeof GM.registerMenuCommand != 'undefined') {
_GM_registerMenuCommand = GM.registerMenuCommand;
} else {
_GM_registerMenuCommand = (s, f) => {};
}
if (typeof GM_info != 'undefined') {
_GM_info = GM_info;
} else if (typeof GM != 'undefined' && typeof GM.info != 'undefined') {
_GM_info = GM.info;
} else {
_GM_info = {script: {}};
}
if (typeof GM_notification != 'undefined') {
_GM_notification = GM_notification;
} else if (typeof GM != 'undefined' && typeof GM.notification != 'undefined') {
_GM_notification = GM.notification;
} else {
_GM_notification = (s) => {showTips(s)};
}
if (typeof GM_openInTab != 'undefined') {
_GM_openInTab = GM_openInTab;
} else if (typeof GM != 'undefined' && typeof GM.openInTab != 'undefined') {
_GM_openInTab = GM.openInTab;
} else {
_GM_openInTab = (s,t) => {window.open(s)};
}
if (typeof GM_addStyle != 'undefined') {
_GM_addStyle = GM_addStyle;
} else if (typeof GM != 'undefined' && typeof GM.addStyle != 'undefined') {
_GM_addStyle = GM.addStyle;
} else {
_GM_addStyle = cssStr => {
let styleEle = document.createElement("style");
styleEle.innerHTML = cssStr;
document.head.appendChild(styleEle);
return styleEle;
};
}
if (typeof GM_setClipboard != 'undefined') {
_GM_setClipboard = GM_setClipboard;
} else if (typeof GM != 'undefined' && typeof GM.setClipboard != 'undefined') {
_GM_setClipboard = GM.setClipboard;
} else {
_GM_setClipboard = (s, i) => {};
}
const _unsafeWindow = (typeof unsafeWindow == 'undefined') ? window : unsafeWindow;//兼容 ios userscripts 的寫法
const storage = {
supportGM: typeof GM_getValue == 'function' && typeof GM_getValue('a', 'b') != 'undefined',
supportGMPromise: typeof GM != 'undefined' && typeof GM.getValue == 'function' && typeof GM.getValue('a', 'b') != 'undefined' && typeof GM.getValue('a', 'b').then == 'function',
supportCrossSave: function() {
return this.supportGM || this.supportGMPromise;
},
mxAppStorage: (function() {
try {
return window.external.mxGetRuntime().storage;
} catch(e) {
}
})(),
operaUJSStorage: (function() {
try {
return window.opera.scriptStorage;
} catch(e) {
}
})(),
setItem: function(key, value) {
if (this.supportGMPromise) {
GM.setValue(key, value);
if (value === "" && typeof GM != 'undefined' && typeof GM.deleteValue != 'undefined') {
GM.deleteValue(key);
}
} else if (this.supportGM) {
GM_setValue(key, value);
if (value === "" && typeof GM_deleteValue != 'undefined') {
GM_deleteValue(key);
}
} else if (this.operaUJSStorage) {
this.operaUJSStorage.setItem(key, value);
} else if (this.mxAppStorage) {
this.mxAppStorage.setConfig(key, value);
} else if (window.localStorage) {
window.localStorage.setItem(key, value);
}
},
getItem: function(key, cb) {
var value;
if (this.supportGMPromise) {
value = GM.getValue(key).then(v => {cb(v)});
return;
} else if (this.supportGM) {
value = GM_getValue(key);
} else if (this.operaUJSStorage) {
value = this.operaUJSStorage.getItem(key);
} else if (this.mxAppStorage) {
value = this.mxAppStorage.getConfig(key);
} else if (window.localStorage) {
value = window.localStorage.getItem(key);
};
cb(value);
}
};
var rulesData = {uninited: true}, ruleUrls, updateDate;
const configPage = ["https://github.com/hoothin/UserScripts/tree/master/Pagetual",
"https://hoothin.github.io/UserScripts/Pagetual/"];
const guidePage = /^https?:\/\/.*pagetual.*rule\.html/i;
const ruleImportUrlReg = /greasyfork\.org\/.*scripts\/438684(\-[^\/]*)?(\/discussions|\/?$|\/feedback)|github\.com\/hoothin\/UserScripts\/(tree\/master\/Pagetual|issues)/i;
const allOfBody = "body>*";
const mainSel = "article,.article,[role=main],main,.main,#main";
const nextTextReg1 = new RegExp("\u005e\u7ffb\u003f\u005b\u4e0b\u540e\u5f8c\u6b21\u005d\u005b\u4e00\u30fc\u0031\u005d\u003f\u005b\u9875\u9801\u5f20\u5f35\u005d\u007c\u005e\u006e\u0065\u0078\u0074\u005b\u0020\u005f\u002d\u005d\u003f\u0070\u0061\u0067\u0065\u005c\u0073\u002a\u005b\u203a\u003e\u2192\u00bb\u005d\u003f\u0024\u007c\u6b21\u306e\u30da\u30fc\u30b8\u007c\u005e\u6b21\u3078\u003f\u0024\u007cВперед", "i");
const nextTextReg2 = new RegExp("\u005e\u0028\u005b\u4e0b\u540e\u5f8c\u6b21\u005d\u005b\u4e00\u30fc\u0031\u005d\u003f\u005b\u7ae0\u8bdd\u8a71\u8282\u7bc0\u4e2a\u500b\u5e45\u005d\u007c\u006e\u0065\u0078\u0074\u002e\u003f\u0063\u0068\u0061\u0070\u0074\u0065\u0072\u0029\u0028\u005b\u003a\uff1a\u005c\u005c\u002d\u005f\u2014\u0020\u005c\u005c\u002e\u3002\u003e\u0023\u00b7\u005c\u005c\u005b\u3010\u3001\uff08\u005c\u005c\u0028\u002f\u002c\uff0c\uff1b\u003b\u005d\u007c\u0024\u0029", "i");
const lazyImgAttr = ["data-lazy-src", "data-lazy", "data-url", "data-orig-file", "zoomfile", "file", "original", "load-src", "imgsrc", "real_src", "src2", "origin-src", "data-lazyload", "data-lazyload-src", "data-lazy-load-src", "data-ks-lazyload", "data-ks-lazyload-custom", "data-src", "data-defer-src", "data-actualsrc", "data-cover", "data-original", "data-thumb", "data-imageurl", "data-placeholder", "lazysrc"];
_GM_registerMenuCommand(i18n("configure"), () => {
_GM_openInTab(rulesData.configPage || configPage[0], {active: true});
});
_GM_registerMenuCommand(i18n("editCurrent"), () => {
picker.start();
});
function getBody(doc) {
return doc.body || doc.querySelector('body') || doc;
}
function getElementByXpath(xpath, doc, contextNode) {
doc = doc || document;
contextNode = contextNode || doc;
try {
let result = doc.evaluate(xpath, contextNode, null, XPathResult.FIRST_ORDERED_NODE_TYPE, null);
return result.singleNodeValue && result.singleNodeValue.nodeType === 1 && result.singleNodeValue;
} catch (err) {
debug(`Invalid xpath: ${xpath}`);
}
return null;
}
function getAllElementsByXpath(xpath, contextNode, doc) {
doc = doc || document;
contextNode = contextNode || doc;
var result = [];
try {
var query = doc.evaluate(xpath, contextNode, null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null);
for (var i = 0; i < query.snapshotLength; i++) {
var node = query.snapshotItem(i);
if (node.nodeType === 1) result.push(node);
}
} catch (err) {
debug(`Invalid xpath: ${xpath}`);
}
return result;
}
function isXPath(xpath) {
if (!xpath) return false;
return /^\(*(descendant::|\.\/|\/|id\()/.test(xpath);
}
function getAllElements(sel, doc, contextNode) {
try {
if (!isXPath(sel)) {
return doc.querySelectorAll(sel);
}
} catch(e) {
debug(e, 'Error selector');
}
return getAllElementsByXpath(sel, contextNode, doc);
}
function getElement(sel, doc, contextNode, bySort) {
try {
if (!isXPath(sel)) {
if (!bySort) {
return doc.querySelector(sel);
} else {
let selArr = sel.split(",");
try {
for (let i = 0; i < selArr.length; i++) {
let ele = doc.querySelector(selArr[i].trim());
if (ele) return ele;
}
} catch(e) {
return doc.querySelector(sel);
}
return null;
}
}
} catch(e) {
debug(e, 'Error selector');
}
return getElementByXpath(sel, doc, contextNode);
}
function geneSelector(ele, addID) {
let selector = ele.nodeName.toLowerCase();
//Google id class都是隨機。百度更過分,style script順序都是隨機的
if (selector != "html" && selector != "body") {
let hasId = false;
if (addID && ele.id && /^[a-z_][\w\-_]*$/i.test(ele.id)) {
if (ele.ownerDocument && ele.ownerDocument.querySelectorAll("#" + ele.id).length == 1) {
hasId = true;
selector = '#' + ele.id;
}
}
if (!hasId) {
let className = "";
if (ele.className) {
let classList = ele.classList, i = 0;
for (let i = 0; i < classList.length; i++) {
let c = classList[i];
if (/^[\w\-_]+$/.test(c) && !/\d{4,}/.test(c)) {
className += '.' + c;
}
}
selector += className;
}
let parent = ele.parentElement;
if (parent) {
selector = geneSelector(parent, addID) + ' > ' + selector;
if (!className && !hasId && parent.children.length > 1 && !/^HTML$/i.test(parent.nodeName)) {
let i, nth = 0, all = 0;
for (i = 0; i < parent.children.length; i++) {
if (parent.children[i].nodeName == ele.nodeName) {
all++;
if (parent.children[i] == ele) {
nth = all;
}
if (nth > 0 && all > 1) break;
}
}
selector += (all == 1 ? "" : `:nth-of-type(${nth})`);
}
}
}
}
return selector;
}
function createXPathFromElement(elm) {
let allNodes = document.getElementsByTagName('*'), segs;
for (segs = []; elm && elm.nodeType == 1; elm = elm.parentNode) {
if (/^(BODY|HTML)$/i.test(elm.nodeName)) {
segs.unshift(elm.localName.toLowerCase());
continue;
}
if (elm.hasAttribute && elm.hasAttribute('id')) {
var uniqueIdCount = 0;
for (var n = 0; n < allNodes.length; n++) {
if (allNodes[n].hasAttribute('id') && allNodes[n].id == elm.id) uniqueIdCount++;
if (uniqueIdCount > 1) break;
}
if ( uniqueIdCount == 1) {
segs.unshift('id("' + elm.getAttribute('id') + '")');
return segs.join('/');
} else {
segs.unshift(elm.localName.toLowerCase() + '[@id="' + elm.getAttribute('id') + '"]');
}
} else if (elm.hasAttribute && elm.hasAttribute('class')) {
segs.unshift(elm.localName.toLowerCase() + '[@class="' + elm.getAttribute('class') + '"]');
} else {
let i, sib;
for (i = 1, sib = elm.previousSibling; sib; sib = sib.previousSibling) {
if (sib.localName == elm.localName) i++;
}
segs.unshift(elm.localName.toLowerCase() + '[' + i + ']');
}
}
return segs.length ? '/' + segs.join('/') : null;
}
const escapeHTMLPolicy = (_unsafeWindow.trustedTypes && _unsafeWindow.trustedTypes.createPolicy) ? _unsafeWindow.trustedTypes.createPolicy('pagetual_default', {
createHTML: (string, sink) => string
}) : null;
function createHTML(html) {
return escapeHTMLPolicy ? escapeHTMLPolicy.createHTML(html) : html;
}
const AsyncFunction = Object.getPrototypeOf(async function(){}).constructor;
async function sleep(time) {
await new Promise((resolve) => {
setTimeout(() => {
resolve();
}, time);
})
}
class RuleParser {
constructor() {
this.hpRules = [];
this.smartRules = [];
this.customRules = [];
this.rules = [];
this.pageDoc = document;
this.nextLinkHref = null;
this.nextTitle = "";
this.oldUrl = "";
this.curUrl = location.href;
this.curSiteRule = {};
}
initSavedRules(callback) {
var self = this;
storage.getItem("smartRules", smartRules => {
if (smartRules) self.smartRules = smartRules;
storage.getItem("hpRules", hpRules => {
if (hpRules) self.hpRules = hpRules;
storage.getItem("customRules", customRules => {
if (customRules) self.customRules = customRules;
storage.getItem("rules", rules => {
if (rules) self.rules = rules;
callback();
});
});
});