Merge branch 'main' of https://github.com/vbenjs/vue-vben-admin into dev
						commit
						ea31db17ad
					
				|  | @ -1,3 +1,4 @@ | ||||||
|  | import type { VxeTableGridOptions } from '@vben/plugins/vxe-table'; | ||||||
| import type { Recordable } from '@vben/types'; | import type { Recordable } from '@vben/types'; | ||||||
| 
 | 
 | ||||||
| import { h } from 'vue'; | import { h } from 'vue'; | ||||||
|  | @ -63,7 +64,7 @@ setupVbenVxeTable({ | ||||||
|         round: true, |         round: true, | ||||||
|         showOverflow: true, |         showOverflow: true, | ||||||
|         size: 'small', |         size: 'small', | ||||||
|       }, |       } as VxeTableGridOptions, | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|     // 表格配置项可以用 cellRender: { name: 'CellImage' },
 |     // 表格配置项可以用 cellRender: { name: 'CellImage' },
 | ||||||
|  |  | ||||||
|  | @ -1,3 +1,4 @@ | ||||||
|  | import type { VxeTableGridOptions } from '@vben/plugins/vxe-table'; | ||||||
| import type { Recordable } from '@vben/types'; | import type { Recordable } from '@vben/types'; | ||||||
| 
 | 
 | ||||||
| import { h } from 'vue'; | import { h } from 'vue'; | ||||||
|  | @ -63,7 +64,7 @@ setupVbenVxeTable({ | ||||||
|         round: true, |         round: true, | ||||||
|         showOverflow: true, |         showOverflow: true, | ||||||
|         size: 'small', |         size: 'small', | ||||||
|       }, |       } as VxeTableGridOptions, | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|     // 表格配置项可以用 cellRender: { name: 'CellImage' },
 |     // 表格配置项可以用 cellRender: { name: 'CellImage' },
 | ||||||
|  |  | ||||||
|  | @ -1,3 +1,4 @@ | ||||||
|  | import type { VxeTableGridOptions } from '@vben/plugins/vxe-table'; | ||||||
| import type { Recordable } from '@vben/types'; | import type { Recordable } from '@vben/types'; | ||||||
| 
 | 
 | ||||||
| import { h } from 'vue'; | import { h } from 'vue'; | ||||||
|  | @ -57,7 +58,7 @@ setupVbenVxeTable({ | ||||||
|         round: true, |         round: true, | ||||||
|         showOverflow: true, |         showOverflow: true, | ||||||
|         size: 'small', |         size: 'small', | ||||||
|       }, |       } as VxeTableGridOptions, | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|     // 表格配置项可以用 cellRender: { name: 'CellImage' },
 |     // 表格配置项可以用 cellRender: { name: 'CellImage' },
 | ||||||
|  |  | ||||||
|  | @ -122,6 +122,7 @@ async function onBtnClick(value: ValueType) { | ||||||
|       v-bind="btnDefaultProps" |       v-bind="btnDefaultProps" | ||||||
|       :variant="innerValue.includes(btn.value) ? 'default' : 'outline'" |       :variant="innerValue.includes(btn.value) ? 'default' : 'outline'" | ||||||
|       @click="onBtnClick(btn.value)" |       @click="onBtnClick(btn.value)" | ||||||
|  |       type="button" | ||||||
|     > |     > | ||||||
|       <div class="icon-wrapper" v-if="props.showIcon"> |       <div class="icon-wrapper" v-if="props.showIcon"> | ||||||
|         <slot |         <slot | ||||||
|  |  | ||||||
|  | @ -8,19 +8,40 @@ import { isFunction } from '@vben/utils'; | ||||||
| 
 | 
 | ||||||
| import { useElementHover } from '@vueuse/core'; | import { useElementHover } from '@vueuse/core'; | ||||||
| 
 | 
 | ||||||
|  | interface HoverDelayOptions { | ||||||
|  |   /** 鼠标进入延迟时间 */ | ||||||
|  |   enterDelay?: (() => number) | number; | ||||||
|  |   /** 鼠标离开延迟时间 */ | ||||||
|  |   leaveDelay?: (() => number) | number; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | const DEFAULT_LEAVE_DELAY = 500; // 鼠标离开延迟时间,默认为 500ms
 | ||||||
|  | const DEFAULT_ENTER_DELAY = 0; // 鼠标进入延迟时间,默认为 0(立即响应)
 | ||||||
|  | 
 | ||||||
| /** | /** | ||||||
|  * 监测鼠标是否在元素内部,如果在元素内部则返回 true,否则返回 false |  * 监测鼠标是否在元素内部,如果在元素内部则返回 true,否则返回 false | ||||||
|  * @param refElement 所有需要检测的元素。如果提供了一个数组,那么鼠标在任何一个元素内部都会返回 true |  * @param refElement 所有需要检测的元素。如果提供了一个数组,那么鼠标在任何一个元素内部都会返回 true | ||||||
|  * @param delay 延迟更新状态的时间 |  * @param delay 延迟更新状态的时间,可以是数字或包含进入/离开延迟的配置对象 | ||||||
|  * @returns 返回一个数组,第一个元素是一个 ref,表示鼠标是否在元素内部,第二个元素是一个控制器,可以通过 enable 和 disable 方法来控制监听器的启用和禁用 |  * @returns 返回一个数组,第一个元素是一个 ref,表示鼠标是否在元素内部,第二个元素是一个控制器,可以通过 enable 和 disable 方法来控制监听器的启用和禁用 | ||||||
|  */ |  */ | ||||||
| export function useHoverToggle( | export function useHoverToggle( | ||||||
|   refElement: Arrayable<MaybeElementRef>, |   refElement: Arrayable<MaybeElementRef>, | ||||||
|   delay: (() => number) | number = 500, |   delay: (() => number) | HoverDelayOptions | number = DEFAULT_LEAVE_DELAY, | ||||||
| ) { | ) { | ||||||
|  |   // 兼容旧版本API
 | ||||||
|  |   const normalizedOptions: HoverDelayOptions = | ||||||
|  |     typeof delay === 'number' || isFunction(delay) | ||||||
|  |       ? { enterDelay: DEFAULT_ENTER_DELAY, leaveDelay: delay } | ||||||
|  |       : { | ||||||
|  |           enterDelay: DEFAULT_ENTER_DELAY, | ||||||
|  |           leaveDelay: DEFAULT_LEAVE_DELAY, | ||||||
|  |           ...delay, | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|   const isHovers: Array<Ref<boolean>> = []; |   const isHovers: Array<Ref<boolean>> = []; | ||||||
|   const value = ref(false); |   const value = ref(false); | ||||||
|   const timer = ref<ReturnType<typeof setTimeout> | undefined>(); |   const enterTimer = ref<ReturnType<typeof setTimeout> | undefined>(); | ||||||
|  |   const leaveTimer = ref<ReturnType<typeof setTimeout> | undefined>(); | ||||||
|   const refs = Array.isArray(refElement) ? refElement : [refElement]; |   const refs = Array.isArray(refElement) ? refElement : [refElement]; | ||||||
|   refs.forEach((refEle) => { |   refs.forEach((refEle) => { | ||||||
|     const eleRef = computed(() => { |     const eleRef = computed(() => { | ||||||
|  | @ -32,15 +53,47 @@ export function useHoverToggle( | ||||||
|   }); |   }); | ||||||
|   const isOutsideAll = computed(() => isHovers.every((v) => !v.value)); |   const isOutsideAll = computed(() => isHovers.every((v) => !v.value)); | ||||||
| 
 | 
 | ||||||
|  |   function clearTimers() { | ||||||
|  |     if (enterTimer.value) { | ||||||
|  |       clearTimeout(enterTimer.value); | ||||||
|  |       enterTimer.value = undefined; | ||||||
|  |     } | ||||||
|  |     if (leaveTimer.value) { | ||||||
|  |       clearTimeout(leaveTimer.value); | ||||||
|  |       leaveTimer.value = undefined; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|   function setValueDelay(val: boolean) { |   function setValueDelay(val: boolean) { | ||||||
|     timer.value && clearTimeout(timer.value); |     clearTimers(); | ||||||
|     timer.value = setTimeout( | 
 | ||||||
|       () => { |     if (val) { | ||||||
|         value.value = val; |       // 鼠标进入
 | ||||||
|         timer.value = undefined; |       const enterDelay = normalizedOptions.enterDelay ?? DEFAULT_ENTER_DELAY; | ||||||
|       }, |       const delayTime = isFunction(enterDelay) ? enterDelay() : enterDelay; | ||||||
|       isFunction(delay) ? delay() : delay, | 
 | ||||||
|     ); |       if (delayTime <= 0) { | ||||||
|  |         value.value = true; | ||||||
|  |       } else { | ||||||
|  |         enterTimer.value = setTimeout(() => { | ||||||
|  |           value.value = true; | ||||||
|  |           enterTimer.value = undefined; | ||||||
|  |         }, delayTime); | ||||||
|  |       } | ||||||
|  |     } else { | ||||||
|  |       // 鼠标离开
 | ||||||
|  |       const leaveDelay = normalizedOptions.leaveDelay ?? DEFAULT_LEAVE_DELAY; | ||||||
|  |       const delayTime = isFunction(leaveDelay) ? leaveDelay() : leaveDelay; | ||||||
|  | 
 | ||||||
|  |       if (delayTime <= 0) { | ||||||
|  |         value.value = false; | ||||||
|  |       } else { | ||||||
|  |         leaveTimer.value = setTimeout(() => { | ||||||
|  |           value.value = false; | ||||||
|  |           leaveTimer.value = undefined; | ||||||
|  |         }, delayTime); | ||||||
|  |       } | ||||||
|  |     } | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   const watcher = watch( |   const watcher = watch( | ||||||
|  | @ -61,7 +114,7 @@ export function useHoverToggle( | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   onUnmounted(() => { |   onUnmounted(() => { | ||||||
|     timer.value && clearTimeout(timer.value); |     clearTimers(); | ||||||
|   }); |   }); | ||||||
| 
 | 
 | ||||||
|   return [value, controller] as [typeof value, typeof controller]; |   return [value, controller] as [typeof value, typeof controller]; | ||||||
|  |  | ||||||
|  | @ -26,14 +26,14 @@ function getDefaultState(): VxeGridProps { | ||||||
|   }; |   }; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| export class VxeGridApi { | export class VxeGridApi<T extends Record<string, any> = any> { | ||||||
|   public formApi = {} as ExtendedFormApi; |   public formApi = {} as ExtendedFormApi; | ||||||
| 
 | 
 | ||||||
|   // private prevState: null | VxeGridProps = null;
 |   // private prevState: null | VxeGridProps = null;
 | ||||||
|   public grid = {} as VxeGridInstance; |   public grid = {} as VxeGridInstance<T>; | ||||||
|   public state: null | VxeGridProps = null; |   public state: null | VxeGridProps<T> = null; | ||||||
| 
 | 
 | ||||||
|   public store: Store<VxeGridProps>; |   public store: Store<VxeGridProps<T>>; | ||||||
| 
 | 
 | ||||||
|   private isMounted = false; |   private isMounted = false; | ||||||
| 
 | 
 | ||||||
|  | @ -99,8 +99,8 @@ export class VxeGridApi { | ||||||
| 
 | 
 | ||||||
|   setState( |   setState( | ||||||
|     stateOrFn: |     stateOrFn: | ||||||
|       | ((prev: VxeGridProps) => Partial<VxeGridProps>) |       | ((prev: VxeGridProps<T>) => Partial<VxeGridProps<T>>) | ||||||
|       | Partial<VxeGridProps>, |       | Partial<VxeGridProps<T>>, | ||||||
|   ) { |   ) { | ||||||
|     if (isFunction(stateOrFn)) { |     if (isFunction(stateOrFn)) { | ||||||
|       this.store.setState((prev) => { |       this.store.setState((prev) => { | ||||||
|  |  | ||||||
|  | @ -9,7 +9,7 @@ import type { Ref } from 'vue'; | ||||||
| 
 | 
 | ||||||
| import type { ClassType, DeepPartial } from '@vben/types'; | import type { ClassType, DeepPartial } from '@vben/types'; | ||||||
| 
 | 
 | ||||||
| import type { VbenFormProps } from '@vben-core/form-ui'; | import type { BaseFormComponentType, VbenFormProps } from '@vben-core/form-ui'; | ||||||
| 
 | 
 | ||||||
| import type { VxeGridApi } from './api'; | import type { VxeGridApi } from './api'; | ||||||
| 
 | 
 | ||||||
|  | @ -35,7 +35,11 @@ export interface SeparatorOptions { | ||||||
|   show?: boolean; |   show?: boolean; | ||||||
|   backgroundColor?: string; |   backgroundColor?: string; | ||||||
| } | } | ||||||
| export interface VxeGridProps { | 
 | ||||||
|  | export interface VxeGridProps< | ||||||
|  |   T extends Record<string, any> = any, | ||||||
|  |   D extends BaseFormComponentType = BaseFormComponentType, | ||||||
|  | > { | ||||||
|   /** |   /** | ||||||
|    * 标题 |    * 标题 | ||||||
|    */ |    */ | ||||||
|  | @ -55,15 +59,15 @@ export interface VxeGridProps { | ||||||
|   /** |   /** | ||||||
|    * vxe-grid 配置 |    * vxe-grid 配置 | ||||||
|    */ |    */ | ||||||
|   gridOptions?: DeepPartial<VxeTableGridOptions>; |   gridOptions?: DeepPartial<VxeTableGridOptions<T>>; | ||||||
|   /** |   /** | ||||||
|    * vxe-grid 事件 |    * vxe-grid 事件 | ||||||
|    */ |    */ | ||||||
|   gridEvents?: DeepPartial<VxeGridListeners>; |   gridEvents?: DeepPartial<VxeGridListeners<T>>; | ||||||
|   /** |   /** | ||||||
|    * 表单配置 |    * 表单配置 | ||||||
|    */ |    */ | ||||||
|   formOptions?: VbenFormProps; |   formOptions?: VbenFormProps<D>; | ||||||
|   /** |   /** | ||||||
|    * 显示搜索表单 |    * 显示搜索表单 | ||||||
|    */ |    */ | ||||||
|  | @ -74,9 +78,12 @@ export interface VxeGridProps { | ||||||
|   separator?: boolean | SeparatorOptions; |   separator?: boolean | SeparatorOptions; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| export type ExtendedVxeGridApi = VxeGridApi & { | export type ExtendedVxeGridApi< | ||||||
|   useStore: <T = NoInfer<VxeGridProps>>( |   D extends Record<string, any> = any, | ||||||
|     selector?: (state: NoInfer<VxeGridProps>) => T, |   F extends BaseFormComponentType = BaseFormComponentType, | ||||||
|  | > = VxeGridApi<D> & { | ||||||
|  |   useStore: <T = NoInfer<VxeGridProps<D, F>>>( | ||||||
|  |     selector?: (state: NoInfer<VxeGridProps<any, any>>) => T, | ||||||
|   ) => Readonly<Ref<T>>; |   ) => Readonly<Ref<T>>; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,3 +1,5 @@ | ||||||
|  | import type { BaseFormComponentType } from '@vben-core/form-ui'; | ||||||
|  | 
 | ||||||
| import type { ExtendedVxeGridApi, VxeGridProps } from './types'; | import type { ExtendedVxeGridApi, VxeGridProps } from './types'; | ||||||
| 
 | 
 | ||||||
| import { defineComponent, h, onBeforeUnmount } from 'vue'; | import { defineComponent, h, onBeforeUnmount } from 'vue'; | ||||||
|  | @ -7,16 +9,19 @@ import { useStore } from '@vben-core/shared/store'; | ||||||
| import { VxeGridApi } from './api'; | import { VxeGridApi } from './api'; | ||||||
| import VxeGrid from './use-vxe-grid.vue'; | import VxeGrid from './use-vxe-grid.vue'; | ||||||
| 
 | 
 | ||||||
| export function useVbenVxeGrid(options: VxeGridProps) { | export function useVbenVxeGrid< | ||||||
|  |   T extends Record<string, any> = any, | ||||||
|  |   D extends BaseFormComponentType = BaseFormComponentType, | ||||||
|  | >(options: VxeGridProps<T, D>) { | ||||||
|   // const IS_REACTIVE = isReactive(options);
 |   // const IS_REACTIVE = isReactive(options);
 | ||||||
|   const api = new VxeGridApi(options); |   const api = new VxeGridApi(options); | ||||||
|   const extendedApi: ExtendedVxeGridApi = api as ExtendedVxeGridApi; |   const extendedApi: ExtendedVxeGridApi<T, D> = api as ExtendedVxeGridApi<T, D>; | ||||||
|   extendedApi.useStore = (selector) => { |   extendedApi.useStore = (selector) => { | ||||||
|     return useStore(api.store, selector); |     return useStore(api.store, selector); | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   const Grid = defineComponent( |   const Grid = defineComponent( | ||||||
|     (props: VxeGridProps, { attrs, slots }) => { |     (props: VxeGridProps<T>, { attrs, slots }) => { | ||||||
|       onBeforeUnmount(() => { |       onBeforeUnmount(() => { | ||||||
|         api.unmount(); |         api.unmount(); | ||||||
|       }); |       }); | ||||||
|  |  | ||||||
|  | @ -1,6 +1,8 @@ | ||||||
| import type { RequestClient } from '../request-client'; | import type { RequestClient } from '../request-client'; | ||||||
| import type { RequestClientConfig } from '../types'; | import type { RequestClientConfig } from '../types'; | ||||||
| 
 | 
 | ||||||
|  | import { isUndefined } from '@vben/utils'; | ||||||
|  | 
 | ||||||
| class FileUploader { | class FileUploader { | ||||||
|   private client: RequestClient; |   private client: RequestClient; | ||||||
| 
 | 
 | ||||||
|  | @ -18,10 +20,10 @@ class FileUploader { | ||||||
|     Object.entries(data).forEach(([key, value]) => { |     Object.entries(data).forEach(([key, value]) => { | ||||||
|       if (Array.isArray(value)) { |       if (Array.isArray(value)) { | ||||||
|         value.forEach((item, index) => { |         value.forEach((item, index) => { | ||||||
|           formData.append(`${key}[${index}]`, item); |           !isUndefined(item) && formData.append(`${key}[${index}]`, item); | ||||||
|         }); |         }); | ||||||
|       } else { |       } else { | ||||||
|         formData.append(key, value); |         !isUndefined(value) && formData.append(key, value); | ||||||
|       } |       } | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,10 +1,16 @@ | ||||||
|  | import type { VxeTableGridOptions } from '@vben/plugins/vxe-table'; | ||||||
| import type { Recordable } from '@vben/types'; | import type { Recordable } from '@vben/types'; | ||||||
| 
 | 
 | ||||||
|  | import type { ComponentType } from './component'; | ||||||
|  | 
 | ||||||
| import { h } from 'vue'; | import { h } from 'vue'; | ||||||
| 
 | 
 | ||||||
| import { IconifyIcon } from '@vben/icons'; | import { IconifyIcon } from '@vben/icons'; | ||||||
| import { $te } from '@vben/locales'; | import { $te } from '@vben/locales'; | ||||||
| import { setupVbenVxeTable, useVbenVxeGrid } from '@vben/plugins/vxe-table'; | import { | ||||||
|  |   setupVbenVxeTable, | ||||||
|  |   useVbenVxeGrid as useGrid, | ||||||
|  | } from '@vben/plugins/vxe-table'; | ||||||
| import { get, isFunction, isString } from '@vben/utils'; | import { get, isFunction, isString } from '@vben/utils'; | ||||||
| 
 | 
 | ||||||
| import { objectOmit } from '@vueuse/core'; | import { objectOmit } from '@vueuse/core'; | ||||||
|  | @ -42,7 +48,7 @@ setupVbenVxeTable({ | ||||||
|         round: true, |         round: true, | ||||||
|         showOverflow: true, |         showOverflow: true, | ||||||
|         size: 'small', |         size: 'small', | ||||||
|       }, |       } as VxeTableGridOptions, | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|  | @ -277,7 +283,10 @@ setupVbenVxeTable({ | ||||||
|   useVbenForm, |   useVbenForm, | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| export { useVbenVxeGrid }; | export const useVbenVxeGrid = <T extends Record<string, any>>( | ||||||
|  |   ...rest: Parameters<typeof useGrid<T, ComponentType>> | ||||||
|  | ) => useGrid<T, ComponentType>(...rest); | ||||||
|  | 
 | ||||||
| export type OnActionClickParams<T = Recordable<any>> = { | export type OnActionClickParams<T = Recordable<any>> = { | ||||||
|   code: string; |   code: string; | ||||||
|   row: T; |   row: T; | ||||||
|  |  | ||||||
|  | @ -43,7 +43,22 @@ const gridEvents: VxeGridListeners<RowType> = { | ||||||
|   }, |   }, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| const [Grid, gridApi] = useVbenVxeGrid({ gridEvents, gridOptions }); | const [Grid, gridApi] = useVbenVxeGrid<RowType>({ | ||||||
|  |   // 放开注释查看表单组件的类型 | ||||||
|  |   // formOptions: { | ||||||
|  |   //   schema: [ | ||||||
|  |   //     { | ||||||
|  |   //       component: 'Switch', | ||||||
|  |   //       fieldName: 'name', | ||||||
|  |   //     }, | ||||||
|  |   //   ], | ||||||
|  |   // }, | ||||||
|  |   gridEvents, | ||||||
|  |   gridOptions, | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // 放开注释查看当前表格实例的类型 | ||||||
|  | // gridApi.grid | ||||||
| 
 | 
 | ||||||
| const showBorder = gridApi.useStore((state) => state.gridOptions?.border); | const showBorder = gridApi.useStore((state) => state.gridOptions?.border); | ||||||
| const showStripe = gridApi.useStore((state) => state.gridOptions?.stripe); | const showStripe = gridApi.useStore((state) => state.gridOptions?.stripe); | ||||||
|  |  | ||||||
|  | @ -241,10 +241,10 @@ const schema: VbenFormSchema[] = [ | ||||||
|     component: 'Input', |     component: 'Input', | ||||||
|     dependencies: { |     dependencies: { | ||||||
|       rules: (values) => { |       rules: (values) => { | ||||||
|         return values.type === 'action' ? 'required' : null; |         return values.type === 'button' ? 'required' : null; | ||||||
|       }, |       }, | ||||||
|       show: (values) => { |       show: (values) => { | ||||||
|         return ['action', 'catalog', 'embedded', 'menu'].includes(values.type); |         return ['button', 'catalog', 'embedded', 'menu'].includes(values.type); | ||||||
|       }, |       }, | ||||||
|       triggerFields: ['type'], |       triggerFields: ['type'], | ||||||
|     }, |     }, | ||||||
|  | @ -277,7 +277,7 @@ const schema: VbenFormSchema[] = [ | ||||||
|     }, |     }, | ||||||
|     dependencies: { |     dependencies: { | ||||||
|       show: (values) => { |       show: (values) => { | ||||||
|         return values.type !== 'action'; |         return values.type !== 'button'; | ||||||
|       }, |       }, | ||||||
|       triggerFields: ['type'], |       triggerFields: ['type'], | ||||||
|     }, |     }, | ||||||
|  | @ -295,7 +295,7 @@ const schema: VbenFormSchema[] = [ | ||||||
|     }, |     }, | ||||||
|     dependencies: { |     dependencies: { | ||||||
|       show: (values) => { |       show: (values) => { | ||||||
|         return values.type !== 'action'; |         return values.type !== 'button'; | ||||||
|       }, |       }, | ||||||
|       triggerFields: ['type'], |       triggerFields: ['type'], | ||||||
|     }, |     }, | ||||||
|  | @ -314,7 +314,7 @@ const schema: VbenFormSchema[] = [ | ||||||
|     }, |     }, | ||||||
|     dependencies: { |     dependencies: { | ||||||
|       show: (values) => { |       show: (values) => { | ||||||
|         return values.type !== 'action'; |         return values.type !== 'button'; | ||||||
|       }, |       }, | ||||||
|       triggerFields: ['type'], |       triggerFields: ['type'], | ||||||
|     }, |     }, | ||||||
|  | @ -325,7 +325,7 @@ const schema: VbenFormSchema[] = [ | ||||||
|     component: 'Divider', |     component: 'Divider', | ||||||
|     dependencies: { |     dependencies: { | ||||||
|       show: (values) => { |       show: (values) => { | ||||||
|         return !['action', 'link'].includes(values.type); |         return !['button', 'link'].includes(values.type); | ||||||
|       }, |       }, | ||||||
|       triggerFields: ['type'], |       triggerFields: ['type'], | ||||||
|     }, |     }, | ||||||
|  | @ -372,7 +372,7 @@ const schema: VbenFormSchema[] = [ | ||||||
|     component: 'Checkbox', |     component: 'Checkbox', | ||||||
|     dependencies: { |     dependencies: { | ||||||
|       show: (values) => { |       show: (values) => { | ||||||
|         return !['action'].includes(values.type); |         return !['button'].includes(values.type); | ||||||
|       }, |       }, | ||||||
|       triggerFields: ['type'], |       triggerFields: ['type'], | ||||||
|     }, |     }, | ||||||
|  | @ -402,7 +402,7 @@ const schema: VbenFormSchema[] = [ | ||||||
|     component: 'Checkbox', |     component: 'Checkbox', | ||||||
|     dependencies: { |     dependencies: { | ||||||
|       show: (values) => { |       show: (values) => { | ||||||
|         return !['action', 'link'].includes(values.type); |         return !['button', 'link'].includes(values.type); | ||||||
|       }, |       }, | ||||||
|       triggerFields: ['type'], |       triggerFields: ['type'], | ||||||
|     }, |     }, | ||||||
|  | @ -417,7 +417,7 @@ const schema: VbenFormSchema[] = [ | ||||||
|     component: 'Checkbox', |     component: 'Checkbox', | ||||||
|     dependencies: { |     dependencies: { | ||||||
|       show: (values) => { |       show: (values) => { | ||||||
|         return !['action', 'link'].includes(values.type); |         return !['button', 'link'].includes(values.type); | ||||||
|       }, |       }, | ||||||
|       triggerFields: ['type'], |       triggerFields: ['type'], | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 xingyu4j
						xingyu4j