Compare commits

...

24 Commits
1.0.0 ... 1.2.0

  • 1. 更改手機頁面的menu和toc的顯示方式和顯示特效(ipad也能看TOC)
    2. 可設置禁止複製網站内容
    3. 可設置複製時,内容自動加上版權信息
    4. 可修改tag的top_img
    5. 可修改category的top_img
    6. 可修改valine的背景
    7. archives頁UI優化
    8. ICP增加icon #37
    9. 可設置主頁top_img的高度
    10. 可設置主頁site-info的位置
    11. category頁和tag頁的UI可以設置與主頁UI一樣 #31
    12. 主頁subtitle可設置多個句子(不再限制2個) #37
    13. 設置menu時,頭尾添加空格不受影響
    14. 調整post頁的佈局
    15. 书签添加icon
    16. 公告icon效果
    17. 首頁歸檔模塊,可設置數量限制,會顯示'查看更多'按鈕
    18. 右下角按鈕調整。
    19. 修复文章cover隨機图片生成,同一篇文章,不同地方的cover顯示不一样的bug
    20. 修復gitalk語言設置無效的bug #35
    21. 修復post頁面,當沒有設置word count時,閲讀量前有'|"
    22. 修复sub-menu在safari的显示问题
    23. 修复tags页评论居中问题
    24. 修复header a hover 白色问题
    25. 修復夜間模式下footer的顔色bug
    26. 修復英文語言下,書簽英文顯示不完整的問題
  • 1. 更改手機頁面的menu和toc的顯示方式和顯示特效(ipad也能看TOC)
    1. 更改手機頁面的menu和toc的顯示方式和顯示特效(ipad也能看TOC)
    3. 可設置複製時,内容自動加上版權信息
    4. 可修改tag的top_img
    5. 可修改category的top_img
    6. 可修改valine的背景
    7. archives頁UI優化
    8. ICP增加icon #37
    9. 可設置主頁top_img的高度
    10. 可設置主頁site-info的位置
    11. category頁和tag頁的UI可以設置與主頁UI一樣 #31
    12. 主頁subtitle可設置多個句子(不再限制2個) #37
    13. 設置menu時,頭尾添加空格不受影響
    14. 調整post頁的佈局
    15. 书签添加icon
    16. 公告icon效果
    17. 首頁歸檔模塊,可設置數量限制,會顯示'查看更多'按鈕
    18. 右下角按鈕調整。
    19. 修复文章cover隨機图片生成,同一篇文章,不同地方的cover顯示不一样的bug
    20. 修復gitalk語言設置無效的bug #35
    21. 修復post頁面,當沒有設置word count時,閲讀量前有'|"
    22. 修复sub-menu在safari的显示问题
    23. 修复tags页评论居中问题
    24. 修复header a hover 白色问题
    25. 修復夜間模式下footer的顔色bug
    26. 修復英文語言下,書簽英文顯示不完整的問題
  • 1. Feature: 可设置首页背景图片屏占比
    2. Optimization: 优化多级菜单的使用方式
    3. Optimization: 支持自定义多个主頁subtitle
    4. Optimization: ICP备案信息可显示备案图标
  • 1. Feature: 可設置内联代码块样式 #26
    2. Feature: 可設置夜間模式作爲默認樣式
    3. Feature: 可設置是否顯示code language名稱
    4. Feature: 可設置是否展開或關閉代碼框
    5. Feature: 可設置背景圖片/顔色
    6. Feature: 可設置是否顯示footer背景
    7. Feature: 增加 canvas-nest.js
    8. Feature: 頭像可設置效果(轉圈圈)
    9. Feature: menu可設置分組
    9. Fix: 優化打賞和搜索打開特效
    10. Fix: 優化sidebar的打開特效,避免與文章頁特效不同步
    11. Fix: 適配**hexo-blog-encrypt**,現在可以顯示toc
    12. Fix: 修復設置不顯示評論時,直達評論按鈕沒有消失的bug
    13. Fix: 修復post頁底欄,當沒有顯示評論,不顯示TOC,評論和toc都不顯示 這三種狀態下按鈕的bug
    14. Fix: 修復代碼框左右滑動時,代碼名字跟著滑動的bug
    15. Fix: 其他page頁標題的字體顯示
    16. Fix: 修復當設置開啓canvas_ribbons,進入網站會先顯示canvas_ribbons的bug
    17. Fix: 完善夜間模式下,字體顯示問題
    18. Fix: 修復代碼框 複製 和 代碼名 z-index bug #25
    19. Fix: 完善阅读模式
  • 1. Feature: 手機menu界面重新設計
    2. Feature: 文章頁增加美化(原 melody主題功能),並增加更改標題前綴圖標和顔色
    3. Feature: PC端增加直達評論按鈕
    4. Feature: 可以對單獨文章設置是否顯示版權信息
    5. Fix: 修復閲讀模式下,調整字體大小對代碼無效的bug
    6. Fix: 調整Valine字體顯示問題
    7. Fix: 修正夜間模式下Valine的適配問題
    8. Fix: 修復Valine設置notify和verify無效的bug (thx @VincentTV )
    9. Remove: 去掉主題"閲讀更多"按鈕
  • 1. Feature: 可關閉圖片懶加載
    2. Feature: 增加頁面排版,可選擇把右邊欄放在左邊
    3. Feature: 增加 Note (Bootstrap Callout) (移植於next主題)
    4. Feature: 手機上能夠查看TOC
    5. Feature: 增加直達評論按鈕
    6. Fix: 修復post頁在寬度1024px下的顯示bug
    7. Fix: 修復代碼框部分語言沒有顯示正確的代碼語言
    8. Fix: 修復設置裏把Disqus註釋掉無法運行的bug
  • 1. Feature: the sidebar can auto scroll when the toc out of the screen
    2. Fix: When the picture is loaded, the picture appears black frame
  • 1. Fix: random cover of prev post and next post
    2. Feature: add the option to change the site name font-family
    3. Feature: add the option to close instant-page
    4. Fix: Display null when the sutitle not set
  • 1. Feature: random cover #10
    2. Fix: valine lang not work
    3. Fix: archives page site name not change when the language change
    4. Fix: related posts url error
  • 1. fix bugs of gitalk #9
    2. fix bugs of valine
82 changed files with 2765 additions and 3996 deletions

View File

@@ -12,10 +12,10 @@
git clone -b master https://github.com/jerryc127/hexo-theme-butterfly.git themes/Butterfly git clone -b master https://github.com/jerryc127/hexo-theme-butterfly.git themes/Butterfly
``` ```
如果想要安装比较新的dev分支可以 如果想要安裝比較新的dev分支可以
``` ```
git clone -b div https://github.com/jerryc127/hexo-theme-butterfly.git themes/Butterfly git clone -b dev https://github.com/jerryc127/hexo-theme-butterfly.git themes/Butterfly
``` ```
## 应用主题 ## 应用主题
@@ -29,8 +29,7 @@ theme: Butterfly
## 文档 ## 文档
可查看[这里](https://jerryc.me/posts/21cfbf15) 可查看或[这里](https://docs.jerryc.me/)或[这里](https://jerryc.me/posts/21cfbf15)
## 截图 ## 截图

View File

@@ -1,19 +1,10 @@
# Theme color for customize
# Notice: color value must in double quotes like "#000" or may cause error!
# ---------------
# theme_color:
# enable: true
# main: "#7A7FF1"
# paginator: "#7A7FF1"
# button_hover: "#FF7242"
# text_selection: "#69c46d"
# link_color: "#858585"
# hr_color: "#A4D8FA"
# read-mode-bg_color: '#FAF9DE'
# Main menu navigation # Main menu navigation
# format: xxx: /xxx/||icon
# --------------- # ---------------
# format: xxx: 連結 || icon
# sub-menu
# xxx || icon:
# xxx || 連結 || icon
menu: menu:
Home: / || fa fa-home Home: / || fa fa-home
Archives: /archives/ || fa fa-archive Archives: /archives/ || fa fa-archive
@@ -21,7 +12,9 @@ menu:
Categories: /categories/ || fa fa-folder-open Categories: /categories/ || fa fa-folder-open
Link: /link/ || fa fa-link Link: /link/ || fa fa-link
About: /about/ || fa fa-heart About: /about/ || fa fa-heart
# #XXX: /xxx List||fa fa-list:
- Music || /music/ || fa fa-music
- Movie || /movies/ || fa fa-film
# Favicon # Favicon
@@ -45,11 +38,20 @@ favicon: /img/favicon.ico
# Highlight theme # Highlight theme
# --------------- # ---------------
highlight_theme: light highlight_theme: light
highlight_copy: true highlight_copy: false #代碼複製按鈕
highlight_lang: true #代碼語言顯示
highlight_shrink: false #代碼框不展開,需點擊 '>' 打開
code_word_wrap: false code_word_wrap: false
# Nav settings # copy setting
# 是否禁止複製如果禁止highlight_copy的功能將無效)
# copyright 複製的内容後面加上版權信息
copy:
enable: false # true 開啓 / false 禁止
copyright: false
# social settings
# formal: # formal:
# icon: link # icon: link
# --------------- # ---------------
@@ -57,6 +59,7 @@ social:
fa fa-github: https://github.com/jerryc127 fa fa-github: https://github.com/jerryc127
fa fa-rss: /atom.xml fa fa-rss: /atom.xml
#### search ####
# Algolia search # Algolia search
# --------------- # ---------------
algolia_search: algolia_search:
@@ -69,7 +72,6 @@ algolia_search:
hits_empty: "We didn't find any results for the search: ${query}" # if there are no result hits_empty: "We didn't find any results for the search: ${query}" # if there are no result
hits_stats: "${hits} results found in ${time} ms" hits_stats: "${hits} results found in ${time} ms"
# Local search # Local search
# Please see doc for more details: https://jerryc.me/posts/21cfbf15/#本地搜索 # Please see doc for more details: https://jerryc.me/posts/21cfbf15/#本地搜索
# --------------- # ---------------
@@ -95,8 +97,7 @@ katex:
hide_scrollbar: true hide_scrollbar: true
#### Analysis ####
# Analysis
# --------------- # ---------------
# baidu_analytics: # baidu_analytics:
@@ -121,14 +122,11 @@ cdn:
css: css:
fontawesome: https://cdn.jsdelivr.net/npm/font-awesome@latest/css/font-awesome.min.css fontawesome: https://cdn.jsdelivr.net/npm/font-awesome@latest/css/font-awesome.min.css
# fontawesomeV5: https://use.fontawesome.com/releases/v5.8.1/css/all.css # fontawesomeV5: https://use.fontawesome.com/releases/v5.8.1/css/all.css
googlefont: https://fonts.googleapis.com/css?family=Titillium+Web
fancybox: https://cdn.jsdelivr.net/npm/@fancyapps/fancybox@latest/dist/jquery.fancybox.min.css fancybox: https://cdn.jsdelivr.net/npm/@fancyapps/fancybox@latest/dist/jquery.fancybox.min.css
js: js:
jquery: https://cdn.jsdelivr.net/npm/jquery@latest/dist/jquery.min.js jquery: https://cdn.jsdelivr.net/npm/jquery@latest/dist/jquery.min.js
fancybox: https://cdn.jsdelivr.net/npm/@fancyapps/fancybox@latest/dist/jquery.fancybox.min.js fancybox: https://cdn.jsdelivr.net/npm/@fancyapps/fancybox@latest/dist/jquery.fancybox.min.js
js-cookies: https://cdn.jsdelivr.net/npm/js-cookie@2/src/js.cookie.min.js js-cookies: https://cdn.jsdelivr.net/npm/js-cookie@2/src/js.cookie.min.js
lozy: https://cdn.jsdelivr.net/npm/lozad/dist/lozad.min.js
# Post info settings # Post info settings
# --------------- # ---------------
@@ -149,12 +147,17 @@ default_cover: https://cdn.jsdelivr.net/gh/jerryc127/CDN@latest/cover/default_bg
# the banner image of archive page # the banner image of archive page
archive_img: https://cdn.jsdelivr.net/gh/jerryc127/CDN@latest/Photo/archive.jpg archive_img: https://cdn.jsdelivr.net/gh/jerryc127/CDN@latest/Photo/archive.jpg
# the banner image of tag page
tag_img: https://cdn.jsdelivr.net/gh/jerryc127/CDN/img/tag-bg.png
# the banner image of category page
category_img: https://cdn.jsdelivr.net/gh/jerryc127/CDN/img/category-bg
# if the photo link cannot connect,it will show that # if the photo link cannot connect,it will show that
lodding_bg: lodding_bg:
flink: /img/friend_404.gif flink: /img/friend_404.gif
post_page: /img/404.jpg post_page: /img/404.jpg
post_meta: post_meta:
date_type: both # or created or updated 文章日期是创建日或者更新日或都显示 date_type: both # or created or updated 文章日期是创建日或者更新日或都显示
categories: true # or false 是否显示分类 categories: true # or false 是否显示分类
@@ -177,13 +180,14 @@ post_copyright:
license: CC BY-NC-SA 4.0 license: CC BY-NC-SA 4.0
license_url: https://creativecommons.org/licenses/by-nc-sa/4.0/ license_url: https://creativecommons.org/licenses/by-nc-sa/4.0/
# 自動節選
auto_excerpt: auto_excerpt:
enable: true enable: true
length: 150 length: 150
# Share System #### Share System ####
# --------------- # -----------------------------------------
addThis: addThis:
enable: false enable: false
pubid: pubid:
@@ -204,8 +208,8 @@ addtoany:
- email - email
- copy_link - copy_link
# Comments System #### Comments System ####
# --------------- # ------------------------------------
disqus: disqus:
enable: false enable: false
shortname: shortname:
@@ -228,6 +232,7 @@ disqus:
# repo: # repo:
# owner: # owner:
# admin: # admin:
# language: # en , zh-CN , zh-TW
#### Using this js for redirect to gitalk container after login #### Using this js for redirect to gitalk container after login
#### See https://github.com/gitalk/gitalk/issues/125 #### See https://github.com/gitalk/gitalk/issues/125
# js: https://cdn.jsdelivr.net/gh/upupming/gitalk@36368e5dffd049e956cdbbd751ff96c28d8255cf/dist/gitalk.min.js # js: https://cdn.jsdelivr.net/gh/upupming/gitalk@36368e5dffd049e956cdbbd751ff96c28d8255cf/dist/gitalk.min.js
@@ -241,12 +246,13 @@ valine:
verify: false # valine verify code (true/false) verify: false # valine verify code (true/false)
pageSize: 10 # comment list page size pageSize: 10 # comment list page size
avatar: monsterid # gravatar style https://valine.js.org/#/avatar avatar: monsterid # gravatar style https://valine.js.org/#/avatar
lang: en # i18n: zh-cn/en/tw lang: en # i18n: zh-cn/en
placeholder: Please leave your footprints # valine comment input placeholder(like: Please leave your footprints ) placeholder: Please leave your footprints # valine comment input placeholder(like: Please leave your footprints )
guest_info: nick,mail,link #valine comment header inf guest_info: nick,mail,link #valine comment header info
bg: /img/comment_bg.png # valine background
# Footer Settings ##### Footer Settings ####
# --------------- # ------------------------------------
since: 2018 since: 2018
footer_custom_text: footer_custom_text:
@@ -258,16 +264,10 @@ ICP:
enable: false enable: false
url: url:
text: text:
icon: /img/icp.png
# busuanzi count for PV / UV in site
busuanzi:
site_uv: true
site_pv: true
page_pv: true
#### 站長驗證 ####
# Google Webmaster tools verification setting # Google Webmaster tools verification setting
# See: https://www.google.com/webmasters/ # See: https://www.google.com/webmasters/
google_site_verification: google_site_verification:
@@ -276,10 +276,6 @@ google_site_verification:
# See: https://www.bing.com/webmaster/ # See: https://www.bing.com/webmaster/
bing_site_verification: bing_site_verification:
# Yandex Webmaster tools verification setting
# See: https://webmaster.yandex.ru/
#yandex_site_verification:
# Baidu Webmaster tools verification setting # Baidu Webmaster tools verification setting
# See: https://ziyuan.baidu.com/site/ # See: https://ziyuan.baidu.com/site/
baidu_site_verification: baidu_site_verification:
@@ -288,6 +284,8 @@ baidu_site_verification:
# see http://zhanzhang.so.com/ # see http://zhanzhang.so.com/
qihu_site_verification: qihu_site_verification:
# 友情鏈接界面設置
Flink: Flink:
headline: 友情鏈接 headline: 友情鏈接
info_headline: 我的Blog資料 info_headline: 我的Blog資料
@@ -297,25 +295,7 @@ Flink:
info: Blog 簡介: 今日事,今日畢 info: Blog 簡介: 今日事,今日畢
comment: 如果需要交換友鏈,請留言 comment: 如果需要交換友鏈,請留言
# 打賞按鈕
runtimeshow:
enable: true
start_date: 6/7/2018 00:00:00
nightshift:
enable: true
activate_power_mode:
enable: false
announcement:
content: 感謝訪問本站,若喜歡請收藏 ^_^
reward: reward:
enable: true enable: true
QR_code: QR_code:
@@ -326,11 +306,55 @@ reward:
img: /img/alipay.jpg img: /img/alipay.jpg
text: 支付寶 text: 支付寶
# 推薦文章
related_post: related_post:
enable: true enable: true
limit: 6 # 顯示推薦文章數目 limit: 6 # 顯示推薦文章數目
# canvas_ribbon #### 美化/效果 ####
#--------------------------------
# Theme color for customize
# Notice: color value must in double quotes like "#000" or may cause error!
# ---------------
# theme_color:
# enable: true
# main: "#49B1F5"
# paginator: "#00c4b6"
# button_hover: "#FF7242"
# text_selection: "#00c4b6"
# link_color: "#99a9bf"
# meta_color: '#858585'
# hr_color: "#A4D8FA"
# read-mode-bg_color: '#FAF9DE'
# inline-code-color: '#F47466'
# 主頁設置
# 默認top_img全屏site_info在中間
# 使用默認, 都無需填寫(建議默認)
index_site_info_top: #主頁標題距離頂部距離 例如 300px/300em/300rem/10%
index_top_img_height: #主頁top_img高度 例如 300px/300em/300rem 不能使用百分比
# category和tag頁的UI設置
# index 值代表 UI將與首頁的UI一樣
# 默認跟archives頁面UI一樣
category_ui: # 留空或index
tag_ui: # 留空或index
# 設置網站背景
# 可設置圖片 或者 顔色
# 圖片格式 background: url(http://xxxxxx.com/xxx.jpg)
# 顔色 background: '#49B202'
# 留空 顯示白色
background:
# footer是否顯示圖片背景(與top_img一致)
footer_bg: false
# canvas_ribbon 禁止彩帶背景
# See: https://github.com/hustcc/ribbon.js # See: https://github.com/hustcc/ribbon.js
canvas_ribbon: canvas_ribbon:
enable: false enable: false
@@ -339,37 +363,76 @@ canvas_ribbon:
zIndex: -1 zIndex: -1
click_to_change: false click_to_change: false
# 動態彩帶
canvas_ribbon_piao: canvas_ribbon_piao:
enable: true enable: false
# canvas_nest
# https://github.com/hustcc/canvas-nest.js
canvas_nest:
enable: false
color: '0,0,255' #color of lines, default: '0,0,0'; RGB values: (R,G,B).(note: use ',' to separate.)
opacity: 0.7 # the opacity of line (0~1), default: 0.5.
zIndex: -1 # z-index property of the background, default: -1.
count: 99 # the number of lines, default: 99.
script: https://cdn.jsdelivr.net/gh/jerryc127/CDN/js/canvas-nest.js # or /js/third-party/canvas-nest.js
# 避免重複網址分散seo # 打字效果
canonical: true activate_power_mode:
enable: false
# 禁止百度轉碼 # 鼠標點擊效果
disable_baidu_transformation: true fireworks:
enable: false
twitter_meta: true # 頭像會一直轉圈
Open_Graph_meta: true avatar_effect: false
#閲讀模式 # 網站顯示模式
readmode: # day 默認模式
enable: true # night 黑暗模式(不建議)
display_mode: day
# 美化post頁顯示
post_beautify:
enable: false
title-prefix-icon: '\f0c1'
title-prefix-icon-color: "#F47466"
# 全局字體
font: font:
enable: false enable: false
font-family: Lato, Helvetica Neue For Number, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, PingFang SC, Hiragino Sans GB,"Microsoft JhengHei", "MicrMicrosoft YaHei", Helvetica Neue, Helvetica, Arial, sans-serif font-family: Lato, Helvetica Neue For Number, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, PingFang SC, Hiragino Sans GB, MicrMicrosoft YaHei", Helvetica Neue, Helvetica, Arial, sans-serif
code-font: consolas, Menlo, "PingFang SC", "Microsoft JhengHei","Microsoft YaHei", monospace, Helvetica Neue For Number code-font: consolas, Menlo, "PingFang SC", "Microsoft YaHei", monospace, Helvetica Neue For Number
# 網站名字字體
# 左上角網站名字 主頁居中網站名字
blog_title_font:
font_link: https://fonts.googleapis.com/css?family=Titillium+Web #字體鏈接
font-family: Titillium Web, PingFang SC, Hiragino Sans GB, "Microsoft YaHei", Helvetica Neue, Helvetica, Arial, sans-serif
# 水平分隔綫
hr:
enable: false
icon: '\f21c' #fontawesome上圖標的Unicode
icon-top: -20px
# 主頁subtitle # 主頁subtitle
# 打字效果
# (如果有英文逗號' , ',請使用轉義字符 ,)
subtitle: subtitle:
enable: true enable: true
sub1: 今日事,今日畢 sub:
sub2: Never put off till tomorrow what you can do today - 今日事,今日畢
- Never put off till tomorrow what you can do today
#### 側邊欄 ####
#-------------------------------------
# 側邊欄顯示設置 # 側邊欄顯示設置
aside: aside:
position: right # left or right
card_author: true card_author: true
card_announcement: true card_announcement: true
card_recent_post: true card_recent_post: true
@@ -378,28 +441,94 @@ aside:
card_archives: true card_archives: true
card_webinfo: true card_webinfo: true
# 網站公告
announcement:
content: 感謝訪問本站,若喜歡請收藏 ^_^
## chinese traditional to Simplified # busuanzi count for PV / UV in site
# 訪問人數
busuanzi:
site_uv: true
site_pv: true
page_pv: true
# 網頁開通時間
# 格式: 月/日/年 時間
# 也可以寫成 年/月/日 時間
runtimeshow:
enable: true
start_date: 6/7/2018 00:00:00
#### 右下角按鈕 ####
#----------------------------------------------
# 簡繁轉換
translate: translate:
enable: true enable: true
# 默認按鈕顯示文字 # 默認按鈕顯示文字
default: default:
#网站默认语言1: 繁體中文, 2: 简体中文 #网站默认语言1: 繁體中文, 2: 简体中文
defaultEncoding: 1 defaultEncoding: 2
#延迟时间,若不在前, 要设定延迟翻译时间, 如100表示100ms,默认为0 #延迟时间,若不在前, 要设定延迟翻译时间, 如100表示100ms,默认为0
translateDelay: 0 translateDelay: 0
#博客网址 #博客网址
cookieDomain: "https://jerryc.me/" cookieDomain: "https://xxx/"
#當文字是簡體時,按鈕顯示的文字 #當文字是簡體時,按鈕顯示的文字
msgToTraditionalChinese: "繁" msgToTraditionalChinese: "繁"
#當文字是繁體時,按鈕顯示的文字 #當文字是繁體時,按鈕顯示的文字
msgToSimplifiedChinese: "简" msgToSimplifiedChinese: "简"
# 夜間模式
nightshift:
enable: true
# 鼠標點擊效果 #閲讀模式
fireworks: readmode:
enable: false enable: true
#### other ####
#------------------------------------------------
#百度推送 #百度推送
baidu_push: baidu_push:
enable: false enable: false
# https://instant.page/
# prefetch預加載
instantpage:
enable: true
# Note (Bootstrap Callout)
# https://muse.theme-next.org/docs/tag-plugins/note
note:
# Note tag style values:
# - simple bs-callout old alert style. Default.
# - modern bs-callout new (v2-v3) alert style.
# - flat flat callout style with background, like on Mozilla or StackOverflow.
# - disabled disable all CSS styles import of note tag.
style: simple
icons: true
border_radius: 3
# Offset lighter of background in % for modern and flat styles (modern: -12 | 12; flat: -18 | 6).
# Offset also applied to label tag variables. This option can work with disabled note tag.
light_bg_offset: 0
# 圖片懶加載
lazyload:
enable: true
script: https://cdn.jsdelivr.net/npm/lozad/dist/lozad.min.js
# 避免重複網址分散seo
canonical: true
# 禁止百度轉碼
disable_baidu_transformation: true
# twitter分享自動帶上樣式
# https://i.loli.net/2019/09/08/qm3RfvUCKbct1Wz.png
twitter_meta: true
# facebook QQ 等 分享自動帶上樣式
# https://i.loli.net/2019/09/08/2wbFJEKloisRvhj.png
Open_Graph_meta: true

1260
doc_CN.md

File diff suppressed because it is too large Load Diff

1260
doc_TW.md

File diff suppressed because it is too large Load Diff

View File

@@ -19,7 +19,7 @@ page:
sticky: Sticky sticky: Sticky
no_title: No title no_title: No title
read_more: Read more archives: Archives
post: post:
created: Created created: Created
@@ -50,7 +50,6 @@ pagination:
next: Next Post next: Next Post
comment: Comment comment: Comment
relatedPosts_headline: Recommend
aside: aside:
articles: Articles articles: Articles
@@ -83,5 +82,15 @@ rightside:
font_minus_title: Decrease font size font_minus_title: Decrease font size
translate_title: Traditional Chinese and Simplified Chinese Conversion translate_title: Traditional Chinese and Simplified Chinese Conversion
night_mode_title: Dark Mode night_mode_title: Dark Mode
back_to_top: Back to top
toc: Table of Contents
scroll_to_comment: Scroll to comment
setting: Setting
runtime_unit: days runtime_unit: days
copy_copyright:
author: Author
link: Link
source: Source
info: Copyright is owned by the author. For commercial reprints, please contact the author for authorization. For non-commercial reprints, please indicate the source.

View File

@@ -19,7 +19,7 @@ page:
sticky: Sticky sticky: Sticky
no_title: No title no_title: No title
read_more: Read more archives: Archives
post: post:
created: Created created: Created
@@ -50,7 +50,6 @@ pagination:
next: Next Post next: Next Post
comment: Comment comment: Comment
relatedPosts_headline: Recommend
aside: aside:
articles: Articles articles: Articles
@@ -82,5 +81,15 @@ rightside:
font_minus_title: Decrease font size font_minus_title: Decrease font size
translate_title: Traditional Chinese and Simplified Chinese Conversion translate_title: Traditional Chinese and Simplified Chinese Conversion
night_mode_title: Dark Mode night_mode_title: Dark Mode
back_to_top: Back to top
toc: Table of Contents
scroll_to_comment: Scroll to comment
setting: Setting
runtime_unit: days runtime_unit: days
copy_copyright:
author: Author
link: Link
source: Source
info: Copyright is owned by the author. For commercial reprints, please contact the author for authorization. For non-commercial reprints, please indicate the source.

View File

@@ -19,7 +19,7 @@ page:
sticky: 置顶 sticky: 置顶
no_title: 无题 no_title: 无题
read_more: 阅读更多 archives: 时间轴
post: post:
created: 发表于 created: 发表于
@@ -51,7 +51,6 @@ pagination:
next: 下一篇 next: 下一篇
comment: 评论 comment: 评论
relatedPosts_headline: 相关推荐
aside: aside:
articles: 文章 articles: 文章
@@ -83,5 +82,15 @@ rightside:
font_minus_title: 缩小字体 font_minus_title: 缩小字体
translate_title: 简繁转换 translate_title: 简繁转换
night_mode_title: 夜间模式 night_mode_title: 夜间模式
back_to_top: 回到顶部
toc: 目录
scroll_to_comment: 直达评论
setting: 设置
runtime_unit: runtime_unit:
copy_copyright:
author: 作者
link: 链接
source: 来源
info: 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

View File

@@ -15,20 +15,16 @@ page:
articles: 文章總覽 articles: 文章總覽
tag: 標籤 tag: 標籤
category: 分類 category: 分類
archives: 歸檔 archives: 時間軸
sticky: 置頂 sticky: 置頂
no_title: 無題 no_title: 無題
archives: 時間軸 archives: 時間軸
read_more: 閲讀更多
created_date: 發表於
update_date: 更新於
post: post:
created: 發表於 created: 發表於
updated: 更新於 updated: 更新於
wordcount: 字數總計 wordcount: 字數總計
commentcount: 評論數
min2read: "閲讀時長: %s 分鐘" min2read: "閲讀時長: %s 分鐘"
page_pv: 閲讀量 page_pv: 閲讀量
copyright: copyright:
@@ -56,7 +52,6 @@ pagination:
next: 下一篇 next: 下一篇
comment: 評論 comment: 評論
relatedPosts_headline: 相關推薦
aside: aside:
articles: 文章 articles: 文章
@@ -88,5 +83,15 @@ rightside:
font_minus_title: 縮小字體 font_minus_title: 縮小字體
translate_title: 簡繁轉換 translate_title: 簡繁轉換
night_mode_title: 夜間模式 night_mode_title: 夜間模式
back_to_top: 回到頂部
toc: 目錄
scroll_to_comment: 直達評論
setting: 設置
runtime_unit: runtime_unit:
copy_copyright:
author: 作者
link: 鏈接
source: 來源
info: 著作權歸作者所有。商業轉載請聯繫作者獲得授權,非商業轉載請註明出處。

View File

@@ -1,6 +1,14 @@
extends includes/layout.pug extends includes/layout.pug
block content block content
if theme.category_ui == 'index'
include ./includes/mixins/UI.pug
#recent-posts.recent-posts.category_ui
+UI_NEW(page.posts)
include includes/pagination.pug
#aside_content.aside_content
include includes/aside.pug
else
include ./includes/mixins/article-sort.pug include ./includes/mixins/article-sort.pug
#category #category
.article-sort-title= _p('page.category') + ' - ' + page.category .article-sort-title= _p('page.category') + ' - ' + page.category

View File

@@ -1,12 +1,15 @@
.flink .flink
each i in site.data.link each i in site.data.link
p.comment-word= i.class_name h1= i.class_name
.post-cards .post-cards
ul.md-links ul.md-links
each item in i.link_list each item in i.link_list
li.md-links-item li.md-links-item
a(href=item.link title=item.name target="_blank") a(href=item.link title=item.name target="_blank")
img.lozad(data-src=item.avatar alt=item.name onerror=`onerror=null;src='${theme.lodding_bg.flink}'` height="72px") if theme.lazyload.enable
img.lozad(data-src=item.avatar onerror=`onerror=null;src='${theme.lodding_bg.flink}'` height="72px")
else
img(src=item.avatar onerror=`onerror=null;src='${theme.lodding_bg.flink}'` height="72px")
div(class="md-links-title")= item.name div(class="md-links-title")= item.name
<br/> <br/>
div(class="md-links-des")=item.descr div(class="md-links-des")=item.descr

View File

@@ -22,6 +22,9 @@ if (theme.canvas_ribbon && theme.canvas_ribbon.enable)
if (theme.canvas_ribbon_piao && theme.canvas_ribbon_piao.enable) if (theme.canvas_ribbon_piao && theme.canvas_ribbon_piao.enable)
include ./third-party/canvas-ribbon-piao.pug include ./third-party/canvas-ribbon-piao.pug
if (theme.canvas_nest && theme.canvas_nest.enable)
include ./third-party/canvas-nest.pug
if theme.baidu_push && theme.baidu_push.enable if theme.baidu_push && theme.baidu_push.enable
script(src=url_for('js/baidupush.js')) script(src=url_for('js/baidupush.js'))
@@ -42,14 +45,26 @@ if is_home() && theme.subtitle.enable
script(src="https://cdn.jsdelivr.net/npm/typed.js@2.0.9") script(src="https://cdn.jsdelivr.net/npm/typed.js@2.0.9")
script. script.
var typed = new Typed(".subtitle", { var typed = new Typed(".subtitle", {
strings: ['!{theme.subtitle.sub1}','!{theme.subtitle.sub2}'], strings: '!{theme.subtitle.sub}'.split(","),
startDelay: 300, startDelay: 300,
typeSpeed: 100, typeSpeed: 100,
loop: true, loop: true,
backSpeed: 50 backSpeed: 50
}); });
if is_home() if theme.busuanzi.site_uv || theme.busuanzi.site_pv || theme.busuanzi.page_pv
script(async src="//busuanzi.ibruce.info/busuanzi/2.3/busuanzi.pure.mini.js")
if theme.instantpage.enable
script(src="https://cdn.jsdelivr.net/npm/instant.page@1.2.2/instantpage.min.js" type="module")
if theme.lazyload.enable
script(src=url_for(theme.lazyload.script))
script.
const observer = lozad(); // lazy loads elements with default selector as '.lozad'
observer.observe();
if is_home() && !theme.index_top_img_height && !theme.index_site_info_top
script. script.
//首頁fullpage //首頁fullpage
function alignContent() { function alignContent() {
@@ -60,32 +75,9 @@ if is_home()
$(this).css("top", (n-x)/2) $(this).css("top", (n-x)/2)
}) })
} }
function recent_post_padding() {
$(".recent-post-info").each(function () {
var k = $(".recent-post-item").height();
var e = $(this).height();
$(this).css({"padding-top": (k-e)/2 , "padding-bottom": (k-e)/2 })
})
}
alignContent(); alignContent();
//recent-post-item垂直置中
if ($(window).width() > 768) {
recent_post_padding();
}
$(window).bind("resize", function () { $(window).bind("resize", function () {
alignContent() alignContent()
if ($(window).width() > 768) {
recent_post_padding();
}
}) })
if theme.busuanzi.site_uv || theme.busuanzi.site_pv || theme.busuanzi.page_pv
script(async src="//busuanzi.ibruce.info/busuanzi/2.3/busuanzi.pure.mini.js")
script(src="https://cdn.jsdelivr.net/npm/instant.page@1.2.2/instantpage.min.js" type="module")

View File

@@ -1,132 +1,21 @@
if theme.aside.card_author if theme.aside.card_author
.card_widget.card-author include widget/card_author.pug
.card-content
.post_data
.data-item.text-center
img.lozad(data-src=theme.avatar || url_for('/img/avatar.png') onerror=`onerror=null;src='${theme.lodding_bg.flink}'`)
p.author-info__name.text-center= config.author
p.author-info__description.text-center= config.description
.post_data.data_config
if site.posts.length
.data-item.text-center
.data_link
a(href=url_for(config.archive_dir) + '/')
p.headline= _p('aside.articles')
p.length_num= site.posts.length
if site.tags.length
.data-item.text-center
.data_link
a(href=url_for(config.tag_dir) + '/' )
p.headline= _p('aside.tags')
p.length_num= site.tags.length
if site.categories.length
.data-item.text-center
.data_link
a(href=url_for(config.category_dir) + '/')
p.headline= _p('aside.categories')
p.length_num= site.categories.length
.post_data.text-center
a#bookmark-it.data-item.bookmark.bookmarke--primary.bookmark--animated(href="javascript:;" title= _p('aside.card_bookmark') )= _p('aside.card_bookmark') || 'Follow Me'
if(theme.social)
.post_data.data_config
#aside-social-icons
each url, icon in theme.social
a.social-icon.data-item(href=url target="_blank")
i(class=icon)
if theme.aside.card_announcement if theme.aside.card_announcement
.card_widget.card-announcement include widget/card_announcement.pug
.card-content
.item_headline
i.fa.fa-bullhorn.card-announcement-animation(aria-hidden="true")
span= _p('aside.card_announcement')
.announcement_content= theme.announcement.content
if theme.aside.card_recent_post if theme.aside.card_recent_post
.card_widget.card-recent-post include widget/card_recent_post.pug
.card-content
.item_headline
i.fa.fa-history(aria-hidden="true")
span= _p('aside.card_recent_post')
.aside_recent_item
- site.posts.sort('date', -1).limit(5).each(function(article){
.aside_recent_post
- var link = article.link || article.path
a(href=url_for(link))
- var post_cover = article.cover
- var default_post_cover = theme.default_cover
.aside_post_cover
if (post_cover)
img.aside_post_bg.lozad(data-src=`${post_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'` title=article.title || _p('no_title'))
else
img.aside_post_bg.lozad(data-src=`${default_post_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'` title=article.title || _p('no_title'))
div#aside_title
.aside_post_title(href=url_for(link) title=article.title || _p('no_title'))= article.title || _p('no_title')
if (theme.post_meta.date_type)
- var date_type = theme.post_meta.date_type == 'updated' ? 'updated' : 'date'
time.aside_post_meta.post-meta__date #[=date(article[date_type], config.date_format)]
- })
if theme.aside.card_categories if theme.aside.card_categories
.card_widget.card-categories include widget/card_categories.pug
.card-content
.item_headline
i.fa.fa-folder-open(aria-hidden="true")
span= _p('aside.card_categories')
ul.aside_category_item
- site.categories.sort('name').each(function(category){
li.aside_category_list
a.aside_category_list_link(href='/' + `${category.path}`)
span.aside_category_list_name= category.name
span.aside_category_list_length= category.length
- })
if theme.aside.card_tags if theme.aside.card_tags
.card_widget.card-tags include widget/card_tags.pug
.card-content
.item_headline
i.fa.fa-tags(aria-hidden="true")
span= _p('aside.card_tags')
.card-tag-cloud!= tagcloud({min_font: 16, max_font: 24, amount: 200, color: true, start_color: '#999', end_color: '#000'})
if theme.aside.card_archives if theme.aside.card_archives
.card_widget.card-archives include widget/card_archives.pug
.card-content
.item_headline
i.fa.fa-archive(aria-hidden="true")
span= _p('aside.card_archives')
div.archives_item!= list_archives({type:'monthly',format: 'YYYY年MM月'})
if theme.aside.card_webinfo if theme.aside.card_webinfo
.card_widget.card-webinfo include widget/card_webinfo.pug
.card-content
.item_headline
i.fa.fa-line-chart(aria-hidden="true")
span= _p('aside.card_webinfo.headline')
.webinfo
.webinfo_item
.webinfo_article_name= _p('aside.card_webinfo.article_name') + " :"
.webinfo_article_count= site.posts.length
if theme.runtimeshow.enable
.webinfo_item
.webinfo_runtime_name= _p('aside.card_webinfo.runtime_name') + " :"
#webinfo_runtime_count.webinfo_runtime_count
script#runtionshow(src=url_for('js/runtimeshow.js') start_date=theme.runtimeshow.start_date)
if theme.busuanzi.site_uv
.webinfo_item
.webinfo_site_uv_name= _p('aside.card_webinfo.site_uv_name') + " :"
.webinfo_site_uv_count#busuanzi_value_site_uv
if theme.busuanzi.site_pv
.webinfo_item
.webinfo_site_name= _p('aside.card_webinfo.site_pv_name') + " :"
.webinfo_site_pv_count#busuanzi_value_site_pv

View File

@@ -1,4 +1,4 @@
if theme.disqus.enable if theme.disqus && theme.disqus.enable
#disqus_thread #disqus_thread
script. script.
var unused = null; var unused = null;
@@ -11,5 +11,3 @@ if theme.disqus.enable
s.src = "https://" + '!{theme.disqus.shortname}' +".disqus.com/embed.js"; s.src = "https://" + '!{theme.disqus.shortname}' +".disqus.com/embed.js";
s.setAttribute('data-timestamp', '' + +new Date()); s.setAttribute('data-timestamp', '' + +new Date());
(d.head || d.body).appendChild(s); (d.head || d.body).appendChild(s);
if theme.disqus.count
script#dsq-count-scr(src="https://" + theme.disqus.shortname + ".disqus.com/count.js" async)

View File

@@ -1,13 +1,13 @@
if theme.gitment && theme.gitment.enable if theme.gitalk && theme.gitalk.enable
#gitment-container #gitalk-container
script. script.
var gitment = new Gitment({ var gitalk = new Gitalk({
clientID: '!{theme.gitalk.client_id}',
clientSecret: '!{theme.gitalk.client_secret}',
repo: '!{theme.gitalk.repo}',
owner: '!{theme.gitalk.owner}',
admin: '!{theme.gitalk.admin}',
id: md5(decodeURI(location.pathname)), id: md5(decodeURI(location.pathname)),
owner: '!{theme.gitment.owner}', language: '!{theme.gitalk.language}'
repo: '!{theme.gitment.repo}',
oauth: {
client_id: '!{theme.gitment.client_id}',
client_secret: '!{theme.gitment.client_secret}'
}
}) })
gitment.render('gitment-container') gitalk.render('gitalk-container')

View File

@@ -2,6 +2,7 @@ if theme.gitment && theme.gitment.enable
#gitment-container #gitment-container
script. script.
var gitment = new Gitment({ var gitment = new Gitment({
id: md5(decodeURI(location.pathname)),
owner: '!{theme.gitment.owner}', owner: '!{theme.gitment.owner}',
repo: '!{theme.gitment.repo}', repo: '!{theme.gitment.repo}',
oauth: { oauth: {

View File

@@ -1,40 +1,35 @@
if theme.disqus.enable if theme.disqus && theme.disqus.enable
hr hr
#post-comment #post-comment
.comment_headling .comment_headling
i.fa.fa-comments.fa-fw(aria-hidden="true") i.fa.fa-comments.fa-fw(aria-hidden="true")
=" " span= ' ' + _p('comment')
span= _p('comment')
include ./disqus.pug include ./disqus.pug
else if theme.laibili && theme.laibili.enable else if theme.laibili && theme.laibili.enable
hr hr
#post-comment #post-comment
.comment_headling .comment_headling
i.fa.fa-comments.fa-fw(aria-hidden="true") i.fa.fa-comments.fa-fw(aria-hidden="true")
=" " span= ' ' + _p('comment')
span= _p('comment')
include ./laibili.pug include ./laibili.pug
else if theme.gitment && theme.gitment.enable else if theme.gitment && theme.gitment.enable
hr hr
#post-comment #post-comment
.comment_headling .comment_headling
i.fa.fa-comments.fa-fw(aria-hidden="true") i.fa.fa-comments.fa-fw(aria-hidden="true")
=" " span= ' ' + _p('comment')
span= _p('comment')
include ./gitment.pug include ./gitment.pug
else if theme.gitalk && theme.gitalk.enable else if theme.gitalk && theme.gitalk.enable
hr hr
#post-comment #post-comment
.comment_headling .comment_headling
i.fa.fa-comments.fa-fw(aria-hidden="true") i.fa.fa-comments.fa-fw(aria-hidden="true")
=" " span= ' ' + _p('comment')
span= _p('comment')
include ./gitalk.pug include ./gitalk.pug
else if theme.valine && theme.valine.enable else if theme.valine && theme.valine.enable
hr hr
#post-comment #post-comment
.comment_headling .comment_headling
i.fa.fa-comments.fa-fw(aria-hidden="true") i.fa.fa-comments.fa-fw(aria-hidden="true")
=" " span= ' ' + _p('comment')
span= _p('comment')
include ./valine.pug include ./valine.pug

View File

@@ -1,60 +1,16 @@
if theme.valine && theme.valine.enable if theme.valine && theme.valine.enable
#vcomment.vcomment #vcomment.vcomment
script(src='https://cdn1.lncld.net/static/js/3.0.4/av-min.js')
script(src='https://cdn.jsdelivr.net/npm/valine/dist/Valine.min.js') script(src='https://cdn.jsdelivr.net/npm/valine/dist/Valine.min.js')
script. script.
var notify = '#{ theme.valine.notify }' == true ? true : false; var notify = #{ theme.valine.notify } == true ? true : false;
var verify = '#{ theme.valine.verify }' == true ? true : false; var verify = #{ theme.valine.verify } == true ? true : false;
var GUEST_INFO = ['nick','mail','link']; var GUEST_INFO = ['nick','mail','link'];
var guest_info = '#{ theme.valine.guest_info }'.split(',').filter(function(item){ var guest_info = '#{ theme.valine.guest_info }'.split(',').filter(function(item){
return GUEST_INFO.indexOf(item) > -1 return GUEST_INFO.indexOf(item) > -1
}); });
guest_info = guest_info.length == 0 ? GUEST_INFO :guest_info; guest_info = guest_info.length == 0 ? GUEST_INFO :guest_info;
var localeName = 'tw', window.valine = new Valine({
localeMode = {
head: {
nick: '暱稱(必填)',
mail: '郵箱(必填,可以收到回復提醒)',
link: '網址(選填)',
},
tips: {
comments: '評論',
sofa: '快來做第一個評論的人吧~',
busy: '還在提交中,請稍候...',
again: '這麼簡單也能錯,也是沒誰了.'
},
ctrl: {
reply: '回覆',
ok: '好的',
sure: '確認',
cancel: '取消',
confirm: '確認',
continue: '繼續',
more: '查看更多...',
try: '再試試?',
preview: '預覽',
emoji: '表情'
},
error: {
99: '初始化失敗請檢查init中的`el`元素.',
100: '初始化失敗請檢查你的AppId和AppKey.',
401: '未經授權的操作請檢查你的AppId和AppKey.',
403: '訪問被api域名白名單拒絕請檢查你的安全域名設置.',
},
timeago: {
seconds: '秒前',
minutes: '分鐘前',
hours: '小時前',
days: '天前',
now: '剛剛'
}
};
window.valine = new Valine();
valine.installLocale(localeName,localeMode);
valine.init({
el:'#vcomment', el:'#vcomment',
notify:notify, notify:notify,
verify:verify, verify:verify,

View File

@@ -28,7 +28,6 @@
} }
var translate = 'undefined'; var translate = 'undefined';
if (theme.translate && theme.translate.enable){ if (theme.translate && theme.translate.enable){
var defaultEncoding;
translate = JSON.stringify({ translate = JSON.stringify({
defaultEncoding: theme.translate.defaultEncoding, defaultEncoding: theme.translate.defaultEncoding,
translateDelay: theme.translate.translateDelay, translateDelay: theme.translate.translateDelay,
@@ -38,7 +37,19 @@
}) })
} }
var copyright = 'undefined' ;
if (theme.copy.enable && theme.copy.copyright){
copyright = JSON.stringify({
languages: {
author: _p("copy_copyright.author") + ': ' + config.author,
link: _p("copy_copyright.link") + ': ' + without_html,
source: _p("copy_copyright.source") + ': ' + config.title,
info: _p("copy_copyright.info")
}
})
}
var copy_copyright_js = theme.copy.enable && theme.copy.copyright
@@ -49,6 +60,8 @@ script.
localSearch: !{localSearch}, localSearch: !{localSearch},
translate: !{translate}, translate: !{translate},
highlight_copy: '!{theme.highlight_copy}', highlight_copy: '!{theme.highlight_copy}',
highlight_lang: '!{theme.highlight_lang}',
highlight_shrink: '!{theme.highlight_shrink}',
copy: { copy: {
success: '!{_p("copy.success")}', success: '!{_p("copy.success")}',
error: '!{_p("copy.error")}', error: '!{_p("copy.error")}',
@@ -59,8 +72,9 @@ script.
message_prev: '!{_p("bookmark.message_prev")}', message_prev: '!{_p("bookmark.message_prev")}',
message_next: '!{_p("bookmark.message_next")}' message_next: '!{_p("bookmark.message_next")}'
}, },
runtime_unit: '!{_p("runtime_unit")}' runtime_unit: '!{_p("runtime_unit")}',
copyright: !{copyright},
copy_copyright_js: !{copy_copyright_js}
} }

View File

@@ -1,4 +1,4 @@
#footer.layout #footer
- var now = new Date() - var now = new Date()
- var nowYear = now.getFullYear() - var nowYear = now.getFullYear()
if theme.since && theme.since != nowYear if theme.since && theme.since != nowYear
@@ -19,4 +19,6 @@
if theme.ICP.enable if theme.ICP.enable
.icp .icp
a(href=theme.ICP.url) a(href=theme.ICP.url)
if theme.ICP.icon
img.icp-icon(src=url_for(theme.ICP.icon))
span=theme.ICP.text span=theme.ICP.text

View File

@@ -1,5 +1,7 @@
- var without_index = url.replace('index.html', '') - var without_index = url.replace('index.html', '')
- var without_html = without_index.replace('.html', '') - var without_html = without_index.replace('.html', '')
- var photo_check = is_post() ? page.cover || theme.avatar : theme.avatar
- var photo_link = url_check (photo_check) ? photo_check : config.url + photo_check
meta(http-equiv="x-dns-prefetch-control" content="on") meta(http-equiv="x-dns-prefetch-control" content="on")
if theme.canonical if theme.canonical
@@ -9,7 +11,7 @@ if theme.twitter_meta
meta(name="twitter:card" content="summary_large_image") meta(name="twitter:card" content="summary_large_image")
meta(name="twitter:title" content=pageTitle_no_include_blog_name) meta(name="twitter:title" content=pageTitle_no_include_blog_name)
meta(name="twitter:description" content=pageDescription) meta(name="twitter:description" content=pageDescription)
meta(name="twitter:image" content= page.cover|| theme.avatar) meta(name="twitter:image" content=photo_link)
if theme.Open_Graph_meta if theme.Open_Graph_meta
if is_post() if is_post()
@@ -21,7 +23,7 @@ if theme.Open_Graph_meta
meta(property="og:url" content=without_html) meta(property="og:url" content=without_html)
meta(property="og:site_name" content=config.title) meta(property="og:site_name" content=config.title)
meta(property="og:description" content=pageDescription) meta(property="og:description" content=pageDescription)
meta(property="og:image" content= page.cover|| theme.avatar) meta(property="og:image" content=photo_link)
if theme.disable_baidu_transformation if theme.disable_baidu_transformation
meta(http-equiv="Cache-Control" content="no-transform") meta(http-equiv="Cache-Control" content="no-transform")
@@ -105,9 +107,18 @@ if theme.qihu_site_verification
- var preload_archive_img = theme.archive_img ||theme.top_img || config.top_img - var preload_archive_img = theme.archive_img ||theme.top_img || config.top_img
- var preload_tag_img = theme.tag_img ||theme.top_img || config.top_img
- var preload_category_img = theme.category_img ||theme.top_img || config.top_img
- var preload_img = page.top_img || theme.top_img || config.top_img - var preload_img = page.top_img || theme.top_img || config.top_img
if (is_archive() && preload_archive_img) if (is_archive() && preload_archive_img)
link(rel="preload" href=preload_img as="image" ) link(rel="preload" href=url_for(preload_archive_img) as="image" )
else if (is_tag() && preload_tag_img)
link(rel="preload" href=url_for(preload_tag_img) as="image" )
else if (is_category() && preload_category_img)
link(rel="preload" href=url_for(preload_category_img) as="image" )
else if (!is_post() && preload_img) else if (!is_post() && preload_img)
link(rel="preload" href=preload_img as="image" ) link(rel="preload" href=url_for(preload_img) as="image" )
if theme.blog_title_font.font_link
link(rel='stylesheet', href=url_for(theme.blog_title_font.font_link))

View File

@@ -1,20 +1,12 @@
#header
#page-header #page-header
span.pull-left span#blog_name.pull-left
a#site-name.blog_title(href=url_for('/')) #[=config.title] a#site-name.blog_title(href=url_for('/')) #[=config.title]
//- i.fa.fa-bars.toggle-menu.pull-right(aria-hidden="true") i.fa.fa-bars.fa-fw.toggle-menu.pull-right.close(aria-hidden="true")
.open.toggle-menu.pull-right
.menu-icon-first
.menu-icon-second
.menu-icon-third
span.pull-right.menus span.pull-right.menus
each value, label in theme.menu .menus_items
a.site-page(href=value.split('||')[0]) include menu_item.pug
i.fa-fw(class=value.split('||')[1]) span#search_button.pull-right
span=' '+label
script.
document.body.addEventListener('touchstart', function(){ });
span.pull-right
if (theme.algolia_search.enable || theme.local_search && theme.local_search.enable) if (theme.algolia_search.enable || theme.local_search && theme.local_search.enable)
a.site-page.social-icon.search a.site-page.social-icon.search
i.fa.fa-search.fa-fw i.fa.fa-search.fa-fw

View File

@@ -7,18 +7,24 @@
- if (is_year()) pageTitle += ': ' + page.year - if (is_year()) pageTitle += ': ' + page.year
- var pageTitle_saved //- 暫時存儲pageTitle - var pageTitle_saved //- 暫時存儲pageTitle
- var pageTitle_no_include_blog_name //- 存儲pageTitle 不帶 " | "meta用 - var pageTitle_no_include_blog_name //- 存儲pageTitle 不帶 " | "meta用
- var home_subtitle_true //有subtitle
//- home時顯示config.title (JerryC),其他顯示 pageTitle。meta用 //- home時顯示config.title (JerryC),其他顯示 pageTitle。meta用
- is_home() ? pageTitle_no_include_blog_name = config.title : pageTitle_no_include_blog_name = pageTitle - is_home() ? pageTitle_no_include_blog_name = config.title : pageTitle_no_include_blog_name = pageTitle
//- 暫時存儲pageTitle //- 暫時存儲pageTitle
- pageTitle ? pageTitle_saved = pageTitle + ' | ' + config.title : pageTitle_saved = config.title - pageTitle ? pageTitle_saved = pageTitle + ' | ' + config.title : pageTitle_saved = config.title
//- 是否有 config.subtitle 是各自显示
- config.subtitle ? home_subtitle_true = ' - ' + config.subtitle : home_subtitle_true = ''
//- home時pageTitle顯示 JerryC - subtitle其他顯示 pageTitle | JerryC //- home時pageTitle顯示 JerryC - subtitle其他顯示 pageTitle | JerryC
- is_home() ? pageTitle = config.title + ' - ' + config.subtitle : pageTitle = pageTitle_saved - is_home() ? pageTitle = config.title + home_subtitle_true : pageTitle = pageTitle_saved
//- 判断keywords
- var pageDescription = page.description || page.title || config.description || '' - var pageDescription = page.description || page.title || config.description || ''
- var pageKeywords = (config.keywords || []).join(',') - var pageKeywords = Array.isArray(config.keywords) ? (config.keywords).join(','): ([]).join(',') || config.keywords
- if (page.tags && page.tags.data) pageKeywords = page.tags.data.map(function(tag) {return tag.name;}).join(',') - if (page.tags && page.tags.data) pageKeywords = page.tags.data.map(function(tag) {return tag.name;}).join(',')
- var pageAuthor = config.email ? config.author + ',' + config.email : config.author - var pageAuthor = config.email ? config.author + ',' + config.email : config.author
- var pageCopyright = config.copyright || config.author - var pageCopyright = config.copyright || config.author
- var body_class = theme.display_mode == 'night' ? 'night-mode' : ''
doctype html doctype html
html(lang=config.language) html(lang=config.language)
@@ -41,9 +47,14 @@ html(lang=config.language)
link(rel='stylesheet', href=item) link(rel='stylesheet', href=item)
include ./head.pug include ./head.pug
include ./config.pug include ./config.pug
body body(class=body_class)
if theme.fireworks && theme.fireworks.enable if theme.fireworks && theme.fireworks.enable
canvas.fireworks canvas.fireworks
include ./header.pug
include ./mobile-sidebar.pug
#body-wrap
if theme.background
#web_bg
if (is_post() && page.toc != false && theme.toc.enable) if (is_post() && page.toc != false && theme.toc.enable)
i.fa.fa-arrow-right#toggle-sidebar(aria-hidden="true") i.fa.fa-arrow-right#toggle-sidebar(aria-hidden="true")
include ./sidebar.pug include ./sidebar.pug
@@ -63,13 +74,10 @@ html(lang=config.language)
div!= body div!= body
else else
block content block content
//- - var top_img = page.top_img || theme.post_meta.top_img || theme.top_img || config.top_img || true
//- - var bg_img = top_img !== true ? `background-image: url(${top_img})` : '' - var footer_bg = theme.footer_bg == false ? '' : bg_img
//- - var footer_bg_class= bg_img ? 'footer-bg' : '' footer(style=footer_bg)
//- footer(style=bg_img class=footer_bg_class)
footer
include ./footer.pug include ./footer.pug
i.fa.fa-arrow-up#go-up(aria-hidden="true")
include ./rightside.pug include ./rightside.pug
each item in theme.cdn.js each item in theme.cdn.js
if item !== undefined if item !== undefined

View File

@@ -0,0 +1,20 @@
each value, label in theme.menu
if !Array.isArray(value)
.menus_item
a.site-page(href=trim(value.split('||')[0]))
i.fa-fw(class=trim(value.split('||')[1]))
span=' '+label
else
.menus_item
a.site-page
i.fa-fw(class=trim(label.split('||')[1]) aria-hidden="true")
span=' '+ trim(label.split('||')[0])
i.fa.fa-chevron-down.menus-expand(aria-hidden="true")
ul.menus_item_child
each i in value
li
a.site-page(href=trim(i.split('||')[1]))
i.fa-fw(class=trim(i.split('||')[2]))
span=' '+trim(i.split('||')[0])
script.
document.body.addEventListener('touchstart', function(){ });

View File

@@ -0,0 +1,41 @@
mixin UI_NEW(posts)
- posts.each(function(article,index){
.recent-post-item.article-container
- var link = article.link || article.path
if index%2 == 0
.post_cover.is_left
a(href=url_for(link) title=article.title || _p('no_title'))
- var post_cover = article.cover
if theme.lazyload.enable
img.post_bg.lozad(data-src=`${post_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'`)
else
img.post_bg(src=`${post_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'`)
else
.post_cover.is_right
a(href=url_for(link) title=article.title || _p('no_title'))
- var post_cover = article.cover
if theme.lazyload.enable
img.post_bg.lozad(data-src=`${post_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'`)
else
img.post_bg(src=`${post_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'`)
.recent-post-info
a.article-title(href=url_for(link) title= article.title || _p('no_title'))= article.title || _p('no_title')
if (theme.post_meta.date_type)
- var date_type = theme.post_meta.date_type == 'updated' ? 'updated' : 'date'
time.post-meta__date #[i.fa.fa-calendar(aria-hidden="true")] #[=date(article[date_type], config.date_format)]
if (theme.post_meta.categories && article.categories.data.length > 0)
span.article-meta
span.article-meta__separator |
each item, index in article.categories.data
i.fa.fa-inbox.article-meta__icon(aria-hidden="true")
a(href=url_for(item.path)).article-meta__categories #[=item.name]
if (index < article.categories.data.length - 1)
i.fa.fa-angle-right(aria-hidden="true")
if theme.auto_excerpt && theme.auto_excerpt.enable
- const content = strip_html(article.content)
- let expert = content.substring(0, theme.auto_excerpt.length)
- content.length > theme.auto_excerpt.length ? expert += ' ...' : ''
.content!= expert
else
.content!= article.description
- })

View File

@@ -7,6 +7,12 @@ mixin articleSort(posts)
- year = tempYear - year = tempYear
.article-sort-item.year= year .article-sort-item.year= year
.article-sort-item .article-sort-item
.article-sort-img
a.article-sort-item__img(href=url_for(article.path))
img(src=article.cover)
.article-sort-post
a.article-sort-item__post(href=url_for(article.path))
i.fa.fa-clock-o(aria-hidden="true")
time.article-sort-item__time= date(article.date) time.article-sort-item__time= date(article.date)
a.article-sort-item__title(href=url_for(article.path))= article.title || 'No Title' .article-sort-item__title= article.title || 'No Title'
- }) - })

View File

@@ -0,0 +1,46 @@
#mobile-sidebar
#menu_mask
#mobile-sidebar-menus
.mobile_author_icon
img.lozad.avatar_img(src=url_for(theme.avatar) onerror=`onerror=null;src='${theme.lodding_bg.flink}'`)
.mobile_post_data
if site.posts.length
.mobile_data_item.is_center
.mobile_data_link
a(href=url_for(config.archive_dir) + '/')
.headline= _p('aside.articles')
.length_num= site.posts.length
if site.tags.length
.mobile_data_item.is_center
.mobile_data_link
a(href=url_for(config.tag_dir) + '/' )
.headline= _p('aside.tags')
.length_num= site.tags.length
if site.categories.length
.mobile_data_item.is_center
.mobile_data_link
a(href=url_for(config.category_dir) + '/')
.headline= _p('aside.categories')
.length_num= site.categories.length
hr
.menus_items
include menu_item.pug
- const showToc = is_post() && page.toc != false && theme.toc.enable
-
let tocNumber
if (page.toc_number !== undefined) tocNumber = page.toc_number
else if (theme.toc.number !== undefined) tocNumber = theme.toc.number
else tocNumber = true
-
if (showToc)
#mobile-sidebar-toc
.toc_mobile_headline= _p('sidebar.catalog')
if (page.encrypt == true)
.toc-div-class(style="display:none")!=toc(page.origin,{"class":"toc_mobile_items",list_number:tocNumber})
else
!=toc(page.content,{"class":"toc_mobile_items",list_number:tocNumber})

View File

@@ -1,5 +1,9 @@
if (is_archive()) if is_archive()
- var top_img = theme.archive_img ||theme.top_img || config.top_img - var top_img = theme.archive_img ||theme.top_img || config.top_img
else if is_tag()
- var top_img = theme.tag_img ||theme.top_img || config.top_img
else if is_category()
- var top_img = theme.category_img ||theme.top_img || config.top_img
else else
- var top_img = page.top_img||theme.top_img || config.top_img - var top_img = page.top_img||theme.top_img || config.top_img
@@ -7,8 +11,8 @@ else
if is_home() if is_home()
nav#nav.full_page(style=bg_img) nav#nav.full_page
include ./header.pug .nav_bg(style=bg_img)
#site-info #site-info
#site-title #site-title
span.blogtitle= page.title || page.tag || page.category || config.title span.blogtitle= page.title || page.tag || page.category || config.title
@@ -25,8 +29,8 @@ if is_home()
i.fa.fa-angle-down.scroll-down-effects i.fa.fa-angle-down.scroll-down-effects
else else
nav#nav.bg_local(style=bg_img) nav#nav.not_index_bg
include ./header.pug .nav_bg(style=bg_img)
#page_site-info #page_site-info
#site-title #site-title
if (is_archive()) if (is_archive())

View File

@@ -0,0 +1,6 @@
- site.tags.sort('path').each(function (tags){
- var fontSize = Math.floor(Math.random() * 15 + 15) + "px"; //15 ~ 30
- var color = "rgb(" + Math.floor(Math.random() * 201) + ", " + Math.floor(Math.random() * 201) +", " + Math.floor(Math.random() * 201) +")"; // 0,0,0 -> 200,200,200
a(href=url_for(tags.path) style='font-size:' + fontSize + ';color:' + color)=tags.name
-})

View File

@@ -14,43 +14,49 @@ else
if(page.prev) if(page.prev)
if(page.next) if(page.next)
.prev-post.pull-left .prev-post.pull-left
- var pagination_cover = page.prev.cover || theme.default_cover - var pagination_cover = page.prev.cover
a(href=url_for(page.prev.path)) a(href=url_for(page.prev.path))
if theme.lazyload.enable
img.prev_cover.lozad(data-src=`${pagination_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'` ) img.prev_cover.lozad(data-src=`${pagination_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'` )
else
img.prev_cover(src=`${pagination_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'` )
.label=_p('pagination.prev') .label=_p('pagination.prev')
.prev_info .prev_info
//- i.fa.fa-chevron-left
span=page.prev.title span=page.prev.title
else else
.prev-post.pull-full .prev-post.pull-full
- var pagination_cover = page.prev.cover || theme.default_cover - var pagination_cover = page.prev.cover
a(href=url_for(page.prev.path)) a(href=url_for(page.prev.path))
if theme.lazyload.enable
img.prev_cover.lozad(data-src=`${pagination_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'`) img.prev_cover.lozad(data-src=`${pagination_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'`)
else
img.prev_cover(src=`${pagination_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'`)
.label=_p('pagination.prev') .label=_p('pagination.prev')
.prev_info .prev_info
//- i.fa.fa-chevron-left
span=page.prev.title span=page.prev.title
if(page.next) if(page.next)
if(page.prev) if(page.prev)
.next-post.pull-right .next-post.pull-right
- var pagination_cover = page.next.cover || theme.default_cover - var pagination_cover = page.next.cover
a(href=url_for(page.next.path)) a(href=url_for(page.next.path))
if theme.lazyload.enable
img.next_cover.lozad(data-src=`${pagination_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'`) img.next_cover.lozad(data-src=`${pagination_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'`)
else
img.next_cover(src=`${pagination_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'`)
.label=_p('pagination.next') .label=_p('pagination.next')
.next_info .next_info
span=page.next.title span=page.next.title
//- i.fa.fa-chevron-right
else else
.next-post.pull-full .next-post.pull-full
- var pagination_cover = page.next.cover || theme.default_cover - var pagination_cover = page.next.cover
a(href=url_for(page.next.path)) a(href=url_for(page.next.path))
if theme.lazyload.enable
img.next_cover.lozad(data-src=`${pagination_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'`) img.next_cover.lozad(data-src=`${pagination_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'`)
else
img.next_cover(src=`${pagination_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'`)
.label=_p('pagination.next') .label=_p('pagination.next')
.next_info .next_info
span=page.next.title span=page.next.title
//- i.fa.fa-chevron-right

View File

@@ -3,23 +3,20 @@ each article , index in page.posts.data
- var link = article.link || article.path - var link = article.link || article.path
if index%2 == 0 if index%2 == 0
.post_cover.is_left .post_cover.is_left
a(href=url_for(link)) a(href=url_for(link) title=article.title || _p('no_title'))
- var post_cover = article.cover - var post_cover = article.cover
- var default_post_cover = theme.default_cover if theme.lazyload.enable
if (post_cover) img.post_bg.lozad(data-src=`${post_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'`)
img.post_bg.lozad(data-src=`${post_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'` title=article.title || _p('no_title'))
else else
img.post_bg.lozad(data-src=`${default_post_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'` title=article.title || _p('no_title')) img.post_bg(src=`${post_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'`)
else else
.post_cover.is_right .post_cover.is_right
a(href=url_for(link)) a(href=url_for(link) title=article.title || _p('no_title'))
- var post_cover = article.cover - var post_cover = article.cover
- var default_post_cover = theme.default_cover if theme.lazyload.enable
if (post_cover) img.post_bg.lozad(data-src=`${post_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'`)
img.post_bg.lozad(data-src=`${post_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'` title=article.title || _p('no_title'))
else else
img.post_bg.lozad(data-src=`${default_post_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'` title=article.title || _p('no_title')) img.post_bg(src=`${post_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'`)
.recent-post-info .recent-post-info
a.article-title(href=url_for(link) title= article.title || _p('no_title'))= article.title || _p('no_title') a.article-title(href=url_for(link) title= article.title || _p('no_title'))= article.title || _p('no_title')
if (article.top) if (article.top)
@@ -38,21 +35,11 @@ each article , index in page.posts.data
a(href=url_for(item.path)).article-meta__categories #[=item.name] a(href=url_for(item.path)).article-meta__categories #[=item.name]
if (index < article.categories.data.length - 1) if (index < article.categories.data.length - 1)
i.fa.fa-angle-right(aria-hidden="true") i.fa.fa-angle-right(aria-hidden="true")
//- if (theme.post_meta.tags && article.tags.data.length > 0)
//- span.article-meta.tags
//- span.article-meta__separator |
//- each item, index in article.tags.data
//- i.fa.fa-tag.article-meta__icon(aria-hidden="true")
//- a(href=url_for(item.path)).article-meta__tags #[=item.name]
//- if (index < article.tags.data.length - 1)
//- span.article-meta__link -
if theme.auto_excerpt && theme.auto_excerpt.enable if theme.auto_excerpt && theme.auto_excerpt.enable
- const content = strip_html(article.content) - const content = strip_html(article.content)
- let expert = content.substring(0, theme.auto_excerpt.length) - let expert = content.substring(0, theme.auto_excerpt.length)
- content.length > theme.auto_excerpt.length ? expert += ' ...' : '' - content.length > theme.auto_excerpt.length ? expert += ' ...' : ''
.content!= expert .content!= expert
.more_setting
a.more.more--border.more--primary.more--animated(href=url_for(link) + '#more' style="margin-top: 14px")= _p('read_more')
else else
.content!= article.description .content!= article.description

View File

@@ -1,6 +0,0 @@
.relatedPosts
.relatedPosts_headline
i.fa.fa-thumbs-up(aria-hidden="true")
span=' ' + _p('relatedPosts_headline')
.relatedPosts_list!= related_posts(page,site.posts)
.clear_both

View File

@@ -1,65 +1,11 @@
.post-reward .post-reward
a.reward-buttom a.reward-button
i.fa.fa-qrcode i.fa.fa-qrcode
= ' ' + _p('donate') = ' ' + _p('donate')
.reward-main .reward-main
ul.reward-all ul.reward-all
each item in theme.reward.QR_code each item in theme.reward.QR_code
li.reward-item li.reward-item
img.lozad.post-qr-code__img(data-src=(item.itemlist||item).img) img.lozad.post-qr-code__img(src=(item.itemlist||item).img)
.post-qr-code__desc=(item.itemlist||item).text .post-qr-code__desc=(item.itemlist||item).text
//- donate-share样式1
//- .post-reward-share
//- .post-reward
//- a.reward-buttom
//- i.fa.fa-qrcode
//- = ' ' + _p('donate')
//- .reward-main
//- ul.reward-all
//- each item in theme.QR_code
//- li.reward-item
//- img.lozad.post-qr-code__img(data-src=(item.itemlist||item).img)
//- .post-qr-code__desc=(item.itemlist||item).text
//- .post-share
//- include share/index.pug
//- a.share-buttom
//- i.fa.fa-share-alt
//- = ' ' + _p('share')
//- donate-share样式1
//- #social
//- .social-main
//- span.social-donate
//- a#social-donate
//- i.fa.fa-qrcode
//- = _p('donate')
//- .circle
//- .circle-empty
//- span
//- span.circle_item
//- a(style="cursor:pointer")
//- .social-sharebutton
//- span.share-s
//- a(href="javascript:void(0)" id="share-s" title=_p('share'))
//- i.fa.fa-share-alt
//- = _p('share')
//- include share/index.pug
//- if (theme.QR_code)
//- if (theme.QR_code.length > 0)
//- .post-qr-code
//- each item in theme.QR_code
//- .post-qr-code-item
//- img.lozad.post-qr-code__img(data-src=(item.itemlist||item).img)
//- .post-qr-code__desc=(item.itemlist||item).text

View File

@@ -1,9 +1,20 @@
section#rightside.rightside section#rightside.rightside
#rightside-config-hide
if theme.readmode.enable && is_post() if theme.readmode.enable && is_post()
i#readmode.fa.fa-book(title=_p('rightside.readmode_title')) i#readmode.fa.fa-book(title=_p('rightside.readmode_title'))
i#font_plus.fa.fa-plus(title=_p('rightside.font_plus_title')) i#font_plus.fa.fa-plus(title=_p('rightside.font_plus_title'))
i#font_minus.fa.fa-minus(title=_p('rightside.font_minus_title')) i#font_minus.fa.fa-minus(title=_p('rightside.font_minus_title'))
if theme.translate && theme.translate.enable if theme.translate && theme.translate.enable
a#translateLink.translate_chn_to_cht(href="javascript:translatePage();" title=_p('rightside.translate_title'))= theme.translate.default a#translateLink.translate_chn_to_cht(href="javascript:translatePage();" title=_p('rightside.translate_title'))= theme.translate.default
if theme.nightshift.enable if theme.nightshift && theme.nightshift.enable
i#nightshift.fa.fa-moon-o.nightshift(title=_p('rightside.night_mode_title')) - var display_mode = theme.display_mode == 'night'? 'fa fa-sun-o' : 'fa fa-moon-o'
i#nightshift.nightshift(class=display_mode title=_p('rightside.night_mode_title'))
#rightside-config-show
#rightside_config(title=_p("rightside.setting"))
i.fa.fa-cog(aria-hidden="true")
if is_post() && page.comments !== false
a#to_comment(href="#post-comment" title=_p("rightside.scroll_to_comment"))
i.scroll_to_comment.fa.fa-comments
if is_post() && page.toc != false && theme.toc.enable
i#mobile-toc-button.fa.fa-list-ul.close(title=_p("rightside.toc") aria-hidden="true")
i.fa.fa-arrow-up#go-up(title=_p("rightside.back_to_top") aria-hidden="true")

View File

@@ -17,4 +17,8 @@
span.progress-num 0 span.progress-num 0
span.progress-percentage % span.progress-percentage %
div.sidebar-toc__progress-bar div.sidebar-toc__progress-bar
if (page.encrypt == true)
div.sidebar-toc__content.toc-div-class(style="display:none")!=toc(page.origin, {list_number: tocNumber})
else
div.sidebar-toc__content!=toc(page.content, {list_number: tocNumber}) div.sidebar-toc__content!=toc(page.content, {list_number: tocNumber})

View File

@@ -0,0 +1 @@
script(color=theme.canvas_nest.color opacity=theme.canvas_nest.opacity zIndex=theme.canvas_nest.zIndex count=theme.canvas_nest.count src=url_for(theme.canvas_nest.script))

View File

@@ -0,0 +1,6 @@
.card_widget.card-announcement
.card-content
.item_headline
i.fa.fa-bullhorn.card-announcement-animation(aria-hidden="true")
span= _p('aside.card_announcement')
.announcement_content= theme.announcement.content

View File

@@ -0,0 +1,6 @@
.card_widget.card-archives
.card-content
.item_headline
i.fa.fa-archive(aria-hidden="true")
span= _p('aside.card_archives')
div.archives_item!= list_archives({type:'monthly',format: 'YYYY年MM月'})

View File

@@ -0,0 +1,43 @@
.card_widget.card-author
.card-content
.post_data
.data-item.is_center
img.lozad.avatar_img(src=url_for(theme.avatar) onerror=`onerror=null;src='${theme.lodding_bg.flink}'`)
p.author-info__name.is_center= config.author
p.author-info__description.is_center= config.description
.post_data.data_config
if site.posts.length
.data-item.is_center
.data_link
a(href=url_for(config.archive_dir) + '/')
p.headline= _p('aside.articles')
p.length_num= site.posts.length
if site.tags.length
.data-item.is_center
.data_link
a(href=url_for(config.tag_dir) + '/' )
p.headline= _p('aside.tags')
p.length_num= site.tags.length
if site.categories.length
.data-item.is_center
.data_link
a(href=url_for(config.category_dir) + '/')
p.headline= _p('aside.categories')
p.length_num= site.categories.length
.post_data.is_center
a#bookmark-it.data-item.bookmark.bookmarke--primary.bookmark--animated(href="javascript:;" title= _p('aside.card_bookmark') )
i.fa.fa-bookmark(aria-hidden="true")
span= _p('aside.card_bookmark') || 'Follow Me'
if(theme.social)
.post_data.data_config
#aside-social-icons
each url, icon in theme.social
a.social-icon.data-item(href=url target="_blank")
i(class=icon)

View File

@@ -0,0 +1,23 @@
if site.categories.length
.card_widget.card-categories
.card-content
.item_headline
i.fa.fa-folder-open(aria-hidden="true")
span= _p('aside.card_categories')
ul.aside_category_item
mixin displayCategories(parent = undefined)
- site.categories.find({ parent }).sort("name").each(function(category) {
- var childCount = site.categories.find({ parent: category._id }).count();
li.aside_category_list
a.aside_category_list_link(href=url_for(category.path))
span.aside_category_list_name= category.name
span.aside_category_list_length= category.length
if childCount > 0
ul.aside_category_item.child
+displayCategories(category._id)
- })
+displayCategories()

View File

@@ -0,0 +1,23 @@
.card_widget.card-recent-post
.card-content
.item_headline
i.fa.fa-history(aria-hidden="true")
span= _p('aside.card_recent_post')
.aside_recent_item
- site.posts.sort('date', -1).limit(5).each(function(article){
.aside_recent_post
- var link = article.link || article.path
a(href=url_for(link))
- var post_cover = article.cover
.aside_post_cover
if theme.lazyload.enable
img.aside_post_bg.lozad(data-src=`${post_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'` title=article.title || _p('no_title'))
else
img.aside_post_bg(src=`${post_cover}` onerror=`onerror=null;src='${theme.lodding_bg.post_page}'` title=article.title || _p('no_title'))
div#aside_title
.aside_post_title(href=url_for(link) title=article.title || _p('no_title'))= article.title || _p('no_title')
if (theme.post_meta.date_type)
- var date_type = theme.post_meta.date_type == 'updated' ? 'updated' : 'date'
time.aside_post_meta.post-meta__date #[=date(article[date_type], config.date_format)]
- })

View File

@@ -0,0 +1,7 @@
if site.tags.length
.card_widget.card-tags
.card-content
.item_headline
i.fa.fa-tags(aria-hidden="true")
span= _p('aside.card_tags')
.card-tag-cloud!= tagcloud({min_font: 16, max_font: 24, amount: 200, color: true, start_color: '#999', end_color: '#000'})

View File

@@ -0,0 +1,24 @@
.card_widget.card-webinfo
.card-content
.item_headline
i.fa.fa-line-chart(aria-hidden="true")
span= _p('aside.card_webinfo.headline')
.webinfo
.webinfo_item
.webinfo_article_name= _p('aside.card_webinfo.article_name') + " :"
.webinfo_article_count= site.posts.length
if theme.runtimeshow.enable
.webinfo_item
.webinfo_runtime_name= _p('aside.card_webinfo.runtime_name') + " :"
#webinfo_runtime_count.webinfo_runtime_count
script#runtionshow(src=url_for('js/runtimeshow.js') start_date=theme.runtimeshow.start_date)
if theme.busuanzi.site_uv
.webinfo_item
.webinfo_site_uv_name= _p('aside.card_webinfo.site_uv_name') + " :"
.webinfo_site_uv_count#busuanzi_value_site_uv
if theme.busuanzi.site_pv
.webinfo_item
.webinfo_site_name= _p('aside.card_webinfo.site_pv_name') + " :"
.webinfo_site_pv_count#busuanzi_value_site_pv

View File

@@ -6,7 +6,8 @@ block content
.tag-cloud__title= _p('page.tag') .tag-cloud__title= _p('page.tag')
| - | -
span.tag-cloud__amount= site.tags.length span.tag-cloud__amount= site.tags.length
.tag-cloud-tags!= tagcloud({min_font: 20, max_font: 43, amount: 200, color: true, start_color: '#A4D8FA', end_color: '#0790E8'}) .tag-cloud-tags
include includes/page_tag.pug
if page.comments !== false if page.comments !== false
include includes/comments/index.pug include includes/comments/index.pug
#aside_content.aside_content #aside_content.aside_content

View File

@@ -4,7 +4,6 @@ block top_img
- var top_img = page.top_img || page.cover || theme.post_meta.top_img || theme.post_img || theme.top_img || config.top_img - var top_img = page.top_img || page.cover || theme.post_meta.top_img || theme.post_img || theme.top_img || config.top_img
- var bg_img = top_img !== true ? `background-image: url(${top_img})` : '' - var bg_img = top_img !== true ? `background-image: url(${top_img})` : ''
div#top-container(style=bg_img) div#top-container(style=bg_img)
include ./includes/header.pug
#post-info #post-info
#post-title #post-title
.posttitle=page.title || _p('no_title') .posttitle=page.title || _p('no_title')
@@ -30,14 +29,15 @@ block top_img
a(href=url_for(item.path)).post-meta__categories #[=item.name] a(href=url_for(item.path)).post-meta__categories #[=item.name]
if (index < page.categories.data.length - 1) if (index < page.categories.data.length - 1)
i.fa.fa-angle-right(aria-hidden="true") i.fa.fa-angle-right(aria-hidden="true")
if (theme.wordcount && theme.wordcount.enable)
.post-meta-wordcount .post-meta-wordcount
if (theme.wordcount && theme.wordcount.enable)
span= _p('post.wordcount') + ': ' span= _p('post.wordcount') + ': '
span.word-count= wordcount(page.content) span.word-count= wordcount(page.content)
span.post-meta__separator | span.post-meta__separator |
span= _p('post.min2read', min2read(page.content, {cn: 350, en: 160})) span= _p('post.min2read', min2read(page.content, {cn: 350, en: 160}))
if theme.busuanzi.page_pv if (theme.wordcount && theme.wordcount.enable && theme.busuanzi.page_pv)
span.post-meta__separator | span.post-meta__separator |
if theme.busuanzi.page_pv
span= _p('post.page_pv') + ': ' span= _p('post.page_pv') + ': '
span#busuanzi_value_page_pv span#busuanzi_value_page_pv
@@ -45,7 +45,7 @@ block top_img
block content block content
article#post(class="") article#post(class="")
#post-content.article-container!= page.content #post-content.article-container!= page.content
if (theme.post_copyright && theme.post_copyright.enable) if (theme.post_copyright && theme.post_copyright.enable && page.copyright != false)
.post-copyright .post-copyright
.post-copyright__author .post-copyright__author
span.post-copyright-meta= _p('post.copyright.author') + ": " span.post-copyright-meta= _p('post.copyright.author') + ": "
@@ -71,6 +71,6 @@ block content
include includes/pagination.pug include includes/pagination.pug
if theme.related_post && theme.related_post.enable if theme.related_post && theme.related_post.enable
include includes/related-posts.pug != related_posts(page,site.posts)
if page.comments !== false if page.comments !== false
include includes/comments/index.pug include includes/comments/index.pug

View File

@@ -1,6 +1,14 @@
extends includes/layout.pug extends includes/layout.pug
block content block content
if theme.tag_ui == 'index'
include ./includes/mixins/UI.pug
#recent-posts.recent-posts
+UI_NEW(page.posts)
include includes/pagination.pug
#aside_content.aside_content
include includes/aside.pug
else
include ./includes/mixins/article-sort.pug include ./includes/mixins/article-sort.pug
#tag #tag
.article-sort-title= _p('page.tag') + ' - ' + page.tag .article-sort-title= _p('page.tag') + ' - ' + page.tag

5
package.json Normal file
View File

@@ -0,0 +1,5 @@
{
"name": "hexo-theme-melody",
"version": "1.2.0",
"description": "A Hexo Theme: Butterfly"
}

133
scripts/list_archives.js Normal file
View File

@@ -0,0 +1,133 @@
'use strict';
hexo.extend.helper.register('list_archives', function (options = {}) {
const {
config
} = this;
const archiveDir = config.archive_dir;
const {
timezone
} = config;
const lang = this.page.lang || this.page.language || config.language;
let {
format
} = options;
const type = options.type || 'monthly';
const {
style = 'list', transform, separator = ', '
} = options;
const showCount = Object.prototype.hasOwnProperty.call(options, 'show_count') ? options.show_count : true;
const className = options.class || 'archive';
const order = options.order || -1;
const limit = 8;
let result = '';
var more_button
if (lang === 'zh-CN') {
more_button = '查看更多';
} else if (lang === 'zh-TW') {
more_button = '查看更多';
} else {
more_button = 'More';
}
if (!format) {
format = type === 'monthly' ? 'MMMM YYYY' : 'YYYY';
}
const posts = this.site.posts.sort('date', order);
if (!posts.length) return result;
const data = [];
let length = 0;
posts.forEach(post => {
// Clone the date object to avoid pollution
let date = post.date.clone();
if (timezone) date = date.tz(timezone);
if (lang) date = date.locale(lang);
const year = date.year();
const month = date.month() + 1;
const name = date.format(format);
const lastData = data[length - 1];
if (!lastData || lastData.name !== name) {
length = data.push({
name,
year,
month,
count: 1
});
} else {
lastData.count++;
}
});
const link = item => {
let url = `${archiveDir}/${item.year}/`;
if (type === 'monthly') {
if (item.month < 10) url += '0';
url += `${item.month}/`;
}
return this.url_for(url);
};
if (style === 'list') {
result += `<ul class="${className}-list">`;
for (let i = 0, len = data.length; i < Math.min(len, limit); i++) {
const item = data[i];
result += `<li class="${className}-list-item">`;
result += `<a class="${className}-list-link" href="${link(item)}">`;
result += transform ? transform(item.name) : item.name;
if (showCount) {
result += `<span class="${className}-list-count">${item.count}</span>`;
}
result += '</a>';
result += '</li>';
}
if (data.length > limit) {
result += `<li class="${className}-list-item">`;
result += `<a class="${className}-list-link is_center" href="${archiveDir}" >`;
result += more_button;
result += '</a>';
result += '</li>';
}
result += '</ul>';
} else {
for (let i = 0, len = data.length; i < Math.min(len, limit); i++) {
const item = data[i];
if (i) result += separator;
result += `<a class="${className}-link" href="${link(item)}">`;
result += transform ? transform(item.name) : item.name;
if (showCount) {
result += `<span class="${className}-count">${item.count}</span>`;
}
result += '</a>';
}
if (data.length > limit) {
result += `<a class="${className}-link" is_center" href="${archiveDir}" >`;
result += more_button;
result += '</a>';
}
}
return result;
})

15
scripts/note.js Normal file
View File

@@ -0,0 +1,15 @@
/**
* note.js
* transplant from hexo-theme-next
*/
'use strict';
function postNote(args, content) {
return `<div class="note ${args.join(' ')}">
${hexo.render.renderSync({text: content, engine: 'markdown'}).split('\n').join('')}
</div>`;
}
hexo.extend.tag.register('note', postNote, {ends: true});
hexo.extend.tag.register('subnote', postNote, {ends: true});

20
scripts/post-lazyload.js Normal file
View File

@@ -0,0 +1,20 @@
'use strict';
let cheerio;
hexo.extend.filter.register('after_post_render', data => {
var theme = hexo.theme.config;
if (!theme.lazyload.enable) return;
if (!cheerio) cheerio = require('cheerio');
const $ = cheerio.load(data.content, {decodeEntities: false});
const images = $('img');
if (!images.length) return;
images.each((i, o) => {
let src = $(o).attr('src');
$(o).attr('data-src', src).removeAttr('src');
$(o).addClass('lozad');
});
data.content = $.html();
}, 100);

18
scripts/random_cover.js Normal file
View File

@@ -0,0 +1,18 @@
hexo.extend.filter.register('before_post_render', function(data){
data.cover = data.cover || random_cover()
return data;
});
var random_cover = function () {
var cover;
var num;
if (!Array.isArray(hexo.theme.config.default_cover)) {
cover = hexo.theme.config.default_cover
return cover
} else {
num = Math.floor(Math.random() * (hexo.theme.config.default_cover.length));
cover = hexo.theme.config.default_cover[num];
return cover
}
}

View File

@@ -23,16 +23,39 @@ hexo.extend.helper.register('related_posts', function(currentPost, allPosts){
if (relatedPosts.length == 0) { return '' }; if (relatedPosts.length == 0) { return '' };
var result = ""; var result = "";
var limit_num = hexo.theme.config.related_post.limit || 6 var limit_num = hexo.theme.config.related_post.limit || 6
var lang = hexo.theme.config.rootConfig.language;
var headline_lang;
if (lang === 'zh-CN') {
headline_lang = '相关推荐';
} else if ( lang === 'zh-TW') {
headline_lang = '相關推薦';
} else {
headline_lang = 'Recommend';
}
relatedPosts = relatedPosts.sort(compare('weight')); relatedPosts = relatedPosts.sort(compare('weight'));
var lazy_src = hexo.theme.config.lazyload.enable ? lazy_src = 'data-src' : lazy_src = 'src'
var lazy_class = hexo.theme.config.lazyload.enable ? lazy_class = 'lozad' : lazy_class = ''
if (relatedPosts.length > 0) {
result += '<div class="relatedPosts">'
result += '<div class="relatedPosts_headline"><i class="fa fa-fw fa-thumbs-up" aria-hidden="true"></i><span>' + ' ' + headline_lang + '</span></div>'
result += '<div class="relatedPosts_list">'
for (var i = 0; i < Math.min(relatedPosts.length, limit_num); i++) { for (var i = 0; i < Math.min(relatedPosts.length, limit_num); i++) {
var cover = relatedPosts[i].cover|| hexo.theme.config.default_cover|| data.butterfly.default_cover var cover = relatedPosts[i].cover
result += '<div class="relatedPosts_item"><a href="/' + relatedPosts[i].path + '" title="' + relatedPosts[i].title +'">';
result += '<img class="relatedPosts_cover lozad" data-src="' + cover + '">'; result += '<div class="relatedPosts_item"><a href="' + hexo.theme.config.rootConfig.root + relatedPosts[i].path + '" title="' + relatedPosts[i].title + '">';
result += '<img class="relatedPosts_cover '+ lazy_class + '"' + lazy_src + '="' + cover + '">';
result += '<div class="relatedPosts_title">' + relatedPosts[i].title + '</div>'; result += '<div class="relatedPosts_title">' + relatedPosts[i].title + '</div>';
result += '</a></div>' result += '</a></div>'
}; // console.log(relatedPosts); };
result += '</div><div class="clear_both"></div></div>'
return result; return result;
}
}); });
hexo.extend.helper.register('echo', function(path){ hexo.extend.helper.register('echo', function(path){
return path; return path;
@@ -61,4 +84,3 @@ function compare (attr) {
return val2 - val1; return val2 - val1;
} }
} }

8
scripts/url_check.js Normal file
View File

@@ -0,0 +1,8 @@
hexo.extend.helper.register('url_check', function (p) {
let src = p ;
let reg = /^https?/ig;
return reg.test(src)
})

View File

@@ -13,6 +13,12 @@ body
font-family: $font-family font-family: $font-family
line-height: $text-line-height line-height: $text-line-height
if !hexo-config('copy.enable')
user-select: none
-moz-user-select: none
-webkit-user-select: none
-ms-user-select: none
*::-webkit-scrollbar *::-webkit-scrollbar
width: 8px width: 8px
height: 8px height: 8px
@@ -23,6 +29,19 @@ body
*::-webkit-scrollbar-track *::-webkit-scrollbar-track
background-color: transparent background-color: transparent
#web_bg
background: $web-bg
height: 100%
width: 100%
background-size: cover
position: fixed
z-index: -999
background-attachment: local
background-repeat: no-repeat
background-position: center
h1, h1,
h2, h2,
h3, h3,
@@ -58,20 +77,6 @@ h6
transition: all 0.2s transition: all 0.2s
opacity: 0 opacity: 0
#go-up
position: fixed
right: $go-up-right
bottom: $go-up-bottom
z-index: 100
font-size: $sidebar-icon-size
opacity: 0
cursor: pointer
transition: all .2s
.fancybox-caption
text-align: center
hr hr
position: relative position: relative
margin: 2rem auto margin: 2rem auto
@@ -85,11 +90,11 @@ hr
&:before &:before
position: absolute position: absolute
top: -10px top: $hr-icon-top
left: 5% left: 5%
z-index: 1 z-index: 1
color: $light-blue color: $light-blue
content: "\f0c4" content: $hr-icon
font: normal normal normal 14px / 1 FontAwesome font: normal normal normal 14px / 1 FontAwesome
font-size: 20px font-size: 20px
transition: all 1s ease-in-out transition: all 1s ease-in-out
@@ -129,14 +134,50 @@ table
background: $selection background: $selection
color: $pale-grey color: $pale-grey
.text-center
.full_page #site-title,
.full_page #site-sub-title,
#site-name,
#aside_content .author-info__name,
#aside_content .author-info__description
font-family: $site-name-font
.is_right
text-align: right
.is_left
text-align: left
.is_center
text-align: center text-align: center
.is_visible
display: block !important
.is_invisible
display: none !important
.is_hidden
overflow: hidden
.pull-left .pull-left
float: left float: left
.pull-right .pull-right
float: right float: right
.fireworks
position: fixed
z-index: -1
pointer-events: none
//
img[src=""],img:not([src])
opacity: 0
#body-wrap
transition: all .3s
@media screen and (max-width: $bg) @media screen and (max-width: $bg)
i#toggle-sidebar, i#toggle-sidebar,
#sidebar #sidebar
@@ -144,211 +185,3 @@ table
body body
padding-left: 0 !important padding-left: 0 !important
// valine
#vcomment
input
font-size: 0.65rem
button
font-size: .7rem
padding: .3rem 1rem
background-color: $light-blue
color: #fff
border-color: #fff
textarea
font-size: 0.7rem
background: url(/img/comment_bg.png) 100% 100% no-repeat
.info
display: none
.vcomment
margin-top: 20px
.vimg
border: 0
&:hover
-moz-transform: rotate(540deg)
-o-transform: rotate(540deg)
-webkit-transform: rotate(540deg)
transform: rotate(540deg)
.vcount
font-size: 0.775rem
.vnum
font-size: 1.1rem
.vnick
font-size: 100%
.vsys
font-size: 70%
.vtime
font-size: .65rem
.vcontent
font-size: 100%
.vat
font-size: .7125rem;
color: $cyan;
border: 1px solid $cyan;
padding: 0 .8rem;
border-radius: 5px;
#site-title, #site-sub-title,
#site-name,
#aside_content .author-info__name,
#aside_content .author-info__description
font-family: 'Titillium Web',Lato,PingFang SC, Hiragino Sans GB, "Microsoft JhengHei", "Microsoft YaHei", Helvetica Neue, Helvetica, Arial, sans-serif
#rightside
right: -38px
z-index: 100
position: fixed
bottom: 50px
padding-bottom: 32px
opacity: 0
transition: all .2s
#readmode,#font_plus,#font_minus
width: 30px
height: 30px
background-color: $light-blue
color: #e3e8ee
text-align: center
line-height: 29px
font-size: 16px
display: block
margin-bottom: 2px
cursor: pointer
text-decoration: none
#font_minus,#font_plus
display: none
.translate_chn_to_cht
width: 30px
height: 30px
background-color: $light-blue
color: #e3e8ee
text-align: center
line-height: 29px
font-size: 16px
display: block
margin-bottom: 2px
cursor: pointer
text-decoration: none
.nightshift
width: 30px
height: 30px
background-color: $light-blue
color: #e3e8ee
text-align: center
font-size: 17px
display: block
margin-bottom: 2px
cursor: pointer
padding-top: 6px
a
&:hover
color: white
&:after
color: white
.comment_headling
font-size: 20px
font-weight: 700
margin-bottom: 10px
// bookmark
.fc-container .fancybox-bg {
background: #eee;
}
.fancybox-is-open.fc-container .fancybox-bg {
opacity: 0.95;
}
.fc-content {
margin: 20px;
max-width: 550px;
padding: 50px;
box-shadow: 10px 10px 60px -25px;
border-radius: 4px;
}
.fc-content h3 {
margin-top: 0;
font-size: 1.6em;
letter-spacing: normal;
}
.fc-content p {
color: #666;
line-height: 1.5;
}
.fc-content p:last-child {
margin-bottom: 0;
}
/* Custom animation */
.fancybox-fx-material.fancybox-slide--previous,
.fancybox-fx-material.fancybox-slide--next {
transform: translateY(-60px) scale(1.1);
opacity: 0;
}
.fancybox-fx-material.fancybox-slide--current {
opacity: 1;
transform: translateY(0) scale(1);
}
.bookmark-ok
background: #FF6666;
border-width: 0;
color: #fff;
text-decoration: none;
padding: 7px 20px;
line-height: 1.5;
border-radius: 20px;
text-transform: uppercase;
font-family: 'Montserrat', 'Helvetica Neue', Helvetica, Arial, sans-serif;
font-size: 80%;
font-weight: 700;
margin: 5px 5px 5px 0;
display: inline-block;
cursor: pointer;
outline: none;
transition: all .2s ease-in-out;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
.tright
text-align: right
.is_visible
display: block !important
.fireworks
position: fixed;
z-index: -1;
pointer-events: none;

View File

@@ -2,21 +2,8 @@
@require "theme" @require "theme"
@require "diff" @require "diff"
languages = "js" "javascript" "python" "ruby" "xml" "html" "css" "perl" "sql" "coffeescript" "java" "scala" "kotlin" "c" "c\+\+" "go" "less" "sass" "scss" "stylus" "styl" "typescript" "ts" "bash" "yml" "yaml" "gradle" "groovy" "ejs" "swig" "markdown"
wordWrap = !hexo-config("rootConfig.highlight.line_number") && hexo-config("code_word_wrap") wordWrap = !hexo-config("rootConfig.highlight.line_number") && hexo-config("code_word_wrap")
loopForLanguages()
for lang in languages
.article-container
figure.highlight
&{"." + lang}
table
&:before
content: lang
loopForLanguages()
// Placeholder: $code-block
$code-block $code-block
overflow: auto overflow: auto
margin: 1rem 0 margin: 1rem 0
@@ -102,18 +89,8 @@ blockquote
width: auto width: auto
border: none border: none
&:before if hexo-config('highlight_shrink') == true
position: absolute display: none
z-index: 1
display: inline-block
margin-top: -1.4rem
padding: 0 0.7rem
width: 5rem
color: $highlight-foreground
content: "Code"
font-weight: bold
font-size: 0.8rem
line-height: 1.4rem
&:after &:after
position: absolute position: absolute

View File

@@ -5,18 +5,12 @@
-webkit-box-shadow: 0 4px 8px 6px rgba(7,17,27,.06) -webkit-box-shadow: 0 4px 8px 6px rgba(7,17,27,.06)
box-shadow: 0 4px 8px 6px rgba(7,17,27,.06) box-shadow: 0 4px 8px 6px rgba(7,17,27,.06)
border-radius: 8px border-radius: 8px
-webkit-transition: all .3s
-moz-transition: all .3s
-o-transition: all .3s
-ms-transition: all .3s
transition: all .3s transition: all .3s
background: #fff background: #fff
margin-top: 20px margin-top: 20px
margin-left: 15px
overflow: hidden overflow: hidden
&:hover &:hover
-webkit-box-shadow: 0 4px 12px 12px rgba(7,17,27,0.15)
box-shadow: 0 4px 12px 12px rgba(7,17,27,0.15) box-shadow: 0 4px 12px 12px rgba(7,17,27,0.15)
.card-author .card-author
@@ -29,10 +23,8 @@
transition: all .3s transition: all .3s
&:hover &:hover
-moz-transform: rotate(540deg)
-o-transform: rotate(540deg)
-webkit-transform: rotate(540deg)
transform: rotate(540deg) transform: rotate(540deg)
.author-info .author-info
&__name &__name
font-size: 1.1rem font-size: 1.1rem
@@ -55,10 +47,9 @@
.headline .headline
display: block display: block
font-size: 0.7rem font-size: 0.7rem
letter-spacing: 1px
margin-bottom: -21px margin-bottom: -21px
text-transform: uppercase text-transform: uppercase
color:#4c4948 color:$font-black
#aside-social-icons #aside-social-icons
margin: 0.5rem auto -0.7rem margin: 0.5rem auto -0.7rem
@@ -67,8 +58,7 @@
.social-icon .social-icon
margin: 0 0.5rem margin: 0 0.5rem
color: #4c4948 color: $font-black
/* text-shadow: 0.1rem 0.1rem 0.2rem rgba(0,0,0,0.15) */
font-size: 1rem font-size: 1rem
cursor: pointer cursor: pointer
@@ -76,16 +66,10 @@
transition: all 0.3s transition: all 0.3s
&:hover &:hover
-moz-transform: rotate(540deg)
-o-transform: rotate(540deg)
-webkit-transform: rotate(540deg)
transform: rotate(540deg) transform: rotate(540deg)
#bookmark-it
a#bookmark-it
display: inline-block
margin-top: .2rem margin-top: .2rem
padding: 0 1rem
height: 1.6rem height: 1.6rem
background: $light-blue background: $light-blue
color: #fff color: #fff
@@ -95,6 +79,9 @@
text-transform: uppercase text-transform: uppercase
z-index: 1 z-index: 1
span
padding-left: 10px
.toggle_change--primary,.bookmark--primary .toggle_change--primary,.bookmark--primary
color: $ruby color: $ruby
@@ -102,7 +89,7 @@
transition-property: color transition-property: color
transition-duration: 1s transition-duration: 1s
&:before { &:before
content: "" content: ""
position: absolute position: absolute
top: 0 top: 0
@@ -116,18 +103,13 @@
transition-duration: 0.5s transition-duration: 0.5s
transition-timing-function: ease-out transition-timing-function: ease-out
z-index: -1 z-index: -1
}
&:hover { &:hover
color: white color: white
&:before { &:before
transform: scaleX(1) transform: scaleX(1)
transition-timing-function: cubic-bezier(0.45, 1.64, 0.47, 0.66) transition-timing-function: cubic-bezier(0.45, 1.64, 0.47, 0.66)
}
}
.card-content .card-content
padding: 1rem 1.2rem padding: 1rem 1.2rem
@@ -141,7 +123,6 @@
flex-basis: auto flex-basis: auto
justify-content: center justify-content: center
.item_headline .item_headline
font-size: 0.8rem font-size: 0.8rem
@@ -171,39 +152,41 @@
&::after &::after
width: 100% width: 100%
.aside_recent_item .aside_recent_item
margin: 10px 0 -15px 0 margin: 10px 0 -15px 0
.aside_recent_post .aside_recent_post
a a
text-decoration: none text-decoration: none
color: #4c4948 color: $font-black
.aside_recent_post .aside_recent_post
margin-bottom: 10px margin-bottom: 10px
width: 100% width: 100%
.aside_post_cover .aside_post_cover
height: 70px height: 66px
width: 70px width: 66px
float: left float: left
overflow: hidden
.aside_post_bg .aside_post_bg
object-fit: cover object-fit: cover
width: 100% width: 100%
height: 100% height: 100%
max-width: 100% max-width: 100%
padding: 0
transition: all .6s
&:hover &:hover
box-shadow: none box-shadow: none
transform: scale(1.1)
#aside_title #aside_title
padding-top: 4px
.aside_post_meta .aside_post_meta
font-size: 0.6rem font-size: 0.6rem
padding-left: 5px padding-left: 10px
color: #99a9bf
.aside_post_title .aside_post_title
line-height: 1rem line-height: 1rem
@@ -211,29 +194,43 @@
-webkit-line-clamp: 2 -webkit-line-clamp: 2
-webkit-box-orient: vertical -webkit-box-orient: vertical
overflow: hidden overflow: hidden
height: 41px height: 40px
padding-left: 5px padding-left: 10px
&:hover &:hover
color: $light-blue !important color: $light-blue !important
.aside_category_item,.archive-list .aside_category_item,.archive-list
list-style: none list-style: none
margin-bottom: -3px margin-bottom: -3px
margin-block-start: 0.2rem margin-block-start: 0.2rem
.aside_category_item.child
margin-bottom: -3px
margin-block-start: 0rem
.aside_category_list
margin-left: -50px
.aside_category_list,.archive-list-item .aside_category_list,.archive-list-item
margin-left: -40px margin-left: -40px
padding: 0.2rem 1rem
&:hover &:hover
background-color: $light-blue background-color: $light-blue
color: #363636 color: #363636
a a
text-decoration: none text-decoration: none
color: #4c4948 color: $font-black
padding: 0.2rem 1rem
.aside_category_list_name,.archive-list-link
white-space: nowrap
overflow: hidden
text-overflow: ellipsis
flex: auto
.aside_category_list_link,.archive-list-item
display: flex
.aside_category_list_length,.archive-list-count .aside_category_list_length,.archive-list-count
float: right float: right
@@ -241,9 +238,6 @@
.card-archives .card-archives
margin-bottom: 20px margin-bottom: 20px
.card-announcement-animation
animation: announ_animation 1.5s infinite
.card-webinfo .card-webinfo
.webinfo .webinfo
padding: 0.2rem 1rem padding: 0.2rem 1rem
@@ -265,19 +259,60 @@
float: right float: right
display: inline-block display: inline-block
// bookmark
.fc-container .fancybox-bg
background: #eee
@keyframes announ_animation{ .fancybox-is-open.fc-container .fancybox-bg
opacity: 0.95
0%,to{ .fc-content
color: #4c4948 margin: 20px
max-width: 550px
padding: 50px
box-shadow: 10px 10px 60px -25px
border-radius: 4px
} .fc-content h3
50%{ margin-top: 0
color: #FF0000 font-size: 1.6em
letter-spacing: normal
} .fc-content p
} color: #666
line-height: 1.5
.fc-content p:last-child
margin-bottom: 0
/* Custom animation */
.fancybox-fx-material.fancybox-slide--previous,
.fancybox-fx-material.fancybox-slide--next
transform: translateY(-60px) scale(1.1)
opacity: 0
.fancybox-fx-material.fancybox-slide--current
opacity: 1
transform: translateY(0) scale(1)
.bookmark-ok
background: #FF6666
border-width: 0
color: #fff
text-decoration: none
padding: 7px 20px
line-height: 1.5
border-radius: 20px
text-transform: uppercase
font-family: 'Montserrat', 'Helvetica Neue', Helvetica, Arial, sans-serif
font-size: 80%
font-weight: 700
margin: 5px 5px 5px 0
display: inline-block
cursor: pointer
outline: none
transition: all .2s ease-in-out
user-select: none
@media screen and (max-width: 900px) @media screen and (max-width: 900px)
.layout_page .layout_page
@@ -287,6 +322,14 @@
width: 100% !important width: 100% !important
.card_widget .card_widget
margin-left: 0 !important margin-left: 0
margin-right: 0
@media screen and (min-width: 900px)
#aside_content
.card_widget
if hexo-config("aside.position") == "right"
margin-left: 15px
else
margin-right: 15px

View File

@@ -16,7 +16,6 @@
li li
position: relative position: relative
margin: 0.3rem 0 margin: 0.3rem 0
// padding-left: 0.3rem
padding: 0.1rem 0.5rem 0.1rem 1.5rem !important padding: 0.1rem 0.5rem 0.1rem 1.5rem !important
&:hover &:hover

View File

@@ -1,2 +1,65 @@
#disqus_thread #disqus_thread
margin-top: 1rem margin-top: 1rem
.comment_headling
font-size: 20px
font-weight: 700
margin-bottom: 10px
// valine
#vcomment
font-size: inherit
input
font-size: 0.65rem
button
font-size: .7rem
padding: .3rem 1rem
background-color: $light-blue
color: #fff
border-color: #fff
&:hover
background-color: darken($light-blue, 40)
textarea
font-size: 0.7rem
if hexo-config("valine.bg")
background: url(convert(hexo-config("valine.bg"))) 100% 100% no-repeat
.info
display: none
.vimg
border: 0
&:hover
transform: rotate(540deg)
.vcount
font-size: 0.775rem
.vnum
font-size: 1.1rem
.vsys
font-size: 80%
.vtime
font-size: .65rem
.vcontent
font-size: 100%
.vat
font-size: .7125rem
color: $cyan
border: 1px solid $cyan
padding: 0 .8rem
border-radius: 5px
&:hover
background-color: alpha($cyan,0.5)
code, pre
font-size: 98%

View File

@@ -24,13 +24,10 @@
text-overflow: ellipsis text-overflow: ellipsis
overflow: hidden overflow: hidden
border-radius: 8px border-radius: 8px
-webkit-transform: perspective(1px) translateZ(0)
transform: perspective(1px) translateZ(0) transform: perspective(1px) translateZ(0)
box-shadow: 0 0 1px rgba(0, 0, 0, 0) box-shadow: 0 0 1px rgba(0, 0, 0, 0)
position: relative position: relative
-webkit-transition-property: color
transition-property: color transition-property: color
-webkit-transition-duration: 0.3s
transition-duration: 0.3s transition-duration: 0.3s
img img
@@ -44,9 +41,6 @@
&:hover &:hover
img img
filter: unqoute("progid:DXImageTransform.Microsoft.BasicImage(rotation=3)") filter: unqoute("progid:DXImageTransform.Microsoft.BasicImage(rotation=3)")
-moz-transform: rotate(540deg)
-o-transform: rotate(540deg)
-webkit-transform: rotate(540deg)
transform: rotate(540deg) transform: rotate(540deg)
&:before &:before
@@ -58,13 +52,9 @@
right: 0 right: 0
bottom: 0 bottom: 0
background: $light-blue !important background: $light-blue !important
-webkit-transform: scale(0)
transform: scale(0) transform: scale(0)
-webkit-transition-property: transform
transition-property: transform transition-property: transform
-webkit-transition-duration: 0.3s
transition-duration: 0.3s transition-duration: 0.3s
-webkit-transition-timing-function: ease-out
transition-timing-function: ease-out transition-timing-function: ease-out
.md-links-item:hover, .md-links-item:hover,
@@ -94,7 +84,7 @@
.post-cards .post-cards
margin-top: 5px margin-top: 5px
min-height: 100px min-height: 100px
padding: 15px padding: 0 15px
border-radius: 15px border-radius: 15px
.comment-word .comment-word
@@ -121,8 +111,6 @@
li li
width: calc(100%/2 - 14px) width: calc(100%/2 - 14px)
@media screen and (max-width:600px) @media screen and (max-width:600px)
.flink .flink
.md-links .md-links

View File

@@ -2,16 +2,29 @@ footer
margin-top: 1rem margin-top: 1rem
background: $light-blue background: $light-blue
background-attachment: local background-attachment: local
&.footer-bg
background-position: bottom background-position: bottom
background-size: cover background-size: cover
position: relative
if hexo-config('footer_bg') != false
&:before
position: absolute
bottom: 0
left: 0
display: block
content: ''
width: 100%
height: 100%
opacity: 0.5
background-color: #394245
background-image: linear-gradient(234deg, #394245 0%, #000 100%)
#footer #footer
padding: 1.2rem 1rem 1rem padding: 1.2rem 1rem 1rem
color: $light-grey color: $light-grey
text-align: center text-align: center
position: relative
a a
color: $light-grey color: $light-grey
@@ -24,3 +37,7 @@ footer
.footer-separator .footer-separator
margin: 0 0.2rem margin: 0 0.2rem
.icp-icon
padding: 0 4px
vertical-align: text-bottom

View File

@@ -1,18 +1,20 @@
#nav #nav
position: relative position: relative
margin-bottom: 1rem margin-bottom: 1rem
&.full_page
height: $index_top_img_height
.nav_bg
width: 100%
height: 100%
background-color: $light-blue background-color: $light-blue
background-position: center background-position: center
background-size: cover background-size: cover
&.full_page
background-attachment: local
height: 100vh
&.bg_local
background-attachment: local background-attachment: local
&.not_index_bg
height: 20rem
#site-social-icons #site-social-icons
margin: 0 auto margin: 0 auto
@@ -33,7 +35,7 @@
#site-info #site-info
position: absolute position: absolute
width: 100% width: 100%
top: 43% top: $index_site_info_top
#site-title, #site-title,
#site-sub-title #site-sub-title
@@ -49,6 +51,11 @@
#site-sub-title #site-sub-title
font-size: 0.8rem font-size: 0.8rem
#page_site-info
position: absolute
top: 10rem
width: 100%
.scroll-down .scroll-down
position: absolute position: absolute
bottom: 0 bottom: 0
@@ -58,6 +65,12 @@
font-size: 30px font-size: 30px
text-align: center text-align: center
.scroll-down-effects
position: absolute
color: $white
#header
position: relative
#page-header #page-header
position: absolute position: absolute
@@ -67,47 +80,17 @@
width: 100% width: 100%
border: none border: none
font-size: 18px font-size: 18px
transition: all 0.2s ease-in-out transition: all .3s
.toggle-menu .toggle-menu
display: none display: none
padding-top: 0.6rem padding-top: 0.6rem
color: $light-grey color: $light-grey
cursor: pointer cursor: pointer
transition: all 0.2s ease-in-out
&:hover &:hover
color: $white color: $white
.menu-icon-first,
.menu-icon-second,
.menu-icon-third
width: 18px
height: 3px
background-color: #eee
margin: 2px 0
transition: 0.4s
&.close
/* 线 */
.menu-icon-first
-webkit-transform: rotate(45deg) translate(4px, 3px)
transform: rotate(45deg) translate(4px, 3px)
/* 线 */
.menu-icon-second
opacity: 0
/* 线 */
.menu-icon-third
-webkit-transform: rotate(-45deg) translate(4px, -4px)
transform: rotate(-45deg) translate(4px, -4px)
a a
color: $light-grey color: $light-grey
text-decoration: none text-decoration: none
@@ -115,9 +98,89 @@
&:hover &:hover
color: $white color: $white
&.fixed
position: fixed
top: -60px
z-index: 101
background: alpha($white, 0.8)
box-shadow: 0 5px 6px -5px alpha($grey, 0.6)
transition: transform 0.2s ease-in-out, opacity 0.2s ease-in-out
&.open-sidebar
.site-page
display: none
opacity: 0
a,
#site-name,
.toggle-menu
color: $light-black
text-shadow: none
&:hover
color: $light-blue
&.visible
transform: translate3d(0, 100%, 0)
transition: all .3s
.menus_item_child
background-color: $white !important
&:before
border-color: transparent transparent $white !important
#site-name
text-shadow: 0.1rem 0.1rem 0.2rem rgba(0, 0, 0, 0.15)
font-weight: bold
cursor: pointer
.menus_item
display: inline-block
padding: 0 0 0 0.7rem
&:hover,&:focus
.menus_item_child
display: block
.menus-expand
transform: rotate(180deg) !important
.menus-expand
padding: 4px
transform: rotate(0deg)
transition: all .3s
.menus_item_child
position: absolute
background-color: alpha($white, 0.8)
padding: 8px 10px
border-radius: 5px
box-shadow: 0 5px 20px -4px rgba(0,0,0,.5)
display: none
opacity: 1
animation: sub_menus .3s .1s ease both
&:before
content: ""
position: absolute
top: -20px
left: 50%
margin-left: -10px
border-width: 10px
border-style: solid
border-color: transparent transparent alpha($white, 0.8)
li
list-style: none
text-align: center
a
color: #3b3a3a
text-shadow: none
.site-page .site-page
position: relative position: relative
margin-left: 0.6rem
padding-bottom: 0.3rem padding-bottom: 0.3rem
text-shadow: 0.05rem 0.05rem 0.1rem rgba(0, 0, 0, 0.3) text-shadow: 0.05rem 0.05rem 0.1rem rgba(0, 0, 0, 0.3)
font-size: 0.7rem font-size: 0.7rem
@@ -138,42 +201,6 @@
&::after &::after
width: 100% width: 100%
&.fixed
position: fixed
top: -60px
z-index: 101
background: alpha($white, 0.8)
box-shadow: 0 5px 6px -5px alpha($grey, 0.6)
transition: transform 0.2s ease-in-out, opacity 0.2s ease-in-out
&.open-sidebar
.site-page
display: none
opacity: 0
a,
#site-name
color: $light-black
text-shadow: none
.menu-icon-first,
.menu-icon-second,
.menu-icon-third
background-color: $light-black
text-shadow: none
&a,#site-name
&:hover
color: $light-blue
&.visible
transform: translate3d(0, 100%, 0)
#site-name
text-shadow: 0.1rem 0.1rem 0.2rem rgba(0, 0, 0, 0.15)
font-weight: bold
cursor: pointer
@media screen and (min-width: $sm) @media screen and (min-width: $sm)
#site-title #site-title
@@ -182,50 +209,25 @@
#site-sub-title #site-sub-title
font-size: 1.2rem font-size: 1.2rem
@media screen and (max-width: $sm)
@media screen and (max-width: $sm)
#page-header #page-header
padding: 10px 0.8rem padding: 10px 0.8rem
.menus
display: none
.toggle-menu .toggle-menu
display: block display: block
.menus
position: absolute
top: 3rem
right: 0.8rem
display: none
width: 8rem
background: alpha($white, 0.9)
cursor: pointer
box-shadow: 0 0 4px rgba(0, 0, 0, 0.27)
a
display: block !important
opacity: 1 !important
margin-left: 0
padding-top: 0.3rem
padding-bottom: 0.3rem
padding-left: 0.6rem
color: $font-black
text-shadow: none
font-size: 0.8rem
z-index: 0
&:hover
color: $light-blue
.search .search
right: 0.5rem
span span
display none display none
&.fixed.open-sidebar @media screen and (max-width: $bg)
.search #page-header
display: inline-block; &.fixed
opacity: 1; &.open-sidebar
.site-page
display: inline-block
#page-header .site-page opacity: 1
margin-left: 1rem

View File

@@ -0,0 +1,163 @@
#mobile-sidebar
#menu_mask
position: fixed
top: 0
bottom: 0
width: 100%
height: 110vh
left: 0
right: 0
background: alpha($black,0.7)
z-index: 102
display: none
#mobile-sidebar-menus,#mobile-sidebar-toc
position: fixed
top: 0
right: -254px
width: 250px
height 101vh
background: $white
cursor: pointer
box-shadow: 0 0 4px alpha($dark-black,0.27)
z-index: 103
overflow-y: scroll
display: block
transition: all .3s
display: none
#mobile-sidebar-menus
.mobile_author_icon
padding: 1.3rem 1.5rem 0
text-align: center
img
height: 120px
width: 120px
display: inline-block
vertical-align: top
border-radius: 70px
transition: all .3s
.mobile_post_data
display: flex
justify-content: center
padding: .6rem .5rem 0
.mobile_data_item
flex: 1
.mobile_data_link
a
text-decoration: none
.length_num
font-size: .9rem
color: $dark-black
.headline
display: block
font-size: 0.7rem
text-transform: uppercase
color:$font-black
hr
margin: 1rem auto
.menus_items
padding: 0 .5rem
margin-bottom: 5rem
a
display: block !important
opacity: 1 !important
margin: 0
padding: .3rem 1.5rem
color: $font-black
text-shadow: none
font-size: 0.8rem
z-index: 0
text-overflow: ellipsis
overflow: hidden
white-space: nowrap
i
width: 30%
text-align: left
span
width 70%
&:hover
color: $light-blue
.menus-expand
position: absolute
width: 30px !important
height: 30px
right: 0
padding: 6px
transform: rotate(0deg)
transition: all .3s
&.menus-closed
transform: rotate(180deg) !important
transition: all .3s
.menus_item_child
list-style: none
margin: 0
#mobile-sidebar-toc
padding: 15px 10px
ol,li
list-style: none
padding: 0 0 0 5px
margin: 0
.toc_mobile_headline
text-align: center
font-size: 18px
font-weight: bold
a
text-decoration: none
color: $light-black
&:hover
color: $light-blue
// menustoc
.open-mobile-menus,
.open-mobile-toc
overflow: hidden
#body-wrap
transform: translateX(-250px)
#page-header
transform: translateX(-250px)
&.fixed.visible
transform: translate3d(-250px, 100%, 0)
#rightside
transform: translate3d(-288px, 0, 0) !important
.open-mobile-menus
#mobile-sidebar
#mobile-sidebar-menus
transform: translateX(-254px)
.open-mobile-toc
#mobile-sidebar
#mobile-sidebar-toc
transform: translateX(-254px)
@media screen and (max-width: $sm)
#mobile-sidebar-menus
display: block !important
@media screen and (max-width: $bg)
#mobile-sidebar-toc
display: block !important

View File

@@ -1,7 +1,7 @@
if hexo-config("nightshift") && hexo-config("nightshift.enable") if hexo-config("nightshift") && hexo-config("nightshift.enable")
.night-mode .night-mode
footer color: #99a9bf
background: #2d3035 background-color: #2d3032
#sidebar #sidebar
background: #2d3035 !important background: #2d3035 !important
@@ -10,6 +10,9 @@ if hexo-config("nightshift") && hexo-config("nightshift.enable")
&::-webkit-scrollbar-thumb &::-webkit-scrollbar-thumb
background: lighten(#2d3035,5) background: lighten(#2d3035,5)
#toggle-sidebar
color: #99a9bf !important
if hexo-config("local_search") && hexo-config("local_search.enable") if hexo-config("local_search") && hexo-config("local_search.enable")
#local-search #local-search
background: #2d3035 background: #2d3035
@@ -39,7 +42,7 @@ if hexo-config("nightshift") && hexo-config("nightshift.enable")
// //
#vcomment #vcomment
* p,a,textarea,.vemoji-btn,.vpreview-btn,input,path,.vcount,.vnum,.vtime,.vsys,.vsys,.vnick
color: #99a9bf !important color: #99a9bf !important
.vsys .vsys
@@ -48,9 +51,33 @@ if hexo-config("nightshift") && hexo-config("nightshift.enable")
.vbtn .vbtn
background: rgb(45, 48, 53) !important background: rgb(45, 48, 53) !important
color: #99a9bf !important color: #99a9bf !important
border: 1px solid #99a9bf
.recent-post-item .article-title .vwrap
color: #99a9bf border: 1px solid #99a9bf
input
border-bottom: 1px dashed #616a6b
.vh
border-bottom: 1px dashed #616a6b
pre
background-color: #2d3035
border: 1px solid #99a9bf
.vcontent.expand:before
background: linear-gradient(180deg,hsla(0, 0%, 0%, 0),hsl(218, 8%, 19%))
.vcontent.expand:after
background: hsla(204, 5%, 22%, 1)
.recent-post-item
background: #2d3032 !important
.article-title,
a
color: #99a9bf !important
#page-header #page-header
&.fixed &.fixed
@@ -108,7 +135,6 @@ if hexo-config("nightshift") && hexo-config("nightshift.enable")
background: rgb(27, 38, 59) background: rgb(27, 38, 59)
.post-cards,.md-links-item .post-cards,.md-links-item
// background: #2d3035
a a
color: #99a9bf color: #99a9bf
@@ -127,7 +153,13 @@ if hexo-config("nightshift") && hexo-config("nightshift.enable")
.translate_chn_to_cht, .translate_chn_to_cht,
.nightshift, .nightshift,
#readmode #readmode,
#to_comment,
#font_plus,
#font_minus,
#rightside_config,
#go-up,
#mobile-toc-button
background-color: #2d3035 !important background-color: #2d3035 !important
img img
@@ -163,7 +195,8 @@ if hexo-config("nightshift") && hexo-config("nightshift.enable")
background:#2d3035 background:#2d3035
#nav, #nav,
#top-container #top-container,
footer
&::before &::before
content: "" content: ""
position: absolute position: absolute
@@ -182,15 +215,23 @@ if hexo-config("nightshift") && hexo-config("nightshift.enable")
#site-info .blogtitle, #site-info .blogtitle,
span.subtitle, span.subtitle,
#site-title,
#post-info .posttitle, #post-info .posttitle,
#post-info #post-meta, #post-info #post-meta,
#site-social-icons i, #site-social-icons i,
#top-container a #top-container a,
#footer,
#footer a,
#page-header a,
#page-header .toggle-menu
color: rgba(238,238,238,.6) color: rgba(238,238,238,.6)
#footer
background-color: #2d3032
// //
.post-reward .post-reward
.reward-buttom .reward-button
background-color: #616a6b background-color: #616a6b
.post_share .post_share
filter: brightness(0.6) filter: brightness(0.6)
@@ -200,30 +241,45 @@ if hexo-config("nightshift") && hexo-config("nightshift.enable")
&::-webkit-scrollbar-thumb &::-webkit-scrollbar-thumb
background: lighten(#2d3035,5) background: lighten(#2d3035,5)
@media screen and (max-width: 768px) #web_bg
.night-mode
color: #99a9bf
background-color: rgb(45, 48, 53)
#page-header
.menus
a
color: #99a9bf
background: #2d3035
&.fixed
.menu-icon-first,
.menu-icon-second,
.menu-icon-third
background-color: #99a9bf;
@media screen and (min-width: 768px)
.night-mode
color: #99a9bf
background-color: #2d3032 background-color: #2d3032
.recent-post-item #hbe-security
background: #2d3035 !important label
color: #99a9bf !important
input
background-color: #616a6b
#mobile-sidebar
#mobile-sidebar-menus
background: #2d3035
.headline
color: #99a9bf !important
.length_num
color: darken(#99a9bf,10) !important
a
color: #99a9bf !important
#mobile-sidebar-toc
background: #2d3035
a
color: #99a9bf !important
#page-header
.menus_item_child
background-color: #2d3035 !important
&:before
border-color: transparent transparent #2d3035 !important
li
a
color: #99a9bf

View File

@@ -0,0 +1,256 @@
.note
$note-icons = hexo-config('note.icons')
$note-style = hexo-config('note.style')
margin: 10px 0
padding: 15px
position: relative
if ($note-style == 'simple')
border: 1px solid $light-grey
border-left-width: 5px
if ($note-style == 'modern')
background-color: $whitesmoke
border: 1px solid transparent
if ($note-style == 'flat')
background-color: lighten($light-grey, 65%)
border: initial
border-left: 5px solid $light-grey
if (hexo-config('note.border_radius') is a 'unit')
border-radius: unit(hexo-config('note.border_radius'), px)
h2, h3, h4, h5, h6
if ($note-icons)
margin-top: 3px
else
margin-top: 0
border-bottom: initial
margin-bottom: 0
padding-top: 0 !important
p, ul, ol, table, pre, blockquote, img
&:first-child
margin-top: 0 !important
&:last-child
margin-bottom: 0 !important
if ($note-icons)
&:not(.no-icon)
padding-left: 45px
&::before
font-family: 'FontAwesome'
font-size: larger
left: 15px
position: absolute
top: 13px
&.default
if ($note-style == 'flat')
background-color: $note-default-bg
if ($note-style == 'modern')
background-color: $note-modern-default-bg
border-color: $note-modern-default-border
color: $note-modern-default-text
a, span.exturl
&:not(.btn)
border-bottom: 1px solid $note-modern-default-text
color: $note-modern-default-text
&:hover
border-bottom: 1px solid $note-modern-default-hover
color: $note-modern-default-hover
if ($note-style != 'modern')
border-left-color: $note-default-border
h2, h3, h4, h5, h6
color: $note-default-text
if ($note-icons)
&:not(.no-icon)
&::before
content: $note-default-icon
if ($note-style != 'modern')
color: $note-default-text
&.primary
if ($note-style == 'flat')
background-color: $note-primary-bg
if ($note-style == 'modern')
background-color: $note-modern-primary-bg
border-color: $note-modern-primary-border
color: $note-modern-primary-text
a, span.exturl
&:not(.btn)
border-bottom: 1px solid $note-modern-primary-text
color: $note-modern-primary-text
&:hover
border-bottom: 1px solid $note-modern-primary-hover
color: $note-modern-primary-hover
if ($note-style != 'modern')
border-left-color: $note-primary-border
h2, h3, h4, h5, h6
color: $note-primary-text
if ($note-icons)
&:not(.no-icon)
&::before
content: $note-primary-icon
if ($note-style != 'modern')
color: $note-primary-text
&.info
if ($note-style == 'flat')
background-color: $note-info-bg
if ($note-style == 'modern')
background-color: $note-modern-info-bg
border-color: $note-modern-info-border
color: $note-modern-info-text
a, span.exturl
&:not(.btn)
border-bottom: 1px solid $note-modern-info-text
color: $note-modern-info-text
&:hover
border-bottom: 1px solid $note-modern-info-hover
color: $note-modern-info-hover
if ($note-style != 'modern')
border-left-color: $note-info-border
h2, h3, h4, h5, h6
color: $note-info-text
if ($note-icons)
&:not(.no-icon)
&::before
content: $note-info-icon
if ($note-style != 'modern')
color: $note-info-text
&.success
if ($note-style == 'flat')
background-color: $note-success-bg
if ($note-style == 'modern')
background-color: $note-modern-success-bg
border-color: $note-modern-success-border
color: $note-modern-success-text
a, span.exturl
&:not(.btn)
border-bottom: 1px solid $note-modern-success-text
color: $note-modern-success-text
&:hover
border-bottom: 1px solid $note-modern-success-hover
color: $note-modern-success-hover
if ($note-style != 'modern')
border-left-color: $note-success-border
h2, h3, h4, h5, h6
color: $note-success-text
if ($note-icons)
&:not(.no-icon)
&::before
content: $note-success-icon
if ($note-style != 'modern')
color: $note-success-text
&.warning
if ($note-style == 'flat')
background-color: $note-warning-bg
if ($note-style == 'modern')
background-color: $note-modern-warning-bg
border-color: $note-modern-warning-border
color: $note-modern-warning-text
a, span.exturl
&:not(.btn)
border-bottom: 1px solid $note-modern-warning-text
color: $note-modern-warning-text
&:hover
border-bottom: 1px solid $note-modern-warning-hover
color: $note-modern-warning-hover
if ($note-style != 'modern')
border-left-color: $note-warning-border
h2, h3, h4, h5, h6
color: $note-warning-text
if ($note-icons)
&:not(.no-icon)
&::before
content: $note-warning-icon
if ($note-style != 'modern')
color: $note-warning-text
&.danger
if ($note-style == 'flat')
background-color: $note-danger-bg
if ($note-style == 'modern')
background-color: $note-modern-danger-bg
border-color: $note-modern-danger-border
color: $note-modern-danger-text
a, span.exturl
&:not(.btn)
border-bottom: 1px solid $note-modern-danger-text
color: $note-modern-danger-text
&:hover
border-bottom: 1px solid $note-modern-danger-hover
color: $note-modern-danger-hover
if ($note-style != 'modern')
border-left-color: $note-danger-border
h2, h3, h4, h5, h6
color: $note-danger-text
if ($note-icons)
&:not(.no-icon)
&::before
content: $note-danger-icon
if ($note-style != 'modern')
color: $note-danger-text

View File

@@ -105,24 +105,6 @@ galleryItemStyle(w, h)
time time
color: $grey color: $grey
.more_setting
display: none
.more
display: inline-block
padding: 0 1rem
height: h = 1.6rem
// background: $light-blue
// color: $white
text-align: center
text-decoration: none
line-height: h
cursor: pointer
// transition: all 0.2s ease-in-out
// &:hover
// background: $ruby
.article-title .article-title
margin-bottom: 0.3rem margin-bottom: 0.3rem
color: $black color: $black
@@ -143,20 +125,25 @@ galleryItemStyle(w, h)
color: $light-blue !important color: $light-blue !important
.tag-cloud .tag-cloud
padding: 1.5rem 1rem 2rem padding: 40px 44px 44px
text-align: center
a a
display: inline-block display: inline-block
margin: 0 0.4rem margin: 0 0.4rem
text-decoration: none text-decoration: none
cursor: pointer cursor: pointer
transition: all .3s
&:hover &:hover
color: $ruby !important color: $ruby !important
transform: scale(1.1)
&__title &__title
font-size: 1.8rem font-size: 1.8rem
text-align: center
&-tags
text-align: center
#tag, #tag,
#category, #category,
@@ -204,7 +191,7 @@ galleryItemStyle(w, h)
&-item &-item
position: relative position: relative
margin-bottom: 1rem margin: 0 0 1rem 0.5rem
transition: all 0.2s ease-in-out transition: all 0.2s ease-in-out
&:hover &:hover
@@ -214,8 +201,8 @@ galleryItemStyle(w, h)
&:before &:before
$w = 0.3rem $w = 0.3rem
position: absolute position: absolute
top: 0.48rem top: 1.8rem
left: calc(-1rem - 7px) left: calc(-1rem - 17px)
width: w = $w width: w = $w
height: h = w height: h = w
border: 0.5 * w solid $light-blue border: 0.5 * w solid $light-blue
@@ -237,18 +224,55 @@ galleryItemStyle(w, h)
border-color: $ruby border-color: $ruby
&__time &__time
position: absolute
top: 0.1rem
color: $a-link-color color: $a-link-color
font-size: 0.7rem
padding-left: 0.4rem
&__title &__title
display: block
margin-left: 5rem
color: $font-black color: $font-black
font-size: 0.75rem
height: 60px
overflow: hidden
display: -webkit-box
-webkit-line-clamp: 2
-webkit-box-orient: vertical
transition: all .3s
&:hover
color: $light-blue
transform: translateX(20px)
&__img
img
height: 100%
width: 100%
object-fit: cover
padding: 0
transition: all .6s
&:hover
transform: scale(1.1)
&__post
text-decoration: none text-decoration: none
font-size: 0.8rem
cursor: pointer cursor: pointer
&:hover
color: $a-link-color
&-img
height: 80px
width: 80px
display: inline-block
overflow: hidden
&-post
display: inline-block
top: 0
position: absolute
margin-left: 1rem
.category-lists .category-lists
padding: 1rem 0 1.5rem padding: 1rem 0 1.5rem

View File

@@ -22,10 +22,10 @@
color: $white color: $white
cursor: default cursor: default
img.prev_cover, img.next_cover img.prev_cover,
img.next_cover
position: absolute position: absolute
padding: 0 padding: 0
z-index: 50
top: 0 top: 0
left: 0 left: 0
width: 100% width: 100%

View File

@@ -1,3 +1,18 @@
if hexo-config("post_beautify.enable")
headStyle(fontsize)
padding-left: unit(fontsize + 0.3, "rem")
code
font-size: unit(fontsize, "rem")
&:before
top: calc(50% - unit(fontsize / 2 - 0.05, "rem"))
font-size: unit(fontsize, "rem")
&:hover
padding-left: unit(fontsize + 0.2, "rem")
#post-title #post-title
font-size: 1.4rem font-size: 1.4rem
@@ -100,6 +115,114 @@
#post-content #post-content
margin-bottom: 1rem margin-bottom: 1rem
if hexo-config("post_beautify.enable")
h1,
h2,
h3,
h4,
h5,
h6
cursor: pointer
transition: all 0.2s ease-out
&:before
position: absolute
top: calc(50% - 0.35rem)
left: 0
color: $title-prefix-icon-color
content: $title-prefix-icon
font: normal normal normal 14px / 1 FontAwesome
font-size: 0.8rem
transition: all 0.2s ease-out
&:hover
padding-left: 1.1rem
&:before
color: $light-blue
h1
headStyle(1)
h2
headStyle(0.9)
h3
headStyle(0.8)
h4
headStyle(0.7)
h5
headStyle(0.6)
h6
headStyle(0.6)
ol,
ul
margin-top: 0.4rem
padding: 0 0 0 0.8rem
list-style: none
counter-reset: li
p
margin: 0
ol,
ul
padding-left: 0.5rem
li
position: relative
margin: 0.2rem 0
padding: 0.1rem 0.5rem 0.1rem 1.5rem
&:hover
&:before
transform: rotate(360deg)
&:before
position: absolute
top: 0
left: 0
background: $light-blue
color: $white
cursor: pointer
transition: all 0.3s ease-out
ol
> li
&:before
margin-top: 0.2rem
width: w = 1.2rem
height: h = w
border-radius: 0.5 * w
content: counter(li)
counter-increment: li
text-align: center
font-size: 0.6rem
line-height: h
ul
> li
&:hover
&:before
border-color: $ruby
&:before
$w = 0.3rem
top: 10px
margin-left: 0.45rem
width: w = $w
height: h = w
border: 0.5 * w solid $light-blue
border-radius: w
background: $white
content: ""
line-height: h
else
ol, ol,
ul ul
margin-top: 0.4rem margin-top: 0.4rem
@@ -162,6 +285,31 @@ img
&:hover &:hover
color: darken($highlight-aqua, 20%) color: darken($highlight-aqua, 20%)
.code_lang
position: absolute
font-weight: bold;
font-size: 0.8rem;
line-height: 1.4rem;
color: $highlight-foreground
left: 30px
z-index: 1
cursor: pointer
.code-expand
position: absolute
top: 0
color: $highlight-foreground
padding: 7px 10px
z-index: 1
cursor: pointer
transition: all .3s
transform: rotate(0deg)
.code-closed
transform: rotate(-90deg) !important
transition: all .3s
.copy-notice .copy-notice
position: absolute position: absolute
top: 0 top: 0
@@ -229,8 +377,6 @@ img
.layout .layout
width: $content-large-width width: $content-large-width
.katex-wrap .katex-wrap
overflow: auto overflow: auto
if hexo-config("katex") && hexo-config("katex.hide_scrollbar") if hexo-config("katex") && hexo-config("katex.hide_scrollbar")
@@ -239,48 +385,35 @@ img
// //
#post-content p { #post-content p
font-size: 1.1em font-size: 1.1em
}
#post-content ol, #post-content ul {
#post-content ol,
#post-content ul
font-size: 1em font-size: 1em
}
@media screen and (max-width: 1024px)
@media screen and (max-width: 900px)
.layout .layout
margin: 0 15px margin: 0 15px
width: auto width: auto
.layout_post .layout_post
padding: 50px padding: 50px
-webkit-box-shadow: 0 4px 8px 6px rgba(7,17,27,0.06)
box-shadow: 0 4px 8px 6px rgba(7,17,27,0.06) box-shadow: 0 4px 8px 6px rgba(7,17,27,0.06)
border-radius: 8px border-radius: 8px
-webkit-transition: all 0.3s
-moz-transition: all 0.3s
-o-transition: all 0.3s
-ms-transition: all 0.3s
transition: all 0.3s transition: all 0.3s
background: #fff background: #fff
margin-top: 40px margin-top: 40px
margin-bottom: 40px margin-bottom: 40px
&:hover &:hover
-webkit-box-shadow: 0 4px 12px 12px rgba(7,17,27,0.15)
box-shadow: 0 4px 12px 12px rgba(7,17,27,0.15) box-shadow: 0 4px 12px 12px rgba(7,17,27,0.15)
img img
margin:0 auto
display:block display:block
.tag_share .tag_share
display: block display: block
@@ -310,3 +443,34 @@ img
a a
text-decoration: none text-decoration: none
color: $light-blue color: $light-blue
h1
margin: 0.8rem 0
h2,
h3,
h4,
h5,
h6
margin: 1rem 0 0.5rem 0
img
margin: 0 auto 0.8rem
blockquote,
p
margin: 0 0 0.8rem 0
table,.note
margin: 0.8rem 0
figure
margin: 0.8rem 0
table
margin: 0
blockquote
p
margin: 0.5rem 0

View File

@@ -7,27 +7,34 @@ if hexo-config("readmode") && hexo-config("readmode.enable")
#toggle-sidebar #toggle-sidebar
display: none display: none
#page-header
#site-name,
.site-page,
.toggle-menu
text-shadow: none
color: $font-black
.menus_item_child
background-color: darken($pale-yellow,5) !important
&:before
border-color: transparent transparent darken($pale-yellow,5) !important
#top-container #top-container
background-image: none !important background-image: none !important
height: 14rem height: 14rem
background-color: $pale-yellow background-color: $pale-yellow
a a
color: #4c4948 color: $font-black
&:before &:before
opacity: 0 opacity: 0
#site-name,
.site-page
text-shadow: none
color: #4c4948
#post-info #post-info
text-align: center text-align: center
padding: 0 padding: 0
color: #4c4948 color: $font-black
#post-title, #post-title,
#post-meta #post-meta
@@ -35,7 +42,7 @@ if hexo-config("readmode") && hexo-config("readmode.enable")
#page-header #page-header
&.fixed &.fixed
background: none background: alpha(darken($pale-yellow,5),0.5)
box-shadow: none box-shadow: none
&.open-sidebar &.open-sidebar
@@ -43,11 +50,6 @@ if hexo-config("readmode") && hexo-config("readmode.enable")
display: inline-block display: inline-block
opacity: 1 opacity: 1
.toggle-menu
.menu-icon-first,
.menu-icon-second,
.menu-icon-third
background-color: #4c4948
.layout_post .layout_post
box-shadow: none box-shadow: none
@@ -113,5 +115,3 @@ if hexo-config("readmode") && hexo-config("readmode.enable")

View File

@@ -21,10 +21,6 @@
.relatedPosts_cover .relatedPosts_cover
border: 0 border: 0
-webkit-transition: all 0.6s
-moz-transition: all 0.6s
-o-transition: all 0.6s
-ms-transition: all 0.6s
transition: all 0.6s transition: all 0.6s
display: block display: block
width: 100% width: 100%
@@ -60,7 +56,6 @@
clear: both clear: both
@media screen and (max-width:768px) @media screen and (max-width:768px)
.relatedPosts_item .relatedPosts_item
width: calc(100%/2 - 4px) width: calc(100%/2 - 4px)

View File

@@ -5,7 +5,7 @@
text-align: center text-align: center
display: block display: block
.reward-buttom .reward-button
text-align: center text-align: center
display: inline-block display: inline-block
cursor: pointer cursor: pointer
@@ -30,6 +30,7 @@
left: 0 left: 0
transition: all 0.6s transition: all 0.6s
display: none display: none
opacity: 1
.reward-all .reward-all
margin: 0 auto margin: 0 auto

View File

@@ -0,0 +1,64 @@
#rightside
right: -38px
position: fixed
bottom: 40px
transition: all .3s
opacity 0
#rightside-config-hide
transition: all .3s
display none
#readmode,
#font_plus,
#font_minus,
#to_comment,
.nightshift,
#mobile-toc-button,
#go-up,
#rightside_config
width: 30px
height: 30px
background-color: $light-blue
color: $white
text-align: center
line-height: 29px
font-size: 16px
display: block
margin-bottom: 2px
cursor: pointer
text-decoration: none
&:hover
background-color: $ruby
#rightside_config
i
animation: avatar_turn_around 2s linear infinite
.translate_chn_to_cht
width: 30px
height: 30px
background-color: $light-blue
color: $white
text-align: center
line-height: 29px
font-size: 16px
display: block
margin-bottom: 2px
cursor: pointer
text-decoration: none
&:hover
background-color: $ruby
#mobile-toc-button
display: none
@media screen and (max-width: $bg)
#rightside
#mobile-toc-button
display: block

View File

@@ -10,7 +10,6 @@
background: $sidebar-background background: $sidebar-background
box-shadow: -0.25rem 0 0.25rem rgba(232, 237, 250, 0.6) inset box-shadow: -0.25rem 0 0.25rem rgba(232, 237, 250, 0.6) inset
opacity: 0.9 opacity: 0.9
transition: all 0.2s
.sidebar-toc .sidebar-toc
ol, ol,

View File

@@ -1,12 +1,10 @@
#recent-posts #recent-posts
width: 75%
.recent-post-item .recent-post-item
padding: 0 padding: 0
box-shadow: 0 4px 8px 6px rgba(7,17,27,0.06) box-shadow: 0 4px 8px 6px rgba(7,17,27,0.06)
border-radius: 8px border-radius: 8px
-webkit-transition: all 0.3s
-moz-transition: all 0.3s
-o-transition: all 0.3s
-ms-transition: all 0.3s
transition: all 0.3s transition: all 0.3s
background: #fff background: #fff
margin-top: 20px margin-top: 20px
@@ -34,9 +32,6 @@
height: 280px height: 280px
overflow: hidden overflow: hidden
img.post_bg img.post_bg
border: 0 border: 0
transition: all .6s transition: all .6s
@@ -47,14 +42,12 @@
margin: 0 margin: 0
object-fit: cover object-fit: cover
&:hover &:hover
transform:scale(1.1) transform:scale(1.1)
#pagination #pagination
margin-top: 2rem margin-top: 2rem
.recent-post-info .recent-post-info
padding: 50px 40px padding: 50px 40px
display: inline-block display: inline-block
@@ -76,53 +69,6 @@ a.article-meta__categories
overflow: hidden overflow: hidden
height: 90px height: 90px
.more {
position: relative
letter-spacing: 1.2px
text-transform: uppercase
overflow: hidden
z-index: 1
background-color: $light-blue
&:focus {
outline: none
}
}
.more--primary {
color: $white
}
.more--animated {
transition-property: color
transition-duration: 0.5s
&:before {
content: ""
position: absolute
top: 0
left: 0
right: 0
bottom: 0
background: $ruby
transform: scaleX(0)
transform-origin: 0 50%
transition-property: transform
transition-duration: 0.5s
transition-timing-function: ease-out
z-index: -1
}
&:hover {
color: white
&:before {
transform: scaleX(1)
transition-timing-function: cubic-bezier(0.45, 1.64, 0.47, 0.66)
}
}
}
.layout_page .layout_page
display: flex display: flex
margin: 0 auto margin: 0 auto
@@ -130,8 +76,6 @@ a.article-meta__categories
align-items: flex-start align-items: flex-start
padding: 0 15px padding: 0 15px
#recent-posts
width: 75%
#page,.category-content,.flink #page,.category-content,.flink
padding: 40px 44px 44px padding: 40px 44px 44px
@@ -147,23 +91,24 @@ a.article-meta__categories
.card_widget,#archive,.tag-cloud,#tag,.category-content,#category,#page,.flink .card_widget,#archive,.tag-cloud,#tag,.category-content,#category,#page,.flink
&:hover &:hover
-webkit-box-shadow: 0 4px 12px 12px rgba(7,17,27,0.15)
box-shadow: 0 4px 12px 12px rgba(7,17,27,0.15) box-shadow: 0 4px 12px 12px rgba(7,17,27,0.15)
#page_site-info
padding: 10rem 1rem 7rem
#site-title @media screen and (min-width: 900px)
font-family: PingFang SC, Hiragino Sans GB, "Microsoft JhengHei", "Microsoft YaHei", Helvetica Neue, Helvetica, Arial, sans-serif if hexo-config("aside.position") == "left"
#recent-posts,#page,.category-content,#archive,.tag-cloud,.flink,#tag,#category
order: 2
@media screen and (max-width: 900px) @media screen and (max-width: 900px)
#page,.category-content,#archive,.tag-cloud,.flink,#tag,#category #page,.category-content,#archive,.tag-cloud,.flink,#tag,#category
width: 100% !important width: 100% !important
// .recent-post-info
// padding: 40px 30px 20px
@media screen and (max-width:768px) @media screen and (max-width:768px)
#web_bg
display: none
.recent-post-item .recent-post-item
height: auto !important height: auto !important
border-radius: 8px border-radius: 8px
@@ -203,41 +148,32 @@ a.article-meta__categories
-webkit-box-shadow: none -webkit-box-shadow: none
box-shadow: none box-shadow: none
.layout_page .layout_page
padding: 0 !important padding: 0 !important
#aside_content #aside_content
display: none !important display: none !important
// .card_widget
// box-shadow: none
// border-radius: 0
// border-top: 1px dashed #a4d8fa
// &:hover
// box-shadow: none
.category-lists .category-lists
padding: 0 padding: 0
#recent-posts
.recent-post-info .recent-post-info
padding: 20px 10px !important padding: 20px 10px !important
width: 100% width: 100%
#recent-posts #pagination #pagination
margin-bottom: 0 margin-bottom: 0
.more_setting #nav
display: block !important #site-social-icons
#nav #site-social-icons
display: block display: block
&.not_index_bg
height: 14rem
#page_site-info #page_site-info
padding: 7rem 1rem 5rem top: 7rem
#top-container #top-container
height: 14rem height: 14rem
@@ -254,99 +190,113 @@ a.article-meta__categories
display: none !important display: none !important
.layout_page, .layout_page,
.layout_post, .layout_post,
footer footer
animation: main 1s; animation: main 1s
#nav, #nav,
#top-container #top-container,
#page-header
animation: header 1s animation: header 1s
#site-title #site-title
animation: titlescale 1s animation: titlescale 1s
.search-dialog canvas,
transition: all .2s #web_bg
animation: to_show 4s
.card-announcement-animation
animation: announ_animation .8s linear infinite
color: #FF0000
.scroll-down-effects .scroll-down-effects
-webkit-animation: pulse 1.5s infinite animation: scroll-down-effect 1.5s infinite
animation: pulse 1.5s infinite
// font-size: 28px
position: absolute
color: #fff
@keyframes pulse{ if hexo-config("avatar_effect") == true
.avatar_img
animation: avatar_turn_around 2s linear infinite
0%,to{ .reward-main
// -ms-filter:"alpha(opacity=40)" animation: donate_effcet .3s .1s ease both
// filter:alpha(opacity=40)
opacity:.4 .rightside-in
top:0} animation: rightside_in_animate .3s
50%{ display: block !important
// -ms-filter:none
// -webkit-filter:none @keyframes scroll-down-effect
// filter:none 0%
opacity: 0.4
top: 0
50%
opacity: 1 opacity: 1
top:-16px} top: -16px
} 100%
opacity: 0.4
top: 0
@keyframes header { @keyframes header
0% { 0%
opacity: 0; opacity: 0
transform: translateY(-50px) transform: translateY(-50px)
} 100%
100% { opacity: 1
opacity: 1;
transform: translateY(0) transform: translateY(0)
}
} @keyframes main
0%
opacity: 0
@keyframes main {
0% {
opacity: 0;
transform: translateY(50px) transform: translateY(50px)
} 100%
100% { opacity: 1
opacity: 1;
transform: translateY(0) transform: translateY(0)
}
}
@keyframes titlescale{ @keyframes titlescale
0%
0% { opacity: 0
// opacity:0;
transform: scale(0.7) transform: scale(0.7)
} 100%
100% { opacity: 1
// opacity:1;
transform: scale(1) transform: scale(1)
}
} @keyframes to_show
0%
opacity: 0
100%
opacity: 1
@keyframes avatar_turn_around
from
transform: rotate(0deg)
to
transform: rotate(360deg)
.article-container .code_full_page @keyframes sub_menus
position: fixed; 0%
top: 0; opacity: 0
left: 0; transform: translateY(10px)
width: 100%; 100%
height: 100%; opacity: 1
min-width: 100%; transform: translateY(0)
z-index: 9999;
margin: 0;
animation: code_full_page 1s;
.code_body @keyframes donate_effcet
overflow: hidden 0%
opacity: 0
transform: translateY(-20px)
100%
opacity: 1
transform: translateY(0)
@keyframes code_full_page{ @keyframes announ_animation
0%{transform:scale(0)} 0%,to
50%{transform:scale(1)} transform: scale(1)
80%{transform:scale(.98)} 50%
100%{transform:scale(1)}} transform: scale(1.2)
@keyframes rightside_in_animate
0%
transform: translateX(28px)
100%
transform: translateX(0)

View File

@@ -7,9 +7,15 @@ $theme-meta-color = #858585
$theme-link-color = #99a9bf $theme-link-color = #99a9bf
$theme-hr-color = #A4D8FA $theme-hr-color = #A4D8FA
$theme-read-mode-bg-color = #FAF9DE $theme-read-mode-bg-color = #FAF9DE
$inline-code-color = #F47466
$font-family= Lato, Helvetica Neue For Number, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, PingFang SC, Hiragino Sans GB, "Microsoft YaHei", Helvetica Neue, Helvetica, Arial, sans-serif $font-family= Lato, Helvetica Neue For Number, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, PingFang SC, Hiragino Sans GB, "Microsoft YaHei", Helvetica Neue, Helvetica, Arial, sans-serif
$code-font = consolas, Menlo, "PingFang SC", "Microsoft YaHei", monospace, Helvetica Neue For Number $code-font = consolas, Menlo, "PingFang SC", "Microsoft YaHei", monospace, Helvetica Neue For Number
$site-name-font = "Titillium Web", Lato,PingFang SC, Hiragino Sans GB, "Microsoft JhengHei", "Microsoft YaHei", Helvetica Neue, Helvetica, Arial, sans-serif
//hr icon
$hr-icon = '\f0c4'
$hr-icon-top = -10px
$title-prefix-icon = '\f0c1'
$title-prefix-icon-color = #F47466
if hexo-config("theme_color") && hexo-config("theme_color.enable") if hexo-config("theme_color") && hexo-config("theme_color.enable")
$theme-color = convert(hexo-config("theme_color.main")) || #49B1F5 $theme-color = convert(hexo-config("theme_color.main")) || #49B1F5
@@ -20,17 +26,32 @@ if hexo-config("theme_color") && hexo-config("theme_color.enable")
$theme-meta-color = convert(hexo-config("theme_color.meta_color")) || #858585 $theme-meta-color = convert(hexo-config("theme_color.meta_color")) || #858585
$theme-hr-color = convert(hexo-config("theme_color.hr_color")) || #A4D8FA $theme-hr-color = convert(hexo-config("theme_color.hr_color")) || #A4D8FA
$theme-read-mode-bg-color = convert(hexo-config("theme_color.read-mode-bg_color")) || #FAF9DE $theme-read-mode-bg-color = convert(hexo-config("theme_color.read-mode-bg_color")) || #FAF9DE
$inline-code-color = convert(hexo-config("theme_color.inline-code-color")) || #F47466
if hexo-config("font") && hexo-config("font.enable") if hexo-config("font") && hexo-config("font.enable")
$font-family = convert(hexo-config("font.font-family")) || 'Lato, Helvetica Neue For Number, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, PingFang SC, Hiragino Sans GB, "Microsoft YaHei", Helvetica Neue, Helvetica, Arial, sans-serif' $font-family = convert(hexo-config("font.font-family")) || 'Lato, Helvetica Neue For Number, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, PingFang SC, Hiragino Sans GB, "Microsoft YaHei", Helvetica Neue, Helvetica, Arial, sans-serif'
$code-font = convert(hexo-config("font.code-font")) || 'consolas, Menlo, "PingFang SC", "Microsoft YaHei", monospace, Helvetica Neue For Number' $code-font = convert(hexo-config("font.code-font")) || 'consolas, Menlo, "PingFang SC", "Microsoft YaHei", monospace, Helvetica Neue For Number'
if hexo-config("blog_title_font.font-family")
$site-name-font = convert(hexo-config("blog_title_font.font-family")) || '"Titillium Web",Lato,PingFang SC, Hiragino Sans GB, "Microsoft JhengHei", "Microsoft YaHei", Helvetica Neue, Helvetica, Arial, sans-serif'
if hexo-config("hr") && hexo-config("hr.enable")
$hr-icon = hexo-config("hr.icon") || '\f0c4'
$hr-icon-top = convert(hexo-config("hr.icon-top")) || -10px
if hexo-config("post_beautify.enable")
$title-prefix-icon = hexo-config("post_beautify.title-prefix-icon") || '\f0c1'
$title-prefix-icon-color= convert(hexo-config("post_beautify.title-prefix-icon-color")) || #F47466
// Global Variables // Global Variables
$font-size = 14px $font-size = 14px
$font-color = #1F2D3D $font-color = #1F2D3D
$rem = 20px $rem = 20px
$font-family = $font-family $font-family = $font-family
$code-font = $code-font $code-font = $code-font
$site-name-font = $site-name-font
$text-line-height = 2 $text-line-height = 2
$sm = 768px $sm = 768px
$bg = 1024px $bg = 1024px
@@ -39,8 +60,9 @@ $lg = 1450px
$sidebar-icon-top = 20px $sidebar-icon-top = 20px
$sidebar-icon-left = $sidebar-icon-top - 4px $sidebar-icon-left = $sidebar-icon-top - 4px
$sidebar-icon-size = 16px $sidebar-icon-size = 16px
$go-up-bottom = $sidebar-icon-top $web-bg = convert(hexo-config("background"))
$go-up-right = -($sidebar-icon-left) $index_top_img_height = convert(hexo-config('index_top_img_height')) || 100vh
$index_site_info_top = convert(hexo-config("index_site_info_top")) || 43%
// Global color & SVG // Global color & SVG
$pale-blue = $theme-hr-color $pale-blue = $theme-hr-color
$light-blue = $theme-color $light-blue = $theme-color
@@ -67,6 +89,7 @@ $light-grey = #EEEEEE
$grey = $theme-meta-color $grey = $theme-meta-color
$pale-yellow = $theme-read-mode-bg-color $pale-yellow = $theme-read-mode-bg-color
$white = #FFFFFF $white = #FFFFFF
$whitesmoke = #f5f5f5;
$dark-white = #F9F9F9 $dark-white = #F9F9F9
$font-black = #4C4948 $font-black = #4C4948
$selection = $theme-text-selection-color $selection = $theme-text-selection-color
@@ -74,7 +97,7 @@ $selection = $theme-text-selection-color
// code // code
$code-font-size = $font-size $code-font-size = $font-size
$code-font-family = $font-family $code-font-family = $font-family
$code-foreground = $font-color $code-foreground = $inline-code-color
$code-background = rgba(27, 31, 35, 0.05) $code-background = rgba(27, 31, 35, 0.05)
$line-height-code-block = 20px $line-height-code-block = 20px
$blockquote-color = #6a737d $blockquote-color = #6a737d
@@ -90,3 +113,74 @@ $img-border-padding = 4px
// sidebar // sidebar
$sidebar-width = 300px $sidebar-width = 300px
$sidebar-background = #f6f8fa $sidebar-background = #f6f8fa
// Note colors
// --------------------------------------------------
hexo-config('note.light_bg_offset') is a 'unit' ? ($lbg = unit(hexo-config('note.light_bg_offset'),"%")) : ($lbg = 0);
// Default
$note-default-border = #777;
$note-default-bg = lighten(spin($note-default-border, 0), 94% + $lbg);
$note-default-text = $note-default-border;
$note-default-icon = "\f0a9";
$note-modern-default-border = #e1e1e1;
$note-modern-default-bg = lighten(spin($note-modern-default-border, 10), 60% + ($lbg * 4));
$note-modern-default-text = #666;
$note-modern-default-hover = darken(spin($note-modern-default-text, -10), 32%);
// Primary
$note-primary-border = #6f42c1;
$note-primary-bg = lighten(spin($note-primary-border, 10), 92% + $lbg);
$note-primary-text = $note-primary-border;
$note-primary-icon = "\f055";
$note-modern-primary-border = #e1c2ff;
$note-modern-primary-bg = lighten(spin($note-modern-primary-border, 10), 40% + ($lbg * 4));
$note-modern-primary-text = #6f42c1;
$note-modern-primary-hover = darken(spin($note-modern-primary-text, -10), 22%);
// Info
$note-info-border = #428bca;
$note-info-bg = lighten(spin($note-info-border, -10), 91% + $lbg);
$note-info-text = $note-info-border;
$note-info-icon = "\f05a";
$note-modern-info-border = #b3e5ef;
$note-modern-info-bg = lighten(spin($note-modern-info-border, 10), 50% + ($lbg * 4));
$note-modern-info-text = #31708f;
$note-modern-info-hover = darken(spin($note-modern-info-text, -10), 32%);
// Success
$note-success-border = #5cb85c;
$note-success-bg = lighten(spin($note-success-border, 10), 90% + $lbg);
$note-success-text = $note-success-border;
$note-success-icon = "\f058";
$note-modern-success-border = #d0e6be;
$note-modern-success-bg = lighten(spin($note-modern-success-border, 10), 40% + ($lbg * 4));
$note-modern-success-text = #3c763d;
$note-modern-success-hover = darken(spin($note-modern-success-text, -10), 27%);
// Warning
$note-warning-border = #f0ad4e;
$note-warning-bg = lighten(spin($note-warning-border, 10), 88% + $lbg);
$note-warning-text = $note-warning-border;
$note-warning-icon = "\f06a";
$note-modern-warning-border = #fae4cd;
$note-modern-warning-bg = lighten(spin($note-modern-warning-border, 10), 43% + ($lbg * 4));
$note-modern-warning-text = #8a6d3b;
$note-modern-warning-hover = darken(spin($note-modern-warning-text, -10), 18%);
// Danger
$note-danger-border = #d9534f;
$note-danger-bg = lighten(spin($note-danger-border, -10), 92% + $lbg);
$note-danger-text = $note-danger-border;
$note-danger-icon = "\f056";
$note-modern-danger-border = #ebcdd2;
$note-modern-danger-bg = lighten(spin($note-modern-danger-border, 10), 35% + ($lbg * 4));
$note-modern-danger-text = #a94442;
$note-modern-danger-hover = darken(spin($note-modern-danger-text, -10), 22%);

BIN
source/img/icp.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 19 KiB

View File

@@ -1,4 +1,8 @@
$(function () { $(function () {
/**
* 進入post頁sidebar自動打開
*/
if ($('#sidebar').hasClass('auto_open')) { if ($('#sidebar').hasClass('auto_open')) {
if ($(".sidebar-toc__content").children().length > 0) { if ($(".sidebar-toc__content").children().length > 0) {
$(".layout_post").animate({}, function () { $(".layout_post").animate({}, function () {
@@ -9,11 +13,11 @@ $(function () {
$('body').animate({ $('body').animate({
paddingLeft: 300 paddingLeft: 300
}, 200) }, 200)
$('#sidebar').animate({}, function () {
$('#sidebar').css({ $('#sidebar').animate({
'transform': 'translateX(300px)' left: 0
}, 200) }, 200)
})
$('#toggle-sidebar').animate({}, function () { $('#toggle-sidebar').animate({}, function () {
$('#toggle-sidebar').css({ $('#toggle-sidebar').css({
'transform': 'rotateZ(180deg)', 'transform': 'rotateZ(180deg)',
@@ -32,8 +36,9 @@ $(function () {
} }
//------------------------------------------------------------------------------------------------------- /**
//sidebar * 點擊左下角箭頭,顯示sidebar
*/
$('#toggle-sidebar').on('click', function () { $('#toggle-sidebar').on('click', function () {
if (!isMobile() && $('#sidebar').is(':visible')) { if (!isMobile() && $('#sidebar').is(':visible')) {
@@ -45,11 +50,9 @@ $(function () {
paddingLeft: 0 paddingLeft: 0
}, 200) }, 200)
$('#sidebar').animate({}, function () { $('#sidebar').animate({
$('#sidebar').css({ left: -300
'transform': 'translateX(0px)' }, 200)
})
})
$('#toggle-sidebar').animate({}, function () { $('#toggle-sidebar').animate({}, function () {
$('#toggle-sidebar').css({ $('#toggle-sidebar').css({
@@ -63,11 +66,11 @@ $(function () {
$('body').animate({ $('body').animate({
paddingLeft: 300 paddingLeft: 300
}, 200) }, 200)
$('#sidebar').animate({}, function () {
$('#sidebar').css({ $('#sidebar').animate({
'transform': 'translateX(300px)' left: 0
}) }, 200)
})
$('#toggle-sidebar').animate({}, function () { $('#toggle-sidebar').animate({}, function () {
$('#toggle-sidebar').css({ $('#toggle-sidebar').css({
'transform': 'rotateZ(180deg)', 'transform': 'rotateZ(180deg)',
@@ -78,55 +81,25 @@ $(function () {
} }
}) })
//----------------------------------------------------------------------------------------------------- /**
//fullpage添加 *fullpage添加
// 添加class * 添加class
*/
if (/Android|webOS|iPhone|iPod|iPad|BlackBerry/i.test(navigator.userAgent)) {} else { if (/Android|webOS|iPhone|iPod|iPad|BlackBerry/i.test(navigator.userAgent)) {} else {
$('.full_page').css('background-attachment', 'fixed') $('.full_page .nav_bg').css('background-attachment', 'fixed');
} }
//--------------------------------------------------------------------------------------------------------- /**
* 首頁top_img底下的箭頭
*/
$(".scroll-down").on("click", function () { $(".scroll-down").on("click", function () {
scrollTo('#content-outer') scrollTo('#content-outer')
}); });
//-------------------------------------------------------------------------------------------------------- /**
// tags 隨機大小 顔色 * BOOKMARK 書簽
var list = document.querySelectorAll(".tag-cloud .tag-cloud-tags a"); */
if ($(window).width() > 768) {
Array.prototype.forEach.call(list, (item, index) => {
item.style.fontSize = Math.floor(Math.random() * 20 + 15) + "px"; //15 ~ 35
item.style.color =
"rgb(" +
Math.floor(Math.random() * 201) +
", " +
Math.floor(Math.random() * 201) +
", " +
Math.floor(Math.random() * 201) +
")"; // 0,0,0 -> 200,200,200
});
} else {
Array.prototype.forEach.call(list, (item, index) => {
item.style.fontSize = Math.floor(Math.random() * 13 + 15) + "px"; //15 ~ 28
item.style.color =
"rgb(" +
Math.floor(Math.random() * 201) +
", " +
Math.floor(Math.random() * 201) +
", " +
Math.floor(Math.random() * 201) +
")"; // 0,0,0 -> 200,200,200
});
}
//--------------------------------------------------------------------------------------------------------
// bookmark
$.fancyConfirm = function (opts) { $.fancyConfirm = function (opts) {
opts = $.extend(true, { opts = $.extend(true, {
title: 'Are you sure?', title: 'Are you sure?',
@@ -141,7 +114,7 @@ $(function () {
src: '<div class="fc-content">' + src: '<div class="fc-content">' +
'<h3>' + opts.title + '</h3>' + '<h3>' + opts.title + '</h3>' +
'<p>' + opts.message + '</p>' + '<p>' + opts.message + '</p>' +
'<p class="tright">' + '<p class="is_right">' +
'<button data-value="1" data-fancybox-close class="bookmark-ok">' + opts.okButton + '</button>' + '<button data-value="1" data-fancybox-close class="bookmark-ok">' + opts.okButton + '</button>' +
'</p>' + '</p>' +
'</div>', '</div>',
@@ -179,13 +152,14 @@ $(function () {
} }
}); });
//------------------------------------------------------------------------------------------------------- /**
//代码copy * 代碼copy
// Add copy icon * Add copy icon
*/
$('figure.highlight').wrap('<div class="code-area-wrap"></div>')
var highlight_copy = GLOBAL_CONFIG.highlight_copy var highlight_copy = GLOBAL_CONFIG.highlight_copy
if (highlight_copy == 'true') { if (highlight_copy == 'true') {
$('figure.highlight').wrap('<div class="code-area-wrap"></div>')
var $copyIcon = $('<i class="fa fa-clipboard" aria-hidden="true"></i>') var $copyIcon = $('<i class="fa fa-clipboard" aria-hidden="true"></i>')
var $notice = $('<div class="copy-notice"></div>') var $notice = $('<div class="copy-notice"></div>')
$('.code-area-wrap').prepend($copyIcon) $('.code-area-wrap').prepend($copyIcon)
@@ -240,27 +214,76 @@ $(function () {
selection.removeAllRanges() selection.removeAllRanges()
}) })
} }
//---------------------------------------------------------------------------------------------------
//fancybox /**
var imgList = $(".recent-post-info img"); * 代碼框語言識別
if (imgList.length === 0) { */
imgList = $("#post-content img"); var highlight_lang = GLOBAL_CONFIG.highlight_lang
if (highlight_lang == 'true') {
var $highlight_lang = $('<div class="code_lang"></div>')
$('figure').before($highlight_lang)
var lang_name_index
var lang_name
$('figure').each(function () {
lang_name_index = lang_name = $(this).attr('class').split(' ')[1];
if (lang_name_index == 'js')
lang_name = 'javascript'
if (lang_name_index == 'md')
lang_name = 'markdown'
if (lang_name_index == 'plain')
lang_name = 'code'
if (lang_name_index == 'py')
lang_name = 'python'
$(this).siblings(".code_lang").text(lang_name)
})
} }
/**
* 代碼收縮
*/
var highlight_shrink = GLOBAL_CONFIG.highlight_shrink
if (highlight_shrink == 'true') {
var $code_expand = $('<i class="fa fa-angle-down code-expand code-closed" aria-hidden="true"></i>')
} else {
var $code_expand = $('<i class="fa fa-angle-down code-expand" aria-hidden="true"></i>')
}
$('.code-area-wrap').prepend($code_expand)
$('.code-area-wrap .code-expand').on('click', function () {
if ($(this).hasClass('code-closed')) {
$(this).siblings('figure').find('table').show();
$(this).removeClass('code-closed');
} else {
$(this).siblings('figure').find('table').hide();
$(this).addClass('code-closed');
}
})
/**
* fancybox
*/
var imgList = $(".recent-post-info img").not('.no-fancybox');
if (imgList.length === 0) {
imgList = $("#post-content img").not('.no-fancybox');
}
for (var i = 0; i < imgList.length; i++) { for (var i = 0; i < imgList.length; i++) {
var lazyload_src = imgList[i].src ? imgList[i].src : imgList.eq(i).attr("data-src")
var $a = $( var $a = $(
'<a href="' + '<a href="' +
imgList[i].src + lazyload_src +
'" data-fancybox="group" data-caption="' + '" data-fancybox="group" data-caption="' +
imgList[i].alt + imgList[i].alt +
'" class="fancybox"></a>' '" class="fancybox"></a>'
); )
var alt = imgList[i].alt;
var $wrap = $(imgList[i]).wrap($a);
if (alt) {
$wrap.after('<div class="img-alt">' + alt + "</div>");
}
}
var alt = imgList[i].alt
var $wrap = $(imgList[i]).wrap($a)
if (alt) {
$wrap.after('<div class="img-alt">' + alt + '</div>')
}
}
$().fancybox({ $().fancybox({
selector: "[data-fancybox]", selector: "[data-fancybox]",
loop: true, loop: true,
@@ -292,52 +315,68 @@ $(function () {
}); });
//-------------------------------------------------------------------------------------------------------- /**
//lazy懶加載 * 手機menu和toc按鈕點擊
//把img的src删除添加data-src,用于lozad.js * 顯示menu和toc的sidebar
var $img = $("#post img"); */
$img.addClass("lozad"); function mobile_menu_close() {
$img.each(function () { if ($(".toggle-menu").hasClass("open")) {
var src_link = $(this).attr("src");
$(this).attr("data-src", src_link);
$(this).removeAttr("src");
})
const observer = lozad(); // lazy loads elements with default selector as '.lozad'
observer.observe();
//---------------------------------------------------------------------------------------------------------
/** head点击*/
$('.toggle-menu').on('click', function () {
if (!$('.menus').is(':visible')) {
$(".toggle-menu").removeClass("open").addClass("close"); $(".toggle-menu").removeClass("open").addClass("close");
$('.menus').slideDown(300) $('body').removeClass("open-mobile-menus");
} else { $('#menu_mask').fadeOut()
$(".toggle-menu").removeClass("close").addClass("open");
$('.menus').slideUp(200)
} }
}
function mobile_toc_close() {
if ($("#mobile-toc-button").hasClass("open")) {
$("#mobile-toc-button").removeClass("open").addClass("close");
$('body').removeClass("open-mobile-toc");
$('#menu_mask').fadeOut();
}
}
$('.toggle-menu').on('click', function () {
if ($(".toggle-menu").hasClass("close")) {
$(".toggle-menu").removeClass("close").addClass("open");
$('body').addClass("open-mobile-menus");
$('#menu_mask').fadeIn();
}
}) })
$(document).on('click touchstart', function (e) { $('#mobile-toc-button').on('click', function () {
var flag = $('.menus')[0].contains(e.target) || $('.toggle-menu')[0].contains(e.target) if ($("#mobile-toc-button").hasClass("close")) {
if (!flag && $('.toggle-menu').is(':visible')) { $("#mobile-toc-button").removeClass("close").addClass("open");
$(".toggle-menu").removeClass("close").addClass("open"); $('body').addClass("open-mobile-toc");
$('.menus').slideUp(200) $('#menu_mask').fadeIn();
} }
}) })
$('#menu_mask').on('click touchstart', function () {
mobile_menu_close()
mobile_toc_close()
})
$(window).on('resize', function (e) { $(window).on('resize', function (e) {
if (!$('.toggle-menu').is(':visible')) { if (!$('.toggle-menu').is(':visible')) {
if (!$('.menus').is(':visible')) { mobile_menu_close()
$(".toggle-menu").removeClass("open").addClass("close");
$('.menus').slideDown(300)
} }
if (!$('#mobile-toc-button').is(':visible')) {
mobile_toc_close()
} }
}) })
//--------------------------------------------------------------------------------------------------------- //點擊toc收起sidebar
/** scroll 滚动 toc*/ $("#mobile-sidebar-toc a").on('click', function () {
mobile_toc_close()
})
/**
* scroll 滚动 toc
*/
var initTop = 0 var initTop = 0
$('.toc-child').hide() $('.toc-child').hide()
@@ -349,55 +388,42 @@ $(function () {
scrollPercent(currentTop) scrollPercent(currentTop)
// head position // head position
findHeadPosition(currentTop) findHeadPosition(currentTop)
auto_scroll_toc(currentTop)
} }
var isUp = scrollDirection(currentTop) var isUp = scrollDirection(currentTop)
if (currentTop > 56) { if (currentTop > 56) {
if (isUp) { if (isUp) {
$('#page-header').hasClass('visible') ? $('#page-header').removeClass('visible') : console.log() $('#page-header').hasClass('visible') ? $('#page-header').removeClass('visible') : console.log()
} else { } else {
$('#page-header').hasClass('visible') ? console.log() : $('#page-header').addClass('visible') $('#page-header').hasClass('visible') ? console.log() : $('#page-header').addClass('visible')
} }
$('#page-header').addClass('fixed') $('#page-header').addClass('fixed')
if ($('#go-up').css('opacity') === '0') {
$('#go-up').animate({}, function () {
$('#go-up').css({
'opacity': '1',
'transform': 'translateX(-30px) rotateZ(360deg)'
})
})
}
if ($('#rightside').css('opacity') === '0') { if ($('#rightside').css('opacity') === '0') {
$('#rightside').animate({}, function () { $('#rightside').animate({}, function () {
$('#rightside').css({ $(this).css({
'opacity': '1', 'opacity': '1',
'transform': 'translateX(-38px)' 'transform': 'translateX(-38px)'
}) })
}) })
} }
} else { } else {
if (currentTop === 0) { if (currentTop === 0) {
$('#page-header').removeClass('fixed').removeClass('visible') $('#page-header').removeClass('fixed').removeClass('visible')
} }
$('#go-up').animate({}, function () {
$('#go-up').css({
'opacity': '0',
'transform': 'translateX(0) rotateZ(180deg) '
})
})
$('#rightside').animate({}, function () { $('#rightside').animate({}, function () {
$('#rightside').css({ $('#rightside').css({
'opacity': '0', 'opacity': '',
'transform': 'translateX(0)' 'transform': ''
}) })
}) })
} }
}, 50, 100)) }, 50, 100))
// go up smooth scroll // go up smooth scroll
@@ -406,9 +432,9 @@ $(function () {
}) })
// head scroll // head scroll
$('#post-content').find('h1,h2,h3,h4,h5,h6').on('click', function (e) { // $('#post-content').find('h1,h2,h3,h4,h5,h6').on('click', function (e) {
scrollToHead('#' + $(this).attr('id')) // scrollToHead('#' + $(this).attr('id'))
}) // })
// head scroll // head scroll
$('.toc-link').on('click', function (e) { $('.toc-link').on('click', function (e) {
@@ -501,41 +527,138 @@ $(function () {
// Hide their respective list of subsections // Hide their respective list of subsections
.find('.toc-child').hide() .find('.toc-child').hide()
} }
} }
//代碼框雙擊全屏 function auto_scroll_toc(currentTop) {
$('figure').on('dblclick', function (e) { if ($('.toc-link').hasClass('active')) {
if (e.target !== this) var active_position = $(".active").offset().top;
return; var sidebar_scrolltop = $("#sidebar").scrollTop();
$(this).toggleClass('code_full_page'); if (active_position > (currentTop + $(window).height() - 50)) {
$('body').toggleClass('code_body'); $("#sidebar").scrollTop(sidebar_scrolltop + 100);
}); } else if (active_position < currentTop + 50) {
$("#sidebar").scrollTop(sidebar_scrolltop - 100);
}
}
}
/**
//閲讀模式 * 閲讀模式
*/
$("#readmode").click(function () { $("#readmode").click(function () {
if (Cookies.get("night-mode") == "night") { if (Cookies.get("night-mode") == "night") {
$('body').toggleClass('night-mode'); $('body').toggleClass('night-mode');
$('body').toggleClass('read-mode'); $('body').toggleClass('read-mode');
$('#font_plus,#font_minus').toggleClass('is_visible'); $('#to_comment').toggleClass('is_invisible');
} else { } else {
$('body').toggleClass('read-mode'); $('body').toggleClass('read-mode');
$('#font_plus,#font_minus').toggleClass('is_visible'); $('#to_comment').toggleClass('is_invisible');
} }
}); });
/**
//閲讀模式下字體調整 * 字體調整
*/
$("#font_plus").click(function () { $("#font_plus").click(function () {
var font_size_record = parseFloat($('body').css('font-size')) var font_size_record = parseFloat($('body').css('font-size'))
var pre_size_record = parseFloat($('pre').css('font-size'))
var code_size_record = parseFloat($('code').css('font-size'))
$('body').css('font-size', font_size_record + 1) $('body').css('font-size', font_size_record + 1)
$('pre').css('font-size', pre_size_record + 1)
$('code').css('font-size', code_size_record + 1)
}); });
$("#font_minus").click(function () { $("#font_minus").click(function () {
var font_size_record = parseFloat($('body').css('font-size')) var font_size_record = parseFloat($('body').css('font-size'))
var pre_size_record = parseFloat($('pre').css('font-size'))
var code_size_record = parseFloat($('code').css('font-size'))
$('body').css('font-size', font_size_record - 1) $('body').css('font-size', font_size_record - 1)
$('pre').css('font-size', pre_size_record - 1)
$('code').css('font-size', code_size_record - 1)
}); });
/**
* sub-menus 位置調整
*/
if ($(window).width() > 768) {
$('.menus_item_child').each(function () {
var a_width = $(this).siblings('a').outerWidth(true);
var child_width = $(this).outerWidth(true);
$(this).css("margin-left", -(child_width / 2 - a_width / 2))
})
}
/**
* 手機端sub-menu 展開/收縮
*/
$('.menus-expand').on('click', function () {
if ($(this).hasClass('menus-closed')) {
$(this).parents('.menus_item').find('.menus_item_child').show();
$(this).removeClass('menus-closed');
} else {
$(this).parents('.menus_item').find('.menus_item_child').hide();
$(this).addClass('menus-closed');
}
})
/**
* rightside 點擊設置 按鈕 展開
*/
$('#rightside_config').on('click', function () {
$('#rightside-config-hide').toggleClass("rightside-in")
})
/**
* 調正recent_post 上下間距
*/
function recent_post_padding() {
$(".recent-post-info").each(function () {
var k = $(".recent-post-item").height();
var e = $(this).height();
$(this).css({
"padding-top": (k - e) / 2,
"padding-bottom": (k - e) / 2
})
})
}
//recent-post-item垂直置中
if ($(window).width() > 768) {
recent_post_padding();
}
$(window).bind("resize", function () {
if ($(window).width() > 768) {
recent_post_padding();
}
})
/**
* 複製時加上版權信息
*/
var copy_copyright_js = GLOBAL_CONFIG.copy_copyright_js
var copyright = GLOBAL_CONFIG.copyright
if (copyright) {
document.body.oncopy = event => {
event.preventDefault();
let textFont, copyFont = window.getSelection(0).toString();
if (copyFont.length > 45) {
textFont = copyFont + '\n' + '\n' + '\n' +
copyright.languages.author + '\n' +
copyright.languages.link + '\n' +
copyright.languages.source + '\n' +
copyright.languages.info;
} else {
textFont = copyFont;
}
if (event.clipboardData) {
return event.clipboardData.setData('text', textFont);
} else {
// 兼容IE
return window.clipboardData.setData("text", textFont);
}
}
}
}); });

View File

@@ -11,6 +11,10 @@ $(function () {
} }
function changeReadModel() { function changeReadModel() {
if (Cookies.get("night-mode") == null)
return
if (Cookies.get("night-mode") == "night") { if (Cookies.get("night-mode") == "night") {
$("body").addClass("night-mode"); $("body").addClass("night-mode");
$("#nightshift").removeClass("fa-moon-o").addClass("fa-sun-o"); $("#nightshift").removeClass("fa-moon-o").addClass("fa-sun-o");

View File

@@ -7,7 +7,7 @@ $(function () {
$('.search-dialog').css({ $('.search-dialog').css({
'display': 'block', 'display': 'block',
'animation': 'titlescale 0.5s' 'animation': 'titlescale 0.5s'
}) }),300
}) })
$('.ais-search-box--input').focus() $('.ais-search-box--input').focus()

View File

@@ -7,7 +7,7 @@ $(function () {
$('.search-dialog').css({ $('.search-dialog').css({
'display': 'block', 'display': 'block',
'animation': 'titlescale 0.5s' 'animation': 'titlescale 0.5s'
}) }),300
}) })
$('#local-search-input input').focus() $('#local-search-input input').focus()

11
source/js/third-party/canvas-nest.js vendored Normal file
View File

@@ -0,0 +1,11 @@
!function(){
var userAgentInfo = navigator.userAgent;
var Agents = ["iPad", "iPhone", "Android",
"SymbianOS", "Windows Phone",
"iPod", "webOS", "BlackBerry", "IEMobile"];
for (var v = 0; v < Agents.length; v++) {
if (userAgentInfo.indexOf(Agents[v]) > 0) {
return;
}
}
function o(w,v,i){return w.getAttribute(v)||i}function j(i){return document.getElementsByTagName(i)}function l(){var i=j("script"),w=i.length,v=i[w-1];return{l:w,z:o(v,"zIndex",-1),o:o(v,"opacity",0.5),c:o(v,"color","0,0,0"),n:o(v,"count",99)}}function k(){r=u.width=window.innerWidth||document.documentElement.clientWidth||document.body.clientWidth,n=u.height=window.innerHeight||document.documentElement.clientHeight||document.body.clientHeight}function b(){e.clearRect(0,0,r,n);var w=[f].concat(t);var x,v,A,B,z,y;t.forEach(function(i){i.x+=i.xa,i.y+=i.ya,i.xa*=i.x>r||i.x<0?-1:1,i.ya*=i.y>n||i.y<0?-1:1,e.fillRect(i.x-0.5,i.y-0.5,1,1);for(v=0;v<w.length;v++){x=w[v];if(i!==x&&null!==x.x&&null!==x.y){B=i.x-x.x,z=i.y-x.y,y=B*B+z*z;y<x.max&&(x===f&&y>=x.max/2&&(i.x-=0.03*B,i.y-=0.03*z),A=(x.max-y)/x.max,e.beginPath(),e.lineWidth=A/2,e.strokeStyle="rgba("+s.c+","+(A+0.2)+")",e.moveTo(i.x,i.y),e.lineTo(x.x,x.y),e.stroke())}}w.splice(w.indexOf(i),1)}),m(b)}var u=document.createElement("canvas"),s=l(),c="c_n"+s.l,e=u.getContext("2d"),r,n,m=window.requestAnimationFrame||window.webkitRequestAnimationFrame||window.mozRequestAnimationFrame||window.oRequestAnimationFrame||window.msRequestAnimationFrame||function(i){window.setTimeout(i,1000/45)},a=Math.random,f={x:null,y:null,max:20000};u.id=c;u.style.cssText="position:fixed;top:0;left:0;z-index:"+s.z+";opacity:"+s.o;j("body")[0].appendChild(u);k(),window.onresize=k;window.onmousemove=function(i){i=i||window.event,f.x=i.clientX,f.y=i.clientY},window.onmouseout=function(){f.x=null,f.y=null};for(var t=[],p=0;s.n>p;p++){var h=a()*r,g=a()*n,q=2*a()-1,d=2*a()-1;t.push({x:h,y:g,xa:q,ya:d,max:6000})}setTimeout(function(){b()},100)}();