mirror of
https://github.com/reonokiy/blog.nokiy.net.git
synced 2025-06-16 11:41:17 +02:00
chore: refine plugins and astro config
This commit is contained in:
parent
5d77abf77c
commit
77fc6eff6c
10 changed files with 346 additions and 460 deletions
|
@ -1,6 +1,8 @@
|
||||||
|
// Plugins
|
||||||
import type { ThemeConfig } from './src/types'
|
import type { ThemeConfig } from './src/types'
|
||||||
import mdx from '@astrojs/mdx'
|
import mdx from '@astrojs/mdx'
|
||||||
import sitemap from '@astrojs/sitemap'
|
import sitemap from '@astrojs/sitemap'
|
||||||
|
import { transformerCopyButton } from '@rehype-pretty/transformers'
|
||||||
import swup from '@swup/astro'
|
import swup from '@swup/astro'
|
||||||
import compress from 'astro-compress'
|
import compress from 'astro-compress'
|
||||||
import robotsTxt from 'astro-robots-txt'
|
import robotsTxt from 'astro-robots-txt'
|
||||||
|
@ -17,14 +19,13 @@ import remarkDirective from 'remark-directive'
|
||||||
import remarkGithubAdmonitionsToDirectives from 'remark-github-admonitions-to-directives'
|
import remarkGithubAdmonitionsToDirectives from 'remark-github-admonitions-to-directives'
|
||||||
import remarkMath from 'remark-math'
|
import remarkMath from 'remark-math'
|
||||||
import remarkSectionize from 'remark-sectionize'
|
import remarkSectionize from 'remark-sectionize'
|
||||||
//
|
// Markdown Extensions
|
||||||
import UnoCSS from 'unocss/astro'
|
import UnoCSS from 'unocss/astro'
|
||||||
import { themeConfig } from './src/config'
|
import { themeConfig } from './src/config'
|
||||||
import { AdmonitionComponent } from './src/plugins/rehype-component-admonition.ts'
|
import { AdmonitionComponent } from './src/plugins/rehype-component-admonition.ts'
|
||||||
import { GithubCardComponent } from './src/plugins/rehype-component-github-card.ts'
|
import { GithubCardComponent } from './src/plugins/rehype-component-github-card.ts'
|
||||||
import { parseDirectiveNode } from './src/plugins/remark-directive-rehype.ts'
|
import { parseDirectiveNode } from './src/plugins/remark-directive-rehype.ts'
|
||||||
import { remarkExcerpt } from './src/plugins/remark-excerpt.ts'
|
import { remarkExcerpt } from './src/plugins/remark-excerpt.ts'
|
||||||
|
|
||||||
import { remarkReadingTime } from './src/plugins/remark-reading-time.ts'
|
import { remarkReadingTime } from './src/plugins/remark-reading-time.ts'
|
||||||
|
|
||||||
const { url }: { url: ThemeConfig['site']['url'] } = themeConfig.site
|
const { url }: { url: ThemeConfig['site']['url'] } = themeConfig.site
|
||||||
|
@ -36,8 +37,15 @@ export default defineConfig({
|
||||||
integrations: [
|
integrations: [
|
||||||
UnoCSS({ injectReset: true }),
|
UnoCSS({ injectReset: true }),
|
||||||
mdx(),
|
mdx(),
|
||||||
sitemap(),
|
sitemap({
|
||||||
robotsTxt(),
|
changefreq: 'weekly',
|
||||||
|
priority: 0.7,
|
||||||
|
lastmod: new Date(),
|
||||||
|
}),
|
||||||
|
robotsTxt({
|
||||||
|
policy: [{ userAgent: '*', allow: '/' }],
|
||||||
|
sitemap: true,
|
||||||
|
}),
|
||||||
compress(),
|
compress(),
|
||||||
swup({
|
swup({
|
||||||
theme: false,
|
theme: false,
|
||||||
|
@ -66,14 +74,22 @@ export default defineConfig({
|
||||||
[
|
[
|
||||||
rehypePrettyCode,
|
rehypePrettyCode,
|
||||||
{
|
{
|
||||||
|
// TODO: Add auto theme switcher
|
||||||
theme: 'github-dark',
|
theme: 'github-dark',
|
||||||
|
transformers: [
|
||||||
|
transformerCopyButton({
|
||||||
|
visibility: 'hover',
|
||||||
|
feedbackDuration: 2_500,
|
||||||
|
}),
|
||||||
|
],
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
rehypeExternalLinks,
|
rehypeExternalLinks,
|
||||||
{
|
{
|
||||||
target: '_blank',
|
target: '_blank',
|
||||||
rel: ['nofollow', 'noopener', 'noreferrer'],
|
rel: ['nofollow', 'noopener', 'noreferrer', 'external'],
|
||||||
|
protocols: ['http', 'https', 'mailto'],
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
|
@ -114,5 +130,4 @@ export default defineConfig({
|
||||||
],
|
],
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
|
|
||||||
})
|
})
|
||||||
|
|
17
package.json
17
package.json
|
@ -18,12 +18,13 @@
|
||||||
"@astrojs/mdx": "^4.0.5",
|
"@astrojs/mdx": "^4.0.5",
|
||||||
"@astrojs/rss": "^4.0.11",
|
"@astrojs/rss": "^4.0.11",
|
||||||
"@astrojs/sitemap": "^3.2.1",
|
"@astrojs/sitemap": "^3.2.1",
|
||||||
|
"@rehype-pretty/transformers": "^0.13.2",
|
||||||
"@swup/astro": "^1.5.0",
|
"@swup/astro": "^1.5.0",
|
||||||
|
"@unocss/reset": "^65.4.0",
|
||||||
"astro": "^5.1.6",
|
"astro": "^5.1.6",
|
||||||
"astro-compress": "^2.3.6",
|
"astro-compress": "^2.3.6",
|
||||||
"astro-robots-txt": "^1.0.0",
|
"astro-robots-txt": "^1.0.0",
|
||||||
"astro-seo": "^0.8.4",
|
"astro-seo": "^0.8.4",
|
||||||
"markdown-it": "^14.1.0",
|
|
||||||
"overlayscrollbars": "^2.10.1",
|
"overlayscrollbars": "^2.10.1",
|
||||||
"photoswipe": "^5.4.4",
|
"photoswipe": "^5.4.4",
|
||||||
"rehype-autolink-headings": "^7.1.0",
|
"rehype-autolink-headings": "^7.1.0",
|
||||||
|
@ -33,39 +34,33 @@
|
||||||
"rehype-pretty-code": "^0.14.0",
|
"rehype-pretty-code": "^0.14.0",
|
||||||
"rehype-slug": "^6.0.0",
|
"rehype-slug": "^6.0.0",
|
||||||
"remark-directive": "^3.0.0",
|
"remark-directive": "^3.0.0",
|
||||||
"remark-directive-rehype": "^0.4.2",
|
|
||||||
"remark-github-admonitions-to-directives": "^2.1.0",
|
"remark-github-admonitions-to-directives": "^2.1.0",
|
||||||
"remark-math": "^6.0.0",
|
"remark-math": "^6.0.0",
|
||||||
"remark-sectionize": "^2.1.0",
|
"remark-sectionize": "^2.1.0",
|
||||||
"sanitize-html": "^2.14.0",
|
"sanitize-html": "^2.14.0",
|
||||||
"sharp": "^0.33.5",
|
"sharp": "^0.33.5",
|
||||||
"shiki": "^1.26.2",
|
|
||||||
"typescript": "~5.7.3",
|
"typescript": "~5.7.3",
|
||||||
"unist-util-visit": "^5.0.0",
|
"unist-util-visit": "^5.0.0",
|
||||||
"vite": "^6.0.7"
|
"vite": "^6.0.7"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@antfu/eslint-config": "^3.14.0",
|
"@antfu/eslint-config": "^3.14.0",
|
||||||
"@types/markdown-it": "^14.1.2",
|
"@types/hast": "^3.0.4",
|
||||||
"@types/mdast": "^4.0.4",
|
"@types/mdast": "^4.0.4",
|
||||||
"@types/node": "^22.10.5",
|
"@types/node": "^22.10.6",
|
||||||
"@types/sanitize-html": "^2.13.0",
|
"@types/sanitize-html": "^2.13.0",
|
||||||
"@types/unist": "^3.0.3",
|
"@types/unist": "^3.0.3",
|
||||||
"@unocss/eslint-plugin": "^65.4.0",
|
"@unocss/eslint-plugin": "^65.4.0",
|
||||||
"@unocss/preset-attributify": "^65.4.0",
|
|
||||||
"@unocss/reset": "^65.4.0",
|
|
||||||
"@unocss/transformer-directives": "^65.4.0",
|
|
||||||
"astro-eslint-parser": "^1.1.0",
|
"astro-eslint-parser": "^1.1.0",
|
||||||
"consola": "^3.3.3",
|
|
||||||
"eslint": "^9.18.0",
|
"eslint": "^9.18.0",
|
||||||
"eslint-plugin-astro": "^1.3.1",
|
"eslint-plugin-astro": "^1.3.1",
|
||||||
"esno": "^4.8.0",
|
|
||||||
"hastscript": "^9.0.0",
|
"hastscript": "^9.0.0",
|
||||||
"lint-staged": "^15.3.0",
|
"lint-staged": "^15.3.0",
|
||||||
"mdast-util-to-string": "^4.0.0",
|
"mdast-util-to-string": "^4.0.0",
|
||||||
"reading-time": "^1.5.0",
|
"reading-time": "^1.5.0",
|
||||||
"unocss": "^65.4.0",
|
"unocss": "^65.4.0",
|
||||||
"unocss-preset-theme": "^0.14.1"
|
"unocss-preset-theme": "^0.14.1",
|
||||||
|
"vfile": "^6.0.3"
|
||||||
},
|
},
|
||||||
"lint-staged": {
|
"lint-staged": {
|
||||||
"*.{js,ts,jsx,tsx,astro}": "eslint --fix"
|
"*.{js,ts,jsx,tsx,astro}": "eslint --fix"
|
||||||
|
|
618
pnpm-lock.yaml
generated
618
pnpm-lock.yaml
generated
File diff suppressed because it is too large
Load diff
|
@ -1,8 +1,6 @@
|
||||||
---
|
---
|
||||||
import Welcome from '@/components/Welcome.astro'
|
|
||||||
import Layout from '@/layouts/Layout.astro'
|
import Layout from '@/layouts/Layout.astro'
|
||||||
---
|
---
|
||||||
|
|
||||||
<Layout>
|
<Layout>
|
||||||
<Welcome />
|
|
||||||
</Layout>
|
</Layout>
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
import type { Element, Properties as HastProperties, Node } from 'hast'
|
import type { Element, Properties as HastProperties, Node } from 'hast'
|
||||||
/// <reference types="mdast" />
|
|
||||||
import { h } from 'hastscript'
|
import { h } from 'hastscript'
|
||||||
|
|
||||||
interface AdmonitionProperties extends HastProperties {
|
interface AdmonitionProperties extends HastProperties {
|
||||||
|
@ -7,25 +6,19 @@ interface AdmonitionProperties extends HastProperties {
|
||||||
'has-directive-label'?: boolean
|
'has-directive-label'?: boolean
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
type AdmonitionType = 'tip' | 'note' | 'important' | 'caution' | 'warning'
|
||||||
* Creates an admonition component.
|
|
||||||
*
|
const ADMONITION_CLASS_PREFIX = 'bdm-'
|
||||||
* @param properties - The properties of the component.
|
const DEFAULT_ERROR_MESSAGE = 'Invalid admonition directive. (Admonition directives must be of block type ":::note{name="name"} <content> :::")'
|
||||||
* @param type - The admonition type.
|
|
||||||
* @param children - The children elements of the component.
|
|
||||||
* @returns The created admonition component as a Hast Element.
|
|
||||||
*/
|
|
||||||
export function AdmonitionComponent(
|
export function AdmonitionComponent(
|
||||||
properties: AdmonitionProperties,
|
properties: AdmonitionProperties,
|
||||||
type: 'tip' | 'note' | 'important' | 'caution' | 'warning',
|
type: AdmonitionType,
|
||||||
children: Node[],
|
children: Node[],
|
||||||
): Element {
|
): Element {
|
||||||
if (!Array.isArray(children) || children.length === 0) {
|
if (!Array.isArray(children) || children.length === 0) {
|
||||||
return h(
|
console.warn('Invalid admonition directive: empty or invalid children')
|
||||||
'div',
|
return h('div', { class: 'hidden' }, DEFAULT_ERROR_MESSAGE)
|
||||||
{ class: 'hidden' },
|
|
||||||
'Invalid admonition directive. (Admonition directives must be of block type ":::note{name="name"} <content> :::")',
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
let label: Element | string | null = null
|
let label: Element | string | null = null
|
||||||
|
@ -36,14 +29,14 @@ export function AdmonitionComponent(
|
||||||
|
|
||||||
if (firstChild && firstChild.type === 'element') {
|
if (firstChild && firstChild.type === 'element') {
|
||||||
label = firstChild as Element
|
label = firstChild as Element
|
||||||
label.tagName = 'div' // Change the tag <p> to <div>
|
label.tagName = 'div'
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
label = ''
|
label = ''
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return h('blockquote', { class: `admonition bdm-${type}` }, [
|
return h('blockquote', { class: `${ADMONITION_CLASS_PREFIX}${type}` }, [
|
||||||
h('span', { class: 'bdm-title' }, label || type.toUpperCase()),
|
h('span', { class: 'bdm-title' }, label || type.toUpperCase()),
|
||||||
...(children as Element[]),
|
...(children as Element[]),
|
||||||
] as Element[])
|
] as Element[])
|
||||||
|
|
|
@ -1,17 +1,10 @@
|
||||||
/// <reference types="mdast" />
|
/// <reference types="mdast" />
|
||||||
|
import type { RootContent } from 'mdast'
|
||||||
import { h } from 'hastscript'
|
import { h } from 'hastscript'
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates a GitHub Card component.
|
|
||||||
*
|
|
||||||
* @param {object} properties - The properties of the component.
|
|
||||||
* @param {string} properties.repo - The GitHub repository in the format "owner/repo".
|
|
||||||
* @param {import('mdast').RootContent[]} children - The children elements of the component.
|
|
||||||
* @returns {import('mdast').Parent} The created GitHub Card component.
|
|
||||||
*/
|
|
||||||
export function GithubCardComponent(
|
export function GithubCardComponent(
|
||||||
properties: { repo: string },
|
properties: { repo: string },
|
||||||
children: import('mdast').RootContent[],
|
children: RootContent[],
|
||||||
): import('mdast').Parent {
|
): import('mdast').Parent {
|
||||||
if (Array.isArray(children) && children.length !== 0) {
|
if (Array.isArray(children) && children.length !== 0) {
|
||||||
return h('div', { class: 'hidden' }, [
|
return h('div', { class: 'hidden' }, [
|
||||||
|
@ -28,7 +21,7 @@ export function GithubCardComponent(
|
||||||
}
|
}
|
||||||
|
|
||||||
const repo = properties.repo
|
const repo = properties.repo
|
||||||
const cardUuid = `GC${Math.random().toString(36).slice(-6)}` // Collisions are not important
|
const cardUuid = `GC${Math.random().toString(36).slice(-6)}`
|
||||||
|
|
||||||
const nAvatar = h(`div#${cardUuid}-avatar`, { class: 'gc-avatar' })
|
const nAvatar = h(`div#${cardUuid}-avatar`, { class: 'gc-avatar' })
|
||||||
const nLanguage = h(
|
const nLanguage = h(
|
||||||
|
@ -63,29 +56,39 @@ export function GithubCardComponent(
|
||||||
`script#${cardUuid}-script`,
|
`script#${cardUuid}-script`,
|
||||||
{ type: 'text/javascript', defer: true },
|
{ type: 'text/javascript', defer: true },
|
||||||
`
|
`
|
||||||
fetch('https://api.github.com/repos/${repo}', { referrerPolicy: "no-referrer" }).then(response => response.json()).then(data => {
|
fetch('https://api.github.com/repos/${repo}', {
|
||||||
if (data.description) {
|
referrerPolicy: "no-referrer",
|
||||||
document.getElementById('${cardUuid}-description').innerText = data.description.replace(/:[a-zA-Z0-9_]+:/g, '');
|
headers: {
|
||||||
} else {
|
'Accept': 'application/vnd.github.v3+json',
|
||||||
document.getElementById('${cardUuid}-description').innerText = "Description not set"
|
},
|
||||||
|
signal: AbortSignal.timeout(5000)
|
||||||
|
}).then(response => {
|
||||||
|
if (!response.ok)
|
||||||
|
throw new Error(\`HTTP error! status: \${response.status}\`)
|
||||||
|
return response.json()
|
||||||
|
}).then(data => {
|
||||||
|
const elements = {
|
||||||
|
description: document.getElementById('${cardUuid}-description'),
|
||||||
|
language: document.getElementById('${cardUuid}-language'),
|
||||||
|
stars: document.getElementById('${cardUuid}-stars'),
|
||||||
}
|
}
|
||||||
document.getElementById('${cardUuid}-language').innerText = data.language;
|
|
||||||
document.getElementById('${cardUuid}-forks').innerText = Intl.NumberFormat('en-us', { notation: "compact", maximumFractionDigits: 1 }).format(data.forks).replaceAll("\\u202F", '');
|
elements.description.innerText = data.description?.replace(/:[a-zA-Z0-9_]+:/g, '') ?? 'Description not set'
|
||||||
document.getElementById('${cardUuid}-stars').innerText = Intl.NumberFormat('en-us', { notation: "compact", maximumFractionDigits: 1 }).format(data.stargazers_count).replaceAll("\\u202F", '');
|
elements.language.innerText = data.language
|
||||||
const avatarEl = document.getElementById('${cardUuid}-avatar');
|
elements.stars.innerText = Intl.NumberFormat('en-us', { notation: "compact", maximumFractionDigits: 1 }).format(data.stargazers_count).replaceAll("\\u202F", '')
|
||||||
avatarEl.style.backgroundImage = 'url(' + data.owner.avatar_url + ')';
|
|
||||||
avatarEl.style.backgroundColor = 'transparent';
|
const avatarEl = document.getElementById('${cardUuid}-avatar')
|
||||||
if (data.license?.spdx_id) {
|
avatarEl.style.backgroundImage = 'url(' + data.owner.avatar_url + ')'
|
||||||
document.getElementById('${cardUuid}-license').innerText = data.license?.spdx_id
|
avatarEl.style.backgroundColor = 'transparent'
|
||||||
} else {
|
|
||||||
document.getElementById('${cardUuid}-license').innerText = "no-license"
|
document.getElementById('${cardUuid}-license').innerText = data.license?.spdx_id ?? 'no-license'
|
||||||
};
|
document.getElementById('${cardUuid}-card').classList.remove("fetch-waiting")
|
||||||
document.getElementById('${cardUuid}-card').classList.remove("fetch-waiting");
|
|
||||||
console.log("[GITHUB-CARD] Loaded card for ${repo} | ${cardUuid}.")
|
console.log("[GITHUB-CARD] Loaded card for ${repo} | ${cardUuid}.")
|
||||||
}).catch(err => {
|
}).catch(err => {
|
||||||
const c = document.getElementById('${cardUuid}-card');
|
const c = document.getElementById('${cardUuid}-card')
|
||||||
c.classList.add("fetch-error");
|
c.classList.add("fetch-error")
|
||||||
console.warn("[GITHUB-CARD] (Error) Loading card for ${repo} | ${cardUuid}.")
|
document.getElementById('${cardUuid}-description').innerText = "Failed to load repository data"
|
||||||
|
console.warn("[GITHUB-CARD] (Error) Loading card for ${repo} | ${cardUuid}:", err.message)
|
||||||
})
|
})
|
||||||
`,
|
`,
|
||||||
)
|
)
|
||||||
|
@ -98,11 +101,6 @@ export function GithubCardComponent(
|
||||||
target: '_blank',
|
target: '_blank',
|
||||||
repo,
|
repo,
|
||||||
},
|
},
|
||||||
[
|
[nTitle, nDescription, h('div', { class: 'gc-infobar' }, [nStars, nForks, nLicense, nLanguage]), nScript],
|
||||||
nTitle,
|
|
||||||
nDescription,
|
|
||||||
h('div', { class: 'gc-infobar' }, [nStars, nForks, nLicense, nLanguage]),
|
|
||||||
nScript,
|
|
||||||
],
|
|
||||||
) as unknown as import('mdast').Parent
|
) as unknown as import('mdast').Parent
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,14 +28,11 @@ export function parseDirectiveNode() {
|
||||||
) {
|
) {
|
||||||
const data = directiveNode.data || (directiveNode.data = {})
|
const data = directiveNode.data || (directiveNode.data = {})
|
||||||
directiveNode.attributes = directiveNode.attributes || {}
|
directiveNode.attributes = directiveNode.attributes || {}
|
||||||
if (
|
|
||||||
directiveNode.children.length > 0
|
|
||||||
&& directiveNode.children[0].data?.directiveLabel
|
|
||||||
) {
|
|
||||||
directiveNode.attributes['has-directive-label'] = true
|
|
||||||
}
|
|
||||||
const hast = h(directiveNode.name, directiveNode.attributes)
|
|
||||||
|
|
||||||
|
if (directiveNode.children[0]?.data?.directiveLabel)
|
||||||
|
directiveNode.attributes['has-directive-label'] = true
|
||||||
|
|
||||||
|
const hast = h(directiveNode.name, directiveNode.attributes)
|
||||||
data.hName = hast.tagName
|
data.hName = hast.tagName
|
||||||
data.hProperties = hast.properties
|
data.hProperties = hast.properties
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,18 +4,9 @@ import { toString } from 'mdast-util-to-string'
|
||||||
|
|
||||||
export function remarkExcerpt() {
|
export function remarkExcerpt() {
|
||||||
return function (tree: Root, file: VFile) {
|
return function (tree: Root, file: VFile) {
|
||||||
let excerpt = ''
|
const firstParagraph = tree.children.find(node => node.type === 'paragraph')
|
||||||
for (const node of tree.children) {
|
const excerpt = firstParagraph ? toString(firstParagraph) : ''
|
||||||
if (node.type === 'paragraph') {
|
const frontmatter = (file.data.astro ??= {}).frontmatter ??= {}
|
||||||
excerpt = toString(node)
|
frontmatter.excerpt = excerpt
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// 确保 data.astro.frontmatter 存在
|
|
||||||
file.data.astro = file.data.astro || {}
|
|
||||||
file.data.astro.frontmatter = file.data.astro.frontmatter || {}
|
|
||||||
|
|
||||||
file.data.astro.frontmatter.excerpt = excerpt
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,12 +7,8 @@ export function remarkReadingTime() {
|
||||||
return function (tree: Root, file: VFile) {
|
return function (tree: Root, file: VFile) {
|
||||||
const textOnPage = toString(tree)
|
const textOnPage = toString(tree)
|
||||||
const readingTime = getReadingTime(textOnPage)
|
const readingTime = getReadingTime(textOnPage)
|
||||||
|
const frontmatter = (file.data.astro ??= {}).frontmatter ??= {}
|
||||||
// 确保 data.astro.frontmatter 存在
|
frontmatter.minutes = Math.max(1, Math.round(readingTime.minutes))
|
||||||
file.data.astro = file.data.astro || {}
|
frontmatter.words = readingTime.words
|
||||||
file.data.astro.frontmatter = file.data.astro.frontmatter || {}
|
|
||||||
|
|
||||||
file.data.astro.frontmatter.minutes = Math.max(1, Math.round(readingTime.minutes))
|
|
||||||
file.data.astro.frontmatter.words = readingTime.words
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
5
src/styles/global.css
Normal file
5
src/styles/global.css
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
:root {
|
||||||
|
--uno-colors-primary: theme('colors.primary');
|
||||||
|
--uno-colors-backgroundStart: theme('colors.backgroundStart');
|
||||||
|
--uno-colors-backgroundEnd: theme('colors.backgroundEnd');
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue