hexo-theme-shokax 0.4.6-dev6 → 0.4.7

Sign up to get free protection for your applications and to get access to all the features.
Files changed (186) hide show
  1. package/CODE_OF_CONDUCT.md +128 -128
  2. package/CONTRIBUTING.md +58 -58
  3. package/LICENSE +660 -660
  4. package/LICENSE-shoka +21 -21
  5. package/README.md +76 -99
  6. package/README_en.MD +75 -91
  7. package/UsageRestrictions.md +25 -25
  8. package/_config.yml +381 -381
  9. package/_images.yml +9 -9
  10. package/eslint.config.mjs +55 -55
  11. package/languages/README.md +19 -19
  12. package/languages/default.yml +1 -1
  13. package/languages/en.yml +153 -153
  14. package/languages/ja.yml +153 -153
  15. package/languages/zh-CN.yml +153 -153
  16. package/languages/zh-HK.yml +153 -153
  17. package/languages/zh-TW.yml +153 -153
  18. package/layout/_alternate/atom.ejs +30 -30
  19. package/layout/_alternate/json.ejs +16 -16
  20. package/layout/_alternate/rss.ejs +34 -34
  21. package/layout/_mixin/breadcrumb.pug +33 -33
  22. package/layout/_mixin/card.pug +38 -38
  23. package/layout/_mixin/comment.pug +6 -6
  24. package/layout/_mixin/postmeta.pug +29 -29
  25. package/layout/_mixin/segment.pug +35 -35
  26. package/layout/_mixin/sidebar.pug +40 -40
  27. package/layout/_mixin/widgets.pug +28 -28
  28. package/layout/_partials/footer.pug +43 -43
  29. package/layout/_partials/head/head.pug +55 -55
  30. package/layout/_partials/head/head_com.pug +24 -24
  31. package/layout/_partials/head/pwa.pug +18 -18
  32. package/layout/_partials/header.pug +18 -18
  33. package/layout/_partials/layout.pug +140 -140
  34. package/layout/_partials/loading.pug +13 -13
  35. package/layout/_partials/pagination.pug +4 -4
  36. package/layout/_partials/post/copyright.pug +20 -20
  37. package/layout/_partials/post/footer.pug +17 -17
  38. package/layout/_partials/post/nav.pug +13 -13
  39. package/layout/_partials/post/post.pug +41 -41
  40. package/layout/_partials/post/reward.pug +18 -18
  41. package/layout/_partials/sidebar/menu.pug +37 -37
  42. package/layout/_partials/sidebar/overview.pug +42 -42
  43. package/layout/_partials/third-party/baidu-analytics.pug +11 -11
  44. package/layout/_partials/third-party/clarity.pug +8 -8
  45. package/layout/_partials/third-party/google-analytics.pug +9 -9
  46. package/layout/archive.pug +118 -118
  47. package/layout/category.pug +59 -59
  48. package/layout/index.pug +33 -33
  49. package/layout/page.pug +55 -55
  50. package/layout/post.pug +36 -36
  51. package/layout/tag.pug +43 -43
  52. package/package.json +71 -72
  53. package/scripts/filters/locals.js +52 -0
  54. package/scripts/filters/post.js +5 -0
  55. package/scripts/generaters/archive.js +133 -0
  56. package/scripts/generaters/config.js +51 -0
  57. package/scripts/generaters/images.js +23 -0
  58. package/scripts/generaters/index.js +107 -0
  59. package/scripts/generaters/pages.js +15 -0
  60. package/scripts/generaters/script.js +156 -0
  61. package/scripts/helpers/asset.js +73 -0
  62. package/scripts/helpers/engine.js +177 -0
  63. package/scripts/helpers/list_categories.js +80 -0
  64. package/scripts/helpers/summary_ai.js +107 -0
  65. package/scripts/helpers/symbols_count_time.js +69 -0
  66. package/scripts/plugin/check.js +32 -0
  67. package/scripts/plugin/index.js +81 -0
  68. package/scripts/plugin/lib/injects-point.js +20 -0
  69. package/scripts/plugin/lib/injects.js +89 -0
  70. package/scripts/tags/links.js +44 -0
  71. package/scripts/tags/media.js +19 -0
  72. package/scripts/utils.js +13 -0
  73. package/source/assets/algolia_logo.svg +9 -9
  74. package/source/assets/logo.svg +16 -16
  75. package/source/css/_colors.styl +207 -207
  76. package/source/css/_common/components/components.styl +6 -6
  77. package/source/css/_common/components/highlight/highlight.styl +357 -357
  78. package/source/css/_common/components/highlight/operation.styl +21 -21
  79. package/source/css/_common/components/pages/collapse.styl +119 -119
  80. package/source/css/_common/components/pages/home.styl +391 -391
  81. package/source/css/_common/components/pages/pages.styl +56 -56
  82. package/source/css/_common/components/pages/tag-cloud.styl +12 -12
  83. package/source/css/_common/components/post/breadcrumb.styl +39 -39
  84. package/source/css/_common/components/post/copyright.styl +41 -41
  85. package/source/css/_common/components/post/expand.styl +263 -263
  86. package/source/css/_common/components/post/footer.styl +11 -11
  87. package/source/css/_common/components/post/header.styl +79 -79
  88. package/source/css/_common/components/post/nav.styl +64 -64
  89. package/source/css/_common/components/post/post.styl +29 -29
  90. package/source/css/_common/components/post/reward.styl +50 -50
  91. package/source/css/_common/components/post/rtl.styl +12 -12
  92. package/source/css/_common/components/post/tags.styl +39 -39
  93. package/source/css/_common/components/tags/collapse.styl +72 -72
  94. package/source/css/_common/components/tags/container.styl +49 -49
  95. package/source/css/_common/components/tags/label.styl +12 -12
  96. package/source/css/_common/components/tags/links.styl +77 -77
  97. package/source/css/_common/components/tags/list.styl +131 -131
  98. package/source/css/_common/components/tags/note.styl +70 -70
  99. package/source/css/_common/components/tags/player.styl +361 -361
  100. package/source/css/_common/components/tags/quiz.styl +200 -200
  101. package/source/css/_common/components/tags/tabs.styl +89 -89
  102. package/source/css/_common/components/tags/tags.styl +9 -9
  103. package/source/css/_common/components/third-party/loading.styl +222 -222
  104. package/source/css/_common/components/third-party/mermaid/class.styl +90 -90
  105. package/source/css/_common/components/third-party/mermaid/flowchart.styl +72 -72
  106. package/source/css/_common/components/third-party/mermaid/gantt.styl +251 -251
  107. package/source/css/_common/components/third-party/mermaid/git.styl +7 -7
  108. package/source/css/_common/components/third-party/mermaid/mermaid.styl +37 -37
  109. package/source/css/_common/components/third-party/mermaid/pie.styl +9 -9
  110. package/source/css/_common/components/third-party/mermaid/sequence.styl +95 -95
  111. package/source/css/_common/components/third-party/mermaid/state.styl +130 -130
  112. package/source/css/_common/components/third-party/pace.styl +18 -18
  113. package/source/css/_common/components/third-party/search.styl +167 -167
  114. package/source/css/_common/components/third-party/theme.styl +151 -151
  115. package/source/css/_common/components/third-party/third-party.styl +22 -22
  116. package/source/css/_common/components/third-party/widgets.styl +57 -57
  117. package/source/css/_common/outline/footer/footer.styl +67 -67
  118. package/source/css/_common/outline/header/brand.styl +77 -77
  119. package/source/css/_common/outline/header/header.styl +20 -20
  120. package/source/css/_common/outline/header/image.styl +85 -85
  121. package/source/css/_common/outline/header/menu.styl +117 -117
  122. package/source/css/_common/outline/header/nav.styl +81 -81
  123. package/source/css/_common/outline/header/right.styl +15 -15
  124. package/source/css/_common/outline/header/tool.styl +207 -207
  125. package/source/css/_common/outline/header/waves.styl +57 -57
  126. package/source/css/_common/outline/mobile.styl +46 -46
  127. package/source/css/_common/outline/outline.styl +78 -78
  128. package/source/css/_common/outline/sidebar/author.styl +59 -59
  129. package/source/css/_common/outline/sidebar/dimmer.styl +23 -23
  130. package/source/css/_common/outline/sidebar/menu.styl +63 -63
  131. package/source/css/_common/outline/sidebar/quick.styl +43 -43
  132. package/source/css/_common/outline/sidebar/related.styl +56 -56
  133. package/source/css/_common/outline/sidebar/sidebar.styl +80 -80
  134. package/source/css/_common/outline/sidebar/social.styl +69 -69
  135. package/source/css/_common/outline/sidebar/state.styl +37 -37
  136. package/source/css/_common/outline/sidebar/tab.styl +71 -71
  137. package/source/css/_common/outline/sidebar/toc.styl +47 -47
  138. package/source/css/_common/scaffolding/animate.styl +322 -322
  139. package/source/css/_common/scaffolding/base.styl +190 -190
  140. package/source/css/_common/scaffolding/buttons.styl +48 -48
  141. package/source/css/_common/scaffolding/divider.styl +36 -36
  142. package/source/css/_common/scaffolding/iconfont.styl +443 -443
  143. package/source/css/_common/scaffolding/normalize.styl +273 -273
  144. package/source/css/_common/scaffolding/pagination.styl +81 -81
  145. package/source/css/_common/scaffolding/ribbon.styl +38 -38
  146. package/source/css/_common/scaffolding/scaffolding.styl +14 -14
  147. package/source/css/_common/scaffolding/scrollbar.styl +37 -37
  148. package/source/css/_common/scaffolding/tables.styl +50 -50
  149. package/source/css/_common/scaffolding/tip.styl +19 -19
  150. package/source/css/_common/scaffolding/toggles.styl +59 -59
  151. package/source/css/_iconfont.styl +455 -455
  152. package/source/css/_mixins.styl +148 -148
  153. package/source/css/_variables.styl +89 -89
  154. package/source/css/app.styl +41 -41
  155. package/source/css/mermaid.styl +5 -5
  156. package/source/css/optimize.styl +5 -5
  157. package/source/js/_app/components/comments.ts +88 -88
  158. package/source/js/_app/components/sidebar.ts +239 -239
  159. package/source/js/_app/components/tcomments.ts +54 -54
  160. package/source/js/_app/globals/globalVars.ts +99 -99
  161. package/source/js/_app/globals/handles.ts +124 -124
  162. package/source/js/_app/globals/themeColor.ts +63 -63
  163. package/source/js/_app/globals/thirdparty.ts +63 -63
  164. package/source/js/_app/globals/tools.ts +75 -75
  165. package/source/js/_app/library/anime.ts +110 -110
  166. package/source/js/_app/library/declare.d.ts +128 -128
  167. package/source/js/_app/library/dom.ts +28 -28
  168. package/source/js/_app/library/loadFile.ts +47 -47
  169. package/source/js/_app/library/proto.ts +137 -137
  170. package/source/js/_app/library/scriptPjax.ts +72 -72
  171. package/source/js/_app/library/storage.ts +12 -12
  172. package/source/js/_app/library/vue.ts +49 -49
  173. package/source/js/_app/page/common.ts +43 -43
  174. package/source/js/_app/page/fancybox.ts +72 -72
  175. package/source/js/_app/page/post.ts +266 -266
  176. package/source/js/_app/page/search.ts +115 -115
  177. package/source/js/_app/page/tab.ts +60 -60
  178. package/source/js/_app/pjax/domInit.ts +97 -97
  179. package/source/js/_app/pjax/refresh.ts +140 -140
  180. package/source/js/_app/pjax/siteInit.ts +106 -106
  181. package/source/js/_app/player.ts +798 -798
  182. package/toolbox/compiler.mjs +10 -19
  183. package/toolbox/hoistdep.mjs +5 -5
  184. package/toolbox/lib.mjs +63 -63
  185. package/index.html +0 -231
  186. package/meta.json +0 -6431
@@ -1,88 +1,88 @@
1
- import { CONFIG } from '../globals/globalVars'
2
- import { init, RecentComments } from '@waline/client'
3
- import { pageviewCount } from '@waline/client/pageview'
4
- await import('@waline/client/style')
5
-
6
- export const walineComment = function () {
7
- init({
8
- el: '#comments',
9
- serverURL: CONFIG.waline.serverURL,
10
- lang: CONFIG.waline.lang,
11
- locale: CONFIG.waline.locale,
12
- emoji: CONFIG.waline.emoji,
13
- meta: CONFIG.waline.meta,
14
- requiredMeta: CONFIG.waline.requiredMeta,
15
- wordLimit: CONFIG.waline.wordLimit,
16
- pageSize: CONFIG.waline.pageSize,
17
- pageview: CONFIG.waline.pageview,
18
- path: window.location.pathname,
19
- dark: 'html[data-theme="dark"]'
20
- })
21
- }
22
-
23
- export const walinePageview = function () {
24
- // TODO waline 上游此模块存在问题
25
- pageviewCount({
26
- serverURL: CONFIG.waline.serverURL,
27
- path: window.location.pathname
28
- })
29
- }
30
-
31
- export const walineRecentComments = async function () {
32
- const root = shokax_siteURL.replace(/^(https?:\/\/)?[^/]*/, '')
33
- let items = []
34
- const { comments } = await RecentComments({
35
- serverURL: CONFIG.waline.serverURL.replace(/\/+$/, ''),
36
- count: 10
37
- })
38
- // TODO 疑似 waline API 返回格式与文档不一致,需要确认是否为上游问题
39
- // @ts-ignore
40
- comments.data.forEach(function (item) {
41
- let cText = (item.orig.length > 50) ? item.orig.substring(0, 50) + '...' : item.orig
42
- item.url = item.url.startsWith('/') ? item.url : '/' + item.url
43
- const siteLink = item.url + '#' + item.objectId
44
-
45
- const time = new Date(item.time)
46
- const now = new Date()
47
- const diff = now.valueOf() - time.valueOf()
48
- let dateStr:string
49
- if (diff < 3600000) {
50
- dateStr = `${Math.floor(diff / 60000)} 分钟前`
51
- } else if (diff < 86400000) {
52
- dateStr = `${Math.floor(diff / 3600000)} 小时前`
53
- } else if (diff < 2592000000) {
54
- dateStr = `${Math.floor(diff / 86400000)} 天前`
55
- } else {
56
- dateStr = `${time.getFullYear()}-${time.getMonth() + 1}-${time.getDate()}`
57
- }
58
-
59
- items.push({
60
- href: siteLink,
61
- nick: item.nick,
62
- time: dateStr,
63
- text: cText
64
- })
65
- })
66
- const newComments = new DocumentFragment()
67
- items.forEach(function (item) {
68
- const commentEl = document.createElement('li')
69
- const commentLink = document.createElement('a')
70
- const commentTime = document.createElement('span')
71
- const commentText = document.createElement('span')
72
-
73
- commentText.innerText = item.text
74
- commentTime.className = 'breadcrumb'
75
- commentTime.innerText = `${item.nick} @ ${item.time}`
76
- commentLink.href = root + item.href
77
- commentLink['data-pjax-state'] = 'data-pjax-state'
78
- commentEl.className = 'item'
79
-
80
- commentText.appendChild(document.createElement('br'))
81
- commentLink.appendChild(commentTime)
82
- commentLink.appendChild(commentText)
83
- commentEl.appendChild(commentLink)
84
- newComments.appendChild(commentEl)
85
- })
86
-
87
- document.getElementById("new-comment").appendChild(newComments)
88
- }
1
+ import { CONFIG } from '../globals/globalVars'
2
+ import { init, RecentComments } from '@waline/client'
3
+ import { pageviewCount } from '@waline/client/pageview'
4
+ await import('@waline/client/style')
5
+
6
+ export const walineComment = function () {
7
+ init({
8
+ el: '#comments',
9
+ serverURL: CONFIG.waline.serverURL,
10
+ lang: CONFIG.waline.lang,
11
+ locale: CONFIG.waline.locale,
12
+ emoji: CONFIG.waline.emoji,
13
+ meta: CONFIG.waline.meta,
14
+ requiredMeta: CONFIG.waline.requiredMeta,
15
+ wordLimit: CONFIG.waline.wordLimit,
16
+ pageSize: CONFIG.waline.pageSize,
17
+ pageview: CONFIG.waline.pageview,
18
+ path: window.location.pathname,
19
+ dark: 'html[data-theme="dark"]'
20
+ })
21
+ }
22
+
23
+ export const walinePageview = function () {
24
+ // TODO waline 上游此模块存在问题
25
+ pageviewCount({
26
+ serverURL: CONFIG.waline.serverURL,
27
+ path: window.location.pathname
28
+ })
29
+ }
30
+
31
+ export const walineRecentComments = async function () {
32
+ const root = shokax_siteURL.replace(/^(https?:\/\/)?[^/]*/, '')
33
+ let items = []
34
+ const { comments } = await RecentComments({
35
+ serverURL: CONFIG.waline.serverURL.replace(/\/+$/, ''),
36
+ count: 10
37
+ })
38
+ // TODO 疑似 waline API 返回格式与文档不一致,需要确认是否为上游问题
39
+ // @ts-ignore
40
+ comments.data.forEach(function (item) {
41
+ let cText = (item.orig.length > 50) ? item.orig.substring(0, 50) + '...' : item.orig
42
+ item.url = item.url.startsWith('/') ? item.url : '/' + item.url
43
+ const siteLink = item.url + '#' + item.objectId
44
+
45
+ const time = new Date(item.time)
46
+ const now = new Date()
47
+ const diff = now.valueOf() - time.valueOf()
48
+ let dateStr:string
49
+ if (diff < 3600000) {
50
+ dateStr = `${Math.floor(diff / 60000)} 分钟前`
51
+ } else if (diff < 86400000) {
52
+ dateStr = `${Math.floor(diff / 3600000)} 小时前`
53
+ } else if (diff < 2592000000) {
54
+ dateStr = `${Math.floor(diff / 86400000)} 天前`
55
+ } else {
56
+ dateStr = `${time.getFullYear()}-${time.getMonth() + 1}-${time.getDate()}`
57
+ }
58
+
59
+ items.push({
60
+ href: siteLink,
61
+ nick: item.nick,
62
+ time: dateStr,
63
+ text: cText
64
+ })
65
+ })
66
+ const newComments = new DocumentFragment()
67
+ items.forEach(function (item) {
68
+ const commentEl = document.createElement('li')
69
+ const commentLink = document.createElement('a')
70
+ const commentTime = document.createElement('span')
71
+ const commentText = document.createElement('span')
72
+
73
+ commentText.innerText = item.text
74
+ commentTime.className = 'breadcrumb'
75
+ commentTime.innerText = `${item.nick} @ ${item.time}`
76
+ commentLink.href = root + item.href
77
+ commentLink['data-pjax-state'] = 'data-pjax-state'
78
+ commentEl.className = 'item'
79
+
80
+ commentText.appendChild(document.createElement('br'))
81
+ commentLink.appendChild(commentTime)
82
+ commentLink.appendChild(commentText)
83
+ commentEl.appendChild(commentLink)
84
+ newComments.appendChild(commentEl)
85
+ })
86
+
87
+ document.getElementById("new-comment").appendChild(newComments)
88
+ }
@@ -1,239 +1,239 @@
1
- /* 边栏分区 */
2
-
3
- import { CONFIG, Container, diffY, menuToggle, showContents, sideBar } from '../globals/globalVars'
4
- import { clipBoard } from '../globals/tools'
5
- import { pageScroll, transition } from '../library/anime'
6
- import { $dom } from '../library/dom'
7
- import initProto, { getHeight, setDisplay } from '../library/proto'
8
-
9
- initProto()
10
- export const sideBarToggleHandle = (event:Event, force?:number) => {
11
- if (sideBar.hasClass('on')) {
12
- sideBar.removeClass('on')
13
- menuToggle.removeClass('close')
14
- if (force) {
15
- // @ts-ignore
16
- // noinspection JSConstantReassignment
17
- sideBar.style = ''
18
- } else {
19
- transition(sideBar, 'slideRightOut')
20
- }
21
- } else {
22
- if (force) {
23
- // @ts-ignore
24
- // noinspection JSConstantReassignment
25
- sideBar.style = ''
26
- } else {
27
- transition(sideBar, 'slideRightIn', () => {
28
- sideBar.addClass('on')
29
- menuToggle.addClass('close')
30
- })
31
- }
32
- }
33
- }
34
-
35
- export const sideBarTab = () => {
36
- const sideBarInner = sideBar.querySelector('.inner')
37
-
38
- if (sideBar.querySelector('.tab')) {
39
- sideBarInner.removeChild(sideBar.querySelector('.tab'))
40
- }
41
-
42
- const list = document.createElement('ul'); let active = 'active'
43
- list.className = 'tab';
44
-
45
- ['contents', 'related', 'overview'].forEach((item) => {
46
- const element = sideBar.querySelector('.panel.' + item)
47
-
48
- if (element.innerHTML.trim().length < 1) {
49
- if (item === 'contents') {
50
- setDisplay(showContents, 'none')
51
- }
52
- return
53
- }
54
-
55
- if (item === 'contents') {
56
- setDisplay(showContents, '')
57
- }
58
-
59
- const tab = document.createElement('li')
60
- const span = document.createElement('span')
61
- const text = document.createTextNode(element.getAttribute('data-title'))
62
- span.appendChild(text)
63
- tab.appendChild(span)
64
- tab.addClass(item + ' item')
65
-
66
- if (active) {
67
- element.addClass(active)
68
- tab.addClass(active)
69
- } else {
70
- element.removeClass('active')
71
- }
72
- tab.addEventListener('click', (event) => {
73
- const target = event.currentTarget as HTMLElement
74
- if (target.hasClass('active')) return
75
-
76
- sideBar.find('.tab .item').forEach((element) => {
77
- element.removeClass('active')
78
- })
79
-
80
- sideBar.find('.panel').forEach((element) => {
81
- element.removeClass('active')
82
- })
83
-
84
- sideBar.querySelector('.panel.' + target.className.replace(' item', '')).addClass('active')
85
-
86
- target.addClass('active')
87
- })
88
-
89
- list.appendChild(tab)
90
- active = ''
91
- })
92
-
93
- if (list.childNodes.length > 1) {
94
- sideBarInner.insertBefore(list, sideBarInner.childNodes[0]);
95
- (sideBar.querySelector('.panels') as HTMLElement).style.paddingTop = ''
96
- } else {
97
- (sideBar.querySelector('.panels') as HTMLElement).style.paddingTop = '.625rem'
98
- }
99
- }
100
-
101
- export const sidebarTOC = () => {
102
- const activateNavByIndex = (index:number): void => {
103
- const target = navItems[index]
104
-
105
- if (!target) return
106
-
107
- if (target.hasClass('current')) {
108
- return
109
- }
110
-
111
- $dom.each('.toc .active', (element) => {
112
- element && element.removeClass('active current')
113
- })
114
-
115
- sections.forEach((element) => {
116
- element && element.removeClass('active')
117
- })
118
-
119
- target.addClass('active current')
120
- sections[index] && sections[index].addClass('active')
121
-
122
- let parent = <Element> target.parentNode
123
-
124
- while (!parent.matches('.contents')) {
125
- if (parent.matches('li')) {
126
- parent.addClass('active')
127
- const t = document.querySelector(parent.querySelector('a.toc-link').getAttribute('href'))
128
- if (t) {
129
- t.addClass('active')
130
- }
131
- }
132
- parent = <Element> parent.parentNode
133
- }
134
- // Scrolling to center active TOC element if TOC content is taller than viewport.
135
- if (getComputedStyle(sideBar).display !== 'none' && tocElement.hasClass('active')) {
136
- pageScroll((tocElement as HTMLElement), target.offsetTop - ((tocElement as HTMLElement).offsetHeight / 4))
137
- }
138
- }
139
- const navItems = $dom.all('.contents li')
140
-
141
- if (navItems.length < 1) {
142
- return
143
- }
144
-
145
- let sections = [...navItems] as HTMLElement[]
146
- let activeLock = null
147
-
148
- sections = sections.map((element, index) => {
149
- const link = element.querySelector('a.toc-link')
150
- const anchor = document.querySelector(decodeURI(link.getAttribute('href')))
151
- if (!anchor) return null
152
- const alink = anchor.querySelector('a.anchor')
153
-
154
- const anchorScroll = (event:MouseEvent) => {
155
- event.preventDefault()
156
- const target = document.querySelector(decodeURI((event.currentTarget as HTMLElement).getAttribute('href')))
157
-
158
- activeLock = index
159
- pageScroll((target as HTMLElement), null, () => {
160
- activateNavByIndex(index)
161
- activeLock = null
162
- })
163
- }
164
-
165
- // TOC item animation navigate.
166
- link.addEventListener('click', anchorScroll)
167
- alink && alink.addEventListener('click', (event) => {
168
- anchorScroll(<MouseEvent>event)
169
- clipBoard(CONFIG.hostname + '/' + LOCAL.path + (event.currentTarget as HTMLElement).getAttribute('href'))
170
- })
171
- return (anchor as HTMLElement)
172
- })
173
-
174
- const tocElement = sideBar.querySelector('.contents.panel')
175
-
176
- const findIndex = (entries: IntersectionObserverEntry[]) => {
177
- let index = 0
178
- let entry = entries[index]
179
-
180
- if (entry.boundingClientRect.top > 0) {
181
- index = sections.indexOf(entry.target as HTMLElement)
182
- return index === 0 ? 0 : index - 1
183
- }
184
- for (; index < entries.length; index++) {
185
- if (entries[index].boundingClientRect.top <= 0) {
186
- entry = entries[index]
187
- } else {
188
- return sections.indexOf(entry.target as HTMLElement)
189
- }
190
- }
191
- return sections.indexOf(entry.target as HTMLElement)
192
- }
193
-
194
- const createIntersectionObserver = () => {
195
- const observer = new IntersectionObserver((entries) => {
196
- const index = findIndex(entries) + (diffY < 0 ? 1 : 0)
197
- if (activeLock === null) {
198
- activateNavByIndex(index)
199
- }
200
- }, {
201
- rootMargin: '0px 0px -100% 0px', threshold: 0
202
- })
203
-
204
- sections.forEach((element) => {
205
- element && observer.observe(element)
206
- })
207
- }
208
-
209
- createIntersectionObserver()
210
- }
211
-
212
- export const backToTopHandle = () => {
213
- pageScroll(0)
214
- }
215
-
216
- export const goToBottomHandle = () => {
217
- pageScroll(parseInt(String(getHeight(Container))))
218
- }
219
-
220
- export const goToCommentHandle = () => {
221
- pageScroll(document.getElementById('comments'))
222
- }
223
-
224
- export const menuActive = () => {
225
- $dom.each('.menu .item:not(.title)', (element) => {
226
- const target = <HTMLAnchorElement> element.querySelector('a[href]')
227
- const parentItem = element.parentNode.parentNode
228
- if (!target) return
229
- const isSamePath = target.pathname === location.pathname || target.pathname === location.pathname.replace('index.html', '')
230
- const isSubPath = !CONFIG.root.startsWith(target.pathname) && location.pathname.startsWith(target.pathname)
231
- const active = !target.onclick && target.hostname === location.hostname && (isSamePath || isSubPath)
232
- element.toggleClass('active', active)
233
- if (element.parentNode.querySelector('.active') && parentItem.hasClass('dropdown')) {
234
- parentItem.removeClass('active').addClass('expand')
235
- } else {
236
- parentItem.removeClass('expand')
237
- }
238
- })
239
- }
1
+ /* 边栏分区 */
2
+
3
+ import { CONFIG, Container, diffY, menuToggle, showContents, sideBar } from '../globals/globalVars'
4
+ import { clipBoard } from '../globals/tools'
5
+ import { pageScroll, transition } from '../library/anime'
6
+ import { $dom } from '../library/dom'
7
+ import initProto, { getHeight, setDisplay } from '../library/proto'
8
+
9
+ initProto()
10
+ export const sideBarToggleHandle = (event:Event, force?:number) => {
11
+ if (sideBar.hasClass('on')) {
12
+ sideBar.removeClass('on')
13
+ menuToggle.removeClass('close')
14
+ if (force) {
15
+ // @ts-ignore
16
+ // noinspection JSConstantReassignment
17
+ sideBar.style = ''
18
+ } else {
19
+ transition(sideBar, 'slideRightOut')
20
+ }
21
+ } else {
22
+ if (force) {
23
+ // @ts-ignore
24
+ // noinspection JSConstantReassignment
25
+ sideBar.style = ''
26
+ } else {
27
+ transition(sideBar, 'slideRightIn', () => {
28
+ sideBar.addClass('on')
29
+ menuToggle.addClass('close')
30
+ })
31
+ }
32
+ }
33
+ }
34
+
35
+ export const sideBarTab = () => {
36
+ const sideBarInner = sideBar.querySelector('.inner')
37
+
38
+ if (sideBar.querySelector('.tab')) {
39
+ sideBarInner.removeChild(sideBar.querySelector('.tab'))
40
+ }
41
+
42
+ const list = document.createElement('ul'); let active = 'active'
43
+ list.className = 'tab';
44
+
45
+ ['contents', 'related', 'overview'].forEach((item) => {
46
+ const element = sideBar.querySelector('.panel.' + item)
47
+
48
+ if (element.innerHTML.trim().length < 1) {
49
+ if (item === 'contents') {
50
+ setDisplay(showContents, 'none')
51
+ }
52
+ return
53
+ }
54
+
55
+ if (item === 'contents') {
56
+ setDisplay(showContents, '')
57
+ }
58
+
59
+ const tab = document.createElement('li')
60
+ const span = document.createElement('span')
61
+ const text = document.createTextNode(element.getAttribute('data-title'))
62
+ span.appendChild(text)
63
+ tab.appendChild(span)
64
+ tab.addClass(item + ' item')
65
+
66
+ if (active) {
67
+ element.addClass(active)
68
+ tab.addClass(active)
69
+ } else {
70
+ element.removeClass('active')
71
+ }
72
+ tab.addEventListener('click', (event) => {
73
+ const target = event.currentTarget as HTMLElement
74
+ if (target.hasClass('active')) return
75
+
76
+ sideBar.find('.tab .item').forEach((element) => {
77
+ element.removeClass('active')
78
+ })
79
+
80
+ sideBar.find('.panel').forEach((element) => {
81
+ element.removeClass('active')
82
+ })
83
+
84
+ sideBar.querySelector('.panel.' + target.className.replace(' item', '')).addClass('active')
85
+
86
+ target.addClass('active')
87
+ })
88
+
89
+ list.appendChild(tab)
90
+ active = ''
91
+ })
92
+
93
+ if (list.childNodes.length > 1) {
94
+ sideBarInner.insertBefore(list, sideBarInner.childNodes[0]);
95
+ (sideBar.querySelector('.panels') as HTMLElement).style.paddingTop = ''
96
+ } else {
97
+ (sideBar.querySelector('.panels') as HTMLElement).style.paddingTop = '.625rem'
98
+ }
99
+ }
100
+
101
+ export const sidebarTOC = () => {
102
+ const activateNavByIndex = (index:number): void => {
103
+ const target = navItems[index]
104
+
105
+ if (!target) return
106
+
107
+ if (target.hasClass('current')) {
108
+ return
109
+ }
110
+
111
+ $dom.each('.toc .active', (element) => {
112
+ element && element.removeClass('active current')
113
+ })
114
+
115
+ sections.forEach((element) => {
116
+ element && element.removeClass('active')
117
+ })
118
+
119
+ target.addClass('active current')
120
+ sections[index] && sections[index].addClass('active')
121
+
122
+ let parent = <Element> target.parentNode
123
+
124
+ while (!parent.matches('.contents')) {
125
+ if (parent.matches('li')) {
126
+ parent.addClass('active')
127
+ const t = document.querySelector(parent.querySelector('a.toc-link').getAttribute('href'))
128
+ if (t) {
129
+ t.addClass('active')
130
+ }
131
+ }
132
+ parent = <Element> parent.parentNode
133
+ }
134
+ // Scrolling to center active TOC element if TOC content is taller than viewport.
135
+ if (getComputedStyle(sideBar).display !== 'none' && tocElement.hasClass('active')) {
136
+ pageScroll((tocElement as HTMLElement), target.offsetTop - ((tocElement as HTMLElement).offsetHeight / 4))
137
+ }
138
+ }
139
+ const navItems = $dom.all('.contents li')
140
+
141
+ if (navItems.length < 1) {
142
+ return
143
+ }
144
+
145
+ let sections = [...navItems] as HTMLElement[]
146
+ let activeLock = null
147
+
148
+ sections = sections.map((element, index) => {
149
+ const link = element.querySelector('a.toc-link')
150
+ const anchor = document.querySelector(decodeURI(link.getAttribute('href')))
151
+ if (!anchor) return null
152
+ const alink = anchor.querySelector('a.anchor')
153
+
154
+ const anchorScroll = (event:MouseEvent) => {
155
+ event.preventDefault()
156
+ const target = document.querySelector(decodeURI((event.currentTarget as HTMLElement).getAttribute('href')))
157
+
158
+ activeLock = index
159
+ pageScroll((target as HTMLElement), null, () => {
160
+ activateNavByIndex(index)
161
+ activeLock = null
162
+ })
163
+ }
164
+
165
+ // TOC item animation navigate.
166
+ link.addEventListener('click', anchorScroll)
167
+ alink && alink.addEventListener('click', (event) => {
168
+ anchorScroll(<MouseEvent>event)
169
+ clipBoard(CONFIG.hostname + '/' + LOCAL.path + (event.currentTarget as HTMLElement).getAttribute('href'))
170
+ })
171
+ return (anchor as HTMLElement)
172
+ })
173
+
174
+ const tocElement = sideBar.querySelector('.contents.panel')
175
+
176
+ const findIndex = (entries: IntersectionObserverEntry[]) => {
177
+ let index = 0
178
+ let entry = entries[index]
179
+
180
+ if (entry.boundingClientRect.top > 0) {
181
+ index = sections.indexOf(entry.target as HTMLElement)
182
+ return index === 0 ? 0 : index - 1
183
+ }
184
+ for (; index < entries.length; index++) {
185
+ if (entries[index].boundingClientRect.top <= 0) {
186
+ entry = entries[index]
187
+ } else {
188
+ return sections.indexOf(entry.target as HTMLElement)
189
+ }
190
+ }
191
+ return sections.indexOf(entry.target as HTMLElement)
192
+ }
193
+
194
+ const createIntersectionObserver = () => {
195
+ const observer = new IntersectionObserver((entries) => {
196
+ const index = findIndex(entries) + (diffY < 0 ? 1 : 0)
197
+ if (activeLock === null) {
198
+ activateNavByIndex(index)
199
+ }
200
+ }, {
201
+ rootMargin: '0px 0px -100% 0px', threshold: 0
202
+ })
203
+
204
+ sections.forEach((element) => {
205
+ element && observer.observe(element)
206
+ })
207
+ }
208
+
209
+ createIntersectionObserver()
210
+ }
211
+
212
+ export const backToTopHandle = () => {
213
+ pageScroll(0)
214
+ }
215
+
216
+ export const goToBottomHandle = () => {
217
+ pageScroll(parseInt(String(getHeight(Container))))
218
+ }
219
+
220
+ export const goToCommentHandle = () => {
221
+ pageScroll(document.getElementById('comments'))
222
+ }
223
+
224
+ export const menuActive = () => {
225
+ $dom.each('.menu .item:not(.title)', (element) => {
226
+ const target = <HTMLAnchorElement> element.querySelector('a[href]')
227
+ const parentItem = element.parentNode.parentNode
228
+ if (!target) return
229
+ const isSamePath = target.pathname === location.pathname || target.pathname === location.pathname.replace('index.html', '')
230
+ const isSubPath = !CONFIG.root.startsWith(target.pathname) && location.pathname.startsWith(target.pathname)
231
+ const active = !target.onclick && target.hostname === location.hostname && (isSamePath || isSubPath)
232
+ element.toggleClass('active', active)
233
+ if (element.parentNode.querySelector('.active') && parentItem.hasClass('dropdown')) {
234
+ parentItem.removeClass('active').addClass('expand')
235
+ } else {
236
+ parentItem.removeClass('expand')
237
+ }
238
+ })
239
+ }