build(deps-dev): remove package rollup-plugin-license
(#1796)
The `rollup-plugin-license` has been using too many deprecated dependencies, so it is necessary to remove it. As an alternative, this changes uses Rollup `output.banner` to insert copyright information. Since `terser` runs after `output`, it is not possible to insert the Front Matter defining permlink for `sw.js` through the same way (Jekyll Front Matter is YAML rather than JS, which would cause errors with terser). Therefore, _Jekyll Collection_ is now used to add permlink to `sw.js`, with the collection named `app`, and the directory placed in `_app`. This directory is not tracked by git, but it will be included when building the gem.
This commit is contained in:
parent
250880c088
commit
7ca9c59784
10 changed files with 35 additions and 58 deletions
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -7,6 +7,7 @@ Gemfile.lock
|
|||
.jekyll-cache
|
||||
.jekyll-metadata
|
||||
_site
|
||||
_app
|
||||
|
||||
# RubyGems
|
||||
*.gem
|
||||
|
|
|
@ -168,6 +168,9 @@ collections:
|
|||
tabs:
|
||||
output: true
|
||||
sort_by: order
|
||||
app:
|
||||
output: true
|
||||
permalink: /:name
|
||||
|
||||
defaults:
|
||||
- scope:
|
||||
|
@ -190,10 +193,6 @@ defaults:
|
|||
values:
|
||||
layout: page
|
||||
permalink: /:title/
|
||||
- scope:
|
||||
path: assets/js/dist
|
||||
values:
|
||||
swcache: true
|
||||
|
||||
sass:
|
||||
style: compressed
|
||||
|
|
|
@ -6,8 +6,6 @@
|
|||
|
||||
<!-- layout specified -->
|
||||
|
||||
{% assign js_dist = '/assets/js/dist/' %}
|
||||
|
||||
{% if page.layout == 'post' or page.layout == 'page' or page.layout == 'home' %}
|
||||
{% assign urls = urls | append: ',' | append: site.data.origin[type]['lazy-polyfill'].js %}
|
||||
|
||||
|
@ -62,7 +60,8 @@
|
|||
{% assign js = 'commons' %}
|
||||
{% endcase %}
|
||||
|
||||
{% capture script %}{{ js_dist }}{{ js }}.min.js{% endcapture %}
|
||||
{% capture script %}/assets/js/dist/{{ js }}.min.js{% endcapture %}
|
||||
|
||||
<script src="{{ script | relative_url }}"></script>
|
||||
|
||||
{% if page.math %}
|
||||
|
@ -93,7 +92,7 @@
|
|||
{% if jekyll.environment == 'production' %}
|
||||
<!-- PWA -->
|
||||
{% if site.pwa.enabled %}
|
||||
<script defer src="{{ 'app.min.js' | prepend: js_dist | relative_url }}"></script>
|
||||
<script defer src="{{ 'app.min.js' | relative_url }}"></script>
|
||||
{% endif %}
|
||||
|
||||
<!-- Web Analytics -->
|
||||
|
|
|
@ -1 +0,0 @@
|
|||
Chirpy v<%= pkg.version %> | © 2019 <%= pkg.author %> | <%= pkg.license %> Licensed | <%= pkg.homepage %>
|
|
@ -1,3 +0,0 @@
|
|||
---
|
||||
permalink: /:basename
|
||||
---
|
|
@ -11,7 +11,7 @@ Gem::Specification.new do |spec|
|
|||
spec.license = "MIT"
|
||||
|
||||
spec.files = `git ls-files -z`.split("\x0").select { |f|
|
||||
f.match(%r!^((_(includes|layouts|sass|(data\/(locales|origin)))|assets)\/|README|LICENSE)!i)
|
||||
f.match(%r!^((_(includes|layouts|sass|app|(data\/(locales|origin)))|assets)\/|README|LICENSE)!i)
|
||||
}
|
||||
|
||||
spec.metadata = {
|
||||
|
|
|
@ -8,6 +8,7 @@
|
|||
},
|
||||
"author": "Cotes Chung",
|
||||
"license": "MIT",
|
||||
"since": 2019,
|
||||
"bugs": {
|
||||
"url": "https://github.com/cotes2020/jekyll-theme-chirpy/issues"
|
||||
},
|
||||
|
@ -43,7 +44,6 @@
|
|||
"husky": "^9.0.11",
|
||||
"purgecss": "^6.0.0",
|
||||
"rollup": "^4.18.0",
|
||||
"rollup-plugin-license": "^3.4.0",
|
||||
"semantic-release": "^24.0.0",
|
||||
"stylelint": "^16.6.1",
|
||||
"stylelint-config-standard-scss": "^13.1.0"
|
||||
|
|
|
@ -1,38 +1,43 @@
|
|||
import babel from '@rollup/plugin-babel';
|
||||
import terser from '@rollup/plugin-terser';
|
||||
import license from 'rollup-plugin-license';
|
||||
import { nodeResolve } from '@rollup/plugin-node-resolve';
|
||||
import fs from 'fs';
|
||||
import path from 'path';
|
||||
import yaml from '@rollup/plugin-yaml';
|
||||
import fs from 'fs';
|
||||
import pkg from './package.json';
|
||||
|
||||
const SRC_DEFAULT = '_javascript';
|
||||
const DIST_DEFAULT = 'assets/js/dist';
|
||||
|
||||
const SRC_PWA = `${SRC_DEFAULT}/pwa`;
|
||||
const DIST_PWA = '_app';
|
||||
|
||||
const banner = `/*!
|
||||
* ${pkg.name} v${pkg.version} | © ${pkg.since} ${pkg.author} | ${pkg.license} Licensed | ${pkg.homepage}
|
||||
*/`;
|
||||
|
||||
const isProd = process.env.BUILD === 'production';
|
||||
|
||||
if (fs.existsSync(DIST_DEFAULT)) {
|
||||
fs.rm(DIST_DEFAULT, { recursive: true, force: true }, (err) => {
|
||||
if (err) {
|
||||
throw err;
|
||||
}
|
||||
});
|
||||
function cleanup(...directories) {
|
||||
for (const dir of directories) {
|
||||
fs.rm(dir, { recursive: true, force: true }, (err) => {
|
||||
if (err) {
|
||||
console.error(`Failed to remove directory ${dir}: ${err}`);
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
function build(filename, opts = {}) {
|
||||
const src = opts.src || SRC_DEFAULT;
|
||||
const dist = opts.dist || DIST_DEFAULT;
|
||||
const bannerUrl =
|
||||
opts.bannerUrl || path.join(__dirname, SRC_DEFAULT, '_copyright');
|
||||
const commentStyle = opts.commentStyle || 'ignored';
|
||||
|
||||
return {
|
||||
input: [`${src}/${filename}.js`],
|
||||
input: `${src}/${filename}.js`,
|
||||
output: {
|
||||
file: `${dist}/${filename}.min.js`,
|
||||
format: 'iife',
|
||||
name: 'Chirpy',
|
||||
banner,
|
||||
sourcemap: !isProd
|
||||
},
|
||||
watch: {
|
||||
|
@ -46,18 +51,13 @@ function build(filename, opts = {}) {
|
|||
}),
|
||||
nodeResolve(),
|
||||
yaml(),
|
||||
isProd && commentStyle === 'none' && terser(),
|
||||
license({
|
||||
banner: {
|
||||
commentStyle,
|
||||
content: { file: bannerUrl }
|
||||
}
|
||||
}),
|
||||
isProd && commentStyle !== 'none' && terser()
|
||||
isProd && terser()
|
||||
]
|
||||
};
|
||||
}
|
||||
|
||||
cleanup(DIST_DEFAULT, DIST_PWA);
|
||||
|
||||
export default [
|
||||
build('commons'),
|
||||
build('home'),
|
||||
|
@ -65,10 +65,6 @@ export default [
|
|||
build('page'),
|
||||
build('post'),
|
||||
build('misc'),
|
||||
build('app', { src: SRC_PWA }),
|
||||
build('sw', {
|
||||
src: SRC_PWA,
|
||||
bannerUrl: path.join(__dirname, SRC_PWA, '_frontmatter'),
|
||||
commentStyle: 'none'
|
||||
})
|
||||
build('app', { src: SRC_PWA, dist: DIST_PWA }),
|
||||
build('sw', { src: SRC_PWA, dist: DIST_PWA })
|
||||
];
|
||||
|
|
|
@ -92,7 +92,7 @@ init_files() {
|
|||
npm i && npm run build
|
||||
|
||||
# track the CSS/JS output
|
||||
_sedi "/.*\/dist$/d" .gitignore
|
||||
_sedi "/.*\/dist$/d;/^_app$/d" .gitignore
|
||||
}
|
||||
|
||||
commit() {
|
||||
|
|
|
@ -17,6 +17,7 @@ CONFIG="_config.yml"
|
|||
|
||||
CSS_DIST="_sass/dist"
|
||||
JS_DIST="assets/js/dist"
|
||||
PWA_DIST="_app"
|
||||
|
||||
FILES=(
|
||||
"$GEM_SPEC"
|
||||
|
@ -111,20 +112,13 @@ prepare() {
|
|||
|
||||
## Build a Gem package
|
||||
build_gem() {
|
||||
if $opt_pkg; then
|
||||
BACKUP_PATH="$(mktemp -d)"
|
||||
mkdir -p "$BACKUP_PATH"/css "$BACKUP_PATH"/js
|
||||
[[ -d $CSS_DIST ]] && cp "$CSS_DIST"/* "$BACKUP_PATH"/css
|
||||
[[ -d $JS_DIST ]] && cp "$JS_DIST"/* "$BACKUP_PATH"/js
|
||||
fi
|
||||
|
||||
# Remove unnecessary theme settings
|
||||
sed -i -E "s/(^timezone:).*/\1/;s/(^cdn:).*/\1/;s/(^avatar:).*/\1/" $CONFIG
|
||||
rm -f ./*.gem
|
||||
|
||||
npm run build
|
||||
# add CSS/JS distribution files to gem package
|
||||
git add "$CSS_DIST" "$JS_DIST" -f
|
||||
git add "$CSS_DIST" "$JS_DIST" "$PWA_DIST" -f
|
||||
|
||||
echo -e "\n> gem build $GEM_SPEC\n"
|
||||
gem build "$GEM_SPEC"
|
||||
|
@ -132,14 +126,6 @@ build_gem() {
|
|||
echo -e "\n> Resume file changes ...\n"
|
||||
git reset
|
||||
git checkout .
|
||||
|
||||
if $opt_pkg; then
|
||||
# restore the dist files for future development
|
||||
mkdir -p "$CSS_DIST" "$JS_DIST"
|
||||
cp "$BACKUP_PATH"/css/* "$CSS_DIST"
|
||||
cp "$BACKUP_PATH"/js/* "$JS_DIST"
|
||||
rm -rf "$BACKUP_PATH"
|
||||
fi
|
||||
}
|
||||
|
||||
# Push the gem to RubyGems.org (using $GEM_HOST_API_KEY)
|
||||
|
|
Loading…
Reference in a new issue