hexo-theme-shokax 0.0.1-alpha6 → 0.0.2-alpha2
Sign up to get free protection for your applications and to get access to all the features.
- package/README.md +4 -2
- package/_config.yml +0 -5
- package/layout/_mixin/comment.pug +2 -0
- package/layout/_partials/footer.pug +1 -1
- package/layout/_partials/header.pug +1 -2
- package/layout/_partials/layout.pug +6 -2
- package/layout/_partials/post/footer.pug +1 -0
- package/layout/_partials/post/post.pug +3 -1
- package/layout/_partials/sidebar/overview.pug +2 -0
- package/package.json +2 -2
- package/scripts/helpers/engine.js +6 -0
- package/scripts/plugin/index.js +4 -4
- package/scripts/plugin/lib/injects-point.js +0 -1
- package/source/css/app.styl +10 -1
- package/layout/_partials/third-party/qweather.pug +0 -35
- package/source/css/plugin.styl +0 -174
package/README.md
CHANGED
@@ -7,7 +7,9 @@
|
|
7
7
|
此项目是shoka的一个二次开发版(算精神续作),致力于提高性能和优化魔改体验 \
|
8
8
|
诞生原因是目前shoka已经两年没有更新了,积压了大量BUG和功能请求。\
|
9
9
|
本项目处于高强度开发期,但github仓库版本已基本可用 \
|
10
|
-
二次开发与常见问题请看wiki
|
10
|
+
二次开发与常见问题请看wiki \
|
11
|
+
`0.0.2-alpha2`开始,`lantern`和`qweather`已迁移为插件 \
|
12
|
+
插件系统已完工,食用方法见[awesome-shokaX](https://github.com/zkz098/awesome-shokaX)
|
11
13
|
|
12
14
|
## 待办名单
|
13
15
|
- [x] 推出一个可用的测试版
|
@@ -17,7 +19,7 @@
|
|
17
19
|
- [x] 注入js和css支持
|
18
20
|
- [x] 自定义font
|
19
21
|
- [x] 部分功能调整为可关闭
|
20
|
-
- [
|
22
|
+
- [x] 插件系统
|
21
23
|
|
22
24
|
## 和shoka的区别
|
23
25
|
原先shoka使用了javascript+Native+nunjucks的技术 \
|
package/_config.yml
CHANGED
@@ -7,6 +7,7 @@ html(lang=page.language?page.language:config.language, style=theme.grayMode ? 'f
|
|
7
7
|
head
|
8
8
|
!= partial('_partials/head/head.pug', {}, {cache: true})
|
9
9
|
!= partial('_partials/head/head_com.pug')
|
10
|
+
!= shokax_inject('head')
|
10
11
|
title
|
11
12
|
block title
|
12
13
|
!= `${alternate?alternate + " = ":""}${title}${subtitle?" = "+subtitle:""}`
|
@@ -133,10 +134,11 @@ html(lang=page.language?page.language:config.language, style=theme.grayMode ? 'f
|
|
133
134
|
!= _vendor_js()
|
134
135
|
!= _js('app.js')
|
135
136
|
!= partial('_partials/third-party/baidu-analytics.pug', {}, {cache: true})
|
136
|
-
|
137
|
+
if theme.qweather.enable
|
138
|
+
!= partial('_partials/third-party/qweather.pug', {}, {cache: true})
|
137
139
|
!= partial('_partials/third-party/clarity.pug', {}, {cache: true})
|
138
140
|
!= _new_comments('twikoo')
|
139
|
-
|
141
|
+
|
140
142
|
|
141
143
|
- var jsInjects = theme?.inject?.body?.js,cssInjects = theme?.inject?.body?.css
|
142
144
|
if cssInjects
|
@@ -145,5 +147,7 @@ html(lang=page.language?page.language:config.language, style=theme.grayMode ? 'f
|
|
145
147
|
if jsInjects
|
146
148
|
!= js(jsInjects)
|
147
149
|
|
150
|
+
!= shokax_inject('bodyEnd')
|
151
|
+
|
148
152
|
|
149
153
|
|
@@ -1,4 +1,5 @@
|
|
1
|
-
|
1
|
+
- var temp = post.lang || config.language
|
2
|
+
article(itemscope itemtype="http://schema.org/Article" class="post block" lang=temp)
|
2
3
|
link(itemprop="mainEntityOfPage" href!=post.permalink)
|
3
4
|
span(hidden itemprop="author" itemscope itemtype="http://schema.org/Person")
|
4
5
|
meta(itemprop="image" content=url_for(theme.statics + theme.images + '/' + theme.sidebar.avatar))
|
@@ -24,3 +25,4 @@ article(itemscope itemtype="http://schema.org/Article" class="post block" lang="
|
|
24
25
|
!= partial('_partials/post/reward.pug', {}, {cache: true})
|
25
26
|
if theme.creative_commons.license
|
26
27
|
!= partial('_partials/post/copyright.pug')
|
28
|
+
!= shokax_inject('postBodyEnd')
|
@@ -35,6 +35,8 @@ div(class="social")
|
|
35
35
|
- var sidebarIcon = '<i class="ic i-' + link.split('||')[1].trim() + '"></i>'
|
36
36
|
!= _url(sidebarURL, sidebarIcon, {title: sidebarURL, class: 'item ' + name})
|
37
37
|
|
38
|
+
!= shokax_inject('sidebar')
|
39
|
+
|
38
40
|
div(class="menu")
|
39
41
|
//!= partial('_partials/sidebar/menu.pug', {}, {cache: true})
|
40
42
|
!= partial('_partials/sidebar/menu.pug')
|
package/package.json
CHANGED
@@ -1,11 +1,11 @@
|
|
1
1
|
{
|
2
2
|
"name": "hexo-theme-shokax",
|
3
|
-
"version": "0.0.
|
3
|
+
"version": "0.0.2-alpha2",
|
4
4
|
"description": "a hexo theme based on shoka",
|
5
5
|
"main": "index.js",
|
6
6
|
"repository": "https://github.com/zkz098/hexo-theme-shokaX",
|
7
7
|
"author": "Chou kaitaku",
|
8
|
-
"license": "
|
8
|
+
"license": "BSD-3-Clause",
|
9
9
|
"scripts": {
|
10
10
|
"test": "cd ./source/js && tsc"
|
11
11
|
},
|
@@ -182,3 +182,9 @@ hexo.extend.helper.register('random_color', function () {
|
|
182
182
|
b.toString(16).length > 1 ? b.toString(16) : '0' + b.toString(16)
|
183
183
|
}`
|
184
184
|
})
|
185
|
+
|
186
|
+
hexo.extend.helper.register('shokax_inject', function (point) {
|
187
|
+
return hexo.theme.config.injects[point]
|
188
|
+
.map(item => this.partial(item.layout, item.locals, item.options))
|
189
|
+
.join('')
|
190
|
+
})
|
package/scripts/plugin/index.js
CHANGED
package/source/css/app.styl
CHANGED
@@ -1,7 +1,13 @@
|
|
1
1
|
@import "_variables";
|
2
2
|
|
3
|
+
for $inject_variable in hexo-config('injects.variable')
|
4
|
+
@import $inject_variable;
|
5
|
+
|
3
6
|
@import "_mixins";
|
4
7
|
|
8
|
+
for $inject_mixin in hexo-config('injects.mixin')
|
9
|
+
@import $inject_mixin;
|
10
|
+
|
5
11
|
if $colors = hexo-config('style.colors')
|
6
12
|
@import $colors;
|
7
13
|
else
|
@@ -24,4 +30,7 @@ else
|
|
24
30
|
if $custom = hexo-config('style.custom')
|
25
31
|
@import $custom;
|
26
32
|
|
27
|
-
|
33
|
+
for $inject_style in hexo-config('injects.style')
|
34
|
+
@import $inject_style;
|
35
|
+
|
36
|
+
|
@@ -1,35 +0,0 @@
|
|
1
|
-
script.
|
2
|
-
WIDGET = {
|
3
|
-
"CONFIG": {
|
4
|
-
"modules": "012",
|
5
|
-
"background": "5",
|
6
|
-
"tmpColor": "var(--text-color);",
|
7
|
-
"tmpSize": "16",
|
8
|
-
"cityColor": "var(--text-color);",
|
9
|
-
"citySize": "16",
|
10
|
-
"aqiColor": "FFFFFF",
|
11
|
-
"aqiSize": "16",
|
12
|
-
"weatherIconSize": "24",
|
13
|
-
"alertIconSize": "18",
|
14
|
-
"padding": "10px 10px 10px 10px",
|
15
|
-
"shadow": "0",
|
16
|
-
"language": "auto",
|
17
|
-
"borderRadius": "5",
|
18
|
-
"fixed": "false",
|
19
|
-
"vertical": "top",
|
20
|
-
"horizontal": "left",
|
21
|
-
"key": "#{theme.qweather.key}"
|
22
|
-
}
|
23
|
-
}
|
24
|
-
|
25
|
-
script.
|
26
|
-
(function (d) {
|
27
|
-
const c = d.createElement('link')
|
28
|
-
c.rel = 'stylesheet'
|
29
|
-
c.href = 'https://widget.qweather.net/simple/static/css/he-simple.css?v=1.4.0'
|
30
|
-
const s = d.createElement('script')
|
31
|
-
s.src = 'https://widget.qweather.net/simple/static/js/he-simple.js?v=1.4.0'
|
32
|
-
const sn = d.getElementsByTagName('script')[0]
|
33
|
-
sn.parentNode.insertBefore(c, sn)
|
34
|
-
sn.parentNode.insertBefore(s, sn)
|
35
|
-
})(document)
|
package/source/css/plugin.styl
DELETED
@@ -1,174 +0,0 @@
|
|
1
|
-
.deng-box {
|
2
|
-
position: fixed;
|
3
|
-
top: -40px;
|
4
|
-
right: -20px;
|
5
|
-
z-index: 99;
|
6
|
-
}
|
7
|
-
.deng-box1 {
|
8
|
-
position: fixed;
|
9
|
-
top: -30px;
|
10
|
-
right: 10px;
|
11
|
-
z-index: 99;
|
12
|
-
.deng {
|
13
|
-
position: relative;
|
14
|
-
width: 120px;
|
15
|
-
height: 90px;
|
16
|
-
margin: 50px;
|
17
|
-
background: #d8000f;
|
18
|
-
background: rgba(216, 0, 15, 0.8);
|
19
|
-
border-radius: 50% 50%;
|
20
|
-
-webkit-transform-origin: 50% -100px;
|
21
|
-
-webkit-animation: swing 5s infinite ease-in-out;
|
22
|
-
box-shadow: -5px 5px 30px 4px rgba(252, 144, 61, 1);
|
23
|
-
}
|
24
|
-
}
|
25
|
-
.deng {
|
26
|
-
position: relative;
|
27
|
-
width: 120px;
|
28
|
-
height: 90px;
|
29
|
-
margin: 50px;
|
30
|
-
background: #d8000f;
|
31
|
-
background: rgba(216, 0, 15, 0.8);
|
32
|
-
border-radius: 50% 50%;
|
33
|
-
-webkit-transform-origin: 50% -100px;
|
34
|
-
-webkit-animation: swing 3s infinite ease-in-out;
|
35
|
-
box-shadow: -5px 5px 50px 4px rgba(250, 108, 0, 1);
|
36
|
-
&:before {
|
37
|
-
position: absolute;
|
38
|
-
top: -7px;
|
39
|
-
left: 29px;
|
40
|
-
height: 12px;
|
41
|
-
width: 60px;
|
42
|
-
content: " ";
|
43
|
-
display: block;
|
44
|
-
z-index: 999;
|
45
|
-
border-radius: 5px 5px 0 0;
|
46
|
-
border: solid 1px #dc8f03;
|
47
|
-
background: #ffa500;
|
48
|
-
background: linear-gradient(to right, #dc8f03, #ffa500, #dc8f03, #ffa500, #dc8f03);
|
49
|
-
}
|
50
|
-
&:after {
|
51
|
-
position: absolute;
|
52
|
-
bottom: -7px;
|
53
|
-
left: 10px;
|
54
|
-
height: 12px;
|
55
|
-
width: 60px;
|
56
|
-
content: " ";
|
57
|
-
display: block;
|
58
|
-
margin-left: 20px;
|
59
|
-
border-radius: 0 0 5px 5px;
|
60
|
-
border: solid 1px #dc8f03;
|
61
|
-
background: #ffa500;
|
62
|
-
background: linear-gradient(to right, #dc8f03, #ffa500, #dc8f03, #ffa500, #dc8f03);
|
63
|
-
}
|
64
|
-
}
|
65
|
-
.deng-a {
|
66
|
-
width: 100px;
|
67
|
-
height: 90px;
|
68
|
-
background: #d8000f;
|
69
|
-
background: rgba(216, 0, 15, 0.1);
|
70
|
-
margin: 12px 8px 8px 10px;
|
71
|
-
border-radius: 50% 50%;
|
72
|
-
border: 2px solid #dc8f03;
|
73
|
-
}
|
74
|
-
.deng-b {
|
75
|
-
width: 45px;
|
76
|
-
height: 90px;
|
77
|
-
background: #d8000f;
|
78
|
-
background: rgba(216, 0, 15, 0.1);
|
79
|
-
margin: -4px 8px 8px 26px;
|
80
|
-
border-radius: 50% 50%;
|
81
|
-
border: 2px solid #dc8f03;
|
82
|
-
}
|
83
|
-
.xian {
|
84
|
-
position: absolute;
|
85
|
-
top: -20px;
|
86
|
-
left: 60px;
|
87
|
-
width: 2px;
|
88
|
-
height: 20px;
|
89
|
-
background: #dc8f03;
|
90
|
-
}
|
91
|
-
.shui-a {
|
92
|
-
position: relative;
|
93
|
-
width: 5px;
|
94
|
-
height: 20px;
|
95
|
-
margin: -5px 0 0 59px;
|
96
|
-
-webkit-animation: swing 4s infinite ease-in-out;
|
97
|
-
-webkit-transform-origin: 50% -45px;
|
98
|
-
background: #ffa500;
|
99
|
-
border-radius: 0 0 5px 5px;
|
100
|
-
}
|
101
|
-
.shui-b {
|
102
|
-
position: absolute;
|
103
|
-
top: 14px;
|
104
|
-
left: -2px;
|
105
|
-
width: 10px;
|
106
|
-
height: 10px;
|
107
|
-
background: #dc8f03;
|
108
|
-
border-radius: 50%;
|
109
|
-
}
|
110
|
-
.shui-c {
|
111
|
-
position: absolute;
|
112
|
-
top: 18px;
|
113
|
-
left: -2px;
|
114
|
-
width: 10px;
|
115
|
-
height: 35px;
|
116
|
-
background: #ffa500;
|
117
|
-
border-radius: 0 0 0 5px;
|
118
|
-
}
|
119
|
-
.deng-t {
|
120
|
-
font-size: 3.2rem;
|
121
|
-
color: #dc8f03;
|
122
|
-
font-weight: bold;
|
123
|
-
line-height: 85px;
|
124
|
-
text-align: center;
|
125
|
-
}
|
126
|
-
.night .deng-t,
|
127
|
-
.night .deng-box,
|
128
|
-
.night .deng-box1 {
|
129
|
-
background: transparent !important;
|
130
|
-
}
|
131
|
-
@-moz-keyframes swing {
|
132
|
-
0% {
|
133
|
-
-moz-transform: rotate(-10deg)
|
134
|
-
}
|
135
|
-
50% {
|
136
|
-
-moz-transform: rotate(10deg)
|
137
|
-
}
|
138
|
-
100% {
|
139
|
-
-moz-transform: rotate(-10deg)
|
140
|
-
}
|
141
|
-
}
|
142
|
-
|
143
|
-
@-webkit-keyframes swing {
|
144
|
-
0% {
|
145
|
-
-webkit-transform: rotate(-10deg)
|
146
|
-
}
|
147
|
-
50% {
|
148
|
-
-webkit-transform: rotate(10deg)
|
149
|
-
}
|
150
|
-
100% {
|
151
|
-
-webkit-transform: rotate(-10deg)
|
152
|
-
}
|
153
|
-
}
|
154
|
-
|
155
|
-
@keyframes swing {
|
156
|
-
0% {
|
157
|
-
-webkit-transform: rotate(-10deg)
|
158
|
-
}
|
159
|
-
50% {
|
160
|
-
-webkit-transform: rotate(10deg)
|
161
|
-
}
|
162
|
-
100% {
|
163
|
-
-webkit-transform: rotate(-10deg)
|
164
|
-
}
|
165
|
-
}
|
166
|
-
|
167
|
-
@media (max-width: 870px){
|
168
|
-
.s-sticker-tmp ,.s-sticker-city{
|
169
|
-
display: none !important;
|
170
|
-
}
|
171
|
-
.s-sticker {
|
172
|
-
padding: 0
|
173
|
-
}
|
174
|
-
}
|