fix: optimize the dependency detection script prompt and fix the loop dependency problem

pull/48/MERGE
vince 2024-07-10 21:40:29 +08:00
parent a765d3bbc0
commit 25a1e93ab2
12 changed files with 56 additions and 51 deletions

View File

@ -27,7 +27,7 @@
"build": "cross-env NODE_OPTIONS=--max-old-space-size=8192 turbo build", "build": "cross-env NODE_OPTIONS=--max-old-space-size=8192 turbo build",
"build:docker": "./build-local-docker-image.sh", "build:docker": "./build-local-docker-image.sh",
"changeset": "pnpm exec changeset", "changeset": "pnpm exec changeset",
"check": "pnpm run check:dep && pnpm run check:circular && pnpm run check:type && pnpm run check:spell", "check": "pnpm run check:dep && pnpm run check:circular && pnpm run check:type && pnpm run check:cspell",
"check:circular": "vsh check-circular", "check:circular": "vsh check-circular",
"check:dep": "vsh check-dep", "check:dep": "vsh check-dep",
"check:cspell": "cspell lint \"**/*.ts\" \"**/README.md\" \".changeset/*.md\" --no-progress", "check:cspell": "cspell lint \"**/*.ts\" \"**/README.md\" \".changeset/*.md\" --no-progress",

View File

@ -36,7 +36,6 @@
} }
}, },
"dependencies": { "dependencies": {
"@vben-core/toolkit": "workspace:*",
"@vben-core/typings": "workspace:*", "@vben-core/typings": "workspace:*",
"vue-router": "^4.4.0" "vue-router": "^4.4.0"
} }

View File

@ -36,6 +36,7 @@ async function setupI18n(app: App, options: LocaleSetupOptions = {}) {
} }
export { $t, i18n, loadLocaleMessages, loadLocalesMap, setupI18n }; export { $t, i18n, loadLocaleMessages, loadLocalesMap, setupI18n };
export type { CompileError } from '@intlify/core-base';
export { useI18n } from 'vue-i18n'; export { useI18n } from 'vue-i18n';
export type { Locale } from 'vue-i18n';
export type { ImportLocaleFn }; export type { ImportLocaleFn };
export type { Locale } from 'vue-i18n';

View File

@ -9,7 +9,7 @@ import {
useForwardPropsEmits, useForwardPropsEmits,
} from 'radix-vue'; } from 'radix-vue';
import { type ToastProps, toastVariants } from '.'; import { type ToastProps, toastVariants } from './toast';
const props = defineProps<ToastProps>(); const props = defineProps<ToastProps>();

View File

@ -1,14 +1,12 @@
<script setup lang="ts"> <script setup lang="ts">
import { isVNode } from 'vue'; import { isVNode } from 'vue';
import { import Toast from './Toast.vue';
Toast, import ToastClose from './ToastClose.vue';
ToastClose, import ToastDescription from './ToastDescription.vue';
ToastDescription, import ToastProvider from './ToastProvider.vue';
ToastProvider, import ToastTitle from './ToastTitle.vue';
ToastTitle, import ToastViewport from './ToastViewport.vue';
ToastViewport,
} from '.';
import { useToast } from './use-toast'; import { useToast } from './use-toast';
const { toasts } = useToast(); const { toasts } = useToast();

View File

@ -1,9 +1,3 @@
import type { ToastRootProps } from 'radix-vue';
import type { HTMLAttributes } from 'vue';
import { type VariantProps, cva } from 'class-variance-authority';
export { default as Toast } from './Toast.vue'; export { default as Toast } from './Toast.vue';
export { default as ToastAction } from './ToastAction.vue'; export { default as ToastAction } from './ToastAction.vue';
export { default as ToastClose } from './ToastClose.vue'; export { default as ToastClose } from './ToastClose.vue';
@ -12,28 +6,6 @@ export { default as ToastProvider } from './ToastProvider.vue';
export { default as ToastTitle } from './ToastTitle.vue'; export { default as ToastTitle } from './ToastTitle.vue';
export { default as ToastViewport } from './ToastViewport.vue'; export { default as ToastViewport } from './ToastViewport.vue';
export { default as Toaster } from './Toaster.vue'; export { default as Toaster } from './Toaster.vue';
export * from './toast';
export { toast, useToast } from './use-toast'; export { toast, useToast } from './use-toast';
export const toastVariants = cva(
'group pointer-events-auto relative flex w-full items-center justify-between space-x-2 overflow-hidden rounded-md border p-4 pr-6 shadow-lg transition-all data-[swipe=cancel]:translate-x-0 data-[swipe=end]:translate-x-[var(--radix-toast-swipe-end-x)] data-[swipe=move]:translate-x-[var(--radix-toast-swipe-move-x)] data-[swipe=move]:transition-none data-[state=open]:animate-in data-[state=closed]:animate-out data-[swipe=end]:animate-out data-[state=closed]:fade-out-80 data-[state=closed]:slide-out-to-right-full data-[state=open]:slide-in-from-top-full data-[state=open]:sm:slide-in-from-bottom-full',
{
defaultVariants: {
variant: 'default',
},
variants: {
variant: {
default: 'border bg-background border-border text-foreground',
destructive:
'destructive group border-destructive bg-destructive text-destructive-foreground',
},
},
},
);
type ToastVariants = VariantProps<typeof toastVariants>;
export interface ToastProps extends ToastRootProps {
class?: HTMLAttributes['class'];
onOpenChange?: ((value: boolean) => void) | undefined;
variant?: ToastVariants['variant'];
}

View File

@ -0,0 +1,29 @@
import type { ToastRootProps } from 'radix-vue';
import type { HTMLAttributes } from 'vue';
import { type VariantProps, cva } from 'class-variance-authority';
export const toastVariants = cva(
'group pointer-events-auto relative flex w-full items-center justify-between space-x-2 overflow-hidden rounded-md border p-4 pr-6 shadow-lg transition-all data-[swipe=cancel]:translate-x-0 data-[swipe=end]:translate-x-[var(--radix-toast-swipe-end-x)] data-[swipe=move]:translate-x-[var(--radix-toast-swipe-move-x)] data-[swipe=move]:transition-none data-[state=open]:animate-in data-[state=closed]:animate-out data-[swipe=end]:animate-out data-[state=closed]:fade-out-80 data-[state=closed]:slide-out-to-right-full data-[state=open]:slide-in-from-top-full data-[state=open]:sm:slide-in-from-bottom-full',
{
defaultVariants: {
variant: 'default',
},
variants: {
variant: {
default: 'border bg-background border-border text-foreground',
destructive:
'destructive group border-destructive bg-destructive text-destructive-foreground',
},
},
},
);
type ToastVariants = VariantProps<typeof toastVariants>;
export interface ToastProps extends ToastRootProps {
class?: HTMLAttributes['class'];
onOpenChange?: ((value: boolean) => void) | undefined;
variant?: ToastVariants['variant'];
}

View File

@ -1,4 +1,4 @@
import type { ToastProps } from '.'; import type { ToastProps } from './toast';
import { computed, ref } from 'vue'; import { computed, ref } from 'vue';
import type { Component, VNode } from 'vue'; import type { Component, VNode } from 'vue';

View File

@ -4,4 +4,5 @@ export default defineBuildConfig({
clean: true, clean: true,
declaration: true, declaration: true,
entries: ['src/index'], entries: ['src/index'],
externals: ['vue'],
}); });

View File

@ -35,7 +35,6 @@
} }
}, },
"dependencies": { "dependencies": {
"@vben-core/iconify": "workspace:*", "@vben-core/iconify": "workspace:*"
"vue": "^3.4.31"
} }
} }

View File

@ -559,9 +559,6 @@ importers:
packages/@core/forward/helpers: packages/@core/forward/helpers:
dependencies: dependencies:
'@vben-core/toolkit':
specifier: workspace:*
version: link:../../shared/toolkit
'@vben-core/typings': '@vben-core/typings':
specifier: workspace:* specifier: workspace:*
version: link:../../shared/typings version: link:../../shared/typings
@ -939,9 +936,6 @@ importers:
'@vben-core/iconify': '@vben-core/iconify':
specifier: workspace:* specifier: workspace:*
version: link:../@core/shared/iconify version: link:../@core/shared/iconify
vue:
specifier: ^3.4.31
version: 3.4.31(typescript@5.5.3)
packages/styles: packages/styles:
dependencies: dependencies:

View File

@ -10,6 +10,7 @@ async function runDepcheck() {
packages.map(async (pkg) => { packages.map(async (pkg) => {
if ( if (
[ [
'@vben/backend-mock',
'@vben/commitlint-config', '@vben/commitlint-config',
'@vben/eslint-config', '@vben/eslint-config',
'@vben/lint-staged-config', '@vben/lint-staged-config',
@ -40,6 +41,17 @@ async function runDepcheck() {
ignorePatterns: ['dist', 'node_modules', 'public'], ignorePatterns: ['dist', 'node_modules', 'public'],
}); });
// 删除file:前缀的依赖提示,该依赖是本地依赖
Reflect.deleteProperty(unused.missing, 'file:');
Object.keys(unused.missing).forEach((key) => {
unused.missing[key] = unused.missing[key].filter(
(item: string) => !item.startsWith('/'),
);
if (unused.missing[key].length === 0) {
Reflect.deleteProperty(unused.missing, key);
}
});
if ( if (
Object.keys(unused.missing).length === 0 && Object.keys(unused.missing).length === 0 &&
unused.dependencies.length === 0 && unused.dependencies.length === 0 &&