annotate melonbooks-unlazy.user.js @ 104:93e21738b588

Run fix on whole body on start There's no guarantee the script loads before document.
author nanaya <me@nanaya.net>
date Sun, 25 Dec 2022 11:52:30 +0900
parents 3fded109e23a
children 2c4470b73ad9
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
95
afad36fddb64 Add melonbooks unlazy
nanaya <me@nanaya.net>
parents:
diff changeset
1 // ==UserScript==
afad36fddb64 Add melonbooks unlazy
nanaya <me@nanaya.net>
parents:
diff changeset
2 // @name melonbooks unlazy
afad36fddb64 Add melonbooks unlazy
nanaya <me@nanaya.net>
parents:
diff changeset
3 // @namespace https://nanaya.net
afad36fddb64 Add melonbooks unlazy
nanaya <me@nanaya.net>
parents:
diff changeset
4 // @match https://www.melonbooks.co.jp/*
afad36fddb64 Add melonbooks unlazy
nanaya <me@nanaya.net>
parents:
diff changeset
5 // @grant none
97
c8f9350c5307 More thorough lazyload monitor
nanaya <me@nanaya.net>
parents: 96
diff changeset
6 // @run-at document-start
104
93e21738b588 Run fix on whole body on start
nanaya <me@nanaya.net>
parents: 102
diff changeset
7 // @version 1.0.5
95
afad36fddb64 Add melonbooks unlazy
nanaya <me@nanaya.net>
parents:
diff changeset
8 // @author nanaya
afad36fddb64 Add melonbooks unlazy
nanaya <me@nanaya.net>
parents:
diff changeset
9 // @description replace lazy loaded images with just images
afad36fddb64 Add melonbooks unlazy
nanaya <me@nanaya.net>
parents:
diff changeset
10 // @downloadURL https://hg.nanaya.net/ec-userscripts/raw-file/tip/melonbooks-unlazy.user.js
afad36fddb64 Add melonbooks unlazy
nanaya <me@nanaya.net>
parents:
diff changeset
11 // ==/UserScript==
afad36fddb64 Add melonbooks unlazy
nanaya <me@nanaya.net>
parents:
diff changeset
12
afad36fddb64 Add melonbooks unlazy
nanaya <me@nanaya.net>
parents:
diff changeset
13 'use strict'
afad36fddb64 Add melonbooks unlazy
nanaya <me@nanaya.net>
parents:
diff changeset
14
97
c8f9350c5307 More thorough lazyload monitor
nanaya <me@nanaya.net>
parents: 96
diff changeset
15 function fix (image) {
102
3fded109e23a Also run on own node
nanaya <me@nanaya.net>
parents: 99
diff changeset
16 if (!image.classList.contains('lazyload')) return
3fded109e23a Also run on own node
nanaya <me@nanaya.net>
parents: 99
diff changeset
17
98
3e5f1fa9ed52 Skip redundant class check and add dataset check instead
nanaya <me@nanaya.net>
parents: 97
diff changeset
18 const src = image.dataset.src
3e5f1fa9ed52 Skip redundant class check and add dataset check instead
nanaya <me@nanaya.net>
parents: 97
diff changeset
19
99
b44d5cb661c5 Also check for empty string
nanaya <me@nanaya.net>
parents: 98
diff changeset
20 if (src == null || src === '') return
97
c8f9350c5307 More thorough lazyload monitor
nanaya <me@nanaya.net>
parents: 96
diff changeset
21
c8f9350c5307 More thorough lazyload monitor
nanaya <me@nanaya.net>
parents: 96
diff changeset
22 image.classList.remove('lazyload')
c8f9350c5307 More thorough lazyload monitor
nanaya <me@nanaya.net>
parents: 96
diff changeset
23 image.src = image.dataset.src
c8f9350c5307 More thorough lazyload monitor
nanaya <me@nanaya.net>
parents: 96
diff changeset
24 delete image.dataset.src
c8f9350c5307 More thorough lazyload monitor
nanaya <me@nanaya.net>
parents: 96
diff changeset
25 }
95
afad36fddb64 Add melonbooks unlazy
nanaya <me@nanaya.net>
parents:
diff changeset
26
104
93e21738b588 Run fix on whole body on start
nanaya <me@nanaya.net>
parents: 102
diff changeset
27 function run (node) {
93e21738b588 Run fix on whole body on start
nanaya <me@nanaya.net>
parents: 102
diff changeset
28 if (!(node instanceof window.HTMLElement)) return
93e21738b588 Run fix on whole body on start
nanaya <me@nanaya.net>
parents: 102
diff changeset
29
93e21738b588 Run fix on whole body on start
nanaya <me@nanaya.net>
parents: 102
diff changeset
30 fix(node)
93e21738b588 Run fix on whole body on start
nanaya <me@nanaya.net>
parents: 102
diff changeset
31 for (const image of node.querySelectorAll('.lazyload')) {
93e21738b588 Run fix on whole body on start
nanaya <me@nanaya.net>
parents: 102
diff changeset
32 fix(image)
93e21738b588 Run fix on whole body on start
nanaya <me@nanaya.net>
parents: 102
diff changeset
33 }
93e21738b588 Run fix on whole body on start
nanaya <me@nanaya.net>
parents: 102
diff changeset
34 }
93e21738b588 Run fix on whole body on start
nanaya <me@nanaya.net>
parents: 102
diff changeset
35
97
c8f9350c5307 More thorough lazyload monitor
nanaya <me@nanaya.net>
parents: 96
diff changeset
36 function onMutate (mutations) {
c8f9350c5307 More thorough lazyload monitor
nanaya <me@nanaya.net>
parents: 96
diff changeset
37 for (const mutation of mutations) {
c8f9350c5307 More thorough lazyload monitor
nanaya <me@nanaya.net>
parents: 96
diff changeset
38 for (const node of mutation.addedNodes) {
104
93e21738b588 Run fix on whole body on start
nanaya <me@nanaya.net>
parents: 102
diff changeset
39 run(node)
97
c8f9350c5307 More thorough lazyload monitor
nanaya <me@nanaya.net>
parents: 96
diff changeset
40 }
95
afad36fddb64 Add melonbooks unlazy
nanaya <me@nanaya.net>
parents:
diff changeset
41 }
afad36fddb64 Add melonbooks unlazy
nanaya <me@nanaya.net>
parents:
diff changeset
42 }
97
c8f9350c5307 More thorough lazyload monitor
nanaya <me@nanaya.net>
parents: 96
diff changeset
43
c8f9350c5307 More thorough lazyload monitor
nanaya <me@nanaya.net>
parents: 96
diff changeset
44 const observer = new window.MutationObserver(onMutate)
c8f9350c5307 More thorough lazyload monitor
nanaya <me@nanaya.net>
parents: 96
diff changeset
45 observer.observe(document, { childList: true, subtree: true })
104
93e21738b588 Run fix on whole body on start
nanaya <me@nanaya.net>
parents: 102
diff changeset
46 run(document.body)