1
0
mirror of https://github.com/kuohuanhuan/x-markdown-css.git synced 2024-11-25 06:18:19 +00:00

Compare commits

..

45 Commits

Author SHA1 Message Date
6deb3d86ef chore(deps-dev): bump postcss-preset-env from 8.0.1 to 8.1.0 (#7)
Bumps [postcss-preset-env](https://github.com/csstools/postcss-plugins/tree/HEAD/plugin-packs/postcss-preset-env) from 8.0.1 to 8.1.0.
- [Release notes](https://github.com/csstools/postcss-plugins/releases)
- [Changelog](https://github.com/csstools/postcss-plugins/blob/main/plugin-packs/postcss-preset-env/CHANGELOG.md)
- [Commits](https://github.com/csstools/postcss-plugins/commits/HEAD/plugin-packs/postcss-preset-env)

---
updated-dependencies:
- dependency-name: postcss-preset-env
  dependency-type: direct:development
  update-type: version-update:semver-minor
...

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2023-03-27 21:24:08 +08:00
48d9671f65 chore(deps): bump sass from 1.58.3 to 1.60.0 (#6)
Bumps [sass](https://github.com/sass/dart-sass) from 1.58.3 to 1.60.0.
- [Release notes](https://github.com/sass/dart-sass/releases)
- [Changelog](https://github.com/sass/dart-sass/blob/main/CHANGELOG.md)
- [Commits](https://github.com/sass/dart-sass/compare/1.58.3...1.60.0)

---
updated-dependencies:
- dependency-name: sass
  dependency-type: direct:production
  update-type: version-update:semver-minor
...

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2023-03-24 21:07:38 +08:00
3a7f38d21c chore(deps-dev): bump stylelint from 15.2.0 to 15.3.0 (#5)
Bumps [stylelint](https://github.com/stylelint/stylelint) from 15.2.0 to 15.3.0.
- [Release notes](https://github.com/stylelint/stylelint/releases)
- [Changelog](https://github.com/stylelint/stylelint/blob/main/CHANGELOG.md)
- [Commits](https://github.com/stylelint/stylelint/compare/15.2.0...15.3.0)

---
updated-dependencies:
- dependency-name: stylelint
  dependency-type: direct:development
  update-type: version-update:semver-minor
...

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2023-03-24 21:07:28 +08:00
cbea6295e8 chore(deps-dev): bump @kuohuanhuan/stylelint-config from 0.0.4 to 0.0.5 (#2)
Bumps [@kuohuanhuan/stylelint-config](https://github.com/kuohuanhuan/stylelint-config) from 0.0.4 to 0.0.5.
- [Release notes](https://github.com/kuohuanhuan/stylelint-config/releases)
- [Commits](https://github.com/kuohuanhuan/stylelint-config/compare/v0.0.4...v0.0.5)

---
updated-dependencies:
- dependency-name: "@kuohuanhuan/stylelint-config"
  dependency-type: direct:development
  update-type: version-update:semver-patch
...

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2023-03-24 21:07:20 +08:00
132eb4ff72 chore: release v0.1.5 2023-03-18 22:59:26 +08:00
4a9dbe84aa chore(ci): remove quote with tags 2023-03-11 20:14:58 +08:00
ba95b90714 chore(deps-dev): bump autoprefixer from 10.4.13 to 10.4.14 (#1)
Bumps [autoprefixer](https://github.com/postcss/autoprefixer) from 10.4.13 to 10.4.14.
- [Release notes](https://github.com/postcss/autoprefixer/releases)
- [Changelog](https://github.com/postcss/autoprefixer/blob/main/CHANGELOG.md)
- [Commits](https://github.com/postcss/autoprefixer/compare/10.4.13...10.4.14)

---
updated-dependencies:
- dependency-name: autoprefixer
  dependency-type: direct:development
  update-type: version-update:semver-patch
...

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2023-03-10 22:29:52 +08:00
6b4fd5f2c5 chore: release v0.1.4 2023-03-08 18:49:35 +08:00
c8bc7d3438 feat(colors): rename $border-rev to $border-table 2023-03-08 18:45:18 +08:00
b44d47b14f chore: release v0.1.3 2023-03-07 22:29:52 +08:00
5fcbb64413 fix(figure): use correct color for figcaption 2023-03-07 22:28:53 +08:00
0af430670a style(comments): add comments to describe light/dark modes 2023-03-07 22:26:09 +08:00
47e16ecde7 fix(colors): solve deprecated grammars 2023-03-07 22:25:07 +08:00
bf04be0379 feat(quote): apply opacity: .75; instead of .8 on quotes 2023-03-07 22:22:48 +08:00
b43013e33e feat(table): use more flexible selector for thead and tbody 2023-03-07 22:18:31 +08:00
0f50a7c98d fix(media): remove hardcoded pixel height and width 2023-03-07 22:09:11 +08:00
f4d95387c3 style: run Stylelint to fix lint problems 2023-03-07 22:07:28 +08:00
42967ea775 feat(link): improve user experience with links 2023-03-07 22:04:15 +08:00
b4d1423d37 feat(colors): update default color palette 2023-03-07 21:59:39 +08:00
008564db1b chore: release v0.1.2 2023-03-07 21:18:34 +08:00
21de988cb9 feat(colors)!: rewrite color variables logic 2023-03-07 21:18:13 +08:00
5568aa278f chore: release v0.1.1-patch 2023-03-07 20:17:04 +08:00
919ebfaf39 chore(package)!: fix incorrect dependency 2023-03-07 20:16:20 +08:00
458b495b44 chore: release v0.1.1 2023-03-07 19:53:37 +08:00
ff23b42eec feat(title): improve .header-anchor display effect 2023-03-07 19:47:52 +08:00
32be4bf51a refactor: use @forward instead of @use in _all.scss 2023-03-07 18:57:50 +08:00
ce94858f01 feat(code): add specify styles for code blocks 2023-03-07 18:56:37 +08:00
6c0c7e7624 fix(code): remove Shiki integration 2023-03-07 18:38:01 +08:00
10ae6dc593 chore: release v0.1.0 2023-03-06 22:16:47 +08:00
28fcbf66a8 chore(ci): use Node.js version lts/* at lint and release 2023-03-06 22:12:09 +08:00
e9264bfa01 chore(lint): use @kuohuanhuan/stylelint-config as Stylelint config 2023-03-06 22:07:19 +08:00
0e6c171424 chore(package): standardize author field in package.json 2023-03-06 19:43:44 +08:00
d45e09d7bf chore(ci): add lts/* to node-version in CI 2023-03-05 19:53:39 +08:00
eb2e5f532a chore(ci): rename Build and Release to Release 2023-03-05 19:39:45 +08:00
2e99e64a3e refactor(colors)!: rename $link-border to $a-border 2023-03-05 18:15:14 +08:00
877ea710d6 chore(ci): only run lint and build when specified files modified 2023-03-05 18:09:07 +08:00
df63212d6d chore(ci): use windows-2022 to create releases [skip actions] 2023-03-05 17:52:14 +08:00
ee89b96068 fix(code)!: respect shiki themes 2023-03-05 17:43:16 +08:00
63a6fc2072 refactor!: deprecate .prose class and lint 2023-03-05 17:39:51 +08:00
e54282e5f8 docs(readme): move documentation to Wiki 2023-03-05 17:14:04 +08:00
2b9619f2e2 refactor: migrate to modern module system 2023-03-05 15:00:12 +08:00
2cb60cc6c4 fix(markdown): remove invalid .highlight class 2023-03-05 13:55:52 +08:00
beedb0e803 docs(readme): remove unnecessary remark 2023-03-05 12:46:14 +08:00
77e57fe3ae chore: release v0.0.5 2023-03-05 12:33:18 +08:00
5f45d99381 Due to a restrict of npm, we cannot override the 0.0.3 version. 2023-03-05 12:33:00 +08:00
33 changed files with 407 additions and 486 deletions

View File

@ -4,6 +4,12 @@ on:
push:
branches:
- master
paths:
- src/**.scss
- package.json
- Gruntfile.coffee
- .stylelintrc
- .stylelintignore
pull_request:
branches:
- master
@ -21,7 +27,7 @@ jobs:
- name: Setup Node.js
uses: actions/setup-node@v3
with:
node-version: 18
node-version: lts/*
registry-url: https://registry.npmjs.com
# Step III
- name: Install Dependencies

View File

@ -1,15 +1,15 @@
name: Build and Release
name: Release
on:
push:
tags:
- 'v*'
- v*
jobs:
# NPM Registry & GitHub Release
release:
# Use Ubuntu 22.04 LTS
runs-on: ubuntu-22.04
# Use Windows Server 2022
runs-on: windows-2022
steps:
# Step I
- name: Get Source Code
@ -20,7 +20,7 @@ jobs:
- name: Setup Node.js
uses: actions/setup-node@v3
with:
node-version: 18
node-version: lts/*
registry-url: https://registry.npmjs.com
# Step III
- name: Install Dependencies

View File

@ -1,21 +1,4 @@
{
"ignoreDisables": true,
"extends": [
"stylelint-config-standard-scss",
"stylelint-config-hudochenkov/order"
],
"plugins": ["stylelint-scss"],
"rules": {
"alpha-value-notation": "number",
"at-rule-empty-line-before": null,
"block-no-empty": true,
"color-named": "never",
"color-hex-case": "lower",
"import-notation": null,
"max-nesting-depth": 5,
"no-invalid-position-at-import-rule": null,
"number-leading-zero": "never",
"property-no-vendor-prefix": true,
"rule-empty-line-before": null
}
"extends": "@kuohuanhuan/stylelint-config"
}

View File

@ -14,37 +14,9 @@
According to [.browserslistrc](https://github.com/kuohuanhuan/x-markdown-css/blob/master/.browserslistrc), `x-markdown-css` supports **all browsers support CSS variables.**
## Usage
## Get Started
You can use `x-markdown-css` with:
1. A CDN service:
- UNPKG: `https://unpkg.com/x-markdown-css`
- jsDelivr: `https://fastly.jsdelivr.net/npm/x-markdown-css`
- CDNJS: *Coming soon. **Waiting for you to make `x-markdown-css` [popular enough](https://github.com/cdnjs/packages/blob/master/CONTRIBUTING.md#policy-rules-and-guidelines)**!*
> *ps. Note that `bundle.css` without `.min` stands for unminified version.*
1. A CSS (with Node.js) / Sass / SCSS project:
First, install it with NPM ([PNPM](https://pnpm.io) or [Yarn](https://yarnpkg.com) also works):
```sh
npm i x-markdown-css@latest
```
Then, add it to your `.css` / `.sass` / `.scss` file.
For example, in CSS / SCSS you do:
```css
@import 'x-markdown-css';
```
> *ps. Note that no path or file extention is required
> since the `style` and `sass` field in `package.json` is filled.
> Just simply use `'x-markdown-css'` to import it.*
Visit the [Wiki](https://github.com/kuohuanhuan/x-markdown-css/wiki) page for more information.
## Built with

398
package-lock.json generated
View File

@ -1,18 +1,19 @@
{
"name": "x-markdown-css",
"version": "0.0.3",
"version": "0.1.5",
"lockfileVersion": 3,
"requires": true,
"packages": {
"": {
"name": "x-markdown-css",
"version": "0.0.1-patch.3",
"version": "0.1.5",
"license": "MIT",
"dependencies": {
"coffeescript": "^2.7.0",
"sass": "^1.58.3"
},
"devDependencies": {
"@kuohuanhuan/stylelint-config": "^0.0.5",
"@lodder/grunt-postcss": "^3.1.1",
"autoprefixer": "^10.4.13",
"bumpp": "^9.0.0",
@ -22,10 +23,7 @@
"load-grunt-tasks": "^5.1.0",
"postcss": "^8.4.21",
"postcss-preset-env": "^8.0.1",
"stylelint": "^15.2.0",
"stylelint-config-hudochenkov": "^9.0.0",
"stylelint-config-standard-scss": "^7.0.1",
"stylelint-scss": "^4.4.0"
"stylelint": "^15.2.0"
},
"engines": {
"node": ">=16"
@ -159,9 +157,9 @@
}
},
"node_modules/@csstools/css-calc": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/@csstools/css-calc/-/css-calc-1.0.0.tgz",
"integrity": "sha512-Xw0b/Jr+vLGGYD8cxsGWPaY5n1GtVC6G4tcga+eZPXZzRjjZHorPwW739UgtXzL2Da1RLxNE73c0r/KvmizPsw==",
"version": "1.0.1",
"resolved": "https://registry.npmjs.org/@csstools/css-calc/-/css-calc-1.0.1.tgz",
"integrity": "sha512-VBI8X0bmStfc85wWTa2bsbnlBQxgW4FmJ0Ts9ar9UqytE6kii3yg6GO+wpgzht2oK5Qlbpkm1Fy2kcqVmu6f3Q==",
"dev": true,
"engines": {
"node": "^14 || ^16 || >=18"
@ -175,10 +173,44 @@
"@csstools/css-tokenizer": "^2.0.1"
}
},
"node_modules/@csstools/css-color-parser": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/@csstools/css-color-parser/-/css-color-parser-1.0.0.tgz",
"integrity": "sha512-u3JrK+pQIGGnXe+YhohWwAwOum2y25NRdEjRQFD3moMnOJgmU/nj8BPAF6DDQAooy8Ty9RNKiAh2njuqwMgUNQ==",
"dev": true,
"dependencies": {
"@csstools/color-helpers": "^2.0.0",
"@csstools/css-calc": "^1.0.1"
},
"engines": {
"node": "^14 || ^16 || >=18"
},
"funding": {
"type": "opencollective",
"url": "https://opencollective.com/csstools"
},
"peerDependencies": {
"@csstools/css-parser-algorithms": "^2.1.0",
"@csstools/css-tokenizer": "^2.1.0"
}
},
"node_modules/@csstools/css-color-parser/node_modules/@csstools/color-helpers": {
"version": "2.0.0",
"resolved": "https://registry.npmjs.org/@csstools/color-helpers/-/color-helpers-2.0.0.tgz",
"integrity": "sha512-VcPjEnp07RNgz/D+oI2uIALg+IPCSl6mj0XhA3pl3F2bM2B95vgzatExmmzSg/X0zkh+R2v+jFY/J2pV/bnwpw==",
"dev": true,
"engines": {
"node": "^14 || ^16 || >=18"
},
"funding": {
"type": "opencollective",
"url": "https://opencollective.com/csstools"
}
},
"node_modules/@csstools/css-parser-algorithms": {
"version": "2.0.1",
"resolved": "https://registry.npmjs.org/@csstools/css-parser-algorithms/-/css-parser-algorithms-2.0.1.tgz",
"integrity": "sha512-B9/8PmOtU6nBiibJg0glnNktQDZ3rZnGn/7UmDfrm2vMtrdlXO3p7ErE95N0up80IRk9YEtB5jyj/TmQ1WH3dw==",
"version": "2.1.0",
"resolved": "https://registry.npmjs.org/@csstools/css-parser-algorithms/-/css-parser-algorithms-2.1.0.tgz",
"integrity": "sha512-KP8TicdXpUyeB1NMlbHud/1l39xvLGvqNFWMpG4qC6H1zs9SadGUHe5SO92n/659sDW9aGDvm9AMru0DZkN1Bw==",
"dev": true,
"engines": {
"node": "^14 || ^16 || >=18"
@ -262,6 +294,28 @@
"postcss": "^8.4"
}
},
"node_modules/@csstools/postcss-color-mix-function": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/@csstools/postcss-color-mix-function/-/postcss-color-mix-function-1.0.0.tgz",
"integrity": "sha512-JuI8SKpE/XIpfmvALcxvk6flaq36KCJwqQgZ958Jz189r1diQZADq+7xFmjcv+B0vHQ4nSa92gGExtzOZ1iiUg==",
"dev": true,
"dependencies": {
"@csstools/css-color-parser": "^1.0.0",
"@csstools/css-parser-algorithms": "^2.0.1",
"@csstools/css-tokenizer": "^2.1.0",
"@csstools/postcss-progressive-custom-properties": "^2.0.0"
},
"engines": {
"node": "^14 || ^16 || >=18"
},
"funding": {
"type": "opencollective",
"url": "https://opencollective.com/csstools"
},
"peerDependencies": {
"postcss": "^8.4"
}
},
"node_modules/@csstools/postcss-font-format-keywords": {
"version": "2.0.2",
"resolved": "https://registry.npmjs.org/@csstools/postcss-font-format-keywords/-/postcss-font-format-keywords-2.0.2.tgz",
@ -282,13 +336,14 @@
}
},
"node_modules/@csstools/postcss-hwb-function": {
"version": "2.1.1",
"resolved": "https://registry.npmjs.org/@csstools/postcss-hwb-function/-/postcss-hwb-function-2.1.1.tgz",
"integrity": "sha512-XijKzdxBdH2hU6IcPWmnaU85FKEF1XE5hGy0d6dQC6XznFUIRu1T4uebL3krayX40m4xIcxfCBsQm5zphzVrtg==",
"version": "2.2.0",
"resolved": "https://registry.npmjs.org/@csstools/postcss-hwb-function/-/postcss-hwb-function-2.2.0.tgz",
"integrity": "sha512-7gDPKacr3KhonzEyj4dzAEcetFJbN+JVPZXtANpf9SAVUHDUK+cCw7367uRlXnCeAoTdmRAyBk3agg2+snFxAw==",
"dev": true,
"dependencies": {
"@csstools/color-helpers": "^1.0.0",
"postcss-value-parser": "^4.2.0"
"@csstools/css-color-parser": "^1.0.0",
"@csstools/css-parser-algorithms": "^2.0.1",
"@csstools/css-tokenizer": "^2.1.0"
},
"engines": {
"node": "^14 || ^16 || >=18"
@ -455,14 +510,15 @@
}
},
"node_modules/@csstools/postcss-oklab-function": {
"version": "2.1.0",
"resolved": "https://registry.npmjs.org/@csstools/postcss-oklab-function/-/postcss-oklab-function-2.1.0.tgz",
"integrity": "sha512-U/odSNjOVhagNRu+RDaNVbn8vaqA9GyCOoneQA2je7697KOrtRDc7/POrYsP7QioO2aaezDzKNX02wBzc99fkQ==",
"version": "2.2.0",
"resolved": "https://registry.npmjs.org/@csstools/postcss-oklab-function/-/postcss-oklab-function-2.2.0.tgz",
"integrity": "sha512-5QMtgn9IWpeTbbt8DwLvr41CQRJef2fKhznTFQI1Og/v3zr/uKYu+aSKZEEaoZnO9OophM4YJnkVJne3CqvJDQ==",
"dev": true,
"dependencies": {
"@csstools/color-helpers": "^1.0.0",
"@csstools/postcss-progressive-custom-properties": "^2.0.0",
"postcss-value-parser": "^4.2.0"
"@csstools/css-color-parser": "^1.0.0",
"@csstools/css-parser-algorithms": "^2.0.1",
"@csstools/css-tokenizer": "^2.1.0",
"@csstools/postcss-progressive-custom-properties": "^2.0.0"
},
"engines": {
"node": "^14 || ^16 || >=18"
@ -555,12 +611,14 @@
}
},
"node_modules/@csstools/postcss-trigonometric-functions": {
"version": "2.0.1",
"resolved": "https://registry.npmjs.org/@csstools/postcss-trigonometric-functions/-/postcss-trigonometric-functions-2.0.1.tgz",
"integrity": "sha512-uGmmVWGHozyWe6+I4w321fKUC034OB1OYW0ZP4ySHA23n+r9y93K+1yrmW+hThpSfApKhaWySoD4I71LLlFUYQ==",
"version": "2.1.0",
"resolved": "https://registry.npmjs.org/@csstools/postcss-trigonometric-functions/-/postcss-trigonometric-functions-2.1.0.tgz",
"integrity": "sha512-Ly7YczO+QdnByYeGqlppJoA2Tb2vsFfj5gSrszPTXJ+/4g3nnEZnG0VSeTK/WA8y7fzyL/qVNkkdEeOnruNWFQ==",
"dev": true,
"dependencies": {
"postcss-value-parser": "^4.2.0"
"@csstools/css-calc": "^1.0.0",
"@csstools/css-parser-algorithms": "^2.0.1",
"@csstools/css-tokenizer": "^2.0.1"
},
"engines": {
"node": "^14 || ^16 || >=18"
@ -621,6 +679,18 @@
"node": ">=10"
}
},
"node_modules/@kuohuanhuan/stylelint-config": {
"version": "0.0.5",
"resolved": "https://registry.npmjs.org/@kuohuanhuan/stylelint-config/-/stylelint-config-0.0.5.tgz",
"integrity": "sha512-I0TNXQUNozKCGp6uojOaah/T3oWPgBFB/aAKcPjG27MkyP3VAjc4XrpHvmxNKGvzy2gr/AsVmJrugNbWrLBaVQ==",
"dev": true,
"peerDependencies": {
"postcss-scss": "^4.0.6",
"stylelint": "^15.2.0",
"stylelint-order": "^6.0.2",
"stylelint-scss": "^4.4.0"
}
},
"node_modules/@lodder/grunt-postcss": {
"version": "3.1.1",
"resolved": "https://registry.npmjs.org/@lodder/grunt-postcss/-/grunt-postcss-3.1.1.tgz",
@ -829,9 +899,9 @@
"dev": true
},
"node_modules/autoprefixer": {
"version": "10.4.13",
"resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-10.4.13.tgz",
"integrity": "sha512-49vKpMqcZYsJjwotvt4+h/BCjJVnhGwcLpDt5xkcaOG3eLrG/HUYLagrihYsQ+qrIBgIzX1Rw7a6L8I/ZA1Atg==",
"version": "10.4.14",
"resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-10.4.14.tgz",
"integrity": "sha512-FQzyfOsTlwVzjHxKEqRIAdJx9niO6VCBCoEwax/VLSoQF29ggECcPuBqUMZ+u8jCZOPSy8b8/8KnuFbp0SaFZQ==",
"dev": true,
"funding": [
{
@ -844,8 +914,8 @@
}
],
"dependencies": {
"browserslist": "^4.21.4",
"caniuse-lite": "^1.0.30001426",
"browserslist": "^4.21.5",
"caniuse-lite": "^1.0.30001464",
"fraction.js": "^4.2.0",
"normalize-range": "^0.1.2",
"picocolors": "^1.0.0",
@ -1012,9 +1082,9 @@
}
},
"node_modules/caniuse-lite": {
"version": "1.0.30001460",
"resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001460.tgz",
"integrity": "sha512-Bud7abqjvEjipUkpLs4D7gR0l8hBYBHoa+tGtKJHvT2AYzLp1z7EmVkUT4ERpVUfca8S2HGIVs883D8pUH1ZzQ==",
"version": "1.0.30001464",
"resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001464.tgz",
"integrity": "sha512-oww27MtUmusatpRpCGSOneQk2/l5czXANDSFvsc7VuOQ86s3ANhZetpwXNf1zY/zdfP63Xvjz325DAdAoES13g==",
"dev": true,
"funding": [
{
@ -1298,9 +1368,9 @@
}
},
"node_modules/cssdb": {
"version": "7.4.1",
"resolved": "https://registry.npmjs.org/cssdb/-/cssdb-7.4.1.tgz",
"integrity": "sha512-0Q8NOMpXJ3iTDDbUv9grcmQAfdDx4qz+fN/+Md2FGbevT+6+bJNQ2LjB2YIUlLbpBTM32idU1Sb+tb/uGt6/XQ==",
"version": "7.5.1",
"resolved": "https://registry.npmjs.org/cssdb/-/cssdb-7.5.1.tgz",
"integrity": "sha512-YdmjGmoS9TT5wgoKjySaBqgbPYtyxbbegeK8WNqWbZRa7SJcX9V0qGfDjbI8oPQwmh/zuA6ZSnQBCKLj9bZufw==",
"dev": true,
"funding": {
"type": "opencollective",
@ -1578,9 +1648,9 @@
"dev": true
},
"node_modules/electron-to-chromium": {
"version": "1.4.320",
"resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.320.tgz",
"integrity": "sha512-h70iRscrNluMZPVICXYl5SSB+rBKo22XfuIS1ER0OQxQZpKTnFpuS6coj7wY9M/3trv7OR88rRMOlKmRvDty7Q==",
"version": "1.4.322",
"resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.322.tgz",
"integrity": "sha512-KovjizNC9XB7dno/2GjxX8VS0SlfPpCjtyoKft+bCO+UfD8bFy16hY4Sh9s0h9BDxbRH2U0zX5VBjpM1LTcNlg==",
"dev": true
},
"node_modules/emoji-regex": {
@ -2504,9 +2574,9 @@
}
},
"node_modules/known-css-properties": {
"version": "0.26.0",
"resolved": "https://registry.npmjs.org/known-css-properties/-/known-css-properties-0.26.0.tgz",
"integrity": "sha512-5FZRzrZzNTBruuurWpvZnvP9pum+fe0HcK8z/ooo+U+Hmp4vtbyp1/QDsqmufirXy4egGzbaH/y2uCZf+6W5Kg==",
"version": "0.27.0",
"resolved": "https://registry.npmjs.org/known-css-properties/-/known-css-properties-0.27.0.tgz",
"integrity": "sha512-uMCj6+hZYDoffuvAJjFAPz56E9uoowFHmTkqRtRq5WyC5Q6Cu/fTZKNQpX/RbzChBYLLl3lo8CjFZBAZXq9qFg==",
"dev": true
},
"node_modules/liftup": {
@ -3566,14 +3636,15 @@
}
},
"node_modules/postcss-lab-function": {
"version": "5.1.0",
"resolved": "https://registry.npmjs.org/postcss-lab-function/-/postcss-lab-function-5.1.0.tgz",
"integrity": "sha512-iZApRTNcpc71uTn7PkzjHtj5cmuZpvu6okX4jHnM5OFi2fG97sodjxkq6SpL65xhW0NviQrAMSX97ntyGVRV0w==",
"version": "5.2.0",
"resolved": "https://registry.npmjs.org/postcss-lab-function/-/postcss-lab-function-5.2.0.tgz",
"integrity": "sha512-ie/k0xFCib22LV56jZoygLuWfM4J4migb89QnEXOjORGh6UwsDVSPW/x+P2MYS+AKFfZ5Npcu5HYEzYcezAAag==",
"dev": true,
"dependencies": {
"@csstools/color-helpers": "^1.0.0",
"@csstools/postcss-progressive-custom-properties": "^2.0.0",
"postcss-value-parser": "^4.2.0"
"@csstools/css-color-parser": "^1.0.0",
"@csstools/css-parser-algorithms": "^2.0.1",
"@csstools/css-tokenizer": "^2.1.0",
"@csstools/postcss-progressive-custom-properties": "^2.0.0"
},
"engines": {
"node": "^14 || ^16 || >=18"
@ -3876,9 +3947,9 @@
}
},
"node_modules/postcss-opacity-percentage": {
"version": "1.1.3",
"resolved": "https://registry.npmjs.org/postcss-opacity-percentage/-/postcss-opacity-percentage-1.1.3.tgz",
"integrity": "sha512-An6Ba4pHBiDtyVpSLymUUERMo2cU7s+Obz6BTrS+gxkbnSBNKSuD0AVUc+CpBMrpVPKKfoVz0WQCX+Tnst0i4A==",
"version": "2.0.0",
"resolved": "https://registry.npmjs.org/postcss-opacity-percentage/-/postcss-opacity-percentage-2.0.0.tgz",
"integrity": "sha512-lyDrCOtntq5Y1JZpBFzIWm2wG9kbEdujpNt4NLannF+J9c8CgFIzPa80YQfdza+Y+yFfzbYj/rfoOsYsooUWTQ==",
"dev": true,
"funding": [
{
@ -3891,7 +3962,7 @@
}
],
"engines": {
"node": "^12 || ^14 || >=16"
"node": "^14 || ^16 || >=18"
},
"peerDependencies": {
"postcss": "^8.2"
@ -3961,63 +4032,64 @@
}
},
"node_modules/postcss-preset-env": {
"version": "8.0.1",
"resolved": "https://registry.npmjs.org/postcss-preset-env/-/postcss-preset-env-8.0.1.tgz",
"integrity": "sha512-IUbymw0JlUbyVG+I85963PNWgPp3KhnFa1sxU7M/2dGthxV8e297P0VV5W9XcyypoH4hirH2fp1c6fmqh6YnSg==",
"version": "8.1.0",
"resolved": "https://registry.npmjs.org/postcss-preset-env/-/postcss-preset-env-8.1.0.tgz",
"integrity": "sha512-YIsPebk8tMZ9dOcKynyDue5zaod1oyXQ7WhbjmTufjNf9RyJlJx0A/4jYLVKxaHL8XgeygoUghg99+vwPX4SFA==",
"dev": true,
"dependencies": {
"@csstools/postcss-cascade-layers": "^3.0.0",
"@csstools/postcss-color-function": "^2.0.0",
"@csstools/postcss-font-format-keywords": "^2.0.0",
"@csstools/postcss-hwb-function": "^2.0.0",
"@csstools/postcss-ic-unit": "^2.0.0",
"@csstools/postcss-is-pseudo-class": "^3.0.0",
"@csstools/postcss-logical-float-and-clear": "^1.0.0",
"@csstools/postcss-logical-resize": "^1.0.0",
"@csstools/postcss-logical-viewport-units": "^1.0.0",
"@csstools/postcss-media-queries-aspect-ratio-number-values": "^1.0.0",
"@csstools/postcss-nested-calc": "^2.0.0",
"@csstools/postcss-normalize-display-values": "^2.0.0",
"@csstools/postcss-oklab-function": "^2.0.0",
"@csstools/postcss-progressive-custom-properties": "^2.0.0",
"@csstools/postcss-scope-pseudo-class": "^2.0.0",
"@csstools/postcss-stepped-value-functions": "^2.0.0",
"@csstools/postcss-text-decoration-shorthand": "^2.0.0",
"@csstools/postcss-trigonometric-functions": "^2.0.0",
"@csstools/postcss-unset-value": "^2.0.0",
"autoprefixer": "^10.4.13",
"browserslist": "^4.21.4",
"css-blank-pseudo": "^5.0.0",
"css-has-pseudo": "^5.0.0",
"css-prefers-color-scheme": "^8.0.0",
"cssdb": "^7.4.0",
"postcss-attribute-case-insensitive": "^6.0.0",
"@csstools/postcss-cascade-layers": "^3.0.1",
"@csstools/postcss-color-function": "^2.1.0",
"@csstools/postcss-color-mix-function": "^1.0.0",
"@csstools/postcss-font-format-keywords": "^2.0.2",
"@csstools/postcss-hwb-function": "^2.2.0",
"@csstools/postcss-ic-unit": "^2.0.2",
"@csstools/postcss-is-pseudo-class": "^3.1.1",
"@csstools/postcss-logical-float-and-clear": "^1.0.1",
"@csstools/postcss-logical-resize": "^1.0.1",
"@csstools/postcss-logical-viewport-units": "^1.0.2",
"@csstools/postcss-media-queries-aspect-ratio-number-values": "^1.0.1",
"@csstools/postcss-nested-calc": "^2.0.2",
"@csstools/postcss-normalize-display-values": "^2.0.1",
"@csstools/postcss-oklab-function": "^2.2.0",
"@csstools/postcss-progressive-custom-properties": "^2.1.0",
"@csstools/postcss-scope-pseudo-class": "^2.0.2",
"@csstools/postcss-stepped-value-functions": "^2.1.0",
"@csstools/postcss-text-decoration-shorthand": "^2.2.1",
"@csstools/postcss-trigonometric-functions": "^2.1.0",
"@csstools/postcss-unset-value": "^2.0.1",
"autoprefixer": "^10.4.14",
"browserslist": "^4.21.5",
"css-blank-pseudo": "^5.0.2",
"css-has-pseudo": "^5.0.2",
"css-prefers-color-scheme": "^8.0.2",
"cssdb": "^7.5.1",
"postcss-attribute-case-insensitive": "^6.0.2",
"postcss-clamp": "^4.1.0",
"postcss-color-functional-notation": "^5.0.0",
"postcss-color-hex-alpha": "^9.0.0",
"postcss-color-rebeccapurple": "^8.0.0",
"postcss-custom-media": "^9.1.0",
"postcss-custom-properties": "^13.1.0",
"postcss-custom-selectors": "^7.1.0",
"postcss-dir-pseudo-class": "^7.0.0",
"postcss-double-position-gradients": "^4.0.0",
"postcss-focus-visible": "^8.0.0",
"postcss-focus-within": "^7.0.0",
"postcss-color-functional-notation": "^5.0.2",
"postcss-color-hex-alpha": "^9.0.2",
"postcss-color-rebeccapurple": "^8.0.2",
"postcss-custom-media": "^9.1.2",
"postcss-custom-properties": "^13.1.4",
"postcss-custom-selectors": "^7.1.2",
"postcss-dir-pseudo-class": "^7.0.2",
"postcss-double-position-gradients": "^4.0.2",
"postcss-focus-visible": "^8.0.2",
"postcss-focus-within": "^7.0.2",
"postcss-font-variant": "^5.0.0",
"postcss-gap-properties": "^4.0.0",
"postcss-image-set-function": "^5.0.0",
"postcss-gap-properties": "^4.0.1",
"postcss-image-set-function": "^5.0.2",
"postcss-initial": "^4.0.1",
"postcss-lab-function": "^5.0.0",
"postcss-logical": "^6.0.0",
"postcss-lab-function": "^5.2.0",
"postcss-logical": "^6.1.0",
"postcss-media-minmax": "^5.0.0",
"postcss-nesting": "^11.0.0",
"postcss-opacity-percentage": "^1.1.3",
"postcss-overflow-shorthand": "^4.0.0",
"postcss-nesting": "^11.2.1",
"postcss-opacity-percentage": "^2.0.0",
"postcss-overflow-shorthand": "^4.0.1",
"postcss-page-break": "^3.0.4",
"postcss-place": "^8.0.0",
"postcss-pseudo-class-any-link": "^8.0.0",
"postcss-place": "^8.0.1",
"postcss-pseudo-class-any-link": "^8.0.2",
"postcss-replace-overflow-wrap": "^4.0.0",
"postcss-selector-not": "^7.0.0",
"postcss-selector-not": "^7.0.1",
"postcss-value-parser": "^4.2.0"
},
"engines": {
@ -4127,6 +4199,7 @@
"url": "https://tidelift.com/funding/github/npm/postcss-scss"
}
],
"peer": true,
"engines": {
"node": ">=12.0"
},
@ -4167,9 +4240,9 @@
}
},
"node_modules/postcss-sorting": {
"version": "8.0.1",
"resolved": "https://registry.npmjs.org/postcss-sorting/-/postcss-sorting-8.0.1.tgz",
"integrity": "sha512-go9Zoxx7KQH+uLrJ9xa5wRErFeXu01ydA6O8m7koPXkmAN7Ts//eRcIqjo0stBR4+Nir2gMYDOWAOx7O5EPUZA==",
"version": "8.0.2",
"resolved": "https://registry.npmjs.org/postcss-sorting/-/postcss-sorting-8.0.2.tgz",
"integrity": "sha512-M9dkSrmU00t/jK7rF6BZSZauA5MAaBW4i5EnJXspMwt4iqTh/L9j6fgMnbElEOfyRyfLfVbIHj/R52zHzAPe1Q==",
"dev": true,
"peer": true,
"peerDependencies": {
@ -4550,9 +4623,9 @@
"dev": true
},
"node_modules/sass": {
"version": "1.58.3",
"resolved": "https://registry.npmjs.org/sass/-/sass-1.58.3.tgz",
"integrity": "sha512-Q7RaEtYf6BflYrQ+buPudKR26/lH+10EmO9bBqbmPh/KeLqv8bjpTNqxe71ocONqXq+jYiCbpPUmQMS+JJPk4A==",
"version": "1.60.0",
"resolved": "https://registry.npmjs.org/sass/-/sass-1.60.0.tgz",
"integrity": "sha512-updbwW6fNb5gGm8qMXzVO7V4sWf7LMXnMly/JEyfbfERbVH46Fn6q02BX7/eHTdKpE7d+oTkMMQpFWNUMfFbgQ==",
"dependencies": {
"chokidar": ">=3.0.0 <4.0.0",
"immutable": "^4.0.0",
@ -4657,9 +4730,9 @@
}
},
"node_modules/spdx-correct": {
"version": "3.1.1",
"resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.1.tgz",
"integrity": "sha512-cOYcUWwhCuHCXi49RhFRCyJEK3iPj1Ziz9DpViV3tbZOwXD49QzIN3MpOLJNxh2qwq2lJJZaKMVw9qNi4jTC0w==",
"version": "3.2.0",
"resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.2.0.tgz",
"integrity": "sha512-kN9dJbvnySHULIluDHy32WHRUu3Og7B9sbY7tsFLctQkIqnMh3hErYgdMjTYuqmcXX+lK5T1lnUt3G7zNswmZA==",
"dev": true,
"dependencies": {
"spdx-expression-parse": "^3.0.0",
@ -4771,18 +4844,18 @@
}
},
"node_modules/stylelint": {
"version": "15.2.0",
"resolved": "https://registry.npmjs.org/stylelint/-/stylelint-15.2.0.tgz",
"integrity": "sha512-wjg5OLn8zQwjlj5cYUgyQpMWKzct42AG5dYlqkHRJQJqsystFFn3onqEc263KH4xfEI0W3lZCnlIhFfS64uwSA==",
"version": "15.3.0",
"resolved": "https://registry.npmjs.org/stylelint/-/stylelint-15.3.0.tgz",
"integrity": "sha512-9UYBYk7K9rtlKcTUDZrtntE840sZM00qyYBQHHe7tjwMNUsPsGvR6Fd43IxHEAhRrDLzpy3TVaHb6CReBB3eFg==",
"dev": true,
"dependencies": {
"@csstools/css-parser-algorithms": "^2.0.1",
"@csstools/css-tokenizer": "^2.0.1",
"@csstools/css-tokenizer": "^2.1.0",
"@csstools/media-query-list-parser": "^2.0.1",
"@csstools/selector-specificity": "^2.1.1",
"balanced-match": "^2.0.0",
"colord": "^2.9.3",
"cosmiconfig": "^8.0.0",
"cosmiconfig": "^8.1.0",
"css-functions-list": "^3.1.0",
"css-tree": "^2.3.1",
"debug": "^4.3.4",
@ -4797,7 +4870,7 @@
"import-lazy": "^4.0.0",
"imurmurhash": "^0.1.4",
"is-plain-object": "^5.0.0",
"known-css-properties": "^0.26.0",
"known-css-properties": "^0.27.0",
"mathml-tag-names": "^2.1.3",
"meow": "^9.0.0",
"micromatch": "^4.0.5",
@ -4813,7 +4886,7 @@
"string-width": "^4.2.3",
"strip-ansi": "^6.0.1",
"style-search": "^0.1.0",
"supports-hyperlinks": "^2.3.0",
"supports-hyperlinks": "^3.0.0",
"svg-tags": "^1.0.0",
"table": "^6.8.1",
"v8-compile-cache": "^2.3.0",
@ -4830,85 +4903,15 @@
"url": "https://opencollective.com/stylelint"
}
},
"node_modules/stylelint-config-hudochenkov": {
"version": "9.0.0",
"resolved": "https://registry.npmjs.org/stylelint-config-hudochenkov/-/stylelint-config-hudochenkov-9.0.0.tgz",
"integrity": "sha512-IOiSA2URkeIxEbn/Vl7OnkovjFci2o5n4qdC8gMuVkygeqCt7y3JJvagbRGgBoIvr3ldus/WBIEHRr+y8ZLXMw==",
"dev": true,
"peerDependencies": {
"stylelint": "^15.0.0",
"stylelint-order": "^6.0.2"
}
},
"node_modules/stylelint-config-recommended": {
"version": "10.0.1",
"resolved": "https://registry.npmjs.org/stylelint-config-recommended/-/stylelint-config-recommended-10.0.1.tgz",
"integrity": "sha512-TQ4xQ48tW4QSlODcti7pgSRqBZcUaBzuh0jPpfiMhwJKBPkqzTIAU+IrSWL/7BgXlOM90DjB7YaNgFpx8QWhuA==",
"dev": true,
"peerDependencies": {
"stylelint": "^15.0.0"
}
},
"node_modules/stylelint-config-recommended-scss": {
"version": "9.0.1",
"resolved": "https://registry.npmjs.org/stylelint-config-recommended-scss/-/stylelint-config-recommended-scss-9.0.1.tgz",
"integrity": "sha512-qAmz/TdrqslwiMTuLM3QXeISUkfEDUXGMfRBCHm/xrkCJNnQefv+mzG2mWTsWkqcVk8HAyUkug10dwAcYp2fCQ==",
"dev": true,
"dependencies": {
"postcss-scss": "^4.0.2",
"stylelint-config-recommended": "^10.0.1",
"stylelint-scss": "^4.4.0"
},
"peerDependencies": {
"postcss": "^8.3.3",
"stylelint": "^15.0.0"
},
"peerDependenciesMeta": {
"postcss": {
"optional": true
}
}
},
"node_modules/stylelint-config-standard": {
"version": "30.0.1",
"resolved": "https://registry.npmjs.org/stylelint-config-standard/-/stylelint-config-standard-30.0.1.tgz",
"integrity": "sha512-NbeHOmpRQhjZh5XB1B/S4MLRWvz4xxAxeDBjzl0tY2xEcayNhLbaRGF0ZQzq+DQZLCcPpOHeS2Ru1ydbkhkmLg==",
"dev": true,
"dependencies": {
"stylelint-config-recommended": "^10.0.1"
},
"peerDependencies": {
"stylelint": "^15.0.0"
}
},
"node_modules/stylelint-config-standard-scss": {
"version": "7.0.1",
"resolved": "https://registry.npmjs.org/stylelint-config-standard-scss/-/stylelint-config-standard-scss-7.0.1.tgz",
"integrity": "sha512-m5sRdtsB1F5fnC1Ozla7ryftU47wVpO+HWd+JQTqeoG0g/oPh5EfbWfcVHbNCEtuoHfALIySiUWS20pz2hX6jA==",
"dev": true,
"dependencies": {
"stylelint-config-recommended-scss": "^9.0.0",
"stylelint-config-standard": "^30.0.1"
},
"peerDependencies": {
"postcss": "^8.3.3",
"stylelint": "^15.0.0"
},
"peerDependenciesMeta": {
"postcss": {
"optional": true
}
}
},
"node_modules/stylelint-order": {
"version": "6.0.2",
"resolved": "https://registry.npmjs.org/stylelint-order/-/stylelint-order-6.0.2.tgz",
"integrity": "sha512-yuac0BE6toHd27wUPvYVVQicAJthKFIv1HPQFH3Q0dExiO3Z6Uam7geoO0tUd5Z9ddsATYK++1qWNDX4RxMH5Q==",
"version": "6.0.3",
"resolved": "https://registry.npmjs.org/stylelint-order/-/stylelint-order-6.0.3.tgz",
"integrity": "sha512-1j1lOb4EU/6w49qZeT2SQVJXm0Ht+Qnq9GMfUa3pMwoyojIWfuA+JUDmoR97Bht1RLn4ei0xtLGy87M7d29B1w==",
"dev": true,
"peer": true,
"dependencies": {
"postcss": "^8.4.21",
"postcss-sorting": "^8.0.1"
"postcss-sorting": "^8.0.2"
},
"peerDependencies": {
"stylelint": "^14.0.0 || ^15.0.0"
@ -4919,6 +4922,7 @@
"resolved": "https://registry.npmjs.org/stylelint-scss/-/stylelint-scss-4.4.0.tgz",
"integrity": "sha512-Qy66a+/30aylFhPmUArHhVsHOun1qrO93LGT15uzLuLjWS7hKDfpFm34mYo1ndR4MCo8W4bEZM1+AlJRJORaaw==",
"dev": true,
"peer": true,
"dependencies": {
"lodash": "^4.17.21",
"postcss-media-query-parser": "^0.2.3",
@ -4996,16 +5000,16 @@
}
},
"node_modules/supports-hyperlinks": {
"version": "2.3.0",
"resolved": "https://registry.npmjs.org/supports-hyperlinks/-/supports-hyperlinks-2.3.0.tgz",
"integrity": "sha512-RpsAZlpWcDwOPQA22aCH4J0t7L8JmAvsCxfOSEwm7cQs3LshN36QaTkwd70DnBOXDWGssw2eUoc8CaRWT0XunA==",
"version": "3.0.0",
"resolved": "https://registry.npmjs.org/supports-hyperlinks/-/supports-hyperlinks-3.0.0.tgz",
"integrity": "sha512-QBDPHyPQDRTy9ku4URNGY5Lah8PAaXs6tAAwp55sL5WCsSW7GIfdf6W5ixfziW+t7wh3GVvHyHHyQ1ESsoRvaA==",
"dev": true,
"dependencies": {
"has-flag": "^4.0.0",
"supports-color": "^7.0.0"
},
"engines": {
"node": ">=8"
"node": ">=14.18"
}
},
"node_modules/supports-preserve-symlinks-flag": {

View File

@ -1,6 +1,6 @@
{
"name": "x-markdown-css",
"version": "0.0.3",
"version": "0.1.5",
"description": "A simple and customizable markdown CSS stylesheet for everyone.",
"keywords": [
"markdown",
@ -23,7 +23,11 @@
"type": "git",
"url": "git+https://github.com/kuohuanhuan/x-markdown-css.git"
},
"author": "kuohuanhuan",
"author": {
"name": "kuohuanhuan",
"email": "hi@nekohuan.cyou",
"url": "https://nekohuan.cyou"
},
"license": "MIT",
"bugs": {
"url": "https://github.com/kuohuanhuan/x-markdown-css/issues"
@ -43,6 +47,7 @@
"sass": "^1.58.3"
},
"devDependencies": {
"@kuohuanhuan/stylelint-config": "^0.0.5",
"@lodder/grunt-postcss": "^3.1.1",
"autoprefixer": "^10.4.13",
"bumpp": "^9.0.0",
@ -52,9 +57,6 @@
"load-grunt-tasks": "^5.1.0",
"postcss": "^8.4.21",
"postcss-preset-env": "^8.0.1",
"stylelint": "^15.2.0",
"stylelint-config-hudochenkov": "^9.0.0",
"stylelint-config-standard-scss": "^7.0.1",
"stylelint-scss": "^4.4.0"
"stylelint": "^15.2.0"
}
}

7
src/_content.scss Normal file
View File

@ -0,0 +1,7 @@
@use 'sass:meta';
@use 'partials/container';
.markdown-body {
@include container.container;
@include meta.load-css('partials/all');
}

22
src/_vars.scss Normal file
View File

@ -0,0 +1,22 @@
@use 'sass:meta';
@use 'variables/constants';
@use 'variables/modes/light';
@use 'variables/modes/dark';
:root {
@each $name, $val in meta.module-variables('constants') {
--xm-#{$name}: #{$val};
}
}
.markdown-body {
@each $name, $val in meta.module-variables('light') {
--xm-c-#{$name}: #{$val};
}
}
.dark .markdown-body {
@each $name, $val in meta.module-variables('dark') {
--xm-c-#{$name}: #{$val};
}
}

View File

@ -1,4 +1,2 @@
@use 'scss/vars' as *;
@import 'scss/markdown';
@import 'scss/prose';
@use 'vars';
@use 'content';

9
src/partials/_all.scss Normal file
View File

@ -0,0 +1,9 @@
@forward 'title';
@forward 'text';
@forward 'link';
@forward 'code';
@forward 'quote';
@forward 'figure';
@forward 'list';
@forward 'table';
@forward 'media';

View File

@ -2,5 +2,9 @@
max-width: fit-content;
color: var(--xm-c-regular);
font-size: 1rem;
font-family: var(--xm-font-display) !important;
line-height: 1.75;
&:first-child {
margin-top: 1rem;
}
}

View File

@ -8,13 +8,14 @@ code {
content: '`';
}
}
pre {
overflow-x: auto;
margin-top: 1.75rem;
margin-bottom: 1.75rem;
padding-top: .875rem, 1.15rem;
border-radius: .375rem;
color: var(--xm-c-pre);
color: var(--xm-c-deep);
font-size: .875rem;
line-height: 1.75;
code {
@ -32,4 +33,10 @@ pre {
content: none;
}
}
&:has(code) {
margin: .5rem 0;
font-size: 1.05rem;
font-family: var(--xm-font-code);
line-height: 1.4;
}
}

View File

@ -3,7 +3,7 @@ figure {
margin-bottom: 2rem;
figcaption {
margin-top: .875rem;
color: var(--xm-c-figcaption);
color: var(--xm-c-shallow);
font-size: .875rem;
line-height: 1.45;
}

19
src/partials/link.scss Normal file
View File

@ -0,0 +1,19 @@
a {
border-bottom: 1px solid var(--xm-c-border);
color: var(--xm-c-deeper);
font-weight: 500;
text-decoration: none;
transition: border .3s ease-in-out;
code {
color: var(--xm-c-deep);
}
&:hover {
border-bottom: 1px solid var(--xm-c-regular);
}
&:not([href]) {
border-bottom: none;
color: inherit;
font-weight: normal;
transition: none;
}
}

View File

@ -2,6 +2,7 @@ li {
margin-top: .5rem;
margin-bottom: .5rem;
}
ol {
margin-top: 1.25rem;
margin-bottom: 1.25rem;
@ -13,11 +14,12 @@ ol {
content: counter(list-item, decimal) '.';
position: absolute;
left: 0;
color: var(--xm-c-ol-counter);
color: var(--xm-c-shallow);
font-weight: 400;
}
}
}
ul {
margin-top: 1.25rem;
margin-bottom: 1.25rem;
@ -33,10 +35,11 @@ ul {
width: .375rem;
height: .375rem;
border-radius: 50%;
background-color: var(--xm-c-ul-counter);
background-color: var(--xm-c-shallower);
}
}
}
ul ul,
ul ol,
ol ul,

17
src/partials/media.scss Normal file
View File

@ -0,0 +1,17 @@
img {
display: block;
max-width: 92%;
margin: 1rem auto;
border-radius: .2rem;
}
video {
margin: auto;
}
iframe {
display: flex;
width: 92%;
margin: auto;
border-radius: .2rem;
}

View File

@ -2,12 +2,14 @@ blockquote,
q {
margin-top: 1.65rem;
margin-bottom: 1.65rem;
padding-left: 1rem;
border-left: .25rem solid var(--xm-c-quote-border);
padding: .6rem 1.2rem;
border-left: .25rem solid var(--xm-c-border);
color: inherit;
font-weight: 500;
font-style: italic;
line-height: 1.5rem;
quotes: '\201C''\201D''\2018''\2019';
opacity: .75;
p {
&:first-of-type::before {
content: open-quote;
@ -16,4 +18,12 @@ q {
content: close-quote;
}
}
> * {
&:first-child {
margin-top: 0;
}
&:last-child {
margin-bottom: 0;
}
}
}

19
src/partials/table.scss Normal file
View File

@ -0,0 +1,19 @@
table {
overflow: auto;
width: 100%;
border-spacing: 0;
border-collapse: collapse;
th,
td {
padding: 6px 13px;
border: 1.5px solid var(--xm-c-border-table);
}
thead th {
font-weight: 700;
}
tbody tr {
&:hover {
background-color: var(--xm-c-shallowest);
}
}
}

View File

@ -2,13 +2,16 @@ p {
margin-top: 1.25rem;
margin-bottom: 1.25rem;
}
strong {
color: var(--xm-c-deep);
font-weight: 600;
}
b {
color: var(--xm-c-deep);
}
em {
color: inherit;
}

View File

@ -6,6 +6,7 @@ h1 {
font-size: 2.25rem;
line-height: 1.15;
}
h2 {
margin-top: 2rem;
margin-bottom: 1rem;
@ -20,6 +21,7 @@ h2 {
margin-top: 0;
}
}
h3 {
margin-top: 1.6rem;
margin-bottom: .6rem;
@ -35,6 +37,7 @@ h3 {
margin-top: 0;
}
}
h4 {
margin-top: 1.5rem;
margin-bottom: .5rem;
@ -45,6 +48,7 @@ h4 {
margin-top: 0;
}
}
h5,
h6 {
margin-top: 20px;
@ -54,11 +58,40 @@ h6 {
text-transform: uppercase;
opacity: .5;
}
hr {
margin-top: 3rem;
margin-bottom: 3rem;
width: 50px;
margin-top: 2rem;
margin-bottom: 2rem;
border-color: var(--xm-c-hr-border);
+ * {
margin-top: 0;
}
}
.header-anchor {
float: left;
margin-top: 0;
margin-left: -1.25rem;
padding-right: .5rem;
border: 0 !important;
font-weight: 600;
font-size: inherit;
text-decoration: none;
opacity: 0;
&:hover,
&:focus {
text-decoration: none;
}
}
@for $i from 1 through 6 {
h#{$i} {
&:hover,
&:focus {
.header-anchor {
opacity: .35 + $i * .025;
}
}
}
}

View File

@ -1,103 +0,0 @@
.markdown-body {
color: var(--xm-c-regular);
font-family: var(--xm-font-display) !important;
pre:not(.shiki, .highlight) {
margin: 0;
padding: 0;
background: transparent;
}
.shiki,
.highlight {
margin: .5rem 0;
font-size: 1.05rem;
font-family: var(--xm-font-code) !important;
line-height: 1.4;
&.shiki-light {
background: var(--xm-c-shiki-light) !important;
}
&.shiki-dark {
background: var(--xm-c-shiki-dark) !important;
}
}
img {
width: 100%;
}
a {
border-bottom: 1px solid var(--xm-c-link-border);
font-weight: inherit;
text-decoration: none;
transition: border .3s ease-in-out;
&:hover {
border-bottom: 1px solid var(--xm-c-regular);
}
code {
color: inherit;
}
}
hr {
width: 50px;
margin-top: 2rem;
margin-bottom: 2rem;
}
blockquote,
q {
padding: .6rem 1.2rem;
font-weight: normal;
font-style: normal;
line-height: 1.5rem;
opacity: .8;
> * {
&:first-child {
margin-top: 0;
}
&:last-child {
margin-bottom: 0;
}
}
p:first-of-type {
&::before,
&::after {
content: none;
}
}
}
&:first-child {
margin-top: 1rem;
}
}
html:not(.dark) .shiki-dark,
.dark .shiki-light {
display: none;
}
.item {
text-decoration: none;
opacity: .6;
transition: .2s all ease-out;
&:hover {
opacity: 1;
}
}
.header-anchor {
float: left;
margin-top: .125rem;
margin-left: -1.25rem;
padding-right: .5rem;
border: 0 !important;
font-size: .875rem;
text-decoration: none;
opacity: 0;
&:hover,
&:focus {
text-decoration: none;
}
}
@for $i from 1 through 6 {
h#{$i} {
&:hover,
&:focus {
.header-anchor {
opacity: .35 + $i * .025;
}
}
}
}

View File

@ -1 +0,0 @@
@import 'title', 'text', 'link', 'code', 'quote', 'figure', 'list', 'table', 'media';

View File

@ -1,8 +0,0 @@
a {
color: var(--xm-c-deeper);
font-weight: 500;
text-decoration: none;
code {
color: var(--xm-c-code);
}
}

View File

@ -1,5 +0,0 @@
img,
video {
margin-top: 2rem;
margin-bottom: 2rem;
}

View File

@ -1,44 +0,0 @@
table {
width: 100%;
margin-top: 2rem;
margin-bottom: 2rem;
table-layout: auto;
font-size: .875rem;
line-height: 1.75;
text-align: left;
}
thead {
border-bottom-width: 1px;
border-bottom-color: var(--xm-c-thead-border);
color: var(--xm-c-thead);
font-weight: 600;
th {
vertical-align: bottom;
padding-left: auto .575rem .575rem;
&:first-child {
padding-left: 0;
}
&:last-child {
padding-right: 0;
}
}
}
tbody {
tr {
border-bottom-width: 1px;
border-bottom-color: var(--xm-c-tr-border);
&:last-child {
border-bottom-width: 0;
}
}
td {
vertical-align: top;
padding: .575rem;
&:first-child {
padding-left: 0;
}
&:last-child {
padding-right: 0;
}
}
}

View File

@ -1,6 +0,0 @@
@use 'partials/container' as *;
.prose {
@include container;
@import 'partials/all';
}

View File

@ -1,18 +0,0 @@
// Colors
$pre: #e5e7eb;
$code: #111827;
$figcaption: #6b7280;
$thead: #111827;
$ol-counter: #6b7280;
$ul-counter: #d1d5db;
// Border
$link-border: hsla(0deg 0% 50% / .3);
$hr-border: hsla(0deg 0% 50% / .3);
$quote-border: hsla(0deg 0% 50% / .3);
$thead-border: #d1d5db;
$tr-border: #e5e7eb;
// Shiki (code highlight)
$shiki-light: #f8f8f8;
$shiki-dark: #0e0e0e;

View File

@ -1,3 +0,0 @@
$regular: #bbb;
$deep: #ddd;
$deeper: #fff;

View File

@ -1,3 +0,0 @@
$regular: #555;
$deep: #222;
$deeper: #000;

View File

@ -1,26 +0,0 @@
@use 'sass:meta' as *;
@use 'variables/constants';
@use 'variables/colors';
@use 'variables/modes/light';
@use 'variables/modes/dark';
:root {
@each $name, $val in module-variables('constants') {
--xm-#{$name}: #{$val};
}
@each $name, $val in module-variables('colors') {
--xm-c-#{$name}: #{$val};
}
}
.markdown-body {
@each $name, $val in module-variables('light') {
--xm-c-#{$name}: #{$val};
}
}
.dark .markdown-body {
@each $name, $val in module-variables('dark') {
--xm-c-#{$name}: #{$val};
}
}

View File

@ -0,0 +1,10 @@
// Dark mode
$shallowest: #212121;
$shallower: #555;
$shallow: #777;
$regular: #bbb;
$deep: #ddd;
$deeper: #fff;
$border: hsla(0deg 0% 75% / .35);
$border-table: hsla(0deg 0% 40% / .75);

View File

@ -0,0 +1,10 @@
// Light mode
$shallowest: #f8f8f8;
$shallower: #ddd;
$shallow: #bbb;
$regular: #555;
$deep: #222;
$deeper: #000;
$border: hsla(0deg 0% 50% / .35);
$border-table: hsla(0deg 0% 50% / .5);