├── source
├── CNAME
├── robots.txt
├── _data
│ └── widgets.yml
├── notes
│ ├── index.md
│ ├── json
│ │ └── index.md
│ ├── nodejs
│ │ └── index.md
│ └── flutter
│ │ └── index.md
├── wiki
│ ├── tag.sh
│ │ └── index.md
│ ├── prohud
│ │ ├── getting-started
│ │ │ └── index.md
│ │ ├── custom
│ │ │ └── index.md
│ │ ├── scene
│ │ │ └── index.md
│ │ ├── toast
│ │ │ └── index.md
│ │ └── index.md
│ ├── podspec.sh
│ │ └── index.md
│ ├── nexus
│ │ └── index.md
│ ├── git
│ │ ├── index.md
│ │ └── git-server
│ │ │ └── index.md
│ ├── inspire
│ │ └── index.md
│ ├── smartlamp
│ │ └── index.md
│ ├── vim-cn.sh
│ │ └── index.md
│ ├── volantis
│ │ └── index.md
│ ├── resume
│ │ └── index.md
│ └── heartmate
│ │ └── index.md
├── _posts
│ └── blog
│ │ ├── 2016-02-11-smart-life.md
│ │ ├── 2016-05-22-to-be-a-titan.md
│ │ ├── 2013-02-06-effective-teamwork.md
│ │ ├── 2020-08-23-issues-api.md
│ │ ├── 2017-06-28-ios-strava.md
│ │ └── 2016-11-06-ios-framework.md
├── install
└── friends
│ └── index.md
├── themes
└── stellar
│ ├── .gitignore
│ ├── giscus.json
│ ├── .npmignore
│ ├── source
│ ├── css
│ │ ├── _common
│ │ │ ├── control.styl
│ │ │ ├── image.styl
│ │ │ ├── pre.styl
│ │ │ ├── svg.styl
│ │ │ ├── input.styl
│ │ │ ├── span.styl
│ │ │ ├── cap.styl
│ │ │ ├── blockquote.styl
│ │ │ ├── toast.styl
│ │ │ ├── html.styl
│ │ │ ├── blur.styl
│ │ │ ├── loading.styl
│ │ │ ├── title.styl
│ │ │ ├── base.styl
│ │ │ ├── device.styl
│ │ │ └── button.styl
│ │ ├── _plugins
│ │ │ ├── scrollreveal.styl
│ │ │ ├── aplayer.styl
│ │ │ ├── comments
│ │ │ │ ├── beaudar.styl
│ │ │ │ ├── artalk.styl
│ │ │ │ ├── utterances.styl
│ │ │ │ └── waline.styl
│ │ │ ├── fancybox.styl
│ │ │ ├── copycode.styl
│ │ │ ├── lazyload.styl
│ │ │ ├── index.styl
│ │ │ └── swiper.styl
│ │ ├── _layout
│ │ │ ├── tag-plugins
│ │ │ │ ├── ghcard.styl
│ │ │ │ ├── emoji.styl
│ │ │ │ ├── mark.styl
│ │ │ │ ├── tag.styl
│ │ │ │ ├── override.styl
│ │ │ │ ├── navbar.styl
│ │ │ │ ├── copy.styl
│ │ │ │ ├── toc.styl
│ │ │ │ ├── inline-labels.styl
│ │ │ │ ├── image.styl
│ │ │ │ ├── grid.styl
│ │ │ │ ├── folders.styl
│ │ │ │ ├── poetry.styl
│ │ │ │ ├── frame.styl
│ │ │ │ ├── about.styl
│ │ │ │ ├── note.styl
│ │ │ │ ├── folding.styl
│ │ │ │ ├── friends.styl
│ │ │ │ └── quot.styl
│ │ │ ├── index.styl
│ │ │ ├── widgets
│ │ │ │ ├── toc_blog.styl
│ │ │ │ ├── related.styl
│ │ │ │ ├── tagcloud.styl
│ │ │ │ ├── recent.styl
│ │ │ │ ├── timeline.styl
│ │ │ │ ├── ghrepo.styl
│ │ │ │ ├── toc_wiki.styl
│ │ │ │ ├── widgets.styl
│ │ │ │ └── toc_common.styl
│ │ │ ├── partial
│ │ │ │ ├── bread-nav.styl
│ │ │ │ ├── footer.styl
│ │ │ │ ├── paginator.styl
│ │ │ │ ├── article-footer.styl
│ │ │ │ ├── navbar.styl
│ │ │ │ └── cover.styl
│ │ │ ├── main.styl
│ │ │ ├── pages
│ │ │ │ └── error.styl
│ │ │ ├── layout.styl
│ │ │ └── sidebar
│ │ │ │ ├── sidebar.styl
│ │ │ │ └── footer.styl
│ │ ├── main.styl
│ │ └── _defines
│ │ │ └── const.styl
│ └── js
│ │ └── plugins
│ │ ├── linkcard.js
│ │ └── copycode.js
│ ├── layout
│ ├── _partial
│ │ ├── main
│ │ │ ├── header
│ │ │ │ └── index.ejs
│ │ │ ├── post_list
│ │ │ │ ├── paginator.ejs
│ │ │ │ └── wiki_card.ejs
│ │ │ ├── article
│ │ │ │ ├── ai_abstract.ejs
│ │ │ │ ├── related_posts.ejs
│ │ │ │ └── read_next.ejs
│ │ │ ├── navbar
│ │ │ │ └── list_wiki.ejs
│ │ │ └── footer.ejs
│ │ ├── plugins
│ │ │ └── comments
│ │ │ │ ├── script.ejs
│ │ │ │ ├── artalk
│ │ │ │ ├── layout.ejs
│ │ │ │ └── script.ejs
│ │ │ │ ├── twikoo
│ │ │ │ ├── layout.ejs
│ │ │ │ └── script.ejs
│ │ │ │ ├── waline
│ │ │ │ ├── layout.ejs
│ │ │ │ └── script.ejs
│ │ │ │ ├── giscus
│ │ │ │ ├── layout.ejs
│ │ │ │ └── script.ejs
│ │ │ │ ├── beaudar
│ │ │ │ ├── layout.ejs
│ │ │ │ └── script.ejs
│ │ │ │ ├── utterances
│ │ │ │ ├── layout.ejs
│ │ │ │ └── script.ejs
│ │ │ │ └── layout.ejs
│ │ ├── cover
│ │ │ ├── index.ejs
│ │ │ ├── post_cover.ejs
│ │ │ └── wiki_cover.ejs
│ │ ├── widgets
│ │ │ ├── markdown.ejs
│ │ │ ├── tagcloud.ejs
│ │ │ ├── timeline.ejs
│ │ │ ├── ghissues.ejs
│ │ │ ├── related.ejs
│ │ │ └── search.ejs
│ │ ├── sidebar
│ │ │ ├── menu.ejs
│ │ │ └── header.ejs
│ │ └── menubtn.ejs
│ ├── tags.ejs
│ ├── 404.ejs
│ ├── layout.ejs
│ ├── categories.ejs
│ ├── mermaid.ejs
│ ├── page.ejs
│ ├── mathjax.ejs
│ ├── post.ejs
│ ├── wiki.ejs
│ └── archive.ejs
│ ├── scripts
│ ├── generators
│ │ ├── 404.js
│ │ ├── tags.js
│ │ ├── categories.js
│ │ └── wiki.js
│ ├── helpers
│ │ ├── scrollreveal.js
│ │ ├── category_color.js
│ │ ├── utils.js
│ │ ├── stellar_info.js
│ │ ├── parse_config.js
│ │ └── related_posts.js
│ ├── events
│ │ ├── index.js
│ │ └── lib
│ │ │ └── config.js
│ ├── filters
│ │ ├── index.js
│ │ └── lib
│ │ │ ├── img_onerror.js
│ │ │ └── img_lazyload.js
│ └── tags
│ │ ├── lib
│ │ ├── mark.js
│ │ ├── folding.js
│ │ ├── checkbox.js
│ │ ├── tag.js
│ │ ├── ablock.js
│ │ ├── note.js
│ │ ├── emoji.js
│ │ ├── swiper.js
│ │ ├── poetry.js
│ │ ├── grid.js
│ │ ├── ghcard.js
│ │ ├── navbar.js
│ │ ├── folders.js
│ │ ├── quot.js
│ │ ├── about.js
│ │ ├── friends.js
│ │ ├── copy.js
│ │ ├── tabs.js
│ │ ├── frame.js
│ │ └── toc.js
│ │ ├── inline-labels.js
│ │ └── index.js
│ ├── .github
│ ├── ISSUE_TEMPLATE
│ │ ├── article-share.md
│ │ └── any-question.md
│ └── workflows
│ │ ├── label-commenter.yml
│ │ └── npm-publish.yml
│ ├── _data
│ ├── links.yml
│ └── widgets.yml
│ ├── package.json
│ ├── README.md
│ ├── languages
│ ├── zh-TW.yml
│ ├── zh-CN.yml
│ └── en.yml
│ ├── LICENSE
│ └── npm-publish.sh
├── scaffolds
├── draft.md
├── page.md
└── post.md
├── .gitignore
├── README.md
├── package.json
├── LICENSE
├── .github
└── workflows
│ └── auto-deploy.yml
└── _config.stellar.yml
/source/CNAME:
--------------------------------------------------------------------------------
1 | xaoxuu.com
--------------------------------------------------------------------------------
/themes/stellar/.gitignore:
--------------------------------------------------------------------------------
1 | .DS_Store
2 | node_modules
--------------------------------------------------------------------------------
/source/robots.txt:
--------------------------------------------------------------------------------
1 | User-Agent: *
2 | Allow: /sitemap.xml
--------------------------------------------------------------------------------
/scaffolds/draft.md:
--------------------------------------------------------------------------------
1 | ---
2 | title: {{ title }}
3 | tags:
4 | ---
5 |
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | .DS_Store
2 | node_modules
3 | db.json
4 | .deploy_git
5 | public
--------------------------------------------------------------------------------
/scaffolds/page.md:
--------------------------------------------------------------------------------
1 | ---
2 | title: {{ title }}
3 | date: {{ date }}
4 | ---
5 |
--------------------------------------------------------------------------------
/themes/stellar/giscus.json:
--------------------------------------------------------------------------------
1 | {
2 | "defaultCommentOrder": "newest"
3 | }
4 |
--------------------------------------------------------------------------------
/scaffolds/post.md:
--------------------------------------------------------------------------------
1 | ---
2 | title: {{ title }}
3 | date: {{ date }}
4 | tags:
5 | ---
6 |
--------------------------------------------------------------------------------
/themes/stellar/.npmignore:
--------------------------------------------------------------------------------
1 | .github/
2 | npm-publish.sh
3 | node_modules
4 | giscus.json
--------------------------------------------------------------------------------
/themes/stellar/source/css/_common/control.styl:
--------------------------------------------------------------------------------
1 | .dis-select
2 | disable-select()
3 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_plugins/scrollreveal.styl:
--------------------------------------------------------------------------------
1 | .reveal
2 | visibility: hidden
--------------------------------------------------------------------------------
/themes/stellar/source/css/_plugins/aplayer.styl:
--------------------------------------------------------------------------------
1 | .md-text
2 | .aplayer
3 | border-radius: $border-block
--------------------------------------------------------------------------------
/themes/stellar/source/css/_plugins/comments/beaudar.styl:
--------------------------------------------------------------------------------
1 | .cmt-body.beaudar
2 | margin: 0 -4px
3 | width: 'calc(100% + %s)' % 8px
4 |
--------------------------------------------------------------------------------
/source/_data/widgets.yml:
--------------------------------------------------------------------------------
1 | welcome:
2 | layout: markdown
3 | title: '欢迎,旅行者:'
4 | content: |
5 | 这是一个世界边缘的佛系小站,建于21世纪初,长期维护并保持低频更新。
6 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_plugins/fancybox.styl:
--------------------------------------------------------------------------------
1 | img[fancybox='true']
2 | cursor: zoom-in
3 |
4 | .swiper-slide
5 | cursor: zoom-in
6 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/tag-plugins/ghcard.styl:
--------------------------------------------------------------------------------
1 | .tag-plugin.ghcard
2 | line-height: 0
3 | a.ghcard
4 | display: inline-block
5 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | # rockyzsu's blog
2 |
3 |
4 |
5 | ## 运行
6 | ```shell
7 | npm i # 可能需要 yay -S nasm(安装nasm,编译jpegtran需要)
8 | npm run s
9 | ```
10 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_common/image.styl:
--------------------------------------------------------------------------------
1 | div.lazy.img
2 | width: 100%
3 | height: 100%
4 | background-position: center
5 | background-size: cover
6 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_common/pre.styl:
--------------------------------------------------------------------------------
1 | pre:not([class]):has(>code)
2 | display: block
3 | padding: 1rem
4 | overflow: auto
5 | code
6 | padding: 0
--------------------------------------------------------------------------------
/themes/stellar/source/css/_common/svg.styl:
--------------------------------------------------------------------------------
1 | svg.icon
2 | width: 1em
3 | height: 1em
4 | vertical-align: middle
5 | fill: currentColor
6 | overflow: hidden
7 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/index.styl:
--------------------------------------------------------------------------------
1 | @import 'partial/*'
2 | @import 'tag-plugins/*'
3 | @import 'sidebar/*'
4 | @import 'widgets/*'
5 | @import 'pages/*'
6 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/widgets/toc_blog.styl:
--------------------------------------------------------------------------------
1 | .widget-wrapper.toc.single .doc-tree
2 | &.active>.toc
3 | border-left: 2px solid var(--block-hover)
4 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_plugins/comments/artalk.styl:
--------------------------------------------------------------------------------
1 | .cmt-body.artalk .artalk
2 | --at-color-main: $color-theme
3 | .atk-main-editor
4 | border-radius: $border-block
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/main/header/index.ejs:
--------------------------------------------------------------------------------
1 | <% if (page.header != 'auto' && page.header != false) { %>
2 | <%- partial('../../sidebar/header', {where: 'main'}) %>
3 | <% } %>
4 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/plugins/comments/script.ejs:
--------------------------------------------------------------------------------
1 | <% if (page.cmt && page.cmt.service && page.cmt.service.length > 0) { %>
2 | <%- partial(page.cmt.service + '/script') %>
3 | <% } %>
4 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_plugins/comments/utterances.styl:
--------------------------------------------------------------------------------
1 | .cmt-body.utterances
2 | margin: 0 -4px
3 | width: 'calc(100% + %s)' % 8px
4 |
5 | .related-wrap#comments .cmt-body svg.loading
6 | top: 62px
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/tag-plugins/emoji.styl:
--------------------------------------------------------------------------------
1 | .md-text .tag-plugin.emoji
2 | display: inline-block
3 | margin: -4px 2px 0
4 | vertical-align: middle
5 | img
6 | display: block
7 | object-fit: contain
8 | height: 1.75em
9 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_common/input.styl:
--------------------------------------------------------------------------------
1 | input
2 | background: none
3 | border: none
4 |
5 | input.copy-area
6 | display: block
7 | font-family: $ff-code
8 | font-size: $fs-12
9 | font-weight: 700
10 | color: var(--text-p3)
11 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/widgets/related.styl:
--------------------------------------------------------------------------------
1 | .widget-wrapper.related .widget-body a
2 | margin-top: 0.5rem
3 | margin-bottom: 1rem
4 | .title
5 | font-weight: 700
6 | font-size: $fs-14
7 | .excerpt
8 | -webkit-line-clamp: 3
9 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/widgets/tagcloud.styl:
--------------------------------------------------------------------------------
1 | .widget-wrapper.tagcloud .widget-body
2 | margin-top: 0.25rem
3 | a
4 | word-break: break-word
5 | color: var(--text-p2)
6 | line-height: 1.5
7 | &:hover
8 | color: $color-hover
9 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/generators/404.js:
--------------------------------------------------------------------------------
1 | /**
2 | * 404 v1 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | */
4 |
5 | hexo.extend.generator.register('404', function (locals) {
6 | return {
7 | path: '/404.html',
8 | layout: ['404']
9 | }
10 | });
--------------------------------------------------------------------------------
/themes/stellar/source/css/_common/span.styl:
--------------------------------------------------------------------------------
1 | span.dot,span.sep
2 | font-size: 0.9em
3 | margin: 0 .25em
4 | span.dot:before
5 | content: '·'
6 | font-weight: 900
7 | span.sep:before
8 | content: '/'
9 | padding-left: 2px
10 | padding-right: 2px
11 |
--------------------------------------------------------------------------------
/themes/stellar/.github/ISSUE_TEMPLATE/article-share.md:
--------------------------------------------------------------------------------
1 | ---
2 | name: Article Share【文章分享】
3 | about: 与Stellar相关的文章分享
4 | title: '[分享] '
5 | labels: '分享'
6 | assignees: ''
7 | ---
8 |
9 |
10 |
11 | **[]()**
12 |
13 |
14 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/tag-plugins/mark.styl:
--------------------------------------------------------------------------------
1 | .md-text .tag-plugin.mark
2 | padding: 0 1px
3 | border-radius: 2px
4 | background: var(--theme-bg2)
5 | border: 1px solid var(--theme-border)
6 | color: var(--text-p0)
7 | &[color=dark]
8 | border-color: var(--theme-bg2)
9 |
--------------------------------------------------------------------------------
/themes/stellar/.github/ISSUE_TEMPLATE/any-question.md:
--------------------------------------------------------------------------------
1 | ---
2 | name: Any Question【问题反馈】
3 | about: 主题使用方面任何问题或建议
4 | title: ''
5 | labels: ''
6 | assignees: ''
7 |
8 | ---
9 |
10 |
16 |
--------------------------------------------------------------------------------
/themes/stellar/_data/links.yml:
--------------------------------------------------------------------------------
1 | # 不要直接在这里写,要复制到 blog/source/_data/links.yml 位置
2 | '示例':
3 | - title: XAOXUU
4 | avatar: https://bu.dusays.com/2021/09/24/2f74810ceb3d3.png
5 | url: https://xaoxuu.com
6 | screenshot: https://bu.dusays.com/2022/10/23/63542895cfd29.png
7 | description:
8 |
--------------------------------------------------------------------------------
/source/notes/index.md:
--------------------------------------------------------------------------------
1 | ---
2 | robots: noindex,nofollow
3 | sitemap: false
4 | menu_id: notes
5 | layout: wiki
6 | wiki: Notes
7 | header: true
8 | breadcrumb: false
9 | title: 便笺
10 | seo_title: 收藏的站点
11 | ---
12 |
13 | {% toc wiki:Notes display:mobile TOC %}
14 |
15 | {% sites not:examples %}
16 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/cover/index.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | function layoutCover() {
3 | if (page.layout == 'wiki') {
4 | return partial('wiki_cover');
5 | }
6 | if (page.layout == 'post') {
7 | return partial('post_cover');
8 | }
9 | return '';
10 | }
11 | %>
12 | <%- layoutCover() %>
13 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/helpers/scrollreveal.js:
--------------------------------------------------------------------------------
1 | 'use strict';
2 |
3 | hexo.extend.helper.register('scrollreveal', function(args){
4 | const cfg = hexo.theme.config;
5 | if (cfg.plugins.scrollreveal && cfg.plugins.scrollreveal.enable) {
6 | return ' reveal';
7 | }
8 | return '';
9 | });
10 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/main/post_list/paginator.ejs:
--------------------------------------------------------------------------------
1 | <% if ((is_home() || is_category() || is_tag()) && page.total > 1) { %>
2 |
3 | <%- paginator({
4 | prev_text: '',
5 | next_text: '',
6 | force_prev_next:true
7 | }) %>
8 |
9 | <% } %>
10 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_common/cap.styl:
--------------------------------------------------------------------------------
1 | .cap
2 | font-weight: 500
3 | font-size: $fs-12
4 | scrollbar-width: none
5 | color: var(--text-p3)
6 | &.blue
7 | color: darken($color-md-blue, 6)
8 | &.cyan
9 | color: darken($color-mac-cyan, 6)
10 | &.theme
11 | color: darken($color-theme, 5)
12 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/main.styl:
--------------------------------------------------------------------------------
1 | // 无需修改的常量
2 | @import '_defines/const'
3 |
4 | // 自定义参数
5 | @import '_custom'
6 |
7 | // 含自定义参数的常量以及函数
8 | @import '_defines/theme'
9 | @import '_defines/func'
10 |
11 | // 通用组件
12 | @import '_common/*'
13 | // 布局
14 | @import '_layout/*'
15 |
16 | // 可选插件
17 | @import '_plugins/index'
18 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_common/blockquote.styl:
--------------------------------------------------------------------------------
1 | blockquote
2 | display: block
3 | margin-left: 0
4 | margin-right: 0
5 | padding: 0.25rem 0.75rem
6 | background: var(--block)
7 | $bd-left = 4px
8 | border-left: $bd-left solid var(--text-meta)
9 | border-radius: $bd-left $border-bar $border-bar $bd-left
10 | color: var(--text-p2)
--------------------------------------------------------------------------------
/themes/stellar/scripts/helpers/category_color.js:
--------------------------------------------------------------------------------
1 | 'use strict';
2 |
3 | hexo.extend.helper.register('category_color', function(cat){
4 | const cfg = hexo.theme.config;
5 | if (cfg.article.category_color && cfg.article.category_color[cat]) {
6 | return ' style="color:' + cfg.article.category_color[cat] + '"';
7 | }
8 | return '';
9 | });
10 |
--------------------------------------------------------------------------------
/source/notes/json/index.md:
--------------------------------------------------------------------------------
1 | ---
2 | robots: noindex,nofollow
3 | sitemap: false
4 | menu_id: notes
5 | layout: wiki
6 | wiki: Notes
7 | order: 401
8 | seo_title: Json在线解析工具
9 | ---
10 |
11 | {% folding Json 在线解析工具 child:codeblock open:true %}
12 |
13 | {% endfolding %}
14 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/tag-plugins/tag.styl:
--------------------------------------------------------------------------------
1 | .md-text .tag-plugin.tag
2 | padding: 0px 4px
3 | border-radius: 2px
4 | background: var(--theme-bg1)
5 | color: var(--text-p2)
6 | margin: 2px 0
7 | display: inline-block
8 | font-size: $fs-14
9 | trans2 background color
10 | &:hover
11 | background: var(--text-p2)
12 | color: var(--theme-bg1)
13 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/tag-plugins/override.styl:
--------------------------------------------------------------------------------
1 | .tag-plugin.note, .tag-plugin.folding
2 | blockquote
3 | border-top-left-radius: 0
4 | border-bottom-left-radius: 0
5 | background: none
6 | padding-top: 0
7 | padding-bottom: 0
8 | table:not([class])
9 | th
10 | background: var(--block-hover)
11 | td,th
12 | border-color: var(--block-border)
13 |
14 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/widgets/recent.styl:
--------------------------------------------------------------------------------
1 | .widget-wrapper.recent .widget-body
2 | display: flex
3 | flex-direction: column
4 | align-items: flex-start
5 | margin-top: 0.25rem
6 | a
7 | line-height: 1.2
8 | font-size: $fs-13
9 | margin: 0.25rem 0
10 | .title
11 | font-size: $fs-13
12 | color: var(--text-p2)
13 | &:hover
14 | color: $color-hover
15 |
16 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/generators/tags.js:
--------------------------------------------------------------------------------
1 | /**
2 | * tags v1 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | */
4 |
5 | hexo.extend.generator.register('tags', function (locals) {
6 | if (locals.tags && locals.tags.length > 0) {
7 | return {
8 | path: hexo.config.tag_dir + '/index.html',
9 | data: locals.posts,
10 | layout: ['tags']
11 | }
12 | } else {
13 | return {};
14 | }
15 | });
16 |
--------------------------------------------------------------------------------
/source/wiki/tag.sh/index.md:
--------------------------------------------------------------------------------
1 | ---
2 | layout: wiki
3 | wiki: tag.sh
4 | title: 「tag.sh」一个方便发布git版本的脚本
5 | ---
6 |
7 |
8 | ## 安装脚本
9 |
10 | 打开终端,输入并执行这一行命令即可:
11 |
12 | {% copy width:max curl -s https://xaoxuu.com/install | sh -s tag.sh %}
13 |
14 | ## 发布版本
15 |
16 | 当您需要进行版本发布时,在 git 仓库中打开终端,输入:
17 |
18 | ```sh
19 | tag 版本号 描述
20 | ```
21 |
22 | 然后稍等片刻即可完成发布。
23 |
24 |
25 | ## 删除版本
26 |
27 | ```sh
28 | tag del 版本号
29 | ```
30 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_common/toast.styl:
--------------------------------------------------------------------------------
1 | div.toast
2 | max-width: 60%
3 | padding: 1rem 3rem
4 | line-height: 1.5
5 | color: var(--text-p1)
6 | font-weight: 500
7 | text-align: center
8 | border-radius: $border-card
9 | background: var(--card)
10 | position: fixed
11 | top: 50%
12 | left: 50%
13 | transform: translate(-50%, -50%)
14 | z-index: 9
15 | disable-select()
16 | box-shadow: $boxshadow-float
17 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/generators/categories.js:
--------------------------------------------------------------------------------
1 | /**
2 | * categories v1 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | */
4 |
5 | hexo.extend.generator.register('categories', function (locals) {
6 | if (locals.categories && locals.categories.length > 0) {
7 | return {
8 | path: hexo.config.category_dir + '/index.html',
9 | data: locals.posts,
10 | layout: ['categories']
11 | }
12 | } else {
13 | return {};
14 | }
15 | });
16 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/main/article/ai_abstract.ejs:
--------------------------------------------------------------------------------
1 | <% if (page.layout === 'post' || (page.layout === 'wiki' && page.wiki && page.wiki.length > 0)) { %>
2 |
6 |
7 | <% } %>
8 |
--------------------------------------------------------------------------------
/source/notes/nodejs/index.md:
--------------------------------------------------------------------------------
1 | ---
2 | robots: noindex,nofollow
3 | sitemap: false
4 | menu_id: notes
5 | layout: wiki
6 | wiki: Notes
7 | title: Node.js 相关问题
8 | order: 350
9 | references:
10 | - url: https://nodejs.org/en/
11 | - url: https://www.npmjs.com
12 | ---
13 |
14 | 查看当前的源:
15 | {% copy npm config get registry %}
16 |
17 | 官方源:
18 | {% copy npm set registry https://registry.npmjs.org/ %}
19 |
20 | 淘宝源:
21 | {% copy npm set registry https://registry.npm.taobao.org/ %}
22 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/widgets/timeline.styl:
--------------------------------------------------------------------------------
1 | .widget-wrapper.timeline
2 | .widget-body
3 | margin-top: 0.5rem
4 | .tag-plugin.timeline .timenode
5 | .header
6 | margin-bottom: 0.5rem
7 | txt-ellipsis()
8 | .user-info
9 | background: var(--block)
10 | &:hover
11 | background: $color-hover
12 | color: var(--card)
13 | &:before
14 | display: none
15 | &+.timenode
16 | margin-top: 0.75rem
17 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/events/index.js:
--------------------------------------------------------------------------------
1 | /* global hexo */
2 |
3 | 'use strict';
4 |
5 | hexo.on('generateBefore', () => {
6 | // Merge config.
7 | require('./lib/config')(hexo);
8 | require('./lib/doc_tree')(hexo);
9 | require('./lib/utils')(hexo);
10 | });
11 |
12 | hexo.on('ready', () => {
13 | const { version, homepage, repository } = require('../../package.json');
14 | hexo.log.info(`Welcome to Stellar ${version}
15 | DOCS ${homepage}
16 | REPO ${repository.url}
17 | `);
18 | });
19 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_common/html.styl:
--------------------------------------------------------------------------------
1 | *
2 | outline: none
3 | html
4 | font-family: $ff-body
5 | font-size: $fs-root
6 | -webkit-text-size-adjust: 100%
7 | -ms-text-size-adjust: 100%
8 | if hexo-config('style.smooth_scroll')
9 | scroll-behavior: smooth
10 | body
11 | background: var(--site-bg)
12 | margin: 0
13 | -webkit-font-smoothing: antialiased
14 | -moz-osx-font-smoothing: grayscale
15 | text-rendering: optimizelegibility
16 | -webkit-tap-highlight-color: rgba(0, 0, 0, 0)
17 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/partial/bread-nav.styl:
--------------------------------------------------------------------------------
1 | // 面包屑导航
2 | .bread-nav
3 | padding: 0.25rem 1rem 0
4 | color: var(--text-p3)
5 | font-weight: 500
6 | div#breadcrumb
7 | display: flex
8 | align-items: center
9 | flex-direction: row
10 | &:not([style]) a
11 | color: var(--theme-link)
12 | &[style] a
13 | color: inherit
14 | span.sep
15 | color: var(--text-p3)
16 | a.cap:hover
17 | color: $color-hover
18 | div#post-meta
19 | margin-top: 2px
20 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/main.styl:
--------------------------------------------------------------------------------
1 | .l_main
2 | position: relative
3 | padding-bottom: "calc(1 * %s)" % var(--gap-l)
4 | @media screen and (min-width: 1400px)
5 | margin-left: "calc(2 * %s)" % var(--gap-l)
6 | margin-right: "calc(2 * %s + %s / 2)" % (var(--gap-l) var(--width-left))
7 | @media screen and (min-width: $device-mobile-max)
8 | padding-top: "calc(2 * %s)" % var(--gap-l)
9 | @media screen and (max-width: $device-mobile-max)
10 | padding-top: 1rem
11 | header
12 | margin: 2rem 1rem 1rem
13 | .logo-wrap
14 | margin: 0
15 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/widgets/markdown.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | function layoutDiv() {
3 | if (!item.content?.length) return ''
4 | var el = '';
5 | el += '';
6 | if (item.title?.length > 0) {
7 | el += '';
10 | }
11 | el += '';
12 | el += markdown(item.content);
13 | el += '
';
14 | el += '';
15 | return el;
16 | }
17 | %>
18 | <%- layoutDiv() %>
19 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/main/article/related_posts.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | function layoutDiv() {
3 | if (theme.article.related_posts.enable) {
4 | var el = '';
5 | el += '';
6 | el += popular_posts_wrapper({
7 | title: __('meta.related_posts'),
8 | json: popular_posts_json({ maxCount: theme.article.related_posts.max_count , ulClass: 'related-posts' , PPMixingRate: 0.2 , isImage: true , isExcerpt: true} , page )
9 | });
10 | el += '
';
11 | return el;
12 | }
13 | return;
14 | }
15 | %>
16 | <%- layoutDiv() %>
17 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/helpers/utils.js:
--------------------------------------------------------------------------------
1 | /**
2 | * utils v1 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | */
4 |
5 | 'use strict';
6 |
7 | hexo.extend.helper.register('get_page', function(id) {
8 | const pages = hexo.locals.get('pages');
9 | let page = pages.data.find(element => element._id == id)
10 | if (page && page._id == id) {
11 | return page
12 | } else {
13 | const posts = hexo.locals.get('posts');
14 | let post = posts.data.find(element => element._id == id)
15 | if (post && post._id == id) {
16 | return post
17 | }
18 | }
19 | return null
20 | });
21 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/pages/error.styl:
--------------------------------------------------------------------------------
1 | .md-text.error-page
2 | text-align: center
3 | margin-top: 2rem
4 | img#error
5 | width: 30vw
6 | max-height: 150px
7 | margin-bottom: 2rem
8 | h1
9 | font-size: 4rem
10 | margin-bottom: 0
11 | p.what,p.why
12 | margin: 0.5em
13 | p.why
14 | font-size: $fs-13
15 | a#back
16 | margin: 2rem 0
17 | display: inline-block
18 | background: #FDB62F
19 | color: black
20 | border: 2px solid black
21 |
22 | @media screen and (max-width: $device-tablet)
23 | .md-text.error-page
24 | margin-top: 4rem
25 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_plugins/copycode.styl:
--------------------------------------------------------------------------------
1 | .highlight
2 | position: relative
3 |
4 | .highlight .code .copy-btn
5 | position: absolute
6 | top: 0
7 | right: 0
8 | padding: 4px 0.5rem
9 | opacity: 0
10 | font-weight: 700
11 | color: var(--theme)
12 | cursor: pointer
13 |
14 | .highlight:hover .copy-btn
15 | opacity 0.25
16 |
17 | .highlight .code .copy-btn:hover
18 | color: var(--theme)
19 | opacity: 0.75
20 |
21 | .highlight .code .copy-btn.success
22 | color: $c-green
23 | opacity: 0.75
24 |
25 | .highlight .code .copy-btn.warning
26 | color: $c-orange
27 | opacity: 0.75
--------------------------------------------------------------------------------
/themes/stellar/scripts/filters/index.js:
--------------------------------------------------------------------------------
1 | 'use strict';
2 |
3 | hexo.extend.filter.register('after_render:html', require('./lib/img_lazyload').processSite);
4 | hexo.extend.filter.register('after_render:html', require('./lib/img_onerror').processSite);
5 |
6 | function change_image(data) {
7 | if (this.theme.config.tag_plugins.image.parse_markdown) {
8 | data.content = data.content.replace(
9 | /!\[(.*?)\]\((.*?)\s*(?:"(.*?)")?\)/g,
10 | '{% image $2 $3 %}'
11 | );
12 | }
13 | return data;
14 | }
15 |
16 |
17 | hexo.extend.filter.register('before_post_render', change_image, 9);
18 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/tag-plugins/navbar.styl:
--------------------------------------------------------------------------------
1 | .md-text .tag-plugin.navbar
2 | text-align: center
3 | nav.cap
4 | margin: 0
5 | padding: 1px
6 | background: var(--card)
7 | box-shadow: $boxshadow-button
8 | border-radius: 6px
9 | display: inline-flex
10 | max-width: 100%
11 | a
12 | margin: 1px
13 | padding: 0.25em 0.75rem
14 | color: var(--text-p2)
15 | &:after
16 | display: none
17 | &:hover
18 | background: var(--block)
19 | &.active
20 | background: var(--block)
21 | box-shadow: none
22 | color: var(--text-p1)
--------------------------------------------------------------------------------
/themes/stellar/.github/workflows/label-commenter.yml:
--------------------------------------------------------------------------------
1 | name: Label Commenter
2 |
3 | on:
4 | issues:
5 | types: [labeled, unlabeled]
6 | pull_request_target:
7 | types: [labeled, unlabeled]
8 |
9 | permissions:
10 | contents: read
11 | issues: write
12 | pull-requests: write
13 |
14 | jobs:
15 | comment:
16 | runs-on: ubuntu-20.04
17 | steps:
18 | - uses: actions/checkout@v3
19 | - name: Label Commenter
20 | uses: peaceiris/actions-label-commenter@v1
21 | with:
22 | github_token: ${{ secrets.GITHUB_TOKEN }}
23 | config_file: .github/config/label-commenter-config.yml
24 |
--------------------------------------------------------------------------------
/themes/stellar/layout/tags.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | page.robots = 'noindex,follow';
3 | if (page.menu_id == undefined) {
4 | page.menu_id = 'post';
5 | }
6 | %>
7 | <% if (site.tags.length) { %>
8 | <% page.title = __('btn.tags'); %>
9 | <% page.layout = 'tags'; %>
10 | <%- partial('_partial/main/navbar/list_post') %>
11 |
12 |
13 | <% site.tags.sort('length', -1).each(function(tag){ %>
14 |
15 | <%= tag.name %>
16 |
17 | <% }) %>
18 |
19 |
20 | <% } %>
21 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/tags/lib/mark.js:
--------------------------------------------------------------------------------
1 | /**
2 | * mark.js v1.0 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | * 格式与官方标签插件一致使用空格分隔,中括号内的是可选参数(中括号不需要写出来)
4 | *
5 | * {% mark text [color:color] %}
6 | *
7 | */
8 |
9 | 'use strict'
10 |
11 | module.exports = ctx => function(args) {
12 | args = ctx.args.map(args, ['color'], ['text'])
13 | if (args.color == null) {
14 | args.color = ctx.theme.config.tag_plugins.mark.default_color
15 | }
16 | var el = ''
17 | el += ''
20 | el += args.text
21 | el += ''
22 | return el
23 | }
24 |
--------------------------------------------------------------------------------
/source/wiki/prohud/getting-started/index.md:
--------------------------------------------------------------------------------
1 | ---
2 | layout: wiki
3 | wiki: ProHUD
4 | order: 1
5 | title: 快速开始
6 | ---
7 |
8 |
9 | ## 在项目中集成 ProHUD
10 |
11 | ### Swift Package Manager
12 |
13 | **File** -> **Swift Packages** -> **Add Package Dependency**
14 |
15 | 输入 `https://github.com/xaoxuu/ProHUD.git` 并选择需要的版本。
16 |
17 | ### CocoaPods
18 |
19 | ```
20 | pod 'ProHUD'
21 | ```
22 | ### Manually
23 |
24 | 下载 [源码](https://github.com/xaoxuu/ProHUD) 然后拖入工程即可。
25 |
26 |
27 | ## 体验 Demo 程序
28 |
29 | 从 GitHub 下载 ProHUD 的 [源码](https://github.com/xaoxuu/ProHUD) 并打开其中的 Example 程序。
30 |
31 | - **Example-Old** 是由 Xcode10 以及更古老的版本创建的项目。
32 | - **Example-Xcode11** 是由 Xcode11 创建的基于 SceneDelegate 的新项目。
33 |
--------------------------------------------------------------------------------
/themes/stellar/layout/404.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | page.menu_id = '404';
3 | page.layout = '404';
4 | page.comment_title = '';
5 | page.header = 'auto';
6 | page.robots = 'none';
7 | %>
8 |
9 | 
10 |
11 |
12 | <%- __('page.error.what') %>
13 |
14 |
15 |
16 | <%- __('page.error.why') %>
17 |
18 |
19 | <%- __('page.error.action') %>
20 |
21 | <%- partial('_partial/plugins/comments/layout') %>
22 |
--------------------------------------------------------------------------------
/themes/stellar/layout/layout.ejs:
--------------------------------------------------------------------------------
1 |
2 |
3 | <%- partial('_partial/head') %>
4 |
5 | <%- partial('_partial/cover/index') %>
6 |
7 |
10 |
11 | <%- partial('_partial/main/header/index') %>
12 | <%- body %>
13 | <%- partial('_partial/main/footer') %>
14 | <%- partial('_partial/menubtn') %>
15 |
16 |
17 |
18 | <%- partial('_partial/scripts/index') %>
19 |
20 |
21 |
22 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/sidebar/menu.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | function layoutDiv() {
3 | var el = '';
4 | el += '';
23 | return el;
24 | }
25 | %>
26 |
27 | <%- layoutDiv() %>
28 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_common/blur.styl:
--------------------------------------------------------------------------------
1 | :root
2 | --blur-px: 12px
3 | --blur-bg: alpha(white, .5)
4 | if hexo-config('style.darkmode') == 'auto'
5 | @media (prefers-color-scheme: dark)
6 | :root
7 | --blur-bg: alpha(black, .5)
8 | if hexo-config('style.darkmode') == 'always'
9 | :root
10 | --blur-bg: alpha(black, .5)
11 |
12 | .blur
13 | background: var(--blur-bg)
14 | @supports ((-webkit-backdrop-filter:blur(var(--blur-px))) or (backdrop-filter:blur(var(--blur-px))))
15 | background: var(--blur-bg) !important
16 | backdrop-filter: saturate(200%) blur(var(--blur-px))
17 | -webkit-backdrop-filter: saturate(200%) blur(var(--blur-px))
18 | &:hover
19 | background: var(--card)
20 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/helpers/stellar_info.js:
--------------------------------------------------------------------------------
1 | 'use strict';
2 |
3 | hexo.extend.helper.register('stellar_info', function(args){
4 | const repo = 'https://github.com/xaoxuu/hexo-theme-stellar';
5 | const wiki = 'https://xaoxuu.com/wiki/stellar/';
6 | const issues = repo + '/issues/';
7 | const { version } = require('../../package.json');
8 | const cfg = hexo.theme.config.stellar;
9 | if (!args) {
10 | return repo;
11 | } else if (args == 'name') {
12 | return 'Stellar';
13 | } else if (args == 'version') {
14 | return version;
15 | } else if (args == 'issues') {
16 | return repo + '/issues/'
17 | } else if (args == 'tree') {
18 | return repo + '/tree/' + version;
19 | }
20 | return '';
21 | });
22 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/widgets/tagcloud.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | function layoutDiv() {
3 | var el = '';
4 | if (site.tags == undefined || site.tags.length == 0) {
5 | return el;
6 | }
7 | var opts = Object.assign({}, item);
8 | delete opts['title'];
9 | delete opts['layout'];
10 | opts.class = 'tag ';
11 | el += '';
12 | if (item.title) {
13 | el += '';
16 | }
17 | el += '';
18 | el += tagcloud(site.tags, opts);
19 | el += '
';
20 | el += '';
21 | return el;
22 | }
23 | %>
24 | <%- layoutDiv() %>
25 |
--------------------------------------------------------------------------------
/source/wiki/podspec.sh/index.md:
--------------------------------------------------------------------------------
1 | ---
2 | layout: wiki
3 | title: 一个方便发布podspec的脚本
4 | wiki: podspec.sh
5 | ---
6 |
7 |
8 | ## 开始使用
9 |
10 | let `path` = 你的项目的 `podspec` 所在的路径
11 |
12 | 打开终端,cd 到 `path` ,输入下面这条命令下载脚本到当前文件夹:
13 |
14 | {% copy width:max curl -s https://xaoxuu.com/install | sh -s podspec.sh %}
15 |
16 | 如需安装指定版本,在后面加上版本号即可,例如:
17 |
18 | {% copy width:max curl -s https://xaoxuu.com/install | sh -s podspec.sh 1.2.1 %}
19 |
20 | 需要发布 podspec 到时候,在终端中输入:
21 |
22 | {% copy width:max . podspec.sh %}
23 |
24 | 就会自动开始执行发布流程。
25 |
26 | ## 发布流程
27 |
28 | - 如果目录下有一个 podspec 文件,直接询问版本号,然后打包验证、询问是否发布。
29 | - 如果目录下有多个 podspec 文件,遍历每一个 podspec 文件,询问版本号,然后打包验证、询问是否发布。
30 |
31 | ## 脚本运行权限
32 |
33 | 如果提示没有权限,就输入以下命令修改 `podspec.sh` 的权限
34 |
35 | {% copy width:max chmod 777 podspec.sh %}
36 |
--------------------------------------------------------------------------------
/source/notes/flutter/index.md:
--------------------------------------------------------------------------------
1 | ---
2 | robots: noindex,nofollow
3 | sitemap: false
4 | menu_id: notes
5 | layout: wiki
6 | wiki: Notes
7 | title: Flutter 相关问题
8 | order: 250
9 | references:
10 | - title: 'flutter.cn'
11 | url: https://flutter.cn/
12 | - title: 'flutter.dev'
13 | url: https://flutter.dev/docs
14 | - title: 'flutterchina.club'
15 | url: https://flutterchina.club/docs/
16 | - title: 'alibaba/fish-redux'
17 | url: https://github.com/alibaba/fish-redux/blob/master/doc/README-cn.md
18 | ---
19 |
20 | 运行时弹出「无法打开“iproxy”,因为无法验证开发者。」弹窗,手动添加信任:
21 |
22 | ```
23 | sudo xattr -r -d com.apple.quarantine futter的SDK目录/bin/cache/artifacts/usbmuxd/iproxy
24 | ```
25 |
26 | 清除缓存,重新 build:
27 |
28 | ```
29 | rm -rf build
30 | flutter clean
31 | flutter build ios --debug
32 | ```
33 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/plugins/comments/artalk/layout.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | function layoutDiv() {
3 | var el = '';
4 | el += '';
15 | return el;
16 | }
17 | %>
18 |
19 | <%- layoutDiv() %>
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/plugins/comments/twikoo/layout.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | function layoutDiv() {
3 | var el = '';
4 | el += '';
15 | return el;
16 | }
17 | %>
18 |
19 | <%- layoutDiv() %>
--------------------------------------------------------------------------------
/themes/stellar/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "hexo-theme-stellar",
3 | "version": "1.19.0",
4 | "description": "Elegant and powerful theme for Hexo.",
5 | "main": "package.json",
6 | "scripts": {
7 | "test": "echo test"
8 | },
9 | "repository": {
10 | "type": "git",
11 | "url": "https://github.com/xaoxuu/hexo-theme-stellar.git"
12 | },
13 | "keywords": [
14 | "hexo",
15 | "theme",
16 | "stellar"
17 | ],
18 | "author": "[@xaoxuu](https://github.com/xaoxuu/)",
19 | "license": "MIT",
20 | "bugs": {
21 | "url": "https://github.com/xaoxuu/hexo-theme-stellar/issues/"
22 | },
23 | "dependencies": {
24 | "hexo-renderer-ejs": "^2.0.0",
25 | "hexo-renderer-stylus": "^2.1.0"
26 | },
27 | "homepage": "https://xaoxuu.com/wiki/stellar/",
28 | "devDependencies": {
29 | }
30 | }
31 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/plugins/comments/waline/layout.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | function layoutDiv() {
3 | var el = '';
4 | el += '';
15 | return el;
16 | }
17 | %>
18 |
19 | <%- layoutDiv() %>
20 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_common/loading.styl:
--------------------------------------------------------------------------------
1 | svg.loading
2 | display: block
3 | position: absolute
4 | color: var(--text-p3)
5 | z-index: -1
6 | width: 100%
7 | height: 2rem
8 | margin: auto
9 | animation: spin infinite 2s
10 | animation-timing-function: linear
11 | @keyframes spin
12 | from
13 | transform:rotate(0deg)
14 | to
15 | transform:rotate(360deg)
16 |
17 | .loading-wrap
18 | margin: 0
19 | text-align: center
20 | background: var(--block)
21 | border-radius: $border-card
22 | position relative
23 | padding: 2rem
24 | svg
25 | margin: 4px
26 | &:after
27 | content: hexo-config('style.loading.loading')
28 | color: var(--text-p1)
29 | display: block
30 | font-size: 14px
31 | &.error
32 | &:after
33 | content: hexo-config('style.loading.error')
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/plugins/comments/twikoo/script.ejs:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/themes/stellar/layout/categories.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | page.robots = 'noindex,follow';
3 | if (page.menu_id == undefined) {
4 | page.menu_id = 'post';
5 | }
6 | %>
7 | <% if (site.categories.length) { %>
8 | <% page.title = __('btn.categories'); %>
9 | <% page.layout = 'categories'; %>
10 | <%- partial('_partial/main/navbar/list_post') %>
11 |
12 |
13 | <% site.categories.sort('path').each(function(category){ %>
14 |
20 | <% }) %>
21 |
22 |
23 | <% } %>
24 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_common/title.styl:
--------------------------------------------------------------------------------
1 | h1,.h1
2 | font-size: $fs-h1
3 | font-weight: 700
4 | @media screen and (max-width: $device-mobile)
5 | font-size: $fs-h1
6 | h2,.h2
7 | font-size: $fs-h2
8 | h3,.h3
9 | font-size: $fs-h3
10 | h4,.h4
11 | font-size: $fs-h4
12 | h5
13 | font-size: $fs-h5
14 | h6
15 | font-size: $fs-h6
16 |
17 | // 次级段落字号
18 | .fs14
19 | font-size: $fs-14
20 | p
21 | font-size: $fs-14 !important
22 | li
23 | font-size: $fs-14 !important
24 | // 脚标字号
25 | .fs12
26 | font-size: $fs-12
27 |
28 | .widgets
29 | .post-title
30 | margin: 0.75rem 0
31 | line-height: 1.2
32 | display: block
33 | txt-ellipsis()
34 | .cap
35 | margin-bottom: 2px
36 | opacity: 0.5
37 | a
38 | color: inherit
39 | font-weight: 500
40 | &:hover
41 | color: $color-hover
42 |
--------------------------------------------------------------------------------
/themes/stellar/.github/workflows/npm-publish.yml:
--------------------------------------------------------------------------------
1 | name: npm-publish
2 |
3 | on:
4 | push:
5 | branches:
6 | - npm
7 |
8 | jobs:
9 | npm-publish:
10 | name: npm-publish
11 | runs-on: ubuntu-latest
12 | steps:
13 | - name: Checkout repository
14 | uses: actions/checkout@v3
15 | - name: Publish if version has been updated
16 | uses: pascalgn/npm-publish-action@1.3.9
17 | with: # All of theses inputs are optional
18 | tag_name: "%s"
19 | tag_message: "%s"
20 | commit_pattern: "^release\\:\ (.*)"
21 | workspace: "."
22 | env: # More info about the environment variables in the README
23 | GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} # Leave this as is, it's automatically generated
24 | NPM_AUTH_TOKEN: ${{ secrets.NPM_AUTH_TOKEN }} # You need to set this in your repo settings
25 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/widgets/timeline.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | function layoutDiv() {
3 | var el = '';
4 | if (item.api == undefined) {
5 | return el;
6 | }
7 | el += '';
8 | if (item.title) {
9 | el += '';
12 | }
13 | el += '';
14 | el += '
{
16 | if (item[key]) {
17 | el += ' ' + key + '="' + item[key] + '"';
18 | }
19 | });
20 | el += '>';
21 | el += '
';
22 | el += '
';
23 | el += '';
24 | return el;
25 | }
26 | %>
27 | <%- layoutDiv() %>
28 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/filters/lib/img_onerror.js:
--------------------------------------------------------------------------------
1 | /**
2 | * img_onerror.js v1 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | * 发现这个和 img_lazyload 有点冲突,会被 img_lazyload 覆盖
4 | */
5 |
6 | 'use strict';
7 |
8 | const fs = require('hexo-fs');
9 |
10 | module.exports.processSite = function(htmlContent) {
11 | const default_image = this.theme.config.default.image;
12 | return htmlContent.replace(/
/gi, function(imgTag) {
13 | if (/="data:image(.*?)/gi.test(imgTag)) {
14 | return imgTag;
15 | }
16 | if (/onerror/gi.test(imgTag)) {
17 | return imgTag;
18 | }
19 | if (imgTag.includes(' no-lazy ') == false) {
20 | return imgTag;
21 | }
22 | return imgTag.slice(0,imgTag.length-1) + ' onerror="javascript:this.classList.add(\'error\');this.src=\'' + default_image + '\';"' + imgTag.slice(imgTag.length-1);
23 | });
24 | };
25 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/plugins/comments/giscus/layout.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | function layoutDiv() {
3 | var el = '';
4 | const cmt = page.cmt;
5 | if (cmt && cmt.service && (cmt.service.length > 0)) {
6 | const name = cmt.service;
7 | const body = cmt[name];
8 | el += '';
15 | }
16 | return el;
17 | }
18 | %>
19 |
20 |
21 |
22 | <%- layoutDiv() %>
23 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/plugins/comments/beaudar/layout.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | function layoutDiv() {
3 | var el = '';
4 | const cmt = page.cmt;
5 | if (cmt && cmt.service && (cmt.service.length > 0)) {
6 | const name = cmt.service;
7 | const body = cmt[name];
8 | el += '';
15 | }
16 | return el;
17 | }
18 | %>
19 |
20 |
21 |
22 | <%- layoutDiv() %>
23 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/plugins/comments/utterances/layout.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | function layoutDiv() {
3 | var el = '';
4 | const cmt = page.cmt;
5 | if (cmt && cmt.service && (cmt.service.length > 0)) {
6 | const name = cmt.service;
7 | const body = cmt[name];
8 | el += '';
15 | }
16 | return el;
17 | }
18 | %>
19 |
20 |
21 |
22 | <%- layoutDiv() %>
23 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/plugins/comments/giscus/script.ejs:
--------------------------------------------------------------------------------
1 |
27 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/main/post_list/wiki_card.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | function layoutDiv() {
3 | var el = '';
4 | el += '';
5 | if (proj.logo && proj.logo.src) {
6 | el += '';
7 | el += '

';
12 | el += '
';
13 | }
14 | el += '';
15 | if (proj.tags && proj.tags.length > 0) {
16 | let tag = proj.tags[0];
17 | el += '
' + tag + '
';
18 | }
19 | el += '
' + (proj.title || proj.name) + '
';
20 | if (proj.description) {
21 | el += '
' + proj.description + '
';
22 | }
23 | el += '
';
24 | el += '';
25 | return el;
26 | }
27 | %>
28 | <%- layoutDiv() %>
29 |
--------------------------------------------------------------------------------
/source/wiki/nexus/index.md:
--------------------------------------------------------------------------------
1 | ---
2 | layout: wiki
3 | wiki: NEXUS
4 | title: NEXUS
5 | ---
6 |
7 |
8 | 点击屏幕左上角,即可呼出搜索栏,此搜索栏对于一些常用的网站如[优酷]、[淘宝]等等可以直达官网,省去了搜索引擎检索的步骤。左上角热键是透明的,不影响视觉,只有在允许后台运行时才会生效。
9 |
10 | {% image https://fastly.jsdelivr.net/gh/cdn-x/wiki@1.0.2/nexus/IMG_0355.PNG %}
11 |
12 | {% swiper %}
13 | 
14 | 
15 | 
16 | 
17 | {% endswiper %}
18 |
19 |
20 |
21 |
22 | ## 适用平台
23 |
24 | Windows 7~10
25 |
26 | ## 下载
27 |
28 | {% link https://github.com/xaoxuu/NEXUS-Windows/releases/ 核心程序 %}
29 | {% link https://github.com/xaoxuu/NEXUS-Windows/releases/ 核心程序 %}
30 |
31 | ## 已归档
32 |
33 | 这是一个已经归档的项目,最后一次更新时间是在2017年1月。
34 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/partial/footer.styl:
--------------------------------------------------------------------------------
1 | .page-footer
2 | margin: 4rem 1rem 3rem
3 | color: var(--text-p3)
4 | a
5 | color: var(--text-p3)
6 | &:hover
7 | color: $color-hover
8 |
9 | .page-footer .sitemap
10 | margin: .5rem 0 2rem
11 | display: grid
12 | scrollbar-width: none
13 | grid-gap: 1rem 1rem
14 | grid-auto-flow: column dense
15 | overflow: scroll
16 | scrollbar(0, 0)
17 |
18 |
19 | .page-footer .sitemap .sitemap-group
20 | display: flex
21 | flex-direction: column
22 | align-items: flex-start
23 | >span,>a
24 | text-decoration: none
25 | txt-ellipsis()
26 | >span
27 | margin: .5rem 0
28 | font-weight: 500
29 | color: var(--text-p1)
30 | >a
31 | margin: .2rem 0
32 |
33 |
34 | .page-footer .text
35 | p
36 | margin: 4px 0
37 | line-height: 1.5
38 | a:not([class])
39 | text-decoration: underline
40 | font-weight: 500
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/plugins/comments/beaudar/script.ejs:
--------------------------------------------------------------------------------
1 |
27 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_plugins/lazyload.styl:
--------------------------------------------------------------------------------
1 | trans-cover($p, $t = 0.28s)
2 | trans2pro: transform 0.5s $p $t
3 | trans-site($p)
4 | trans2: box-shadow transform $p
5 | trans-user($p)
6 | trans3: box-shadow transform $p
7 |
8 | if hexo-config('plugins.lazyload.transition') == 'blur'
9 | img.lazy
10 | trans-cover filter
11 | &:not(.loaded)
12 | filter blur(8px)
13 | -webkit-filter blur(8px)
14 | &.loaded,&.error
15 | filter none
16 | -webkit-filter none
17 | .group-body .site-card .card-link>img
18 | trans-site filter
19 | .group-body .user-card .card-link>img
20 | trans-user filter
21 | else
22 | img.lazy
23 | trans-cover opacity 0.5s
24 | &:not(.loaded)
25 | opacity: 0
26 | &.loaded,&.error
27 | opacity: 1
28 | .group-body .site-card .card-link>img
29 | trans-site opacity
30 | .group-body .user-card .card-link>img
31 | trans-user opacity
32 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/plugins/comments/utterances/script.ejs:
--------------------------------------------------------------------------------
1 |
27 |
--------------------------------------------------------------------------------
/themes/stellar/layout/mermaid.ejs:
--------------------------------------------------------------------------------
1 | <% if (theme.plugins.mermaid.enable) { %>
2 |
3 |
4 |
32 | <% } %>
33 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_plugins/index.styl:
--------------------------------------------------------------------------------
1 | @import 'aplayer'
2 |
3 | // 根据主题配置加载
4 | if hexo-config('plugins.lazyload.enable')
5 | @import 'lazyload'
6 | if hexo-config('plugins.swiper.enable')
7 | @import 'swiper'
8 | if hexo-config('plugins.scrollreveal.enable')
9 | @import 'scrollreveal'
10 | if hexo-config('plugins.fancybox.enable')
11 | @import 'fancybox'
12 | if hexo-config('plugins.mermaid.enable')
13 | @import 'mermaid'
14 | if hexo-config('plugins.copycode.enable')
15 | @import 'copycode'
16 |
17 |
18 | // 评论
19 | if hexo-config('comments.service') == 'beaudar'
20 | @import 'comments/beaudar'
21 | if hexo-config('comments.service') == 'twikoo'
22 | @import 'comments/twikoo'
23 | if hexo-config('comments.service') == 'utterances'
24 | @import 'comments/utterances'
25 | if hexo-config('comments.service') == 'waline'
26 | @import 'comments/waline'
27 | if hexo-config('comments.service') == 'artalk'
28 | @import 'comments/artalk'
29 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "hexo-site",
3 | "version": "0.0.0",
4 | "private": true,
5 | "scripts": {
6 | "c": "hexo clean",
7 | "s": "hexo clean && hexo server",
8 | "g": "hexo clean && hexo generate",
9 | "d": "hexo deploy"
10 | },
11 | "hexo": {
12 | "version": "6.3.0"
13 | },
14 | "dependencies": {
15 | "hexo": "^6.3.0",
16 | "hexo-all-minifier": "^0.5.7",
17 | "hexo-autonofollow": "^1.0.1",
18 | "hexo-deployer-git": "^4.0.0",
19 | "hexo-generator-archive": "^2.0.0",
20 | "hexo-generator-category": "^2.0.0",
21 | "hexo-generator-feed": "^3.0.0",
22 | "hexo-generator-index": "^3.0.0",
23 | "hexo-generator-seo-friendly-sitemap": "^0.2.1",
24 | "hexo-generator-tag": "^2.0.0",
25 | "hexo-related-popular-posts": "^5.0.1",
26 | "hexo-renderer-ejs": "^2.0.0",
27 | "hexo-renderer-marked": "^6.0.0",
28 | "hexo-renderer-stylus": "^3.0.0",
29 | "hexo-server": "^3.0.0"
30 | }
31 | }
32 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/tags/lib/folding.js:
--------------------------------------------------------------------------------
1 | /**
2 | * folding.js v1 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | * 格式与官方标签插件一致使用空格分隔,中括号内的是可选参数(中括号不需要写出来)
4 | *
5 | * {% folding [color:yellow] [child:codeblock] [open:false] title %}
6 | * body
7 | * {% endfolding %}
8 | */
9 |
10 | 'use strict'
11 |
12 | module.exports = ctx => function(args, content) {
13 | args = ctx.args.map(args, ['color', 'child', 'open'], ['title'])
14 | var el = ''
15 | // header
16 | el += ''
22 | // summary
23 | el += '' + (args.title || '') + '
'
24 | // content
25 | el += ''
26 | el += ctx.render.renderSync({text: content, engine: 'markdown'}).split('\n').join('')
27 | el += '
'
28 |
29 | return el
30 | }
31 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/tag-plugins/copy.styl:
--------------------------------------------------------------------------------
1 | .md-text .tag-plugin.copy
2 | display: flex
3 | justify-content: space-between
4 | box-sizing: border-box
5 | background: var(--block)
6 | border-radius: $border-bar
7 | border: 1px solid var(--block-border)
8 | overflow: hidden
9 | width: 320px
10 | max-width: 100%
11 | &[width='max']
12 | width: 100%
13 | @media screen and (max-width: $device-mobile-425)
14 | min-width: 100%
15 |
16 | input.copy-area
17 | display: inline-block
18 | padding: 0
19 | width: 100%
20 | color: var(--text-p2)
21 | line-height: 3
22 | text-indent: 1rem
23 | button.copy-btn
24 | margin: 0
25 | line-height: 3
26 | border-left: 1px solid var(--block-border)
27 | display: inline-block
28 | background: var(--block-hover)
29 | line-height: 0
30 | font-size: 1rem
31 | padding: 0 .75rem
32 | color: var(--text-p2)
33 | &:hover
34 | background: var(--card)
35 |
--------------------------------------------------------------------------------
/themes/stellar/README.md:
--------------------------------------------------------------------------------
1 | # Stellar - 每个人的独立博客
2 |
3 | Stellar 是一个内置文档系统的简约商务风 Hexo 主题,支持丰富的标签和动态数据组件,请配合 [文档](https://xaoxuu.com/wiki/stellar/) 使用。
4 |
5 | [](https://starchart.cc/xaoxuu/hexo-theme-stellar)
6 |
7 |
8 | ## Getting Started
9 |
10 | Check your environment:
11 |
12 | ```yaml
13 | Hexo: 5.4.0 ~ 6.3.0
14 | hexo-cli: 4.3.0 ~ latest
15 | node.js: 14.17.3 ~ 18.12.0
16 | npm: 6.14.13 ~ 8.19.2
17 | ```
18 |
19 | Edit your `_config.yml`:
20 |
21 | ```yaml
22 | theme: stellar
23 | ```
24 |
25 | Install Stellar in terminal:
26 |
27 | ```bash
28 | npm i hexo-theme-stellar
29 | ```
30 |
31 | ## Usage
32 |
33 | See docs: https://xaoxuu.com/wiki/stellar/
34 |
35 | ## Examples
36 |
37 | https://xaoxuu.com/wiki/stellar/examples/
38 |
39 | ## Feedback
40 |
41 | Issues: https://github.com/xaoxuu/hexo-theme-stellar/issues/
42 |
43 | Discussions: https://github.com/xaoxuu/hexo-theme-stellar/discussions/
44 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/tags/lib/checkbox.js:
--------------------------------------------------------------------------------
1 | /**
2 | * checkbox.js v1 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | * radio.js v1 | https://github.com/xaoxuu/hexo-theme-stellar/
4 | * 格式与官方标签插件一致使用空格分隔,中括号内的是可选参数(中括号不需要写出来)
5 | *
6 | * {% checkbox [checked:false] [color:cyan] [symbol:plus/minus/times] text %}
7 | * {% radio [checked:false] [color:cyan] text %}
8 | */
9 |
10 | 'use strict'
11 |
12 | module.exports = (ctx, type) => function(args) {
13 | args = ctx.args.map(args, ['color', 'checked', 'symbol'], ['text'])
14 | var el = ''
15 | // div
16 | el += ''
19 | // input
20 | el += ''
25 | // text
26 | el += '' + args.text + ''
27 | // div
28 | el += '
'
29 | return el
30 | }
31 |
--------------------------------------------------------------------------------
/source/_posts/blog/2016-02-11-smart-life.md:
--------------------------------------------------------------------------------
1 | ---
2 | date: 2016-02-11
3 | updated: 2016-09-20
4 | title: 我关于未来的智能生活的畅想
5 | categories: [闲聊时间]
6 | comment_title: 你想象中的未来生活是什么样子呢?
7 | indent: true
8 | ---
9 |
10 | 我从小就对「活着」的机械十分着迷,就是我们现在所说的人工智能,当我初次了解到这个概念的时候,~就确定了我将奉献一生的事业~。
11 |
12 | 然而梦想很遥远,遥远到我这辈子无法见证 [《I, Robot》](https://baike.baidu.com/item/%E6%88%91%EF%BC%8C%E6%9C%BA%E5%99%A8%E4%BA%BA/1189079) 那样的时代。
13 |
14 |
15 |
16 |
17 | ## 智能家居
18 |
19 | 我相信,不久的未来会有越来越多的东西要接入互联网,接入互联网就可以用手机控制。
20 | 网络就像神经,门窗联了网,门窗就活了,扫把联了网,扫把就活了。等所有的家具家电都联网的时候,就需要一个平台来管理这些智能硬件了。
21 |
22 | 所有接入互联网的传感器都成为了这个智能系统的感官,神经将这些信息传递到可以分析、处理数据的终端,经过计算后作出应答,并由这些神经传递指令到相应的智能设备上。
23 |
24 | 人与人、人与物之间的联系就更加紧密了,随时的远程互动,远程协助都更加方便了。
25 | 当然,这中间涉及到的隐私和网络安全问题也十分重要,但问题总要解决,不能因噎废食。
26 |
27 | 传统硬件,将一步一步被替换为智能硬件,至少是能用手机 app 控制,用手机 app 来控制,就是一种雏形了。毕竟目前没有足够多的智能硬件,没有到需要开发一个系统的程度。
28 |
29 |
30 | ## 平台化
31 |
32 | 现在智能硬件也越来越多了,网络也十分发达了,但是它们的「语言」不同,各厂商的产品都用自己的标准,不同厂商之间的硬件是无法协同工作的。它们需要一个协议、或者一个平台,来实现合作。平台,也许就是智能家居时代来临的一个必要条件吧。
33 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/helpers/parse_config.js:
--------------------------------------------------------------------------------
1 | /**
2 | * md_link(theme.sidebar.menu['home']) is '/'
3 | * md_text(theme.sidebar.menu['home']) is 'Home'
4 | */
5 |
6 | 'use strict';
7 |
8 | hexo.extend.helper.register('md_text', function(args) {
9 | if (args == undefined) {
10 | return '';
11 | }
12 | let tmp = args.split('](');
13 | if (tmp.length > 1) {
14 | tmp = tmp[0];
15 | if (tmp.length > 1) {
16 | tmp = tmp.substring(1, tmp.length);
17 | }
18 | }
19 | if (tmp == 'config.title') {
20 | tmp = hexo.config.title;
21 | } else if (tmp == 'config.avatar') {
22 | tmp = hexo.config.avatar;
23 | }
24 | return tmp;
25 | });
26 |
27 | hexo.extend.helper.register('md_link', function(args) {
28 | if (args == undefined) {
29 | return '';
30 | }
31 | let tmp = args.split('](');
32 | if (tmp.length > 1) {
33 | tmp = tmp[1];
34 | if (tmp.length > 1) {
35 | tmp = tmp.substring(0, tmp.length-1);
36 | }
37 | }
38 | return tmp;
39 | });
40 |
--------------------------------------------------------------------------------
/source/wiki/git/index.md:
--------------------------------------------------------------------------------
1 | ---
2 | layout: wiki
3 | wiki: Git
4 | title: 认识 Git
5 | references:
6 | - title: RUNOOB:Git 教程
7 | url: https://www.runoob.com/git/git-tutorial.html
8 | - title: 廖雪峰的官方网站:Git 教程
9 | url: https://www.liaoxuefeng.com/
10 | ---
11 |
12 |
13 |
14 | ## 什么是 Git ?
15 |
16 | Git 是目前世界上最先进的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。
17 |
18 | ### Git 与 SVN 区别点
19 |
20 | 1. Git 是分布式的,SVN 不是。这是 Git 和其它非分布式的版本控制系统如 SVN,CVS 等最核心的区别。
21 | 2. Git 把内容按元数据方式存储,而 SVN 是按文件。
22 | 3. Git 分支和 SVN 的分支不同:分支在 SVN 中一点都不特别,其实它就是版本库中的另外一个目录。
23 | 4. Git 没有一个全局的版本号,而 SVN 有。目前为止这是跟 SVN 相比 Git 缺少的最大的一个特征。
24 | 5. Git 的内容完整性要优于 SVN。Git 的内容存储使用的是 SHA-1 哈希算法。这能确保代码内容的完整性,确保在遇到磁盘故障和网络问题时降低对版本库的破坏。
25 |
26 | {% image https://fastly.jsdelivr.net/gh/cdn-x/wiki@1.0.2/git/svn-git.jpg width:400px 图片来源于 RUNOOB %}
27 |
28 | ## Git 工作区、暂存区和版本库
29 |
30 | - 工作区:就是你在电脑里能看到的目录。
31 | - 暂存区:英文叫stage, 或index。一般存放在 ".git目录下" 下的index文件(.git/index)中,所以我们把暂存区有时也叫作索引(index)。
32 | - 版本库:工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。
33 |
--------------------------------------------------------------------------------
/themes/stellar/layout/page.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | function layoutTitle() {
3 | const title = page.h1 || page.title;
4 | if (title && title.length > 0) {
5 | return '' + title + '
';
6 | } else {
7 | return '';
8 | }
9 | }
10 | function layoutDiv() {
11 | var el = '';
12 | if (page.post_list) {
13 | el += partial('_partial/main/navbar/list_post');
14 | }
15 | if (page.mermaid == true) {
16 | el += partial('mermaid');
17 | }
18 | if (page.h1 || page.title || (page.content && page.content.length > 0)) {
19 | el += partial('_partial/main/navbar/breadcrumb');
20 | }
21 | el += '';
22 | el += layoutTitle();
23 | if (page.content && page.content.length > 0) {
24 | el += page.content;
25 | }
26 | el += '';
27 | el += partial('_partial/plugins/comments/layout');
28 | return el;
29 | }
30 | %>
31 |
32 | <%- layoutDiv() %>
33 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/widgets/ghrepo.styl:
--------------------------------------------------------------------------------
1 | .widget-wrapper.ghrepo
2 | .repo
3 | display: block
4 | padding: 0.75rem 0.5rem
5 | color: var(--text-p2)
6 | background: var(--card)
7 | border-radius: $border-block
8 | box-shadow: $boxshadow-card
9 | trans2 box-shadow transform
10 | >div+div
11 | margin-top: 0.5rem
12 | span
13 | color: var(--text-p2)
14 | &:hover
15 | box-shadow: $boxshadow-card-float
16 | transform: translateY(-1px)
17 | svg
18 | margin-right: 4px
19 | .flex-row
20 | display: flex
21 | align-items: center
22 | .repo-name
23 | font-size: $fs-14
24 | font-weight: 700
25 | color: var(--text-p1)
26 | .repo-desc
27 | font-size: $fs-13
28 | margin-left: 2px
29 | margin-right: 2px
30 | .grid
31 | font-size: $fs-13
32 | display: grid
33 | grid-gap: 2px
34 | grid-template-columns: repeat(auto-fill, "calc((100% - 2 * %s) / 3)" % 2px)
35 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/main/navbar/list_wiki.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | function layoutDiv() {
3 | var el = '';
4 | el += '';
28 | return el;
29 | }
30 | %>
31 |
32 | <%- layoutDiv() %>
33 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/tag-plugins/toc.styl:
--------------------------------------------------------------------------------
1 | details.toc
2 | background: var(--block)
3 | border: 1px solid var(--block-border)
4 | border-radius: $border-bar
5 | overflow: hidden
6 | color: var(--text-p2)
7 | summary
8 | cursor: pointer
9 | padding: 0 .5rem
10 | line-height: 2
11 | color: var(--text-p2)
12 | font-size: $fs-13
13 | font-weight: 500
14 | &:hover
15 | background: var(--block-hover)
16 |
17 | >div.body
18 | margin: var(--gap-p) 1rem 1rem
19 |
20 | details.toc[open] >summary
21 | border-bottom: 1px solid transparent
22 | &:hover
23 | border-bottom-color: var(--block-border)
24 |
25 | details.toc[open] >div.body
26 | section+section
27 | margin-top: 1rem
28 | section
29 | .header
30 | line-height: 2
31 | font-weight: 500
32 | .header+.doc_tree
33 | margin-top: 0
34 |
35 |
36 | @media screen and (max-width: $device-mobile-max)
37 | .tag-plugin.toc[display=mobile]
38 | display: block !important
39 |
--------------------------------------------------------------------------------
/themes/stellar/layout/mathjax.ejs:
--------------------------------------------------------------------------------
1 | <% if (theme.plugins.mathjax.enable){ %>
2 |
10 |
11 |
18 |
19 |
27 |
28 |
29 | <% } %>
30 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/layout.styl:
--------------------------------------------------------------------------------
1 | .l_body
2 | display: flex
3 | margin: auto
4 | padding: 0 var(--gap-l)
5 | justify-content: center
6 |
7 | .l_body .l_left
8 | z-index: 8
9 | width: var(--width-left)
10 | flex-shrink: 0
11 | position: sticky
12 | position: -webkit-sticky
13 | top: 0
14 |
15 | .l_body .l_main
16 | flex-shrink: 1
17 | flex-grow: 1
18 | width: 320px
19 | max-width: var(--width-main)
20 |
21 |
22 | // 手机布局
23 | @media screen and (max-width: $device-mobile-max)
24 | .mobile-only
25 | display: block !important
26 | .l_body
27 | padding: 0
28 | .l_left
29 | position: fixed
30 | transform: translateX(-320px)
31 | margin: 0
32 | left: 0
33 | background: var(--site-bg)
34 | box-shadow: $boxshadow-card-float
35 | z-index: 9
36 | .l_main
37 | max-width: 100%
38 | .l_body.mobile
39 | .l_left
40 | transition: transform .3s ease-out
41 | .l_body.mobile.sidebar
42 | .l_left
43 | transform: translateX(0px)
44 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/generators/wiki.js:
--------------------------------------------------------------------------------
1 | /**
2 | * wiki v1 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | */
4 |
5 | hexo.extend.generator.register('wiki', function (locals) {
6 | var hasWiki = false;
7 | locals.pages.forEach((page, i) => {
8 | if (page.layout == 'wiki') {
9 | hasWiki = true;
10 | }
11 | });
12 | if (hasWiki) {
13 | var ret = [];
14 | ret.push({
15 | path: (hexo.config.wiki_dir || 'wiki') + '/index.html',
16 | data: {'filter': false},
17 | layout: ['wiki']
18 | });
19 | if (hexo.theme.config.wiki && hexo.theme.config.wiki.all_tags) {
20 | for (let id of Object.keys(hexo.theme.config.wiki.all_tags)) {
21 | let tag = hexo.theme.config.wiki.all_tags[id];
22 | ret.push({
23 | path: tag.path,
24 | data: {
25 | 'filter': true,
26 | 'tagName': tag.name
27 | },
28 | layout: ['wiki']
29 | });
30 | }
31 | }
32 | return ret;
33 | } else {
34 | return {};
35 | }
36 | });
37 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/tags/lib/tag.js:
--------------------------------------------------------------------------------
1 | /**
2 | * tag.js v1.0 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | * 格式与官方标签插件一致使用空格分隔,中括号内的是可选参数(中括号不需要写出来)
4 | *
5 | * {% tag text href [color:color] %}
6 | *
7 | */
8 |
9 | 'use strict'
10 |
11 | const tag_colors = ['red', 'orange', 'yellow', 'green', 'cyan', 'blue', 'purple']
12 | var tag_index = 0
13 |
14 | module.exports = ctx => function(args) {
15 | args = ctx.args.map(args, ['color'], ['text', 'href'])
16 | if (args.color == null) {
17 | const default_color = ctx.theme.config.tag_plugins.tag?.default_color
18 | if (default_color) {
19 | args.color = default_color
20 | } else {
21 | args.color = tag_colors[tag_index]
22 | tag_index += 1
23 | if (tag_index >= tag_colors.length) {
24 | tag_index = 0
25 | }
26 | }
27 | }
28 | var el = ''
29 | el += ''
32 | el += args.text
33 | el += ''
34 | return el
35 | }
36 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/tag-plugins/inline-labels.styl:
--------------------------------------------------------------------------------
1 | .md-text
2 | u
3 | text-decoration: none
4 | border-bottom: 2px solid $color-hover
5 | emp
6 | width: fit-content
7 | text-decoration: none
8 | border-bottom: 4px dotted $color-hover
9 | wavy
10 | text-decoration: underline wavy $color-hover
11 | del
12 | color: var(--text-p3)
13 | text-decoration: line-through var(--text-p3)
14 | kbd
15 | border-radius: 4px
16 | border: 1px solid #d2d2d2
17 | border-bottom-width: 2px
18 | background: var(--card)
19 | padding: 2px 4px 1px 4px
20 | font-family: $ff-code
21 | font-weight: 700
22 | psw
23 | color: transparent
24 | background: #a1a1a1
25 | border-radius: 2px
26 | trans1 background
27 | margin: auto 2px
28 | &:hover
29 | color: inherit
30 | background: none
31 | sup,sub
32 | color: var(--theme)
33 | line-height: 1
34 | font-weight: 700
35 | font-family: $ff-code
36 | h1,h2,h3,h4
37 | sup,sub
38 | font-size: .85rem
39 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/tags/lib/ablock.js:
--------------------------------------------------------------------------------
1 | /**
2 | * ablock.js v1.0 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | * 格式与官方标签插件一致使用空格分隔,中括号内的是可选参数(中括号不需要写出来)
4 | *
5 | * {% ablock [color:color] [child:codeblock/tabs] title %}
6 | * body
7 | * {% endablock %}
8 | */
9 |
10 | 'use strict';
11 |
12 | module.exports = ctx => function(args, content) {
13 | args = ctx.args.map(args, ['color', 'child'], ['title'])
14 | const { title } = args
15 | if (args.color == null) {
16 | args.color = ctx.theme.config.tag_plugins.note.default_color
17 | }
18 | var el = ''
19 | // header
20 | el += ''
23 | // title
24 | if (title && title.length > 0) {
25 | el += '
' + title + '
'
26 | }
27 | // content
28 | el += '
'
29 | el += ctx.render.renderSync({text: content, engine: 'markdown'}).split('\n').join('')
30 | el += '
'
31 |
32 | return el
33 | }
34 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/plugins/comments/artalk/script.ejs:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/themes/stellar/languages/zh-TW.yml:
--------------------------------------------------------------------------------
1 | btn:
2 | home: 首頁
3 | blog: 網誌
4 | wiki: Wiki
5 | recent_publish: 近期發布
6 | all_wiki: 所有 Wiki
7 | category: 分類
8 | categories: 分類
9 | tag: 標籤
10 | tags: 標籤
11 | archives: 封存
12 | getting_started: 開始使用
13 |
14 | meta:
15 | recent_update: 最近更新
16 | toc: 本文目錄
17 | read_next: 接下來閱讀
18 | prev: 回顧上一篇
19 | next: 接下來閱讀
20 | older: 較早文章
21 | newer: 較新文章
22 | references: 參考資料
23 | related_posts: 您可能感興趣的文章
24 | comment_title: 參與討論
25 | back_to_top: 回到頁首
26 | more: '更多%s'
27 | created: 發布於
28 | updated: 更新於
29 | license: 授權條款
30 | share: 分享文章
31 | date_suffix:
32 | just: 剛剛
33 | min: 分鐘前
34 | hour: 小時前
35 | day: 天前
36 | month: 個月前
37 |
38 | page:
39 | error:
40 | what: 抱歉,找不到您存取的頁面
41 | why: 可能是網址有誤或已經刪除
42 | action: 返回首頁
43 |
44 | search:
45 | search: 站內搜索
46 | search_in: 在 %s 中搜索
47 | no_results: 沒有找到內容!
48 |
49 | message:
50 | copied: 複製成功
51 |
52 | symbol:
53 | comma: ","
54 | period: "。"
55 | colon: ":"
56 | brackets_l: "("
57 | brackets_r: ")"
58 |
--------------------------------------------------------------------------------
/themes/stellar/languages/zh-CN.yml:
--------------------------------------------------------------------------------
1 | btn:
2 | home: 主页
3 | blog: 文章
4 | wiki: 项目
5 | recent_publish: 近期发布
6 | all_wiki: 所有项目
7 | category: 分类
8 | categories: 分类
9 | tag: 标签
10 | tags: 标签
11 | archives: 归档
12 | getting_started: 开始使用
13 |
14 | meta:
15 | recent_update: 最近更新
16 | toc: 本文目录
17 | read_next: 接下来阅读
18 | prev: 回顾上一篇
19 | next: 接下来阅读
20 | older: 较早文章
21 | newer: 较新文章
22 | references: 参考资料
23 | related_posts: 您可能感兴趣的文章
24 | comment_title: 快来参与讨论吧
25 | back_to_top: 回到顶部
26 | more: '更多%s'
27 | created: 发布于
28 | updated: 更新于
29 | license: 许可协议
30 | share: 分享文章
31 | date_suffix:
32 | just: 刚刚
33 | min: 分钟前
34 | hour: 小时前
35 | day: 天前
36 | month: 个月前
37 |
38 | page:
39 | error:
40 | what: 很抱歉,您访问的页面不存在
41 | why: 可能是输入地址有误或该地址已被删除
42 | action: 返回主页
43 |
44 | search:
45 | search: 站内搜索
46 | search_in: 在 %s 中搜索
47 | no_results: 没有找到内容!
48 |
49 | message:
50 | copied: 复制成功
51 |
52 | symbol:
53 | comma: ","
54 | period: "。"
55 | colon: ":"
56 | brackets_l: "("
57 | brackets_r: ")"
58 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/tag-plugins/image.styl:
--------------------------------------------------------------------------------
1 | .tag-plugin.image
2 | margin-top: 1rem
3 | margin-bottom: 1rem
4 | .image-bg
5 | text-align: center
6 | border-radius: $border-image
7 | position: relative
8 | overflow: hidden
9 | &:hover
10 | .image-download
11 | opacity: 1 !important
12 | img
13 | display: block
14 | object-fit: cover
15 | .image-download
16 | position: absolute
17 | bottom: 8px
18 | right: 8px
19 | font-size: 1.125rem
20 | padding: 6px
21 | line-height: 0
22 | border-radius: 4px
23 | trans3: color opacity background
24 | color: var(--text-p1)
25 | &:hover
26 | background: var(--card) !important
27 | color: $color-hover
28 | .image-meta
29 | display: flex
30 | justify-content: center
31 | padding: 0.5rem 0
32 | .image-caption
33 | display: inline-block
34 | font-size: $fs-12
35 | color: var(--text-p2)
36 | line-height: 1.5
37 | text-align: justify
38 | &:empty
39 | display: none
40 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/tags/lib/note.js:
--------------------------------------------------------------------------------
1 | /**
2 | * note.js v1.1 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | * 格式与官方标签插件一致使用空格分隔,中括号内的是可选参数(中括号不需要写出来)
4 | *
5 | * {% note [color:color] [title] content %}
6 | */
7 |
8 | 'use strict'
9 |
10 | module.exports = ctx => function(args) {
11 | args = ctx.args.map(args, ['color'], ['title', 'content'])
12 | if (args.content == undefined || args.content.length <= 0) {
13 | args.content = args.title
14 | args.title = ''
15 | }
16 | const { title } = args
17 | if (args.color == null) {
18 | args.color = ctx.theme.config.tag_plugins.note.default_color
19 | }
20 | var el = ''
21 | // header
22 | el += ''
25 | // title
26 | if (title && title.length > 0) {
27 | el += '
' + title + '
'
28 | }
29 | // content
30 | el += '
'
31 | el += ctx.render.renderSync({text: args.content, engine: 'markdown'}).split('\n').join('')
32 | el += '
'
33 |
34 | return el
35 | }
36 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/tag-plugins/grid.styl:
--------------------------------------------------------------------------------
1 | .tag-plugin.grid
2 | display: grid
3 | grid-gap: 16px
4 | grid-template-columns: repeat(auto-fill, "calc((100% - 1 * %s) / 2)" % 16px)
5 | >.cell
6 | margin: 1rem 0
7 | p:first-child>strong:only-child
8 | font-size: 1rem
9 | >.cell>
10 | p
11 | line-height: 1.5
12 | :first-child
13 | margin-top: 0
14 | :last-child
15 | margin-bottom: 0
16 | p:first-child
17 | margin-top: -0.25em
18 | p:last-child
19 | margin-bottom: -0.25em
20 |
21 | .md-text .tag-plugin.grid
22 | margin-top: -0.5rem
23 | margin-bottom: -0.5rem
24 |
25 | .tag-plugin.grid
26 | @media screen and (max-width: $device-tablet)
27 | display: block
28 |
29 | .tag-plugin.grid
30 | &[bg]>.cell
31 | padding: 1rem
32 | border-radius: $border-card
33 | &[bg='block']>.cell
34 | background: var(--block)
35 | &[bg='card']>.cell
36 | background: var(--card)
37 | box-shadow: $boxshadow-card
38 | trans2 box-shadow transform
39 | &:hover
40 | transform: translateY(-1px)
41 | box-shadow: $boxshadow-card-float
--------------------------------------------------------------------------------
/LICENSE:
--------------------------------------------------------------------------------
1 | MIT License
2 |
3 | Copyright (c) 2021 xaoxuu
4 |
5 | Permission is hereby granted, free of charge, to any person obtaining a copy
6 | of this software and associated documentation files (the "Software"), to deal
7 | in the Software without restriction, including without limitation the rights
8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 | copies of the Software, and to permit persons to whom the Software is
10 | furnished to do so, subject to the following conditions:
11 |
12 | The above copyright notice and this permission notice shall be included in all
13 | copies or substantial portions of the Software.
14 |
15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21 | SOFTWARE.
22 |
--------------------------------------------------------------------------------
/source/wiki/git/git-server/index.md:
--------------------------------------------------------------------------------
1 | ---
2 | layout: wiki
3 | wiki: Git
4 | title: 搭建 Git 服务器
5 | order: 3
6 | ---
7 |
8 | 网上相关教程挺多,但是步骤略繁琐,本文将借助 Gitblit 开源工具使用最简单的方式搭建和维护 Git 服务器,支持 Linux、Windows、Mac 平台。
9 |
10 |
11 |
12 | ## 服务器搭建
13 |
14 | ### 安装 JDK
15 |
16 | 下载并安装 JDK:https://www.oracle.com/java/technologies/javase-downloads.html
17 |
18 | ### 安装并配置 Gitblit
19 |
20 | - 下载 Gitblit:https://github.com/gitblit/gitblit
21 | - 解压 Gitblit,进入目录 `~/gitblit-1.8.0/data/defaults.properties`
22 | - 用编辑器打开 `defaults.properties`
23 | ```
24 | git.repositoriesFolder = /Users/用户名/gitserver/gitRepository
25 | server.httpPort = 7070
26 | ```
27 |
28 |
29 | ### 启动服务
30 |
31 | 在终端中执行 `gitblit.sh` 脚本即可启动服务:
32 | ```bash
33 | ./gitblit.sh
34 | ```
35 |
36 | {% folding 建议设置开机自启动 %}
37 | 通过 Mac 的自动化工具,将启动指令写成脚本,系统启动后自动运行脚本即可。
38 | Windows 平台可以添加到启动计划任务中。
39 | {% endfolding %}
40 |
41 | ## 客户端访问
42 |
43 | 用服务器 IP + 端口号来访问。例如我的电脑的 IP 是 `10.8.12.200`,那么在局域网内另外一台电脑访问 `http://10.8.12.200:7070` 就可以看到管理页面了:
44 |
45 | {% image https://fastly.jsdelivr.net/gh/cdn-x/wiki@1.0.2/git/gitblit01.jpg width:500px %}
46 |
47 | 网页操作和使用 GitHub、Coding 等平台相似,非常简单。
48 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/sidebar/sidebar.styl:
--------------------------------------------------------------------------------
1 | .l_left
2 | display: flex
3 | flex-direction: column
4 | word-break: break-all
5 | text-align: justify
6 | height: 100vh
7 | .header
8 | margin: var(--gap-l) var(--gap-l) 0
9 | margin-top: "calc(2 * %s)" % var(--gap-l)
10 | @media screen and (min-width: $device-mobile-max)
11 | >.widgets:first-child>.widget-wrapper:first-child
12 | margin-top: "calc(2 * %s)" % var(--gap-l)
13 | @media screen and (max-width: $device-mobile-max)
14 | height: 100vh
15 |
16 |
17 | .l_left[layout=wiki]
18 | padding-bottom: 0
19 | height: 100vh
20 | @media screen and (max-width: $device-mobile-max)
21 | height: 100vh
22 | .widgets >:last-child
23 | margin-bottom: 6rem
24 |
25 |
26 | .l_left .widgets .widget-wrapper.logo-wrap.wiki .widget-body
27 | display: flex
28 | margin-bottom: 1.5rem
29 | flex-direction: column
30 | align-items: flex-start
31 | a.wiki-home
32 | margin-bottom: 0.5rem
33 | color: var(--text-p1)
34 | svg
35 | margin-right: 2px
36 | &:hover
37 | color: $color-hover
38 | filter: unset !important
39 |
40 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/tags/lib/emoji.js:
--------------------------------------------------------------------------------
1 | /**
2 | * emoji.js v1 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | * 格式与官方标签插件一致使用空格分隔,中括号内的是可选参数(中括号不需要写出来)
4 | *
5 | * {% emoji [source] name [height:1.75em] %}
6 | *
7 | */
8 |
9 | 'use strict'
10 |
11 | module.exports = ctx => function(args) {
12 | const config = ctx.theme.config.tag_plugins.emoji
13 | args = ctx.args.map(args, ['height'], ['source', 'name'])
14 | var el = ''
15 | if (args.source == undefined) {
16 | return el
17 | }
18 | el += ''
19 | if (args.name == undefined) {
20 | // 省略了 source
21 | for (let id in config) {
22 | if (config[id]) {
23 | args.name = args.source
24 | args.source = id
25 | break
26 | }
27 | }
28 | }
29 | if (config[args.source] && args.name) {
30 | let url = config[args.source].replace('${name}', args.name)
31 | el += '
'
37 | }
38 | el += ''
39 | return el
40 | }
41 |
--------------------------------------------------------------------------------
/themes/stellar/LICENSE:
--------------------------------------------------------------------------------
1 | MIT License
2 |
3 | Copyright (c) 2021 xaoxuu
4 |
5 | Permission is hereby granted, free of charge, to any person obtaining a copy
6 | of this software and associated documentation files (the "Software"), to deal
7 | in the Software without restriction, including without limitation the rights
8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 | copies of the Software, and to permit persons to whom the Software is
10 | furnished to do so, subject to the following conditions:
11 |
12 | The above copyright notice and this permission notice shall be included in all
13 | copies or substantial portions of the Software.
14 |
15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21 | SOFTWARE.
22 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_common/base.styl:
--------------------------------------------------------------------------------
1 | pre
2 | font-family: $ff-codeblock
3 | font-size: $fs-codeblock
4 | tab-size: 4
5 | -moz-tab-size: 4
6 | -o-tab-size: 4
7 | -webkit-tab-size: 4
8 |
9 | a
10 | text-decoration: none
11 | color: var(--theme-link)
12 | &:hover
13 | color: $color-hover
14 |
15 | .md-text p:not([class])
16 | text-align: convert(hexo-config('style.text-align'))
17 |
18 | hr
19 | color: var(--text-meta)
20 | opacity: .1
21 |
22 |
23 | img
24 | max-width: 100%
25 |
26 |
27 | li
28 | font-size: $fs-15
29 |
30 |
31 | ul,ol
32 | padding-left: 1.5rem
33 |
34 |
35 | // table
36 | table:not([class])
37 | border-collapse: collapse
38 | overflow: auto
39 | display: block
40 | margin: 1rem 0
41 | max-width: 100%
42 | vertical-align: text-top
43 | font-size: $fs-14
44 | th
45 | background: var(--block)
46 | td,th
47 | padding: 0.5em 1em
48 | border: 1px solid var(--block-hover)
49 | line-height: 1.5
50 | tr
51 | word-break: keep-all
52 | white-space:nowrap
53 | trans()
54 | &:hover
55 | background: var(--block)
56 |
57 | *[ff=title]
58 | font-family: $ff-logo
--------------------------------------------------------------------------------
/source/_posts/blog/2016-05-22-to-be-a-titan.md:
--------------------------------------------------------------------------------
1 | ---
2 | date: 2016-05-22
3 | updated: 2016-05-22
4 | title: 十万蝼蚁不如一个巨人
5 | categories: [胡思乱想]
6 | indent: true
7 | ---
8 |
9 | {% poetry Game of Thrones footer:台词节选 %}
10 | 混乱不是深渊。
11 | 混乱是阶梯。
12 | 很多人想往上爬 却失败了
13 | 且永无机会再试。
14 | 他们坠落而亡。
15 | 有人本有机会攀爬,
16 | 但他们拒绝了。
17 | 他们守着王国不放
18 | 守着诸神
19 | 守着爱情
20 | 尽皆幻想。
21 | 唯有阶梯是真实存在。
22 | 攀爬才是生活的全部。
23 | {% endpoetry %}
24 |
25 |
26 |
27 | ## 物竞天择
28 |
29 | 世界是残酷的,强者以弱者为食。
30 |
31 |
32 |
33 | ## 个体意识
34 |
35 | 每个人都是一个独立的个体,群众的力量再强大,他们也不属于你,只是在某些时刻能够帮到你。与其成为一个强大群体中微不足道的一员,不如成为一个强大的个体。
36 |
37 |
38 |
39 | ## 群体意识
40 |
41 | 社会不需要太多巨人,需要团结在一起才能发挥威力的蚂蚁。像牧羊一样,管好头羊,其他都会乖乖跟着头羊,即使有不听话的,也不会威胁到牧羊人。但如果羊羔中有几个或更多比牧羊人掌管的头羊更加强壮的个体,牧羊人就会地位不保。这些羊羔如果足够聪明的话,是不应该过早展露实力的,冲动的结局则是变成一桌美食。
42 |
43 |
44 |
45 | ## 珍惜当下
46 |
47 | 活着本来就是如临深渊,如履薄冰,永远不能保证下一刻不会遭遇意外。每天早上睁开眼能够看到熟悉的世界,能够记得自己走过的人生,都值得庆幸。不做别人的棋子,更不教育自己的后代如何做好这一颗棋子,生活是你自己的。
48 |
49 |
50 | ## 时间、效率、实力
51 |
52 | 我一直把时间作为衡量价值的标准,因为只有时间是有限的、平等的。效率则是将时间转化成实力的最关键一步,是靠自己的努力获得的,谁也赠予不了,谁也偷不了。实力则是我的人生观中的价值所在,也是唯一的追求。
53 |
54 |
55 | ## 选择
56 |
57 | 你可以选择随遇而安,只需要一双发现美的眼睛和积极乐观的心态。
58 |
59 | 也可以攀爬,你会发现到处都是陷阱,一步跌落,就是万丈深渊。哪怕你认为现在的处境已经跌落人生谷底,但是事实是前方依然会有更深的陷阱在等着你。
60 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_common/device.styl:
--------------------------------------------------------------------------------
1 | .mobile-only
2 | display: none
3 | @media screen and (max-width: $device-mobile-max)
4 | display: block !important
5 |
6 | .mobile-hidden
7 | @media screen and (max-width: $device-mobile-max)
8 | display: none !important
9 |
10 | .float-panel
11 | position: sticky
12 | right: 0
13 | bottom: 2rem
14 | float: right
15 | z-index: 10
16 | display: flex
17 | border-radius: 2rem
18 | margin-right: 1rem
19 | overflow: hidden
20 | --blur-px: 16px
21 | --blur-bg: alpha(#fff, .4)
22 | trans1: all
23 | if hexo-config('style.darkmode') == 'auto'
24 | @media (prefers-color-scheme: dark)
25 | --blur-bg: alpha(#000, .4)
26 | if hexo-config('style.darkmode') == 'always'
27 | --blur-bg: alpha(#000, .4)
28 |
29 | .sidebar-toggle.mobile
30 | cursor: pointer
31 | color: var(--text-p0)
32 | background: none
33 | padding: 0.5rem
34 | line-height: 0
35 | font-size: 20px
36 | margin: 0
37 |
38 |
39 | .l_body.mobile.sidebar
40 | .float-panel
41 | box-shadow: $boxshadow-float
42 | transform: translateY(-2px)
43 | .sidebar-toggle.mobile
44 | background: var(--card)
45 | color: $color-hover
46 | border-color: var(--block-border)
47 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/tags/lib/swiper.js:
--------------------------------------------------------------------------------
1 | /**
2 | * swiper.js v1 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | * 格式与官方标签插件一致使用空格分隔,中括号内的是可选参数(中括号不需要写出来)
4 | *
5 | * {% swiper [width:max] [effect:cards] %}
6 | * 
7 | * {% endswiper %}
8 | */
9 |
10 | 'use strict'
11 |
12 | module.exports = ctx => function(args, content) {
13 | args = ctx.args.map(args, ['width', 'effect'])
14 | var el = ''
15 | function slide() {
16 | let imgs = ctx.render.renderSync({text: content, engine: 'markdown'})
17 | imgs = imgs.match(/
/gi)
18 | if (imgs && imgs.length > 0) {
19 | imgs.forEach((img, i) => {
20 | img = img.replace('
' + img + ''
22 | })
23 | }
24 | }
25 | el += ''
28 | el += '
'
29 | slide()
30 | el += '
'
31 | el += ''
32 | el += '
'
33 | el += '
'
34 | el += '
'
35 | return el
36 | }
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/tag-plugins/folders.styl:
--------------------------------------------------------------------------------
1 | .tag-plugin.folders
2 | margin: var(--gap-p) 0
3 | font-size: $fs-14
4 | border-top: 1px solid var(--block-border)
5 | overflow: hidden
6 | .folder
7 | border-bottom: 1px solid var(--block-border)
8 | padding: 1rem
9 | summary
10 | cursor: pointer
11 | color: var(--text-p2)
12 | font-weight: 500
13 | position: relative
14 | line-height: 1.2
15 | outline: none
16 | padding: 1rem
17 | margin: -1rem
18 | &:last-child
19 | border-bottom: none
20 | >
21 | span
22 | margin-left: 0.25em
23 | p,h1,h2,h3,h4,h5,h6
24 | display: inline
25 | border-bottom: none !important
26 | &:hover
27 | color: var(--text-p0)
28 | &:after
29 | position: absolute
30 | content: '+'
31 | text-align: center
32 | top: 50%
33 | transform: translateY(-50%)
34 | right: 1rem
35 |
36 |
37 | .tag-plugin.folders details[open]
38 | >summary
39 | color: var(--text-p1)
40 | font-weight: 700
41 | &:after
42 | content: '-'
43 |
44 | >div.body
45 | font-size: $fs-15
46 | >:first-child
47 | margin-top: 1rem
48 | >:last-child
49 | margin-bottom: 0
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/widgets/toc_wiki.styl:
--------------------------------------------------------------------------------
1 | .widget-wrapper.toc.multi .widget-header
2 | color: var(--text-p1)
3 | font-size: $fs-14
4 |
5 |
6 | // 其它分页链接
7 | .widget-wrapper.toc.multi .doc-tree
8 | border-radius: $border-bar
9 | background: var(--block)
10 | overflow: hidden
11 | border: 1px solid var(--block-border)
12 | a.doc-tree-link
13 | color: var(--text-p2)
14 | padding: 0.5rem
15 | display: block
16 | font-size: $fs-12
17 | font-weight: 500
18 | position: relative
19 | &:after
20 | position: absolute
21 | right: .5rem
22 | &.active
23 | color: var(--text-p1)
24 | &:only-child
25 | background: var(--card)
26 | &:hover
27 | background: var(--block-hover)
28 | &:after
29 | content: '+'
30 |
31 |
32 | // 当前分页链接
33 | .widget-wrapper.toc.multi .doc-tree.active
34 | a.doc-tree-link
35 | background: var(--block)
36 | font-weight: 700
37 | &:not(:only-child)
38 | border-bottom: 1px solid var(--block-border)
39 | &:hover:after
40 | content: none
41 | >.toc
42 | padding: 4px
43 | background: var(--card)
44 | a.toc-link:before
45 | left: -2px
46 | width: 4px
47 | a.toc-link:hover
48 | background: var(--block)
49 |
--------------------------------------------------------------------------------
/source/install:
--------------------------------------------------------------------------------
1 | #!/bin/bash
2 |
3 | # 下载什么
4 | NAME=$1
5 | # 哪个版本
6 | VERSION=$2
7 |
8 | P3=$3
9 | P4=$4
10 |
11 | function on_fail() {
12 | NAME=""
13 | VERSION=""
14 | printf "\n> \033[31m下载失败!\033[0m\n\n"
15 | }
16 |
17 | function start() {
18 | if [ "$VERSION" == "" ];then
19 | VERSION='latest'
20 | fi
21 | printf '\n> 正在请求下载%s@%s...\n' ${NAME} ${VERSION}
22 | curl -s https://fastly.jsdelivr.net/gh/xaoxuu/${NAME}@latest/install | sh -s ${VERSION} ${P3} ${P4} || on_fail
23 | }
24 |
25 | function check_param() {
26 | case $NAME in
27 | '')
28 | clear
29 | printf "可安装的脚本:\n"
30 | printf " \033[1m\033[32m%s\033[0m %s \t (docs: %s) \n" 'tag.sh' '' 'https://xaoxuu.com/wiki/tag.sh/'
31 | printf " \033[1m\033[32m%s\033[0m %s \t (docs: %s) \n" 'hexo.sh' '' 'https://xaoxuu.com/wiki/hexo.sh/'
32 | printf " \033[1m\033[32m%s\033[0m %s \t (docs: %s) \n" 'podspec.sh' '' 'https://xaoxuu.com/wiki/podspec.sh/'
33 | printf " \033[1m\033[32m%s\033[0m %s \t (docs: %s) \n" 'vim-cn.sh' '' 'https://xaoxuu.com/wiki/vim-cn.sh/'
34 | printf "\n"
35 | printf "默认安装最新版本,可以在脚本后面加上版本号安装指定版本,用空格隔开。例如:\n"
36 | printf "curl -s https://xaoxuu.com/install | bash -s hexo.sh v2\n"
37 | printf "\n\n"
38 | ;;
39 | *) start ;;
40 | esac
41 | }
42 |
43 | check_param
44 |
--------------------------------------------------------------------------------
/themes/stellar/languages/en.yml:
--------------------------------------------------------------------------------
1 | btn:
2 | home: Home
3 | blog: Blog
4 | wiki: Wiki
5 | recent_publish: Recent
6 | all_wiki: All Products
7 | category: Category
8 | categories: Categories
9 | tag: Tag
10 | tags: Tags
11 | archives: Archives
12 | getting_started: Getting Started
13 |
14 | meta:
15 | recent_update: Recent Update
16 | toc: TOC
17 | read_next: READ NEXT
18 | prev: Prev
19 | next: Next
20 | older: Older
21 | newer: Newer
22 | references: References
23 | related_posts: Related Posts
24 | comment_title: Join the discussion
25 | back_to_top: Back to top
26 | more: 'More %s'
27 | created: 'Posted on'
28 | updated: 'Updated on'
29 | license: License
30 | share: Share
31 | date_suffix:
32 | just: Just
33 | min: minutes ago
34 | hour: hours ago
35 | day: days ago
36 | month: months ago
37 |
38 | page:
39 | error:
40 | what: Page Not Found
41 | why: The address may be entered incorrectly or the address has been deleted.
42 | action: Back to Home
43 |
44 | search:
45 | search: Search
46 | search_in: Search in %s
47 | no_results: No Results!
48 |
49 | message:
50 | copied: Copied!
51 |
52 | symbol:
53 | comma: ", "
54 | period: ". "
55 | colon: ": "
56 | brackets_l: "("
57 | brackets_r: ")"
58 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/tags/lib/poetry.js:
--------------------------------------------------------------------------------
1 | /**
2 | * poetry.js v1.1 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | * 格式与官方标签插件一致使用空格分隔,中括号内的是可选参数(中括号不需要写出来)
4 | *
5 | * poetry:
6 | * {% poetry [title] [author:作者] [date:日期] [footer:footer] %}
7 | * body
8 | * {% endpoetry %}
9 | *
10 | */
11 |
12 | 'use strict'
13 |
14 | module.exports = ctx => function(args, content) {
15 | var el = ''
16 | args = ctx.args.map(args, ['author', 'date', 'footer'], ['title'])
17 |
18 | el += ''
20 | el += '
'
21 | if (args.title) {
22 | el += '
'
23 | el += args.title
24 | el += '
'
25 | }
26 | if (args.author || args.date) {
27 | el += '
'
28 | if (args.author) {
29 | el += '' + args.author + ''
30 | }
31 | if (args.date) {
32 | el += '' + args.date + ''
33 | }
34 | el += '
'
35 | }
36 | el += '
'
37 | el += ctx.render.renderSync({text: content, engine: 'markdown'}).split('\n').join('')
38 | el += '
'
39 | if (args.footer) {
40 | el += ''
43 | }
44 | el += '
'
45 | el += '
'
46 | return el
47 | }
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/cover/post_cover.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | function div() {
3 | var el = '';
4 | if ((page.banner == undefined || page.banner == false) && !theme.article.auto_banner) {
5 | return el;
6 | }
7 | var url;
8 | if (page.banner != undefined) {
9 | if (page.banner.includes('/')) {
10 | url = page.banner;
11 | } else {
12 | url = 'https://source.unsplash.com/2000x400/?' + page.banner;
13 | }
14 | } else {
15 | // 自动以 tags 作为关键词搜索封面
16 | if (page.tags) {
17 | var params = '';
18 | page.tags.reverse().forEach((tag, i) => {
19 | if (i > 0) {
20 | params += ',';
21 | }
22 | params += tag.name;
23 | });
24 | url = 'https://source.unsplash.com/2000x400/?' + params;
25 | } else {
26 | url = 'https://source.unsplash.com/random/2000x400';
27 | }
28 | }
29 | el += '';
30 | el += '
';
31 | if (theme.plugins.lazyload && theme.plugins.lazyload.enable) {
32 | el += '
';
33 | } else {
34 | el += '
';
35 | }
36 | el += '
';
37 | el += '
';
38 | return el;
39 | }
40 | %>
41 | <%- div() %>
42 |
--------------------------------------------------------------------------------
/source/wiki/prohud/custom/index.md:
--------------------------------------------------------------------------------
1 | ---
2 | layout: wiki
3 | wiki: ProHUD
4 | order: 210
5 | title: 自定义样式
6 |
7 | ---
8 |
9 | ## 微调样式
10 |
11 | 你可以在 AppDelegate 中配置好颜色、字体、间距等
12 |
13 | ```swift
14 | ProHUD.config { (cfg) in
15 | cfg.rootViewController = window!.rootViewController
16 | cfg.primaryLabelColor = .black // 标题颜色
17 | cfg.secondaryLabelColor = .darkGray // 正文颜色
18 | cfg.alert { (a) in
19 | a.titleFont = .bold(22)
20 | a.bodyFont = .regular(17)
21 | a.boldTextFont = .bold(18)
22 | a.buttonFont = .bold(18)
23 | a.forceQuitTimer = 3
24 | a.iconSize = .init(width: 48, height: 48)
25 | a.margin = 8
26 | a.padding = 16
27 | }
28 | cfg.toast { (t) in
29 | t.titleFont = .bold(18)
30 | t.bodyFont = .regular(16)
31 | }
32 | cfg.guard { (g) in
33 | g.titleFont = .bold(22)
34 | g.subTitleFont = .bold(20)
35 | g.bodyFont = .regular(17)
36 | g.buttonFont = .bold(18)
37 | }
38 | }
39 | ```
40 |
41 | ## 完全自定义布局
42 |
43 | ```swift
44 | ProHUD.config { (cfg) in
45 | cfg.alert { (config) in
46 | config.reloadData { (vc) in
47 | // 这是数据模型
48 | vc.vm
49 | // 这是要弹出的vc
50 | vc
51 | // 你可以在这里完全自由布局
52 | }
53 | }
54 | }
55 | ```
56 |
--------------------------------------------------------------------------------
/source/wiki/prohud/scene/index.md:
--------------------------------------------------------------------------------
1 | ---
2 | layout: wiki
3 | wiki: ProHUD
4 | order: 200
5 | title: 场景及其扩展
6 |
7 | ---
8 |
9 | 你可以在一个文件中扩展场景,例如:
10 |
11 | ```swift
12 | extension ProHUD.Scene {
13 | static var confirm: ProHUD.Scene {
14 | var scene = ProHUD.Scene(identifier: "confirm")
15 | scene.image = UIImage(named: "ProHUDMessage")
16 | return scene
17 | }
18 | static var delete: ProHUD.Scene {
19 | var scene = ProHUD.Scene(identifier: "delete")
20 | scene.image = UIImage(named: "ProHUDTrash")
21 | scene.title = "确认删除"
22 | scene.message = "此操作不可撤销"
23 | return scene
24 | }
25 | static var buy: ProHUD.Scene {
26 | var scene = ProHUD.Scene(identifier: "buy")
27 | scene.image = UIImage(named: "ProHUDBuy")
28 | scene.title = "确认付款"
29 | scene.message = "一旦购买拒不退款"
30 | return scene
31 | }
32 | }
33 | ```
34 |
35 | 这样你在发布横幅或者弹窗的时候,scene 参数就可以填写 `.confirm, .delete, .buy` 这三种了。例如:
36 |
37 | ```swift
38 | Alert.push(scene: .delete) { (a) in
39 | a.update() { (vm) in
40 | vm.add(action: .destructive, title: "删除") { [weak a] in
41 | // 删除操作
42 | a?.pop()
43 | }
44 | vm.add(action: .cancel, title: "取消", handler: nil)
45 | }
46 | }
47 | ```
48 |
49 | 这样就可以弹出一个预先配置好的确认删除样式的弹窗。
50 |
--------------------------------------------------------------------------------
/themes/stellar/layout/post.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | if (page.menu_id == undefined) {
3 | page.menu_id = 'post';
4 | }
5 | if (page.header == undefined) {
6 | page.header = 'auto';
7 | }
8 | function layoutTitle() {
9 | const title = page.h1 || page.title;
10 | if (title && title.length > 0) {
11 | return '' + title + '
';
12 | } else {
13 | return '';
14 | }
15 | }
16 | let post = page;
17 | let heti = '';
18 | if (theme.plugins.heti && theme.plugins.heti.enable) {
19 | heti = ' heti';
20 | }
21 | %>
22 | <% if (page.mathjax == true){ %>
23 | <%- partial('mathjax') %>
24 | <% } %>
25 | <% if (page.mermaid == true){ %>
26 | <%- partial('mermaid') %>
27 | <% } %>
28 | <%- partial('_partial/main/navbar/breadcrumb') %>
29 | <%- scrollreveal() %>'>
30 | <%- layoutTitle() %>
31 | <%- post.content %>
32 | <% if (theme.plugins.tianli_gpt.enable && ['all', 'post'].includes(theme.plugins.tianli_gpt.field)) { %>
33 | <%- partial('_partial/main/article/ai_abstract') %>
34 | <% } %>
35 | <%- partial('_partial/main/article/article_footer') %>
36 |
37 | <%- partial('_partial/main/article/read_next') %>
38 | <%- partial('_partial/main/article/related_posts') %>
39 | <%- partial('_partial/plugins/comments/layout') %>
40 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/tag-plugins/poetry.styl:
--------------------------------------------------------------------------------
1 | .md-text .tag-plugin.poetry
2 | display: flex
3 | flex-direction: column
4 | align-items: center
5 | .content
6 | >.title
7 | font-weight: 500
8 | font-size: 1rem
9 | margin-top: var(--gap-p)
10 | >.meta
11 | color: var(--text-p2)
12 | font-size: $fs-12
13 | font-weight: 500
14 | span+span
15 | margin-left: 4px
16 | >.body
17 | margin: var(--gap-p) 0
18 | border-top: 1px dashed var(--block-border)
19 | border-bottom: 1px dashed var(--block-border)
20 | p
21 | font-size: $fs-14
22 | >.footer
23 | font-style: italic
24 | color: var(--text-p4)
25 | margin: var(--gap-p) 0
26 | font-size: $fs-12
27 |
28 | // 描边修饰
29 | .md-text .tag-plugin.poetry .content
30 | padding-left: 1rem
31 | position: relative
32 | &:before
33 | content: ''
34 | position: absolute
35 | width: 4px
36 | left: -4px
37 | top: 4px
38 | bottom: 4px
39 | border-radius: 4px
40 | background: var(--block)
41 | >.title
42 | position: relative
43 | &:before
44 | content: ''
45 | position: absolute
46 | width: 4px
47 | left: calc(-1rem - 4px)
48 | top: 6px
49 | bottom: 6px
50 | border-radius: 4px
51 | background: $color-accent
52 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/main/footer.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | const content = theme.footer.content;
3 | function layoutDiv() {
4 | var el = '';
5 | el += '';
38 | return el;
39 | }
40 | %>
41 | <%- layoutDiv() %>
42 |
--------------------------------------------------------------------------------
/source/wiki/inspire/index.md:
--------------------------------------------------------------------------------
1 | ---
2 | layout: wiki
3 | wiki: Inspire
4 | seo_title: 「Inspire」基于主题的Swift开发工具包
5 | ---
6 |
7 |
8 | ## 特性
9 |
10 | ### 可缓存的
11 |
12 | - App 的样式参数(颜色、字体、布局)存储于 json 文件中。
13 |
14 | ### 可配置的
15 |
16 | - 可由用户修改主题参数并保存或者分享。
17 |
18 | ### 提供便利
19 |
20 | - 便捷的方式获取屏幕布局参数、如各边安全区域尺寸,便于机型适配。
21 |
22 |
23 | ## 开始使用
24 |
25 | ```ruby 在 Podfile 中添加:
26 | pod 'Inspire'
27 | ```
28 |
29 | ```sh 然后执行:
30 | pod install
31 | ```
32 |
33 | ## 用法示例
34 |
35 |
36 |
37 | ### 颜色
38 |
39 | ```swift
40 | view.backgroundColor = .background
41 | view.tintColor = .accent
42 | ```
43 |
44 | ### 字体
45 |
46 | ```swift
47 | let lb = UILabel()
48 | lb.font = .regular(15)
49 | lb.font = .bold(20, for: .title)
50 | lb.font = .regular(14, for: .code)
51 | ```
52 |
53 | ### 边距
54 |
55 |
56 | ```swift
57 | let topMargin = layout.topBarHeight(for: self)
58 | let bottomMargin = layout.bottomBarHeight(for: self)
59 | let safeArea = layout.safeAreaInsets(for: self)
60 | let safeArea2 = Inspire.shared.screen.safeAreaInsets
61 | ```
62 |
63 | ```swift
64 | let layout = Inspire.shared.layout
65 | view.frame.size.height = layout.rowHeight
66 | view.layer.cornerRadius = layout.cornerRadius.large
67 | ```
68 |
69 | ### 缓存
70 |
71 | ```swift
72 | // 保存
73 | Inspire.shared.cache()
74 | Inspire.shared.cache(named: "myTheme")
75 | // 读取
76 | let ipr = Inspire.init("myTheme")
77 | ```
78 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/widgets/ghissues.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | function layoutDiv() {
3 | var el = '';
4 | var repo;
5 | var branch = 'main';
6 | if (page.repo) {
7 | repo = page.repo
8 | } else if (page.layout === 'wiki' && page.wiki) {
9 | let proj = theme.wiki.projects[page.wiki];
10 | if (proj && proj.repo) {
11 | repo = proj.repo;
12 | if (proj.branch != undefined) {
13 | branch = proj.branch;
14 | }
15 | }
16 | }
17 | if (repo == undefined) {
18 | return el;
19 | }
20 | item.api = theme.api_host.ghapi + '/repos/' + repo + '/issues?per_page=' + item.limit;
21 | if (item.labels) {
22 | item.api += '&labels=' + item.labels;
23 | }
24 | el += '';
25 | if (item.title) {
26 | el += '';
29 | }
30 | el += '';
31 | el += '
{
33 | if (item[key]) {
34 | el += ' ' + key + '="' + item[key] + '"';
35 | }
36 | });
37 | el += '>';
38 | el += '
';
39 | el += '
';
40 | el += '';
41 | return el;
42 | }
43 | %>
44 | <%- layoutDiv() %>
45 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_defines/const.styl:
--------------------------------------------------------------------------------
1 | // 用来进行设备适配,请勿修改
2 | $device-mobile-375 = 375px
3 | $device-mobile-425 = 425px
4 | $device-mobile = 500px
5 | $device-mobile-max = 667px
6 | $device-tablet = 768px
7 | $device-laptop = 1024px
8 | $device-desktop = 1440px
9 | $device-2k = 2048px
10 | $device-4k = 2560px
11 |
12 | // 预定义颜色,不需要修改
13 | $color-md-red = #f44336
14 | $color-md-pink = #E91E63
15 | $color-md-purple = #9c27b0
16 | $color-md-deep-purple = #673ab7
17 | $color-md-indigo = #3f51b5
18 | $color-md-light-blue = #4BA7EE
19 | $color-md-blue = #2196f3
20 | $color-md-deep-blue = #3367d6
21 | $color-md-teal = #009688
22 | $color-md-green = #4caf50
23 | $color-md-light-green = #8bc34a
24 | $color-md-orange = #ff9800
25 | $color-md-deep-orange = #ff5722
26 | $color-md-brown = #795548
27 | $color-md-blue-grey = #607d8b
28 | $color-md-grey = #9e9e9e
29 | $color-md-light-grey =#e0e0e0
30 | $color-md-yellow = #FCEC60
31 | $color-md-amber = #F6C344
32 |
33 | $color-mac-cyan = #1BCDFC
34 | $color-mac-green = #3DC550
35 | $color-mac-yellow = #FFBD2B
36 | $color-mac-red = #FE5F58
37 |
38 | $color-google-blue = #4688F1
39 | $color-google-green = #3AA757
40 | $color-google-yellow = #FABB2D
41 | $color-google-red = #E8453C
42 |
43 | $c-red = #F44336
44 | $c-orange = #FA6400
45 | $c-yellow = #FFBD2B
46 | $c-green = #3DC550
47 | $c-cyan = #1BCDFC
48 | $c-blue = #2196f3
49 | $c-purple = #9c27b0
50 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_common/button.styl:
--------------------------------------------------------------------------------
1 | button
2 | border: none
3 | font-weight: 500
4 | outline: none
5 | disable-select()
6 | cursor: pointer
7 |
8 | a.button
9 | font-weight: 500
10 | line-height: 1
11 | padding: 0.75rem 2rem
12 | border-radius: $border-button
13 | font-size: $fs-15
14 | user-select: none
15 | &.theme
16 | background: $color-theme
17 | color: var(--card)
18 | &:hover
19 | background: $color-hover
20 | &.start
21 | border-radius: 100px
22 | background: var(--text-p1)
23 | color: var(--card)
24 |
25 | a[onclick]:hover
26 | cursor: pointer
27 |
28 | a.button.start.gradient
29 | transition: 0.38s ease-out
30 | position relative
31 | z-index: 0
32 | background: convert(hexo-config('style.gradient.start'))
33 | background-size: 1000%
34 | color: white
35 | text-shadow: 0 0 1px rgba(0,0,0,0.12)
36 | animation: glow 60s linear infinite
37 | @keyframes glow {
38 | from {
39 | background-position: 0%
40 | }
41 | to {
42 | background-position: 1000%
43 | }
44 | }
45 | &:after
46 | content: ''
47 | position absolute
48 | left: 0
49 | right: 0
50 | top: 0
51 | bottom: 0
52 | border-radius: 100px
53 | background: inherit
54 | z-index -1
55 | filter: blur(36px)
56 | transition: 0.38s ease-out
57 | opacity 0
58 | &:hover:after
59 | opacity 1
--------------------------------------------------------------------------------
/themes/stellar/scripts/tags/inline-labels.js:
--------------------------------------------------------------------------------
1 | /**
2 | * 修饰文本标签 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | *
4 | * example:
5 | * {% psw 这是密码 %}
6 | */
7 |
8 | 'use strict'
9 |
10 |
11 | hexo.extend.tag.register('u', function(args) {
12 | return `${args.join(' ')}`
13 | })
14 | hexo.extend.tag.register('emp', function(args) {
15 | return `${args.join(' ')}`
16 | })
17 | hexo.extend.tag.register('wavy', function(args) {
18 | return `${args.join(' ')}`
19 | })
20 | hexo.extend.tag.register('del', function(args) {
21 | return `${args.join(' ')}`
22 | })
23 | hexo.extend.tag.register('kbd', function(args) {
24 | return `${args.join(' ')}`
25 | })
26 | hexo.extend.tag.register('psw', function(args) {
27 | return `${args.join(' ')}`
28 | })
29 | hexo.extend.tag.register('sup', function(args) {
30 | args = hexo.args.map(args, ['color'], ['text'])
31 | var el = ''
32 | el += ''
33 | el += args.text
34 | el += ''
35 | return el
36 | })
37 | hexo.extend.tag.register('sub', function(args) {
38 | args = hexo.args.map(args, ['color'], ['text'])
39 | var el = ''
40 | el += ''
41 | el += args.text
42 | el += ''
43 | return el
44 | })
45 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/partial/paginator.styl:
--------------------------------------------------------------------------------
1 | .paginator-wrap
2 | margin: 1rem
3 | display: flex
4 | justify-content: space-between
5 | align-items: center
6 | font-size: 1rem
7 | font-weight: 700
8 | background: var(--card)
9 | border-radius: $border-card
10 | overflow: hidden
11 | box-shadow: 0 2px 8px 0px rgba(0, 0, 0, 0.03)
12 | .page-number
13 | padding: 4px 8px
14 | border-radius: 8px
15 | background: var(--block)
16 | margin: 2px
17 | .extend
18 | text-align: center
19 | background-size: contain
20 | width: 1rem
21 | height: 1rem
22 | background-origin: content-box
23 | background-clip: content-box
24 | &.next
25 | border-left: 1px dashed var(--block-border)
26 | background-image: url('https://gcore.jsdelivr.net/gh/cdn-x/placeholder@1.0.4/arrow/064b95430caf4.svg')
27 | &.prev
28 | border-right: 1px dashed var(--block-border)
29 | background-image: url('https://gcore.jsdelivr.net/gh/cdn-x/placeholder@1.0.4/arrow/f049bbd4e88ec.svg')
30 | .current
31 | font-family: $ff-code
32 | color: var(--text-p3)
33 | .extend
34 | color: var(--text-p3)
35 | padding: 1rem
36 | line-height: 0
37 | filter: grayscale(100%)
38 | img
39 | height: 1rem
40 | &.disable
41 | pointer-events: none
42 | span.extend
43 | opacity: 0.25
44 | a.extend:hover
45 | filter: unset
46 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/menubtn.ejs:
--------------------------------------------------------------------------------
1 |
2 |
5 |
6 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/partial/article-footer.styl:
--------------------------------------------------------------------------------
1 | .md-text .article-footer
2 | margin-top: 4rem
3 | padding: 1rem
4 | background: var(--block)
5 | border-radius: $border-block
6 | border: 1px solid var(--block-border)
7 | &:empty
8 | display: none
9 | .header
10 | font-weight: 500
11 | color: var(--text-p2)
12 | font-size: $fs-h4
13 | .body
14 | input.copy-area
15 | margin: 0.75rem 0
16 | padding: 0
17 | width: 100%
18 | p
19 | color: var(--text-p2)
20 | margin: 0.5em 0
21 | a
22 | font-weight: unset
23 | ul
24 | margin: 0
25 | overflow: hidden
26 | .post-title
27 | margin: 0.5rem 0
28 | line-height: 1.2
29 | word-break: break-all
30 | section+section
31 | margin-top: 1rem
32 | padding-top: 1rem
33 | border-top: 1px solid var(--block-border)
34 |
35 | .md-text .article-footer .social-wrap
36 | grid-gap: 0.5rem 1rem
37 | margin: 0
38 |
39 | .md-text .article-footer .qrcode
40 | width: 128px
41 | padding: 4px
42 | background: white
43 | border-radius: 4px
44 | box-shadow: 0 4px 8px 0px rgba(0, 0, 0, 0.1), 0 0 32px 0px rgba(0, 0, 0, 0.1)
45 | overflow: hidden
46 | trans1 height
47 | img
48 | object-fit: contain
49 |
50 | .md-text .article-footer .qrcode.display
51 | margin: 2rem auto 1rem
52 | height: 128px !important
53 | visibility: visible !important
54 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/widgets/related.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | function layoutDiv() {
3 | if (page.layout !== "wiki") {
4 | return '';
5 | }
6 | var related = [];
7 | let proj = theme.wiki.projects[page.wiki];
8 | if (proj.related && proj.related.length > 0) {
9 | proj.related.forEach((pid, i) => {
10 | let p = theme.wiki.projects[pid];
11 | if (p && p.title !== proj.title && p.index !== false) {
12 | related.push(p);
13 | }
14 | });
15 | }
16 | var el = '';
17 | if (related.length > 0) {
18 | el += '';
19 | el += '';
26 | el += '';
37 | el += '';
38 | }
39 | return el;
40 | }
41 | %>
42 | <%- layoutDiv() %>
43 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/tags/lib/grid.js:
--------------------------------------------------------------------------------
1 | /**
2 | * grid.js v1.0 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | * 格式与官方标签插件一致使用空格分隔,中括号内的是可选参数(中括号不需要写出来)
4 | *
5 | * {% grid [style:block/card] %}
6 | *
7 | * left body
8 | *
9 | * right body
10 | * {% endgrid %}
11 | */
12 |
13 | 'use strict'
14 |
15 | module.exports = ctx => function(args, content) {
16 | args = ctx.args.map(args, ['bg'])
17 | var el = ''
18 | el += ''
21 |
22 | var arr = content.split(//g).filter(item => item.trim().length > 0)
23 | if (arr.length > 0) {
24 | var nodes = []
25 | arr.forEach((item, i) => {
26 | if (i % 2 == 0) {
27 | nodes.push({
28 | header: item
29 | })
30 | } else if (nodes.length > 0) {
31 | var node = nodes[nodes.length-1]
32 | if (node.body == undefined) {
33 | node.body = item
34 | } else {
35 | node.body += '\n' + item
36 | }
37 | }
38 | })
39 | nodes.forEach((node, i) => {
40 | el += '
'
41 | el += ctx.render.renderSync({text: (node.body || ''), engine: 'markdown'}).split('\n').join('')
42 | el += '
'
43 | })
44 | }
45 |
46 | el += '
'
47 |
48 | return el
49 | }
50 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/sidebar/footer.styl:
--------------------------------------------------------------------------------
1 | .l_left>.footer
2 | margin: 0.5rem var(--gap-l) 1rem
3 |
4 | .social-wrap
5 | display: grid
6 | grid-gap: 0.25rem 0.25rem
7 | grid-template-columns: repeat(auto-fill, 32px)
8 | a.social
9 | line-height: 0
10 | display: inline-block
11 | padding: 6px
12 | border-radius: 4px
13 | filter: grayscale(100%)
14 | overflow: hidden
15 | background: transparent
16 | trans3: box-shadow background transform
17 | &:hover
18 | color: $color-hover
19 | z-index: 1
20 | filter: unset
21 | transform: translateY(-1px)
22 | background: linear-gradient(145deg, #ddd, #fff)
23 | box-shadow: 2px 4px 8px #ddd, -2px -4px 8px #fff
24 | if hexo-config('style.darkmode') == 'auto'
25 | @media (prefers-color-scheme: dark)
26 | box-shadow: none
27 | if hexo-config('style.darkmode') == 'always'
28 | box-shadow: none
29 |
30 | .proj-wrap
31 | display: grid
32 | grid-gap: 0.25rem 0.25rem
33 | a.item
34 | border-radius: 4px
35 | font-size: $fs-13
36 | font-weight: 500
37 | color: var(--text-p2)
38 | background: var(--block)
39 | border: 1px solid var(--block-border)
40 | overflow: hidden
41 | padding: .75em
42 | text-align: center
43 | svg
44 | margin-right: .5em
45 | &:hover
46 | color: $color-hover
47 | background: var(--card)
48 |
--------------------------------------------------------------------------------
/source/_posts/blog/2013-02-06-effective-teamwork.md:
--------------------------------------------------------------------------------
1 | ---
2 | date: 2013-02-06
3 | updated: 2015-03-11
4 | title: 如何进行有效的团队合作
5 | categories: [胡思乱想]
6 | banner: https://fastly.jsdelivr.net/gh/cdn-x/xaoxuu@1.0.1/blog/2013-0206a@1x.svg
7 | indent: true
8 | ---
9 |
10 | 本文只是我在大学时期关于小组决策效率与分工方面的思考,可能不适用于其它场景。
11 |
12 | 在任何一个团队中,我始终都是先做一个观察者,因为在掌握足够的信息之前,我的看法可能是片面的,由此产生的观点及推论发表出来可能会误导人。
13 |
14 |
15 |
16 | ## 偏执
17 |
18 | 我印象非常深刻的一次经历:初二的时候,物理老师提问一个思考问题,我的答案和班上其它同学的都不一样,我有点犹豫了,老师说了一句话:{% quot el:span 有时候,真理往往掌握在少数人手中 %},而正是那一次的正确的坚持,让我受益匪浅。这件事在我的成长过程中起到了非常重要的作用,所以现在我是一个对认定事情非常偏执的人。
19 |
20 | 要相信自己有理有据的判断,在追求真理的路上敢于以一敌众,后来的某些经历也表明,即使所有人都反对你,你也未必要因此放弃,因为真相总有浮出水面的时候。
21 |
22 |
23 | ## 交流意见
24 |
25 | 然而我却又是一个不爱争论的人,往往我发表完我的意见,也理解了对方的意见之后,就不会再继续谈论了。
26 |
27 | 为什么不说服别人呢?我会尝试去说服别人,但是当说服的难度远远大于它所带来的意义的时候,我就放弃了。我没有当过领导者,所以说服别人对我来说也不是个必选项,尤其是考虑到这个过程所花费的时间成本跟成果的价值孰轻孰重,我会越来越谨慎行事。
28 |
29 | ## 独立决策与民主决策
30 |
31 | 两者并非不可兼得。为什么要兼得?为了效率。
32 |
33 | 我的眼中只有效率,不在乎形式,假如一个问题有两种既定方案,如果三十个人讨论半天各执己见,有些人选择A方案,有些人选择B方案,选择A方案的人试图说服选择B方案的人,选择B方案的人也试图说服选择A方案的人,最终的结果可能是选A也可能是选B,也可能出来一种新的C方案。
34 |
35 | **不是所有人都能看见真相**,经过讨论可能会让更多人走向正确的道路,也有可能会让少部分持有最佳方案却意志不够坚定的人被说服放弃,历史上这样的例子并不少见,每时每刻,都有数不清的人会在讨论中与**成为历史**或**被历史遗忘**擦肩而过。
36 |
37 | 我们更需要的是:交流意见 --> 独立思考 --> 独立决策。
38 |
39 | ## 合力不等于力量的叠加
40 |
41 | 力量都是有方向的,方向相同则相加。很多时候一次糟糕的合作导致若干力量相抵消,最终还不如一个人的效率高,一个聪明的团队应该在力量和方向上都作出最优选择。
42 |
43 | 我自认为是一个没有大家所谓的“团队精神”的人,因为我认为即使我们做不到最好,也不要硬撑着搞形式,作出最糟糕的选择,效率才是最终目的。
44 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/tags/lib/ghcard.js:
--------------------------------------------------------------------------------
1 | /**
2 | * friends.js v1 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | * 格式与官方标签插件一致使用空格分隔,中括号内的是可选参数(中括号不需要写出来)
4 | *
5 | * {% ghcard user/repo [theme:xxx] %} or {% ghcard user %}
6 | *
7 | * example:
8 | * {% ghcard xaoxuu %}
9 | * {% ghcard xaoxuu/hexo-theme-stellar %}
10 | *
11 | * API: https://github.com/anuraghazra/github-readme-stats
12 | */
13 |
14 | 'use strict'
15 |
16 | module.exports = ctx => function(args) {
17 | var params = ['show_owner', 'theme', 'title_color', 'text_color', 'icon_color', 'bg_color', 'hide_border', 'cache_seconds', 'locale']
18 | args = ctx.args.map(args, params, ['repo'])
19 | const path = args.repo
20 | var el = ''
21 | el += ''
38 | return el
39 | }
40 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/tag-plugins/frame.styl:
--------------------------------------------------------------------------------
1 | .md-text .frame-wrap
2 | position: relative
3 | overflow: hidden
4 | margin: 0 auto
5 | max-width: 100%
6 | display: flex
7 | flex-direction: column
8 | align-items: center
9 | img,video
10 | border-radius: 0
11 | .md-text .frame-wrap .frame
12 | z-index: 1
13 | display: block
14 | position: absolute;
15 | background-size: 100%;
16 | background-repeat: no-repeat;
17 | overflow: hidden;
18 |
19 | .md-text .tag-plugin.img-wrap .frame-wrap
20 | &[focus]
21 | height: auto
22 |
23 | .md-text .frame-wrap
24 | iphone11
25 | img,video
26 | width: 287px
27 | margin-top: 19px
28 | margin-bottom: 20px
29 | .frame
30 | background-image: url(https://gcore.jsdelivr.net/gh/cdn-x/placeholder@1.0.4/frame/iphone11.svg);
31 | width: 329px
32 | height: 658px
33 | &[focus='top']
34 | img,video
35 | margin-bottom: 0 !important
36 | &:not([focus='bottom'])
37 | .frame
38 | top: 0
39 | &[focus='bottom']
40 | img,video
41 | bottom: 0
42 | margin-top: 0 !important
43 | .frame
44 | bottom: 0
45 |
46 | @media screen and (max-width: $device-mobile)
47 | .md-text .frame-wrap
48 | iphone11
49 | img,video
50 | width: 208px
51 | margin-top: 13px
52 | margin-bottom: 14px
53 | .frame
54 | width: 238px
55 | height: 476px
56 |
--------------------------------------------------------------------------------
/source/wiki/prohud/toast/index.md:
--------------------------------------------------------------------------------
1 | ---
2 | layout: wiki
3 | wiki: ProHUD
4 | order: 120
5 | seo_title: Toast - 通知横幅组件
6 | title: 通知横幅组件
7 | ---
8 |
9 | Toast 是用于顶部通知横幅的组件,它的层级最高,只接受一个点击事件,可以预先对不同的场景配置不同的默认值(图标、持续时间)。当多个 Toast 同时存在时,它们从上往下平铺。
10 |
11 | {% frame iphone11 img:https://fastly.jsdelivr.net/gh/cdn-x/wiki/prohud/docs/toast-loading@2x.jpg video:https://fastly.jsdelivr.net/gh/cdn-x/wiki/prohud/docs/toast-loading@2x.mov focus:top %}
12 |
13 | 默认提供的场景有:`default, loading, success, warning, error`。
14 |
15 | 示例1:发布一个警告
16 |
17 | ```swift
18 | Toast.push(scene: .warning, title: "设备电量过低", message: "请及时对设备进行充电,以免影响使用。")
19 | ```
20 |
21 | 示例2:发布一个警告并设置其他属性
22 |
23 | ```swift
24 | Toast.push(scene: .warning, title: "设备电量过低", message: "请及时对设备进行充电,以免影响使用。") { (toast) in
25 | // 设置identifier
26 | toast.identifier = "这是唯一标识"
27 | // 禁止通过手势将其移出屏幕
28 | toast.isRemovable = false
29 | // 监听点击事件
30 | toast.didTapped {
31 | debugPrint("点击了这条横幅")
32 | }
33 | }
34 | ```
35 |
36 | ## 如何避免重叠
37 |
38 | 示例:发布一个横幅或者弹窗,如果已经有了就更新标题。
39 |
40 | ```swift
41 | Toast.find("aaa", last: { (t) in
42 | t.update() { (vm) in
43 | vm.title = "已经存在了"
44 | }
45 | }) {
46 | Toast.push(title: "这是一条id为aaa的横幅", message: "避免重复发布同一条信息") { (t) in
47 | t.identifier = "aaa"
48 | t.update { (vm) in
49 | vm.scene = .warning
50 | vm.duration = 0
51 | }
52 | }
53 | }
54 | ```
55 |
--------------------------------------------------------------------------------
/source/_posts/blog/2020-08-23-issues-api.md:
--------------------------------------------------------------------------------
1 | ---
2 | date: 2020-08-23
3 | title: 静态博客使用 Issues API 来实现动态发布友链、书签
4 | categories: [设计开发]
5 | tags: [博客, GitHub]
6 | banner: https://fastly.jsdelivr.net/gh/cdn-x/xaoxuu@1.0.1/blog/2020-0823a@2x.jpg
7 | repo: xaoxuu/issues-api
8 | ---
9 |
10 | 由于发布 issue 的成本远远低于发布一次博客更新(即便是使用了持续集成),可以用 issue 来简化每个独立博客都必备的友链系统,也可以通过 issue 来快速发布动态资讯,弥补静态博客必须更新静态文件才能更新内容的缺点。此功能已经集成到了主题中,使用非常方便。
11 |
12 |
13 |
14 | ## 实现思路
15 |
16 | 如标题所说,例如 Issues API 来实现,把请求到的结果进行解析,然后生成 HTML 标签,添加到页面中。为了获取到需要的信息,创建 Issue 需要遵循一定的格式,例如「网站卡片」就需要截图、网站标题、网站链接、网站描述、头像。可以设置 [Issues 模版](https://github.com/volantis-x/examples/issues/new/choose) 来简化步骤。
17 |
18 | 通过 issue 方式发布内容可以支持 `script` 脚本,为了安全起见,最好设置一个限制,例如用标签来激活 `labels=active` 或者只对自己发布的有效,可以在解析数据的时候过滤掉 `script` 标签。
19 |
20 |
21 | ## 如何在主题中使用?
22 |
23 | 在 GitHub 或者 Gitee 创建仓库,仿照下面的示例,把 api 中的用户名和仓库名改成自己的。Issue 内容中需要有一段满足 JSON 格式的代码块:
24 |
25 | ```json
26 | {
27 | "title": "",
28 | "description": "",
29 | "screenshot": "",
30 | "url": "",
31 | "avatar": "",
32 | "version": "版本:^4.0"
33 | }
34 | ```
35 |
36 | 示例代码:
37 |
38 | ```
39 | {% issues sites api:https://api.github.com/repos/xaoxuu/friends/issues?sort=updated&state=open&page=1&per_page=100&labels=active %}
40 | ```
41 |
42 | 上述示例对应的仓库链接:
43 |
44 | {% link https://github.com/xaoxuu/friends/issues GitHub: xaoxuu/friends %}
45 |
46 | ## 在线演示效果
47 |
48 | 见本站友链
49 |
50 | {% link /friends/ 友链 %}
51 |
--------------------------------------------------------------------------------
/themes/stellar/layout/wiki.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | if (page.menu_id == undefined) {
3 | page.menu_id = 'wiki';
4 | }
5 | if (page.layout == undefined) {
6 | page.layout = 'wiki_index';
7 | }
8 | if (page.title == undefined) {
9 | if (page.tagName) {
10 | page.title = page.tagName;
11 | } else {
12 | page.title = __('btn.wiki');
13 | }
14 | }
15 | function layoutTitle() {
16 | const title = page.h1 || page.title;
17 | if (title && title.length > 0) {
18 | return '' + title + '
';
19 | } else {
20 | return '';
21 | }
22 | }
23 | %>
24 | <% if (page.layout === 'wiki_index') { %>
25 | <%- partial('index') %>
26 | <% } else { %>
27 | <%
28 | if (page.header == undefined) {
29 | page.header = 'auto';
30 | }
31 | %>
32 | <% if (page.mermaid == true){ %>
33 | <%- partial('mermaid') %>
34 | <% } %>
35 | <%- partial('_partial/main/navbar/breadcrumb') %>
36 | <%- scrollreveal() %>'>
37 | <%- layoutTitle() %>
38 | <%- page.content %>
39 | <% if (theme.plugins.tianli_gpt.enable && ['all', 'wiki'].includes(theme.plugins.tianli_gpt.field)) { %>
40 | <%- partial('_partial/main/article/ai_abstract') %>
41 | <% } %>
42 | <%- partial('_partial/main/article/article_footer') %>
43 |
44 | <%- partial('_partial/main/article/read_next') %>
45 | <%- partial('_partial/plugins/comments/layout') %>
46 | <% } %>
47 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/tag-plugins/about.styl:
--------------------------------------------------------------------------------
1 | .tag-plugin.about
2 | background: var(--block)
3 | border-radius: $border-card
4 | padding: 2rem
5 | position: relative
6 | .nav-back
7 | display: none
8 | position: absolute
9 | line-height: 1
10 | overflow: hidden
11 | left: 0.75rem
12 | top: 0.75rem
13 | align-items: center
14 | @media screen and (max-width: $device-mobile-max)
15 | display: flex
16 | svg
17 | width: 1rem
18 | height: 1rem
19 | .about-header
20 | display: flex
21 | justify-content: center
22 | flex-wrap: wrap
23 | margin: 1.5rem 0
24 | img
25 | object-fit: contain
26 | >img
27 | margin: auto 0
28 | >p
29 | font-size: $fs-12
30 | font-weight: 500
31 | color: var(--text-p3)
32 | padding-top: 0.75rem
33 | strong:first-child
34 | font-size: 3rem
35 | font-weight: 700
36 | color: var(--text-p1)
37 | margin-right: 0.75rem
38 | .avatar
39 | display: inline-flex
40 | margin: 0 1rem
41 | .about-body
42 | >p
43 | line-height: 1.5
44 | &:first-child
45 | margin-top: 2.5rem
46 | p+.tag-plugin.navbar .cap
47 | margin-top: 1rem
48 | .about-header+.about-body
49 | margin-top: 2rem
50 |
51 | @media screen and (max-width: $device-mobile)
52 | .tag-plugin.about
53 | padding: 2rem 1rem
54 | .about-header
55 | p
56 | width 100%
57 |
--------------------------------------------------------------------------------
/source/_posts/blog/2017-06-28-ios-strava.md:
--------------------------------------------------------------------------------
1 | ---
2 | date: 2017-06-28
3 | updated: 2017-06-28
4 | title: iOS 接入 Strava 分享模块(下篇:StravaSDK)
5 | categories: [解决方案]
6 | tags: [iOS, StravaSDK]
7 | references:
8 | - url: https://strava.github.io/api/
9 | - url: https://github.com/StravaKit/StravaKit/
10 | - url: https://github.com/xaoxuu/StravaSDK/
11 | ---
12 |
13 | [StravaKit](https://github.com/StravaKit/StravaKit) 是一个比较新而且代码比较规范的第三方SDK,但是目前还没有上传功能(详见 [todo](https://github.com/StravaKit/StravaKit/blob/master/TODO.md)) 。所以我不得已对 `StravaKit 0.9.5` 增加上传功能,并进行一些简单封装和改编,使之能够植入到公司项目中。由于时间有限,我只增加了上传fit文件的功能,并且使用了第三方框架 `Alamofire`,所以需要在项目中导入 `Alamofire`。
14 |
15 |
16 |
17 |
18 | ## 开始使用
19 |
20 | StravaSDK 下载:[StravaSDK.zip](https://github.com/xaoxuu/StravaSDK)
21 |
22 |
23 | ## 配置环境
24 |
25 | 需要三个参数:`ClientId`、`ClientSecret` 和app的 `URLSchemes`。其中前两个是在 [Strava平台](https://labs.strava.com/developers/) 注册一个app的时候会给出。
26 | 示例代码:
27 |
28 | ```swift
29 | StravaSDK.config(clientId: "18583", clientSecret: "a05fde98a830effde2e0f84cc39d76b040d4d67e", appSchemes: "hitfit")
30 | ```
31 |
32 |
33 |
34 | ## 授权
35 |
36 | 获取授权
37 | ```swift
38 | StravaSDK.authorize()
39 | ```
40 |
41 | 取消授权
42 | ```swift
43 | StravaSDK.deauthorize()
44 | ```
45 |
46 | 查询是否已授权
47 | ```swift
48 | StravaSDK.isAuthorized
49 | ```
50 |
51 |
52 | ## 上传活动数据(.fit)
53 |
54 | ```swift
55 | StravaSDK.uploadActivity(path: ".../test.fit", type: "run", name: "Afternoon Run") { (response, error) in
56 |
57 | }
58 | ```
59 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/tag-plugins/note.styl:
--------------------------------------------------------------------------------
1 | .md-text .tag-plugin.note
2 | position: relative
3 | padding: 0.25rem 1rem
4 | border-radius: $border-block
5 | background: var(--theme-bg2)
6 | overflow: hidden
7 | if hexo-config('tag_plugins.note.border') == true
8 | border: 1px solid var(--theme-border)
9 | color: var(--text-p1)
10 | >.title
11 | font-size: $fs-15
12 | line-height: 1.5
13 | margin-top: var(--gap-p-compact)
14 | font-weight: 500
15 | color: var(--text-p0)
16 | >.body
17 | &,p
18 | font-size: $fs-14
19 | line-height: 1.5
20 | margin-top: var(--gap-p-compact)
21 | margin-bottom: var(--gap-p-compact)
22 | >.body:only-child
23 | margin: 'calc(%s - 0.25rem)' % var(--gap-p) 0
24 |
25 |
26 | .md-text .tag-plugin.note[color]
27 | code
28 | background: none
29 | .md-text .tag-plugin.note:not([color])
30 | .highlight
31 | background: var(--block-hover)
32 | .md-text .tag-plugin.note[child=codeblock]
33 | padding: 0
34 | >.title, >.body:only-child
35 | margin-top: 0
36 | >.body
37 | margin-bottom: 0
38 | .highlight
39 | margin: 0
40 | border: none
41 | background: none
42 |
43 | .md-text .tag-plugin.note[child=tabs]
44 | >.body
45 | margin: 0
46 | >.tabs
47 | margin-top: .5rem
48 |
49 | .md-text .tag-plugin.note[child=iframe]
50 | padding: 0
51 | >.body
52 | margin: 0
53 | iframe
54 | margin: 0
55 |
56 |
57 | .md-text .tag-plugin .tag-plugin.note
58 | --gap-p: 1rem
59 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_plugins/swiper.styl:
--------------------------------------------------------------------------------
1 | :root
2 | --swiper-theme-color: $color-theme !important
3 | .swiper
4 | width: 100%
5 | border-radius: 4px
6 | --gap-p: 2rem
7 | .swiper:not(.swiper-initialized)
8 | display: none
9 | div.swiper-slide
10 | text-align: center
11 | display: -webkit-box
12 | display: -ms-flexbox
13 | display: -webkit-flex
14 | display: flex
15 | align-self: center
16 | -webkit-box-pack: center
17 | -ms-flex-pack: center
18 | -webkit-justify-content: center
19 | justify-content: center
20 | -webkit-box-align: center
21 | -ms-flex-align: center
22 | -webkit-align-items: center
23 | align-items: center
24 | width: 50%
25 | img
26 | border-radius: 4px
27 |
28 | .swiper[width='max'] .swiper-slide
29 | width: 100%
30 |
31 | .swiper[width='min'] .swiper-slide
32 | width: 25%
33 |
34 | .swiper[effect='cards'] .swiper-slide
35 | max-width: 75%
36 |
37 | .swiper-button-prev,.swiper-button-next
38 | padding: 1rem 0.25rem
39 | margin-top: -2rem !important
40 | border-radius: 40px
41 | background: alpha(white, 0.25)
42 | trans1 background
43 | --swiper-theme-color: var(--text-p0) !important
44 | &:after
45 | font-size: 1.2rem !important
46 | font-weight: 700 !important
47 | color: var(--swiper-theme-color)
48 | &:hover
49 | background: white !important
50 | --swiper-theme-color: $color-hover !important
51 |
52 | .swiper-button-prev:after
53 | transform: translateX(-1px)
54 |
55 | .swiper-button-next:after
56 | transform: translateX(1px)
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/plugins/comments/layout.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | var cmt = {
3 | service: theme.comments.service
4 | };
5 | if (cmt.service) {
6 | cmt[cmt.service] = Object.assign({}, theme.comments[cmt.service]);
7 | }
8 | var loadComment = false;
9 | if (theme.comments.service && theme.comments.service.length > 0) {
10 | if (page.comments == undefined || page.comments != false) {
11 | loadComment = true;
12 | }
13 | }
14 | // 合并项目评论
15 | if (loadComment && page.layout == 'wiki' && page.wiki) {
16 | let proj = theme.wiki.projects[page.wiki];
17 | if (proj.comment_title != undefined && page.comment_title == undefined) {
18 | if (['utterances', 'beaudar', 'giscus'].includes(theme.comments.service)) {
19 | page.comment_title = proj.comment_title;
20 | }
21 | }
22 | if (proj.comments && proj.comments.service) {
23 | cmt = proj.comments;
24 | let s = proj.comments.service;
25 | cmt[s] = Object.assign({}, theme.comments[s], proj.comments[s]);
26 | }
27 | }
28 | if (cmt.service && page[cmt.service]) {
29 | Object.assign(cmt[cmt.service], page[cmt.service]);
30 | }
31 | page.cmt = cmt;
32 | %>
33 | <% if (loadComment) { %>
34 |
42 | <% } %>
43 |
--------------------------------------------------------------------------------
/source/wiki/smartlamp/index.md:
--------------------------------------------------------------------------------
1 | ---
2 | layout: wiki
3 | wiki: SmartLamp
4 | title: 蓝牙智能灯毕业设计项目
5 | ---
6 |
7 | {% swiper %}
8 | 
9 | 
10 | 
11 | 
12 | 
13 | 
14 | {% endswiper %}
15 |
16 |
17 |
18 | ## 特性
19 |
20 | **调节亮度、颜色、定时关闭**
21 |
22 | 主页是核心功能,实现一键连接蓝牙灯、自由调节颜色、亮度、设置定时关灯等功能。
23 | 情景页是保存用户设置的情景模式,可以根据使用场景不同快速切换至对应的工作模式。
24 | 设备页可以管理多台蓝牙灯。
25 | 发现页提供一些智能家居相关资讯。
26 |
27 |
28 | ## 技术点
29 |
30 | ### ATTitleBar
31 |
32 | - 支持横向滑动切换tab,并具有点击涟漪效果。
33 | - titlebar是在app中广泛应用的一种tab设计。我写的这个小框架模仿Google的Material Design设计,涟漪效果代码由MaterialControls框架改写。
34 | - 页面较多时采用类似tableview的懒加载模式,只加载需要显示的几页,减少内存占用,提高流畅度。
35 |
36 | ### ReactiveCocoa
37 |
38 | - 本项目大量使用了ReactiveCocoa框架进行响应式编程,大幅简化代码、提高可读性。
39 | - RAC的订阅机制使得一对多传值有了新的选择,如蓝牙中心设备。
40 | - RAC的信号监听机制使得我更容易根据需要定制个性化控件。如带翻转、旋转效果的tabbar、带缩放和回弹效果的slider等,使app的界面栩栩如生。
41 |
42 | ### CBCentralManager
43 |
44 | - CBCentralManager是蓝牙类app的核心,本项目在编写这部分代码时使用了链式语法进行封装,外界调用起来十分方便。
45 |
46 | ### ATCarouselView
47 |
48 | - 轮播图也是在app中广泛存在的一种自定义控件,我将这部分代码封装至ATKit中,以Pods导入方式使用,便于维护和扩展,同时也使得本项目代码更加简洁。
49 | - 部分app的轮播图可以根据下方列表的滑动而改变高度或者添加蒙版效果,我目前实现了改变高度的功能。
50 |
--------------------------------------------------------------------------------
/source/friends/index.md:
--------------------------------------------------------------------------------
1 | ---
2 | robots: noindex,nofollow
3 | sitemap: false
4 | menu_id: more
5 | seo_title: 友链
6 | toc_title: 友链索引
7 | comment_title: 快来交换友链吧~
8 | comment_id: '留言板'
9 | ---
10 |
11 | ## 海内存知己 天涯若比邻
12 | 感谢人生旅途中的每一份真挚的友谊,按结识先后顺序:
13 | {% friends only:group1 %}
14 |
15 | ## 特别感谢的开源大佬
16 | 感谢开源大佬们的无私奉献,按结识先后顺序:
17 | {% friends only:group2 %}
18 |
19 | ## 来自 GitHub 的朋友
20 | 以下友链通过 [GitHub Issue](https://github.com/xaoxuu/friends/issues/) 提交:
21 | {% friends only:group3 %}
22 |
23 |
24 | {% grid color:yellow 友链更新通知 %}
25 |
26 | 由于近期对友链系统进行了重做,原链接失效的小伙伴请按照下方交换友链的步骤进行填写。在新的友链系统中,您随时可以对自己的信息进行修改而无需等待博主更新。
27 |
28 | {% endgrid %}
29 |
30 | ## 如何自助添加友链?
31 |
32 |
33 | 先友后链,在我们有一定了解了之后才可以交换友链,除此之外,您的网站还应满足以下条件:
34 |
35 | - 合法的、非营利性、无商业广告
36 | - 有实质性原创内容的 `HTTPS` 站点
37 |
38 | {% timeline %}
39 |
40 |
41 |
42 | 新建 [GitHub Issue](https://github.com/xaoxuu/friends/issues/) 按照模板格式填写并提交。
43 |
44 | 为了提高图片加载速度,建议优化头像:
45 | 1. 打开 [压缩图](https://www.yasuotu.com/) 上传自己的头像,将图片尺寸调整到 `96px` 后下载。
46 | 2. 将压缩后的图片上传到 [去不图床](https://7bu.top/) 并使用此图片链接作为头像。
47 |
48 |
49 |
50 | 请添加本站到您的友链中,如果您也使用 issue 作为友链源,只需要告知您的友链源仓库即可。
51 |
52 | {% codeblock lang:yaml %}
53 | title: xaoxuu
54 | avatar: https://fastly.jsdelivr.net/gh/cdn-x/xaoxuu/avatar/rect-256@2x.png
55 | url: https://xaoxuu.com
56 | screenshot: https://i.loli.net/2020/08/21/VuSwWZ1xAeUHEBC.jpg
57 | {% endcodeblock %}
58 |
59 | 待管理员审核通过,添加了 `active` 标签后,回来刷新即可生效。
60 |
61 | {% endtimeline %}
62 |
63 | 如果您需要更新自己的友链,请直接修改 issue 内容,大约 3 分钟内生效,无需等待博客更新。如果无法修改,可以重新创建一个。
64 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/tags/lib/navbar.js:
--------------------------------------------------------------------------------
1 | /**
2 | * navbar.js v1 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | * 格式与官方标签插件一致使用空格分隔,中括号内的是可选参数(中括号不需要写出来)
4 | *
5 | * {% navbar [markdown link] ... %}
6 | *
7 | * example:
8 | * {% navbar active:1 [Home](/) [About](/about/) [Comments](#comments) %}
9 | */
10 |
11 | 'use strict'
12 |
13 | module.exports = ctx => function(args) {
14 | if (args.length == 0) {
15 | return
16 | }
17 | args = ctx.args.map(args, ['active'], ['links'])
18 | if (args.links) {
19 | args.links = args.links.split(' ')
20 | }
21 | var el = ''
56 | return el
57 | }
58 |
--------------------------------------------------------------------------------
/source/wiki/vim-cn.sh/index.md:
--------------------------------------------------------------------------------
1 | ---
2 | layout: wiki
3 | wiki: vim-cn.sh
4 | title: 一个快速批量上传图片的脚本
5 | ---
6 |
7 |
8 |
9 | ## 直接使用
10 |
11 | 打开终端,`cd` 到存放图片的文件夹,输入这行命令就开始上传图片:
12 |
13 | {% copy width:max curl -s https://fastly.jsdelivr.net/gh/xaoxuu/vim-cn.sh@2.1/upload.sh | sh %}
14 |
15 | {% note color:cyan 为了简化指令,建议下载安装后使用。 %}
16 |
17 | ## 安装脚本
18 |
19 | 打开终端,输入这行命令:
20 |
21 | {% copy width:max curl -s https://xaoxuu.com/install | sh -s vim-cn.sh %}
22 |
23 | 如需安装指定版本,在后面加上版本号即可,例如:
24 |
25 | {% copy width:max curl -s https://xaoxuu.com/install | sh -s vim-cn.sh 2.1.0 %}
26 |
27 | 然后就会开始下载脚本并安装到 `usr/local/bin` 路径,可能需要输入电脑密码以授权。
28 |
29 | ## 上传文件
30 |
31 | 需要上传图片到时候,打开终端,`cd` 到存放图片的文件夹,输入 `upload` 就可以了。当然,还可以传递参数:
32 |
33 | ```sh
34 | upload [扩展名] [操作]
35 | ```
36 |
37 | | 扩展名 | 含义 |
38 | | :---------------------------------- | :------------------ |
39 | | `all` 或者不传任何参数 | 上传所有格式的文件 |
40 | | `png`、`jpg`、`ico` 等具体的某个扩展名 | 上传指定格式的文件 |
41 |
42 | | 操作 | 含义 |
43 | | :--------------- | :------------------ |
44 | | `open` | 上传成功后打开链接 |
45 |
46 |
47 | {% folding 常见的用法示例 %}
48 |
49 | 上传当前文件夹中的所有文件
50 |
51 | ```sh
52 | upload
53 | ```
54 |
55 | 上传当前文件夹中的所有文件,并打开链接
56 |
57 | ```sh
58 | upload all open
59 | ```
60 |
61 | 上传当前文件夹中的所有png格式的图片
62 |
63 | ```sh
64 | upload png
65 | ```
66 | {% endfolding %}
67 |
68 |
69 | ## 支持的文件格式
70 |
71 |
72 | 经测试,可以上传的格式有:png、jpg、ico、gif、svg、tiff、webp、pdf、mp3、mp4、zip等。
73 |
74 | 支持的文件大小大概在 50MB 以内。
75 |
76 | ## 请勿滥用
77 |
78 | {% note color:yellow 注意 为了大家都能愉快使用,请不要上传一些奇奇怪怪的图片。 %}
79 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/widgets/widgets.styl:
--------------------------------------------------------------------------------
1 | .widgets
2 | .loading-wrap
3 | margin: 0.5rem 0
4 |
5 | .widgets
6 | overflow: scroll
7 | flex-grow: 1
8 | scrollbar-width: none
9 | scrollbar(0, 0)
10 | z-index: 1
11 | line-height: 1.2
12 | .widget-wrapper
13 | .widget-header
14 | padding-left: var(--gap-l)
15 | padding-right: var(--gap-l)
16 | display: flex
17 | justify-content: space-between
18 | align-items: center
19 | font-weight: 500
20 | position: sticky
21 | top: -2px
22 | background: var(--site-bg)
23 | padding-top: 2px
24 | z-index 1
25 | .item
26 | display: block
27 | >span
28 | margin: 0.25rem 0
29 | text-align: left
30 | &:empty
31 | display: none
32 | .cap-action
33 | hover-block 4px 4px
34 | line-height: 0
35 | color: var(--text-meta)
36 | trans2: color background
37 | .icon
38 | fill: var(--text-meta)
39 | &:hover
40 | color: $color-hover
41 | .icon
42 | fill: $color-hover
43 |
44 | .widget-body
45 | margin: 0.5rem var(--gap-l)
46 | color: var(--text-p1)
47 | p
48 | margin-top: .5em
49 | margin-bottom: .5em
50 | line-height: 1.5
51 | .widget-header+.widget-body
52 | margin-top: 0
53 | .widget-wrapper+.widget-wrapper .widget-header
54 | margin-top: 3rem
55 | .widget-wrapper+.widget-wrapper.toc .widget-header
56 | margin-top: 1rem
57 |
58 | .widget-wrapper
59 | display: block
60 | margin: 2rem 0
--------------------------------------------------------------------------------
/themes/stellar/layout/archive.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | page.robots = 'noindex,follow';
3 | if (page.menu_id == undefined) {
4 | page.menu_id = 'post';
5 | }
6 | %>
7 | <% if (page.posts && (is_category() || is_tag())) { %>
8 | <%- partial('index') %>
9 | <% } else { %>
10 | <% page.title = __('btn.archives'); %>
11 | <%- partial('_partial/main/navbar/list_post') %>
12 |
13 | <% var years = []; %>
14 | <% site.posts.sort('date', -1).each(function(post) { %>
15 | <% post.year = date(post.date, 'YYYY'); %>
16 | <% if (post.year && (years.includes(post.year) == false) && (post.title || post.date)) { %>
17 | <% years.push(post.year); %>
18 | <% } %>
19 | <% }); %>
20 | <% years.forEach((year, i) => { %>
21 |
22 |
23 | <% site.posts.sort('date', -1).filter(function (post) { %>
24 | <% post.year = date(post.date, 'YYYY'); %>
25 | <% return post.year == year; %>
26 | <% }).each(function(post) { %>
27 |
39 | <% }); %>
40 |
41 | <% }); %>
42 |
43 | <% } %>
44 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/tags/lib/folders.js:
--------------------------------------------------------------------------------
1 | /**
2 | * folders.js v1 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | * 格式与官方标签插件一致使用空格分隔,中括号内的是可选参数(中括号不需要写出来)
4 | *
5 | * {% folders [color:white] %}
6 | *
7 | * body 1
8 | *
9 | * body 2
10 | * {% endtable %}
11 | */
12 |
13 | 'use strict'
14 |
15 | module.exports = ctx => function(args, content) {
16 | args = ctx.args.map(args, ['color'])
17 | var el = ''
18 | el += ''
21 |
22 | var arr = content.split(//g).filter(item => item.trim().length > 0)
23 | if (arr.length > 0) {
24 | var nodes = []
25 | arr.forEach((item, i) => {
26 | if (i % 2 == 0) {
27 | nodes.push({
28 | header: item
29 | })
30 | } else if (nodes.length > 0) {
31 | var node = nodes[nodes.length-1]
32 | if (node.body == undefined) {
33 | node.body = item
34 | } else {
35 | node.body += '\n' + item
36 | }
37 | }
38 | })
39 | nodes.forEach((node, i) => {
40 | el += '
'
41 | // summary
42 | el += '' + (node.header || '') + '
'
43 | // content
44 | el += ''
45 | el += ctx.render.renderSync({text: (node.body || ''), engine: 'markdown'}).split('\n').join('')
46 | el += '
'
47 | })
48 | }
49 |
50 | el += '
'
51 |
52 | return el
53 | }
54 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/partial/navbar.styl:
--------------------------------------------------------------------------------
1 | .nav-wrap
2 | position: sticky
3 | position: -webkit-sticky
4 | margin-top: -0.5rem
5 | top: -2px
6 | background: var(--site-bg)
7 | padding: 0 1rem
8 | z-index: 8
9 | margin-bottom: 1px
10 | &:after
11 | content: ''
12 | width: 'calc(100% - 2 * %s)' % 1rem
13 | height: 2px
14 | border-radius: 2px
15 | position: absolute
16 | bottom: 0
17 | left: 1rem
18 | background: var(--block-hover)
19 |
20 | nav.cap
21 | display: flex
22 | overflow: scroll visible
23 | scrollbar(0, 0)
24 | >p
25 | margin: 0
26 | a
27 | padding: .25rem 1rem
28 | margin: 10px 0 8px 0
29 | line-height: 2
30 | color: var(--text-p3)
31 | border-radius: 4px
32 | font-weight: 500
33 | white-space: nowrap
34 | position: relative
35 | z-index: 1
36 | &:after
37 | height: 2px
38 | position: absolute
39 | bottom: -8px
40 | left: 1rem
41 | right: 1rem
42 | background: $color-theme
43 | border-radius: 2px
44 | pointer-events: none
45 | &:hover
46 | background: var(--block-hover)
47 | &.active, &:hover
48 | color: var(--text-p1)
49 | &.active
50 | background: var(--card)
51 | box-shadow: $boxshadow-button
52 | &.active:after
53 | content: ''
54 | a+a
55 | margin-left: 4px
56 |
57 | @media screen and (max-width: $device-mobile-max)
58 | .nav-wrap
59 | margin-top: 0
60 | padding-left: 0
61 | padding-right: 0
62 | nav
63 | a:first-child
64 | margin-left: 1rem
65 | a:last-child
66 | margin-right: 1rem
67 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/cover/wiki_cover.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | function layoutWikiCover() {
3 | var el = '';
4 | let proj = theme.wiki.projects[page.wiki];
5 | if (proj == undefined) {
6 | return el;
7 | }
8 | if (proj.homepage.path !== page.path) {
9 | return;
10 | }
11 | if (proj.cover == undefined || proj.cover === false || proj.cover === '[]') {
12 | return el;
13 | }
14 | var cover = proj.cover;
15 | let logo = proj.logo;
16 | let title = proj.title || page.title;
17 | let desc = proj.description || page.description;
18 | if (cover === true) {
19 | cover = ['logo', 'title', 'description'];
20 | }
21 | el += '';
46 | el += '
';
47 | return el;
48 | }
49 | %>
50 | <%- layoutWikiCover() %>
51 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/tags/lib/quot.js:
--------------------------------------------------------------------------------
1 | /**
2 | * quot.js v1.2 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | * 格式与官方标签插件一致使用空格分隔,中括号内的是可选参数(中括号不需要写出来)
4 | *
5 | * quot:
6 | * {% quot [el:h2] [icon:default] text %}
7 | *
8 | */
9 |
10 | 'use strict'
11 |
12 | module.exports = ctx => function(args) {
13 | var el = ''
14 | args = ctx.args.map(args, ['el', 'icon'], ['text'])
15 | if (!args.el) {
16 | args.el = 'p'
17 | }
18 |
19 | var type = ''
20 | if (args.icon && args.icon != 'square' && args.icon != 'quotes') {
21 | type = ' type="icon"'
22 | } else {
23 | type = ' type="text"'
24 | }
25 | function content() {
26 | if (!args.icon) {
27 | return args.text
28 | }
29 | var el = ''
30 | const cfg = ctx.theme.config.tag_plugins.quot[args.icon]
31 | if (cfg && cfg.prefix) {
32 | el += '
'
33 | }
34 | el += args.text
35 | if (cfg && cfg.suffix) {
36 | el += '
'
37 | }
38 | return el
39 | }
40 | if (args.el.includes('h')) {
41 | el += ''
42 | el += '<' + args.el + ' class="content" id="' + args.text + '"' + type + '>'
43 | el += ''
44 | el += content()
45 | el += '' + args.el + '>'
46 | el += '
'
47 | } else {
48 | el += ''
49 | el += '<' + args.el + ' class="content"' + type + '>'
50 | el += content()
51 | el += '' + args.el + '>'
52 | el += '
'
53 | }
54 | return el
55 | }
56 |
--------------------------------------------------------------------------------
/.github/workflows/auto-deploy.yml:
--------------------------------------------------------------------------------
1 | name: auto deploy # workflow name
2 |
3 | on:
4 | [push] # 触发事件
5 |
6 | jobs:
7 | build: # job1 id
8 | runs-on: ubuntu-latest # 运行环境为最新版 Ubuntu
9 | name: auto deploy
10 | steps:
11 | - name: Checkout # step1 获取源码
12 | uses: actions/checkout@v1 # 使用 actions/checkout@v1
13 | with: # 条件
14 | submodules: true # Checkout private submodules(themes or something else). 当有子模块时切换分支?
15 | - name: Setup Node.js 16.13.x
16 | uses: actions/setup-node@master
17 | with:
18 | node-version: "16.13.x"
19 | - name: Generate Public Files
20 | run: |
21 | npm i
22 | npm install hexo-cli -g
23 | hexo clean && hexo generate
24 | # Deploy to GitHub Pages
25 | - name: Deploy to GitHub Pages
26 | uses: peaceiris/actions-gh-pages@v3
27 | with:
28 | deploy_key: ${{ secrets.DEPLOY_KEY }}
29 | external_repository: xaoxuu/xaoxuu.github.io
30 | publish_branch: gh-pages
31 | publish_dir: ./public
32 | commit_message: ${{ github.event.head_commit.message }}
33 | user_name: 'github-actions[bot]'
34 | user_email: 'github-actions[bot]@users.noreply.github.com'
35 | # Deploy to Server
36 | - name: Deploy to Server
37 | uses: easingthemes/ssh-deploy@v2
38 | env:
39 | SSH_PRIVATE_KEY: ${{ secrets.SERVER_SSH_KEY }}
40 | ARGS: "-rltgoDzvO --delete"
41 | EXCLUDE: ".well-known"
42 | SOURCE: public/
43 | REMOTE_HOST: ${{ secrets.REMOTE_HOST }}
44 | REMOTE_PORT: ${{ secrets.REMOTE_PORT }}
45 | REMOTE_USER: ${{ secrets.REMOTE_USER }}
46 | TARGET: ${{ secrets.TARGET }}
47 |
--------------------------------------------------------------------------------
/source/_posts/blog/2016-11-06-ios-framework.md:
--------------------------------------------------------------------------------
1 | ---
2 | date: 2016-11-06
3 | updated: 2016-11-06
4 | title: 如何封装自己的 iOS Framework 静态库
5 | categories: [解决方案]
6 | tags: [iOS, Framework]
7 | references:
8 | - title: iOS开发——创建你自己的Framework
9 | url: http://www.cocoachina.com/articles/11022
10 | ---
11 |
12 | 像工作中使用的第三方SDK基本上都是闭源的,因为公司不能把自己的机密泄露出去。所以当需要给别人提供SDK但不让他们知道代码的实现时就需要封装成静态库。
13 |
14 |
15 |
16 | ## 步骤
17 |
18 | 1. 创建工程,最好是起名为 `xxxDemo` 例如 `AXKitDemo`,然后新建一个 target 名为 `AXKit`,并把原来的工程改名为 `AXKit`。(为了方便在 demo 中调试静态库)
19 | 2. 新建一个 target ,选择类型为 `framework`。
20 | 3. 在 `framework` 中创建需要封装的类,写好代码。
21 | 4. 在 `Build Setting` 里更改参数,`Math-O Type` 为 `Static Library`。
22 | 5. 在 `Build Phases -> Headers` 里将需要暴露出来的头文件从 `Project` 移动到 `Public`。
23 | 6. 添加一个 `Aggregate` 的 target,并添加运行脚本。目的是把编译出来的真机版和模拟器版的 `framework` 合并。
24 | 7. 模拟器编译一下,真机编译一下,然后 `Aggregate` 编译一下,然后在项目的 `Products` 文件夹里就有了最终生成的静态库。
25 |
26 | ## 自动合成脚本
27 |
28 | `Aggregate` 的 Run Script 脚本:
29 |
30 | ```
31 | if [ "${ACTION}" = "build" ]
32 | then
33 | INSTALL_DIR=${SRCROOT}/Products/${PROJECT_NAME}.framework
34 |
35 | DEVICE_DIR=${BUILD_ROOT}/${CONFIGURATION}-iphoneos/${PROJECT_NAME}.framework
36 |
37 | SIMULATOR_DIR=${BUILD_ROOT}/${CONFIGURATION}-iphonesimulator/${PROJECT_NAME}.framework
38 |
39 |
40 | if [ -d "${INSTALL_DIR}" ]
41 | then
42 | rm -rf "${INSTALL_DIR}"
43 | fi
44 |
45 | mkdir -p "${INSTALL_DIR}"
46 |
47 | cp -R "${DEVICE_DIR}/" "${INSTALL_DIR}/"
48 | #ditto "${DEVICE_DIR}/Headers" "${INSTALL_DIR}/Headers"
49 |
50 | lipo -create "${DEVICE_DIR}/${PROJECT_NAME}" "${SIMULATOR_DIR}/${PROJECT_NAME}" -output "${INSTALL_DIR}/${PROJECT_NAME}"
51 |
52 | #open "${DEVICE_DIR}"
53 | #open "${SRCROOT}/Products"
54 | fi
55 | ```
56 |
--------------------------------------------------------------------------------
/themes/stellar/npm-publish.sh:
--------------------------------------------------------------------------------
1 | #!/bin/bash
2 | #
3 | # https://xaoxuu.com/wiki/stellar
4 | #
5 | # 只有 rc 阶段的测试版本和正式版本发布到 npm
6 | #
7 | # 1. 输入要发布的版本号
8 | # 2. 修改主题 _config.yml 中的 stellar.version
9 | # 3. 修改主题 package.json 中的 version
10 | # 4. 提交 commit
11 |
12 | # 版本号 例如 1.0.0-rc.1
13 | VERSION=$1
14 |
15 | # 替换版本号
16 | function prepare() {
17 | text="'"${VERSION}"'"
18 | sed -i "" "s/^ version:\([^\"]\{1,\}\)/ version: ${text}/g" '_config.yml'
19 | sed -i "" "s/^ \"version\":\([^,]\{1,\}\)/ \"version\": \"${VERSION}\"/g" 'package.json'
20 | main=${VERSION%%.*}
21 | sub=${VERSION#*.}
22 | sub=${sub%%.*}
23 | jsdelivr=$main'.'$sub
24 | sed -i "" "s/\(gcore.jsdelivr.net\/npm\/hexo-theme-stellar@[^/]\{1,\}\)/gcore.jsdelivr.net\/npm\/hexo-theme-stellar@${jsdelivr}/g" '_config.yml'
25 | }
26 |
27 | # 提交
28 | function commit() {
29 | msg="release: ${VERSION}"
30 |
31 | printf "\n\n> \033[32m%s\033[0m" 'git add --all'
32 | printf "\n"
33 | git add --all
34 |
35 | printf "\n\n> \033[32m%s\033[0m" 'git commit -m'
36 | printf " \033[35m%s\033[0m" ${msg}
37 | printf "\n"
38 | git commit -m "${msg}"
39 |
40 | git checkout npm
41 | git rebase main
42 |
43 | printf "\n\n> \033[32m%s\033[0m" 'git push origin'
44 | # printf "\n"
45 | git push origin main
46 | git push origin npm
47 |
48 | # npm publish
49 |
50 | # git tag ${VERSION}
51 | # git push --tags
52 |
53 | git checkout main
54 | # done
55 | printf "\n\n> \033[32m%s\033[0m\n" 'Congratulations!'
56 | }
57 |
58 |
59 | while :
60 | do
61 | case $VERSION in
62 | '')
63 | read -p "请输入要发布的版本号: " VERSION
64 | ;;
65 | *)
66 | break
67 | ;;
68 | esac
69 | done
70 |
71 | prepare && commit
72 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/tags/lib/about.js:
--------------------------------------------------------------------------------
1 | /**
2 | * about.js v1 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | * 格式与官方标签插件一致使用空格分隔,中括号内的是可选参数(中括号不需要写出来)
4 | *
5 | * {% about [avatar:xxx] [height:80px] %}
6 | * title / body
7 | * {% endabout %}
8 | */
9 |
10 | 'use strict';
11 |
12 | module.exports = ctx => function(args, content) {
13 | const url_for = require('hexo-util').url_for.bind(ctx)
14 | args = ctx.args.map(args, ['avatar', 'height', 'border', 'back'])
15 | var rows = ctx.render.renderSync({text: content, engine: 'markdown'}).split('\n')
16 | var el = ''
17 | // wrapper
18 | el += ''
19 | if (args.back) {
20 | el += '
'
21 | el += ''
22 | el += ''
23 | }
24 | // avatar
25 | var avatar_url = args.avatar
26 | if (avatar_url) {
27 | el += ''
39 | }
40 |
41 | // content
42 | el += '
'
43 | el += rows.join('')
44 | el += '
'
45 |
46 | el += '
'
47 | return el
48 | }
--------------------------------------------------------------------------------
/themes/stellar/scripts/helpers/related_posts.js:
--------------------------------------------------------------------------------
1 | /**
2 | * https://github.com/tea3/hexo-related-popular-posts/wiki/More-Settings#customize-html
3 | */
4 |
5 | 'use strict';
6 |
7 | var util = require('hexo-util');
8 |
9 | hexo.extend.helper.register('popular_posts_wrapper', function(args){
10 | const title = args.title;
11 | const json = args.json.json;
12 | const cls = args.json.class;
13 | if (json == undefined || json.length == 0) {
14 | return '';
15 | }
16 | const cfg = hexo.theme.config.article.related_posts;
17 | if (cfg.enable != true) return;
18 | var returnHTML = "";
19 | var div = `
20 |
23 |
24 | `;
25 |
26 | const posts = this.site.posts;
27 | const root = this.config.root;
28 |
29 | function listItem(obj){
30 | var el = '';
31 | el += '';
32 | var p = posts.filter(p => root + p.path == obj.path)
33 | if (p && p.length > 0) {
34 | p = p.data[0];
35 | }
36 | el += '' + obj.title + '';
37 | if (obj.excerpt && obj.excerpt.length > 0) {
38 | el += '' + util.truncate(util.stripHTML(obj.excerpt), {length: 120}) + '';
39 | }
40 | el += '';
41 | return el;
42 | }
43 |
44 | if (json.length > 0) {
45 | for(var i = 0; i < json.length; i++) {
46 | returnHTML += listItem(json[i]);
47 | }
48 | }
49 |
50 | if (returnHTML != "") returnHTML = "" + returnHTML + "
";
51 | div += returnHTML;
52 | div += '';
53 | return div;
54 | });
55 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/partial/cover.styl:
--------------------------------------------------------------------------------
1 | .l_cover
2 | height: 100vh
3 | text-align: center
4 | display: flex
5 | flex-direction: column
6 | justify-content: center
7 | align-items: center
8 | position: relative
9 | &.post
10 | height: inherit
11 |
12 |
13 | .l_cover .cover-wrap
14 | margin-bottom: 0
15 | display: flex
16 | flex-direction: column
17 | justify-content: center
18 | align-items: center
19 | .cover-title
20 | font-weight: 700
21 | font-size: 1.5rem
22 | margin: 1rem 0
23 | line-height: 1.2
24 | .description
25 | margin: 1rem 0
26 | .start-wrap
27 | margin: 2rem 0
28 | flex-shrink: 0
29 | a.start
30 | display: inline-block
31 |
32 | .l_cover.post
33 | .cover
34 | z-index: -1
35 | width: 100%
36 | height: 30vh
37 | max-width: $device-2k
38 | min-height: 150px
39 | max-height: 400px
40 | @media screen and (max-width: $device-tablet)
41 | height: 25vh
42 | @media screen and (max-width: $device-mobile)
43 | height: 20vh
44 | @media screen and (min-width: $device-2k)
45 | margin-top: 4rem
46 | .img
47 | border-radius: 2rem
48 |
49 |
50 | .l_cover.post .cover-wrap
51 | z-index: 1
52 | .article-title
53 | text-align: center
54 | padding: 1rem
55 | margin: 1em 0 0 0
56 | @media screen and (min-width: $device-2k)
57 | font-size: 3rem
58 |
59 |
60 | .l_cover.wiki .cover-wrap
61 | max-width: $device-mobile
62 | .preview
63 | margin-bottom: 2rem
64 | img
65 | object-fit: contain
66 | max-height: 35vh
67 | max-width: 100%
68 | @media screen and (max-width: $device-mobile)
69 | max-width: 60%
70 | .cover-title
71 | &:first-child
72 | font-size: 3rem
73 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/tag-plugins/folding.styl:
--------------------------------------------------------------------------------
1 | details.folding
2 | display: block
3 | padding: 1rem
4 | margin: 1rem 0
5 | border-radius: $border-block
6 | background: var(--theme-bg2)
7 | border: 1px solid var(--theme-border)
8 | summary
9 | cursor: pointer
10 | padding: 1rem
11 | margin: -1rem
12 | color: var(--text-p2)
13 | font-weight: 500
14 | font-size: $fs-14
15 | position: relative
16 | line-height: 1.2
17 | outline: none
18 | >
19 | span
20 | margin-left: 0.25em
21 | p,h1,h2,h3,h4,h5,h6
22 | display: inline
23 | border-bottom: none !important
24 | &:hover
25 | color: var(--text-p0)
26 | &:after
27 | position: absolute
28 | content: '+'
29 | text-align: center
30 | top: 50%
31 | transform: translateY(-50%)
32 | right: 1rem
33 | line-height: 1
34 |
35 |
36 | details.folding[open]
37 | >summary
38 | color: var(--text-p1)
39 | font-weight: 700
40 | z-index 1
41 | &:after
42 | content: '-'
43 | >div.body
44 | padding: 0 1rem 1rem
45 | margin: 0 -1rem -1rem
46 | color: var(--text-p1)
47 | >:first-child
48 | margin-top: 1rem
49 | >:last-child
50 | margin-bottom: 0
51 |
52 | details.folding[child=codeblock]>div.body
53 | padding: 0
54 | background: transparent
55 | overflow: hidden
56 | .highlight
57 | border: none
58 | border-radius: 0
59 | background: transparent
60 | margin: 0
61 | figcaption
62 | display: none
63 | .code:before
64 | content: none
65 |
66 | details.folding[child=iframe]
67 | overflow: hidden
68 | background: none
69 | >summary
70 | background: none
71 | >div.body
72 | padding: 0
73 | background: none
74 | overflow: hidden
--------------------------------------------------------------------------------
/themes/stellar/scripts/tags/lib/friends.js:
--------------------------------------------------------------------------------
1 | /**
2 | * friends.js v2 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | * 格式与官方标签插件一致使用空格分隔,中括号内的是可选参数(中括号不需要写出来)
4 | *
5 | * {% friends [group] [repo:owner/repo] [api:http] %}
6 | */
7 |
8 | 'use strict'
9 |
10 | module.exports = ctx => function(args) {
11 | args = ctx.args.map(args, ['repo', 'api'], ['group'])
12 | var links = ctx.locals.get('data').links
13 | if (links == undefined) {
14 | links = {}
15 | }
16 | var api
17 | if (args.api) {
18 | api = args.api
19 | } else if (args.repo) {
20 | api = 'https://api.vlts.cc/output_data/v2/' + args.repo
21 | }
22 |
23 | var el = ''
24 | if (api) {
25 | el += '
'
28 | el += '
'
29 | el += '
'
30 | } else if (args.group) {
31 | function cell(item) {
32 | if (item.url && item.title) {
33 | var cell = '
'
38 | return cell
39 | } else {
40 | return ''
41 | }
42 | }
43 | el += '
'
44 | const items = links[args.group] || []
45 | items.forEach((item, i) => {
46 | el += cell(item)
47 | })
48 | el += '
'
49 | }
50 |
51 | el += '
'
52 | return el
53 | }
54 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/plugins/comments/waline/script.ejs:
--------------------------------------------------------------------------------
1 |
40 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/tag-plugins/friends.styl:
--------------------------------------------------------------------------------
1 | .users-wrap
2 | overflow: hidden
3 | .group-header
4 | margin: 0 0 1rem
5 | p
6 | margin: 0
7 | font-size: $fs-14
8 | &:first-child
9 | font-size: 1.25rem
10 | font-weight: 500
11 | .group-body
12 | width: 100%
13 | display: flex
14 | flex-wrap: wrap
15 | align-items: stretch
16 | &+.group-header
17 | margin-top: 2rem
18 | .stellar-friends-api
19 | display: block
20 |
21 |
22 | .users-wrap .user-card
23 | flex-shrink: 1
24 | display: flex
25 | align-items: stretch
26 | width: 12.5%
27 | @media screen and (max-width: 980px)
28 | width: 14.28%
29 | @media screen and (max-width: 900px)
30 | width: 16.66%
31 | @media screen and (max-width: 820px)
32 | width: 20%
33 | @media screen and (max-width: $device-mobile-max)
34 | width: 16.66%
35 | @media screen and (max-width: $device-mobile)
36 | width: 25%
37 | .card-link
38 | margin: 0
39 | width: 100%
40 | color: var(--text-p1)
41 | font-size: 10px
42 | font-weight: 500
43 | display: flex
44 | justify-content: flex-start
45 | flex-direction: column
46 | align-items: center
47 | text-align: center
48 | line-height: 1.2
49 | border-radius: 4px
50 | overflow: hidden
51 | position: relative
52 | padding: 1rem 0.5rem
53 | img
54 | object-fit: cover
55 | display: block
56 | width: 48px
57 | height: 48px
58 | background: var(--card)
59 | border-radius: 64px
60 | margin: 0 0 0.5rem
61 |
62 | // transform
63 | .users-wrap .user-card .card-link
64 | >img
65 | trans2 transform box-shadow
66 | &:hover
67 | background: var(--block-hover)
68 | img
69 | transform: scale(1.2) rotate(8deg)
70 | box-shadow: $boxshadow-card-float
71 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/widgets/toc_common.styl:
--------------------------------------------------------------------------------
1 | .widget-wrapper.toc .widget-header
2 | margin-top: 1rem
3 |
4 | .widget-wrapper.toc.single .widget-header
5 | font-weight: 500
6 | font-size: $fs-12
7 | >span
8 | margin: 0.5rem 0
9 |
10 | .widget-wrapper.toc .widget-body
11 | margin-top: 0
12 | ul ul, ul ol
13 | padding-left: 0
14 | ol ul, ol ol
15 | padding-left: 0
16 |
17 | .doc-tree
18 | margin: 4px 0
19 | .toc
20 | padding: 0
21 | margin: 0
22 | padding-left: 0.25rem
23 | .toc-item .toc-link
24 | padding: 0.5rem
25 | font-weight: 500
26 | font-size: $fs-13
27 | color: var(--text-p2)
28 | .toc-child .toc-item .toc-link
29 | padding: 0.25rem 0.5rem 0.25rem 1.3rem
30 | font-weight: 400
31 | color: var(--text-p2)
32 | .toc-child .toc-child .toc-item .toc-link
33 | padding-left: 2.1rem
34 | font-size: $fs-12
35 | color: var(--text-p3)
36 | .toc-child .toc-child .toc-child .toc-item .toc-link
37 | padding-left: 2.9rem
38 |
39 |
40 | .widget-wrapper.toc .toc-item
41 | color: var(--text-p2)
42 | font-size: $fs-12
43 | padding: 0
44 | list-style: none
45 | &.active
46 | color: $color-theme
47 | border-left-color: @color
48 | .toc-child .toc-item
49 | padding: 0
50 | .widget-wrapper.toc a.toc-link
51 | color: inherit
52 | display: block
53 | line-height: 1.2
54 | border-radius: 4px
55 | position: relative
56 | &:before
57 | content: ''
58 | position: absolute
59 | left: -6px
60 | top: 'calc(50% - %s)' % 6px
61 | bottom: 'calc(50% - %s)' % 6px
62 | width: 2px
63 | border-radius: 2px
64 | background: $color-theme
65 | visibility: hidden
66 | &:hover
67 | background: var(--block-hover)
68 | &.active
69 | color: $color-theme !important
70 | &:before
71 | visibility: visible
72 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/tags/lib/copy.js:
--------------------------------------------------------------------------------
1 | /**
2 | * copy.js v1 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | * 格式与官方标签插件一致使用空格分隔,中括号内的是可选参数(中括号不需要写出来)
4 | *
5 | * {% copy xxx %}
6 | * {% copy git xaoxuu/hexo-theme-stellar %}
7 | *
8 | */
9 |
10 | 'use strict'
11 |
12 | var copy_index = 0
13 |
14 | module.exports = ctx => function(args) {
15 | args = ctx.args.map(args, ['width', 'git'], ['text'])
16 | if (args == undefined || args.text == undefined) {
17 | return ''
18 | }
19 | var text = args.text
20 | if (args.git) {
21 | if (text.substr(0,1) == '/') {
22 | text = text.substring(1)
23 | }
24 | if (args.git == 'ssh') {
25 | text = 'git@github.com:' + text + '.git'
26 | } else if (args.git == 'gh') {
27 | text = 'gh repo clone ' + text
28 | } else {
29 | text = 'https://github.com/' + text + '.git'
30 | }
31 | }
32 |
33 | const copy_id = 'copy_' + ++copy_index
34 |
35 | var el = ''
36 | el += ''
41 | el += '
'
43 | el += '
'
46 |
47 | el += '
'
48 | return el
49 | }
50 |
--------------------------------------------------------------------------------
/themes/stellar/source/js/plugins/linkcard.js:
--------------------------------------------------------------------------------
1 | // 本插件由CardLink定制而成,原项目源码: https://github.com/Lete114/CardLink
2 |
3 | function renderer(el, obj) {
4 | var autofill = [];
5 | const autofillStr = el.getAttribute('autofill');
6 | if (autofillStr) {
7 | autofill = autofillStr.split(',');
8 | }
9 | if (obj.title && obj.title.length > 0 && autofill.includes('title')) {
10 | el.querySelector('.title').innerHTML = obj.title;
11 | el.title = obj.title;
12 | }
13 | if (obj.icon && obj.icon.length > 0 && autofill.includes('icon')) {
14 | el.querySelector('.img').style = 'background-image: url("' + obj.icon + '");';
15 | el.querySelector('.img').setAttribute('data-bg', obj.icon);
16 | }
17 | let desc = el.querySelector('.desc');
18 | if (desc && obj.desc && obj.desc.length > 0 && autofill.includes('desc')) {
19 | desc.innerHTML = obj.desc;
20 | }
21 | }
22 |
23 | /**
24 | * Create card links
25 | * @param {NodeList} nodes A collection of nodes or a collection of arrays,
26 | * if it is an array then the array must always contain node element
27 | */
28 | function setCardLink(nodes) {
29 | // If the `nodes` do not contain a `forEach` method, then the default `a[cardlink]` is used
30 | nodes = 'forEach' in (nodes || {}) ? nodes : document.querySelectorAll('a[cardlink]')
31 | nodes.forEach((el) => {
32 | // If it is not a tag element then it is not processed
33 | if (el.nodeType !== 1) return
34 | el.removeAttribute('cardlink');
35 | const link = el.href;
36 | const api = 'https://api.vlts.cc/site_info/v1?url=';
37 | fetch(api + link).then(function(response) {
38 | if (response.ok) {
39 | return response.json();
40 | }
41 | throw new Error('Network response was not ok.');
42 | }).then(function(data) {
43 | renderer(el, data);
44 | }).catch(function(error) {
45 | console.log(error);
46 | });
47 | })
48 | }
49 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/sidebar/header.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | var proj;
3 | if (page.layout === 'wiki' && page.wiki) {
4 | proj = theme.wiki.projects[page.wiki];
5 | }
6 | function layoutTitle(main, url, sub) {
7 | var el = '';
8 | el += '';
9 | el += '' + main + '
';
10 | if (sub) {
11 | let arr = sub.split('|');
12 | if (arr.length > 1) {
13 | el += '' + arr.shift().trim() + '
';
14 | el += '' + arr.join('|') + '
';
15 | } else {
16 | el += '' + sub + '
';
17 | }
18 | }
19 | el += '';
20 | return el;
21 | }
22 |
23 | function layoutDiv() {
24 | var el = '';
25 | if (page.layout == 'wiki' && page.menu_id == 'wiki') {
26 | return el;
27 | }
28 | el += '';
33 |
34 | el += '';
50 |
51 | if (where != 'main') {
52 | el += partial('menu', {where: where});
53 | }
54 | el += '';
55 | return el;
56 | }
57 | %>
58 |
59 | <%- layoutDiv() %>
60 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_layout/tag-plugins/quot.styl:
--------------------------------------------------------------------------------
1 | .md-text .tag-plugin.quot
2 | text-align: center
3 | align-items: center
4 | display: flex
5 | flex-direction: column
6 |
7 | .content
8 | display: flex
9 | align-items: center
10 | border-bottom: none
11 | font-weight: 700
12 | padding: 16px 24px
13 | a.headerlink:before
14 | content: ''
15 | @media screen and (max-width: $device-mobile)
16 | padding: 12px 20px
17 | line-height: 1.2
18 |
19 | .md-text .tag-plugin.quot .content
20 | max-width 500px
21 | position: relative
22 | // override
23 | .md-text.content .tag-plugin.quot
24 | h1
25 | font-size: $fs-h1
26 | font-weight: 900
27 | padding: 20px 32px 12px 32px
28 | @media screen and (max-width: $device-mobile)
29 | padding: 20px 24px 12px
30 | h2,h3,h4,h5,h6
31 | font-size: $fs-h3
32 | margin-top: 1em
33 | margin-bottom: 0
34 | p
35 | font-size: $fs-h4
36 | color: var(--text-p0)
37 |
38 | // type=text
39 | .md-text .tag-plugin.quot
40 | .content[type=text]
41 | &:before,&:after
42 | content: ""
43 | position: absolute
44 | width: 8px
45 | height: 14px
46 | &:before
47 | top: 8px
48 | left: 0
49 | border-top: 6px solid $color-accent
50 | border-left: 6px solid $color-accent
51 | &:after
52 | right: 0
53 | bottom: 8px
54 | border-right: 6px solid $color-accent
55 | border-bottom: 6px solid $color-accent
56 | h1.content[type=text]
57 | &:before,&:after
58 | width: 12px
59 | height: 20px
60 | border-width: 8px
61 |
62 | // type=icon
63 | .md-text .tag-plugin.quot .content[type=icon]
64 | .icon
65 | height: 1.5em
66 | display: inline-block
67 | color: $color-accent
68 | border-radius: 0
69 | &.prefix
70 | margin-left: -0.5rem
71 | margin-right: .5rem
72 | &.suffix
73 | margin-left: .5rem
74 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/main/article/read_next.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | function layoutDiv() {
3 | var prev,next;
4 | var title = __('meta.read_next');
5 | var title_prev = __('meta.prev');
6 | var title_next = __('meta.next');
7 | if (page.layout === 'post') {
8 | prev = page.prev;
9 | next = page.next;
10 | title_prev = __('meta.newer');
11 | title_next = __('meta.older');
12 | } else if (page.layout === 'wiki' && page.wiki && page.wiki.length > 0) {
13 | let proj = theme.wiki.projects[page.wiki];
14 | if (proj) {
15 | const current = page.order || 0;
16 | proj.pages.forEach((p, i) => {
17 | if (p.order < current) {
18 | if (prev == undefined || p.order > prev.order) {
19 | prev = p;
20 | }
21 | } else if (p.order > current) {
22 | if (next == undefined || p.order < next.order) {
23 | next = p;
24 | }
25 | }
26 | });
27 | }
28 | }
29 | let el = '';
30 | if (prev || next) {
31 | el += '';
54 | }
55 | return el;
56 | }
57 | %>
58 | <%- layoutDiv(); %>
59 |
--------------------------------------------------------------------------------
/themes/stellar/layout/_partial/widgets/search.ejs:
--------------------------------------------------------------------------------
1 | <%
2 | function layoutDiv() {
3 | var el = ''
4 | el += ''
5 | el += '
'
6 | el += '
'
32 | el += '
'
33 | el += '
' + __('search.no_results') + '
'
34 | el += '
'
35 | el += '
'
36 | el += ''
37 | return el
38 | }
39 | %>
40 | <%- layoutDiv() %>
41 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/filters/lib/img_lazyload.js:
--------------------------------------------------------------------------------
1 | /**
2 | * img_lazyload.js v1 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | *
4 | */
5 |
6 | 'use strict';
7 |
8 | const fs = require('hexo-fs');
9 |
10 | function lazyProcess(htmlContent) {
11 | const cfg = this.theme.config.plugins.lazyload;
12 | if (cfg == undefined || cfg.enable != true) {
13 | return htmlContent;
14 | }
15 | return htmlContent.replace(/
/gi, function(imgTag, src_before, src_value, src_after) {
16 | // might be duplicate
17 | if (/data-srcset/gi.test(imgTag)) {
18 | return imgTag;
19 | }
20 | if (/src="data:image(.*?)/gi.test(imgTag)) {
21 | return imgTag;
22 | }
23 | if (imgTag.includes(' no-lazy ')) {
24 | return imgTag;
25 | }
26 | var newImgTag = imgTag;
27 | if (newImgTag.includes(' class="') == false) {
28 | newImgTag = newImgTag.slice(0,4) + ' class=""' + newImgTag.slice(4);
29 | }
30 | // class 中增加 lazy
31 | newImgTag = newImgTag.replace(/(.*?) class="(.*?)" (.*?)>/gi, function(ori, before, value, after){
32 | var newClass = value;
33 | if (newClass.length > 0) {
34 | newClass += ' ';
35 | }
36 | newClass += 'lazy';
37 | if (value) {
38 | return ori.replace('class="' + value, 'class="' + newClass);
39 | } else {
40 | return ori.replace('class="', 'class="' + newClass);
41 | }
42 | });
43 | // 加载图
44 | const loadingImg = '';
45 | newImgTag = newImgTag.replace(src_value, loadingImg + '" data-src="' + src_value);
46 | return newImgTag;
47 | });
48 | }
49 |
50 | module.exports.processSite = function(htmlContent) {
51 | return lazyProcess.call(this, htmlContent);
52 | };
53 |
--------------------------------------------------------------------------------
/themes/stellar/source/js/plugins/copycode.js:
--------------------------------------------------------------------------------
1 | const codeElementArr = document.querySelectorAll('.code')
2 | codeElementArr.forEach(code => {
3 | const codeBeforeWidth = window.getComputedStyle(code, '::before').width.split('px')[0]
4 | const codeBeforePadding = window.getComputedStyle(code, '::before').padding.split(' ').pop().split('px')[0]
5 |
6 | // copy btn
7 | const codeCopyBtn = document.createElement('div')
8 | codeCopyBtn.classList.add('copy-btn')
9 | codeCopyBtn.style.right = Number(codeBeforeWidth) + Number(codeBeforePadding) * 2 + 'px'
10 | codeCopyBtn.innerText = stellar.plugins.copycode.default_text
11 |
12 | code.appendChild(codeCopyBtn)
13 |
14 | codeCopyBtn.addEventListener('click', async () => {
15 | const currentCodeElement = code.children[0]?.innerText
16 | await copyCode(currentCodeElement)
17 |
18 | codeCopyBtn.innerText = stellar.plugins.copycode.success_text
19 | codeCopyBtn.classList.add('success')
20 |
21 | setTimeout(() => {
22 | codeCopyBtn.innerText = stellar.plugins.copycode.default_text
23 | codeCopyBtn.classList.remove('success')
24 | },3000)
25 | })
26 | })
27 |
28 | async function copyCode(currentCode) {
29 | // console.log(currentCode)
30 | // console.log('复制代码')
31 | if (navigator.clipboard) {
32 | try {
33 | await navigator.clipboard.writeText(currentCode)
34 | } catch (error) {
35 | // 未获得用户许可
36 | codeCopyBtn.innerText = '未获得用户许可'
37 | codeCopyBtn.classList.add('warning')
38 | setTimeout(() => {
39 | codeCopyBtn.innerText = stellar.plugins.copycode.default_text
40 | codeCopyBtn.classList.remove('warning')
41 | },3000)
42 | }
43 | } else {
44 | codeCopyBtn.innerText = '当前浏览器不支持此api'
45 | codeCopyBtn.classList.add('warning')
46 | setTimeout(() => {
47 | codeCopyBtn.innerText = stellar.plugins.copycode.default_text
48 | codeCopyBtn.classList.remove('warning')
49 | },3000)
50 | }
51 | }
--------------------------------------------------------------------------------
/source/wiki/volantis/index.md:
--------------------------------------------------------------------------------
1 | ---
2 | layout: wiki
3 | wiki: Volantis
4 | title: Volantis for Hexo
5 | ---
6 |
7 | Volantis 是一个高度模块化的 Hexo 主题,拥有丰富的内置标签和第三方插件支持,拥有庞大的开发者团队和年轻活跃的社区文化。得益于其强大的模块化特性,您可以轻松搭建一个极简风格的轻博客,也可以仿照社区主页搭建一个多人协作的、包含 wiki 的综合型站点。
8 |
9 | Volantis(瓦兰提斯)取名自《冰与火之歌》,寓意为自由。Volantis X 是 Volantis 社区文化的符号。在过去的 3 年里,30 余名开发者为其贡献了 1600+ commits,数以千计的用户为瓦兰提斯点亮了星星,50 余名来自各行各业的热情的小伙伴们参与了社区建设,因为大家的参与,Volantis 变得越来越强大和富有生命力。
10 |
11 | {% link https://volantis.js.org Volantis 中文社区 %}
12 |
13 | ## 开始之前
14 |
15 | 尽管我们致力于降低使用门槛,但是自建独立博客仍然需要一定的相关知识,[markdown](https://www.runoob.com/markdown/md-tutorial.html) 常用语法是必须要掌握的,除此之外,您还需要知道 `yaml` 文件格式、简单的 `git` 知识,最最重要的是,遇到问题知道该如何高效地寻找答案:
16 |
17 | 1. 翻阅和搜索文档
18 | 2. 搜索 issues 中是否已经有解决办法
19 | 3. 如果没有,新建 issue 并按照要求进行操作,详尽地描述您遇到的问题
20 |
21 | 如果您没有使用过 Hexo 也不要着急,可以先通读一遍 [Hexo](https://hexo.io/zh-cn/docs/) 中文文档,要想使用地得心应手,最好参照团队提供的开源项目的源码进行搭建:
22 |
23 | [Demo 源码](https://github.com/volantis-x/demo) | [官网源码](https://github.com/volantis-x/community)
24 |
25 | 如果您从旧版本更新或着其它主题迁移,请确保环境版本不要太低,否则会产生兼容性问题。
26 |
27 | ```yaml
28 | Hexo: 5.3.0
29 | hexo-cli: 4.2.0
30 | node.js: 14.15.4 LTS # 选 LTS 就行,过高的版本 hexo 还没有进行兼容。
31 | npm: 6.14.10 LTS
32 | ```
33 |
34 | ## 快速体验
35 |
36 | 如果您已经具备环境配置条件,可以在终端中输入下面这行代码,稍等片刻就可以看到示例站点已经运行起来了:
37 |
38 | {% copy git clone https://github.com/volantis-x/demo.git && cd demo && npm i && hexo s %}
39 |
40 | ## 下载与安装
41 |
42 | - 如果您是 Mac 用户,可以在博客路径打开终端,下载安装并应用主题:
43 | {% copy curl -s https://volantis.js.org/start | bash %}
44 |
45 | - 如果您是内容创作者,推荐使用 npm 稳定版本:
46 | {% copy npm i hexo-theme-volantis %}
47 |
48 | - 如果您需要定制主题,请 [fork](https://github.com/volantis-x/hexo-theme-volantis/) 主题,然后添加为子模块,详细教程如下:
49 | {% link https://github.com/volantis-x/hexo-theme-volantis/issues/459#issuecomment-679465906 如何正确地更新主题(Fork篇) %}
50 | {% note color:orange 温馨提示 请一定不要直接下载源码并进行修改使用,因为这样会导致**失去版本管理系统**且**无法获得更新**。 %}
51 |
52 | ## 配置与使用
53 |
54 | 完整而详细的文档请移步瓦兰提斯社区查看:
55 |
56 | {% link https://volantis.js.org/v4/site-settings/ 配置与使用 %}
57 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/tags/lib/tabs.js:
--------------------------------------------------------------------------------
1 | /**
2 | * tabs.js v2 | 基于NexT修改: https://theme-next.js.org/docs/tag-plugins/tabs
3 | */
4 |
5 | 'use strict'
6 |
7 | var tab_index = 0
8 |
9 | module.exports = ctx => function(args, content = '') {
10 | var arr = content.split(//g).filter(item => item.trim().length > 0)
11 | if (arr.length < 1) {
12 | return ''
13 | }
14 | var tabs = []
15 | arr.forEach((item, i) => {
16 | if (i % 2 == 0) {
17 | tabs.push({
18 | header: item
19 | })
20 | } else if (tabs.length > 0) {
21 | var tab = tabs[tabs.length-1]
22 | if (tab.body == undefined) {
23 | tab.body = item
24 | } else {
25 | tab.body += '\n' + item
26 | }
27 | }
28 | })
29 |
30 | args = ctx.args.map(args, ['active', 'align'])
31 | const tabName = 'tab_' + ++tab_index
32 | const tabActive = Number(args.active) || 0
33 |
34 | let tabId = 0
35 | let tabNav = ''
36 | let tabContent = ''
37 | tabs.forEach((tab, i) => {
38 | let content = ctx.render.renderSync({ text: (tab.body || ''), engine: 'markdown' }).trim()
39 | const abbr = tabName + ' ' + ++tabId
40 | const href = abbr.toLowerCase().split(' ').join('-')
41 | const isActive = (tabActive > 0 && tabActive === tabId) || (tabActive === 0 && tabId === 1) ? ' active' : ''
42 | tabNav += ``
43 | tabContent += `${content}
`
44 | })
45 |
46 | tabNav = `${tabNav}
`
47 | tabContent = `${tabContent}
`
48 |
49 | var el = ''
50 | el += ''
56 | el += tabNav + tabContent
57 | el += '
'
58 | return el
59 | }
60 |
--------------------------------------------------------------------------------
/themes/stellar/source/css/_plugins/comments/waline.styl:
--------------------------------------------------------------------------------
1 | .cmt-body.waline
2 | .wl-panel
3 | margin: 0.5em 0 !important
4 | .wl-meta-head
5 | padding: 0 !important
6 | --waline-font-size: 0.9375rem;
7 | /* 常规颜色 */
8 | --waline-white: #fff;
9 | --waline-light-grey: #999;
10 | --waline-dark-grey: #666;
11 | /* 主题色 */
12 | --waline-theme-color: $color-theme;
13 | --waline-active-color: $color-hover;
14 | /* 布局颜色 */
15 | --waline-color: #444;
16 | --waline-bgcolor: #fff;
17 | --waline-bgcolor-light: #f8f8f8;
18 | --waline-bgcolor-hover: #f0f0f0;
19 | --waline-border-color: #ddd;
20 | --waline-disable-bgcolor: #f8f8f8;
21 | --waline-disable-color: #bbb;
22 | --waline-code-bgcolor: #282c34;
23 | /* 特殊颜色 */
24 | --waline-bq-color: #f0f0f0;
25 | /* 头像 */
26 | --waline-avatar-size: 3.25rem;
27 | --waline-m-avatar-size: calc(var(--waline-avatar-size) * 9 / 13);
28 | /* 徽章 */
29 | --waline-badge-color: #3498db;
30 | --waline-badge-font-size: 0.725em;
31 | /* 信息 */
32 | --waline-info-bgcolor: #f8f8f8;
33 | --waline-info-color: #999;
34 | --waline-info-font-size: 0.725em;
35 | /* 渲染选择 */
36 | --waline-border: 1px solid var(--waline-border-color);
37 | --waline-avatar-radius: 50%;
38 | --waline-box-shadow: none;
39 |
40 |
41 | @media (prefers-color-scheme: dark)
42 | --waline-white: #000;
43 | --waline-light-grey: #666;
44 | --waline-dark-grey: #999;
45 | /* 布局颜色 */
46 |
47 | --waline-color: #fff;
48 | --waline-bgcolor: var(--block);
49 | --waline-bgcolor-light: #272727;
50 | --waline-border-color: #333;
51 | --waline-disable-bgcolor: #444;
52 | --waline-disable-color: #272727;
53 | /* 特殊颜色 */
54 | --waline-bq-color: #272727;
55 | /* 其他颜色 */
56 | --waline-info-bgcolor: #272727;
57 | --waline-info-color: #666;
58 |
59 | .wl-count
60 | @media (prefers-color-scheme: dark)
61 | padding: .375em;
62 | font-weight: bold;
63 | font-size: 1.25em;
64 | color: #fff;
65 |
66 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/tags/index.js:
--------------------------------------------------------------------------------
1 | /* global hexo */
2 |
3 | 'use strict';
4 |
5 | // container
6 | hexo.extend.tag.register('tabs', require('./lib/tabs')(hexo), true)
7 | hexo.extend.tag.register('ablock', require('./lib/ablock')(hexo), true)
8 | hexo.extend.tag.register('about', require('./lib/about')(hexo), true)
9 | hexo.extend.tag.register('folding', require('./lib/folding')(hexo), true)
10 | hexo.extend.tag.register('folders', require('./lib/folders')(hexo), true)
11 | hexo.extend.tag.register('grid', require('./lib/grid')(hexo), true)
12 | hexo.extend.tag.register('swiper', require('./lib/swiper')(hexo), true)
13 |
14 | // data
15 | hexo.extend.tag.register('users', require('./lib/friends')(hexo))
16 | hexo.extend.tag.register('friends', require('./lib/friends')(hexo))
17 | hexo.extend.tag.register('sites', require('./lib/sites')(hexo))
18 | hexo.extend.tag.register('ghcard', require('./lib/ghcard')(hexo))
19 | hexo.extend.tag.register('toc', require('./lib/toc')(hexo))
20 | hexo.extend.tag.register('timeline', require('./lib/timeline')(hexo), {ends: true})
21 |
22 | // express
23 | hexo.extend.tag.register('checkbox', require('./lib/checkbox')(hexo, 'checkbox'))
24 | hexo.extend.tag.register('radio', require('./lib/checkbox')(hexo, 'radio'))
25 | hexo.extend.tag.register('copy', require('./lib/copy')(hexo))
26 | hexo.extend.tag.register('emoji', require('./lib/emoji')(hexo))
27 | hexo.extend.tag.register('frame', require('./lib/frame')(hexo))
28 | hexo.extend.tag.register('image', require('./lib/image')(hexo))
29 | hexo.extend.tag.register('link', require('./lib/link')(hexo))
30 | hexo.extend.tag.register('mark', require('./lib/mark')(hexo))
31 | hexo.extend.tag.register('navbar', require('./lib/navbar')(hexo))
32 | hexo.extend.tag.register('note', require('./lib/note')(hexo))
33 | hexo.extend.tag.register('poetry', require('./lib/poetry')(hexo), true)
34 | hexo.extend.tag.register('quot', require('./lib/quot')(hexo))
35 | hexo.extend.tag.register('tag', require('./lib/tag')(hexo))
36 |
37 | // others
38 |
--------------------------------------------------------------------------------
/themes/stellar/_data/widgets.yml:
--------------------------------------------------------------------------------
1 | # 您可以在这里创建属于自己的侧边栏组件库,在需要的位置放置自己的组件
2 | # layout即组件布局,支持自定义的有:
3 | # - markdown: 渲染 md 文本
4 | #
5 | search:
6 | layout: search
7 | filter: auto # auto or 'path'
8 |
9 |
10 | search_blog:
11 | layout: search
12 | filter: /blog/ # auto or 'path'
13 | placeholder: 文章搜索
14 |
15 | search_docs:
16 | layout: search
17 | filter: /wiki/ # auto or 'path'
18 | placeholder: 文档搜索
19 |
20 | ghrepo:
21 | layout: ghrepo
22 | related:
23 | layout: related
24 |
25 | ghissues:
26 | layout: ghissues
27 | title: # Recent Issues
28 | limit: 3 # 显示的issues最大数量
29 | labels: # 过滤只显示具有某些标签的issues
30 |
31 | # 将其覆盖设置为空,可删除一个默认组件,例如 welcome:
32 | # Recent update
33 | recent:
34 | layout: recent
35 | rss: # /atom.xml # npm i hexo-generator-feed
36 | limit: 5 # Count of posts
37 | # TOC (valid only in layout:post/wiki)
38 | toc:
39 | layout: toc
40 | list_number: false
41 | min_depth: 2
42 | max_depth: 5
43 | fallback: recent # Use a backup widget when toc does not exist.
44 | # github user info
45 | ghuser:
46 | layout: ghuser
47 | username: github # your github login username
48 | avatar: true # show avatar or not
49 | menu: true # show menu or not
50 |
51 | tagcloud:
52 | layout: tagcloud
53 | title: 标签云
54 | # 标签云配置
55 | min_font: 12
56 | max_font: 24
57 | amount: 100
58 | orderby: name
59 | order: 1 # 1, sac 升序;-1, desc 降序
60 | color: false # 使用颜色
61 | start_color: # 开始的颜色。您可使用十六进位值(#b700ff),rgba(rgba(183, 0, 255, 1)),hsla(hsla(283, 100%, 50%, 1))或 颜色关键字。此变量仅在 color 参数开启时才有用。
62 | end_color: # 结束的颜色。您可使用十六进位值(#b700ff),rgba(rgba(183, 0, 255, 1)),hsla(hsla(283, 100%, 50%, 1))或 颜色关键字。此变量仅在 color 参数开启时才有用。
63 | show_count: false # 显示每个标签的文章总数
64 |
65 | timeline:
66 | layout: timeline
67 | title: 近期动态
68 | api: # https://api.github.com/repos/xaoxuu/hexo-theme-stellar/issues
69 | user: # 默认显示所有人的数据,设置名称可过滤为仅显示某人的数据,多个名称用英文逗号隔开,不要加空格
70 | type: # 默认不用写,如果是友链朋友圈数据请写 fcircle
71 | limit: # 默认通过 api 上增加 per_page 来设置,如果是友链朋友圈,可通过这个设置数量
72 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/events/lib/config.js:
--------------------------------------------------------------------------------
1 | /**
2 | * 部分代码借鉴自 NexT:
3 | * https://github.com/next-theme/hexo-theme-next/blob/master/scripts/events/lib/config.js
4 | * Volantis:
5 | * https://github.com/volantis-x/hexo-theme-volantis/blob/master/scripts/events/lib/cdn.js
6 | */
7 |
8 | 'use strict';
9 |
10 | const path = require('path');
11 |
12 | module.exports = hexo => {
13 |
14 | const { cache, language_switcher } = hexo.theme.config;
15 | const warning = function(...args) {
16 | hexo.log.warn(`Since ${args[0]} is turned on, the ${args[1]} is disabled to avoid potential hazards.`);
17 | };
18 |
19 | if (cache && cache.enable && language_switcher) {
20 | warning('language_switcher', 'caching');
21 | cache.enable = false;
22 | }
23 |
24 | if (cache && cache.enable && hexo.config.relative_link) {
25 | warning('caching', '`relative_link` option in Hexo `_config.yml`');
26 | hexo.config.relative_link = false;
27 | }
28 | // hexo.config.meta_generator = false;
29 |
30 | // merge data
31 | const data = hexo.locals.get('data');
32 | // merge widgets
33 | var widgets = hexo.render.renderSync({ path: path.join(hexo.theme_dir, '_data/widgets.yml'), engine: 'yaml' });
34 | if (data.widgets) {
35 | for (let i of Object.keys(data.widgets)) {
36 | let widget = data.widgets[i];
37 | if (widget == null || widget.length == 0) {
38 | // delete
39 | delete widgets[i];
40 | } else {
41 | // create
42 | if (widgets[i] == null) {
43 | widgets[i] = widget;
44 | } else {
45 | // merge
46 | for (let j of Object.keys(widget)) {
47 | widgets[i][j] = widget[j];
48 | }
49 | }
50 | }
51 | }
52 | }
53 | if (hexo.theme.config.data == undefined) {
54 | hexo.theme.config.data = {};
55 | }
56 | hexo.theme.config.data['widgets'] = widgets;
57 |
58 | // default menu
59 | if (hexo.theme.config.sidebar.menu == undefined) {
60 | hexo.theme.config.sidebar.menu = [];
61 | }
62 |
63 | };
64 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/tags/lib/frame.js:
--------------------------------------------------------------------------------
1 | /**
2 | * frame.js v1 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | * 格式与官方标签插件一致使用空格分隔,中括号内的是可选参数(中括号不需要写出来)
4 | *
5 | * {% frame iphone11 [img:src] [video:url] [focus:top/bottom] [alt] %}
6 | */
7 |
8 | 'use strict'
9 |
10 | module.exports = ctx => function(args) {
11 | args = ctx.args.map(args, ['focus', 'img', 'video'], ['device', 'alt'])
12 | const img = args.img || ''
13 | const video = args.video || ''
14 | const device = args.device || ''
15 | const focus = args.focus || ''
16 | const alt = args.alt || ''
17 | if ((img.length == 0 && video.length == 0) || device.length == 0) {
18 | return
19 | }
20 | var el = ''
21 | function imgTag(url, alt) {
22 | let i = ''
23 | i += '
0) {
25 | i += ' alt="' + alt + '"'
26 | }
27 | i += '/>'
28 | return i
29 | }
30 | if (video.length > 0) {
31 | el += ''
32 | el += '
0) {
34 | el += 'focus="' + focus + '">'
35 | } else {
36 | el += '>'
37 | }
38 | el += '
'
45 |
46 | el += '
'
47 | el += '
'
48 | el += '
'
49 | } else if (img.length > 0) {
50 | el += ''
51 | el += '
0) {
53 | el += 'focus="' + focus + '">'
54 | } else {
55 | el += '>'
56 | }
57 | el += imgTag(img, alt)
58 | el += '
'
59 | el += '
'
60 | if (alt.length > 0) {
61 | el += '
' + alt + ''
62 | }
63 | el += '
'
64 | }
65 | return el
66 | }
67 |
--------------------------------------------------------------------------------
/themes/stellar/scripts/tags/lib/toc.js:
--------------------------------------------------------------------------------
1 | /**
2 | * toc.js v1 | https://github.com/xaoxuu/hexo-theme-stellar/
3 | * 格式与官方标签插件一致使用空格分隔,中括号内的是可选参数(中括号不需要写出来)
4 | *
5 | * {% toc wiki:xxx [title] [open:true] [display:mobile] %}
6 | */
7 |
8 | 'use strict'
9 |
10 | function layoutDocTree(ctx, pages) {
11 | const url_for = require('hexo-util').url_for.bind(ctx)
12 | var el = ''
13 | el += ''
22 | return el
23 | }
24 |
25 | module.exports = ctx => function(args) {
26 | args = ctx.args.map(args, ['wiki', 'open', 'display'], ['title'])
27 |
28 | var el = ''
29 | el += ''
35 |
36 | el += '
'
41 | el += ''
42 | el += args.title || 'TOC'
43 | el += '
'
44 |
45 | if (args.wiki) {
46 | const proj = ctx.theme.config.wiki.projects[args.wiki]
47 | if (proj == undefined) {
48 | return ''
49 | }
50 | if (proj.sections && proj.sections.length > 1) {
51 | el += ''
52 | proj.sections.forEach((sec, i) => {
53 | el += ''
54 | el += ''
57 | el += layoutDocTree(ctx, sec.pages)
58 | el += ''
59 | })
60 | el += '
'
61 | } else {
62 | el += ''
63 | el += '
'
64 | el += layoutDocTree(ctx, proj.pages)
65 | el += '
'
66 | el += '
'
67 | }
68 | }
69 | el += ' '
70 | // end
71 | el += '
'
72 | return el
73 | }
--------------------------------------------------------------------------------
/source/wiki/prohud/index.md:
--------------------------------------------------------------------------------
1 | ---
2 | layout: wiki
3 | wiki: ProHUD
4 | title: 为什么选择 ProHUD
5 | ---
6 |
7 |
8 | ## 易于上手
9 |
10 | 您可以用相似的接口调用 Toast、Alert、Guard,发布一则通知或者弹窗可以简单到一行代码:
11 |
12 | ```swift
13 | Toast.push(title: "Hello World", message: "This is a test message from ProHUD.")
14 | ```
15 |
16 |
17 | {% frame iphone11 img:https://fastly.jsdelivr.net/gh/cdn-x/wiki/prohud/docs/toast-helloword@2x.jpg focus:top %}
18 |
19 | 您可能好奇上方的图标从何而来,别着急,后面的「场景及其扩展」章节将会告诉您如何自定义一个实例的默认效果。
20 |
21 |
22 | ## 功能强大
23 |
24 | ProHUD 对每个实例记录 ID ,您只需要知道它的 ID 就可以随时修改它,例如把「正在加载」修改为「加载成功」。ProHUD 改善了传统弹窗类控件重叠的糟糕体验,如果您无法保证业务上万无一失,那么能够优雅处理极端场景的 ProHUD 就能够帮助您避免意外,关于这部分,详见「[如何避免重叠](/wiki/prohud/alert/#如何避免重叠)」。此外,ProHUD 容器对横屏和 iPad 也做了优化,使得您的应用能够适应多种场景。
25 |
26 | ## 样式与逻辑分离
27 |
28 | 在程序初始化时配置样式,调用的地方只需要专注于业务逻辑。ProHUD 提供了「场景」模板特性,可以更加统一高效地规划这些控件的样式。ProHUD 的 UI 与逻辑分离,这就意味着您可以自由的在 ProHUD 容器中设计您的 UI 样式而无需处理控件逻辑问题。如果您不打算重新设计 UI ,使用默认提供的样式也可以轻松调整字体、颜色、边距等细节,新增「场景」模板。
29 |
30 | {% swiper width:min %}
31 | 
32 | 
33 | 
34 | 
35 | 
36 | 
37 | 
38 | 
39 | 
40 | 
41 | {% endswiper %}
42 |
43 | 对横屏也进行了适配:
44 |
45 | {% swiper width:max %}
46 | 
47 | 
48 | 
49 | {% endswiper %}
50 |
--------------------------------------------------------------------------------
/source/wiki/resume/index.md:
--------------------------------------------------------------------------------
1 | ---
2 | layout: wiki
3 | wiki: Resume
4 | title: 一个简约的在线简历主题
5 | ---
6 |
7 | {% link https://resume.js.org/zh-cn/ 在线演示 %}
8 | {% link https://github.com/xaoxuu/hexo-theme-resume 主题源码 %}
9 |
10 |
11 |
12 | ## 如何使用
13 |
14 | ### 方式一
15 |
16 | 1. 下载 [示例源码](https://github.com/xaoxuu/resume-docs) 的整个仓库代码。
17 | ```sh
18 | git clone https://github.com/xaoxuu/resume-docs
19 | ```
20 |
21 | 2. 然后安装必要的依赖包
22 | ```sh
23 | npm i
24 | ```
25 |
26 |
27 | ### 方式二
28 |
29 | 创建全新的博客,通过 `npm` 命令安装:
30 |
31 | ```bash
32 | npm i hexo-theme-resume
33 | ```
34 |
35 | 然后删除多余的依赖包(重要),打开 `package.json` 复制并全部替换为以下内容:
36 |
37 | ```json
38 | {
39 | "name": "hexo-site",
40 | "private": true,
41 | "hexo": {
42 | "version": "5.0.0"
43 | },
44 | "scripts": {
45 | "start": "hexo server",
46 | "build": "node pre-deploy.js && hexo clean && hexo generate",
47 | "deploy": "npm run build && hexo deploy"
48 | },
49 | "engines": {
50 | "node": ">=8.9.0"
51 | },
52 | "dependencies": {
53 | "hexo": "^5.0.0",
54 | "hexo-all-minifier": "^0.5.3",
55 | "hexo-autonofollow": "^1.0.1",
56 | "hexo-deployer-git": "^2.1.0",
57 | "hexo-fs": "^3.1.0",
58 | "hexo-lazyload-image": "^1.0.9",
59 | "hexo-offline": "^1.0.0",
60 | "hexo-renderer-ejs": "^1.0.0",
61 | "hexo-renderer-marked": "^3.0.0",
62 | "hexo-renderer-stylus": "^1.1.0",
63 | "hexo-server": "^1.0.0"
64 | }
65 | }
66 | ```
67 |
68 | 然后输入 `npm i` 安装依赖包。
69 |
70 |
71 | ## 编写简历
72 |
73 | 打开 `index.md` 文件:
74 | ```
75 | resume-docs/src/index.md
76 | ```
77 |
78 | 按照示例中的提示语将信息修改为自己的。
79 |
80 | ## 部署
81 |
82 | 打开站点配置文件:
83 | ```yaml resume-docs/_config.yaml
84 | deploy:
85 | - type: git
86 | repo: # 项目路径
87 | branch: master
88 | message: update pages
89 | ```
90 |
91 | Hexo官方教程: https://hexo.io/zh-cn/docs/one-command-deployment
92 |
93 | {% grid 小提示 %}
94 |
95 | 图标从这里找:https://fontawesome.com/
96 | 如果需要更多DIY,请自行修改源码。
97 | 简历主题不支持评论,如果需要,请自行集成。
98 |
99 | {% endgrid %}
100 |
--------------------------------------------------------------------------------
/source/wiki/heartmate/index.md:
--------------------------------------------------------------------------------
1 | ---
2 | layout: wiki
3 | wiki: heartmate
4 | title: 心率管家
5 | h1: 心率管家:一个简单易用的掌上心率计
6 | references:
7 | - title: 心率管家 App 的设计与开发流程
8 | url: /blog/2019-07-23-heartmate
9 | ---
10 |
11 | 专为那些没有智能手环或手表却需要测量心率的用户而设计,可以方便快捷的测量和记录心率。 使用Heart Mate心率助手,你可以在没有智能手环等心率监测设备的情况下随时检测并记录自己的心率。 通过设置tag标签,快速记录当前状态,如饭后、运动后等,方便以后检索具有同样标签的心率数据,从而分析这些情景下的心率数据,发现健康问题。
12 |
13 |
14 |
15 | {% swiper width:min %}
16 | 
17 | 
18 | 
19 | 
20 | 
21 | 
22 | {% endswiper %}
23 |
24 |
25 |
26 | 心率管家App(仅iOS端),专业版不定期限免,欢迎下载体验。
27 |
28 | 如果您看到的时候已经过了限免期,可以先下载免费版使用。为了吸引app推荐类网站的爬虫进行推荐,专业版的价格通常在1元到68元之间浮动变化的。
29 |
30 | ## 下载安装
31 |
32 | {% link https://apps.apple.com/cn/app/heart-mate-lite-hrm-utility/id1475747930?ls=1 心率管家(免费版) %}
33 |
34 | {% link https://apps.apple.com/cn/app/heart-mate-lite-hrm-utility/id1463348922?ls=1 心率管家(专业版) %}
35 |
36 | ## 如何测量
37 |
38 | {% frame iphone11 img:https://fastly.jsdelivr.net/gh/cdn-x/wiki/heartmate/docs/usage01.jpg video:https://fastly.jsdelivr.net/gh/cdn-x/wiki/heartmate/docs/usage01.mp4 focus:top %}
39 |
40 | ### 第一步,调整位置
41 |
42 | 请用一只手指同时按住手机后方的摄像头和闪光灯,调整遮挡的位置使上方的取景器看起来是红色的。
43 |
44 | ### 第二步,保持不动
45 |
46 | 太好了,现在手指尽量不要动,请等待数据稳定,这大概需要10秒钟。
47 |
48 | ### 第三步,继续保持不动
49 |
50 | 正在采集数据,马上就要成功了,手指请继续保持不动。
51 |
52 | ### 第四步,请松开手
53 |
54 | 恭喜您,测量已经完成,您可以松开手指结束此次测量,也可以保持不动继续测量更长时间以提高准确性。
55 |
56 | > App内部有详细的使用帮助。
57 |
58 |
59 | ## 近期限免日程
60 |
61 | 
62 |
63 | 付费真不是为了赚钱,是为了骗应用推荐类网站的爬虫给我做推广,同时这样也减少了免费时的莫名其妙的大量差评。已经高价购买的用户实在是抱歉,我的其它 App 也会采用类似的定价策略,所以请多多关注我的博客,能省下不少钱呢。
64 |
65 |
66 | ## 安装测试版
67 |
68 | 安装地址:https://testflight.apple.com/join/rqNjAxg1
69 |
--------------------------------------------------------------------------------
/_config.stellar.yml:
--------------------------------------------------------------------------------
1 | sidebar:
2 | menu:
3 | post: '[博客](/)'
4 | wiki: '[项目](/wiki/)'
5 | notes: '[便笺](/notes/)'
6 | more: '[更多](/about/)'
7 | widgets:
8 | # Recent update
9 | recent:
10 | rss: /atom.xml # npm i hexo-generator-feed
11 |
12 | article:
13 | # 分类颜色
14 | category_color:
15 | '新闻稿': '#DA0F47'
16 | '设计开发': '#03a9f4'
17 | # '奇思妙想': '#009688'
18 | '解决方案': '#ff9800'
19 | '技术加油站': '#4caf50'
20 | '开源库': '#4caf50'
21 | '博客主题': '#ffa000'
22 | # '应用程序': '#e91e63'
23 | # '实用脚本': '#009688'
24 | share: [wechat, weibo, email, link]
25 | related_posts:
26 | enable: true
27 | auto_cover: false
28 |
29 | comments:
30 | service: beaudar
31 | beaudar:
32 | repo: xaoxuu/blog-comments
33 |
34 | footer:
35 | social:
36 | github:
37 | icon: '
'
38 | url: https://github.com/xaoxuu
39 | music:
40 | icon: '
'
41 | url: https://music.163.com/#/user/home?id=63035382
42 | unsplash:
43 | icon: '
'
44 | url: https://unsplash.com/@xaoxuu
45 | comments:
46 | icon: '
'
47 | url: /about/#comments
48 | sitemap:
49 | '博客':
50 | - '[近期](/)'
51 | - '[分类](/blog/categories/)'
52 | - '[标签](/blog/tags/)'
53 | - '[归档](/blog/archives/)'
54 | '项目':
55 | - '[开源库](/wiki/tags/开源库/)'
56 | - '[实用脚本](/wiki/tags/实用脚本/)'
57 | - '[博客主题](/wiki/tags/博客主题/)'
58 | - '[应用程序](/wiki/tags/应用程序/)'
59 | '社交':
60 | - '[友链](/friends/)'
61 | - '[留言板](/about/#comments)'
62 | '更多':
63 | - '[关于本站](/about/)'
64 | - '[GitHub](https://github.com/xaoxuu)'
65 | - '[GitLab](http://42.192.89.158:8099/explore)'
66 | source: '[GitHub](https://github.com/xaoxuu/xaoxuu.github.io/)'
67 |
68 |
69 | style:
70 | codeblock:
71 | scrollbar: 0px
72 |
--------------------------------------------------------------------------------