Compare commits

...

356 Commits
v1.0 ... master

Author SHA1 Message Date
aleks
203268ef54 update
All checks were successful
continuous-integration/drone/push Build is passing
2024-01-25 16:54:32 +03:00
alleks
465a1f871b add yandex metrica
Some checks failed
continuous-integration/drone/push Build is failing
2023-05-29 16:37:13 +03:00
alleks
0b55074b50 del qrcode
All checks were successful
continuous-integration/drone/push Build is passing
2023-03-19 22:00:21 +03:00
alleks
6a7213ccfb del qrcode
All checks were successful
continuous-integration/drone/push Build is passing
2023-03-19 21:52:23 +03:00
alleks
d6596af54c add tizer add
All checks were successful
continuous-integration/drone/push Build is passing
2023-03-19 21:42:27 +03:00
alleks
6e45d27f95 add tizer add
All checks were successful
continuous-integration/drone/push Build is passing
2023-03-19 21:23:54 +03:00
alleks
9421e614f8 add yandex metrika
All checks were successful
continuous-integration/drone/push Build is passing
2023-03-19 19:52:11 +03:00
alleks
adccb1fb64 update
All checks were successful
continuous-integration/drone/push Build is passing
2023-03-19 19:16:50 +03:00
alleks
d774e4868d update
All checks were successful
continuous-integration/drone/push Build is passing
2023-03-19 19:10:23 +03:00
alleks
b3280e8d81 update
Some checks failed
continuous-integration/drone/push Build is failing
2023-03-19 19:07:30 +03:00
alleks
c2f6f674b0 update
Some checks failed
continuous-integration/drone/push Build is failing
2023-03-19 18:53:58 +03:00
alleks
d67e7b66e4 update
Some checks failed
continuous-integration/drone/push Build is failing
2023-03-19 18:07:20 +03:00
alleks
daa9eafe47 github
All checks were successful
continuous-integration/drone/push Build is passing
2023-01-23 02:24:55 +03:00
alleks
be3c627b53 гзвфеу
All checks were successful
continuous-integration/drone/push Build is passing
2023-01-23 02:15:48 +03:00
alleks
bf50fa3cbf github
All checks were successful
continuous-integration/drone/push Build is passing
2023-01-23 02:10:24 +03:00
alleks
47c68fbcf6 github
All checks were successful
continuous-integration/drone/push Build is passing
2023-01-23 02:07:53 +03:00
alleks
7df5fb3bbc edit gitignore
All checks were successful
continuous-integration/drone/push Build is passing
2023-01-23 02:01:00 +03:00
alleks
7875f1f10b edit gitignore
All checks were successful
continuous-integration/drone/push Build is passing
2023-01-23 02:00:38 +03:00
alleks
0f2ce49711 edit config
All checks were successful
continuous-integration/drone/push Build is passing
2023-01-23 01:48:10 +03:00
alleks
62bbf2ea84 edit config
All checks were successful
continuous-integration/drone/push Build is passing
2023-01-23 01:32:28 +03:00
alleks
73d1541964 add drone files
All checks were successful
continuous-integration/drone/push Build is passing
2023-01-23 01:21:37 +03:00
alleks
3f62a1d379 add drone files
All checks were successful
continuous-integration/drone/push Build is passing
2023-01-23 01:13:59 +03:00
alleks
65660e28ff add drone files
Some checks reported errors
continuous-integration/drone/push Build encountered an error
2023-01-23 01:12:46 +03:00
alleks
f16f3f3b67 add drone files
All checks were successful
continuous-integration/drone/push Build is passing
2023-01-23 00:58:23 +03:00
alleks
d5967b9b27 add drone files
All checks were successful
continuous-integration/drone/push Build is passing
2023-01-23 00:52:21 +03:00
alleks
3c4e20c278 add drone files
All checks were successful
continuous-integration/drone/push Build is passing
2023-01-23 00:31:21 +03:00
alleks
9f8cdc1e08 add drone files
Some checks failed
continuous-integration/drone/push Build is failing
2023-01-23 00:27:54 +03:00
alleks
f741f71d48 add drone files
Some checks failed
continuous-integration/drone/push Build is failing
2023-01-23 00:26:11 +03:00
alleks
5f67e530ca add drone files
Some checks failed
continuous-integration/drone/push Build is failing
2023-01-23 00:24:36 +03:00
alleks
ae0dc7c60e add drone files
Some checks failed
continuous-integration/drone/push Build is failing
2023-01-23 00:20:17 +03:00
alleks
1480ba764a add drone files
Some checks failed
continuous-integration/drone/push Build is failing
2023-01-23 00:17:45 +03:00
alleks
0d50488be9 add drone files
Some checks failed
continuous-integration/drone Build is failing
2023-01-23 00:15:25 +03:00
aleks
5367cb98aa update 2023-01-20 19:31:12 +03:00
aleks
4180e196a7 update 2023-01-20 19:07:42 +03:00
Eric Shen
aa8f962b96
Merge pull request #161 from MHG-LAB/master
remove: mv
2022-09-03 14:12:42 +08:00
MHuiG
f5c57c26a4
remove: mv 2022-08-21 15:46:57 +08:00
Eric Shen
4c6353ef4f
Merge pull request #157 from shrimp509/fix-google-analytics
fix: update google analytics
2022-05-27 22:47:34 +08:00
UncleSam
ac48e4b5d7 fix: update google analytics 2022-05-23 16:36:09 +08:00
shenyu
f3932d682c 1.9.7-0 2022-02-24 17:18:36 +08:00
shenyu
07f3f29b6a 2022-02-24 17:13:48 +08:00
shenyu
47c56cc364 1.9.6 2022-02-24 11:27:13 +08:00
shenyu
bf2f718d73 Merge branch 'master' of github.com:Shen-Yu/hexo-theme-ayer 2022-02-24 11:21:56 +08:00
shenyu
550ab8a68d ️ update CDN 2022-02-24 11:21:40 +08:00
Eric Shen
15b16e79ce
Update README.md 2022-02-23 17:45:58 +08:00
Eric Shen
84bca19471
Merge pull request #151 from eigeen/fix-new-miit-url
fix: new miit url
2022-01-07 18:14:23 +08:00
Eigeen
313752c594 fix: new miit url 2022-01-06 14:38:12 +08:00
shenyu
7ef6c7c618 📝 2021-08-13 10:43:37 +08:00
shenyu
31b38391de 1.9.5 2021-08-03 17:01:15 +08:00
shenyu
9c53a603f3 1.9.5-0 2021-08-03 17:01:02 +08:00
shenyu
a9db32d0cb 🐛 fix: blank space on firefox 2021-08-03 16:59:39 +08:00
shenyu
3ff73f9805 1.9.4-0 2021-07-29 14:26:46 +08:00
shenyu
5969d1a456 1.9.3 2021-07-23 13:46:11 +08:00
shenyu
219bb6db37 🎨 style: code format 2021-07-23 13:45:50 +08:00
shenyu
e0f4461fe5 🗑️ remove jquery-2.0.3.min.js 2021-07-23 13:28:34 +08:00
shenyu
20332ad8f2 ⬆️ chore: upgrade jquery 2021-07-23 13:26:32 +08:00
shenyu
8229b7436f 1.9.2 2021-07-23 11:49:13 +08:00
shenyu
c24db5e371 feat: Encrypt 2021-07-23 11:47:30 +08:00
shenyu
8b6074fef4 1.9.2-0 2021-07-01 10:17:43 +08:00
shenyu
3d4a4fcc7e 💄 add image caption 2021-07-01 10:14:42 +08:00
shenyu
a842da9697 1.9.1 2021-06-28 14:36:44 +08:00
shenyu
72c4fd9761 💄 fix: toc style 2021-06-28 14:27:23 +08:00
shenyu
f1c3083f09 🔧 2021-06-21 17:11:35 +08:00
shenyu
a29108efdc 1.9.0 2021-06-08 09:41:00 +08:00
shenyu
c679fd6256 📝 docs 2021-05-31 10:24:23 +08:00
shenyu
49dfb78503 📝 update 2021-05-30 11:08:08 +08:00
shenyu
809d54eae2 1.8.24 2021-05-29 10:58:17 +08:00
shenyu
e76f208516 ️ bundle assets by rollup 2021-05-29 10:57:34 +08:00
shenyu
aad79d1baa ✏️ README.md 2021-05-24 11:45:14 +08:00
shenyu
221c637409 Merge branch 'master' of https://github.com/Shen-Yu/hexo-theme-ayer 2021-05-24 11:29:54 +08:00
shenyu
5a4edd6483 1.8.23 2021-05-24 11:29:16 +08:00
shenyu
0163b6bfe5 🛠️ hexo scripts 2021-05-24 11:28:56 +08:00
Eric Shen
3fa2e339c5
Update README.md 2021-05-18 10:19:02 +08:00
shenyu
1c857a0c5f 1.8.22 2021-05-15 12:48:41 +08:00
shenyu
302c6080fd 🐛 fix: float btns 2021-05-15 12:48:29 +08:00
shenyu
ec47bd254a Merge branch 'master' of https://github.com/Shen-Yu/hexo-theme-ayer 2021-04-28 10:37:59 +08:00
shenyu
42a6eb0c33 1.8.21 2021-04-28 10:37:27 +08:00
shenyu
0c0ea3312c 💄 fix: sidebar overflow scroll 2021-04-28 10:37:17 +08:00
Eric Shen
1e0275d757
Merge pull request #116 from MHG-LAB/master
minivaline v6
2021-04-26 14:23:49 +08:00
MHuiG
c5f8d5d058
minivaline v6 dark 2021-04-19 18:54:39 +08:00
MHuiG
38e99de4fb
minivaline v6 2021-04-19 18:43:10 +08:00
shenyu
24be666717 🙈 update: ignore 2021-04-14 11:52:50 +08:00
shenyu
4991ad5085 1.8.20 2021-04-14 11:26:24 +08:00
shenyu
ed96a4ac21 feat: mermaid 2021-04-14 11:26:09 +08:00
shenyu
c61cbb4803 1.8.19 2021-04-14 10:40:23 +08:00
Eric Shen
2e7b792039
Merge pull request #114 from Kiprey/master
添加 mermaid 支持;提高gitalk版本,修复 busuanzi引用span错误
2021-04-14 10:38:14 +08:00
Kiprey
76096640f4 添加 mermaid 支持,提高gitalk版本,修复 busuanzi引用span错误 2021-04-14 09:38:10 +08:00
shenyu
343b1435c1 1.8.18 2021-04-09 13:58:21 +08:00
shenyu
6270c15b76 fix: sidebar 2021-04-09 13:57:44 +08:00
shenyu
1292dbff48 💄 rebuild 2021-04-09 11:06:37 +08:00
Eric Shen
651ccc266c
Merge pull request #113 from wangwei1237/master
在文章title下方为每篇文章增加作者信息
2021-04-09 10:57:18 +08:00
Wang Wei
61ddfbf724 在文章title下方为每篇文章增加作者信息 2021-04-08 19:55:08 +08:00
Wang Wei
826a654766 在文章title下方为每篇文章增加作者信息 2021-04-08 19:36:55 +08:00
shenyu
6a407dc892 update: 404 page 2021-04-02 10:56:36 +08:00
shenyu
cb4eba81c7 1.8.17 2021-04-02 10:33:11 +08:00
shenyu
24a5b177ac 📦 update: parcel-bundler & remove: parcel-plugin-bundle-visualiser 2021-04-02 10:32:00 +08:00
shenyu
49cf370803 📈 update: track 2021-04-02 10:29:31 +08:00
shenyu
4dc27165b9 1.8.16 2021-04-01 09:50:21 +08:00
shenyu
77caffdbfa 👥 update: README.md 2021-03-30 11:37:38 +08:00
shenyu
9767e1fa3f 📝 README.md 2021-03-29 15:12:09 +08:00
shenyu
83572e499b ❤️ update: FUNDING.yml 2021-03-23 15:16:29 +08:00
shenyu
ea8711e0ca 🌐 fix: languages 2021-03-22 10:06:27 +08:00
shenyu
5fc9da7249 1.8.15 2021-03-11 15:05:32 +08:00
shenyu
b7c3ce4f21 update test 2021-03-11 14:48:59 +08:00
shenyu
7af6fda960 1.8.14 2021-03-11 14:12:50 +08:00
shenyu
501ce9a842 🐛 fix: share 2021-03-11 14:12:21 +08:00
沈宇
8de56d6a6e 1.8.13 2021-01-26 11:24:10 +08:00
沈宇
acb071831b 🚑 fix: head.ejs 2021-01-26 11:23:30 +08:00
沈宇
cd0825d52a 1.8.12 2021-01-24 12:28:36 +08:00
沈宇
5fec2eb442 chore: sponsor.jpg 2021-01-24 12:26:13 +08:00
沈宇
8e8f682098 chore: sponsor 2021-01-20 10:58:24 +08:00
沈宇
0753bb9bf3 1.8.11 2021-01-04 10:47:25 +08:00
沈宇
8066ea8b5b 📝 chore: advertisement 2021-01-04 10:46:42 +08:00
沈宇
85fe5c123e 1.8.10 2020-12-31 16:11:53 +08:00
沈宇
f6be671638 1.8.9 2020-12-31 16:11:41 +08:00
沈宇
240304719d feat: advertisement 2020-12-31 16:10:38 +08:00
Eric Shen
bb87ce34fc
Merge pull request #100 from MHG-LAB/master
mv dark
2020-12-27 10:48:26 +08:00
MHuiG
777fc5af56
mv dark 2020-12-25 14:56:42 +08:00
Eric Shen
c585654582
Merge pull request #99 from MHG-LAB/master
minivaline v5
2020-12-25 12:25:08 +08:00
MHuiG
948cb65243
minivaline v5 2020-12-25 10:04:38 +08:00
沈宇
106f2494eb feat: twikoo 2020-12-24 13:42:43 +08:00
沈宇
4c72c3521c Merge branch 'master' of https://github.com/Shen-Yu/hexo-theme-ayer 2020-12-24 13:37:09 +08:00
沈宇
2dd7a5408b feat: twikoo 2020-12-24 13:36:44 +08:00
Eric Shen
7b58e4541a
Merge pull request #96 from hankzhangcn/front_matter—comment
Front matter—comment
2020-11-30 10:27:17 +08:00
hankzhangcn
16ce821f1f
📝 docs: README.md 2020-11-27 16:05:49 +08:00
hankzhangcn
8aaa2094c4
📝 docs: README.md 2020-11-27 15:57:01 +08:00
hankzhangcn
567584695c
Update valine.ejs 2020-11-27 15:52:22 +08:00
hankzhangcn
cd6c3c6e28
Update minivaline.ejs 2020-11-27 15:51:40 +08:00
hankzhangcn
def8609767
Update gitalk.ejs 2020-11-27 15:50:58 +08:00
hankzhangcn
af0bc34076
Update minivaline.ejs 2020-11-27 15:36:02 +08:00
沈宇
1c3644ef7b Merge branch 'master' of https://github.com/Shen-Yu/hexo-theme-ayer 2020-11-26 15:58:12 +08:00
hankzhangcn
b1def36445
添加关闭gitalk评论区的front-matter
在文章头添加`comment: false`可以关闭单篇文章的gitalk评论区。
2020-11-26 15:12:08 +08:00
hankzhangcn
47d33f0b13
添加关闭valine评论区的front-matter
在文章头添加`comment: false`可以关闭单篇文章的valine评论区。
2020-11-26 15:09:33 +08:00
Eric Shen
e868170925
🙈 update: gitignore 2020-11-24 17:37:34 +08:00
沈宇
2e497bf1b5 1.8.9-2 2020-11-05 16:17:12 +08:00
沈宇
03607113d3 fix: language 2020-11-05 16:15:53 +08:00
沈宇
a31a403ec9 1.8.9-1 2020-10-26 11:26:49 +08:00
沈宇
7d0130035e 1.8.9-0 2020-10-26 11:24:42 +08:00
沈宇
e95daf0fe7 fix: meta 2020-10-26 11:13:12 +08:00
沈宇
a350cb7098 update 2020-10-21 21:16:51 +08:00
沈宇
0415b2999a 1.8.8-1 2020-10-16 16:55:05 +08:00
沈宇
e24c1c8fde 📝 docs: README.md 2020-10-15 11:23:39 +08:00
沈宇
4460828c6a 📝 docs: README.md 2020-09-30 11:01:24 +08:00
Eric Shen
3932a3d8ef
Merge pull request #87 from bianyukun1213/patch-2
Rename plain-page to plain-page.ejs
2020-09-17 15:09:30 +08:00
边宇琨
1c0b980462
Rename plain-page to plain-page.ejs 2020-09-17 14:52:47 +08:00
Eric Shen
c63f8450e3
🔧 new layout: plain-page. 2020-09-10 18:14:18 +08:00
边宇琨
7548895d03
New layout: plain-page.
Added a new layout to provide a plain look which is similar to built-in pages. It has a “page-type-title” and removes advance functions such as sharing. When switching pages in the sidebar, readers will have a constant experience. To use this layout, add “layout: plain-page” to Front-matter.

添加了一种新的布局“plain-page”以提供类似内置页面(「归档」、「分类」、「标签」、「友链」等)的外观。它使用一个左对齐的标题(page-type-title)并且移除了「分享」这类高级功能。用户在侧边栏切换页面时能得到更连贯的阅读体验。在 Front-matter 中添加“layout: plain-page”来使用这种布局。
2020-09-10 17:38:12 +08:00
沈宇
b1fc783466 Merge branch 'master' of https://github.com/Shen-Yu/hexo-theme-ayer 2020-09-10 15:15:57 +08:00
沈宇
ef684cecba 📝 fix: README.md 2020-09-10 15:15:47 +08:00
Eric Shen
4027d32ce0
Merge pull request #83 from bianyukun1213/patch-2
实现版权声明内容自定义。
2020-09-10 15:13:58 +08:00
边宇琨
736a5d3876
实现版权声明内容自定义。
通过 Front-matter 实现针对特定文章的版权声明内容自定义。  
例如:  
copyright_content: 本文章遵守 CC BY-SA 4.0 协议。
2020-09-10 02:22:51 +08:00
沈宇
b9284527ec 📝 docs: license 2020-09-09 14:07:12 +08:00
沈宇
c48d95fcd9 1.8.8-0 2020-09-09 12:40:10 +08:00
沈宇
ee3908d8aa 💄 fix: darkmode 2020-09-09 12:39:01 +08:00
沈宇
14e0f01357 1.8.7 2020-09-07 18:26:46 +08:00
沈宇
e95cdd5cd8 feat: friends link 2020-09-07 18:26:26 +08:00
沈宇
3bb55b8fcb 1.8.6 2020-09-04 20:01:08 +08:00
沈宇
c18a2e681e 📝 beian 2020-09-04 20:00:13 +08:00
沈宇
7642eba4d6 📝 beian 2020-09-04 19:59:16 +08:00
Eric Shen
4d3776ea3c
Merge pull request #79 from bilikxjh/master
添加公安备案信息显示/Add public security record information display
2020-09-04 19:49:15 +08:00
沈宇
9bb629ee79 1.8.5 2020-09-01 10:47:18 +08:00
沈宇
83b79e97c1 feat: boardcast 2020-09-01 10:47:02 +08:00
kaixin
b04e2838a0 Update _config.yml 2020-08-30 17:08:35 +08:00
kaixin
e3724557a3 尾部添加公安备案
尾部添加公安备案显示,备案链接添加”rel="nofollow"“属性,有利于SEO
2020-08-30 17:07:41 +08:00
shenyu
c775133f5b 1.8.4 2020-08-24 21:30:35 +08:00
shenyu
48a39f4322 📦 homepage 2020-08-24 21:29:28 +08:00
沈宇
b1f929876c 1.8.3 2020-08-24 12:20:06 +08:00
沈宇
8b0ab2c38d 🚀 npm support 2020-08-24 12:20:00 +08:00
沈宇
505f34cd3f 1.8.2 2020-08-24 11:17:18 +08:00
shenyu
7d1f337d59 1.8.1 2020-08-23 22:02:01 +08:00
shenyu
7f495adc00 👷 travis 2020-08-20 22:18:13 +08:00
shenyu
abc77cc06e 🙈 .gitignore 2020-08-20 22:09:00 +08:00
shenyu
944ae944e1 📦 bundle visualiser 2020-08-20 22:05:41 +08:00
shenyu
a19fce2fb0 🔖 badge 2020-08-15 23:42:31 +08:00
shenyu
820e492f53 1.8.0 2020-08-15 23:29:17 +08:00
shenyu
d5a8f7b105 1.7.0 2020-08-15 23:29:10 +08:00
shenyu
a1d6ea6caa 1.6.0 2020-08-15 23:29:05 +08:00
shenyu
c383089978 1.5.0 2020-08-15 23:29:01 +08:00
shenyu
d223d30789 1.4.0 2020-08-15 23:28:55 +08:00
shenyu
0d498784fe 1.3.0 2020-08-15 23:28:51 +08:00
shenyu
80091fa674 1.2.0 2020-08-15 23:28:48 +08:00
shenyu
1b1cacee23 1.1.0 2020-08-15 23:28:42 +08:00
shenyu
ca3fe89197 💄 page nav 2020-08-15 23:08:45 +08:00
shenyu
8217da81ab fix: scroll speed 2020-08-08 21:32:36 +08:00
shenyu
40071e8acc 📝 docs: multi language support 2020-08-04 21:12:32 +08:00
shenyu
bb10282d89 📝 docs: multi language support 2020-08-04 21:04:59 +08:00
shenyu
1384ea58a7 Merge branch 'master' of https://github.com/Shen-Yu/hexo-theme-ayer 2020-08-04 19:20:50 +08:00
shenyu
469943c62b fix 2020-08-04 19:20:40 +08:00
Eric Shen
f0a002fd23
Update package.json 2020-08-04 13:23:38 +08:00
shenyu
3e815c0438 Merge branch 'master' of https://github.com/Shen-Yu/hexo-theme-ayer 2020-07-05 20:52:57 +08:00
shenyu
f05527e92d 💄 fix: article fontsize 2020-07-05 20:52:25 +08:00
Eric Shen
b96c126078
Update README.md 2020-06-30 14:47:30 +08:00
shenyu
141208f47e fix: typed warning 2020-06-28 21:59:40 +08:00
shenyu
eb98909f8b docs: README.md 2020-06-13 07:52:13 +08:00
shenyu
69406768b1 fix 2020-06-13 07:45:38 +08:00
shenyu
45456e4b37 Merge branch 'master' into local
# Conflicts:
#	_config.yml
2020-06-13 07:43:39 +08:00
Eric Shen
2b0ebe976b
Merge pull request #61 from MiniValine/master
MiniValine darkmode
2020-06-07 20:21:19 +08:00
MHuiG
0b41e237e0 darkmode 2020-06-07 16:49:52 +08:00
shen-yu
1f5956994a fix: _config.yml 2020-06-07 10:46:29 +08:00
Eric Shen
2f5c468007
Merge pull request #60 from MiniValine/master
MiniValine2.7.0更新配置
2020-06-07 10:41:53 +08:00
shen-yu
7cb66de22e 👷 fix: issue template 2020-06-07 10:38:04 +08:00
shen-yu
7a0d513a5b 👷 add: issue template & welcome 2020-06-07 10:33:32 +08:00
H
807060dc82
fix 2020-06-07 10:32:59 +08:00
H
c8e83e34cf
Merge branch 'master' into master 2020-06-07 10:30:14 +08:00
MHuiG
dabe749770 MiniValine2.7.0更新配置 2020-06-07 10:25:24 +08:00
MHuiG
9da6ecc35d MiniValine2.7.0更新配置 2020-06-07 10:25:06 +08:00
shen-yu
3ff6f74bff fix: _config.yml 2020-06-07 10:19:54 +08:00
shen-yu
6a925ba53c 📦 update: minivaline 2020-06-07 10:10:49 +08:00
shen-yu
5c501a9db7 📦 update: minivaline 2020-06-07 10:05:53 +08:00
shen-yu
48d03030a8 📦 update: valine 2020-06-07 09:59:30 +08:00
shen-yu
15ffef6fe6 💄 fix: style 2020-06-06 10:44:34 +08:00
shenyu
16a56f6528 Merge branch 'master' into local 2020-06-03 19:43:51 +08:00
shenyu
5119a4c925 branch: local 2020-06-03 19:42:24 +08:00
沈宇
1fe6bd6ca2 📝 docs: katex support 2020-06-03 11:10:59 +08:00
shenyu
319522746e 📝 fix: README.md 2020-06-02 22:11:38 +08:00
shenyu
21f0d86f63 fix: canvas in mobile 2020-06-02 22:05:48 +08:00
shenyu
60c2930d39 fix: _config.yml 2020-06-02 20:49:24 +08:00
shenyu
fb2dbe73a2 🔥 remove: minivaline 2020-06-02 20:48:42 +08:00
shenyu
05af377fa9 📝 update: README.md 2020-06-02 20:45:17 +08:00
shenyu
1609b61336 fix: click effect 2020-06-02 20:41:10 +08:00
沈宇
da27325950 🚀 feat: canvas bg & custom mouse 2020-06-02 16:01:50 +08:00
沈宇
42bd579f19 📝 update: LICENSE 2020-06-02 10:47:32 +08:00
沈宇
ee1211d86b 📝 update: LICENSE 2020-06-02 10:37:55 +08:00
沈宇
f0adf9a62e 🚀 feat: clickBoom2 2020-06-01 18:44:02 +08:00
shenyu
c0ef5fc0ad fix: categories 2020-05-28 23:13:00 +08:00
shenyu
86cd94fc80 🚀 fix: valine 2020-05-27 20:40:52 +08:00
shen-yu
b67d410b86 🚀 update 404.html 2020-05-24 10:30:34 +08:00
shenyu
4711891b4a 🚀 feat: clickBoom 2020-05-23 06:46:58 +08:00
shenyu
9317a2d5d4 🚀 feat: clickBoom 2020-05-23 06:45:12 +08:00
shenyu
de1e586b8c Merge branch 'master' of https://github.com/Shen-Yu/hexo-theme-ayer 2020-05-03 09:53:23 +08:00
shenyu
4f386df7ee 🎨 fix: styles 2020-05-03 09:53:04 +08:00
沈宇
0c7e535867 📝 docs: README 2020-04-28 14:44:39 +08:00
沈宇
7bf0adfd98 🎨 fix: code 2020-04-23 15:04:32 +08:00
沈宇
a0e92eb20c 📝 docs: rss 2020-04-21 14:38:15 +08:00
沈宇
46fc5df869 🎉 release: v2.1 2020-04-21 14:16:21 +08:00
沈宇
29561f6687 💄 fix: markdown style 2020-04-21 14:04:51 +08:00
shenyu
7034f76024 💄 fix: darkmode 2020-04-16 21:53:51 +08:00
shenyu
f21fbe4e2b fix: footer & languages 2020-04-15 22:17:11 +08:00
沈宇
2e211f7609 add: CDN 2020-04-15 18:10:26 +08:00
沈宇
e4218c40fa 🚀 fix: darkmode style && language 2020-04-15 16:30:10 +08:00
shenyu
c0d20c3732 💄 update: 404 style 2020-04-14 20:06:54 +08:00
shenyu
586f38c9ed feat: Copy Code 2020-04-12 21:17:46 +08:00
沈宇
84f7538acd feat: minivaline 2020-04-10 16:27:35 +08:00
沈宇
424ace4186
Merge pull request #40 from MiniValine/master
Feat: A simple and minimalist comment system.
2020-04-10 16:20:53 +08:00
MHuiG
92b24d4a2b fix 2020-04-10 16:06:54 +08:00
沈宇
40c23e99d5 🌐 language support: Vietnamese 2020-04-09 13:09:21 +08:00
沈宇
8cc982d5f5 🌐 language support: nl, no, pt 2020-04-09 11:30:04 +08:00
MH
43738d5335
Merge pull request #1 from MiniValine/imgbot
[ImgBot] Optimize images
2020-04-08 19:27:19 +08:00
MHuiG
c5c22237f0 Feat: A simple and minimalist comment system 2020-04-08 19:26:39 +08:00
ImgBotApp
9974ff6a56
[ImgBot] Optimize images
*Total -- 698.57kb -> 627.95kb (10.11%)

/logo.png -- 3.88kb -> 1.67kb (56.89%)
/source/images/ayer.png -- 3.88kb -> 1.67kb (56.89%)
/source/images/cover7.jpg -- 8.50kb -> 6.10kb (28.26%)
/source/images/alipay.jpg -- 116.75kb -> 88.95kb (23.81%)
/source/images/sponsor.jpg -- 94.75kb -> 80.73kb (14.8%)
/source/images/404.jpg -- 69.11kb -> 63.15kb (8.63%)
/source/images/cover6.jpg -- 141.00kb -> 134.25kb (4.79%)
/screenshots/hexo-theme-ayer.png -- 241.18kb -> 232.42kb (3.63%)
/source/images/ayer-side.svg -- 5.09kb -> 4.94kb (2.9%)
/source/images/ayer.svg -- 5.09kb -> 4.94kb (2.9%)
/source/images/forkme.png -- 9.33kb -> 9.13kb (2.16%)

Signed-off-by: ImgBotApp <ImgBotHelp@gmail.com>
2020-04-08 11:06:15 +00:00
shenyu
4c16804821 🌐 language support: de, es, fr, ru, ja, ko, zh-TW 2020-04-06 15:17:17 +08:00
shenyu
cdf2bceb40 🌐 en support 2020-04-04 14:38:01 +08:00
shenyu
85fbcf5702 🐛 fix: tocboc style 2020-04-01 22:30:45 +08:00
shenyu
9ee2605a49 feat: Katex support 2020-03-30 20:27:17 +08:00
shenyu
b07d7c7ec7 🎉 release: v2.0 2020-03-30 20:01:02 +08:00
shenyu
6557b6a34c feat: clickLove 2020-03-30 19:55:19 +08:00
shenyu
6fbda2ece3 💄 404 style 2020-03-29 22:48:12 +08:00
shenyu
79b014ab4a 🚀 feat: custom layoutWidth 2020-03-29 18:18:22 +08:00
shenyu
b4f1246c53 🚀 fix: sidebar style 2020-03-25 23:41:05 +08:00
沈宇
2a080f157c
Merge pull request #37 from wangwei1237/master
增加生成的网页中的lang根据config.language来定义的特性
2020-03-25 10:59:42 +08:00
Wang Wei
7ba48368df 增加生成的网页中的lang根据config.language来定义的特性 2020-03-25 10:41:27 +08:00
shenyu
16fe9782f7 🚀 fix: tocbot warning 2020-03-24 22:19:01 +08:00
shenyu
785a9f33e1 🚀 fix: warning 2020-03-24 22:09:20 +08:00
shenyu
55d5c26161 🚀 fix: tocbot warning 2020-03-24 22:03:59 +08:00
shenyu
c1cedb6104 🚀 fix: tocbot warning 2020-03-24 21:57:41 +08:00
shenyu
085292ac1d 🚀 fix: search 2020-03-24 19:53:16 +08:00
沈宇
97e79abc8d 🚀 feat: showThemeInConsole 2020-03-24 14:06:11 +08:00
沈宇
ebe1e25719 🚀 refactor: code 2020-03-24 12:51:01 +08:00
shenyu
1003d95815 🚀 feat: Dark Mode 2020-03-23 23:04:50 +08:00
沈宇
c3588e1752 feat: darkmode 2020-03-23 18:06:38 +08:00
shenyu
66a6390998 🚀 fix: pin top 2020-03-21 17:20:59 +08:00
沈宇
a9473d4d22 🚀 fix: albums display 2020-03-16 11:24:54 +08:00
shenyu
68b1022367 🐛 fix: albums display 2020-03-15 19:04:20 +08:00
沈宇
8eadb41a90 Merge branch 'master' of https://github.com/Shen-Yu/hexo-theme-ayer 2020-03-06 11:21:35 +08:00
沈宇
6b3edff55f 🐛 fix: progressBar && CDN 2020-03-06 11:20:54 +08:00
shenyu
185374380f 🐛 Update Gitalk to 1.6.2 2020-03-04 21:57:50 +08:00
shenyu
6afa47978e 🎉 v1.9 2020-03-02 20:12:01 +08:00
shenyu
718cf389ee 🔖 v1.9 2020-03-02 20:08:57 +08:00
shenyu
eaf683440a 🚀 feat: postcss 2020-03-02 19:32:14 +08:00
沈宇
bc0119d821 🚀 feat: Add Parcel 2020-03-02 13:55:29 +08:00
shenyu
196253f025 fix: music 2020-02-27 19:47:53 +08:00
沈宇
836246b4e0 feat: Music 2020-02-27 15:42:29 +08:00
沈宇
28d8716cf4 fix: icp 2020-02-27 13:55:58 +08:00
沈宇
1f6b859952 fix: beian 2020-02-27 10:21:02 +08:00
沈宇
a32496edbe feat: beian 2020-02-27 10:05:41 +08:00
shenyu
4fcc3ff32b fix: excerpt_all 2020-02-15 23:28:28 +08:00
shenyu
641abe0ae9 docs: README.md 2020-02-14 12:11:58 +08:00
shenyu
00b8d2c47a fix 2020-02-12 14:28:08 +08:00
shenyu
608766a430 fix: style 2020-02-12 14:02:20 +08:00
shenyu
71bc221675 feat: excerpt_all 2020-02-12 12:50:12 +08:00
沈宇
200450fadd
Merge pull request #19 from ckyOL/master
Update Gitalk to 1.5.2 to fix bug
2020-02-11 23:16:03 +08:00
ckyOL
3fedba6204 Update Gitalk to 1.5.2 to fix bug 2020-02-11 22:06:45 +08:00
shenyu
f98e95ccf8 fix: style 2020-02-11 13:05:04 +08:00
shenyu
380a5cc4ab fix: table 2020-02-10 16:55:51 +08:00
shenyu
9fac2a8e2c fix: valine notify 2020-02-10 12:29:25 +08:00
shenyu
d1534ef60e fix: style 2020-02-09 17:17:31 +08:00
shenyu
ff240c9011 fix: highlight style 2020-02-09 13:36:33 +08:00
shenyu
c22c19547d fix: README.md 2020-02-08 23:49:40 +08:00
shenyu
eb1ecd74fa fix: style 2020-02-07 15:12:49 +08:00
shenyu
14f1f432c9 feat: Copyright 2020-02-07 12:42:33 +08:00
shenyu
ad93a588f7 feat: Add Share Platform 2020-02-06 23:14:35 +08:00
shenyu
83243b93f4 fix: typed.js warning 2020-02-05 11:27:16 +08:00
shenyu
8070697b20 fix: warning 2020-02-05 11:21:08 +08:00
shenyu
ed5e4803d1 feat: share button enable 2020-02-03 11:40:27 +08:00
shenyu
4c7e107c08 fix: category head.ejs 2020-02-02 10:59:00 +08:00
shenyu
2184d5f5ee fix: subtitle 2020-01-30 14:36:03 +08:00
shenyu
da20d7b3c9 feat: Subtitle typed animation 2020-01-30 14:14:35 +08:00
shenyu
7fcdbf8722 fix: tocbot 2020-01-29 20:36:48 +08:00
shenyu
71e1c2149d fix: style 2020-01-25 12:42:48 +08:00
shenyu
e528545051 release: v1.6 2020-01-24 13:06:25 +08:00
shenyu
3908fbe0e5 feat: valine comment verify 2020-01-24 13:02:50 +08:00
shenyu
db78e3261e fix: sidebar width 2020-01-23 14:19:50 +08:00
shenyu
8f267514b3 fix: sidebar 2020-01-23 14:13:24 +08:00
shenyu
0fb41a4ce2 fix: README.md 2020-01-23 11:30:35 +08:00
shenyu
dd35431d98 docs: images in article support click to fullscreen 2020-01-20 21:02:13 +08:00
沈宇
3d85b0926a feat: Support image display fullscreen 2020-01-20 15:09:23 +08:00
shenyu
661902f0f4 Merge branch 'master' of https://github.com/Shen-Yu/hexo-theme-ayer 2020-01-18 22:14:24 +08:00
shenyu
ef3c7271ef fix: style 2020-01-18 22:13:43 +08:00
沈宇
ad5e15c0e0 docs: fix license 2020-01-15 10:25:12 +08:00
沈宇
459860c16a docs: v1.5 2020-01-15 10:11:33 +08:00
沈宇
8c7a957f6e
Create LICENSE 2020-01-15 08:35:30 +08:00
shenyu
7d408946e9 fix: docs 2020-01-15 08:25:50 +08:00
shenyu
df2f61aad0 fix: style 2020-01-15 07:57:43 +08:00
shenyu
bffec8c8d9 fix: style 2020-01-13 22:02:19 +08:00
shenyu
380d4c6501 Merge branch 'master' of https://github.com/Shen-Yu/hexo-theme-ayer 2020-01-13 21:36:53 +08:00
shenyu
8f93d6494e fix: sponsor.jpg 2020-01-13 21:36:32 +08:00
沈宇
f610f83e09
Create FUNDING.yml 2020-01-13 21:30:21 +08:00
shenyu
9dcd4aca7c feat: sponsor 2020-01-13 21:25:44 +08:00
shenyu
77ecc930bd style: Categories,Tags 2020-01-13 20:58:07 +08:00
shenyu
54216601f2 release: v1.3 2020-01-09 21:32:48 +08:00
shenyu
a38c874bb4 feat: close reward and comments in md 2020-01-09 20:26:44 +08:00
shenyu
63497f1ad2 fix:arrow jump&styles 2020-01-09 19:55:59 +08:00
shenyu
42b387c94a fix: wordcount style 2020-01-07 20:13:38 +08:00
shenyu
11a4aaacf2 feat: WordCount 2020-01-07 19:44:35 +08:00
沈宇
ca99e5de86 feat: WordCount 2020-01-07 14:05:02 +08:00
沈宇
758b378e82
fix: change anchor jump to scrollIntoView 2020-01-07 13:12:44 +08:00
沈宇
a8b0534861
Update _extend.styl 2020-01-06 13:19:29 +08:00
shenyu
246cae5164 fix: footer.ejs 2020-01-02 19:35:23 +08:00
shenyu
4e57d75cb9 fix 2019-12-31 22:59:03 +08:00
shenyu
faef444acd fix: README.md 2019-12-31 22:53:01 +08:00
shenyu
38131011fc fix: README.md 2019-12-31 22:48:55 +08:00
shenyu
4367d51759 release: v1.2 2019-12-30 22:01:38 +08:00
shenyu
ffb7bcb2d9 fix: style 2019-12-30 22:00:24 +08:00
shenyu
feb9fe196e fix: markdown style 2019-12-30 21:47:25 +08:00
shenyu
f1c03a8f21 fix: markdown list style 2019-12-30 21:23:12 +08:00
shenyu
0bc4b48060 fix: README.md 2019-12-30 20:22:40 +08:00
shenyu
1dbbc6110f fix: footer 2019-12-29 16:44:12 +08:00
shenyu
c90f268255 release: v1.1 2019-12-29 11:02:30 +08:00
shenyu
8498c48374 fix: README.md 2019-12-29 10:57:24 +08:00
shenyu
91abd96dce fix: style 2019-12-28 21:07:01 +08:00
shenyu
baa5a1cdc7 fix: style 2019-12-25 23:31:54 +08:00
shenyu
5d0cf6f1da fix: README.md 2019-12-25 23:27:30 +08:00
shenyu
0cccbcc7e0 feat: stylint 2019-12-25 21:43:56 +08:00
shenyu
3e8987666d fix 2019-12-25 21:31:38 +08:00
shenyu
b0626bfc24 feat: .travis.yml 2019-12-25 21:22:01 +08:00
shenyu
bb21bce8bf fix: README.md 2019-12-25 21:01:24 +08:00
shenyu
60fdc61f67 fix: README.md 2019-12-25 20:49:21 +08:00
155 changed files with 6960 additions and 10085 deletions

58
.drone.yml Normal file
View File

@ -0,0 +1,58 @@
kind: pipeline
steps:
- name: restore-cache
image: meltwater/drone-cache:dev
environment:
AWS_ACCESS_KEY_ID:
from_secret: aws_acces
AWS_SECRET_ACCESS_KEY:
from_secret: aws_key
pull: true
settings:
debug: false
cache_key: '{{ arch }}_{{ os }}_{{ checksum "package-lock.json" }}'
archive_format: "gzip"
endpoint: storage.yandexcloud.net
restore: true
bucket: drone-cache
region: ru-central1
mount: 'node_modules'
- name: run-sh
image: node:alpine
commands:
- chmod +x ./bin/run.sh
- ./bin/run.sh
- name: update-site
image: plugins/downstream
settings:
server: https://drone.lp76.ru
token:
from_secret: drone_token
fork: false
repositories:
- aleks/site
- name: rebuild-cache
image: meltwater/drone-cache:dev
environment:
AWS_ACCESS_KEY_ID:
from_secret: aws_acces
AWS_SECRET_ACCESS_KEY:
from_secret: aws_key
pull: true
settings:
debug: false
cache_key: '{{ arch }}_{{ os }}_{{ checksum "package-lock.json" }}'
archive_format: "gzip"
endpoint: storage.yandexcloud.net
rebuild: true
bucket: drone-cache
region: ru-central1
mount: 'node_modules'
- name: telegram
image: appleboy/drone-telegram
settings:
token:
from_secret: token_telegramm
to:
from_secret: to_telegram_user
message: #success {{build.status}}

3
.gitattributes vendored Normal file
View File

@ -0,0 +1,3 @@
*.html linguist-language=javascript
*.stylus linguist-language=javascript
*.ejs linguist-language=javascript

31
.github/workflows/node.yml vendored Normal file
View File

@ -0,0 +1,31 @@
# This workflow will do a clean installation of node dependencies, cache/restore them, build the source code and run tests across different versions of node
# For more information see: https://docs.github.com/en/actions/automating-builds-and-tests/building-and-testing-nodejs
name: Node.js CI
on:
push:
branches: [ "master" ]
pull_request:
branches: [ "master" ]
jobs:
build:
runs-on: ubuntu-latest
strategy:
matrix:
node-version: [16.x, 18.x]
# See supported Node.js release schedule at https://nodejs.org/en/about/releases/
steps:
- uses: actions/checkout@v3
- name: Use Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v3
with:
node-version: ${{ matrix.node-version }}
cache: 'npm'
- run: npm ci
- run: npm run build --if-present
- run: npm test

8
.gitignore vendored Normal file
View File

@ -0,0 +1,8 @@
.DS_Store
.idea/
*.log
*.iml
node_modules/
.cache
.history
_bak.yml

4
.npmignore Normal file
View File

@ -0,0 +1,4 @@
.cache/
.history/
.github/
_bak.yml

45
.stylintrc Normal file
View File

@ -0,0 +1,45 @@
{
"blocks": false,
"brackets": "never",
"colons": false,
"colors": "never",
"commaSpace": false,
"commentSpace": "never",
"cssLiteral": "never",
"customProperties": [],
"depthLimit": false,
"duplicates": false,
"efficient": false,
"exclude": [],
"extendPref": false,
"globalDupe": false,
"groupOutputByFile": false,
"indentPref": false,
"leadingZero": "never",
"maxErrors": false,
"maxWarnings": false,
"mixed": false,
"mixins": [],
"namingConvention": "lowercase-dash",
"namingConventionStrict": false,
"none": "never",
"noImportant": false,
"parenSpace": false,
"placeholders": "always",
"prefixVarsWithDollar": "always",
"quotePref": false,
"reporterOptions": {
"columns": ["lineData", "severity", "description", "rule"],
"columnSplitter": " ",
"showHeaders": false,
"truncate": false
},
"semicolons": "never",
"sortOrder": "never",
"stackedProperties": false,
"trailingWhitespace": "never",
"universal": false,
"valid": false,
"zeroUnits": "never",
"zIndexNormalize": false
}

390
README.md
View File

@ -1,109 +1,247 @@
<h1 align="center">Ayer</h1>
:ocean: Ayer is a clean and elegant theme for Hexo, also fast, powerful and responsive. It contains many awesome features, It's perfect for your blog, "Ayer" means "water" in Malaysian and "yesterday" in Spanish. If you have any queries or advice during the process of using, Please contact me!
收藏本主题请点右上角Star谢谢~
### [Preview](https://shen-yu.gitee.io)
### [中文说明](https://shen-yu.gitee.io/2019/ayer/)
![Screenshot](screenshots/hexo-theme-ayer.png) ![Screenshot](screenshots/hexo-theme-ayer.png)
### Install ## Install
``` bash ### For hexo >= 5.0
$ git clone https://github.com/Shen-Yu/hexo-theme-ayer.git themes/ayer
```shell
npm i hexo-theme-ayer -S
``` ```
### Enable - If this theme is newly installed, a `_config.ayer.yml` file will be generated in the root directory after the installation is complete, and you can directly edit the `_config.ayer.yml` file for configuration.
- If it is a theme upgrade, you can use the configuration method of hexo < 5.0, or you can move the original configuration file to the root directory and rename it to `_config.ayer.yml`.
### For hexo < 5.0
```shell
git clone https://github.com/Shen-Yu/hexo-theme-ayer.git themes/ayer
```
## Enable
Modify `theme` setting in `_config.yml` to `ayer` Modify `theme` setting in `_config.yml` to `ayer`
``` yml ```yml
theme: ayer theme: ayer
``` ```
### Update ## Update
``` bash ```bash
cd themes/ayer cd themes/ayer
git pull git pull
``` ```
### Configuration ## Multi Language Support
let me know if you cant find something. zh-CN中文简体 enEnglish zh-TW中文繁体 ja日本語 esEspañol deDeutsch frFrançais ruРусский ko한국어 viTiếng Việt nlNederlands nonorsk ptPortuguês
``` yml English is default languge, if you want to change, modify `language` option in `_config.yml` file in your Hexo blog's root folder.
# Menu-侧边栏菜单
## Configuration
let me know if you have any questions.
```yml
# Menu-Sidebar
menu: menu:
Home: / Home: /
Archives: /archives Archives: /archives
Categories: /categories
Tags: /tags
Gallery: http://shenyu-vip.lofter.com Gallery: http://shenyu-vip.lofter.com
Travel: /tags/旅行/ Travel: /tags/旅行/
About: /2019/about About: /2019/about
# 网站图标和侧边栏logo # Subtitle and Typing animation
# https://github.com/mattboldt/typed.js
subtitle:
enable: true
text: A clean and elegant theme
text2: It's perfect for your hexo blog
text3: Have fun! #Supports up to three lines of text
startDelay: 0
typeSpeed: 200
loop: true
backSpeed: 100
showCursor: true
# Favicon and sidebar logo
favicon: /favicon.ico favicon: /favicon.ico
logo: /images/ayer-side.svg logo: /images/ayer-side.svg
# 封面配置 # Cover Setting
# enable-是否启用封面path-封面背景图logo-封面logo # enable: [true|false]path: [background-image]logo: [cover-logo-image]
cover: cover:
enable: true enable: true
path: /images/cover1.jpg # images目录下附送多张美图可更换 path: /images/cover1.jpg # there are some beautiful cover images in Ayer's directory: /source/images, choose your favorite image to replace it.
logo: /images/ayer.svg logo: /images/ayer.svg
# 页面顶部进度条 # ProgressBar
progressBar: ture progressBar: true
# 文章配置 # Boardcast
# 文章太长,截断按钮文字(在需要截断的行增加此标记:<!--more-->) broadcast:
enable: true
type: 2 # 1custom2hitokoto api(https://hitokoto.cn/)
text: a clean and elegant theme, fast and responsive. # only work in custom mode
# Article Setting
# (Use this to excerpt if article is too long<!--more-->)
excerpt_link: Read More... excerpt_link: Read More...
# 文章分享文字 excerpt_all: false
# Copy code button
copy_btn: true
# Share
share_enable: true
# If you are not in China, maybe you prefer to set:false
share_china: true
# share text
share_text: Share share_text: Share
# 搜索文字 # search text
search_text: Search search_text: Search
# 分页文字 # nav text
nav_text: nav_text:
page_prev: Prev page page_prev: Prev page
page_next: Next page page_next: Next page
post_prev: Newer posts post_prev: Newer posts
post_next: Older posts post_next: Older posts
# 文章页是否显示目录 # Catalog in article
toc: true toc: true
# 打赏 # images in the article support click to fullscreen
# 打赏type设定0-关闭打赏; 1-文章对应的md文件里有reward:true属性才有打赏 2-所有文章均有打赏 image_viewer: true
# https://github.com/willin/hexo-wordcount
word_count:
enable: true
# only display in article page(not in index page)
only_article_visit: true
# Reward Setting
# type0-close reward 1-only open in article which you have configured reward:true 2-open in all articles
reward_type: 2 reward_type: 2
# 打赏wording # reward word
reward_wording: '请我喝杯咖啡吧~' reward_wording: "Buy me a cup of coffee~"
# 支付宝二维码图片地址跟你设置logo的方式一样。比如/images/alipay.jpg # qrcode image path
alipay: /images/alipay.jpg alipay: /images/alipay.jpg
# 微信二维码图片地址 # qrcode image path
weixin: /images/wechat.jpg weixin: /images/wechat.jpg
# 是否启用搜索 # Copyright
# type0-close all 1-only display in article which you have configured copyright: true 2-all articles
copyright_type: 2
# Search
# https://github.com/theme-next/hexo-generator-searchdb
search: true search: true
# RSS订阅(先安装hexo-generator-feed插件再去博客根目录config进行配置) # RSS
# leave it empty if you dont' need
rss: /atom.xml rss: /atom.xml
# 评论1、Valine(推荐)2、Gitalk # DarkMode
darkmode: true
# 1、Valine[一款快速、简洁且高效的无后端评论系统](https://github.com/xCss/Valine) # Canvas background style: 0-close1-moveline
# 启用Valine必须先创建leancloud应用 获取 id|key 填入即可 canvas_bg: 0
leancloud:
# Custom mouse pointerreplace /images/mouse.cur
mouse:
enable: false
path: /images/mouse.cur
# Click effect: 0-close1-love2-boom3-particles
click_effect: 0
# articleWidth and sidebarWidth
layout:
article_width: 80rem
sidebar_width: 8rem
# GitHub Ribbons(https://github.blog/2008-12-19-github-ribbons/)
github:
# (Set false if you don't need)
enable: false
url: https://github.com/Shen-Yu/hexo-theme-ayer
# pv&uv statistics
busuanzi:
enable: true
# cnzz statistics
cnzz:
enable: true
url: #
# Google Analytics
google_analytics: ""
# Baidu Analytics
baidu_analytics: ""
# Mathjax Support
mathjax: true
# Katex Support
# note: need change the hexo-renderernpm un hexo-renderer-marked -S && npm i hexo-renderer-markdown-it-katex -S
katex:
enable: false # true
allpost: true
copy_tex: false
# since year
since: 2019
# only for chinese website
# ICP
icp:
enable: false
url: "http://www.beian.miit.gov.cn/"
text: "浙ICP备88888888"
# gongan
gongan:
enable: false
img: /images/beian.png
url: "http://www.beian.gov.cn/portal/registerSystemInfo?recordcode=01234567890123" #link
text: "浙公网安备01234567890123号"
# friends link
friends_link:
Ayer: #site name
# site url
url: https://github.com/Shen-Yu/hexo-theme-ayer
# site icon(optional)
img: /images/ayer.png
GitHub:
url: https://github.com/Shen-Yu
img: https://i.loli.net/2020/09/07/indb4PRYDA98EkN.png
gitee:
url: https://gitee.com/shen-yu
img: https://i.loli.net/2020/09/07/K3AqO7h6krQFlRX.png
Hexo:
url: https://hexo.io
img: https://i.loli.net/2020/09/07/UYGzjo7h68CRWny.png
hexo-tag-chart:
url: https://github.com/Shen-Yu/hexo-tag-chart
img: https://i.loli.net/2020/09/07/GIXBYE5SoylhR1r.png
# Comment1、Valine (recommended)2、Gitalk3、Twikoo4、MiniValine
# You can close the comment section on one of your posts by marking `comments: false` in front-matter.
# 1、Valine [A fast, simple & powerful comment system](https://github.com/xCss/Valine)
# You need create leancloud account first (https://console.leancloud.app), then put the id|key in below.
leancloud:
enable: true enable: true
app_id: # app_id: #
app_key: # app_key: #
# Valine配置 # Valine Setting
valine: valine:
enable: true # 是否启用 enable: true
avatar: mp # 头像样式(https://valine.js.org/avatar.html) avatar: mp # (https://valine.js.org/avatar.html)
placeholder: 给我的文章加点评论吧~ # placeholder placeholder: Add some comments to my article~ # placeholder
# 2、Gitalk(https://github.com/gitalk/gitalk) # 2、Gitalk(https://github.com/gitalk/gitalk)
gitalk: gitalk:
@ -114,47 +252,42 @@ gitalk:
owner: # GitHub ID owner: # GitHub ID
admin: # GitHub ID admin: # GitHub ID
# GitHub Ribbons(https://github.blog/2008-12-19-github-ribbons/) # 3、Twikoo(https://github.com/imaegoo/twikoo)
github: twikoo:
# (关闭请设置为false) enable: false
url: https://github.com/Shen-Yu/hexo-theme-ayer envId: #
# fancybox(仅用于相册展示若需要可配置albums)
fancybox: true
# 访问量统计(不蒜子) # advertisement
busuanzi: # if there is an "ad" word in photo or urlit may blocked by adblock or any other browser extensions
enable: true ads:
ad_1:
title: vultr优惠vps
img: https://cdn.jsdelivr.net/gh/Shen-Yu/cdn/img/vultr.png
url: https://www.vultr.com/?ref=8630075
width: 300
ad_2:
title: 云服务器全球购低至2折
img: https://cdn.jsdelivr.net/gh/Shen-Yu/cdn/img/ten_2.jpg
url: https://curl.qcloud.com/kvO7hb43
width: 300
# 友盟cnzz统计(url填js代码src链接) # encrypt settings
cnzz: lock:
enable: true enable: false
url: # password: 123456
# Google Analytics
google_analytics: ''
# 百度统计
baidu_analytics: ''
# 数学公式
mathjax: true
# 网站成立年份(默认为 2019若填入年份小于当前年份则显示为 2018-2019 类似的格式)
since: 2019
#是否显示页脚信息(建议保留,有助于本主题的推广)
pageFooter: true
``` ```
### Plugins ## Plugins
- [hexo-generator-search](https://github.com/wzpan/hexo-generator-search) (for Local Search)
+ [hexo-generator-search](https://github.com/wzpan/hexo-generator-search) Local search
```yml ```yml
$ npm install hexo-generator-searchdb --save $ npm install hexo-generator-searchdb --save
``` ```
Then add the plugin configuration for hexo's configuration file `_config.yml` (note: not the theme's configuration file):
Then add the plugin configuration in hexo's configuration file `_config.yml` (note: not the theme's configuration file):
```yml ```yml
# Hexo-generator-search # Hexo-generator-search
search: search:
@ -163,16 +296,16 @@ pageFooter: true
format: html format: html
``` ```
+ [hexo-generate-feed](https://github.com/hexojs/hexo-generator-feed) RSS - [hexo-generator-feed](https://github.com/hexojs/hexo-generator-feed) (for RSS)
```yml ```yml
$ npm install hexo-generator-feed --save $ npm install hexo-generator-feed --save
``` ```
Then add the plugin configuration for hexo's configuration file `_config.yml` (note: not the theme's configuration file): Then add the plugin configuration in hexo's configuration file `_config.yml` (note: not the theme's configuration file):
```yml ```yml
feed: feed:m
type: atom type: atom
path: atom.xml path: atom.xml
limit: 20 limit: 20
@ -180,63 +313,84 @@ pageFooter: true
content: content:
content_limit: 140 content_limit: 140
content_limit_delim: ' ' content_limit_delim: ' '
order_by: -date order_by: -date
``` ```
+ [hexo-generator-index-pin-top](https://github.com/netcan/hexo-generator-index-pin-top) - [hexo-generator-index-pin-top](https://github.com/netcan/hexo-generator-index-pin-top) (for Sticky Post)
``` bash ```bash
$ npm uninstall hexo-generator-index --save $ npm uninstall hexo-generator-index --save
$ npm install hexo-generator-index-pin-top --save $ npm install hexo-generator-index-pin-top --save
``` ```
### Post poster ## Categories
``` md ```bash
hexo new page categories
```
Then paste following codes to file: /source/categories/index.md
```md
--- ---
title: Post name title: categories
type: categories
photos: [ layout: "categories"
["img_url"],
["img_url"]
]
--- ---
``` ```
### Gallery ## Tags
Same as categories.
## Friend Links
```bash
hexo new page friends
```
Then paste following codes to file: /source/friends/index.md
```md
---
title: friends
type: friends
layout: "friends"
---
```
Then edit `friends_link` in `_config.yml`
## Gallery
Need to write in the head of the markdown, this is not a good way to write, I hope to get a better way to write on github. Need to write in the head of the markdown, this is not a good way to write, I hope to get a better way to write on github.
``` md ```md
--- ---
title: Gallery title: Gallery
albums: [ albums: [["img_url", "img_caption"], ["img_url", "img_caption"]]
["img_url","img_caption"],
["img_url","img_caption"]
]
--- ---
``` ```
### Toc ## Toc
Use Tocbot to parse the title tags (h1~h6) in the content and insert the directory. Use Tocbot to parse the title tags (h1~h6) in the content and insert the directory.
+ ayer/_config.yml - ayer/\_config.yml
``` bash ```bash
# Toc # Toc
toc: true toc: true
``` ```
+ If Toc is turned on in ayer/_config.yml, then Tocbot will generate a Toc article directory in the title tag of each blog parsing content, but not all blogs require Toc, so in the Front-matter section of markdown Can be closed:
``` md - If Toc is turned on in ayer/\_config.yml, then Tocbot will generate a Toc article directory in the title tag of each blog parsing content, but not all blogs require Toc, so in the Front-matter section of markdown Can be closed:
---
toc: false ```md
--- ---
``` no_toc: true
---
```
--- ---
Inspired by [Ocean](https://github.com/zhwangart/hexo-theme-ocean)
<a rel="license" href="http://creativecommons.org/licenses/by-nc-sa/4.0/"><img alt="Creative Commons License" style="border-width:0" src="https://i.creativecommons.org/l/by-nc-sa/4.0/88x31.png" /></a><br><span xmlns:dct="http://purl.org/dc/terms/" property="dct:title">Ayer</span> by <a xmlns:cc="http://creativecommons.org/ns#" href="https://github.com/Shen-Yu/hexo-theme-ayer" property="cc:attributionName" rel="cc:attributionURL">Eric-Shen</a> is licensed under a <a rel="license" href="http://creativecommons.org/licenses/by-nc-sa/4.0/">Creative Commons Attribution-NonCommercial-ShareAlike 4.0 International License</a>.

View File

@ -1,11 +1,22 @@
# 侧边栏菜单 # 侧边栏菜单
menu: menu:
主页: / Главная: /
目录: /archives Архивы: /archives
标签: /tags Категории: /categories
旅行: /tags/旅行/ Теги: /tags
摄影: http://shenyu-vip.lofter.com
关于我: /2019/about # 站点次标题和打字动效
# https://github.com/mattboldt/typed.js
subtitle:
enable: true # 是否开启动效
text: # 显示的文字
text2: # 滚动播放,如果不需要可以留空
text3: # 最多支持三段文字
startDelay: 0 # 延迟时间
typeSpeed: 200 # 打字速度
loop: true # 是否循环
backSpeed: 100 # 回退速度
showCursor: true # 是否显示光标
# 网站图标和侧边栏logo # 网站图标和侧边栏logo
favicon: /favicon.ico favicon: /favicon.ico
@ -15,93 +26,189 @@ logo: /images/ayer-side.svg
# enable-是否启用封面path-封面背景图logo-封面logo # enable-是否启用封面path-封面背景图logo-封面logo
cover: cover:
enable: true enable: true
path: /images/cover1.jpg # images目录下附送多张美图可更换 path: /images/cover1.jpg # /source/images目录下附送多张美图可更换
logo: false #/images/ayer.svg如果不要直接设置成false logo: false #/images/ayer.svg如果不要直接设置成false
# 页面顶部进度条 # 页面顶部进度条
progressBar: ture progressBar: true
# 告示板模块
broadcast:
enable: false # true开启false关闭
type: 2 # 1自定义输入2一言api(https://hitokoto.cn/)
text: енен # type为1时有效
# 文章配置 # 文章配置
# 文章太长,截断按钮文字(在需要截断的行增加此标记:<!--more-->) # 文章太长,截断按钮文字(在需要截断的行增加此标记:<!--more-->)
excerpt_link: 阅读更多... excerpt_link: false
# 如果你嫌每篇文章手动加more标记比较麻烦又不想在首页全文显示可以把excerpt_all设置成true这样首页只会显示文章归档
excerpt_all: false
# 是否开启代码复制按钮
copy_btn: true
# 是否开启文章分享按钮
share_enable: true
# 国内的社交平台(If you are not in China, maybe you prefer to set:false)
share_china: false
# 文章分享文字 # 文章分享文字
share_text: 分享 share_text: Поделится
# 分页文字 # 分页文字
nav_text: nav_text:
page_prev: 上一页 page_prev: Страница назад
page_next: 下一页 page_next: Страница вперед
post_prev: 上一篇 post_prev: Предыдущая запись
post_next: 下一篇 post_next: Следующая запись
# 文章页是否显示目录 # 文章页是否显示目录
toc: true toc: true
# 文章中的图片是否支持点击放大
image_viewer: true
# https://github.com/willin/hexo-wordcount
# 是否开启字数统计(关闭请设置enable为false)
# 也可以单独在md文件里Front-matter设置`no_word_count: true`属性,来自定义关闭字数统计
word_count:
enable: true
# 只在文章详情显示(不在首页显示)
only_article_visit: true
# 打赏 # 打赏
# 打赏type设定0-关闭打赏; 1-文章对应的md文件里有reward:true属性才有打赏 2-所有文章均有打赏 # 打赏type设定0-关闭打赏; 1-文章对应的md文件里有reward:true属性才有打赏 2-所有文章均有打赏
reward_type: 2 reward_type: 2
# 打赏wording # 打赏wording
reward_wording: '请我喝杯咖啡吧~' reward_wording: "wording"
# 支付宝二维码图片地址跟你设置logo的方式一样。比如/images/alipay.jpg # 支付宝二维码图片地址跟你设置logo的方式一样。比如/images/alipay.jpg
alipay: /images/alipay.jpg alipay: /images/alipay.jpg
# 微信二维码图片地址 # 微信二维码图片地址
weixin: /images/wechat.jpg weixin: /images/wechat.jpg
# 版权声明
# 版权声明type设定0-关闭版权声明; 1-文章对应的md文件里有copyright: true属性才有版权声明 2-所有文章均有版权声明
copyright_type: 2
# 是否启用搜索 # 是否启用搜索
# 需要安装hexo-generator-searchdb(https://github.com/theme-next/hexo-generator-searchdb)
search: true search: true
# RSS订阅(先安装hexo-generator-feed插件再去博客根目录config进行配置) # RSS订阅(先安装hexo-generator-feed插件再去博客根目录config进行配置)
# 不想显示可以直接留空
rss: /atom.xml rss: /atom.xml
# 评论1、Valine(推荐)2、Gitalk # 是否启用黑夜模式开关
darkmode: true
# 1、Valine[一款快速、简洁且高效的无后端评论系统](https://github.com/xCss/Valine) # 动态背景效果: 0-关闭1-动态线条(跟随鼠标)
# 启用Valine必须先创建leancloud应用 获取 id|key 填入即可 canvas_bg: 0
leancloud:
enable: true
app_id: #
app_key: #
# Valine配置
valine:
enable: true # 是否启用
avatar: mp # 头像样式(https://valine.js.org/avatar.html)
placeholder: 给我的文章加点评论吧~ # placeholder
# 2、Gitalk(https://github.com/gitalk/gitalk) # 自定义鼠标样式,直接替换/images/mouse.cur文件
gitalk: mouse:
enable: false # true enable: false
clientID: # GitHub Application Client ID path: /images/mouse.cur
clientSecret: # Client Secret
repo: # Repository name
owner: # GitHub ID
admin: # GitHub ID
# GitHub Ribbons(https://github.blog/2008-12-19-github-ribbons/) # 鼠标点击效果0-关闭1-爱心2-爆炸烟花3-粒子烟花
github: click_effect: 0
# 页面宽度自定义不建议修改可能造成布局混乱article_width文章宽度sidebar_width侧边栏宽度
layout:
article_width: 80rem
sidebar_width: 8rem
# GitHub Ribbons-封面右上角的forkme换样式直接在source/images目录下替换forkme图片
github:
# (关闭请设置为false) # (关闭请设置为false)
url: https://github.com/Shen-Yu/hexo-theme-ayer enable: true
url: https://github.com/alkyl1978/hexo-theme-ayer
# fancybox(仅用于相册展示若需要可配置albums) # 网易云音乐插件
fancybox: true music:
enable: false
# 播放器尺寸类型(1小尺寸、2大尺寸)
type: 1
id: 22707008 # 网易云分享的音乐ID(更换音乐请更改此配置项)
autoPlay: true # 是否开启自动播放
# 访问量统计(不蒜子) # 访问量统计(不蒜子)
busuanzi: busuanzi:
enable: true enable: false
# 友盟cnzz统计(url填js代码src链接) # 友盟cnzz统计(url填js代码src链接)
cnzz: cnzz:
enable: true enable: false
url: https://s9.cnzz.com/z_stat.php?id=1278069914&web_id=1278069914 url: https://s9.cnzz.com/z_stat.php?id=1278069914&web_id=1278069914
# Google Analytics # Google Analytics
google_analytics: '' google_analytics: ""
# 百度统计 # 百度统计
baidu_analytics: '' baidu_analytics: ""
# 数学公式 yandex_analytics: true
# Mathjax数学公式
mathjax: false mathjax: false
# 网站成立年份(默认为 2019若填入年份小于当前年份则显示为 2018-2019 类似的格式) # Katex数学公式(allpost设置为false时只有头部设置math:true的文章才开启)
since: 2015 # 需要更换hexo渲染器npm un hexo-renderer-marked -S && npm i hexo-renderer-markdown-it-katex -S
katex:
enable: true # true
allpost: true
copy_tex: false
#是否显示页脚信息(建议保留,有助于本主题的推广) # mermaid流程图 三个选项缺一不可(https://mermaid-js.github.io/mermaid/)
pageFooter: true mermaid:
enable: true
cdn: https://cdn.staticfile.org/mermaid/8.14.0/mermaid.min.js
theme: forest
# 网站成立年份(默认为 2019若填入年份小于当前年份则显示为 2018-2019 类似的格式)
since: 2023
# ICP备案信息尾部显示
icp:
enable: false
url: "https://beian.miit.gov.cn/" # 备案链接
text: "浙ICP备88888888" # 备案信息
# 公安备案信息尾部显示
gongan:
enable: false
img: /images/beian.png #公安备案图片
url: "http://www.beian.gov.cn/portal/registerSystemInfo?recordcode=01234567890123" #公安备案链接
text: "浙公网安备01234567890123号" #公安备案信息
# 友情链接
friends_link:
Ayer主题: #网站名称
#网站地址
url: https://github.com/alkyl1978/hexo-theme-ayer
#网站图片(可忽略不写)
img: /images/ayer.png
GitHub:
url: https://github.com/alkyl1978
img: /images/github.png
码云:
url: https://lp76.ru
img: /images/gitee.png
Hexo官网:
url: https://hexo.io
img: /images/hexo.png
# 评论1、Valine(推荐)2、Gitalk3、Twikoo;
# 首页广告配置
# 可以根据需要自行增加ad_3ad_4...留空则不显示建议图片和url不要带ad等关键词否则可能会被adblock等插件屏蔽
#ads:
# ad_1:
# title: 云服务器限时秒杀
# img: https://pic.imgdb.cn/item/62174b452ab3f51d912a5ccc.jpg
# url: https://curl.qcloud.com/kvO7hb43
# width: 300
# ad_2:
# title: vultr优惠vps
# img: https://pic.imgdb.cn/item/62174b452ab3f51d912a5cd7.png
# url: https://www.vultr.com/?ref=8630075
# width: 300
# 网站开启加密访问,密码可设置任何字符
lock:
enable: true
password: 123456

6
bin/run.sh Normal file
View File

@ -0,0 +1,6 @@
#!/bin/sh
set -x
set -e
npm i
npm run build

2
index.js Normal file
View File

@ -0,0 +1,2 @@
// 这个文件用来防止 hexo 5.0.0以上 使用 "hexo clean" 命令报错。
// This file is used to prevent hexo above 5.0.0 from using "hexo clean" command error.

View File

@ -1,19 +0,0 @@
categories: Kategorien
search: Suche
tags: Tags
tagcloud: Tag Cloud
tweets: Tweets
prev: zurück
next: weiter
comment: Kommentare
archive_a: Archiv
archive_b: "Archive: %s"
page: Seite %d
recent_posts: letzter Beitrag
newer: Neuer
older: Älter
share: Teilen
powered_by: Powered by
rss_feed: RSS Feed
category: Kategorie
tag: Tag

View File

@ -13,7 +13,26 @@ recent_posts: Recent Posts
newer: Newer newer: Newer
older: Older older: Older
share: Share share: Share
powered_by: Powered by powered_by: Powered by %s
theme: Theme - %s
rss_feed: RSS Feed rss_feed: RSS Feed
category: Category category: Category
tag: Tag tag: Tag
site_visitors: Visitors
page_views: Views
friends: Friends
post:
word_count: Word count
read_time: Reading time
minutes: min
reward: Donate
sticky: Sticky
copyright_title: Copyright
copyright_content: Copyright is owned by the author. For commercial reprints, please contact the author for authorization. For non-commercial reprints, please indicate the source.
lock:
lock_info: Please enter password
lock_error: Incorrect password, please try again
confirm_text: Ok
cancel_text: Cancel

38
languages/en.yml Normal file
View File

@ -0,0 +1,38 @@
categories: Categories
search: Search
tags: Tags
tagcloud: Tag Cloud
tweets: Tweets
prev: Prev
next: Next
comment: Comments
archive_a: Archives
archive_b: "Archives: %s"
page: Page %d
recent_posts: Recent Posts
newer: Newer
older: Older
share: Share
powered_by: Powered by %s
theme: Theme - %s
rss_feed: RSS Feed
category: Category
tag: Tag
site_visitors: Visitors
page_views: Views
friends: Friends
post:
word_count: Word count
read_time: Reading time
minutes: min
reward: Donate
sticky: Sticky
copyright_title: Copyright
copyright_content: Copyright is owned by the author. For commercial reprints, please contact the author for authorization. For non-commercial reprints, please indicate the source.
lock:
lock_info: Please enter password
lock_error: Incorrect password, please try again
confirm_text: Ok
cancel_text: Cancel

View File

@ -1,19 +0,0 @@
categories: Categorías
search: Buscar
tags: Tags
tagcloud: Nube de Tags
tweets: Tweets
prev: Previo
next: Siguiente
comment: Comentarios
archive_a: Archivos
archive_b: "Archivos: %s"
page: Página %d
recent_posts: Posts recientes
newer: Nuevo
older: Viejo
share: Compartir
powered_by: Construido por
rss_feed: RSS
category: Categoría
tag: Tag

View File

@ -13,7 +13,26 @@ recent_posts: Articles récents
newer: Récent newer: Récent
older: Ancien older: Ancien
share: Partager share: Partager
powered_by: Propulsé par powered_by: Powered by %s
theme: Theme - %s
rss_feed: Flux RSS rss_feed: Flux RSS
category: Catégorie category: Catégorie
tag: Mot-clé tag: Mot-clé
site_visitors: Visitors
page_views: Views
friends: Mes amis
post:
word_count: Nombre de mots
read_time: Temps de lecture
minutes: min
reward: Récompense
sticky: Haut
copyright_title: Avis de copyright
copyright_content: Le droit d'auteur appartient à l'auteur. Pour les réimpressions commerciales, veuillez contacter l'auteur pour autorisation. Pour les réimpressions non commerciales, veuillez indiquer la source.
lock:
lock_info: Please enter password
lock_error: Incorrect password, please try again
confirm_text: Ok
cancel_text: Cancel

View File

@ -1,19 +0,0 @@
categories: カテゴリ
search: 検索
tags: タグ
tagcloud: タグクラウド
tweets: ツイート
prev: 戻る
next: 次へ
comment: コメント
archive_a: アーカイブ
archive_b: "アーカイブ: %s"
page: ページ %d
recent_posts: 最近の投稿
newer: 次の記事
older: 前の記事
share: 共有
powered_by: Powered by
rss_feed: RSSフィード
category: カテゴリ
tag: タグ

View File

@ -1,19 +0,0 @@
categories: 카테고리
search: 검색
tags: 태그
tagcloud: 태그 클라우드
tweets: 트윗
prev: 이전
next: 다음
comment: 댓글
archive_a: 아카이브
archive_b: "아카이브: %s"
page: 페이지 %d
recent_posts: 최근 포스트
newer: 최신
older: 이전
share: 공유
powered_by: Powered by
rss_feed: RSS Feed
category: 카테고리
tag: 태그

View File

@ -1,4 +1,3 @@
categories: Categorieën categories: Categorieën
search: Zoeken search: Zoeken
tags: Labels tags: Labels
@ -14,7 +13,26 @@ recent_posts: Recente berichten
newer: Nieuwer newer: Nieuwer
older: Ouder older: Ouder
share: Delen share: Delen
powered_by: Powered by powered_by: Powered by %s
theme: Theme - %s
rss_feed: RSS Feed rss_feed: RSS Feed
category: Categorie category: Categorie
tag: Label tag: Label
site_visitors: Visitors
page_views: Views
friends: Vrienden
post:
word_count: Aantal woorden in artikel
read_time: Leestijd
minutes: min
reward: Doneer
sticky: Sticky
copyright_title: Copyright melding
copyright_content: Copyright is eigendom van de auteur. Neem voor commerciële herdrukken contact op met de auteur voor autorisatie. Geef de bron aan voor niet-commerciële herdrukken.
lock:
lock_info: Please enter password
lock_error: Incorrect password, please try again
confirm_text: Ok
cancel_text: Cancel

View File

@ -13,7 +13,26 @@ recent_posts: Siste innlegg
newer: Newer newer: Newer
older: Older older: Older
share: Share share: Share
powered_by: Powered by powered_by: Powered by %s
theme: Theme - %s
rss_feed: RSS Feed rss_feed: RSS Feed
category: Category category: Category
tag: Tag tag: Tag
site_visitors: Visitors
page_views: Views
friends: Venner
post:
word_count: Ordtelling
read_time: Lesetid
minutes: min
reward: Donere
sticky: Sticky
copyright_title: Opphavsrett
copyright_content: Opphavsrett eies av forfatteren. For kommersielle opptrykk, vennligst kontakt forfatteren for godkjenning. For ikke-kommersiell uttrykk, vennligst oppgi kilden.
lock:
lock_info: Please enter password
lock_error: Incorrect password, please try again
confirm_text: Ok
cancel_text: Cancel

View File

@ -1,19 +0,0 @@
categories: Categorias
search: Buscar
tags: Tags
tagcloud: Nuvem de Tags
tweets: Tweets
prev: Anterior
next: Próximo
comment: Comentários
archive_a: Arquivos
archive_b: "Arquivos: %s"
page: Página %d
recent_posts: Postagens Recentes
newer: Mais Recente
older: Mais Antigo
share: Compartilhar
powered_by: Desenvolvido por
rss_feed: Feed RSS
category: Categoria
tag: Tag

View File

@ -13,7 +13,26 @@ recent_posts: Недавние записи
newer: Следующий newer: Следующий
older: Предыдущий older: Предыдущий
share: Поделиться share: Поделиться
powered_by: Создано с помощью powered_by: Powered by %s
theme: Theme - %s
rss_feed: RSS-каналы rss_feed: RSS-каналы
category: Категория category: Категория
tag: Метка tag: Метка
site_visitors: Visitors
page_views: Views
friends: друзья
post:
word_count: Количество слов
read_time: Время чтения
minutes: минут
reward: вознаграждение
sticky: липкий
copyright_title: Авторские права
copyright_content: Авторские права принадлежат автору. Для коммерческих перепечаток, пожалуйста, свяжитесь с автором для авторизации. Для некоммерческих перепечаток, пожалуйста, укажите источник.
lock:
lock_info: Please enter password
lock_error: Incorrect password, please try again
confirm_text: Ok
cancel_text: Cancel

View File

@ -1,19 +0,0 @@
categories: 分类
search: 搜索
tags: 标签
tagcloud: 标签云
tweets: 推文
prev: 上一页
next: 下一页
comment: 留言
archive_a: 归档
archive_b: 归档:%s
page: 第 %d 页
recent_posts: 最新文章
newer: Newer
older: Older
share: 分享
powered_by: Powered by
rss_feed: RSS Feed
category: Category
tag: Tag

View File

@ -1,19 +0,0 @@
categories: 分類
search: 搜尋
tags: 標籤
tagcloud: 標籤雲
tweets: 推文
prev: 上一頁
next: 下一頁
comment: 留言
archive_a: 彙整
archive_b: 彙整:%s
page: 第 %d 頁
recent_posts: 最新文章
newer: Newer
older: Older
share: Share
powered_by: Powered by
rss_feed: RSS Feed
category: Category
tag: Tag

9
layout/_partial/ads.ejs Normal file
View File

@ -0,0 +1,9 @@
<ul class="ads">
<% for (var i in theme.ads){ %>
<li>
<a href="<%= theme.ads[i].url %>">
<img src="<%= theme.ads[i].img %>" width="<%= theme.ads[i].width %>" alt="<%=theme.ads[i].title %>">
</a>
</li>
<% } %>
</ul>

View File

@ -1,43 +1,57 @@
<%- js('/js/jquery-2.0.3.min') %> <%- js('/js/jquery-3.6.0.min') %> <%- js('/js/lazyload.min') %>
<%- js('/js/jquery.justifiedGallery.min') %> <!-- Tocbot -->
<%- js('/js/lazyload.min') %> <% if (theme.toc && is_post() && !page.no_toc){ %> <%- js('/js/tocbot.min') %>
<%- js('/js/busuanzi-2.3.pure.min') %> <script>
<% if (theme.fancybox){ %> tocbot.init({
<%- js('fancybox/jquery.fancybox.min') %> tocSelector: ".tocbot",
contentSelector: ".article-entry",
headingSelector: "h1, h2, h3, h4, h5, h6",
hasInnerContainers: true,
scrollSmooth: true,
scrollContainer: "main",
positionFixedSelector: ".tocbot",
positionFixedClass: "is-position-fixed",
fixedSidebarOffset: "auto",
});
</script>
<% } %> <% } %>
<script src="https://cdn.staticfile.org/jquery-modal/0.9.2/jquery.modal.min.js"></script>
<% if (theme.toc && is_post()){ %> <link
<%- js('/js/tocbot.min') %> rel="stylesheet"
<script> href="https://cdn.staticfile.org/jquery-modal/0.9.2/jquery.modal.min.css"
// Tocbot_v4.7.0 http://tscanlin.github.io/tocbot/ />
tocbot.init({ <script src="https://cdn.staticfile.org/justifiedGallery/3.8.1/js/jquery.justifiedGallery.min.js"></script>
tocSelector: '.tocbot', <%- js('dist/main') %>
contentSelector: '.article-entry', <!-- ImageViewer -->
headingSelector: 'h1, h2, h3, h4, h5, h6', <% if (theme.image_viewer){ %> <%- partial('viewer') %> <% } %>
hasInnerContainers: true, <!-- MathJax -->
scrollSmooth: true, <% if (theme.mathjax){ %> <%- partial('mathjax') %>
positionFixedSelector: '.tocbot',
positionFixedClass: 'is-position-fixed',
fixedSidebarOffset: 'auto',
});
</script>
<% } %>
<script> <script>
var ayerConfig = { var ayerConfig = {
mathjax: <%=theme.mathjax %> mathjax: true,
};
</script>
<% } %>
<!-- Katex -->
<% if (theme.katex.enable){ %> <%- partial('katex') %> <% } %>
<!-- busuanzi -->
<% if (theme.busuanzi && theme.busuanzi.enable){ %> <%-
js('/js/busuanzi-2.3.pure.min') %> <% } %>
<!-- ClickLove -->
<% if (theme.click_effect===1){ %> <%- js('/js/clickLove') %> <% } %>
<!-- ClickBoom1 -->
<% if (theme.click_effect===2){ %>
<script src="https://cdn.staticfile.org/animejs/3.2.1/anime.min.js"></script>
<%- js('/js/clickBoom1') %> <% } %>
<!-- ClickBoom2 -->
<% if (theme.click_effect===3){ %> <%- js('/js/clickBoom2') %> <% } %>
<!-- CodeCopy -->
<% if (theme.copy_btn == true) { %> <%- css('/css/clipboard') %> <%-
partial('post/clipboard') %> <% } %>
<!-- CanvasBackground -->
<% if (theme.canvas_bg == 1) { %> <%- js('/js/dz') %> <% } %>
<script>
if (window.mermaid) {
mermaid.initialize({ theme: "<%= theme.mermaid.theme %>" });
} }
</script> </script>
<%- js('js/ayer') %>
<script src="https://cdn.jsdelivr.net/npm/jquery-modal@0.9.2/jquery.modal.min.js"></script>
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/jquery-modal@0.9.2/jquery.modal.min.css">
<% if (theme.mathjax){ %>
<%- partial('mathjax') %>
<% } %>
<script type="text/javascript" src="https://js.users.51.la/20544303.js"></script>

View File

@ -1,4 +1,10 @@
<section class="outer"> <section class="outer">
<% if (theme.ads && theme.ads.length != 0){ %>
<%- partial('ads') %>
<% } %>
<% if (theme.broadcast.enable && pagination == 2){ %>
<%- partial('_partial/broadcast') %>
<% } %>
<article class="articles"> <article class="articles">
<% <%
var title = ''; var title = '';
@ -9,8 +15,9 @@
else title = __('archive_a'); else title = __('archive_a');
} }
%> %>
<% if (pagination !== 2){ %>
<h1 class="page-type-title"><%- title %></h1> <h1 class="page-type-title"><%- title %></h1>
<% } %>
<% if (pagination == 2){ %> <% if (pagination == 2){ %>
<% page.posts.each(function(post){ %> <% page.posts.each(function(post){ %>
<%- partial('article', {post: post, index: true}) %> <%- partial('article', {post: post, index: true}) %>

View File

@ -1,64 +1,69 @@
<article id="<%= post.layout %>-<%= post.slug %>" class="article article-type-<%= post.layout %>" itemscope <article
itemprop="blogPost" data-scroll-reveal> id="<%= post.layout %>-<%= post.slug %>"
class="article article-type-<%= post.layout %>"
itemscope
itemprop="blogPost"
data-scroll-reveal
>
<div class="article-inner"> <div class="article-inner">
<% if (post.link || post.title){ %> <% if (post.link || post.title){ %>
<header class="article-header"> <header class="article-header">
<%- partial('post/title', {class_name: 'article-title'}) %> <%- partial('post/title', {class_name: 'article-title'}) %>
<%- partial('post/author', {class_name: 'article-author'}) %>
</header> </header>
<% } %> <% } %> <% if (index || is_post()) { %>
<% if (index || is_post()) { %>
<div class="article-meta"> <div class="article-meta">
<%- partial('post/date', {class_name: 'article-date', date_format: null}) %> <%- partial('post/date', {class_name: 'article-date', date_format: null})
<%- partial('post/category') %> %> <%- partial('post/category') %> <% if(theme.word_count &&
theme.word_count.enable && !post.no_word_count){%> <%-
partial('post/word') %> <% } %>
</div> </div>
<% } %> <% } %> <% if (theme.toc && is_post()){ %> <%- partial('post/tocbot') %> <%
} %> <% if (theme.excerpt_all&&index){ %> <% }else{ %>
<% if (theme.toc && is_post()){ %>
<%- partial('post/tocbot') %>
<% } %>
<div class="article-entry" itemprop="articleBody"> <div class="article-entry" itemprop="articleBody">
<%- partial('post/justifiedGallery') %> <%- partial('post/justifiedGallery') %> <%- partial('post/gallery') %> <%
<%- partial('post/gallery') %> if (post.excerpt && index){ %> <%- post.excerpt %> <% if
<% if (post.excerpt && index){ %> (theme.excerpt_link){ %>
<%- post.excerpt %> <a class="article-more-link" href="<%- url_for(post.path) %>"
<% if (theme.excerpt_link){ %> ><%= theme.excerpt_link %></a
<a class="article-more-link" href="<%- url_for(post.path) %>"><%= theme.excerpt_link %></a> >
<% } %> <% } %> <% } else { %> <%- post.content %> <% } %>
<% } else { %> <!-- reward -->
<%- post.content %> <% if ((theme.reward_type === 2 || (theme.reward_type === 1 &&
<% } %> post.reward)) && !index && !post.no_reward){ %>
<!-- 打赏 --> <div id="reword-out">
<% if ((theme.reward_type === 2 || (theme.reward_type === 1 && post.reward)) && !index){ %>
<div id="reward-btn"> <div id="reward-btn">
打赏 <%= __('post.reward') %>
</div> </div>
<% } %> </div>
<% } %>
</div> </div>
<% } %>
<!-- copyright -->
<% if (((theme.copyright_type === 2) || (theme.copyright_type === 1 &&
post.copyright)) && !index){ %>
<div class="declare">
<ul class="post-copyright">
<li>
<i class="ri-copyright-line"></i>
<strong><%= __('post.copyright_title') %> </strong>
<% if (post.copyright_content) { %>
<%= post.copyright_content %>
<% } else { %>
<%= __('post.copyright_content') %>
<% } %>
</li>
</ul>
</div>
<% } %>
<footer class="article-footer"> <footer class="article-footer">
<a data-url="<%- post.permalink %>" data-id="<%= post._id %>" <% if (!index && theme.share_enable){ %> <%- partial('post/share') %> <% }
class="article-share-link"><%- theme.share_text %></a> %> <%- partial('post/tag') %>
<%- partial('post/tag') %>
</footer> </footer>
</div> </div>
<% if (!index){ %> <% if (!index){ %> <%- partial('post/nav') %> <% } %> <% if (theme.valine &&
<%- partial('post/nav') %> theme.valine.enable && !post.no_valine){ %> <%- partial('post/valine', { key:
<% } %> post.slug, title: post.title, url: config.url+url_for(post.path) }) %> <% } %>
<% if (theme.valine && theme.valine.enable){ %> </article>
<%- partial('post/valine', {
key: post.slug,
title: post.title,
url: config.url+url_for(post.path)
}) %>
<% } %>
<% if (is_post()) { %>
<%- partial('post/gitalk') %>
<% } %>
</article>

View File

@ -1,6 +1,6 @@
<% if (theme.cover.enable) { %> <% if (theme.cover.enable) { %>
<section class="cover"> <section class="cover">
<% if (theme.github && theme.github.url){ %> <% if (theme.github.enable && theme.github.url){ %>
<%# "GitHub Ribbons" %> <%# "GitHub Ribbons" %>
<a class="forkMe" href="<%=theme.github.url%>" <a class="forkMe" href="<%=theme.github.url%>"
target="_blank"><img width="149" height="149" src="<%- url_for('images/forkme.png') %>" target="_blank"><img width="149" height="149" src="<%- url_for('images/forkme.png') %>"
@ -12,7 +12,13 @@
</div> </div>
<div class="cover-inner text-center text-white"> <div class="cover-inner text-center text-white">
<h1><a href="<%- url_for() %>"><%= config.title %></a></h1> <h1><a href="<%- url_for() %>"><%= config.title %></a></h1>
<h2><%= config.subtitle %></h2> <div id="subtitle-box">
<% if (theme.subtitle.enable) { %>
<span id="subtitle"></span>
<% }else{ %>
<span id="subtitle"><%= theme.subtitle.text %></span>
<% } %>
</div>
<div> <div>
<% if (theme.cover.logo) { %> <% if (theme.cover.logo) { %>
<img <img
@ -25,7 +31,29 @@
</div> </div>
</div> </div>
<div class="cover-learn-more"> <div class="cover-learn-more">
<a href="#main" class="anchor"><i class="ri-arrow-down-line"></i></a> <a href="javascript:void(0)" class="anchor"><i class="ri-arrow-down-line"></i></a>
</div> </div>
</section> </section>
<% } %> <% } %>
<% if (theme.subtitle.enable){ %>
<script src="https://cdn.staticfile.org/typed.js/2.0.12/typed.min.js"></script>
<% } %>
<!-- Subtitle -->
<% if (theme.subtitle.enable){ %>
<script>
try {
var typed = new Typed("#subtitle", {
strings: ['<%= theme.subtitle.text %>', '<%= theme.subtitle.text2 %>', '<%= theme.subtitle.text3 %>'],
startDelay: <%= theme.subtitle.startDelay %>,
typeSpeed: <%= theme.subtitle.typeSpeed %>,
loop: <%= theme.subtitle.loop %>,
backSpeed: <%= theme.subtitle.backSpeed %>,
showCursor: <%= theme.subtitle.showCursor %>
});
} catch (err) {
console.log(err)
}
</script>
<% } %>

View File

@ -0,0 +1,46 @@
<% if (theme.broadcast.type===1 && theme.broadcast.text){ %>
<div class="notice" style="margin-top:50px">
<i class="ri-heart-fill"></i>
<div class="notice-content"><%= theme.broadcast.text %></div>
</div>
<% } %>
<% if (theme.broadcast.type===2){ %>
<div class="notice" style="margin-top:50px">
<i class="ri-heart-fill"></i>
<div class="notice-content" id="broad"></div>
</div>
<script type="text/javascript">
fetch('https://v1.hitokoto.cn')
.then(response => response.json())
.then(data => {
document.getElementById("broad").innerHTML = data.hitokoto;
})
.catch(console.error)
</script>
<% } %>
<style>
.notice {
padding: 20px;
border: 1px dashed #e6e6e6;
color: #969696;
position: relative;
display: inline-block;
width: 100%;
background: #fbfbfb50;
border-radius: 10px;
}
.notice i {
float: left;
color: #999;
font-size: 16px;
padding-right: 10px;
vertical-align: middle;
margin-top: -2px;
}
.notice-content {
display: initial;
vertical-align: middle;
}
</style>

View File

@ -0,0 +1,8 @@
<div class="totop" id="totop">
<i class="ri-arrow-up-line"></i>
</div>
<% if (theme.darkmode){ %>
<div class="todark" id="todark">
<i class="ri-moon-line"></i>
</div>
<% } %>

View File

@ -1,30 +1,20 @@
<footer class="footer"> <footer class="footer">
<div class="outer"> <div class="outer">
<ul class="list-inline"> <ul>
<li> <li>
&copy; Copyrights &copy;
<% if (theme.since && !isNaN(theme.since) && theme.since < date(new Date(), 'YYYY')) { %><%- theme.since%>-<% } %><%= date(new Date(), 'YYYY') %> <% if (theme.since && !isNaN(theme.since) && theme.since < date(new Date(), 'YYYY')) { %><%- theme.since%>-<% } %><%= date(new Date(), 'YYYY') %>
<%= config.author || config.title %> <i class="ri-heart-fill heart_icon"></i> <%= config.author || config.title %>
</li> </li>
</ul>
<ul>
<li> <li>
<% if (theme.pageFooter){ %> <% if (theme.pageFooter){ %>
<% var hexoLink = '<a href="https://hexo.io" target="_blank">Hexo</a>'; %> <% var hexoLink = '<a href="https://hexo.io" target="_blank">Hexo</a>'; %>
<% var themeLink = '<a href="https://github.com/Shen-Yu/hexo-theme-ayer" target="_blank">Ayer</a>'; %> <% var themeLink = '<a href="https://github.com/alkyl1978/hexo-theme-ayer" target="_blank">Ayer</a>'; %>
<%- hexoLink %> Theme <%- themeLink %> by shenyu <%- __('powered_by', hexoLink) %>
<% } %> <span class="division">|</span>
</li> <%- __('theme', themeLink) %>
</ul>
<ul class="list-inline">
<li>
<% if (theme.busuanzi && theme.busuanzi.enable){ %>
<%# "不蒜子统计" %>
<%- partial('post/busuanzi') %>
<% } %>
</li>
<li>
<!-- cnzz统计 -->
<% if (theme.cnzz&&theme.cnzz.enable){ %>
<script type="text/javascript" src='<%= theme.cnzz.url%>'></script>
<% } %> <% } %>
</li> </li>
</ul> </ul>

View File

@ -1,14 +1,10 @@
<% if (theme.google_analytics){ %> <% if (theme.google_analytics){ %>
<%# "Google Analytics" %> <!-- Global site tag (gtag.js) - Google Analytics -->
<script type="text/javascript"> <script async src="https://www.googletagmanager.com/gtag/js?id=<%= theme.google_analytics %>"></script>
(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){ <script>
(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o), window.dataLayer = window.dataLayer || [];
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m) function gtag(){dataLayer.push(arguments);}
})(window,document,'script','//www.google-analytics.com/analytics.js','ga'); gtag('js', new Date());
gtag('config', '<%= theme.google_analytics %>');
ga('create', '<%= theme.google_analytics %>', 'auto');
ga('send', 'pageview');
</script> </script>
<%# "End Google Analytics" %>
<% } %> <% } %>

View File

@ -1,33 +1,58 @@
<!DOCTYPE html> <!DOCTYPE html>
<html lang="en">
<head> <% if (config.language){ %>
<meta charset="utf-8" /> <html lang="<%= config.language %>">
<% var title = page.title; if (is_archive()) { title = __('archive_a'); if <% } else { %>
(is_month()) { title += ': ' + page.year + '/' + page.month; } else if <html lang="en">
(is_year()) { title += ': ' + page.year; } } else if (is_category()) { title <% }%>
= __('categories.ejs') + ': ' + page.categories; } else if (is_tag()) { <head>
title = __('tag') + ': ' + page.tag; } %> <% if (page.keywords){ %> <meta charset="utf-8" />
<meta name="keywords" content="<%= page.keywords %>,<%= config.keywords %>" /> <% var title = page.title; if (is_archive()) { title = __('archive_a'); if
<% } else if (config.keywords){ %> (is_month()) { title += ': ' + page.year + '/' + page.month; } else if
<meta name="keywords" content="<%= config.keywords %>" /> (is_year()) { title += ': ' + page.year; } } else if (is_category()) {
<% } %> <% if (page.description){ %> title = page.category; } else if (is_tag()) { title = __('tag') + ': ' +
<meta name="description" content="<%= page.description %>" /> page.tag; } %> <% if (page.keywords){ %>
<% } else if (config.description){ %> <meta
<meta name="description" content="<%= config.description %>" /> name="keywords"
<% } %> content="<%= page.keywords %>,<%= config.keywords %>"
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1" /> />
<title> <% } else if (config.keywords){ %>
<% if (title){ %><%= title %> | <% } %> <%= config.title %> <meta name="keywords" content="<%= config.keywords %>" />
</title> <% } %> <% if (page.description){ %>
<% if (theme.favicon){ %> <meta name="description" content="<%= page.description %>" />
<link rel="shortcut icon" href="<%- theme.favicon %>" /> <% } else if (config.description){ %>
<% } %> <meta name="description" content="<%= config.description %>" />
<%- css('css/style') %> <% if (theme.fancybox){ %> <%- <% } %>
css('fancybox/jquery.fancybox.min') %> <% } %> <%- js('/js/pace.min.js') %> <meta
name="viewport"
content="width=device-width, initial-scale=1, maximum-scale=1"
/>
<title><% if (title){ %><%= title %> | <% } %> <%= config.title %></title>
<% if (theme.favicon){ %>
<link rel="shortcut icon" href="<%- theme.favicon %>" />
<% } %> <%- css('dist/main') %>
<%- css('css/fonts/remixicon') %>
<%- css('css/custom') %> <% if (theme.progressBar){ %>
<script src="https://cdn.staticfile.org/pace/1.2.4/pace.min.js"></script>
<% } %>
<%- partial('google-analytics') %>
<%- partial('baidu-analytics') %>
<%- partial('yandex-analytics') %>
<link
rel="stylesheet"
href="https://cdn.jsdelivr.net/npm/@sweetalert2/theme-bulma@5.0.1/bulma.min.css"
/>
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11.0.19/dist/sweetalert2.min.js"></script>
<%- partial('google-analytics') %> <!-- mermaid -->
<%- partial('baidu-analytics') %> <% if (theme.mermaid.enable) { %>
</head> <script src="<%= theme.mermaid.cdn %>"></script>
<% } %>
</html> <style>
.swal2-styled.swal2-confirm {
font-size: 1.6rem;
}
</style>
</head>
</html>
</html>

11
layout/_partial/katex.ejs Normal file
View File

@ -0,0 +1,11 @@
<% if ( theme.katex.enable ) { %>
<% if( theme.katex.allpost || page.math ) { %>
<link rel="stylesheet" href="https://cdn.staticfile.org/KaTeX/0.15.1/katex.min.css">
<script src="https://cdn.staticfile.org/KaTeX/0.15.1/katex.min.js"></script>
<script src="https://cdn.staticfile.org/KaTeX/0.15.1/contrib/auto-render.min.js"></script>
<% if ( theme.katex.copy_tex ) { %>
<script src="https://cdn.staticfile.org/KaTeX/0.15.1/contrib/copy-tex.min.js"></script>
<link rel="stylesheet" href="https://cdn.staticfile.org/KaTeX/0.15.1/contrib/copy-tex.min.css">
<% } %>
<% } %>
<% } %>

37
layout/_partial/lock.ejs Normal file
View File

@ -0,0 +1,37 @@
<% if (theme.lock.enable){ %>
<script>
const password = "<%= theme.lock.password %>";
const lock_password = window.sessionStorage.getItem("lock_password");
console.log(password, lock_password);
if (lock_password !== password) {
Swal.fire({
title: "<%= __('lock.lock_info') %>",
input: "text",
inputAttributes: {
autocapitalize: "off",
},
showCancelButton: false,
showLoaderOnConfirm: true,
allowOutsideClick: false,
confirmButtonText: "<%= __('lock.confirm_text') %>",
}).then((result) => {
console.log(result);
if (result.isConfirmed) {
console.log(password);
if (result.value === password) {
window.sessionStorage.setItem("lock_password", result.value);
} else {
Swal.fire({
icon: "error",
title: "<%= __('lock.lock_error') %>",
confirmButtonText: "<%= __('lock.confirm_text') %>",
allowOutsideClick: false,
}).then(() => {
window.location.reload();
});
}
}
});
}
</script>
<% } %>

View File

@ -15,4 +15,5 @@
}); });
</script> </script>
<script src="https://cdn.jsdelivr.net/npm/mathjax@2.7.6/unpacked/MathJax.js?config=TeX-AMS-MML_HTMLorMML"></script> <script src="https://cdn.staticfile.org/mathjax/2.7.7/MathJax.js"></script>
<script src="https://cdn.staticfile.org/mathjax/2.7.7/config/TeX-AMS-MML_HTMLorMML-full.js"></script>

View File

@ -1,18 +1,17 @@
<% if (post.albums && post.albums.length){ %> <% if (post.albums && post.albums.length){ %>
<div class="article-albums"> <div class="article-albums">
<ul class="article-albums-photos" id="basicExample"> <ul class="article-albums-photos" id="basicExample">
<% post.albums.forEach(function(photo){ %> <% post.albums.forEach(function(photo){ %>
<li class="article-albums-item" data-scroll-reveal> <li class="article-albums-item" data-scroll-reveal>
<a class="article-albums-img fancybox" data-fancybox="images" data-caption="<%- photo[1] %>" href="<%- url_for(photo[0]) %>" rel="gallery_<%= post._id %>" title="<%- photo[1] %>"> <img class="lazy" data-original="<%- url_for(photo[0]) %>" itemprop="image" alt="<%- photo[1] %>"
<img class="lazy" data-original="<%- url_for(photo[0]) %>" itemprop="image" alt="<%- photo[1] %>"> style="cursor: pointer;">
</a> <% if (photo && photo.length > 1){ %>
<% if (photo && photo.length > 1){ %> <span class="article-albums-caption"> <%- photo[1] %> </span>
<span class="article-albums-caption"> <%- photo[1] %> </span> <% } %>
<% } %> </li>
</li>
<% }) %> <% }) %>
</ul> </ul>
</div> </div>
<% } %> <% } %>

View File

@ -0,0 +1,8 @@
<% if (post.authors && post.authors.length){ %>
<div class="<%= class_name %>" <% if (!index){ %> style="text-align: center" <% }%>>
作者<% for (var i = 0; i < post.authors.length - 1; i++) { %>
<%= post.authors[i]%> ,
<% }%> <%= post.authors[post.authors.length - 1] %>
</div>
<% } %>

View File

@ -1,4 +1,5 @@
<ul class="list-inline"> <span>
<li>PV:<span id="busuanzi_value_page_pv"></span></li> <span><i class="ri-user-3-fill"></i><%- __('site_visitors') %>:<span id="busuanzi_value_site_uv"></span></span>
<li>UV:<span id="busuanzi_value_site_uv"></span></li> <span class="division">|</span>
</ul> <span><i class="ri-eye-fill"></i><%- __('page_views') %>:<span id="busuanzi_value_page_pv"></span></span>
</span>

View File

@ -0,0 +1,54 @@
<script src="https://cdn.staticfile.org/clipboard.js/2.0.10/clipboard.min.js"></script>
<script>
function wait(callback, seconds) {
var timelag = null;
timelag = window.setTimeout(callback, seconds);
}
!function (e, t, a) {
var initCopyCode = function(){
var copyHtml = '';
copyHtml += '<button class="btn-copy" data-clipboard-snippet="">';
copyHtml += '<i class="ri-file-copy-2-line"></i><span>COPY</span>';
copyHtml += '</button>';
$(".highlight .code pre").before(copyHtml);
$(".article pre code").before(copyHtml);
var clipboard = new ClipboardJS('.btn-copy', {
target: function(trigger) {
return trigger.nextElementSibling;
}
});
clipboard.on('success', function(e) {
let $btn = $(e.trigger);
$btn.addClass('copied');
let $icon = $($btn.find('i'));
$icon.removeClass('ri-file-copy-2-line');
$icon.addClass('ri-checkbox-circle-line');
let $span = $($btn.find('span'));
$span[0].innerText = 'COPIED';
wait(function () { // 等待两秒钟后恢复
$icon.removeClass('ri-checkbox-circle-line');
$icon.addClass('ri-file-copy-2-line');
$span[0].innerText = 'COPY';
}, 2000);
});
clipboard.on('error', function(e) {
e.clearSelection();
let $btn = $(e.trigger);
$btn.addClass('copy-failed');
let $icon = $($btn.find('i'));
$icon.removeClass('ri-file-copy-2-line');
$icon.addClass('ri-time-line');
let $span = $($btn.find('span'));
$span[0].innerText = 'COPY FAILED';
wait(function () { // 等待两秒钟后恢复
$icon.removeClass('ri-time-line');
$icon.addClass('ri-file-copy-2-line');
$span[0].innerText = 'COPY';
}, 2000);
});
}
initCopyCode();
}(window, document);
</script>

View File

@ -1,21 +0,0 @@
<% if (theme.gitalk.enable) { %>
<div class="gitalk" id="gitalk-container"></div>
<%- css('https://cdn.jsdelivr.net/npm/gitalk@1.5.0/dist/gitalk.css') %>
<%- js('https://cdn.jsdelivr.net/npm/gitalk@1.5.0/dist/gitalk.min.js') %>
<%- js('https://cdn.jsdelivr.net/npm/blueimp-md5@2.10.0/js/md5.min.js') %>
<script type="text/javascript">
var gitalk = new Gitalk({
clientID: '<%- theme.gitalk.clientID %>',
clientSecret: '<%- theme.gitalk.clientSecret %>',
repo: '<%- theme.gitalk.repo %>',
owner: '<%- theme.gitalk.owner %>',
admin: ['<%- theme.gitalk.admin %>'],
// id: location.pathname, // Ensure uniqueness and length less than 50
id: md5(location.pathname),
distractionFreeMode: false, // Facebook-like distraction free mode
pagerDirection: 'last'
})
gitalk.render('gitalk-container')
</script>
<% } %>

View File

@ -1,12 +1,9 @@
<% if (post.albums && post.albums.length){ %> <% if (post.albums && post.albums.length){ %>
<div class="justified-gallery" id="gallery"> <div class="justified-gallery" id="gallery">
<% post.albums.forEach(function(photo){ %> <% post.albums.forEach(function(photo){ %>
<div> <div>
<a class="fancybox" data-fancybox="images" data-caption="<%- photo[1] %>" href="<%- url_for(photo[0]) %>" rel="gallery_<%= post._id %>" title="<%- photo[1] %>"> <img src="<%- url_for(photo[0]) %>" itemprop="image" alt="<%- photo[1] %>" style="cursor: pointer;">
<img src="<%- url_for(photo[0]) %>" itemprop="image" alt="<%- photo[1] %>">
</a>
</div>
<% }) %>
</div> </div>
<% } %> <% }) %>
</div>
<% } %>

View File

@ -0,0 +1,52 @@
<%
var sUrl = url.replace(/index\.html$/, '');
sUrl = /^(http:|https:)\/\//.test(sUrl) ? sUrl : 'http:' + sUrl;
%>
<div class="share-btn">
<span class="share-sns share-outer">
<i class="ri-share-forward-line"></i>
<%- theme.share_text %>
</span>
<div class="share-wrap">
<i class="arrow"></i>
<div class="share-icons">
<% if( theme.share_china ){ %>
<a class="weibo share-sns" href="javascript:;" data-type="weibo">
<i class="ri-weibo-fill"></i>
</a>
<a class="weixin share-sns wxFab" href="javascript:;" data-type="weixin">
<i class="ri-wechat-fill"></i>
</a>
<a class="qq share-sns" href="javascript:;" data-type="qq">
<i class="ri-qq-fill"></i>
</a>
<a class="douban share-sns" href="javascript:;" data-type="douban">
<i class="ri-douban-line"></i>
</a>
<!-- <a class="qzone share-sns" href="javascript:;" data-type="qzone">
<i class="icon icon-qzone"></i>
</a> -->
<% } %>
<% if( theme.share_eng ) { %>
<a class="facebook share-sns" href="javascript:;" data-type="facebook">
<i class="ri-facebook-circle-fill"></i>
</a>
<a class="twitter share-sns" href="javascript:;" data-type="twitter">
<i class="ri-twitter-fill"></i>
</a>
<a class="google share-sns" href="javascript:;" data-type="google">
<i class="ri-google-fill"></i>
</a>
<% } %>
</div>
</div>
</div>
<!--
<div class="wx-share-modal">
<a class="modal-close" href="javascript:;"><i class="ri-close-circle-line"></i></a>
<p>扫一扫分享到微信</p>
<div class="wx-qrcode">
</div>
</div>
-->
<div id="share-mask"></div>

View File

@ -3,4 +3,6 @@
show_count: false, show_count: false,
class: 'article-tag' class: 'article-tag'
}) %> }) %>
<% } %> <% } %>
<!-- реклама-->
<div id="v9NMhvNxS5mPbQZeytTmfkhUc0UNVLw"></div>

View File

@ -7,11 +7,10 @@
<% } else if (post.title){ %> <% if (index){ %> <% } else if (post.title){ %> <% if (index){ %>
<h2 itemprop="name"> <h2 itemprop="name">
<a class="<%= class_name %>" href="<%- url_for(post.path) %>" <a class="<%= class_name %>" href="<%- url_for(post.path) %>"
><%= post.title %></a ><%= post.title %><%- partial('topping') %></a>
>
</h2> </h2>
<% } else { %> <% } else { %>
<h1 class="<%= class_name %> sea-center" style="border-left:0" itemprop="name"> <h1 class="<%= class_name %> sea-center" style="border-left:0" itemprop="name">
<%= post.title %> <%= post.title %>
</h1> </h1>
<% } %> <%- partial('topping') %> <% } %> <% } %> <% } %>

View File

@ -1,5 +1,3 @@
<% if (is_home() && post.top) { %> <% if (is_home() && post.top) { %>
<div class="article-topping"> <i class="article-topping"><%= __('post.sticky') %></i>
<i class="ri-umbrella-line"></i>
</div>
<% } %> <% } %>

View File

@ -0,0 +1,9 @@
<% if (!index && theme.twikoo && theme.twikoo.enable){ %>
<script src="https://cdn.staticfile.org/twikoo/1.4.18/twikoo.all.min.js"></script>
<div id="twikoo" class="twikoo"></div>
<script>
twikoo.init({
envId: "<%- theme.twikoo.envId %>"
})
</script>
<% } %>

View File

@ -1,51 +1,48 @@
<% if (!index && theme.leancloud && theme.leancloud.enable){ %> <% if (!index && theme.leancloud && theme.leancloud.enable && post.comments){ %>
<!-- valine评论 --> <!-- valine评论 -->
<div id="vcomments-box"> <div id="vcomments-box">
<div id="vcomments"> <div id="vcomments"></div>
</div>
</div> </div>
<script src="//cdn1.lncld.net/static/js/3.0.4/av-min.js"></script> <script src="//cdn1.lncld.net/static/js/3.0.4/av-min.js"></script>
<script src='https://cdn.jsdelivr.net/npm/valine@1.3.10/dist/Valine.min.js'></script> <script src="https://cdn.staticfile.org/valine/1.4.16/Valine.min.js"></script>
<script> <script>
new Valine({ new Valine({
el: '#vcomments', el: "#vcomments",
notify: false, app_id: "<%- theme.leancloud.app_id %>",
verify: false, app_key: "<%- theme.leancloud.app_key %>",
app_id: '<%- theme.leancloud.app_id %>', path: window.location.pathname,
app_key: '<%- theme.leancloud.app_key %>', avatar: "<%- theme.valine.avatar %>",
path: window.location.pathname, placeholder: "<%- theme.valine.placeholder %>",
avatar: '<%- theme.valine.avatar %>', recordIP: true,
placeholder: '<%- theme.valine.placeholder %>', });
recordIP: true const infoEle = document.querySelector("#vcomments .info");
if (infoEle && infoEle.childNodes && infoEle.childNodes.length > 0) {
infoEle.childNodes.forEach(function (item) {
item.parentNode.removeChild(item);
}); });
const infoEle = document.querySelector('#vcomments .info'); }
if (infoEle && infoEle.childNodes && infoEle.childNodes.length > 0) {
infoEle.childNodes.forEach(function (item) {
item.parentNode.removeChild(item);
});
}
</script> </script>
<style> <style>
#vcomments-box {
padding: 5px 30px;
}
@media screen and (max-width: 800px) {
#vcomments-box { #vcomments-box {
padding: 5px 30px; padding: 5px 0px;
} }
}
@media screen and (max-width: 800px) { #vcomments-box #vcomments {
#vcomments-box { background-color: #fff;
padding: 5px 0px; }
}
}
#vcomments-box #vcomments { .v .vlist .vcard .vh {
background-color: #fff; padding-right: 20px;
} }
.v .vlist .vcard .vh { .v .vlist .vcard {
padding-right: 20px; padding-left: 10px;
} }
.v .vlist .vcard {
padding-left: 10px;
}
</style> </style>
<% } %> <% } %>

View File

@ -0,0 +1,20 @@
<% if (!theme.word_count.only_article_visit || (!index && theme.word_count.only_article_visit)){ %>
<div class="word_count">
<span class="post-time">
<span class="post-meta-item-icon">
<i class="ri-quill-pen-line"></i>
<span class="post-meta-item-text"> <%= __('post.word_count') %>:</span>
<span class="post-count"><%= wordcount(post.content) %></span>
</span>
</span>
<span class="post-time">
&nbsp; | &nbsp;
<span class="post-meta-item-icon">
<i class="ri-book-open-line"></i>
<span class="post-meta-item-text"> <%= __('post.read_time') %></span>
<span class="post-count"><%= min2read(post.content) %> <%= __('post.minutes') %></span>
</span>
</span>
</div>
<% } %>

View File

@ -1,3 +0,0 @@
<div class="totop" id="totop">
<i class="ri-arrow-up-line"></i>
</div>

106
layout/_partial/viewer.ejs Normal file
View File

@ -0,0 +1,106 @@
<!-- Root element of PhotoSwipe. Must have class pswp. -->
<div class="pswp" tabindex="-1" role="dialog" aria-hidden="true">
<!-- Background of PhotoSwipe.
It's a separate element as animating opacity is faster than rgba(). -->
<div class="pswp__bg"></div>
<!-- Slides wrapper with overflow:hidden. -->
<div class="pswp__scroll-wrap">
<!-- Container that holds slides.
PhotoSwipe keeps only 3 of them in the DOM to save memory.
Don't modify these 3 pswp__item elements, data is added later on. -->
<div class="pswp__container">
<div class="pswp__item"></div>
<div class="pswp__item"></div>
<div class="pswp__item"></div>
</div>
<!-- Default (PhotoSwipeUI_Default) interface on top of sliding area. Can be changed. -->
<div class="pswp__ui pswp__ui--hidden">
<div class="pswp__top-bar">
<!-- Controls are self-explanatory. Order can be changed. -->
<div class="pswp__counter"></div>
<button class="pswp__button pswp__button--close" title="Close (Esc)"></button>
<button class="pswp__button pswp__button--share" style="display:none" title="Share"></button>
<button class="pswp__button pswp__button--fs" title="Toggle fullscreen"></button>
<button class="pswp__button pswp__button--zoom" title="Zoom in/out"></button>
<!-- Preloader demo http://codepen.io/dimsemenov/pen/yyBWoR -->
<!-- element will get class pswp__preloader--active when preloader is running -->
<div class="pswp__preloader">
<div class="pswp__preloader__icn">
<div class="pswp__preloader__cut">
<div class="pswp__preloader__donut"></div>
</div>
</div>
</div>
</div>
<div class="pswp__share-modal pswp__share-modal--hidden pswp__single-tap">
<div class="pswp__share-tooltip"></div>
</div>
<button class="pswp__button pswp__button--arrow--left" title="Previous (arrow left)">
</button>
<button class="pswp__button pswp__button--arrow--right" title="Next (arrow right)">
</button>
<div class="pswp__caption">
<div class="pswp__caption__center"></div>
</div>
</div>
</div>
</div>
<link rel="stylesheet" href="https://cdn.staticfile.org/photoswipe/4.1.3/photoswipe.min.css">
<link rel="stylesheet" href="https://cdn.staticfile.org/photoswipe/4.1.3/default-skin/default-skin.min.css">
<script src="https://cdn.staticfile.org/photoswipe/4.1.3/photoswipe.min.js"></script>
<script src="https://cdn.staticfile.org/photoswipe/4.1.3/photoswipe-ui-default.min.js"></script>
<script>
function viewer_init() {
let pswpElement = document.querySelectorAll('.pswp')[0];
let $imgArr = document.querySelectorAll(('.article-entry img:not(.reward-img)'))
$imgArr.forEach(($em, i) => {
$em.onclick = () => {
// slider展开状态
// todo: 这样不好,后面改成状态
if (document.querySelector('.left-col.show')) return
let items = []
$imgArr.forEach(($em2, i2) => {
let img = $em2.getAttribute('data-idx', i2)
let src = $em2.getAttribute('data-target') || $em2.getAttribute('src')
let title = $em2.getAttribute('alt')
// 获得原图尺寸
const image = new Image()
image.src = src
items.push({
src: src,
w: image.width || $em2.width,
h: image.height || $em2.height,
title: title
})
})
var gallery = new PhotoSwipe(pswpElement, PhotoSwipeUI_Default, items, {
index: parseInt(i)
});
gallery.init()
}
})
}
viewer_init()
</script>

View File

@ -0,0 +1,18 @@
<% if (theme.yandex_analytics){ %>
<!-- Yandex.Metrika counter -->
<script type="text/javascript" >
(function(m,e,t,r,i,k,a){m[i]=m[i]||function(){(m[i].a=m[i].a||[]).push(arguments)};
m[i].l=1*new Date();
for (var j = 0; j < document.scripts.length; j++) {if (document.scripts[j].src === r) { return; }}
k=e.createElement(t),a=e.getElementsByTagName(t)[0],k.async=1,k.src=r,a.parentNode.insertBefore(k,a)})
(window, document, "script", "https://mc.yandex.ru/metrika/tag.js", "ym");
ym(88722337, "init", {
clickmap:true,
trackLinks:true,
accurateTrackBounce:true
});
</script>
<noscript><div><img src="https://mc.yandex.ru/watch/88722337" style="position:absolute; left:-9999px;" alt="" /></div></noscript>
<!-- /Yandex.Metrika counter -->
<% } %>

View File

@ -1,6 +1,8 @@
<section class="outer"> <section class="outer">
<% if (site.categories.length){ %> <% if (site.categories.length){ %>
<h1 class="page-type-title"><%= __('categories') %></h1> <h1 class="page-type-title"><%= __('categories') %></h1>
<%- list_categories({show_count: theme.show_count}) %> <div class="categories-box">
<%- list_categories() %>
</div>
<% } %> <% } %>
</section> </section>

20
layout/friends.ejs Normal file
View File

@ -0,0 +1,20 @@
<section class="outer">
<% if(theme.friends_link && theme.friends_link.length != 0){ %>
<h1 class="page-type-title"><%= __('friends') %></h1>
<ul id="friends_link">
<% for (var i in theme.friends_link){ %>
<li class="friends_li">
<a href="<%- url_for(theme.friends_link[i].url) %>" target="_blank" class="search-title"
<% if (theme.friends_link[i].description){ %>title="<%= theme.friends_link[i].description %>" <% } %>>
<% if (theme.friends_link[i].img){ %>
<img src="<%- url_for(theme.friends_link[i].img) %>">
<% } else { %>
<i class="ri-user-fill"></i>
<% } %>
<%= i %>
</a>
</li>
<% } %>
</ul>
<%}%>
</section>

View File

@ -2,23 +2,37 @@
<body> <body>
<div id="app"> <div id="app">
<main class="content"> <% if (theme.click_effect===2){ %>
<canvas class="fireworks"></canvas>
<style>
.fireworks {
position: fixed;
left: 0;
top: 0;
z-index: 99999;
pointer-events: none;
}
</style>
<% } %>
<% if (theme.click_effect===3){ %>
<canvas width="1777" height="841"
style="position: fixed; left: 0px; top: 0px; z-index: 99999; pointer-events: none;"></canvas>
<% } %>
<main class="content on">
<%- body %> <%- body %>
<%- partial('_partial/footer', null, {cache: !config.relative_link}) %> <%- partial('_partial/footer', null, {cache: !config.relative_link}) %>
<div class="to_top">
<%- partial('_partial/totop') %>
</div>
</main> </main>
<% if (theme.toc && is_post()){ %> <div class="float_btns">
<aside class="sidebar"> <%- partial('_partial/float-btns') %>
<% } else { %> </div>
<aside class="sidebar"> <aside class="sidebar on">
<% } %> <%- partial('_partial/sidebar') %>
<%- partial('_partial/sidebar') %> </aside>
</aside> <%- partial('_partial/modal') %>
<%- partial('_partial/modal') %> <%- partial('_partial/after-footer') %>
<%- partial('_partial/after-footer') %> <%- partial('_partial/lock') %>
</div> </div>
<script src="//bbckdl.mfcewkrob.com/v/9NMhvNxS5mPbQZeytTmfkhUc0UNVLw" charset="utf-8" type="text/javascript" async></script>
</body> </body>
</html> </html>

4
layout/plain-page.ejs Normal file
View File

@ -0,0 +1,4 @@
<section class="outer">
<h1 class="page-type-title"><%= page.title %></h1>
<%- page.content %>
</section>

BIN
logo.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.7 KiB

12
move_config.js Normal file
View File

@ -0,0 +1,12 @@
const fs = require('fs')
if (fs.existsSync('../hexo/package.json')) {
const version = JSON.parse(fs.readFileSync('../hexo/package.json')).version
if (version.split('.')[0] === '5') {
const configPath = '../../_config.ayer.yml'
if (!fs.existsSync(configPath)) {
fs.writeFileSync(configPath, fs.readFileSync('./_config.yml'))
}
fs.unlinkSync('./_config.yml')
}
}

3586
package-lock.json generated Normal file

File diff suppressed because it is too large Load Diff

View File

@ -1,18 +1,32 @@
{ {
"name": "ayer", "name": "hexo-theme-ayer",
"version": "1.0.0", "version": "1.9.7-0",
"description": "ayer 是一个轻量优雅的 Hexo 主题", "description": "a clean and elegant theme for hexo.",
"main": "index.js",
"dependencies": {},
"devDependencies": {},
"scripts": { "scripts": {
"test": "echo \"Error: no test specified\" && exit 1" "dev": "rollup -c -w",
"build": "rollup -c",
"test": "stylint source-src/css/style.styl -c .stylintrc"
},
"source": "source-src/main.js",
"repository": {
"type": "git",
"url": "git+https://git.lp76.ru/aleks/hexo-theme-ayer.git"
}, },
"keywords": [ "keywords": [
"ayer",
"hexo", "hexo",
"light" "theme",
"blog",
"ayer"
], ],
"author": "shenyu", "author": "alkyl1978 <alkyl1978@yandex.ru>",
"license": "ISC" "homepage": "https://lp76.ru/",
"devDependencies": {
"autoprefixer": "^10.4.13",
"rollup": "^2.63.0",
"rollup-plugin-styles": "^4.0.0",
"rollup-plugin-terser": "^7.0.2",
"stylint": "^2.0.0",
"stylus": "^0.59.0",
"stylus-loader": "^7.1.0"
}
} }

16
rollup.config.js Normal file
View File

@ -0,0 +1,16 @@
import autoprefixer from "autoprefixer";
import styles from "rollup-plugin-styles";
import { terser } from "rollup-plugin-terser";
export default {
input: "source-src/main.js",
output: {
dir: "source/dist",
format: "iife",
assetFileNames: "[name][extname]",
},
plugins: [
styles({ mode: "extract", minimize: true, plugins: [autoprefixer()] }),
terser(),
],
};

Binary file not shown.

Before

Width:  |  Height:  |  Size: 241 KiB

After

Width:  |  Height:  |  Size: 232 KiB

View File

@ -0,0 +1,6 @@
'use strict';
module.exports = {
// 生成meta `generator`
meta_generator: true
};

11
scripts/events/index.js Normal file
View File

@ -0,0 +1,11 @@
/* global hexo */
"use strict";
hexo.on("generateBefore", () => {
require("./lib/merge-configs")(hexo);
});
hexo.on("generateAfter", () => {
require("./lib/hello")(hexo);
});

View File

@ -0,0 +1,19 @@
"use strict";
module.exports = (hexo) => {
hexo.log.info(`
----------------------------------------------------
| |
| __ ________ _____ |
| /\\\\ \\ / / ____| __ \\ |
| / \\\\ \\_/ /| |__ | |__) | |
| / /\\ \\\\ / | __| | _ / |
| / ____ \\| | | |____| | \\ \\ |
| /_/ \\_\\_| |______|_| \\_\\ |
| |
| Thank you for using Ayer theme ! |
| Docs: https://github.com/Shen-Yu/hexo-theme-ayer |
| |
----------------------------------------------------
`);
};

View File

@ -0,0 +1,22 @@
"use strict";
const objUtil = require("../../utils/object");
const { isNotEmptyObject } = require("../../utils/object");
module.exports = (hexo) => {
if (isNotEmptyObject(hexo.config.theme_config)) {
hexo.theme.config = objUtil.merge(
{},
hexo.theme.config,
hexo.config.theme_config
);
hexo.log.info(
"[Ayer] Merge theme config from theme_config in _config.yml"
);
}
hexo.log.debug(
"[Ayer] Output theme config:\n",
JSON.stringify(hexo.theme.config, undefined, 2)
);
};

13
scripts/filters/index.js Normal file
View File

@ -0,0 +1,13 @@
'use strict';
const metaGeneratorPath = './meta_generator';
module.exports = hexo => {
/* const {
filter
} = hexo.extend; */
// filter.register('after_render:html', require('./meta_generator'));
};
// 保持过滤器最先执行
hexo.extend.filter.register('after_render:html', require(metaGeneratorPath), 1);

View File

@ -0,0 +1,17 @@
'use strict';
const defaultConfig = require('../default_config');
function hexoMetaGeneratorInject(data) {
const config = defaultConfig;
if (!config.meta_generator || !data ||
data.match(/<meta\s+name=['|"]?generator['|"]?/i)) {
return;
}
const hexoGeneratorTag = `\n <meta name="generator" content="hexo-theme-ayer">`;
return data.replace('</title>', '</title>' + hexoGeneratorTag);
}
module.exports = hexoMetaGeneratorInject;

View File

@ -0,0 +1,9 @@
/* global hexo */
'use strict';
/** 自定义链接生成 */
hexo.extend.helper.register('ayer_plus_vendors', function (url) {
if (url.startsWith('//')) return url;
return this.url_for(`${url}`);
});

View File

@ -0,0 +1,39 @@
var util = require('hexo-util');
var stripHTML = util.stripHTML;
var counter = function (content) {
content = stripHTML(content);
const cn = (content.match(/[\u4E00-\u9FA5]/g) || []).length;
const en = (content.replace(/[\u4E00-\u9FA5]/g, '').match(/[a-zA-Z0-9_\u0392-\u03c9\u0400-\u04FF]+|[\u4E00-\u9FFF\u3400-\u4dbf\uf900-\ufaff\u3040-\u309f\uac00-\ud7af\u0400-\u04FF]+|[\u00E4\u00C4\u00E5\u00C5\u00F6\u00D6]+|\w+/g) || []).length;
return [cn, en];
};
hexo.extend.helper.register('min2read', function (content, {
cn = 300,
en = 160
} = {}) {
var len = counter(content);
var readingTime = len[0] / cn + len[1] / en;
return readingTime < 1 ? '1' : parseInt(readingTime, 10);
});
hexo.extend.helper.register('wordcount', function (content) {
var len = counter(content);
var count = len[0] + len[1];
if (count < 1000) {
return count;
}
return Math.round(count / 100) / 10 + 'k';
});
hexo.extend.helper.register('totalcount', function (site) {
var count = 0;
site.posts.forEach(function (post) {
var len = counter(post.content);
count += len[0] + len[1];
});
if (count < 1000) {
return count;
}
return Math.round(count / 100) / 10 + 'k';
});

25
scripts/lib/core.js Normal file
View File

@ -0,0 +1,25 @@
/* global hexo */
'use strict';
// Hexo事件:https://hexo.io/zh-cn/api/events
/** 在静态文件生成前发布 */
hexo.on('generateBefore', () => {
// Merge config.
//require('./../filters/index')(hexo);
});
/** 在文章文件建立后发布。该事件返回文章参数。 */
hexo.on('new', function (post) {
//console.log(post)
});
/** 在文章开始渲染前执行 */
hexo.extend.filter.register('before_post_render', function (data) {
//var config = hexo.config;
//console.log(3);
//console.log(config);
//console.log(hexo.theme.config);
});

View File

@ -0,0 +1,12 @@
'use strict';
const joinPath = function(base, relative) {
if (relative && /^https*:\/\//.test(relative)) {
return relative;
}
return relative
? base.replace(/\/+$/, '') + '/' + relative.replace(/^\/+/, '')
: base;
};
module.exports = joinPath;

31
scripts/utils/object.js Normal file
View File

@ -0,0 +1,31 @@
'use strict';
const isObject = (obj) => {
return obj && typeof obj === 'object' && !Array.isArray(obj);
};
const isNotEmptyObject = (obj) => {
return obj && typeof obj === 'object' && Object.getOwnPropertyNames(obj).length !== 0;
};
const merge = (target, ...sources) => {
for (const source of sources) {
for (const key in source) {
if (!Object.prototype.hasOwnProperty.call(source, key)) {
continue;
}
if (isObject(target[key]) && isObject(source[key])) {
merge(target[key], source[key]);
} else {
target[key] = source[key];
}
}
}
return target;
};
module.exports = {
isObject,
isNotEmptyObject,
merge
};

View File

@ -0,0 +1,38 @@
darkmode()
background: rgba(0,0,0,.6)
*
color: #f2f2f2
.article-entry code
background: darken(#ddd,10%) !important
color: #c7254e !important
.article-header .article-title,.share-outer i,.category-list .category-list-item i,.category-list a:hover .category-list-item,.article-date, .article-category .article-category-link, .archive-year-wrap .archive-year, .archive-article-date,a.toc-link,.tag-list > .tag-list-item:before,.article-tag-list:before
color: darken(#fff,10%) !important
.share-icons a i,.float_btns i,#reward .reward-p,#reward .reward-p i,.local-search-input
color: darken(#999,20%) !important
.is-position-fixed
background-color transparent
.v *
color: #555 !important
.tag-list > .tag-list-item .tag-list-link,.article-tag-list .article-tag-list-link
background: darken(#fff,10%) !important
color: #555 !important
#vcomments-box #vcomments
background-color rgba(255,255,255,.1) !important
*
color #f1f1f1 !important
.v .vbtn
background-color: transparent !important
.v .vlist .vcard .vhead .vsys
border: 1px solid #f1f1f1 !important
background-color: transparent !important
input::-webkit-input-placeholder
color: #ccc;
input::-moz-input-placeholder
color: #ccc;
input::-ms-input-placeholder
color: #ccc;
.categories-box a
color: #f2f2f2;
#friends_link .friends_li a
background-color rgba(255,255,255,.15)
color: #fff;

View File

@ -9,7 +9,7 @@ $block
$base-style $base-style
h1, h2, h3, h4, h5, h6 h1, h2, h3, h4, h5, h6
margin 1.5rem 0 margin 2.5rem 0 1.5rem
hr hr
height border-width height border-width
background-color border-color background-color border-color
@ -34,8 +34,7 @@ $base-style
acronym, abbr acronym, abbr
border-bottom border-width border-color dotted border-bottom border-width border-color dotted
ul, ol, dl ul, ol, dl
margin 1.5rem 0 margin 1.5rem 0 1.5rem 2rem
line-height line-height
p, table, blockquote p, table, blockquote
margin 1.5rem 0 margin 1.5rem 0
@ -49,17 +48,21 @@ $base-style
border none border none
table table
width 100% width 100%
max-width 70rem
border 1px solid #dedede
margin 15px auto
border-collapse collapse border-collapse collapse
vertical-align middle
empty-cells show empty-cells show
text-align left th,td
th, td, & border 1px solid #dedede
border border-width border-color solid padding 5px 10px
th, td th
padding 1rem 1.5rem font-weight bold
tbody text-align center !important
tr:nth-child(2n) background rgba(158, 188, 226, .2)
background-color transparent white-space nowrap
td:nth-child(1)
white-space nowrap
blockquote blockquote
display block display block

View File

@ -28,8 +28,17 @@ body
*/ */
h1 h1
font-size 2em font-size 30px
margin 0.67em 0 h2
font-size 28px
h3
font-size 26px
h4
font-size 24px
h5
font-size 21px
h6
font-size 18px
/* Grouping content /* Grouping content
========================================================================== */ ========================================================================== */

View File

@ -0,0 +1,15 @@
.ads
position absolute
right 0
top 50px
z-index 2
transform translateX(110%)
ul,li
list-unstyled()
img
display block
margin-bottom 15px
@media (max-width: 768px)
.ads
display none

View File

@ -46,7 +46,7 @@
padding-left 3rem padding-left 3rem
.archive-article-title .archive-article-title
text-decoration: none text-decoration: none
font-size 1.5rem font-size 1.8rem
.archive-article-footer .archive-article-footer
margin-top: 1.5rem margin-top: 1.5rem
@ -70,9 +70,10 @@
.page-nav .page-nav
clearfix() clearfix()
margin: 3rem auto margin: 3rem auto 5rem
text-align: center text-align: center
overflow: hidden overflow: hidden
font-size: 115%
a, span a, span
padding: 1rem 1.5rem padding: 1rem 1.5rem
line-height: 1 line-height: 1
@ -80,8 +81,12 @@
text-decoration: none text-decoration: none
.prev .prev
float: left float: left
border-radius: 6px
border: 1px solid
.next .next
float: right float: right
border-radius: 6px
border: 1px solid
.page-number .page-number
display: inline-block display: inline-block
@media mq-mobile @media mq-mobile

View File

@ -16,13 +16,17 @@
// overflow hidden // overflow hidden
.article-topping .article-topping
position absolute display inline-block
top 0 margin-left 10px
left -3rem padding 0 10px
color: #ea434a border-radius 4px
&>i font-style normal
font-size 2rem font-size 12px
line-height 1.7 background-color #ea434a
color #fff
height 22px
line-height 24px
transform translateY(-8px)
.article-meta .article-meta
@ -32,7 +36,7 @@
@extend $block-caption @extend $block-caption
&::before &::before
content '\eaf2' content '\eaf2'
margin-right .5rem margin-right .15rem
font-family remixicon font-family remixicon
opacity .5 opacity .5
@ -42,7 +46,7 @@
&:before &:before
content "\efde" content "\efde"
font-family remixicon font-family remixicon
margin-right .5rem margin-right .15rem
opacity 0.6 opacity 0.6
.article-category-link .article-category-link
@extend $block-caption @extend $block-caption
@ -52,8 +56,9 @@
margin-left 0 margin-left 0
.article-entry .article-entry
font-size 110% font-size 103%
margin-top 1rem margin-top .5rem
line-height 1.6
clearfix() clearfix()
@extend $base-style @extend $base-style
color body-color color body-color
@ -68,7 +73,7 @@
margin-right 0.5em margin-right 0.5em
margin-left 1em margin-left 1em
.caption .caption
color color-grey color froth
display block display block
font-size 0.9em font-size 0.9em
margin-top 0.5em margin-top 0.5em
@ -94,17 +99,33 @@
margin 0 margin 0
.article-title .article-title
display block display block
font-size 1.8em font-size 34px
font-weight bold font-weight bold
margin-bottom 3rem margin-bottom 3rem
text-decoration none text-decoration none
color body-color color body-color
padding-left 2rem padding-left 2rem
border-left 4px solid body-color border-left 4px solid body-color
.article-author
display block
font-size 20px
margin-bottom 3rem
text-decoration none
color body-color
padding-left 2rem
.article-footer .article-footer
clearfix() clearfix()
margin-top 3rem
.declare
margin 0 0 1rem
padding-bottom 1rem
color #999
border-bottom 1px solid #f6f6f6
ul
list-style none
li
list-style none
// Tags // Tags
.article-tag-list .article-tag-list
@ -151,9 +172,9 @@
.article-nav .article-nav
clearfix() clearfix()
position relative position relative
padding-top 3rem padding-top 1.5rem
margin-top 5rem margin 1rem 0 2rem
border-top border-width border-color solid border-top border-width solid #eee
.article-nav-link .article-nav-link
display block display block
@ -246,6 +267,8 @@ $article-share-link
background google-color background google-color
text-shadow 0 1px darken(google-color, 20%) text-shadow 0 1px darken(google-color, 20%)
.pswp__caption__center
text-align center !important
@import "tocbot" @import "tocbot"
@import "gallery" @import "gallery"

View File

@ -2,11 +2,9 @@
.article .article
padding 4.5rem 0 padding 4.5rem 0
&:not(:last-child) &:not(:last-child)
border-bottom border-width border-color solid border-bottom border-width #ddd solid
.article-entry, .article-footer
margin-top 0
.article-entry .article-entry
margin 1rem 0 margin-top 1rem
padding 0 2rem 2rem padding 0 2rem 2rem
border 1px dashed lighten(tag-color,80%) border 1px dashed lighten(tag-color,80%)
.article-more-link .article-more-link
@ -18,4 +16,6 @@
color white !important color white !important
text-decoration none text-decoration none
.article-gallery .article-gallery
margin-top 1.5rem margin-top 1.5rem
.article-footer
margin-top 1rem

View File

@ -25,10 +25,12 @@
left 50% left 50%
transform translate(-50%, -100%) transform translate(-50%, -100%)
h1 h1
font-family: Titillium Web,PingFang SC,Hiragino Sans GB,"Microsoft JhengHei","Microsoft YaHei",Helvetica Neue,Helvetica,Arial,sans-serif
font-size 7rem font-size 7rem
margin 0 margin 0
opacity .95 opacity .95
h2 #subtitle-box
font-family: Titillium Web,PingFang SC,Hiragino Sans GB,"Microsoft JhengHei","Microsoft YaHei",Helvetica Neue,Helvetica,Arial,sans-serif
font-size 3rem font-size 3rem
margin .5rem 0 1.5rem margin .5rem 0 1.5rem
a, & a, &
@ -53,13 +55,15 @@
&:hover &:hover
color sea color sea
.to_top .float_btns
position fixed position sticky
bottom 10rem bottom 10rem
right 50px right 50px
z-index 9 z-index 9996
text-align center text-align center
transform scale(1.2) transform scale(1.2)
width: 50px
float: right
#mask #mask
position fixed position fixed
@ -71,6 +75,12 @@
z-index 9998 z-index 9998
display none display none
.word_count
margin-top 5px
color darken(gray,30%)
padding-bottom 1rem
border-bottom 1px solid darken(froth-light,2%)
// Media Query // Media Query
@media (max-width: 768px) @media (max-width: 768px)
.cover-inner .cover-inner
@ -78,8 +88,8 @@
width 100% width 100%
h1 h1
font-size 4.5rem font-size 4.5rem
h2 #subtitle-box
font-size 2rem font-size 2rem
.to_top .float_btns
right 10px right 10px

View File

@ -0,0 +1,52 @@
// Categories
.categories-box
max-width 320px
margin-right -.5rem
margin-left -.5rem
border-left 1px solid #eee
span
padding-left: 5px;
color: #aaa;
font-size: 14px
ul li, ol li
list-unstyled()
margin: 15px 0;
padding-left: 15px;
padding-bottom: 12px;
font-size: 16px;
font-weight: 500;
word-wrap: break-word;
border-bottom: 1px solid #eee;
&:last-child
margin-bottom 0
border-bottom 0 solid #000
i
font-style normal
margin-left 10px
color: darken(water,45%)
a
display inline-block
vertical-align middle
text-decoration: none
color: body-color
&:hover
opacity .8
&:before
content "\efde"
font-family remixicon
margin-right .5rem
display inline-block
vertical-align middle
ul ul,ol ul,ul ol,ol ol
list-unstyled()
margin 0 20px
ul ul li,ol ul li,ul ol li,ol ol li
list-unstyled()
border: none;
padding-bottom: 0;
.category-list-count:before, .tag-list-count:before, .archive-list-count:before
content: "(";
.category-list-count:after, .tag-list-count:after, .archive-list-count:after
content: ")";

View File

@ -0,0 +1,50 @@
@keyframes footerHeartBeat
0%
transform: scale(1)
50%
transform: scale(1.2)
100%
transform: scale(1)
.footer
border-top 2px solid #f6f6f6
padding 3rem 0
font-size 115%
.outer
&>ul
position relative
display flex
justify-content center
li
display inline-block
padding .3rem 0
a
text-decoration none
.division
display inline
margin 0 5px
i
margin 0 2px
font-style normal
transform translateY(2px)
span
margin-right 6px
.heart_icon
display: inline-block;
margin: 0 0.4rem;
font-size: 1em;
color: #f00;
-webkit-animation: footerHeartBeat 1.2s infinite;
-moz-animation: footerHeartBeat 1.2s infinite;
-o-animation: footerHeartBeat 1.2s infinite;
-ms-animation: footerHeartBeat 1.2s infinite;
animation: footerHeartBeat 1.2s infinite;
animation-duration: 1.2s;
animation-timing-function: ease;
animation-delay: 0s;
animation-iteration-count: infinite;
animation-direction: normal;
animation-fill-mode: none;
animation-play-state: running;
animation-name: footerHeartBeat;

View File

@ -0,0 +1,29 @@
// friends
#friends_link
.friends_li
list-style none
float left
a
padding 15px 25px
display flex
align-items center
justify-content space-between
font-size 17px
text-decoration none
background-color rgba(6,129,208,.1)
color #000
border-radius 6px
margin-right 20px
margin-bottom 20px
img
display inline-block
width 40px
height 40px
border-radius 50%
margin-right 10px
i
font-size 25px
width 40px
height 40px
&:hover
background-color rgba(6,129,208,.15)

View File

@ -0,0 +1,260 @@
highlight-background = #2d2d2d
highlight-code = #f2f2f2
highlight-code-color = #c7254e
highlight-current-line = grey
highlight-selection = #000
highlight-foreground = #dedede
highlight-comment = #8e908c
highlight-red = #f2777a
highlight-orange = #f99157
highlight-yellow = #ffcc66
highlight-green = #99cc99
highlight-aqua = #66cccc
highlight-blue = #6699cc
highlight-purple = #cc99cc
.article-entry pre,
.article-entry .highlight {
background: highlight-background;
margin: 10px 0;
padding: 10px 10px;
overflow: hidden;
overflow-x: auto;
color: highlight-foreground;
font-size: 0.9em;
line-height: 1.5;
/** */
&::-webkit-scrollbar {
height: 10px;
width: 7px;
background: rgba(0, 0, 0, 0.1);
/* */
/* width: 10px;
height: 10px;
background: #ccc;
border-radius: 0; */
}
&::-webkit-scrollbar:hover {
background: rgba(0, 0, 0, 0.2);
}
/* */
&::-webkit-scrollbar-thumb {
background: rgba(0, 0, 0, 0.3);
-webkit-border-radius: 6px;
-moz-border-radius: 6px;
-ms-border-radius: 6px;
-o-border-radius: 6px;
border-radius: 6px;
}
&::-webkit-scrollbar-thumb:hover {
-webkit-box-shadow: inset 1px 1px 1px rgba(0, 0, 0, 0.25);
/* Webkit browsers */
-moz-box-shadow: inset 1px 1px 1px rgba(0, 0, 0, 0.25);
/* Firefox */
-ms-box-shadow: inset 1px 1px 1px rgba(0, 0, 0, 0.25);
/* IE9 */
-o-box-shadow: inset 1px 1px 1px rgba(0, 0, 0, 0.25);
/* Opera(Old) */
box-shadow: inset 1px 1px 1px rgba(0, 0, 0, 0.25);
/* IE9+, News */
background-color: rgba(0, 0, 0, 0.4);
}
/** */
&::-webkit-scrollbar-track {
/* box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.2); */
background: #ededed;
border-radius: 10px;
}
}
.article-entry .highlight .gutter pre,
.article-entry .highlight .gutter pre .line,
.article-entry .gist .gist-file .gist-data .line-numbers {
/* color: #666; */
color: highlight-current-line;
}
.article-entry pre,
.article-entry code {
font-family: Consolas,Monaco,"Andale Mono","Ubuntu Mono",monospace
}
.article-entry code {
background: #eee;
color: highlight-code-color;
padding: 0 0.3em;
border: none;
}
.article-entry pre code {
background: none;
text-shadow: none;
padding: 0;
color: highlight-foreground;
}
.article-entry .highlight {
border-radius: 4px;
}
.article-entry .highlight pre {
border: none;
margin: 0;
padding: 0;
}
.article-entry .highlight table {
margin: 0;
width: auto;
border: none;
}
.article-entry .highlight td {
border: none;
padding: 0;
}
.article-entry .highlight figcaption {
color: highlight-comment;
line-height: 1em;
margin-bottom: 1em;
}
.article-entry .highlight figcaption:before,
.article-entry .highlight figcaption:after {
content: "";
display: table;
}
.article-entry .highlight figcaption:after {
clear: both;
}
.article-entry .highlight figcaption a {
float: right;
}
.article-entry .highlight .gutter pre {
text-align: right;
padding-right: 20px;
}
.article-entry .highlight .gutter pre .line {
text-shadow: none;
}
.article-entry .highlight .line {
color: highlight-foreground;
min-height: 19px;
}
.article-entry .gist {
margin: 0 -20px;
border-style: solid;
border-color: #ddd;
border-width: 1px 0;
background: #272822;
padding: 15px 20px 15px 0;
}
.article-entry .gist .gist-file {
border: none;
font-family: "Source Code Pro", Consolas, Monaco, Menlo, Consolas, monospace;
margin: 0;
}
.article-entry .gist .gist-file .gist-data {
background: none;
border: none;
}
.article-entry .gist .gist-file .gist-data .line-numbers {
background: none;
border: none;
padding: 0 20px 0 0;
}
.article-entry .gist .gist-file .gist-data .line-data {
padding: 0 !important;
}
.article-entry .gist .gist-file .highlight {
margin: 0;
padding: 0;
border: none;
}
.article-entry .gist .gist-file .gist-meta {
background: #272822;
color: highlight-comment;
font: 0.85em "Helvetica Neue", Helvetica, Arial, sans-serif;
text-shadow: 0 0;
padding: 0;
margin-top: 1em;
margin-left: 20px;
}
.article-entry .gist .gist-file .gist-meta a {
color: #258fb8;
font-weight: normal;
}
.article-entry .gist .gist-file .gist-meta a:hover {
text-decoration: underline;
}
pre .comment {
/* color: #75715e; */
color: highlight-green
}
pre .keyword,
pre .function .keyword,
pre .class .params {
color: #66d9ef;
}
pre .tag,
pre .doctype,
pre .params,
pre .function,
pre .css .value {
color: highlight-foreground;
}
pre .css~* .tag,
pre .title,
pre .at_rule,
pre .at_rule .keyword,
pre .preprocessor,
pre .preprocessor .keyword {
color: #f92672;
}
pre .attribute,
pre .built_in,
pre .class,
pre .css~* .class,
pre .function .title {
color: #a6e22e;
}
pre .value,
pre .string {
color: highlight-foreground;
}
pre .number {
color: highlight-purple
}
pre .id,
pre .css~* .id {
color: #fd971f;
}

View File

@ -14,8 +14,7 @@
display inline-block display inline-block
overflow hidden overflow hidden
background gray /* To have gray placeholders while the gallery is loading with waitThumbnailsLoad = false */ background gray /* To have gray placeholders while the gallery is loading with waitThumbnailsLoad = false */
filter "alpha(opacity=10)" opacity 1
opacity 0.1
margin 0 margin 0
padding 0 padding 0
> img, > a > img, > svg, > a > svg > img, > a > img, > svg, > a > svg
@ -25,8 +24,7 @@
margin 0 margin 0
padding 0 padding 0
border none border none
filter "alpha(opacity=0)" opacity 1
opacity 0
> .caption > .caption
display none display none
position absolute position absolute
@ -40,11 +38,9 @@
&.caption-visible &.caption-visible
display initial display initial
> .jg-entry-visible > .jg-entry-visible
filter "alpha(opacity=100)"
opacity 1 opacity 1
background none background none
> img, > a > img, > svg, > a > svg > img, > a > img, > svg, > a > svg
filter "alpha(opacity=100)"
opacity 1 opacity 1
-webkit-transition opacity 500ms ease-in -webkit-transition opacity 500ms ease-in
-moz-transition opacity 500ms ease-in -moz-transition opacity 500ms ease-in
@ -58,13 +54,11 @@
margin-left -24px margin-left -24px
padding 10px 0 10px 0 padding 10px 0 10px 0
left 50% left 50%
filter "alpha(opacity=100)"
opacity 1 opacity 1
overflow initial overflow initial
> span > span
display inline-block display inline-block
filter "alpha(opacity=0)" opacity 1
opacity 0
width 8px width 8px
height 8px height 8px
margin 0 4px 0 4px margin 0 4px 0 4px

View File

@ -17,7 +17,8 @@
right 0 right 0
.content, .sidebar .content, .sidebar
transition(transition-base) &.anim
transition(transition-base)
.content .content
position relative position relative
@ -29,7 +30,6 @@
overflow-x: hidden overflow-x: hidden
-webkit-overflow-scrolling touch -webkit-overflow-scrolling touch
&.on &.on
transform translateX(aside-width)
margin-left 0 !important margin-left 0 !important
.sidebar .sidebar
@ -63,17 +63,20 @@
font-size larger font-size larger
.wrap, .outer .wrap, .outer
position relative
width 100% width 100%
padding-right gutter-width padding-right gutter-width
padding-left gutter-width padding-left gutter-width
margin auto margin auto
overflow-x hidden
min-height calc( 100% - 157px ) min-height calc( 100% - 157px )
clearfix() clearfix()
.local-search .local-search
width 100% width 100%
#main
position relative
// Media Query // Media Query
@media (min-width: 768px) @media (min-width: 768px)

View File

@ -14,6 +14,13 @@
opacity .8 opacity .8
background-color body-color background-color body-color
&.nav-main &.nav-main
height 60vh
overflow-y scroll
scrollbar-width none
-ms-overflow-style none
&::-webkit-scrollbar
width 0px
height 0px
.nav-item-link .nav-item-link
i i
font-size 1rem font-size 1rem

View File

@ -1,9 +1,13 @@
#reward-out
position: relative
width: 100%
#reward-btn #reward-btn
position relative position relative
display inline-block display inline-block
height 36px height 36px
line-height 36px line-height 36px
margin-top 3rem margin 60px 0
padding 0 20px padding 0 20px
font-size 18px font-size 18px
color #fff color #fff
@ -13,8 +17,7 @@
margin-left 50% margin-left 50%
transform translateX(-50%) transform translateX(-50%)
box-shadow 0 2px 5px 0 rgba(0, 0, 0, 0.16), 0 2px 10px 0 rgba(0, 0, 0, 0.12) box-shadow 0 2px 5px 0 rgba(0, 0, 0, 0.16), 0 2px 10px 0 rgba(0, 0, 0, 0.12)
-webkit-transition .4s ease-in-out transition(.4s ease-in-out)
transition .4s ease-in-out
cursor pointer cursor pointer
&:hover, &:hover,
&:active &:active
@ -30,6 +33,18 @@
padding 0px 20px 20px padding 0px 20px 20px
background-color lighten(water,30%) background-color lighten(water,30%)
display none display none
&.ready {
visibility: hidden;
display: block;
transform: translate(-50%, -100%);
transition: .3s;
}
&.in {
visibility: visible;
opacity: 1;
transform: translate(-50%, 0);
}
.close .close
height 28px height 28px
line-height 28px line-height 28px

View File

@ -0,0 +1,161 @@
.share-wrap {
min-height: 20px;
display: none;
position: relative;
z-index: 1;
right: 0;
bottom: 0;
width: 250px;
background-color #f5f5f5;
border-radius: 2px;
.arrow {
position: absolute;
z-index: -1;
top: -3px;
right:20px;
display: block;
width 10px;
height 10px;
transform: rotate(45deg);
background-color #f5f5f5;
}
}
.share-btn {
float: right;
position: relative;
}
.share-outer {
display: flex;
justify-content: flex-end;
border: none;
text-shadow: none;
text-decoration: none;
width auto;
color: link-color;
height: 28px;
line-height: 26px;
i{
font-size: 18px;
margin-right 5px;
color lighten(link-color,30%)
}
&:hover {
transform: none;
cursor: pointer;
}
}
.share-icons {
display: flex;
justify-content: flex-end;
align-items: center;
flex-wrap: wrap;
a {
border-radius: 50%;
display: inline-block;
vertical-align: middle;
zoom: 1;
margin: 3px;
transition: 0.3s;
text-align: center;
color: main-color;
width: 28px;
height: 28px;
line-height: 26px;
font-size: 13px;
i {
font-size: 24px
}
&.weibo {
color weibo-color
}
&.weixin {
color wechat-color
}
&.qq {
color qq-color
}
&.douban {
color douban-color
}
&.twitter {
color twitter-color
}
&.facebook {
color facebook-color
}
&.google {
color google-color
}
&:active {
color: ocean;
}
&:hover {
transform: scale(1.2);
}
}
}
.wx-share-modal {
position: fixed;
top: 24%;
left: 50%;
z-index: 9999;
padding: 20px;
text-align: center;
color: #727272;
background: #fff;
border-radius: 4px;
box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.16), 0 2px 10px 0 rgba(0, 0, 0, 0.12);
opacity: 0;
transform: translate(-50%, -200%);
p {
margin-bottom: 10px;
}
&.ready {
visibility: 0;
display: block;
transform: translate(-50%, -100%);
transition: .3s;
}
&.in {
display: block;
visibility: visible;
opacity: 1;
transform: translate(-50%, 0);
}
.modal-close {
position: absolute;
right: 15px;
top: 15px;
color: rgba(0, 0, 0, .2);
font-size: 16px;
line-height: 20px;
i{
font-size: 24px;
}
&:hover,
&:active {
color: rgba(0, 0, 0, .4);
}
}
}
#share-mask{
position: fixed;
width: 100%;
height: 100%;
left: 0;
top: 0;
background-color rgba(0,0,0,.6);
z-index: 999;
display: none;
}

Some files were not shown because too many files have changed in this diff Show More