hexo-theme-shokax 0.4.6-dev6 → 0.4.6
Sign up to get free protection for your applications and to get access to all the features.
- package/CODE_OF_CONDUCT.md +128 -128
- package/CONTRIBUTING.md +58 -58
- package/LICENSE +660 -660
- package/LICENSE-shoka +21 -21
- package/README.md +76 -99
- package/README_en.MD +75 -91
- package/UsageRestrictions.md +25 -25
- package/_config.yml +381 -381
- package/_images.yml +9 -9
- package/eslint.config.mjs +55 -55
- package/languages/README.md +19 -19
- package/languages/default.yml +1 -1
- package/languages/en.yml +153 -153
- package/languages/ja.yml +153 -153
- package/languages/zh-CN.yml +153 -153
- package/languages/zh-HK.yml +153 -153
- package/languages/zh-TW.yml +153 -153
- package/layout/_alternate/atom.ejs +30 -30
- package/layout/_alternate/json.ejs +16 -16
- package/layout/_alternate/rss.ejs +34 -34
- package/layout/_mixin/breadcrumb.pug +33 -33
- package/layout/_mixin/card.pug +38 -38
- package/layout/_mixin/comment.pug +6 -6
- package/layout/_mixin/postmeta.pug +29 -29
- package/layout/_mixin/segment.pug +35 -35
- package/layout/_mixin/sidebar.pug +40 -40
- package/layout/_mixin/widgets.pug +28 -28
- package/layout/_partials/footer.pug +43 -43
- package/layout/_partials/head/head.pug +55 -55
- package/layout/_partials/head/head_com.pug +24 -24
- package/layout/_partials/head/pwa.pug +18 -18
- package/layout/_partials/header.pug +18 -18
- package/layout/_partials/layout.pug +140 -140
- package/layout/_partials/loading.pug +13 -13
- package/layout/_partials/pagination.pug +4 -4
- package/layout/_partials/post/copyright.pug +20 -20
- package/layout/_partials/post/footer.pug +17 -17
- package/layout/_partials/post/nav.pug +13 -13
- package/layout/_partials/post/post.pug +41 -41
- package/layout/_partials/post/reward.pug +18 -18
- package/layout/_partials/sidebar/menu.pug +37 -37
- package/layout/_partials/sidebar/overview.pug +42 -42
- package/layout/_partials/third-party/baidu-analytics.pug +11 -11
- package/layout/_partials/third-party/clarity.pug +8 -8
- package/layout/_partials/third-party/google-analytics.pug +9 -9
- package/layout/archive.pug +118 -118
- package/layout/category.pug +59 -59
- package/layout/index.pug +33 -33
- package/layout/page.pug +55 -55
- package/layout/post.pug +36 -36
- package/layout/tag.pug +43 -43
- package/package.json +72 -72
- package/scripts/filters/locals.js +52 -0
- package/scripts/filters/post.js +5 -0
- package/scripts/generaters/archive.js +133 -0
- package/scripts/generaters/config.js +51 -0
- package/scripts/generaters/images.js +23 -0
- package/scripts/generaters/index.js +107 -0
- package/scripts/generaters/pages.js +15 -0
- package/scripts/generaters/script.js +156 -0
- package/scripts/helpers/asset.js +73 -0
- package/scripts/helpers/engine.js +177 -0
- package/scripts/helpers/list_categories.js +80 -0
- package/scripts/helpers/summary_ai.js +107 -0
- package/scripts/helpers/symbols_count_time.js +69 -0
- package/scripts/plugin/check.js +32 -0
- package/scripts/plugin/index.js +81 -0
- package/scripts/plugin/lib/injects-point.js +20 -0
- package/scripts/plugin/lib/injects.js +89 -0
- package/scripts/tags/links.js +44 -0
- package/scripts/tags/media.js +19 -0
- package/scripts/utils.js +13 -0
- package/source/assets/algolia_logo.svg +9 -9
- package/source/assets/logo.svg +16 -16
- package/source/css/_colors.styl +207 -207
- package/source/css/_common/components/components.styl +6 -6
- package/source/css/_common/components/highlight/highlight.styl +357 -357
- package/source/css/_common/components/highlight/operation.styl +21 -21
- package/source/css/_common/components/pages/collapse.styl +119 -119
- package/source/css/_common/components/pages/home.styl +391 -391
- package/source/css/_common/components/pages/pages.styl +56 -56
- package/source/css/_common/components/pages/tag-cloud.styl +12 -12
- package/source/css/_common/components/post/breadcrumb.styl +39 -39
- package/source/css/_common/components/post/copyright.styl +41 -41
- package/source/css/_common/components/post/expand.styl +263 -263
- package/source/css/_common/components/post/footer.styl +11 -11
- package/source/css/_common/components/post/header.styl +79 -79
- package/source/css/_common/components/post/nav.styl +64 -64
- package/source/css/_common/components/post/post.styl +29 -29
- package/source/css/_common/components/post/reward.styl +50 -50
- package/source/css/_common/components/post/rtl.styl +12 -12
- package/source/css/_common/components/post/tags.styl +39 -39
- package/source/css/_common/components/tags/collapse.styl +72 -72
- package/source/css/_common/components/tags/container.styl +49 -49
- package/source/css/_common/components/tags/label.styl +12 -12
- package/source/css/_common/components/tags/links.styl +77 -77
- package/source/css/_common/components/tags/list.styl +131 -131
- package/source/css/_common/components/tags/note.styl +70 -70
- package/source/css/_common/components/tags/player.styl +361 -361
- package/source/css/_common/components/tags/quiz.styl +200 -200
- package/source/css/_common/components/tags/tabs.styl +89 -89
- package/source/css/_common/components/tags/tags.styl +9 -9
- package/source/css/_common/components/third-party/loading.styl +222 -222
- package/source/css/_common/components/third-party/mermaid/class.styl +90 -90
- package/source/css/_common/components/third-party/mermaid/flowchart.styl +72 -72
- package/source/css/_common/components/third-party/mermaid/gantt.styl +251 -251
- package/source/css/_common/components/third-party/mermaid/git.styl +7 -7
- package/source/css/_common/components/third-party/mermaid/mermaid.styl +37 -37
- package/source/css/_common/components/third-party/mermaid/pie.styl +9 -9
- package/source/css/_common/components/third-party/mermaid/sequence.styl +95 -95
- package/source/css/_common/components/third-party/mermaid/state.styl +130 -130
- package/source/css/_common/components/third-party/pace.styl +18 -18
- package/source/css/_common/components/third-party/search.styl +167 -167
- package/source/css/_common/components/third-party/theme.styl +151 -151
- package/source/css/_common/components/third-party/third-party.styl +22 -22
- package/source/css/_common/components/third-party/widgets.styl +57 -57
- package/source/css/_common/outline/footer/footer.styl +67 -67
- package/source/css/_common/outline/header/brand.styl +77 -77
- package/source/css/_common/outline/header/header.styl +20 -20
- package/source/css/_common/outline/header/image.styl +85 -85
- package/source/css/_common/outline/header/menu.styl +117 -117
- package/source/css/_common/outline/header/nav.styl +81 -81
- package/source/css/_common/outline/header/right.styl +15 -15
- package/source/css/_common/outline/header/tool.styl +207 -207
- package/source/css/_common/outline/header/waves.styl +57 -57
- package/source/css/_common/outline/mobile.styl +46 -46
- package/source/css/_common/outline/outline.styl +78 -78
- package/source/css/_common/outline/sidebar/author.styl +59 -59
- package/source/css/_common/outline/sidebar/dimmer.styl +23 -23
- package/source/css/_common/outline/sidebar/menu.styl +63 -63
- package/source/css/_common/outline/sidebar/quick.styl +43 -43
- package/source/css/_common/outline/sidebar/related.styl +56 -56
- package/source/css/_common/outline/sidebar/sidebar.styl +80 -80
- package/source/css/_common/outline/sidebar/social.styl +69 -69
- package/source/css/_common/outline/sidebar/state.styl +37 -37
- package/source/css/_common/outline/sidebar/tab.styl +71 -71
- package/source/css/_common/outline/sidebar/toc.styl +47 -47
- package/source/css/_common/scaffolding/animate.styl +322 -322
- package/source/css/_common/scaffolding/base.styl +190 -190
- package/source/css/_common/scaffolding/buttons.styl +48 -48
- package/source/css/_common/scaffolding/divider.styl +36 -36
- package/source/css/_common/scaffolding/iconfont.styl +443 -443
- package/source/css/_common/scaffolding/normalize.styl +273 -273
- package/source/css/_common/scaffolding/pagination.styl +81 -81
- package/source/css/_common/scaffolding/ribbon.styl +38 -38
- package/source/css/_common/scaffolding/scaffolding.styl +14 -14
- package/source/css/_common/scaffolding/scrollbar.styl +37 -37
- package/source/css/_common/scaffolding/tables.styl +50 -50
- package/source/css/_common/scaffolding/tip.styl +19 -19
- package/source/css/_common/scaffolding/toggles.styl +59 -59
- package/source/css/_iconfont.styl +455 -455
- package/source/css/_mixins.styl +148 -148
- package/source/css/_variables.styl +89 -89
- package/source/css/app.styl +41 -41
- package/source/css/mermaid.styl +5 -5
- package/source/css/optimize.styl +5 -5
- package/source/js/_app/components/comments.ts +88 -88
- package/source/js/_app/components/sidebar.ts +239 -239
- package/source/js/_app/components/tcomments.ts +54 -54
- package/source/js/_app/globals/globalVars.ts +99 -99
- package/source/js/_app/globals/handles.ts +124 -124
- package/source/js/_app/globals/themeColor.ts +63 -63
- package/source/js/_app/globals/thirdparty.ts +63 -63
- package/source/js/_app/globals/tools.ts +75 -75
- package/source/js/_app/library/anime.ts +110 -110
- package/source/js/_app/library/declare.d.ts +128 -128
- package/source/js/_app/library/dom.ts +28 -28
- package/source/js/_app/library/loadFile.ts +47 -47
- package/source/js/_app/library/proto.ts +137 -137
- package/source/js/_app/library/scriptPjax.ts +72 -72
- package/source/js/_app/library/storage.ts +12 -12
- package/source/js/_app/library/vue.ts +49 -49
- package/source/js/_app/page/common.ts +43 -43
- package/source/js/_app/page/fancybox.ts +72 -72
- package/source/js/_app/page/post.ts +266 -266
- package/source/js/_app/page/search.ts +115 -115
- package/source/js/_app/page/tab.ts +60 -60
- package/source/js/_app/pjax/domInit.ts +97 -97
- package/source/js/_app/pjax/refresh.ts +140 -140
- package/source/js/_app/pjax/siteInit.ts +106 -106
- package/source/js/_app/player.ts +798 -798
- package/toolbox/compiler.mjs +10 -6
- package/toolbox/hoistdep.mjs +5 -5
- package/toolbox/lib.mjs +63 -63
- package/index.html +0 -231
- package/meta.json +0 -6431
@@ -1,63 +1,63 @@
|
|
1
|
-
import { $storage } from '../library/storage'
|
2
|
-
import { CONFIG, HTML } from './globalVars'
|
3
|
-
|
4
|
-
/**
|
5
|
-
* 更改日夜模式
|
6
|
-
*/
|
7
|
-
export const changeTheme = (type?: string) => {
|
8
|
-
const btn = document.querySelector('.theme .ic')
|
9
|
-
if (type === 'dark') {
|
10
|
-
HTML.setAttribute('data-theme', type)
|
11
|
-
btn.removeClass('i-sun')
|
12
|
-
btn.addClass('i-moon')
|
13
|
-
} else {
|
14
|
-
HTML.removeAttribute('data-theme')
|
15
|
-
btn.removeClass('i-moon')
|
16
|
-
btn.addClass('i-sun')
|
17
|
-
}
|
18
|
-
}
|
19
|
-
|
20
|
-
/**
|
21
|
-
* 自动调整黑夜白天
|
22
|
-
* 优先级: 手动选择>时间>跟随系统
|
23
|
-
*/
|
24
|
-
export const autoDarkmode = () => {
|
25
|
-
if (CONFIG.auto_dark.enable) {
|
26
|
-
if (new Date().getHours() >= CONFIG.auto_dark.start || new Date().getHours() <= CONFIG.auto_dark.end) {
|
27
|
-
changeTheme('dark')
|
28
|
-
} else {
|
29
|
-
changeTheme()
|
30
|
-
}
|
31
|
-
}
|
32
|
-
}
|
33
|
-
|
34
|
-
/**
|
35
|
-
* 更改主题的meta
|
36
|
-
*/
|
37
|
-
export const changeMetaTheme = (color: string): void => {
|
38
|
-
if (HTML.getAttribute('data-theme') === 'dark') {
|
39
|
-
color = '#222'
|
40
|
-
}
|
41
|
-
|
42
|
-
document.querySelector('meta[name="theme-color"]').setAttribute('content', color)
|
43
|
-
}
|
44
|
-
|
45
|
-
// 记忆日夜模式切换和系统亮暗模式监听
|
46
|
-
export const themeColorListener = () => {
|
47
|
-
window.matchMedia('(prefers-color-scheme: dark)').addEventListener('change', (mediaQueryList) => {
|
48
|
-
if (mediaQueryList.matches) {
|
49
|
-
changeTheme('dark')
|
50
|
-
} else {
|
51
|
-
changeTheme()
|
52
|
-
}
|
53
|
-
})
|
54
|
-
|
55
|
-
const t = $storage.get('theme')
|
56
|
-
if (t) {
|
57
|
-
changeTheme(t)
|
58
|
-
} else {
|
59
|
-
if (CONFIG.darkmode) {
|
60
|
-
changeTheme('dark')
|
61
|
-
}
|
62
|
-
}
|
63
|
-
}
|
1
|
+
import { $storage } from '../library/storage'
|
2
|
+
import { CONFIG, HTML } from './globalVars'
|
3
|
+
|
4
|
+
/**
|
5
|
+
* 更改日夜模式
|
6
|
+
*/
|
7
|
+
export const changeTheme = (type?: string) => {
|
8
|
+
const btn = document.querySelector('.theme .ic')
|
9
|
+
if (type === 'dark') {
|
10
|
+
HTML.setAttribute('data-theme', type)
|
11
|
+
btn.removeClass('i-sun')
|
12
|
+
btn.addClass('i-moon')
|
13
|
+
} else {
|
14
|
+
HTML.removeAttribute('data-theme')
|
15
|
+
btn.removeClass('i-moon')
|
16
|
+
btn.addClass('i-sun')
|
17
|
+
}
|
18
|
+
}
|
19
|
+
|
20
|
+
/**
|
21
|
+
* 自动调整黑夜白天
|
22
|
+
* 优先级: 手动选择>时间>跟随系统
|
23
|
+
*/
|
24
|
+
export const autoDarkmode = () => {
|
25
|
+
if (CONFIG.auto_dark.enable) {
|
26
|
+
if (new Date().getHours() >= CONFIG.auto_dark.start || new Date().getHours() <= CONFIG.auto_dark.end) {
|
27
|
+
changeTheme('dark')
|
28
|
+
} else {
|
29
|
+
changeTheme()
|
30
|
+
}
|
31
|
+
}
|
32
|
+
}
|
33
|
+
|
34
|
+
/**
|
35
|
+
* 更改主题的meta
|
36
|
+
*/
|
37
|
+
export const changeMetaTheme = (color: string): void => {
|
38
|
+
if (HTML.getAttribute('data-theme') === 'dark') {
|
39
|
+
color = '#222'
|
40
|
+
}
|
41
|
+
|
42
|
+
document.querySelector('meta[name="theme-color"]').setAttribute('content', color)
|
43
|
+
}
|
44
|
+
|
45
|
+
// 记忆日夜模式切换和系统亮暗模式监听
|
46
|
+
export const themeColorListener = () => {
|
47
|
+
window.matchMedia('(prefers-color-scheme: dark)').addEventListener('change', (mediaQueryList) => {
|
48
|
+
if (mediaQueryList.matches) {
|
49
|
+
changeTheme('dark')
|
50
|
+
} else {
|
51
|
+
changeTheme()
|
52
|
+
}
|
53
|
+
})
|
54
|
+
|
55
|
+
const t = $storage.get('theme')
|
56
|
+
if (t) {
|
57
|
+
changeTheme(t)
|
58
|
+
} else {
|
59
|
+
if (CONFIG.darkmode) {
|
60
|
+
changeTheme('dark')
|
61
|
+
}
|
62
|
+
}
|
63
|
+
}
|
@@ -1,63 +1,63 @@
|
|
1
|
-
// 与第三方js的交互或第三方嵌入js
|
2
|
-
|
3
|
-
import { CONFIG, loadCat } from './globalVars'
|
4
|
-
import { transition } from '../library/anime'
|
5
|
-
|
6
|
-
// 加载动画
|
7
|
-
export const Loader = {
|
8
|
-
timer: undefined,
|
9
|
-
lock: false,
|
10
|
-
show () {
|
11
|
-
clearTimeout(this.timer)
|
12
|
-
document.body.removeClass('loaded')
|
13
|
-
loadCat.setAttribute('style', 'display:block')
|
14
|
-
Loader.lock = false
|
15
|
-
},
|
16
|
-
hide (sec?: number) {
|
17
|
-
if (!CONFIG.loader.start) {
|
18
|
-
sec = -1
|
19
|
-
}
|
20
|
-
this.timer = setTimeout(this.vanish, sec || 3000)
|
21
|
-
},
|
22
|
-
vanish (): void {
|
23
|
-
if (Loader.lock) {
|
24
|
-
return
|
25
|
-
}
|
26
|
-
if (CONFIG.loader.start) {
|
27
|
-
transition(loadCat, 0)
|
28
|
-
}
|
29
|
-
document.body.addClass('loaded')
|
30
|
-
Loader.lock = true
|
31
|
-
}
|
32
|
-
}
|
33
|
-
|
34
|
-
export const isOutime = (): void => {
|
35
|
-
let updateTime: Date
|
36
|
-
const times = document.getElementsByTagName('time')
|
37
|
-
if (times.length === 0) {
|
38
|
-
return
|
39
|
-
}
|
40
|
-
const posts = document.getElementsByClassName('body md')
|
41
|
-
if (posts.length === 0) {
|
42
|
-
return
|
43
|
-
}
|
44
|
-
|
45
|
-
const now = Date.now() // 当前时间戳
|
46
|
-
const pubTime = new Date(times[0].dateTime) // 文章发布时间戳
|
47
|
-
if (times.length === 1) {
|
48
|
-
updateTime = pubTime // 文章发布时间亦是最后更新时间
|
49
|
-
} else {
|
50
|
-
updateTime = new Date(times[1].dateTime) // 文章最后更新时间戳
|
51
|
-
}
|
52
|
-
// @ts-ignore
|
53
|
-
const interval = parseInt(String(now - updateTime)) // 时间差
|
54
|
-
const days = parseInt(String(CONFIG.outime.days)) || 30 // 设置时效,默认硬编码 30 天
|
55
|
-
// 最后一次更新时间超过 days 天(毫秒)
|
56
|
-
if (interval > (days * 86400000)) {
|
57
|
-
// @ts-ignore
|
58
|
-
const publish = parseInt(String((now - pubTime) / 86400000))
|
59
|
-
const updated = parseInt(String(interval / 86400000))
|
60
|
-
const template = LOCAL.template.replace('{{publish}}', String(publish)).replace('{{updated}}', String(updated))
|
61
|
-
posts[0].insertAdjacentHTML('afterbegin', template)
|
62
|
-
}
|
63
|
-
}
|
1
|
+
// 与第三方js的交互或第三方嵌入js
|
2
|
+
|
3
|
+
import { CONFIG, loadCat } from './globalVars'
|
4
|
+
import { transition } from '../library/anime'
|
5
|
+
|
6
|
+
// 加载动画
|
7
|
+
export const Loader = {
|
8
|
+
timer: undefined,
|
9
|
+
lock: false,
|
10
|
+
show () {
|
11
|
+
clearTimeout(this.timer)
|
12
|
+
document.body.removeClass('loaded')
|
13
|
+
loadCat.setAttribute('style', 'display:block')
|
14
|
+
Loader.lock = false
|
15
|
+
},
|
16
|
+
hide (sec?: number) {
|
17
|
+
if (!CONFIG.loader.start) {
|
18
|
+
sec = -1
|
19
|
+
}
|
20
|
+
this.timer = setTimeout(this.vanish, sec || 3000)
|
21
|
+
},
|
22
|
+
vanish (): void {
|
23
|
+
if (Loader.lock) {
|
24
|
+
return
|
25
|
+
}
|
26
|
+
if (CONFIG.loader.start) {
|
27
|
+
transition(loadCat, 0)
|
28
|
+
}
|
29
|
+
document.body.addClass('loaded')
|
30
|
+
Loader.lock = true
|
31
|
+
}
|
32
|
+
}
|
33
|
+
|
34
|
+
export const isOutime = (): void => {
|
35
|
+
let updateTime: Date
|
36
|
+
const times = document.getElementsByTagName('time')
|
37
|
+
if (times.length === 0) {
|
38
|
+
return
|
39
|
+
}
|
40
|
+
const posts = document.getElementsByClassName('body md')
|
41
|
+
if (posts.length === 0) {
|
42
|
+
return
|
43
|
+
}
|
44
|
+
|
45
|
+
const now = Date.now() // 当前时间戳
|
46
|
+
const pubTime = new Date(times[0].dateTime) // 文章发布时间戳
|
47
|
+
if (times.length === 1) {
|
48
|
+
updateTime = pubTime // 文章发布时间亦是最后更新时间
|
49
|
+
} else {
|
50
|
+
updateTime = new Date(times[1].dateTime) // 文章最后更新时间戳
|
51
|
+
}
|
52
|
+
// @ts-ignore
|
53
|
+
const interval = parseInt(String(now - updateTime)) // 时间差
|
54
|
+
const days = parseInt(String(CONFIG.outime.days)) || 30 // 设置时效,默认硬编码 30 天
|
55
|
+
// 最后一次更新时间超过 days 天(毫秒)
|
56
|
+
if (interval > (days * 86400000)) {
|
57
|
+
// @ts-ignore
|
58
|
+
const publish = parseInt(String((now - pubTime) / 86400000))
|
59
|
+
const updated = parseInt(String(interval / 86400000))
|
60
|
+
const template = LOCAL.template.replace('{{publish}}', String(publish)).replace('{{updated}}', String(updated))
|
61
|
+
posts[0].insertAdjacentHTML('afterbegin', template)
|
62
|
+
}
|
63
|
+
}
|
@@ -1,75 +1,75 @@
|
|
1
|
-
import { pageScroll } from '../library/anime'
|
2
|
-
import { $dom } from '../library/dom'
|
3
|
-
import { $storage } from '../library/storage'
|
4
|
-
import { BODY, CONFIG, LOCAL_HASH, LOCAL_URL, scrollAction, setLocalHash } from './globalVars'
|
5
|
-
import { createChild } from '../library/proto'
|
6
|
-
|
7
|
-
// 显示提示(现阶段用于版权及复制结果提示)
|
8
|
-
export const showtip = (msg: string): void | never => {
|
9
|
-
if (!msg) {
|
10
|
-
return
|
11
|
-
}
|
12
|
-
|
13
|
-
const tipbox = createChild(BODY, 'div', {
|
14
|
-
innerHTML: msg,
|
15
|
-
className: 'tip'
|
16
|
-
})
|
17
|
-
|
18
|
-
setTimeout(() => {
|
19
|
-
tipbox.addClass('hide')
|
20
|
-
setTimeout(() => {
|
21
|
-
BODY.removeChild(tipbox)
|
22
|
-
}, 300)
|
23
|
-
}, 3000)
|
24
|
-
}
|
25
|
-
|
26
|
-
export const pagePosition = () => {
|
27
|
-
// 判断配置项是否开启了自动记录滚动位置
|
28
|
-
if (CONFIG.auto_scroll) {
|
29
|
-
// 将当前页面的滚动位置存入本地缓存
|
30
|
-
$storage.set(LOCAL_URL, String(scrollAction.y))
|
31
|
-
}
|
32
|
-
}
|
33
|
-
|
34
|
-
export const positionInit = (comment?: boolean) => {
|
35
|
-
// 获取页面锚点
|
36
|
-
const anchor = window.location.hash
|
37
|
-
|
38
|
-
let target = null
|
39
|
-
if (LOCAL_HASH) {
|
40
|
-
$storage.del(LOCAL_URL)
|
41
|
-
return
|
42
|
-
}
|
43
|
-
|
44
|
-
if (anchor) {
|
45
|
-
target = document.querySelector(decodeURI(anchor))
|
46
|
-
} else {
|
47
|
-
target = CONFIG.auto_scroll ? parseInt($storage.get(LOCAL_URL)) : 0
|
48
|
-
}
|
49
|
-
|
50
|
-
if (target) {
|
51
|
-
pageScroll(target)
|
52
|
-
setLocalHash(1)
|
53
|
-
}
|
54
|
-
|
55
|
-
if (comment && anchor && !LOCAL_HASH) {
|
56
|
-
pageScroll(target)
|
57
|
-
setLocalHash(1)
|
58
|
-
}
|
59
|
-
}
|
60
|
-
|
61
|
-
/*
|
62
|
-
基于clipboard API的复制功能,仅在https环境下有效
|
63
|
-
*/
|
64
|
-
export const clipBoard = (str: string, callback?: (result:boolean) => void) => {
|
65
|
-
if (navigator.clipboard && window.isSecureContext) {
|
66
|
-
navigator.clipboard.writeText(str).then(() => {
|
67
|
-
callback && callback(true)
|
68
|
-
}, () => {
|
69
|
-
callback && callback(false)
|
70
|
-
})
|
71
|
-
} else {
|
72
|
-
console.error('Too old browser, clipborad API not supported.')
|
73
|
-
callback && callback(false)
|
74
|
-
}
|
75
|
-
}
|
1
|
+
import { pageScroll } from '../library/anime'
|
2
|
+
import { $dom } from '../library/dom'
|
3
|
+
import { $storage } from '../library/storage'
|
4
|
+
import { BODY, CONFIG, LOCAL_HASH, LOCAL_URL, scrollAction, setLocalHash } from './globalVars'
|
5
|
+
import { createChild } from '../library/proto'
|
6
|
+
|
7
|
+
// 显示提示(现阶段用于版权及复制结果提示)
|
8
|
+
export const showtip = (msg: string): void | never => {
|
9
|
+
if (!msg) {
|
10
|
+
return
|
11
|
+
}
|
12
|
+
|
13
|
+
const tipbox = createChild(BODY, 'div', {
|
14
|
+
innerHTML: msg,
|
15
|
+
className: 'tip'
|
16
|
+
})
|
17
|
+
|
18
|
+
setTimeout(() => {
|
19
|
+
tipbox.addClass('hide')
|
20
|
+
setTimeout(() => {
|
21
|
+
BODY.removeChild(tipbox)
|
22
|
+
}, 300)
|
23
|
+
}, 3000)
|
24
|
+
}
|
25
|
+
|
26
|
+
export const pagePosition = () => {
|
27
|
+
// 判断配置项是否开启了自动记录滚动位置
|
28
|
+
if (CONFIG.auto_scroll) {
|
29
|
+
// 将当前页面的滚动位置存入本地缓存
|
30
|
+
$storage.set(LOCAL_URL, String(scrollAction.y))
|
31
|
+
}
|
32
|
+
}
|
33
|
+
|
34
|
+
export const positionInit = (comment?: boolean) => {
|
35
|
+
// 获取页面锚点
|
36
|
+
const anchor = window.location.hash
|
37
|
+
|
38
|
+
let target = null
|
39
|
+
if (LOCAL_HASH) {
|
40
|
+
$storage.del(LOCAL_URL)
|
41
|
+
return
|
42
|
+
}
|
43
|
+
|
44
|
+
if (anchor) {
|
45
|
+
target = document.querySelector(decodeURI(anchor))
|
46
|
+
} else {
|
47
|
+
target = CONFIG.auto_scroll ? parseInt($storage.get(LOCAL_URL)) : 0
|
48
|
+
}
|
49
|
+
|
50
|
+
if (target) {
|
51
|
+
pageScroll(target)
|
52
|
+
setLocalHash(1)
|
53
|
+
}
|
54
|
+
|
55
|
+
if (comment && anchor && !LOCAL_HASH) {
|
56
|
+
pageScroll(target)
|
57
|
+
setLocalHash(1)
|
58
|
+
}
|
59
|
+
}
|
60
|
+
|
61
|
+
/*
|
62
|
+
基于clipboard API的复制功能,仅在https环境下有效
|
63
|
+
*/
|
64
|
+
export const clipBoard = (str: string, callback?: (result:boolean) => void) => {
|
65
|
+
if (navigator.clipboard && window.isSecureContext) {
|
66
|
+
navigator.clipboard.writeText(str).then(() => {
|
67
|
+
callback && callback(true)
|
68
|
+
}, () => {
|
69
|
+
callback && callback(false)
|
70
|
+
})
|
71
|
+
} else {
|
72
|
+
console.error('Too old browser, clipborad API not supported.')
|
73
|
+
callback && callback(false)
|
74
|
+
}
|
75
|
+
}
|
@@ -1,110 +1,110 @@
|
|
1
|
-
import anime from 'theme-shokax-anime'
|
2
|
-
import { siteNavHeight } from '../globals/globalVars'
|
3
|
-
import type { AnimeOptions } from 'theme-shokax-anime/dist/types'
|
4
|
-
import {getTop, setDisplay} from './proto'
|
5
|
-
|
6
|
-
/**
|
7
|
-
* 参数 动画效果
|
8
|
-
* 0 元素逐渐消失
|
9
|
-
* 1 元素逐渐出现
|
10
|
-
* bounceUpIn 元素从下方弹跳出现
|
11
|
-
* shrinkIn 元素从放大到正常大小出现
|
12
|
-
* slideRightIn 元素从右侧滑入
|
13
|
-
* slideRightOut 元素向右侧滑出
|
14
|
-
* TODO 函数功能过于复杂,需要拆分
|
15
|
-
*/
|
16
|
-
export const transition = (target: HTMLElement, type: number|string|Function, complete?: Function, begin?: Function): void => {
|
17
|
-
let animation:Partial<AnimeOptions>
|
18
|
-
let display = 'none'
|
19
|
-
switch (type) {
|
20
|
-
case 0:
|
21
|
-
animation = { opacity: [1, 0] }
|
22
|
-
break
|
23
|
-
case 1:
|
24
|
-
animation = { opacity: [0, 1] }
|
25
|
-
display = 'block'
|
26
|
-
break
|
27
|
-
case 'bounceUpIn':
|
28
|
-
animation = {
|
29
|
-
begin (anim) {
|
30
|
-
setDisplay(target, 'block')
|
31
|
-
},
|
32
|
-
translateY: [
|
33
|
-
{ value: -60, duration: 200 },
|
34
|
-
{ value: 10, duration: 200 },
|
35
|
-
{ value: -5, duration: 200 },
|
36
|
-
{ value: 0, duration: 200 }
|
37
|
-
],
|
38
|
-
opacity: [0, 1]
|
39
|
-
}
|
40
|
-
display = 'block'
|
41
|
-
break
|
42
|
-
case 'shrinkIn':
|
43
|
-
animation = {
|
44
|
-
begin (anim) {
|
45
|
-
setDisplay(target, 'block')
|
46
|
-
},
|
47
|
-
scale: [
|
48
|
-
{ value: 1.1, duration: 300 },
|
49
|
-
{ value: 1, duration: 200 }
|
50
|
-
],
|
51
|
-
opacity: 1
|
52
|
-
}
|
53
|
-
display = 'block'
|
54
|
-
break
|
55
|
-
case 'slideRightIn':
|
56
|
-
animation = {
|
57
|
-
begin (anim) {
|
58
|
-
setDisplay(target, 'block')
|
59
|
-
},
|
60
|
-
translateX: ['100%', '0%'],
|
61
|
-
opacity: [0, 1]
|
62
|
-
}
|
63
|
-
display = 'block'
|
64
|
-
break
|
65
|
-
case 'slideRightOut':
|
66
|
-
animation = {
|
67
|
-
translateX: ['0%', '100%'],
|
68
|
-
opacity: [1, 0]
|
69
|
-
}
|
70
|
-
break
|
71
|
-
default:
|
72
|
-
// @ts-ignore
|
73
|
-
animation = type
|
74
|
-
// @ts-ignore
|
75
|
-
display = type.display
|
76
|
-
break
|
77
|
-
}
|
78
|
-
anime(Object.assign({
|
79
|
-
targets: target,
|
80
|
-
duration: 200,
|
81
|
-
easing: 'linear',
|
82
|
-
begin () {
|
83
|
-
begin && begin()
|
84
|
-
},
|
85
|
-
complete () {
|
86
|
-
setDisplay(target, display)
|
87
|
-
complete && complete()
|
88
|
-
}
|
89
|
-
}, animation)).play()
|
90
|
-
}
|
91
|
-
|
92
|
-
export const pageScroll = (target: HTMLElement|number, offset?: number, complete?: Function) => {
|
93
|
-
// target: 滚动到的目标元素或坐标(number)
|
94
|
-
// offset: 可选的偏移量
|
95
|
-
// complete: 可选的回调函数,在动画完成时调用
|
96
|
-
anime({
|
97
|
-
// 动画目标
|
98
|
-
targets: typeof offset === 'number' && typeof target !== 'number' ? target.parentNode : document.scrollingElement,
|
99
|
-
// 动画持续时间
|
100
|
-
duration: 500,
|
101
|
-
// 动画缓动函数
|
102
|
-
easing: 'easeInOutQuad',
|
103
|
-
// 如果 offset 存在,则滚动到 offset,如果 target 是数字,则滚动到 target,如果 target 是 DOM 元素,则滚动到下述表达式
|
104
|
-
scrollTop: offset || (typeof target === 'number' ? target : (target ? getTop(target) + document.documentElement.scrollTop - siteNavHeight : 0)),
|
105
|
-
// 完成回调函数
|
106
|
-
complete () {
|
107
|
-
complete && complete()
|
108
|
-
}
|
109
|
-
}).play()
|
110
|
-
}
|
1
|
+
import anime from 'theme-shokax-anime'
|
2
|
+
import { siteNavHeight } from '../globals/globalVars'
|
3
|
+
import type { AnimeOptions } from 'theme-shokax-anime/dist/types'
|
4
|
+
import {getTop, setDisplay} from './proto'
|
5
|
+
|
6
|
+
/**
|
7
|
+
* 参数 动画效果
|
8
|
+
* 0 元素逐渐消失
|
9
|
+
* 1 元素逐渐出现
|
10
|
+
* bounceUpIn 元素从下方弹跳出现
|
11
|
+
* shrinkIn 元素从放大到正常大小出现
|
12
|
+
* slideRightIn 元素从右侧滑入
|
13
|
+
* slideRightOut 元素向右侧滑出
|
14
|
+
* TODO 函数功能过于复杂,需要拆分
|
15
|
+
*/
|
16
|
+
export const transition = (target: HTMLElement, type: number|string|Function, complete?: Function, begin?: Function): void => {
|
17
|
+
let animation:Partial<AnimeOptions>
|
18
|
+
let display = 'none'
|
19
|
+
switch (type) {
|
20
|
+
case 0:
|
21
|
+
animation = { opacity: [1, 0] }
|
22
|
+
break
|
23
|
+
case 1:
|
24
|
+
animation = { opacity: [0, 1] }
|
25
|
+
display = 'block'
|
26
|
+
break
|
27
|
+
case 'bounceUpIn':
|
28
|
+
animation = {
|
29
|
+
begin (anim) {
|
30
|
+
setDisplay(target, 'block')
|
31
|
+
},
|
32
|
+
translateY: [
|
33
|
+
{ value: -60, duration: 200 },
|
34
|
+
{ value: 10, duration: 200 },
|
35
|
+
{ value: -5, duration: 200 },
|
36
|
+
{ value: 0, duration: 200 }
|
37
|
+
],
|
38
|
+
opacity: [0, 1]
|
39
|
+
}
|
40
|
+
display = 'block'
|
41
|
+
break
|
42
|
+
case 'shrinkIn':
|
43
|
+
animation = {
|
44
|
+
begin (anim) {
|
45
|
+
setDisplay(target, 'block')
|
46
|
+
},
|
47
|
+
scale: [
|
48
|
+
{ value: 1.1, duration: 300 },
|
49
|
+
{ value: 1, duration: 200 }
|
50
|
+
],
|
51
|
+
opacity: 1
|
52
|
+
}
|
53
|
+
display = 'block'
|
54
|
+
break
|
55
|
+
case 'slideRightIn':
|
56
|
+
animation = {
|
57
|
+
begin (anim) {
|
58
|
+
setDisplay(target, 'block')
|
59
|
+
},
|
60
|
+
translateX: ['100%', '0%'],
|
61
|
+
opacity: [0, 1]
|
62
|
+
}
|
63
|
+
display = 'block'
|
64
|
+
break
|
65
|
+
case 'slideRightOut':
|
66
|
+
animation = {
|
67
|
+
translateX: ['0%', '100%'],
|
68
|
+
opacity: [1, 0]
|
69
|
+
}
|
70
|
+
break
|
71
|
+
default:
|
72
|
+
// @ts-ignore
|
73
|
+
animation = type
|
74
|
+
// @ts-ignore
|
75
|
+
display = type.display
|
76
|
+
break
|
77
|
+
}
|
78
|
+
anime(Object.assign({
|
79
|
+
targets: target,
|
80
|
+
duration: 200,
|
81
|
+
easing: 'linear',
|
82
|
+
begin () {
|
83
|
+
begin && begin()
|
84
|
+
},
|
85
|
+
complete () {
|
86
|
+
setDisplay(target, display)
|
87
|
+
complete && complete()
|
88
|
+
}
|
89
|
+
}, animation)).play()
|
90
|
+
}
|
91
|
+
|
92
|
+
export const pageScroll = (target: HTMLElement|number, offset?: number, complete?: Function) => {
|
93
|
+
// target: 滚动到的目标元素或坐标(number)
|
94
|
+
// offset: 可选的偏移量
|
95
|
+
// complete: 可选的回调函数,在动画完成时调用
|
96
|
+
anime({
|
97
|
+
// 动画目标
|
98
|
+
targets: typeof offset === 'number' && typeof target !== 'number' ? target.parentNode : document.scrollingElement,
|
99
|
+
// 动画持续时间
|
100
|
+
duration: 500,
|
101
|
+
// 动画缓动函数
|
102
|
+
easing: 'easeInOutQuad',
|
103
|
+
// 如果 offset 存在,则滚动到 offset,如果 target 是数字,则滚动到 target,如果 target 是 DOM 元素,则滚动到下述表达式
|
104
|
+
scrollTop: offset || (typeof target === 'number' ? target : (target ? getTop(target) + document.documentElement.scrollTop - siteNavHeight : 0)),
|
105
|
+
// 完成回调函数
|
106
|
+
complete () {
|
107
|
+
complete && complete()
|
108
|
+
}
|
109
|
+
}).play()
|
110
|
+
}
|