feat: unocss-preset-shadcn
This commit is contained in:
20
components.json
Normal file
20
components.json
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
{
|
||||||
|
"$schema": "https://shadcn-vue.com/schema.json",
|
||||||
|
"style": "new-york",
|
||||||
|
"typescript": true,
|
||||||
|
"tailwind": {
|
||||||
|
"config": "tailwind.config.js",
|
||||||
|
"css": "src/shadcn/index.css",
|
||||||
|
"baseColor": "neutral",
|
||||||
|
"cssVariables": true,
|
||||||
|
"prefix": ""
|
||||||
|
},
|
||||||
|
"aliases": {
|
||||||
|
"components": "@/shadcn/components",
|
||||||
|
"composables": "@/shadcn/composables",
|
||||||
|
"utils": "@/shadcn/lib/utils",
|
||||||
|
"ui": "@/shadcn/components/ui",
|
||||||
|
"lib": "@/shadcn/lib"
|
||||||
|
},
|
||||||
|
"iconLibrary": "lucide"
|
||||||
|
}
|
@ -22,6 +22,7 @@ configureVueProject({ scriptLangs: ['ts', 'tsx', 'js', 'jsx'] });
|
|||||||
export default defineConfigWithVueTs(
|
export default defineConfigWithVueTs(
|
||||||
includeIgnoreFile(gitignorePath), // oxlint . --fix -D correctness --ignore-path .gitignore
|
includeIgnoreFile(gitignorePath), // oxlint . --fix -D correctness --ignore-path .gitignore
|
||||||
{ ignores: ['typed-router.d.ts'] },
|
{ ignores: ['typed-router.d.ts'] },
|
||||||
|
{ ignores: ['src/shadcn/**'] },
|
||||||
{
|
{
|
||||||
files: ['**/*.{ts,mts,tsx,vue}'],
|
files: ['**/*.{ts,mts,tsx,vue}'],
|
||||||
name: 'app/files-to-lint',
|
name: 'app/files-to-lint',
|
||||||
|
@ -51,10 +51,13 @@
|
|||||||
"ant-design-vue": "~4.2.6",
|
"ant-design-vue": "~4.2.6",
|
||||||
"axios": "^1.7.9",
|
"axios": "^1.7.9",
|
||||||
"cesium": "^1.127.0",
|
"cesium": "^1.127.0",
|
||||||
|
"class-variance-authority": "^0.7.1",
|
||||||
|
"clsx": "^2.1.1",
|
||||||
"consola": "^3.4.0",
|
"consola": "^3.4.0",
|
||||||
"dayjs": "^1.11.13",
|
"dayjs": "^1.11.13",
|
||||||
"deep-freeze-es6": "^4.0.0",
|
"deep-freeze-es6": "^4.0.0",
|
||||||
"jsencrypt": "^3.3.2",
|
"jsencrypt": "^3.3.2",
|
||||||
|
"lucide-vue-next": "^0.483.0",
|
||||||
"mitt": "^3.0.1",
|
"mitt": "^3.0.1",
|
||||||
"nprogress": "^0.2.0",
|
"nprogress": "^0.2.0",
|
||||||
"orbpro": "^1.126.0",
|
"orbpro": "^1.126.0",
|
||||||
@ -65,7 +68,10 @@
|
|||||||
"primelocale": "^2.0.0",
|
"primelocale": "^2.0.0",
|
||||||
"primevue": "^4.3.1",
|
"primevue": "^4.3.1",
|
||||||
"radash": "^12.1.0",
|
"radash": "^12.1.0",
|
||||||
|
"radix-vue": "^1.9.17",
|
||||||
|
"reka-ui": "^2.1.1",
|
||||||
"satellite.js": "^5.0.0",
|
"satellite.js": "^5.0.0",
|
||||||
|
"tailwind-merge": "^3.0.2",
|
||||||
"tdesign-icons-vue-next": "^0.3.4",
|
"tdesign-icons-vue-next": "^0.3.4",
|
||||||
"ts-enum-util": "^4.1.0",
|
"ts-enum-util": "^4.1.0",
|
||||||
"utils4u": "^4.2.1",
|
"utils4u": "^4.2.1",
|
||||||
@ -118,7 +124,9 @@
|
|||||||
"terser": "^5.38.2",
|
"terser": "^5.38.2",
|
||||||
"typescript": "~5.8.2",
|
"typescript": "~5.8.2",
|
||||||
"unocss": "^66.0.0",
|
"unocss": "^66.0.0",
|
||||||
|
"unocss-preset-animations": "^1.1.1",
|
||||||
"unocss-preset-chinese": "^0.3.3",
|
"unocss-preset-chinese": "^0.3.3",
|
||||||
|
"unocss-preset-shadcn": "^0.5.0",
|
||||||
"unplugin-auto-import": "^19.0.0",
|
"unplugin-auto-import": "^19.0.0",
|
||||||
"unplugin-icons": "^22.0.0",
|
"unplugin-icons": "^22.0.0",
|
||||||
"unplugin-vue-components": "^28.0.0",
|
"unplugin-vue-components": "^28.0.0",
|
||||||
|
528
pnpm-lock.yaml
generated
528
pnpm-lock.yaml
generated
File diff suppressed because it is too large
Load Diff
15
src/pages/UI-components/ShadcnVue/index.page.vue
Normal file
15
src/pages/UI-components/ShadcnVue/index.page.vue
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
<script setup lang="ts">
|
||||||
|
import { Button as ShadcnButton } from '@/shadcn/components/ui/button';
|
||||||
|
|
||||||
|
const onClick = () => {
|
||||||
|
console.log('click');
|
||||||
|
};
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<template>
|
||||||
|
<div>
|
||||||
|
<ShadcnButton variant="link" :onClick>s</ShadcnButton>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<style scoped></style>
|
7
src/shadcn/README.md
Normal file
7
src/shadcn/README.md
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
- https://www.shadcn-vue.com/docs/components/button.html
|
||||||
|
- https://github.com/unocss-community/unocss-preset-shadcn?tab=readme-ov-file#usage
|
||||||
|
- https://unocss-preset-shadcn.vercel.app/
|
||||||
|
|
||||||
|
```
|
||||||
|
npx shadcn-vue@latest add button
|
||||||
|
```
|
26
src/shadcn/components/ui/button/Button.vue
Normal file
26
src/shadcn/components/ui/button/Button.vue
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
<script setup lang="ts">
|
||||||
|
import type { HTMLAttributes } from 'vue'
|
||||||
|
import { cn } from '@/shadcn/lib/utils'
|
||||||
|
import { Primitive, type PrimitiveProps } from 'reka-ui'
|
||||||
|
import { type ButtonVariants, buttonVariants } from '.'
|
||||||
|
|
||||||
|
interface Props extends PrimitiveProps {
|
||||||
|
variant?: ButtonVariants['variant']
|
||||||
|
size?: ButtonVariants['size']
|
||||||
|
class?: HTMLAttributes['class']
|
||||||
|
}
|
||||||
|
|
||||||
|
const props = withDefaults(defineProps<Props>(), {
|
||||||
|
as: 'button',
|
||||||
|
})
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<template>
|
||||||
|
<Primitive
|
||||||
|
:as="as"
|
||||||
|
:as-child="asChild"
|
||||||
|
:class="cn(buttonVariants({ variant, size }), props.class)"
|
||||||
|
>
|
||||||
|
<slot />
|
||||||
|
</Primitive>
|
||||||
|
</template>
|
35
src/shadcn/components/ui/button/index.ts
Normal file
35
src/shadcn/components/ui/button/index.ts
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
import { cva, type VariantProps } from 'class-variance-authority'
|
||||||
|
|
||||||
|
export { default as Button } from './Button.vue'
|
||||||
|
|
||||||
|
export const buttonVariants = cva(
|
||||||
|
'inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium transition-colors focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0',
|
||||||
|
{
|
||||||
|
variants: {
|
||||||
|
variant: {
|
||||||
|
default: 'bg-primary text-primary-foreground shadow hover:bg-primary/90',
|
||||||
|
destructive:
|
||||||
|
'bg-destructive text-destructive-foreground shadow-sm hover:bg-destructive/90',
|
||||||
|
outline:
|
||||||
|
'border border-input bg-background shadow-sm hover:bg-accent hover:text-accent-foreground',
|
||||||
|
secondary:
|
||||||
|
'bg-secondary text-secondary-foreground shadow-sm hover:bg-secondary/80',
|
||||||
|
ghost: 'hover:bg-accent hover:text-accent-foreground',
|
||||||
|
link: 'text-primary underline-offset-4 hover:underline',
|
||||||
|
},
|
||||||
|
size: {
|
||||||
|
default: 'h-9 px-4 py-2',
|
||||||
|
xs: 'h-7 rounded px-2',
|
||||||
|
sm: 'h-8 rounded-md px-3 text-xs',
|
||||||
|
lg: 'h-10 rounded-md px-8',
|
||||||
|
icon: 'h-9 w-9',
|
||||||
|
},
|
||||||
|
},
|
||||||
|
defaultVariants: {
|
||||||
|
variant: 'default',
|
||||||
|
size: 'default',
|
||||||
|
},
|
||||||
|
},
|
||||||
|
)
|
||||||
|
|
||||||
|
export type ButtonVariants = VariantProps<typeof buttonVariants>
|
7
src/shadcn/lib/utils.ts
Normal file
7
src/shadcn/lib/utils.ts
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
import type { ClassValue } from 'clsx';
|
||||||
|
import { clsx } from 'clsx';
|
||||||
|
import { twMerge } from 'tailwind-merge';
|
||||||
|
|
||||||
|
export function cn(...inputs: ClassValue[]) {
|
||||||
|
return twMerge(clsx(inputs));
|
||||||
|
}
|
@ -1,5 +1,8 @@
|
|||||||
import 'nprogress/nprogress.css'; // <link rel="stylesheet" href="https://testingcf.jsdelivr.net/npm/nprogress/nprogress.css" />
|
import 'nprogress/nprogress.css'; // <link rel="stylesheet" href="https://testingcf.jsdelivr.net/npm/nprogress/nprogress.css" />
|
||||||
import '@unocss/reset/tailwind-compat.css'; // https://unocss.dev/guide/style-reset#tailwind-compat // <link rel="stylesheet" href="https://testingcf.jsdelivr.net/npm/@unocss/reset/tailwind.min.css" />
|
// https://unocss.dev/guide/style-reset#tailwind-compat
|
||||||
|
// <link rel="stylesheet" href="https://testingcf.jsdelivr.net/npm/@unocss/reset/tailwind.min.css" />
|
||||||
|
// import '@unocss/reset/tailwind.css';
|
||||||
|
import '@unocss/reset/tailwind-compat.css';
|
||||||
|
|
||||||
import './base.css';
|
import './base.css';
|
||||||
import './main.less';
|
import './main.less';
|
||||||
|
@ -1,11 +1,12 @@
|
|||||||
{
|
{
|
||||||
"files": [],
|
"files": [],
|
||||||
"references": [
|
"references": [{ "path": "./tsconfig.app.json" }, { "path": "./tsconfig.node.json" }],
|
||||||
{
|
"compilerOptions": {
|
||||||
"path": "./tsconfig.node.json"
|
// https://www.shadcn-vue.com/docs/components-json.html#aliases
|
||||||
},
|
// A fallback to tsconfig.app.json if no paths were found in tsconfig.json
|
||||||
{
|
// 有问题?
|
||||||
"path": "./tsconfig.app.json"
|
"paths": {
|
||||||
|
"@/*": ["./src/*"]
|
||||||
}
|
}
|
||||||
]
|
}
|
||||||
}
|
}
|
||||||
|
1
typed-router.d.ts
vendored
1
typed-router.d.ts
vendored
@ -36,6 +36,7 @@ declare module 'vue-router/auto-routes' {
|
|||||||
'UIComponentsInfiniteLoading': RouteRecordInfo<'UIComponentsInfiniteLoading', '/UI-components/infinite-loading', Record<never, never>, Record<never, never>>,
|
'UIComponentsInfiniteLoading': RouteRecordInfo<'UIComponentsInfiniteLoading', '/UI-components/infinite-loading', Record<never, never>, Record<never, never>>,
|
||||||
'UIComponentsInfiniteLoadingDetail': RouteRecordInfo<'UIComponentsInfiniteLoadingDetail', '/UI-components/infinite-loading/detail', Record<never, never>, Record<never, never>>,
|
'UIComponentsInfiniteLoadingDetail': RouteRecordInfo<'UIComponentsInfiniteLoadingDetail', '/UI-components/infinite-loading/detail', Record<never, never>, Record<never, never>>,
|
||||||
'UIComponentsPrimeVue': RouteRecordInfo<'UIComponentsPrimeVue', '/UI-components/PrimeVue', Record<never, never>, Record<never, never>>,
|
'UIComponentsPrimeVue': RouteRecordInfo<'UIComponentsPrimeVue', '/UI-components/PrimeVue', Record<never, never>, Record<never, never>>,
|
||||||
|
'UIComponentsShadcnVue': RouteRecordInfo<'UIComponentsShadcnVue', '/UI-components/ShadcnVue', Record<never, never>, Record<never, never>>,
|
||||||
'VueMacrosDefineRender': RouteRecordInfo<'VueMacrosDefineRender', '/VueMacros/DefineRender', Record<never, never>, Record<never, never>>,
|
'VueMacrosDefineRender': RouteRecordInfo<'VueMacrosDefineRender', '/VueMacros/DefineRender', Record<never, never>, Record<never, never>>,
|
||||||
'VueMacrosReactivityTransform': RouteRecordInfo<'VueMacrosReactivityTransform', '/VueMacros/ReactivityTransform', Record<never, never>, Record<never, never>>,
|
'VueMacrosReactivityTransform': RouteRecordInfo<'VueMacrosReactivityTransform', '/VueMacros/ReactivityTransform', Record<never, never>, Record<never, never>>,
|
||||||
'VueMacrosReusableTemplate': RouteRecordInfo<'VueMacrosReusableTemplate', '/VueMacros/ReusableTemplate', Record<never, never>, Record<never, never>>,
|
'VueMacrosReusableTemplate': RouteRecordInfo<'VueMacrosReusableTemplate', '/VueMacros/ReusableTemplate', Record<never, never>, Record<never, never>>,
|
||||||
|
@ -1,8 +1,23 @@
|
|||||||
// https://github.dev/unocss/unocss/tree/main/examples/vite-vue3
|
// https://github.dev/unocss/unocss/tree/main/examples/vite-vue3
|
||||||
|
|
||||||
import { defineConfig, presetAttributify, presetWind3, transformerDirectives, transformerVariantGroup } from 'unocss';
|
import { defineConfig, presetAttributify, presetWind3, transformerDirectives, transformerVariantGroup } from 'unocss';
|
||||||
|
import presetAnimations from 'unocss-preset-animations';
|
||||||
// import presetChinese, { chineseTypography } from 'unocss-preset-chinese';
|
// import presetChinese, { chineseTypography } from 'unocss-preset-chinese';
|
||||||
|
import { presetShadcn } from 'unocss-preset-shadcn';
|
||||||
|
|
||||||
export default defineConfig({
|
export default defineConfig({
|
||||||
|
// By default, `.ts` and `.js` files are NOT extracted.
|
||||||
|
// If you want to extract them, use the following configuration.
|
||||||
|
// It's necessary to add the following configuration if you use shadcn-vue or shadcn-svelte.
|
||||||
|
content: {
|
||||||
|
pipeline: {
|
||||||
|
include: [
|
||||||
|
// the default
|
||||||
|
/\.(vue|svelte|[jt]sx|mdx?|astro|elm|php|phtml|html)($|\?)/,
|
||||||
|
'src/shadcn/components/**/*.{js,ts}',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
presets: [
|
presets: [
|
||||||
presetWind3({
|
presetWind3({
|
||||||
/* prefix: "u-", */
|
/* prefix: "u-", */
|
||||||
@ -10,6 +25,21 @@ export default defineConfig({
|
|||||||
dark: '.app-dark',
|
dark: '.app-dark',
|
||||||
},
|
},
|
||||||
}),
|
}),
|
||||||
|
presetAnimations(),
|
||||||
|
// https://github.com/unocss-community/unocss-preset-shadcn?tab=readme-ov-file#usage
|
||||||
|
// npx shadcn-vue@latest add button
|
||||||
|
presetShadcn(
|
||||||
|
{
|
||||||
|
color: 'zinc',
|
||||||
|
// With default setting for SolidUI, you need to set the darkSelector option.
|
||||||
|
darkSelector: '.app-dark',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
// If you are using reka ui.
|
||||||
|
componentLibrary: 'reka',
|
||||||
|
},
|
||||||
|
),
|
||||||
|
|
||||||
// chineseTypography(),
|
// chineseTypography(),
|
||||||
// presetChinese({
|
// presetChinese({
|
||||||
// chineseType: 'simplified', // 指定文本为简体中文
|
// chineseType: 'simplified', // 指定文本为简体中文
|
||||||
|
Reference in New Issue
Block a user