mirror of
				https://github.com/cotes2020/chirpy-starter.git
				synced 2025-10-22 13:10:41 +10:00 
			
		
		
		
	Compare commits
	
		
			24 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 0fad01a57b | ||
|   | 1d4e1a21b4 | ||
|   | 051518182c | ||
|   | 46e2bdfa6e | ||
|   | 1d4d35af85 | ||
|   | aa0fd48ad0 | ||
|   | 333ce4603e | ||
|   | 59ad287fb0 | ||
|   | 7ab45bd41f | ||
|   | 6ae7825809 | ||
|   | 00252fd7b8 | ||
|   | 32f4cbe2f7 | ||
|   | 88378f6169 | ||
|   | 586b285258 | ||
|   | c403568b4c | ||
|   | b8605de1ba | ||
|   | 953dbb08e3 | ||
|   | b160f258a0 | ||
|   | 8486ea4ae4 | ||
|   | 756d37c648 | ||
|   | d03f0bbcc7 | ||
|   | 1efe631e7e | ||
|   | 1565392b7e | ||
|   | aea4a8fc59 | 
							
								
								
									
										29
									
								
								.devcontainer/devcontainer.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								.devcontainer/devcontainer.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | |||||||
|  | { | ||||||
|  |   "name": "Jekyll", | ||||||
|  |   "image": "mcr.microsoft.com/devcontainers/jekyll:2-bullseye", | ||||||
|  |   "onCreateCommand": "git config --global --add safe.directory ${containerWorkspaceFolder}", | ||||||
|  |   "postCreateCommand": "bash .devcontainer/post-create.sh", | ||||||
|  |   "customizations": { | ||||||
|  |     "vscode": { | ||||||
|  |       "settings": { | ||||||
|  |         "terminal.integrated.defaultProfile.linux": "zsh" | ||||||
|  |       }, | ||||||
|  |       "extensions": [ | ||||||
|  |         // Liquid tags auto-complete | ||||||
|  |         "killalau.vscode-liquid-snippets", | ||||||
|  |         // Liquid syntax highlighting and formatting | ||||||
|  |         "Shopify.theme-check-vscode", | ||||||
|  |         // Shell | ||||||
|  |         "timonwong.shellcheck", | ||||||
|  |         "mkhl.shfmt", | ||||||
|  |         // Common formatter | ||||||
|  |         "EditorConfig.EditorConfig", | ||||||
|  |         "esbenp.prettier-vscode", | ||||||
|  |         "stylelint.vscode-stylelint", | ||||||
|  |         "yzhang.markdown-all-in-one", | ||||||
|  |         // Git | ||||||
|  |         "mhutchie.git-graph" | ||||||
|  |       ] | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										18
									
								
								.devcontainer/post-create.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								.devcontainer/post-create.sh
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | |||||||
|  | #!/usr/bin/env bash | ||||||
|  |  | ||||||
|  | if [ -f package.json ]; then | ||||||
|  |   bash -i -c "nvm install --lts && nvm install-latest-npm" | ||||||
|  |   npm i | ||||||
|  |   npm run build | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | # Install dependencies for shfmt extension | ||||||
|  | curl -sS https://webi.sh/shfmt | sh &>/dev/null | ||||||
|  |  | ||||||
|  | # Add OMZ plugins | ||||||
|  | git clone https://github.com/zsh-users/zsh-syntax-highlighting.git ~/.oh-my-zsh/custom/plugins/zsh-syntax-highlighting | ||||||
|  | git clone https://github.com/zsh-users/zsh-autosuggestions ~/.oh-my-zsh/custom/plugins/zsh-autosuggestions | ||||||
|  | sed -i -E "s/^(plugins=\()(git)(\))/\1\2 zsh-syntax-highlighting zsh-autosuggestions\3/" ~/.zshrc | ||||||
|  |  | ||||||
|  | # Avoid git log use less | ||||||
|  | echo -e "\nunset LESS" >>~/.zshrc | ||||||
							
								
								
									
										10
									
								
								.github/workflows/pages-deploy.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										10
									
								
								.github/workflows/pages-deploy.yml
									
									
									
									
										vendored
									
									
								
							| @@ -37,12 +37,12 @@ jobs: | |||||||
|  |  | ||||||
|       - name: Setup Pages |       - name: Setup Pages | ||||||
|         id: pages |         id: pages | ||||||
|         uses: actions/configure-pages@v3 |         uses: actions/configure-pages@v4 | ||||||
|  |  | ||||||
|       - name: Setup Ruby |       - name: Setup Ruby | ||||||
|         uses: ruby/setup-ruby@v1 |         uses: ruby/setup-ruby@v1 | ||||||
|         with: |         with: | ||||||
|           ruby-version: 3 |           ruby-version: 3.3 | ||||||
|           bundler-cache: true |           bundler-cache: true | ||||||
|  |  | ||||||
|       - name: Build site |       - name: Build site | ||||||
| @@ -53,11 +53,11 @@ jobs: | |||||||
|       - name: Test site |       - name: Test site | ||||||
|         run: | |         run: | | ||||||
|           bundle exec htmlproofer _site \ |           bundle exec htmlproofer _site \ | ||||||
|             \-\-disable-external=true \ |             \-\-disable-external \ | ||||||
|             \-\-ignore-urls "/^http:\/\/127.0.0.1/,/^http:\/\/0.0.0.0/,/^http:\/\/localhost/" |             \-\-ignore-urls "/^http:\/\/127.0.0.1/,/^http:\/\/0.0.0.0/,/^http:\/\/localhost/" | ||||||
|  |  | ||||||
|       - name: Upload site artifact |       - name: Upload site artifact | ||||||
|         uses: actions/upload-pages-artifact@v1 |         uses: actions/upload-pages-artifact@v3 | ||||||
|         with: |         with: | ||||||
|           path: "_site${{ steps.pages.outputs.base_path }}" |           path: "_site${{ steps.pages.outputs.base_path }}" | ||||||
|  |  | ||||||
| @@ -70,4 +70,4 @@ jobs: | |||||||
|     steps: |     steps: | ||||||
|       - name: Deploy to GitHub Pages |       - name: Deploy to GitHub Pages | ||||||
|         id: deployment |         id: deployment | ||||||
|         uses: actions/deploy-pages@v2 |         uses: actions/deploy-pages@v4 | ||||||
|   | |||||||
							
								
								
									
										7
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -5,6 +5,7 @@ Gemfile.lock | |||||||
|  |  | ||||||
| # Jekyll cache | # Jekyll cache | ||||||
| .jekyll-cache | .jekyll-cache | ||||||
|  | .jekyll-metadata | ||||||
| _site | _site | ||||||
|  |  | ||||||
| # RubyGems | # RubyGems | ||||||
| @@ -16,7 +17,11 @@ package-lock.json | |||||||
|  |  | ||||||
| # IDE configurations | # IDE configurations | ||||||
| .idea | .idea | ||||||
| .vscode | .vscode/* | ||||||
|  | !.vscode/settings.json | ||||||
|  | !.vscode/extensions.json | ||||||
|  | !.vscode/tasks.json | ||||||
|  |  | ||||||
| # Misc | # Misc | ||||||
|  | _sass/vendors | ||||||
| assets/js/dist | assets/js/dist | ||||||
|   | |||||||
							
								
								
									
										3
									
								
								.vscode/extensions.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								.vscode/extensions.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | |||||||
|  | { | ||||||
|  |   "recommendations": ["ms-vscode-remote.remote-containers"] | ||||||
|  | } | ||||||
							
								
								
									
										30
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,30 @@ | |||||||
|  | { | ||||||
|  |   // Prettier | ||||||
|  |   "editor.defaultFormatter": "esbenp.prettier-vscode", | ||||||
|  |   "editor.formatOnSave": true, | ||||||
|  |   // Shopify Liquid | ||||||
|  |   "files.associations": { | ||||||
|  |     "*.html": "liquid" | ||||||
|  |   }, | ||||||
|  |   "[markdown]": { | ||||||
|  |     "editor.defaultFormatter": "yzhang.markdown-all-in-one" | ||||||
|  |   }, | ||||||
|  |   // Formatter | ||||||
|  |   "[html][liquid]": { | ||||||
|  |     "editor.defaultFormatter": "Shopify.theme-check-vscode" | ||||||
|  |   }, | ||||||
|  |   "[shellscript]": { | ||||||
|  |     "editor.defaultFormatter": "mkhl.shfmt" | ||||||
|  |   }, | ||||||
|  |   // Disable vscode built-in stylelint | ||||||
|  |   "css.validate": false, | ||||||
|  |   "scss.validate": false, | ||||||
|  |   "less.validate": false, | ||||||
|  |   // Stylint extension settings | ||||||
|  |   "stylelint.snippet": ["css", "scss"], | ||||||
|  |   "stylelint.validate": ["css", "scss"], | ||||||
|  |   // Run tasks in macOS | ||||||
|  |   "terminal.integrated.profiles.osx": { | ||||||
|  |     "zsh": { "path": "/bin/zsh", "args": ["-l", "-i"] } | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										26
									
								
								.vscode/tasks.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								.vscode/tasks.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | |||||||
|  | { | ||||||
|  |   "version": "2.0.0", | ||||||
|  |   "tasks": [ | ||||||
|  |     { | ||||||
|  |       "label": "Run Jekyll Server", | ||||||
|  |       "type": "shell", | ||||||
|  |       "command": "./tools/run.sh", | ||||||
|  |       "group": { | ||||||
|  |         "kind": "build", | ||||||
|  |         "isDefault": true | ||||||
|  |       }, | ||||||
|  |       "problemMatcher": [], | ||||||
|  |       "detail": "Runs the Jekyll server with live reload." | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "label": "Build Jekyll Site", | ||||||
|  |       "type": "shell", | ||||||
|  |       "command": "./tools/test.sh", | ||||||
|  |       "group": { | ||||||
|  |         "kind": "build" | ||||||
|  |       }, | ||||||
|  |       "problemMatcher": [], | ||||||
|  |       "detail": "Build the Jekyll site for production." | ||||||
|  |     } | ||||||
|  |   ] | ||||||
|  | } | ||||||
							
								
								
									
										15
									
								
								Gemfile
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								Gemfile
									
									
									
									
									
								
							| @@ -2,22 +2,13 @@ | |||||||
|  |  | ||||||
| source "https://rubygems.org" | source "https://rubygems.org" | ||||||
|  |  | ||||||
| gem "jekyll-theme-chirpy", "~> 6.2", ">= 6.2.3" | gem "jekyll-theme-chirpy", "~> 7.4" | ||||||
|  |  | ||||||
| group :test do | gem "html-proofer", "~> 5.0", group: :test | ||||||
|   gem "html-proofer", "~> 4.4" |  | ||||||
| end |  | ||||||
|  |  | ||||||
| # Windows and JRuby does not include zoneinfo files, so bundle the tzinfo-data gem |  | ||||||
| # and associated library. |  | ||||||
| platforms :mingw, :x64_mingw, :mswin, :jruby do | platforms :mingw, :x64_mingw, :mswin, :jruby do | ||||||
|   gem "tzinfo", ">= 1", "< 3" |   gem "tzinfo", ">= 1", "< 3" | ||||||
|   gem "tzinfo-data" |   gem "tzinfo-data" | ||||||
| end | end | ||||||
|  |  | ||||||
| # Performance-booster for watching directories on Windows | gem "wdm", "~> 0.2.0", :platforms => [:mingw, :x64_mingw, :mswin] | ||||||
| gem "wdm", "~> 0.1.1", :platforms => [:mingw, :x64_mingw, :mswin] |  | ||||||
|  |  | ||||||
| # Lock `http_parser.rb` gem to `v0.6.x` on JRuby builds since newer versions of the gem |  | ||||||
| # do not have a Java counterpart. |  | ||||||
| gem "http_parser.rb", "~> 0.6.0", :platforms => [:jruby] |  | ||||||
|   | |||||||
							
								
								
									
										23
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										23
									
								
								README.md
									
									
									
									
									
								
							| @@ -25,25 +25,13 @@ Jekyll site. The following is a list of targets: | |||||||
| To save you time, and also in case you lose some files while copying, we extract those files/configurations of the | To save you time, and also in case you lose some files while copying, we extract those files/configurations of the | ||||||
| latest version of the **Chirpy** theme and the [CD][CD] workflow to here, so that you can start writing in minutes. | latest version of the **Chirpy** theme and the [CD][CD] workflow to here, so that you can start writing in minutes. | ||||||
|  |  | ||||||
| ## Prerequisites |  | ||||||
|  |  | ||||||
| Follow the instructions in the [Jekyll Docs](https://jekyllrb.com/docs/installation/) to complete the installation of |  | ||||||
| the basic environment. [Git](https://git-scm.com/) also needs to be installed. |  | ||||||
|  |  | ||||||
| ## Installation |  | ||||||
|  |  | ||||||
| Sign in to GitHub and [**use this template**][use-template] to generate a brand new repository and name it |  | ||||||
| `USERNAME.github.io`, where `USERNAME` represents your GitHub username. |  | ||||||
|  |  | ||||||
| Then clone it to your local machine and run: |  | ||||||
|  |  | ||||||
| ```console |  | ||||||
| $ bundle |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
| Please see the [theme's docs](https://github.com/cotes2020/jekyll-theme-chirpy#documentation). | Check out the [theme's docs](https://github.com/cotes2020/jekyll-theme-chirpy/wiki). | ||||||
|  |  | ||||||
|  | ## Contributing | ||||||
|  |  | ||||||
|  | This repository is automatically updated with new releases from the theme repository. If you encounter any issues or want to contribute to its improvement, please visit the [theme repository][chirpy] to provide feedback. | ||||||
|  |  | ||||||
| ## License | ## License | ||||||
|  |  | ||||||
| @@ -51,6 +39,5 @@ This work is published under [MIT][mit] License. | |||||||
|  |  | ||||||
| [gem]: https://rubygems.org/gems/jekyll-theme-chirpy | [gem]: https://rubygems.org/gems/jekyll-theme-chirpy | ||||||
| [chirpy]: https://github.com/cotes2020/jekyll-theme-chirpy/ | [chirpy]: https://github.com/cotes2020/jekyll-theme-chirpy/ | ||||||
| [use-template]: https://github.com/cotes2020/chirpy-starter/generate |  | ||||||
| [CD]: https://en.wikipedia.org/wiki/Continuous_deployment | [CD]: https://en.wikipedia.org/wiki/Continuous_deployment | ||||||
| [mit]: https://github.com/cotes2020/chirpy-starter/blob/master/LICENSE | [mit]: https://github.com/cotes2020/chirpy-starter/blob/master/LICENSE | ||||||
|   | |||||||
							
								
								
									
										86
									
								
								_config.yml
									
									
									
									
									
								
							
							
						
						
									
										86
									
								
								_config.yml
									
									
									
									
									
								
							| @@ -8,7 +8,7 @@ theme: jekyll-theme-chirpy | |||||||
| # otherwise, the layout language will use the default value of 'en'. | # otherwise, the layout language will use the default value of 'en'. | ||||||
| lang: en | lang: en | ||||||
|  |  | ||||||
| # Change to your timezone › https://kevinnovak.github.io/Time-Zone-Picker | # Change to your timezone › https://zones.arilyn.cc | ||||||
| timezone: | timezone: | ||||||
|  |  | ||||||
| # jekyll-seo-tag settings › https://github.com/jekyll/jekyll-seo-tag/blob/master/docs/usage.md | # jekyll-seo-tag settings › https://github.com/jekyll/jekyll-seo-tag/blob/master/docs/usage.md | ||||||
| @@ -16,20 +16,20 @@ timezone: | |||||||
|  |  | ||||||
| title: Chirpy # the main title | title: Chirpy # the main title | ||||||
|  |  | ||||||
| tagline: A text-focused Jekyll theme # it will display as the sub-title | tagline: A text-focused Jekyll theme # it will display as the subtitle | ||||||
|  |  | ||||||
| description: >- # used by seo meta and the atom feed | description: >- # used by seo meta and the atom feed | ||||||
|   A minimal, responsive and feature-rich Jekyll theme for technical writing. |   A minimal, responsive and feature-rich Jekyll theme for technical writing. | ||||||
|  |  | ||||||
| # Fill in the protocol & hostname for your site. | # Fill in the protocol & hostname for your site. | ||||||
| # e.g. 'https://username.github.io', note that it does not end with a '/'. | # E.g. 'https://username.github.io', note that it does not end with a '/'. | ||||||
| url: "" | url: "" | ||||||
|  |  | ||||||
| github: | github: | ||||||
|   username: github_username # change to your github username |   username: github_username # change to your GitHub username | ||||||
|  |  | ||||||
| twitter: | twitter: | ||||||
|   username: twitter_username # change to your twitter username |   username: twitter_username # change to your Twitter username | ||||||
|  |  | ||||||
| social: | social: | ||||||
|   # Change to your full name. |   # Change to your full name. | ||||||
| @@ -38,19 +38,44 @@ social: | |||||||
|   email: example@domain.com # change to your email address |   email: example@domain.com # change to your email address | ||||||
|   links: |   links: | ||||||
|     # The first element serves as the copyright owner's link |     # The first element serves as the copyright owner's link | ||||||
|     - https://twitter.com/username # change to your twitter homepage |     - https://twitter.com/username # change to your Twitter homepage | ||||||
|     - https://github.com/username # change to your github homepage |     - https://github.com/username # change to your GitHub homepage | ||||||
|     # Uncomment below to add more social links |     # Uncomment below to add more social links | ||||||
|     # - https://www.facebook.com/username |     # - https://www.facebook.com/username | ||||||
|     # - https://www.linkedin.com/in/username |     # - https://www.linkedin.com/in/username | ||||||
|  |  | ||||||
| google_site_verification: # fill in to your verification string | # Site Verification Settings | ||||||
|  | webmaster_verifications: | ||||||
|  |   google: # fill in your Google verification code | ||||||
|  |   bing: # fill in your Bing verification code | ||||||
|  |   alexa: # fill in your Alexa verification code | ||||||
|  |   yandex: # fill in your Yandex verification code | ||||||
|  |   baidu: # fill in your Baidu verification code | ||||||
|  |   facebook: # fill in your Facebook verification code | ||||||
|  |  | ||||||
| # ↑ -------------------------- | # ↑ -------------------------- | ||||||
| # The end of `jekyll-seo-tag` settings | # The end of `jekyll-seo-tag` settings | ||||||
|  |  | ||||||
| google_analytics: | # Web Analytics Settings | ||||||
|  | analytics: | ||||||
|  |   google: | ||||||
|     id: # fill in your Google Analytics ID |     id: # fill in your Google Analytics ID | ||||||
|  |   goatcounter: | ||||||
|  |     id: # fill in your GoatCounter ID | ||||||
|  |   umami: | ||||||
|  |     id: # fill in your Umami ID | ||||||
|  |     domain: # fill in your Umami domain | ||||||
|  |   matomo: | ||||||
|  |     id: # fill in your Matomo ID | ||||||
|  |     domain: # fill in your Matomo domain | ||||||
|  |   cloudflare: | ||||||
|  |     id: # fill in your Cloudflare Web Analytics token | ||||||
|  |   fathom: | ||||||
|  |     id: # fill in your Fathom Site ID | ||||||
|  |  | ||||||
|  | # Page views settings | ||||||
|  | pageviews: | ||||||
|  |   provider: # now only supports 'goatcounter' | ||||||
|  |  | ||||||
| # Prefer color scheme setting. | # Prefer color scheme setting. | ||||||
| # | # | ||||||
| @@ -60,27 +85,32 @@ google_analytics: | |||||||
| # | # | ||||||
| # Available options: | # Available options: | ||||||
| # | # | ||||||
| #     light  - Use the light color scheme | #     light — Use the light color scheme | ||||||
| #     dark   - Use the dark color scheme | #     dark — Use the dark color scheme | ||||||
| # | # | ||||||
| theme_mode: # [light | dark] | theme_mode: # [light | dark] | ||||||
|  |  | ||||||
| # The CDN endpoint for images. | # The CDN endpoint for media resources. | ||||||
| # Notice that once it is assigned, the CDN url | # Notice that once it is assigned, the CDN url | ||||||
| # will be added to all image (site avatar & posts' images) paths starting with '/' | # will be added to all media resources (site avatar, posts' images, audio and video files) paths starting with '/' | ||||||
| # | # | ||||||
| # e.g. 'https://cdn.com' | # e.g. 'https://cdn.com' | ||||||
| img_cdn: | cdn: | ||||||
|  |  | ||||||
| # the avatar on sidebar, support local or CORS resources | # the avatar on sidebar, support local or CORS resources | ||||||
| avatar: | avatar: | ||||||
|  |  | ||||||
|  | # The URL of the site-wide social preview image used in SEO `og:image` meta tag. | ||||||
|  | # It can be overridden by a customized `page.image` in front matter. | ||||||
|  | social_preview_image: # string, local or CORS resources | ||||||
|  |  | ||||||
| # boolean type, the global switch for TOC in posts. | # boolean type, the global switch for TOC in posts. | ||||||
| toc: true | toc: true | ||||||
|  |  | ||||||
| comments: | comments: | ||||||
|   active: # The global switch for posts comments, e.g., 'disqus'.  Keep it empty means disable |   # Global switch for the post-comment system. Keeping it empty means disabled. | ||||||
|   # The active options are as follows: |   provider: # [disqus | utterances | giscus] | ||||||
|  |   # The provider options are as follows: | ||||||
|   disqus: |   disqus: | ||||||
|     shortname: # fill with the Disqus shortname. › https://help.disqus.com/en/articles/1717111-what-s-a-shortname |     shortname: # fill with the Disqus shortname. › https://help.disqus.com/en/articles/1717111-what-s-a-shortname | ||||||
|   # utterances settings › https://utteranc.es/ |   # utterances settings › https://utteranc.es/ | ||||||
| @@ -94,6 +124,7 @@ comments: | |||||||
|     category: |     category: | ||||||
|     category_id: |     category_id: | ||||||
|     mapping: # optional, default to 'pathname' |     mapping: # optional, default to 'pathname' | ||||||
|  |     strict: # optional, default to '0' | ||||||
|     input_position: # optional, default to 'bottom' |     input_position: # optional, default to 'bottom' | ||||||
|     lang: # optional, default to the value of `site.lang` |     lang: # optional, default to the value of `site.lang` | ||||||
|     reactions_enabled: # optional, default to the value of `1` |     reactions_enabled: # optional, default to the value of `1` | ||||||
| @@ -107,7 +138,14 @@ assets: | |||||||
|     env: # [development | production] |     env: # [development | production] | ||||||
|  |  | ||||||
| pwa: | pwa: | ||||||
|   enabled: true # the option for PWA feature |   enabled: true # The option for PWA feature (installable) | ||||||
|  |   cache: | ||||||
|  |     enabled: true # The option for PWA offline cache | ||||||
|  |     # Paths defined here will be excluded from the PWA cache. | ||||||
|  |     # Usually its value is the `baseurl` of another website that | ||||||
|  |     # shares the same domain name as the current website. | ||||||
|  |     deny_paths: | ||||||
|  |       # - "/example"  # URLs match `<SITE_URL>/example/*` will not be cached by the PWA | ||||||
|  |  | ||||||
| paginate: 10 | paginate: 10 | ||||||
|  |  | ||||||
| @@ -117,6 +155,7 @@ baseurl: "" | |||||||
| # ------------ The following options are not recommended to be modified ------------------ | # ------------ The following options are not recommended to be modified ------------------ | ||||||
|  |  | ||||||
| kramdown: | kramdown: | ||||||
|  |   footnote_backlink: "↩︎" | ||||||
|   syntax_highlighter: rouge |   syntax_highlighter: rouge | ||||||
|   syntax_highlighter_opts: # Rouge Options › https://github.com/jneen/rouge#full-options |   syntax_highlighter_opts: # Rouge Options › https://github.com/jneen/rouge#full-options | ||||||
|     css_class: highlight |     css_class: highlight | ||||||
| @@ -153,14 +192,6 @@ defaults: | |||||||
|     values: |     values: | ||||||
|       layout: page |       layout: page | ||||||
|       permalink: /:title/ |       permalink: /:title/ | ||||||
|   - scope: |  | ||||||
|       path: assets/img/favicons |  | ||||||
|     values: |  | ||||||
|       swcache: true |  | ||||||
|   - scope: |  | ||||||
|       path: assets/js/dist |  | ||||||
|     values: |  | ||||||
|       swcache: true |  | ||||||
|  |  | ||||||
| sass: | sass: | ||||||
|   style: compressed |   style: compressed | ||||||
| @@ -181,8 +212,9 @@ exclude: | |||||||
|   - tools |   - tools | ||||||
|   - README.md |   - README.md | ||||||
|   - LICENSE |   - LICENSE | ||||||
|   - rollup.config.js |   - purgecss.js | ||||||
|   - package*.json |   - "*.config.js" | ||||||
|  |   - "package*.json" | ||||||
|  |  | ||||||
| jekyll-archives: | jekyll-archives: | ||||||
|   enabled: [categories, tags] |   enabled: [categories, tags] | ||||||
|   | |||||||
| @@ -26,3 +26,15 @@ | |||||||
| # - type: stack-overflow | # - type: stack-overflow | ||||||
| #   icon: 'fab fa-stack-overflow' | #   icon: 'fab fa-stack-overflow' | ||||||
| #   url:  ''                  # Fill with your stackoverflow homepage | #   url:  ''                  # Fill with your stackoverflow homepage | ||||||
|  | # | ||||||
|  | # - type: bluesky | ||||||
|  | #   icon: 'fa-brands fa-bluesky' | ||||||
|  | #   url: ''                   # Fill with your Bluesky profile link | ||||||
|  | # | ||||||
|  | # - type: reddit | ||||||
|  | #   icon: 'fa-brands fa-reddit' | ||||||
|  | #   url: ''                   # Fill with your Reddit profile link | ||||||
|  | # | ||||||
|  | # - type: threads | ||||||
|  | #   icon: 'fa-brands fa-threads' | ||||||
|  | #   url: ''                   # Fill with your Threads profile link | ||||||
|   | |||||||
| @@ -18,8 +18,33 @@ platforms: | |||||||
|   # |   # | ||||||
|   # - type: Linkedin |   # - type: Linkedin | ||||||
|   #   icon: "fab fa-linkedin" |   #   icon: "fab fa-linkedin" | ||||||
|   #   link: "https://www.linkedin.com/sharing/share-offsite/?url=URL" |   #   link: "https://www.linkedin.com/feed/?shareActive=true&shareUrl=URL" | ||||||
|   # |   # | ||||||
|   # - type: Weibo |   # - type: Weibo | ||||||
|   #   icon: "fab fa-weibo" |   #   icon: "fab fa-weibo" | ||||||
|   #   link: "http://service.weibo.com/share/share.php?title=TITLE&url=URL" |   #   link: "https://service.weibo.com/share/share.php?title=TITLE&url=URL" | ||||||
|  |   # | ||||||
|  |   # - type: Mastodon | ||||||
|  |   #   icon: "fa-brands fa-mastodon" | ||||||
|  |   #   # See: https://github.com/justinribeiro/share-to-mastodon#properties | ||||||
|  |   #   instances: | ||||||
|  |   #     - label: mastodon.social | ||||||
|  |   #       link: "https://mastodon.social/" | ||||||
|  |   #     - label: mastodon.online | ||||||
|  |   #       link: "https://mastodon.online/" | ||||||
|  |   #     - label: fosstodon.org | ||||||
|  |   #       link: "https://fosstodon.org/" | ||||||
|  |   #     - label: photog.social | ||||||
|  |   #       link: "https://photog.social/" | ||||||
|  |   # | ||||||
|  |   # - type: Bluesky | ||||||
|  |   #   icon: "fa-brands fa-bluesky" | ||||||
|  |   #   link: "https://bsky.app/intent/compose?text=TITLE%20URL" | ||||||
|  |   # | ||||||
|  |   # - type: Reddit | ||||||
|  |   #   icon: "fa-brands fa-square-reddit" | ||||||
|  |   #   link: "https://www.reddit.com/submit?url=URL&title=TITLE" | ||||||
|  |   # | ||||||
|  |   # - type: Threads | ||||||
|  |   #   icon: "fa-brands fa-square-threads" | ||||||
|  |   #   link: "https://www.threads.net/intent/post?text=TITLE%20URL" | ||||||
|   | |||||||
 Submodule assets/lib updated: 6e3fa73468...93e03454ed
									
								
							
							
								
								
									
										54
									
								
								tools/run.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										54
									
								
								tools/run.sh
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,54 @@ | |||||||
|  | #!/usr/bin/env bash | ||||||
|  | # | ||||||
|  | # Run jekyll serve and then launch the site | ||||||
|  |  | ||||||
|  | prod=false | ||||||
|  | command="bundle exec jekyll s -l" | ||||||
|  | host="127.0.0.1" | ||||||
|  |  | ||||||
|  | help() { | ||||||
|  |   echo "Usage:" | ||||||
|  |   echo | ||||||
|  |   echo "   bash /path/to/run [options]" | ||||||
|  |   echo | ||||||
|  |   echo "Options:" | ||||||
|  |   echo "     -H, --host [HOST]    Host to bind to." | ||||||
|  |   echo "     -p, --production     Run Jekyll in 'production' mode." | ||||||
|  |   echo "     -h, --help           Print this help information." | ||||||
|  | } | ||||||
|  |  | ||||||
|  | while (($#)); do | ||||||
|  |   opt="$1" | ||||||
|  |   case $opt in | ||||||
|  |   -H | --host) | ||||||
|  |     host="$2" | ||||||
|  |     shift 2 | ||||||
|  |     ;; | ||||||
|  |   -p | --production) | ||||||
|  |     prod=true | ||||||
|  |     shift | ||||||
|  |     ;; | ||||||
|  |   -h | --help) | ||||||
|  |     help | ||||||
|  |     exit 0 | ||||||
|  |     ;; | ||||||
|  |   *) | ||||||
|  |     echo -e "> Unknown option: '$opt'\n" | ||||||
|  |     help | ||||||
|  |     exit 1 | ||||||
|  |     ;; | ||||||
|  |   esac | ||||||
|  | done | ||||||
|  |  | ||||||
|  | command="$command -H $host" | ||||||
|  |  | ||||||
|  | if $prod; then | ||||||
|  |   command="JEKYLL_ENV=production $command" | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | if [ -e /proc/1/cgroup ] && grep -q docker /proc/1/cgroup; then | ||||||
|  |   command="$command --force_polling" | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | echo -e "\n> $command\n" | ||||||
|  | eval "$command" | ||||||
							
								
								
									
										89
									
								
								tools/test.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										89
									
								
								tools/test.sh
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,89 @@ | |||||||
|  | #!/usr/bin/env bash | ||||||
|  | # | ||||||
|  | # Build and test the site content | ||||||
|  | # | ||||||
|  | # Requirement: html-proofer, jekyll | ||||||
|  | # | ||||||
|  | # Usage: See help information | ||||||
|  |  | ||||||
|  | set -eu | ||||||
|  |  | ||||||
|  | SITE_DIR="_site" | ||||||
|  |  | ||||||
|  | _config="_config.yml" | ||||||
|  |  | ||||||
|  | _baseurl="" | ||||||
|  |  | ||||||
|  | help() { | ||||||
|  |   echo "Build and test the site content" | ||||||
|  |   echo | ||||||
|  |   echo "Usage:" | ||||||
|  |   echo | ||||||
|  |   echo "   bash $0 [options]" | ||||||
|  |   echo | ||||||
|  |   echo "Options:" | ||||||
|  |   echo '     -c, --config   "<config_a[,config_b[...]]>"    Specify config file(s)' | ||||||
|  |   echo "     -h, --help               Print this information." | ||||||
|  | } | ||||||
|  |  | ||||||
|  | read_baseurl() { | ||||||
|  |   if [[ $_config == *","* ]]; then | ||||||
|  |     # multiple config | ||||||
|  |     IFS="," | ||||||
|  |     read -ra config_array <<<"$_config" | ||||||
|  |  | ||||||
|  |     # reverse loop the config files | ||||||
|  |     for ((i = ${#config_array[@]} - 1; i >= 0; i--)); do | ||||||
|  |       _tmp_baseurl="$(grep '^baseurl:' "${config_array[i]}" | sed "s/.*: *//;s/['\"]//g;s/#.*//")" | ||||||
|  |  | ||||||
|  |       if [[ -n $_tmp_baseurl ]]; then | ||||||
|  |         _baseurl="$_tmp_baseurl" | ||||||
|  |         break | ||||||
|  |       fi | ||||||
|  |     done | ||||||
|  |  | ||||||
|  |   else | ||||||
|  |     # single config | ||||||
|  |     _baseurl="$(grep '^baseurl:' "$_config" | sed "s/.*: *//;s/['\"]//g;s/#.*//")" | ||||||
|  |   fi | ||||||
|  | } | ||||||
|  |  | ||||||
|  | main() { | ||||||
|  |   # clean up | ||||||
|  |   if [[ -d $SITE_DIR ]]; then | ||||||
|  |     rm -rf "$SITE_DIR" | ||||||
|  |   fi | ||||||
|  |  | ||||||
|  |   read_baseurl | ||||||
|  |  | ||||||
|  |   # build | ||||||
|  |   JEKYLL_ENV=production bundle exec jekyll b \ | ||||||
|  |     -d "$SITE_DIR$_baseurl" -c "$_config" | ||||||
|  |  | ||||||
|  |   # test | ||||||
|  |   bundle exec htmlproofer "$SITE_DIR" \ | ||||||
|  |     --disable-external \ | ||||||
|  |     --ignore-urls "/^http:\/\/127.0.0.1/,/^http:\/\/0.0.0.0/,/^http:\/\/localhost/" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | while (($#)); do | ||||||
|  |   opt="$1" | ||||||
|  |   case $opt in | ||||||
|  |   -c | --config) | ||||||
|  |     _config="$2" | ||||||
|  |     shift | ||||||
|  |     shift | ||||||
|  |     ;; | ||||||
|  |   -h | --help) | ||||||
|  |     help | ||||||
|  |     exit 0 | ||||||
|  |     ;; | ||||||
|  |   *) | ||||||
|  |     # unknown option | ||||||
|  |     help | ||||||
|  |     exit 1 | ||||||
|  |     ;; | ||||||
|  |   esac | ||||||
|  | done | ||||||
|  |  | ||||||
|  | main | ||||||
		Reference in New Issue
	
	Block a user