hexo-theme-lnote 1.2.7 → 1.2.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (141) hide show
  1. package/README.md +36 -36
  2. package/_config.yml +19 -19
  3. package/config/links.yml +63 -63
  4. package/config/svg.yml +33 -33
  5. package/index.d.ts +3 -3
  6. package/languages/de.yml +69 -69
  7. package/languages/en.yml +73 -73
  8. package/languages/eo.yml +69 -69
  9. package/languages/es.yml +69 -69
  10. package/languages/ja.yml +69 -69
  11. package/languages/ru.yml +69 -69
  12. package/languages/zh-CN.yml +73 -73
  13. package/languages/zh-HK.yml +73 -73
  14. package/languages/zh-TW.yml +73 -73
  15. package/layout/404.ejs +8 -8
  16. package/layout/_partials/archive-list.ejs +17 -17
  17. package/layout/_partials/category-chains.ejs +19 -19
  18. package/layout/_partials/category-list.ejs +62 -62
  19. package/layout/_partials/comments/changyan.ejs +11 -11
  20. package/layout/_partials/comments/cusdis.ejs +25 -25
  21. package/layout/_partials/comments/discuss.ejs +17 -17
  22. package/layout/_partials/comments/disqus.ejs +32 -32
  23. package/layout/_partials/comments/giscus.ejs +36 -36
  24. package/layout/_partials/comments/gitalk.ejs +19 -19
  25. package/layout/_partials/comments/livere.ejs +10 -10
  26. package/layout/_partials/comments/remark42.ejs +29 -29
  27. package/layout/_partials/comments/twikoo.ejs +25 -25
  28. package/layout/_partials/comments/utterances.ejs +27 -27
  29. package/layout/_partials/comments/valine.ejs +23 -23
  30. package/layout/_partials/comments/waline.ejs +24 -24
  31. package/layout/_partials/comments.ejs +8 -8
  32. package/layout/_partials/css.ejs +9 -9
  33. package/layout/_partials/footer/beian.ejs +33 -33
  34. package/layout/_partials/footer/statistics.ejs +39 -39
  35. package/layout/_partials/footer.ejs +7 -7
  36. package/layout/_partials/head.ejs +46 -46
  37. package/layout/_partials/header/banner.ejs +24 -24
  38. package/layout/_partials/header/navigation.ejs +56 -56
  39. package/layout/_partials/header.ejs +4 -4
  40. package/layout/_partials/markdown-plugins.ejs +24 -24
  41. package/layout/_partials/paginator.ejs +14 -14
  42. package/layout/_partials/plugins/CSR.ejs +4 -4
  43. package/layout/_partials/plugins/analytics.ejs +75 -75
  44. package/layout/_partials/plugins/anchorjs.ejs +39 -39
  45. package/layout/_partials/plugins/code-widget.ejs +7 -7
  46. package/layout/_partials/plugins/encrypt.ejs +18 -18
  47. package/layout/_partials/plugins/fancybox.ejs +11 -11
  48. package/layout/_partials/plugins/highlight.ejs +13 -13
  49. package/layout/_partials/plugins/math.ejs +51 -51
  50. package/layout/_partials/plugins/mermaid.ejs +4 -4
  51. package/layout/_partials/plugins/nprogress.ejs +7 -7
  52. package/layout/_partials/plugins/typed.ejs +20 -20
  53. package/layout/_partials/post/category-bar.ejs +18 -18
  54. package/layout/_partials/post/copyright.ejs +50 -50
  55. package/layout/_partials/post/css.ejs +3 -3
  56. package/layout/_partials/post/meta-bottom.ejs +16 -16
  57. package/layout/_partials/post/meta-top.ejs +27 -27
  58. package/layout/_partials/post/scripts.ejs +8 -8
  59. package/layout/_partials/post/sidebar-left.ejs +1 -1
  60. package/layout/_partials/post/sidebar-right.ejs +2 -2
  61. package/layout/_partials/post/toc.ejs +6 -6
  62. package/layout/_partials/scripts.ejs +10 -10
  63. package/layout/_partials/search.ejs +19 -19
  64. package/layout/about.ejs +22 -22
  65. package/layout/archive.ejs +10 -10
  66. package/layout/categories.ejs +20 -20
  67. package/layout/category.ejs +12 -12
  68. package/layout/index.ejs +61 -61
  69. package/layout/layout.ejs +60 -60
  70. package/layout/links.ejs +31 -31
  71. package/layout/page.ejs +15 -15
  72. package/layout/post.ejs +77 -77
  73. package/layout/tag.ejs +12 -12
  74. package/layout/tags.ejs +26 -26
  75. package/package.json +73 -73
  76. package/scripts/index.js +2 -1
  77. package/source/css/_functions/base.styl +8 -8
  78. package/source/css/_mixins/base.styl +23 -23
  79. package/source/css/_pages/_about/about.styl +32 -32
  80. package/source/css/_pages/_archive/archive.styl +32 -32
  81. package/source/css/_pages/_base/_widget/anchorjs.styl +8 -8
  82. package/source/css/_pages/_base/_widget/banner.styl +29 -29
  83. package/source/css/_pages/_base/_widget/board.styl +11 -11
  84. package/source/css/_pages/_base/_widget/code-widget.styl +36 -36
  85. package/source/css/_pages/_base/_widget/copyright.styl +90 -90
  86. package/source/css/_pages/_base/_widget/footer.styl +65 -65
  87. package/source/css/_pages/_base/_widget/footnote.styl +25 -25
  88. package/source/css/_pages/_base/_widget/header.styl +173 -173
  89. package/source/css/_pages/_base/_widget/modal.styl +100 -100
  90. package/source/css/_pages/_base/_widget/navlink.styl +15 -15
  91. package/source/css/_pages/_base/_widget/ngrogress.styl +12 -12
  92. package/source/css/_pages/_base/_widget/noscript.styl +12 -12
  93. package/source/css/_pages/_base/_widget/pagination.styl +23 -23
  94. package/source/css/_pages/_base/_widget/qrcode.styl +17 -17
  95. package/source/css/_pages/_base/_widget/scroll-btn.styl +48 -48
  96. package/source/css/_pages/_base/_widget/text.styl +19 -19
  97. package/source/css/_pages/_base/_widget/toc.styl +75 -75
  98. package/source/css/_pages/_base/base.styl +67 -67
  99. package/source/css/_pages/_base/color-schema.styl +79 -79
  100. package/source/css/_pages/_base/inline.styl +51 -51
  101. package/source/css/_pages/_base/keyframes.styl +31 -31
  102. package/source/css/_pages/_base/print.styl +38 -38
  103. package/source/css/_pages/_category/category-bar.styl +58 -58
  104. package/source/css/_pages/_category/category-chain.styl +6 -6
  105. package/source/css/_pages/_category/category-list.styl +62 -62
  106. package/source/css/_pages/_index/index.styl +75 -75
  107. package/source/css/_pages/_links/links.styl +79 -79
  108. package/source/css/_pages/_post/comment.styl +27 -27
  109. package/source/css/_pages/_post/highlight.styl +76 -76
  110. package/source/css/_pages/_post/markdown.styl +96 -96
  111. package/source/css/_pages/_post/post-page.styl +179 -179
  112. package/source/css/_pages/_post/post-plugin.styl +9 -9
  113. package/source/css/_pages/_post/post-tag.styl +74 -74
  114. package/source/css/_pages/_tag/tags.styl +9 -9
  115. package/source/css/_pages/pages.styl +8 -8
  116. package/source/css/_variables/base.styl +72 -72
  117. package/source/css/gitalk.css +546 -546
  118. package/source/css/main.styl +19 -19
  119. package/source/js/color-schema.js +279 -279
  120. package/source/js/events.js +72 -72
  121. package/source/js/img-lazyload.js +10 -10
  122. package/source/js/local-search.js +70 -70
  123. package/source/js/post/copying-code.js +34 -34
  124. package/source/js/post/enable.js +6 -6
  125. package/source/js/post/img-swipe-bf.js +47 -47
  126. package/source/js/post/img-swipe.js +83 -83
  127. package/source/js/post/mermaiding.js +9 -9
  128. package/source/js/post/play-imgs.js +58 -58
  129. package/source/js/post/toc.js +24 -24
  130. package/source/js/post/view-imgs.js +27 -27
  131. package/source/js/utils.js +245 -245
  132. package/source/xml/local-search.xml +45 -45
  133. package/templates/Chat.vue +52 -52
  134. package/templates/GroupImage.vue +36 -36
  135. package/templates/MenuNav.vue +39 -39
  136. package/templates/Note.vue +33 -33
  137. package/templates/Noun.vue +25 -25
  138. package/templates/NounContent.vue +29 -29
  139. package/templates/Tab.vue +40 -40
  140. package/templates/footer.ejs +12 -12
  141. package/templates/utils/uri.ts +39 -39
@@ -1,72 +1,72 @@
1
- LNote.events = {
2
- registerNavbarEvent() {
3
- const $navbar = document.getElementById('navbar')
4
- if (!$navbar) {
5
- return
6
- }
7
-
8
- function $navUd() {
9
- const top = window.scrollY || document.documentElement.scrollTop
10
- if (top > 0) {
11
- $navbar.classList.remove('navbar-dark')
12
- if (top > 50) {
13
- $navbar.classList.add('top-nav-collapse')
14
- } else {
15
- $navbar.classList.remove('top-nav-collapse')
16
- }
17
- } else {
18
- $navbar.classList.add('navbar-dark')
19
- }
20
- }
21
- $navUd()
22
- LNote.utils.listenScroll($navUd)
23
-
24
- document
25
- .getElementById('navbar-toggler-btn')
26
- .addEventListener('click', (e) => {
27
- document
28
- .querySelector('.animated-icon')
29
- .classList.toggle('open')
30
- $navbar.classList.toggle('navbar-col-show')
31
- })
32
- },
33
-
34
- /* registerImageLoadedEvent: function () {
35
- if (!('NProgress' in window)) {
36
- return
37
- }
38
-
39
- var bg = document.getElementById('banner')
40
- if (bg) {
41
- var src = bg.style.backgroundImage
42
- var url = src.match(/\((.*?)\)/)[1].replace(/(['"])/g, '')
43
- var img = new Image()
44
- img.onload = function () {
45
- window.NProgress && window.NProgress.inc(0.2)
46
- }
47
- img.src = url
48
- if (img.complete) {
49
- img.onload()
50
- }
51
- }
52
-
53
- var notLazyImages = jQuery('main img:not([lazyload])')
54
- var total = notLazyImages.length
55
- for (const img of notLazyImages) {
56
- const old = img.onload
57
- img.onload = function () {
58
- old && old()
59
- window.NProgress && window.NProgress.inc(0.5 / total)
60
- img.onload = null
61
- }
62
- if (img.complete) {
63
- img.onload()
64
- }
65
- }
66
- }, */
67
- }
68
-
69
- document.addEventListener('DOMContentLoaded', function () {
70
- LNote.events.registerNavbarEvent()
71
- // LNote.events.registerImageLoadedEvent()
72
- })
1
+ LNote.events = {
2
+ registerNavbarEvent() {
3
+ const $navbar = document.getElementById('navbar')
4
+ if (!$navbar) {
5
+ return
6
+ }
7
+
8
+ function $navUd() {
9
+ const top = window.scrollY || document.documentElement.scrollTop
10
+ if (top > 0) {
11
+ $navbar.classList.remove('navbar-dark')
12
+ if (top > 50) {
13
+ $navbar.classList.add('top-nav-collapse')
14
+ } else {
15
+ $navbar.classList.remove('top-nav-collapse')
16
+ }
17
+ } else {
18
+ $navbar.classList.add('navbar-dark')
19
+ }
20
+ }
21
+ $navUd()
22
+ LNote.utils.listenScroll($navUd)
23
+
24
+ document
25
+ .getElementById('navbar-toggler-btn')
26
+ .addEventListener('click', (e) => {
27
+ document
28
+ .querySelector('.animated-icon')
29
+ .classList.toggle('open')
30
+ $navbar.classList.toggle('navbar-col-show')
31
+ })
32
+ },
33
+
34
+ /* registerImageLoadedEvent: function () {
35
+ if (!('NProgress' in window)) {
36
+ return
37
+ }
38
+
39
+ var bg = document.getElementById('banner')
40
+ if (bg) {
41
+ var src = bg.style.backgroundImage
42
+ var url = src.match(/\((.*?)\)/)[1].replace(/(['"])/g, '')
43
+ var img = new Image()
44
+ img.onload = function () {
45
+ window.NProgress && window.NProgress.inc(0.2)
46
+ }
47
+ img.src = url
48
+ if (img.complete) {
49
+ img.onload()
50
+ }
51
+ }
52
+
53
+ var notLazyImages = jQuery('main img:not([lazyload])')
54
+ var total = notLazyImages.length
55
+ for (const img of notLazyImages) {
56
+ const old = img.onload
57
+ img.onload = function () {
58
+ old && old()
59
+ window.NProgress && window.NProgress.inc(0.5 / total)
60
+ img.onload = null
61
+ }
62
+ if (img.complete) {
63
+ img.onload()
64
+ }
65
+ }
66
+ }, */
67
+ }
68
+
69
+ document.addEventListener('DOMContentLoaded', function () {
70
+ LNote.events.registerNavbarEvent()
71
+ // LNote.events.registerImageLoadedEvent()
72
+ })
@@ -1,10 +1,10 @@
1
- /* global LNote, CONFIG */
2
-
3
- (function(window, document) {
4
- for (const each of document.querySelectorAll('img[lazyload]')) {
5
- LNote.utils.waitElementVisible(each, function() {
6
- each.removeAttribute('srcset');
7
- each.removeAttribute('lazyload');
8
- }, 2);
9
- }
10
- })(window, document);
1
+ /* global LNote, CONFIG */
2
+
3
+ (function(window, document) {
4
+ for (const each of document.querySelectorAll('img[lazyload]')) {
5
+ LNote.utils.waitElementVisible(each, function() {
6
+ each.removeAttribute('srcset');
7
+ each.removeAttribute('lazyload');
8
+ }, 2);
9
+ }
10
+ })(window, document);
@@ -1,70 +1,70 @@
1
- ;(() => {
2
- const $modal = document.getElementById('modalSearch')
3
- const $input = document.getElementById('modalSearchInput')
4
- const $result = document.getElementById('modalSearchResult')
5
- let inputThol
6
-
7
- let dataSource
8
- function fetchData() {
9
- if (dataSource != null) {
10
- return
11
- }
12
- $result.innerHTML =
13
- '<div class="m-auto text-center"><div class="spinner-grow text-primary" role="status"><span class="visually-hidden">Loading...</span></div></div>'
14
- fetch(LNote.root + 'content.json')
15
- .then((rep) => rep.json())
16
- .then((res) => (dataSource = res))
17
- .finally(() => ($result.innerHTML = ''))
18
- }
19
-
20
- $modal.addEventListener('show.bs.modal', () => {
21
- fetchData()
22
- $input.focus()
23
- })
24
-
25
- $modal.addEventListener('hidden.bs.modal', () => {
26
- console.log('hide')
27
- })
28
-
29
- $input.addEventListener('input', (e) => {
30
- if (dataSource == null) {
31
- return
32
- }
33
- clearTimeout(inputThol)
34
- inputThol = setTimeout(() => {
35
- const kw = e.target.value.trim()
36
- if (kw === '') {
37
- return
38
- }
39
- const matchedList = dataSource.filter((item) => {
40
- return item.excerpt.includes(kw) || item.title.includes(kw)
41
- })
42
- if (matchedList.length > 0) {
43
- e.target.classList.remove('invalid')
44
- e.target.classList.add('valid')
45
- const { root } = LNote
46
- $result.innerHTML = matchedList
47
- .map((item) => {
48
- let { excerpt, title } = item
49
- if (excerpt.includes(kw)) {
50
- excerpt = excerpt.replace(
51
- kw,
52
- `<span class="text-success-emphasis">${kw}</span>`
53
- )
54
- } else if (title.includes(kw)) {
55
- title = title.replace(
56
- kw,
57
- `<span class="text-success-emphasis">${kw}</span>`
58
- )
59
- }
60
-
61
- return `<div><a href="${root}${item.path}" class="fs-5 link-warning">${title}</a><p>${excerpt}</p></div>`
62
- })
63
- .join('')
64
- } else {
65
- e.target.classList.remove('valid')
66
- e.target.classList.add('invalid')
67
- }
68
- }, 500)
69
- })
70
- })()
1
+ ;(() => {
2
+ const $modal = document.getElementById('modalSearch')
3
+ const $input = document.getElementById('modalSearchInput')
4
+ const $result = document.getElementById('modalSearchResult')
5
+ let inputThol
6
+
7
+ let dataSource
8
+ function fetchData() {
9
+ if (dataSource != null) {
10
+ return
11
+ }
12
+ $result.innerHTML =
13
+ '<div class="m-auto text-center"><div class="spinner-grow text-primary" role="status"><span class="visually-hidden">Loading...</span></div></div>'
14
+ fetch(LNote.root + 'content.json')
15
+ .then((rep) => rep.json())
16
+ .then((res) => (dataSource = res))
17
+ .finally(() => ($result.innerHTML = ''))
18
+ }
19
+
20
+ $modal.addEventListener('show.bs.modal', () => {
21
+ fetchData()
22
+ $input.focus()
23
+ })
24
+
25
+ $modal.addEventListener('hidden.bs.modal', () => {
26
+ console.log('hide')
27
+ })
28
+
29
+ $input.addEventListener('input', (e) => {
30
+ if (dataSource == null) {
31
+ return
32
+ }
33
+ clearTimeout(inputThol)
34
+ inputThol = setTimeout(() => {
35
+ const kw = e.target.value.trim()
36
+ if (kw === '') {
37
+ return
38
+ }
39
+ const matchedList = dataSource.filter((item) => {
40
+ return item.excerpt.includes(kw) || item.title.includes(kw)
41
+ })
42
+ if (matchedList.length > 0) {
43
+ e.target.classList.remove('invalid')
44
+ e.target.classList.add('valid')
45
+ const { root } = LNote
46
+ $result.innerHTML = matchedList
47
+ .map((item) => {
48
+ let { excerpt, title } = item
49
+ if (excerpt.includes(kw)) {
50
+ excerpt = excerpt.replace(
51
+ kw,
52
+ `<span class="text-success-emphasis">${kw}</span>`
53
+ )
54
+ } else if (title.includes(kw)) {
55
+ title = title.replace(
56
+ kw,
57
+ `<span class="text-success-emphasis">${kw}</span>`
58
+ )
59
+ }
60
+
61
+ return `<div><a href="${root}${item.path}" class="fs-5 link-warning">${title}</a><p>${excerpt}</p></div>`
62
+ })
63
+ .join('')
64
+ } else {
65
+ e.target.classList.remove('valid')
66
+ e.target.classList.add('invalid')
67
+ }
68
+ }, 500)
69
+ })
70
+ })()
@@ -1,34 +1,34 @@
1
- ;(() => {
2
- if (!'ClipboardJS' in window) {
3
- return
4
- }
5
-
6
- function genSVG(id) {
7
- return `<svg width="1em" height="1em"><use xlink:href="#${id}"/></svg>`
8
- }
9
-
10
- const codes = document.querySelectorAll('.markdown-body .highlight')
11
- codes.forEach((item) => {
12
- const btn = document.createElement('button')
13
- btn.type = 'button'
14
- btn.classList.add('btn-clipboard')
15
- btn.title = 'Copy to clipboard'
16
- btn.innerHTML = genSVG('clipboard')
17
- item.insertAdjacentElement('afterbegin', btn)
18
- })
19
-
20
- const clipboard = new ClipboardJS('.btn-clipboard', {
21
- target: function (trigger) {
22
- return trigger.parentNode.getElementsByTagName('code')[0]
23
- },
24
- })
25
- clipboard.on('success', function (e) {
26
- e.clearSelection()
27
- e.trigger.innerHTML = genSVG('check')
28
- e.trigger.title = 'Copied!'
29
- setTimeout(function () {
30
- e.trigger.innerHTML = genSVG('clipboard')
31
- e.trigger.title = 'Copy to clipboard'
32
- }, 2000)
33
- })
34
- })()
1
+ ;(() => {
2
+ if (!'ClipboardJS' in window) {
3
+ return
4
+ }
5
+
6
+ function genSVG(id) {
7
+ return `<svg width="1em" height="1em"><use xlink:href="#${id}"/></svg>`
8
+ }
9
+
10
+ const codes = document.querySelectorAll('.markdown-body .highlight')
11
+ codes.forEach((item) => {
12
+ const btn = document.createElement('button')
13
+ btn.type = 'button'
14
+ btn.classList.add('btn-clipboard')
15
+ btn.title = 'Copy to clipboard'
16
+ btn.innerHTML = genSVG('clipboard')
17
+ item.insertAdjacentElement('afterbegin', btn)
18
+ })
19
+
20
+ const clipboard = new ClipboardJS('.btn-clipboard', {
21
+ target: function (trigger) {
22
+ return trigger.parentNode.getElementsByTagName('code')[0]
23
+ },
24
+ })
25
+ clipboard.on('success', function (e) {
26
+ e.clearSelection()
27
+ e.trigger.innerHTML = genSVG('check')
28
+ e.trigger.title = 'Copied!'
29
+ setTimeout(function () {
30
+ e.trigger.innerHTML = genSVG('clipboard')
31
+ e.trigger.title = 'Copy to clipboard'
32
+ }, 2000)
33
+ })
34
+ })()
@@ -1,6 +1,6 @@
1
- const popoverTriggerList = document.querySelectorAll(
2
- '[data-bs-toggle="popover"]'
3
- )
4
- const popoverList = [...popoverTriggerList].map(
5
- (popoverTriggerEl) => new bootstrap.Popover(popoverTriggerEl)
6
- )
1
+ const popoverTriggerList = document.querySelectorAll(
2
+ '[data-bs-toggle="popover"]'
3
+ )
4
+ const popoverList = [...popoverTriggerList].map(
5
+ (popoverTriggerEl) => new bootstrap.Popover(popoverTriggerEl)
6
+ )
@@ -1,47 +1,47 @@
1
- ;(() => {
2
- const imgs = document.querySelectorAll('.markdown-body img')
3
- const promiseds = Array.prototype.map.call(imgs, (item) => {
4
- return new Promise((resolve, reject) => {
5
- const src = item.getAttribute('src')
6
- const __img = new Image()
7
- __img.onload = function () {
8
- const a = document.createElement('a')
9
- a.href = src
10
- a.target = '_blank'
11
- a.setAttribute('data-pswp-src', src)
12
- a.setAttribute('data-pswp-width', __img.width)
13
- a.setAttribute('data-pswp-height', __img.height)
14
- const parentNode = item.parentNode
15
- parentNode.removeChild(item)
16
- a.appendChild(item)
17
- parentNode.appendChild(a)
18
- resolve()
19
- }
20
- __img.onerror = function () {
21
- reject()
22
- }
23
- __img.src = src
24
- })
25
- })
26
-
27
- Promise.allSettled(promiseds).then(() => {
28
- const lightbox = new PhotoSwipeLightbox({
29
- gallery: '#board',
30
- children: 'a[data-pswp-src]',
31
- pswpModule: () => PhotoSwipe,
32
- wheelToZoom: true,
33
- })
34
- lightbox.init()
35
- /* lightbox.on('initialLayout', () => {
36
- $('.pswp').on('contextmenu.fb', function (e) {
37
- if (e.button == 2) {
38
- e.preventDefault()
39
- }
40
- return true
41
- })
42
- }) */
43
- /* lightbox.on('destroy', () => {
44
- console.log('destroy');
45
- }); */
46
- })
47
- })()
1
+ ;(() => {
2
+ const imgs = document.querySelectorAll('.markdown-body img')
3
+ const promiseds = Array.prototype.map.call(imgs, (item) => {
4
+ return new Promise((resolve, reject) => {
5
+ const src = item.getAttribute('src')
6
+ const __img = new Image()
7
+ __img.onload = function () {
8
+ const a = document.createElement('a')
9
+ a.href = src
10
+ a.target = '_blank'
11
+ a.setAttribute('data-pswp-src', src)
12
+ a.setAttribute('data-pswp-width', __img.width)
13
+ a.setAttribute('data-pswp-height', __img.height)
14
+ const parentNode = item.parentNode
15
+ parentNode.removeChild(item)
16
+ a.appendChild(item)
17
+ parentNode.appendChild(a)
18
+ resolve()
19
+ }
20
+ __img.onerror = function () {
21
+ reject()
22
+ }
23
+ __img.src = src
24
+ })
25
+ })
26
+
27
+ Promise.allSettled(promiseds).then(() => {
28
+ const lightbox = new PhotoSwipeLightbox({
29
+ gallery: '#board',
30
+ children: 'a[data-pswp-src]',
31
+ pswpModule: () => PhotoSwipe,
32
+ wheelToZoom: true,
33
+ })
34
+ lightbox.init()
35
+ /* lightbox.on('initialLayout', () => {
36
+ $('.pswp').on('contextmenu.fb', function (e) {
37
+ if (e.button == 2) {
38
+ e.preventDefault()
39
+ }
40
+ return true
41
+ })
42
+ }) */
43
+ /* lightbox.on('destroy', () => {
44
+ console.log('destroy');
45
+ }); */
46
+ })
47
+ })()
@@ -1,84 +1,84 @@
1
- import PhotoSwipeLightbox from '//cdn.staticfile.net/photoswipe/5.4.2/photoswipe-lightbox.esm.min.js'
2
-
3
- const lightbox = new PhotoSwipeLightbox({
4
- pswpModule: () => import('//cdn.staticfile.net/photoswipe/5.4.2/photoswipe.esm.min.js'),
5
- wheelToZoom: true,
6
- })
7
- const groups = []
8
-
9
- const imgClick = (event) => {
10
- const dataSwipeI = Number.parseInt(event.target.getAttribute('data-swipe-i'))
11
- const dataSwipeGi = event.target.getAttribute('data-swipe-gi')
12
- lightbox.loadAndOpen(dataSwipeI, groups[dataSwipeGi])
13
- }
14
-
15
- function imgToData($img, groupIndex, index) {
16
- return new Promise((resolve, reject) => {
17
- $img.setAttribute('data-swipe-gi', groupIndex)
18
- $img.setAttribute('data-swipe-i', index)
19
- const src = $img.getAttribute('src')
20
- const alt = $img.getAttribute('alt')
21
- const data = { src, alt }
22
- const loadDone = () => {
23
- groups[groupIndex][index] = {
24
- ...data,
25
- width: $img.naturalWidth,
26
- height: $img.naturalHeight,
27
- }
28
- resolve()
29
- $img.onclick = imgClick
30
- }
31
- if ($img.complete) {
32
- loadDone()
33
- } else {
34
- $img.onload = loadDone
35
- }
36
-
37
- $img.onerror = () => {
38
- reject()
39
- }
40
- })
41
- }
42
-
43
- const promiseds = []
44
-
45
- document.querySelectorAll('.img-swipe-single').forEach($img => {
46
- const groupIndex = groups.length
47
- groups.push([{}])
48
- promiseds.push(imgToData($img, groupIndex, 0))
49
- })
50
-
51
- document.querySelectorAll('.img-swipe-group').forEach($group => {
52
- const groupIndex = groups.length
53
- groups.push([])
54
- $group.querySelectorAll('img').forEach(($img, index) => {
55
- groups[groupIndex].push({})
56
- promiseds.push(imgToData($img, groupIndex, index))
57
- })
58
- })
59
-
60
- if (promiseds.length === 0) {
61
- throw new Error('empty img')
62
- }
63
-
64
- Promise.allSettled(promiseds).then(() => {
65
- lightbox.on('uiRegister', () => {
66
- lightbox.pswp.ui.registerElement({
67
- name: 'custom-caption',
68
- className: 'lnote-lightbox-caption',
69
- order: 9,
70
- isButton: false,
71
- appendTo: 'root',
72
- html: null,
73
- onInit(el, pswp) {
74
- pswp.on('change', () => {
75
- if (pswp.currSlide.data.alt == null) {
76
- return
77
- }
78
- el.innerHTML = `<div>${pswp.currSlide.data.alt}</div>`
79
- })
80
- },
81
- })
82
- })
83
- lightbox.init()
1
+ import PhotoSwipeLightbox from '//cdn.staticfile.net/photoswipe/5.4.2/photoswipe-lightbox.esm.min.js'
2
+
3
+ const lightbox = new PhotoSwipeLightbox({
4
+ pswpModule: () => import('//cdn.staticfile.net/photoswipe/5.4.2/photoswipe.esm.min.js'),
5
+ wheelToZoom: true,
6
+ })
7
+ const groups = []
8
+
9
+ const imgClick = (event) => {
10
+ const dataSwipeI = Number.parseInt(event.target.getAttribute('data-swipe-i'))
11
+ const dataSwipeGi = event.target.getAttribute('data-swipe-gi')
12
+ lightbox.loadAndOpen(dataSwipeI, groups[dataSwipeGi])
13
+ }
14
+
15
+ function imgToData($img, groupIndex, index) {
16
+ return new Promise((resolve, reject) => {
17
+ $img.setAttribute('data-swipe-gi', groupIndex)
18
+ $img.setAttribute('data-swipe-i', index)
19
+ const src = $img.getAttribute('src')
20
+ const alt = $img.getAttribute('alt')
21
+ const data = { src, alt }
22
+ const loadDone = () => {
23
+ groups[groupIndex][index] = {
24
+ ...data,
25
+ width: $img.naturalWidth,
26
+ height: $img.naturalHeight,
27
+ }
28
+ resolve()
29
+ $img.onclick = imgClick
30
+ }
31
+ if ($img.complete) {
32
+ loadDone()
33
+ } else {
34
+ $img.onload = loadDone
35
+ }
36
+
37
+ $img.onerror = () => {
38
+ reject()
39
+ }
40
+ })
41
+ }
42
+
43
+ const promiseds = []
44
+
45
+ document.querySelectorAll('.img-swipe-single').forEach($img => {
46
+ const groupIndex = groups.length
47
+ groups.push([{}])
48
+ promiseds.push(imgToData($img, groupIndex, 0))
49
+ })
50
+
51
+ document.querySelectorAll('.img-swipe-group').forEach($group => {
52
+ const groupIndex = groups.length
53
+ groups.push([])
54
+ $group.querySelectorAll('img').forEach(($img, index) => {
55
+ groups[groupIndex].push({})
56
+ promiseds.push(imgToData($img, groupIndex, index))
57
+ })
58
+ })
59
+
60
+ if (promiseds.length === 0) {
61
+ throw new Error('empty img')
62
+ }
63
+
64
+ Promise.allSettled(promiseds).then(() => {
65
+ lightbox.on('uiRegister', () => {
66
+ lightbox.pswp.ui.registerElement({
67
+ name: 'custom-caption',
68
+ className: 'lnote-lightbox-caption',
69
+ order: 9,
70
+ isButton: false,
71
+ appendTo: 'root',
72
+ html: null,
73
+ onInit(el, pswp) {
74
+ pswp.on('change', () => {
75
+ if (pswp.currSlide.data.alt == null) {
76
+ return
77
+ }
78
+ el.innerHTML = `<div>${pswp.currSlide.data.alt}</div>`
79
+ })
80
+ },
81
+ })
82
+ })
83
+ lightbox.init()
84
84
  })