mirror of
https://github.com/ourongxing/newsnow.git
synced 2025-01-19 03:09:14 +08:00
56 lines
1.6 KiB
TypeScript
56 lines
1.6 KiB
TypeScript
import { defineConfig, presetIcons, presetUno, transformerDirectives, transformerVariantGroup } from "unocss"
|
|
import { hex2rgba } from "@unocss/rule-utils"
|
|
import { colors } from "unocss/preset-mini"
|
|
import { sources } from "./shared/sources"
|
|
|
|
export default defineConfig({
|
|
mergeSelectors: false,
|
|
transformers: [transformerDirectives(), transformerVariantGroup()],
|
|
presets: [
|
|
presetUno(),
|
|
presetIcons({
|
|
scale: 1.2,
|
|
}),
|
|
],
|
|
rules: [
|
|
[/^sprinkle-(.+)$/, ([_, d]) => {
|
|
if (d in colors) {
|
|
// @ts-expect-error >_<
|
|
const hex: any = colors[d]?.[400]
|
|
if (hex) {
|
|
return {
|
|
"background-image": `radial-gradient(ellipse 80% 80% at 50% -30%,
|
|
rgba(${hex2rgba(hex)?.join(", ")}, 0.3),
|
|
rgba(255, 255, 255, 0));`,
|
|
}
|
|
}
|
|
}
|
|
}],
|
|
[
|
|
"font-brand",
|
|
{
|
|
"font-family": `"Baloo 2", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas,
|
|
"Liberation Mono", "Courier New", monospace; `,
|
|
},
|
|
],
|
|
],
|
|
shortcuts: {
|
|
"color-base": "color-neutral-800 dark:color-neutral-300",
|
|
"bg-base": "bg-white dark:bg-dark-600",
|
|
|
|
"color-active": "color-primary-600 dark:color-primary-400",
|
|
"border-active": "border-primary-600/25 dark:border-primary-400/25",
|
|
"bg-active": "bg-primary-400/10",
|
|
|
|
"btn-pure": "op50 hover:op75",
|
|
},
|
|
safelist: [
|
|
...["bg", "color", "border", "sprinkle", "shadow"].map(t => Object.values(sources).map(c => `${t}-${c.color}`)).flat(1),
|
|
],
|
|
extendTheme: (theme) => {
|
|
// @ts-expect-error >_<
|
|
theme.colors.primary = theme.colors.red
|
|
return theme
|
|
},
|
|
})
|