Pre Merge pull request !209 from 芋道源码/dev-dict
						commit
						77f3148f9f
					
				|  | @ -1,12 +1,11 @@ | |||
| <script setup lang="ts"> | ||||
| import { computed } from 'vue'; | ||||
| 
 | ||||
| import { getDictObj } from '@vben/hooks'; | ||||
| import { isValidColor, TinyColor } from '@vben/utils'; | ||||
| 
 | ||||
| import { Tag } from 'ant-design-vue'; | ||||
| 
 | ||||
| import { getDictObj } from '#/utils'; | ||||
| 
 | ||||
| interface DictTagProps { | ||||
|   /** | ||||
|    * 字典类型 | ||||
|  |  | |||
|  | @ -4,6 +4,8 @@ import type { DictSelectProps } from '../typing'; | |||
| 
 | ||||
| import { computed, useAttrs } from 'vue'; | ||||
| 
 | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { | ||||
|   Checkbox, | ||||
|   CheckboxGroup, | ||||
|  | @ -13,8 +15,6 @@ import { | |||
|   SelectOption, | ||||
| } from 'ant-design-vue'; | ||||
| 
 | ||||
| import { getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| defineOptions({ name: 'DictSelect' }); | ||||
| 
 | ||||
| const props = withDefaults(defineProps<DictSelectProps>(), { | ||||
|  |  | |||
|  | @ -1,12 +1,12 @@ | |||
| <script setup lang="ts"> | ||||
| import type { OperateLogProps } from './typing'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictLabel, getDictObj } from '@vben/hooks'; | ||||
| import { formatDateTime } from '@vben/utils'; | ||||
| 
 | ||||
| import { Tag, Timeline } from 'ant-design-vue'; | ||||
| 
 | ||||
| import { DICT_TYPE, getDictLabel, getDictObj } from '#/utils'; | ||||
| 
 | ||||
| defineOptions({ name: 'OperateLogV2' }); | ||||
| 
 | ||||
| withDefaults(defineProps<OperateLogProps>(), { | ||||
|  |  | |||
|  | @ -1,6 +1,6 @@ | |||
| import type { VxeTableGridOptions } from '@vben/plugins/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '#/utils'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| 
 | ||||
| /** 流程实例列表字段 */ | ||||
| export function useGridColumns(): VxeTableGridOptions['columns'] { | ||||
|  |  | |||
|  | @ -1,6 +1,6 @@ | |||
| import type { VxeTableGridOptions } from '@vben/plugins/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '#/utils'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| 
 | ||||
| /** 审批记录列表字段 */ | ||||
| export function useGridColumns(): VxeTableGridOptions['columns'] { | ||||
|  |  | |||
|  | @ -1,191 +0,0 @@ | |||
| // TODO @芋艿:后续再优化
 | ||||
| // TODO @芋艿:可以共享么?
 | ||||
| 
 | ||||
| import type { DictItem } from '@vben/stores'; | ||||
| 
 | ||||
| import { useDictStore } from '@vben/stores'; | ||||
| import { isObject } from '@vben/utils'; | ||||
| 
 | ||||
| // TODO @dhb52:top-level 调用 导致:"getActivePinia()" was called but there was no active Pinia
 | ||||
| // 先临时移入到方法中
 | ||||
| // const dictStore = useDictStore();
 | ||||
| 
 | ||||
| /** AntD 组件的颜色类型 */ | ||||
| type ColorType = 'error' | 'info' | 'success' | 'warning'; | ||||
| 
 | ||||
| /** 字典值类型 */ | ||||
| type DictValueType = 'boolean' | 'number' | 'string'; | ||||
| 
 | ||||
| /** 基础字典数据类型 */ | ||||
| export interface DictDataType { | ||||
|   dictType?: string; | ||||
|   label: string; | ||||
|   value: boolean | number | string; | ||||
|   colorType?: string; | ||||
|   cssClass?: string; | ||||
| } | ||||
| 
 | ||||
| /** 数字类型字典数据 */ | ||||
| export interface NumberDictDataType extends DictDataType { | ||||
|   value: number; | ||||
| } | ||||
| 
 | ||||
| /** 字符串类型字典数据 */ | ||||
| export interface StringDictDataType extends DictDataType { | ||||
|   value: string; | ||||
| } | ||||
| 
 | ||||
| /** 布尔类型字典数据 */ | ||||
| export interface BooleanDictDataType extends DictDataType { | ||||
|   value: boolean; | ||||
| } | ||||
| 
 | ||||
| /** 字典缓存管理器 */ | ||||
| class DictCacheManager { | ||||
|   private cache = new Map<string, DictDataType[]>(); | ||||
|   private maxCacheSize = 100; // 最大缓存数量
 | ||||
| 
 | ||||
|   /** 清空缓存 */ | ||||
|   clear(): void { | ||||
|     this.cache.clear(); | ||||
|   } | ||||
| 
 | ||||
|   /** 删除指定字典类型的缓存 */ | ||||
|   delete(dictType: string): void { | ||||
|     const keysToDelete = []; | ||||
|     for (const key of this.cache.keys()) { | ||||
|       if (key.startsWith(`${dictType}:`)) { | ||||
|         keysToDelete.push(key); | ||||
|       } | ||||
|     } | ||||
|     keysToDelete.forEach((key) => this.cache.delete(key)); | ||||
|   } | ||||
| 
 | ||||
|   /** 获取缓存数据 */ | ||||
|   get(dictType: string, valueType: DictValueType): DictDataType[] | undefined { | ||||
|     return this.cache.get(this.getCacheKey(dictType, valueType)); | ||||
|   } | ||||
| 
 | ||||
|   /** 设置缓存数据 */ | ||||
|   set(dictType: string, valueType: DictValueType, data: DictDataType[]): void { | ||||
|     const key = this.getCacheKey(dictType, valueType); | ||||
| 
 | ||||
|     // 如果缓存数量超过限制,删除最早的缓存
 | ||||
|     if (this.cache.size >= this.maxCacheSize) { | ||||
|       const firstKey = this.cache.keys().next().value; | ||||
|       if (firstKey) { | ||||
|         this.cache.delete(firstKey); | ||||
|       } | ||||
|     } | ||||
| 
 | ||||
|     this.cache.set(key, data); | ||||
|   } | ||||
| 
 | ||||
|   /** 获取缓存键 */ | ||||
|   private getCacheKey(dictType: string, valueType: DictValueType): string { | ||||
|     return `${dictType}:${valueType}`; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /** 字典缓存实例 */ | ||||
| const dictCache = new DictCacheManager(); | ||||
| 
 | ||||
| /** 值转换器映射 */ | ||||
| const valueConverters: Record< | ||||
|   DictValueType, | ||||
|   (value: any) => boolean | number | string | ||||
| > = { | ||||
|   boolean: (value: any) => `${value}` === 'true', | ||||
|   number: (value: any) => Number.parseInt(`${value}`, 10), | ||||
|   string: (value: any) => `${value}`, | ||||
| }; | ||||
| 
 | ||||
| /** | ||||
|  * 获取字典标签 | ||||
|  * @param dictType 字典类型 | ||||
|  * @param value 字典值 | ||||
|  * @returns 字典标签 | ||||
|  */ | ||||
| function getDictLabel(dictType: string, value: any): string { | ||||
|   const dictStore = useDictStore(); | ||||
|   const dictObj = dictStore.getDictData(dictType, value); | ||||
|   return isObject(dictObj) ? dictObj.label : ''; | ||||
| } | ||||
| 
 | ||||
| /** | ||||
|  * 获取字典对象 | ||||
|  * @param dictType 字典类型 | ||||
|  * @param value 字典值 | ||||
|  * @returns 字典对象 | ||||
|  */ | ||||
| function getDictObj(dictType: string, value: any): DictItem | null { | ||||
|   const dictStore = useDictStore(); | ||||
|   const dictObj = dictStore.getDictData(dictType, value); | ||||
|   return isObject(dictObj) ? dictObj : null; | ||||
| } | ||||
| 
 | ||||
| /** | ||||
|  * 获取字典数组 - 优化版本,支持缓存和泛型 | ||||
|  * @param dictType 字典类型 | ||||
|  * @param valueType 字典值类型,默认 string 类型 | ||||
|  * @returns 字典数组 | ||||
|  */ | ||||
| function getDictOptions<T extends DictValueType = 'string'>( | ||||
|   dictType: string, | ||||
|   valueType: T = 'string' as T, | ||||
| ): T extends 'number' | ||||
|   ? NumberDictDataType[] | ||||
|   : T extends 'boolean' | ||||
|     ? BooleanDictDataType[] | ||||
|     : StringDictDataType[] { | ||||
|   // 检查缓存
 | ||||
|   const cachedData = dictCache.get(dictType, valueType); | ||||
|   if (cachedData) { | ||||
|     return cachedData as any; | ||||
|   } | ||||
| 
 | ||||
|   const dictStore = useDictStore(); | ||||
|   const dictOpts = dictStore.getDictOptions(dictType); | ||||
| 
 | ||||
|   if (dictOpts.length === 0) { | ||||
|     return [] as any; | ||||
|   } | ||||
| 
 | ||||
|   const converter = valueConverters[valueType]; | ||||
|   const dictOptions: DictDataType[] = dictOpts.map((d: DictItem) => ({ | ||||
|     value: converter(d.value), | ||||
|     label: d.label, | ||||
|     colorType: d.colorType, | ||||
|     cssClass: d.cssClass, | ||||
|   })); | ||||
| 
 | ||||
|   // 缓存结果
 | ||||
|   dictCache.set(dictType, valueType, dictOptions); | ||||
| 
 | ||||
|   return dictOptions as any; | ||||
| } | ||||
| 
 | ||||
| /** | ||||
|  * 清空字典缓存 | ||||
|  */ | ||||
| export const clearDictCache = (): void => { | ||||
|   dictCache.clear(); | ||||
| }; | ||||
| 
 | ||||
| /** | ||||
|  * 删除指定字典类型的缓存 | ||||
|  * @param dictType 字典类型 | ||||
|  */ | ||||
| export const deleteDictCache = (dictType: string): void => { | ||||
|   dictCache.delete(dictType); | ||||
| }; | ||||
| 
 | ||||
| export { | ||||
|   type ColorType, | ||||
|   type DictValueType, | ||||
|   getDictLabel, | ||||
|   getDictObj, | ||||
|   getDictOptions, | ||||
| }; | ||||
| 
 | ||||
| export { DICT_TYPE } from '@vben/constants'; | ||||
|  | @ -1,5 +1,3 @@ | |||
| export * from './dict'; | ||||
| export * from './formCreate'; | ||||
| export * from './rangePickerProps'; | ||||
| export * from './routerHelper'; | ||||
| export { CommonStatusEnum } from '@vben/constants'; | ||||
|  |  | |||
|  | @ -5,13 +5,14 @@ import type { SystemUserProfileApi } from '#/api/system/user/profile'; | |||
| 
 | ||||
| import { watch } from 'vue'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { $t } from '@vben/locales'; | ||||
| 
 | ||||
| import { message } from 'ant-design-vue'; | ||||
| 
 | ||||
| import { useVbenForm, z } from '#/adapter/form'; | ||||
| import { updateUserProfile } from '#/api/system/user/profile'; | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| const props = defineProps<{ | ||||
|   profile?: SystemUserProfileApi.UserProfileResp; | ||||
|  |  | |||
|  | @ -6,7 +6,8 @@ import { computed, onMounted, ref } from 'vue'; | |||
| import { useRoute } from 'vue-router'; | ||||
| 
 | ||||
| import { confirm } from '@vben/common-ui'; | ||||
| import { SystemUserSocialTypeEnum } from '@vben/constants'; | ||||
| import { DICT_TYPE, SystemUserSocialTypeEnum } from '@vben/constants'; | ||||
| import { getDictLabel } from '@vben/hooks'; | ||||
| import { getUrlValue } from '@vben/utils'; | ||||
| 
 | ||||
| import { Button, Card, Image, message } from 'ant-design-vue'; | ||||
|  | @ -19,7 +20,6 @@ import { | |||
|   socialUnbind, | ||||
| } from '#/api/system/social/user'; | ||||
| import { $t } from '#/locales'; | ||||
| import { DICT_TYPE, getDictLabel } from '#/utils'; | ||||
| 
 | ||||
| const emit = defineEmits<{ | ||||
|   (e: 'update:activeName', v: string): void; | ||||
|  |  | |||
|  | @ -1,8 +1,10 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| 
 | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { DICT_TYPE, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 列表的搜索表单 */ | ||||
| export function useGridFormSchemaConversation(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,8 +1,11 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 列表的搜索表单 */ | ||||
| export function useGridFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -2,10 +2,10 @@ import type { VbenFormSchema } from '#/adapter/form'; | |||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { AiModelTypeEnum, CommonStatusEnum, DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { z } from '#/adapter/form'; | ||||
| import { getModelSimpleList } from '#/api/ai/model/model'; | ||||
| import { getDictOptions } from '#/utils'; | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|   return [ | ||||
|  |  | |||
|  | @ -7,6 +7,7 @@ import { useRoute, useRouter } from 'vue-router'; | |||
| 
 | ||||
| import { useAccess } from '@vben/access'; | ||||
| import { confirm, Page } from '@vben/common-ui'; | ||||
| import { CommonStatusEnum } from '@vben/constants'; | ||||
| 
 | ||||
| import { message, Switch } from 'ant-design-vue'; | ||||
| 
 | ||||
|  | @ -17,7 +18,6 @@ import { | |||
|   updateKnowledgeDocumentStatus, | ||||
| } from '#/api/ai/knowledge/document'; | ||||
| import { $t } from '#/locales'; | ||||
| import { CommonStatusEnum } from '#/utils'; | ||||
| 
 | ||||
| import { useGridColumns, useGridFormSchema } from './data'; | ||||
| 
 | ||||
|  |  | |||
|  | @ -2,10 +2,12 @@ import type { VbenFormSchema } from '#/adapter/form'; | |||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { AiModelTypeEnum, CommonStatusEnum, DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { z } from '#/adapter/form'; | ||||
| import { getModelSimpleList } from '#/api/ai/model/model'; | ||||
| import { getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|   return [ | ||||
|  |  | |||
|  | @ -1,7 +1,9 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|   return [ | ||||
|  |  | |||
|  | @ -1,8 +1,10 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { CommonStatusEnum, DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { z } from '#/adapter/form'; | ||||
| import { CommonStatusEnum, DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|   return [ | ||||
|  |  | |||
|  | @ -1,13 +1,13 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { AiModelTypeEnum } from '@vben/constants'; | ||||
| import { AiModelTypeEnum, CommonStatusEnum, DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { z } from '#/adapter/form'; | ||||
| import { getSimpleKnowledgeList } from '#/api/ai/knowledge/knowledge'; | ||||
| import { getModelSimpleList } from '#/api/ai/model/model'; | ||||
| import { getToolSimpleList } from '#/api/ai/model/tool'; | ||||
| import { CommonStatusEnum, DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|   return [ | ||||
|  |  | |||
|  | @ -1,11 +1,11 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { AiModelTypeEnum } from '@vben/constants'; | ||||
| import { AiModelTypeEnum, CommonStatusEnum, DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { z } from '#/adapter/form'; | ||||
| import { getApiKeySimpleList } from '#/api/ai/model/apiKey'; | ||||
| import { CommonStatusEnum, DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|   return [ | ||||
|  |  | |||
|  | @ -1,12 +1,10 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { | ||||
|   CommonStatusEnum, | ||||
|   DICT_TYPE, | ||||
|   getDictOptions, | ||||
|   getRangePickerDefaultProps, | ||||
| } from '#/utils'; | ||||
| import { CommonStatusEnum, DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|   return [ | ||||
|  |  | |||
|  | @ -1,8 +1,11 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 列表的搜索表单 */ | ||||
| export function useGridFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,7 +1,10 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 列表的搜索表单 */ | ||||
| export function useGridFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -3,9 +3,10 @@ import type { Rule } from 'ant-design-vue/es/form'; | |||
| 
 | ||||
| import { ref } from 'vue'; | ||||
| 
 | ||||
| import { Form, Input, Select } from 'ant-design-vue'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| import { Form, Input, Select } from 'ant-design-vue'; | ||||
| 
 | ||||
| // 创建本地数据副本 | ||||
| const modelData = defineModel<any>(); | ||||
|  |  | |||
|  | @ -4,14 +4,13 @@ import type { AiWriteApi } from '#/api/ai/write'; | |||
| 
 | ||||
| import { ref } from 'vue'; | ||||
| 
 | ||||
| import { AiWriteTypeEnum, WriteExample } from '@vben/constants'; | ||||
| import { AiWriteTypeEnum, DICT_TYPE, WriteExample } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { IconifyIcon } from '@vben/icons'; | ||||
| 
 | ||||
| import { createReusableTemplate } from '@vueuse/core'; | ||||
| import { Button, message, Textarea } from 'ant-design-vue'; | ||||
| 
 | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| import Tag from './Tag.vue'; | ||||
| 
 | ||||
| type TabType = AiWriteApi.Write['type']; | ||||
|  |  | |||
|  | @ -1,8 +1,11 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 列表的搜索表单 */ | ||||
| export function useGridFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,13 +1,11 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { CommonStatusEnum, DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { z } from '#/adapter/form'; | ||||
| import { | ||||
|   CommonStatusEnum, | ||||
|   DICT_TYPE, | ||||
|   getDictOptions, | ||||
|   getRangePickerDefaultProps, | ||||
| } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,8 +1,10 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { CommonStatusEnum, DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { z } from '#/adapter/form'; | ||||
| import { CommonStatusEnum, DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,14 +1,12 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { CommonStatusEnum, DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { z } from '#/adapter/form'; | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { | ||||
|   CommonStatusEnum, | ||||
|   DICT_TYPE, | ||||
|   getDictOptions, | ||||
|   getRangePickerDefaultProps, | ||||
| } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,7 +1,7 @@ | |||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| import type { BpmProcessDefinitionApi } from '#/api/bpm/definition'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '#/utils'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| 
 | ||||
| /** 列表的字段 */ | ||||
| export function useGridColumns(): VxeTableGridOptions<BpmProcessDefinitionApi.ProcessDefinition>['columns'] { | ||||
|  |  | |||
|  | @ -11,6 +11,8 @@ import type { SystemUserApi } from '#/api/system/user'; | |||
| import { ref, watch } from 'vue'; | ||||
| 
 | ||||
| import { useVbenModal } from '@vben/common-ui'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { IconifyIcon } from '@vben/icons'; | ||||
| 
 | ||||
| import { | ||||
|  | @ -25,7 +27,6 @@ import { | |||
| 
 | ||||
| import { DeptSelectModal, UserSelectModal } from '#/components/select-modal'; | ||||
| import { ImageUpload } from '#/components/upload'; | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| const props = defineProps({ | ||||
|   categoryList: { | ||||
|  |  | |||
|  | @ -5,7 +5,8 @@ import type { BpmFormApi } from '#/api/bpm/form'; | |||
| 
 | ||||
| import { ref, watch } from 'vue'; | ||||
| 
 | ||||
| import { BpmModelFormType } from '@vben/constants'; | ||||
| import { BpmModelFormType, DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { CircleHelp } from '@vben/icons'; | ||||
| 
 | ||||
| import FormCreate from '@form-create/ant-design-vue'; | ||||
|  | @ -21,7 +22,7 @@ import { | |||
| } from 'ant-design-vue'; | ||||
| 
 | ||||
| import { getFormDetail } from '#/api/bpm/form'; | ||||
| import { DICT_TYPE, getDictOptions, setConfAndFields2 } from '#/utils'; | ||||
| import { setConfAndFields2 } from '#/utils'; | ||||
| 
 | ||||
| const props = defineProps({ | ||||
|   formList: { | ||||
|  | @ -94,11 +95,11 @@ defineExpose({ validate }); | |||
|     <FormItem label="表单类型" name="formType" class="mb-5"> | ||||
|       <RadioGroup v-model:value="modelData.formType"> | ||||
|         <Radio | ||||
|           v-for="dict in getDictOptions( | ||||
|           v-for="(dict, index) in getDictOptions( | ||||
|             DICT_TYPE.BPM_MODEL_FORM_TYPE, | ||||
|             'number', | ||||
|           )" | ||||
|           :key="dict.value" | ||||
|           :key="index" | ||||
|           :value="dict.value" | ||||
|         > | ||||
|           {{ dict.label }} | ||||
|  |  | |||
|  | @ -1,7 +1,7 @@ | |||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| import type { BpmModelApi } from '#/api/bpm/model'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '#/utils'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| 
 | ||||
| /** 列表的字段 */ | ||||
| export function useGridColumns(): VxeTableGridOptions<BpmModelApi.Model>['columns'] { | ||||
|  |  | |||
|  | @ -4,10 +4,12 @@ import type { DescriptionItemSchema } from '#/components/description'; | |||
| 
 | ||||
| import { h } from 'vue'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { formatDateTime } from '@vben/utils'; | ||||
| 
 | ||||
| import { DictTag } from '#/components/dict-tag'; | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,13 +1,11 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { CommonStatusEnum, DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { z } from '#/adapter/form'; | ||||
| import { | ||||
|   CommonStatusEnum, | ||||
|   DICT_TYPE, | ||||
|   getDictOptions, | ||||
|   getRangePickerDefaultProps, | ||||
| } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,8 +1,11 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { getCategorySimpleList } from '#/api/bpm/category'; | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 列表的搜索表单 */ | ||||
| export function useGridFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -10,6 +10,7 @@ import { | |||
|   BpmModelFormType, | ||||
|   BpmModelType, | ||||
|   BpmTaskStatusEnum, | ||||
|   DICT_TYPE, | ||||
| } from '@vben/constants'; | ||||
| import { formatDateTime } from '@vben/utils'; | ||||
| 
 | ||||
|  | @ -21,7 +22,7 @@ import { | |||
| } from '#/api/bpm/processInstance'; | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import DictTag from '#/components/dict-tag/dict-tag.vue'; | ||||
| import { DICT_TYPE, registerComponent, setConfAndFields2 } from '#/utils'; | ||||
| import { registerComponent, setConfAndFields2 } from '#/utils'; | ||||
| import { | ||||
|   SvgBpmApproveIcon, | ||||
|   SvgBpmCancelIcon, | ||||
|  |  | |||
|  | @ -8,13 +8,14 @@ import type { BpmTaskApi } from '#/api/bpm/task'; | |||
| import { nextTick, onMounted, ref, shallowRef } from 'vue'; | ||||
| 
 | ||||
| import { useVbenModal } from '@vben/common-ui'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { IconifyIcon } from '@vben/icons'; | ||||
| 
 | ||||
| import { Button } from 'ant-design-vue'; | ||||
| 
 | ||||
| import { useVbenVxeGrid } from '#/adapter/vxe-table'; | ||||
| import { getTaskListByProcessInstanceId } from '#/api/bpm/task'; | ||||
| import { DICT_TYPE, setConfAndFields2 } from '#/utils'; | ||||
| import { setConfAndFields2 } from '#/utils'; | ||||
| 
 | ||||
| defineOptions({ | ||||
|   name: 'BpmProcessInstanceTaskList', | ||||
|  |  | |||
|  | @ -4,11 +4,14 @@ import type { BpmProcessInstanceApi } from '#/api/bpm/processInstance'; | |||
| 
 | ||||
| import { h } from 'vue'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { Button } from 'ant-design-vue'; | ||||
| 
 | ||||
| import { getCategorySimpleList } from '#/api/bpm/category'; | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 列表的搜索表单 */ | ||||
| export function useGridFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -5,7 +5,10 @@ import type { | |||
| } from '#/adapter/vxe-table'; | ||||
| import type { BpmProcessInstanceApi } from '#/api/bpm/processInstance'; | ||||
| 
 | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 搜索的表单 */ | ||||
| export function useGridFormSchema( | ||||
|  |  | |||
|  | @ -1,8 +1,10 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { CommonStatusEnum, DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { z } from '#/adapter/form'; | ||||
| import { CommonStatusEnum, DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| export const EVENT_EXECUTION_OPTIONS = [ | ||||
|   { | ||||
|  |  | |||
|  | @ -1,8 +1,11 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { getCategorySimpleList } from '#/api/bpm/category'; | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 列表的搜索表单 */ | ||||
| export function useGridFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,7 +1,9 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| 
 | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 列表的搜索表单 */ | ||||
| export function useGridFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,8 +1,11 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { getCategorySimpleList } from '#/api/bpm/category'; | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 列表的搜索表单 */ | ||||
| export function useGridFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,11 +1,13 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { useUserStore } from '@vben/stores'; | ||||
| 
 | ||||
| import { getAreaTree } from '#/api/system/area'; | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,13 +1,14 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { useUserStore } from '@vben/stores'; | ||||
| 
 | ||||
| import { getSimpleContactList } from '#/api/crm/contact'; | ||||
| import { getCustomerSimpleList } from '#/api/crm/customer'; | ||||
| import { getAreaTree } from '#/api/system/area'; | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,6 +1,7 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { useUserStore } from '@vben/stores'; | ||||
| import { erpPriceInputFormatter, erpPriceMultiply } from '@vben/utils'; | ||||
| 
 | ||||
|  | @ -9,7 +10,6 @@ import { getSimpleBusinessList } from '#/api/crm/business'; | |||
| import { getSimpleContactList } from '#/api/crm/contact'; | ||||
| import { getCustomerSimpleList } from '#/api/crm/customer'; | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { DICT_TYPE } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -3,10 +3,10 @@ import type { DescriptionItemSchema } from '#/components/description'; | |||
| 
 | ||||
| import { h } from 'vue'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { erpPriceInputFormatter, formatDateTime } from '@vben/utils'; | ||||
| 
 | ||||
| import { DictTag } from '#/components/dict-tag'; | ||||
| import { DICT_TYPE } from '#/utils'; | ||||
| /** 详情头部的配置 */ | ||||
| export function useDetailSchema(): DescriptionItemSchema[] { | ||||
|   return [ | ||||
|  |  | |||
|  | @ -1,11 +1,13 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { useUserStore } from '@vben/stores'; | ||||
| 
 | ||||
| import { getAreaTree } from '#/api/system/area'; | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| // TODO @xingyu:缺少 placeholder
 | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,7 +1,8 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| /** 列表的搜索表单 */ | ||||
| export function useGridFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -4,6 +4,8 @@ import type { CrmFollowUpApi } from '#/api/crm/followup'; | |||
| import { ref } from 'vue'; | ||||
| 
 | ||||
| import { useVbenModal } from '@vben/common-ui'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { message } from 'ant-design-vue'; | ||||
| 
 | ||||
|  | @ -12,7 +14,6 @@ import { getBusinessPageByCustomer } from '#/api/crm/business'; | |||
| import { getContactPageByCustomer } from '#/api/crm/contact'; | ||||
| import { createFollowUpRecord } from '#/api/crm/followup'; | ||||
| import { $t } from '#/locales'; | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| const emit = defineEmits(['success']); | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,9 +1,11 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { BizTypeEnum, PermissionLevelEnum } from '#/api/crm/permission'; | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useTransferFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,13 +1,14 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { CommonStatusEnum, DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { useUserStore } from '@vben/stores'; | ||||
| import { handleTree } from '@vben/utils'; | ||||
| 
 | ||||
| import { z } from '#/adapter/form'; | ||||
| import { getProductCategoryList } from '#/api/crm/product/category'; | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { CommonStatusEnum, DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,6 +1,8 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { useUserStore } from '@vben/stores'; | ||||
| 
 | ||||
| import { getContractSimpleList } from '#/api/crm/contract'; | ||||
|  | @ -10,7 +12,6 @@ import { | |||
|   getReceivablePlanSimpleList, | ||||
| } from '#/api/crm/receivable/plan'; | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,13 +1,14 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { useUserStore } from '@vben/stores'; | ||||
| import { erpPriceInputFormatter } from '@vben/utils'; | ||||
| 
 | ||||
| import { getContractSimpleList } from '#/api/crm/contract'; | ||||
| import { getCustomerSimpleList } from '#/api/crm/customer'; | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,4 +1,5 @@ | |||
| import { DICT_TYPE, getDictLabel } from '#/utils'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictLabel } from '@vben/hooks'; | ||||
| 
 | ||||
| export function getChartOptions(activeTabName: any, res: any): any { | ||||
|   switch (activeTabName) { | ||||
|  |  | |||
|  | @ -1,6 +1,8 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { useUserStore } from '@vben/stores'; | ||||
| import { | ||||
|   beginOfDay, | ||||
|  | @ -12,7 +14,7 @@ import { | |||
| 
 | ||||
| import { getSimpleDeptList } from '#/api/system/dept'; | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| const userStore = useUserStore(); | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,12 +1,14 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { useUserStore } from '@vben/stores'; | ||||
| import { beginOfDay, endOfDay, formatDateTime, handleTree } from '@vben/utils'; | ||||
| 
 | ||||
| import { getSimpleDeptList } from '#/api/system/dept'; | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| const userStore = useUserStore(); | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,4 +1,5 @@ | |||
| import { DICT_TYPE, getDictLabel } from '#/utils'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictLabel } from '@vben/hooks'; | ||||
| 
 | ||||
| function areaReplace(areaName: string) { | ||||
|   if (!areaName) { | ||||
|  |  | |||
|  | @ -1,12 +1,13 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { useUserStore } from '@vben/stores'; | ||||
| import { beginOfDay, endOfDay, formatDateTime, handleTree } from '@vben/utils'; | ||||
| 
 | ||||
| import { getSimpleDeptList } from '#/api/system/dept'; | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { DICT_TYPE, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| const userStore = useUserStore(); | ||||
| 
 | ||||
|  |  | |||
|  | @ -3,10 +3,12 @@ import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | |||
| 
 | ||||
| import { h } from 'vue'; | ||||
| 
 | ||||
| import { CommonStatusEnum, DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { Tag } from 'ant-design-vue'; | ||||
| 
 | ||||
| import { z } from '#/adapter/form'; | ||||
| import { CommonStatusEnum, DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -2,11 +2,12 @@ import type { VbenFormSchema } from '#/adapter/form'; | |||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| import type { ErpProductCategoryApi } from '#/api/erp/product/category'; | ||||
| 
 | ||||
| import { CommonStatusEnum, DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { handleTree } from '@vben/utils'; | ||||
| 
 | ||||
| import { z } from '#/adapter/form'; | ||||
| import { getProductCategoryList } from '#/api/erp/product/category'; | ||||
| import { CommonStatusEnum, DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,12 +1,13 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { CommonStatusEnum, DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { handleTree } from '@vben/utils'; | ||||
| 
 | ||||
| import { z } from '#/adapter/form'; | ||||
| import { getProductCategorySimpleList } from '#/api/erp/product/category'; | ||||
| import { getProductUnitSimpleList } from '#/api/erp/product/unit'; | ||||
| import { CommonStatusEnum, DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,8 +1,10 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { CommonStatusEnum, DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { z } from '#/adapter/form'; | ||||
| import { CommonStatusEnum, DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,6 +1,8 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { erpPriceInputFormatter } from '@vben/utils'; | ||||
| 
 | ||||
| import { z } from '#/adapter/form'; | ||||
|  | @ -9,7 +11,6 @@ import { getProductSimpleList } from '#/api/erp/product/product'; | |||
| import { getSupplierSimpleList } from '#/api/erp/purchase/supplier'; | ||||
| import { getWarehouseSimpleList } from '#/api/erp/stock/warehouse'; | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| /** 表单的配置项 */ | ||||
| export function useFormSchema(formType: string): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,6 +1,8 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { erpPriceInputFormatter } from '@vben/utils'; | ||||
| 
 | ||||
| import { z } from '#/adapter/form'; | ||||
|  | @ -8,7 +10,6 @@ import { getAccountSimpleList } from '#/api/erp/finance/account'; | |||
| import { getProductSimpleList } from '#/api/erp/product/product'; | ||||
| import { getSupplierSimpleList } from '#/api/erp/purchase/supplier'; | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| /** 表单的配置项 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,6 +1,8 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { erpNumberFormatter, erpPriceInputFormatter } from '@vben/utils'; | ||||
| 
 | ||||
| import { z } from '#/adapter/form'; | ||||
|  | @ -9,7 +11,6 @@ import { getProductSimpleList } from '#/api/erp/product/product'; | |||
| import { getSupplierSimpleList } from '#/api/erp/purchase/supplier'; | ||||
| import { getWarehouseSimpleList } from '#/api/erp/stock/warehouse'; | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| /** 表单的配置项 */ | ||||
| export function useFormSchema(formType: string): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,7 +1,8 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,8 +1,10 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { CommonStatusEnum, DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { z } from '#/adapter/form'; | ||||
| import { CommonStatusEnum, DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,6 +1,8 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { erpPriceInputFormatter } from '@vben/utils'; | ||||
| 
 | ||||
| import { z } from '#/adapter/form'; | ||||
|  | @ -8,7 +10,6 @@ import { getAccountSimpleList } from '#/api/erp/finance/account'; | |||
| import { getProductSimpleList } from '#/api/erp/product/product'; | ||||
| import { getCustomerSimpleList } from '#/api/erp/sale/customer'; | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| /** 表单的配置项 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,6 +1,8 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { erpNumberFormatter, erpPriceInputFormatter } from '@vben/utils'; | ||||
| 
 | ||||
| import { z } from '#/adapter/form'; | ||||
|  | @ -9,7 +11,6 @@ import { getProductSimpleList } from '#/api/erp/product/product'; | |||
| import { getCustomerSimpleList } from '#/api/erp/sale/customer'; | ||||
| import { getWarehouseSimpleList } from '#/api/erp/stock/warehouse'; | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| /** 表单的配置项 */ | ||||
| export function useFormSchema(formType: string): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,6 +1,8 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { erpNumberFormatter, erpPriceInputFormatter } from '@vben/utils'; | ||||
| 
 | ||||
| import { z } from '#/adapter/form'; | ||||
|  | @ -9,7 +11,6 @@ import { getProductSimpleList } from '#/api/erp/product/product'; | |||
| import { getCustomerSimpleList } from '#/api/erp/sale/customer'; | ||||
| import { getWarehouseSimpleList } from '#/api/erp/stock/warehouse'; | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| /** 表单的配置项 */ | ||||
| export function useFormSchema(formType: string): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,11 +1,13 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { createRequiredValidation } from '#/adapter/vxe-table'; | ||||
| import { getProductSimpleList } from '#/api/erp/product/product'; | ||||
| import { getWarehouseSimpleList } from '#/api/erp/stock/warehouse'; | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| /** 表单的配置项 */ | ||||
| export function useFormSchema(formType: string): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,10 +1,12 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { createRequiredValidation } from '#/adapter/vxe-table'; | ||||
| import { getSupplierSimpleList } from '#/api/erp/purchase/supplier'; | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| /** 表单的配置项 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,11 +1,13 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { createRequiredValidation } from '#/adapter/vxe-table'; | ||||
| import { getProductSimpleList } from '#/api/erp/product/product'; | ||||
| import { getWarehouseSimpleList } from '#/api/erp/stock/warehouse'; | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| /** 表单的配置项 */ | ||||
| export function useFormSchema(formType: string): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,11 +1,13 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { createRequiredValidation } from '#/adapter/vxe-table'; | ||||
| import { getProductSimpleList } from '#/api/erp/product/product'; | ||||
| import { getCustomerSimpleList } from '#/api/erp/sale/customer'; | ||||
| import { getSimpleUserList } from '#/api/system/user'; | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| /** 表单的配置项 */ | ||||
| export function useFormSchema(formType: string): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,9 +1,11 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { getProductSimpleList } from '#/api/erp/product/product'; | ||||
| import { getWarehouseSimpleList } from '#/api/erp/stock/warehouse'; | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| /** 搜索表单 */ | ||||
| export function useGridFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -2,7 +2,8 @@ import type { VbenFormSchema } from '#/adapter/form'; | |||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| import type { ErpWarehouseApi } from '#/api/erp/stock/warehouse'; | ||||
| 
 | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -5,10 +5,12 @@ import type { DescriptionItemSchema } from '#/components/description'; | |||
| import { h } from 'vue'; | ||||
| 
 | ||||
| import { JsonViewer } from '@vben/common-ui'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { formatDateTime } from '@vben/utils'; | ||||
| 
 | ||||
| import { DictTag } from '#/components/dict-tag'; | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 列表的搜索表单 */ | ||||
| export function useGridFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -5,13 +5,14 @@ import type { DescriptionItemSchema } from '#/components/description'; | |||
| import { h } from 'vue'; | ||||
| 
 | ||||
| import { JsonViewer } from '@vben/common-ui'; | ||||
| import { InfraApiErrorLogProcessStatusEnum } from '@vben/constants'; | ||||
| import { DICT_TYPE, InfraApiErrorLogProcessStatusEnum } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { formatDateTime } from '@vben/utils'; | ||||
| 
 | ||||
| import { Textarea } from 'ant-design-vue'; | ||||
| 
 | ||||
| import { DictTag } from '#/components/dict-tag'; | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 列表的搜索表单 */ | ||||
| export function useGridFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -7,13 +7,15 @@ import type { SystemMenuApi } from '#/api/system/menu'; | |||
| 
 | ||||
| import { h } from 'vue'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { IconifyIcon } from '@vben/icons'; | ||||
| import { handleTree } from '@vben/utils'; | ||||
| 
 | ||||
| import { getDataSourceConfigList } from '#/api/infra/data-source-config'; | ||||
| import { getMenuList } from '#/api/system/menu'; | ||||
| import { $t } from '#/locales'; | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 导入数据库表的表单 */ | ||||
| export function useImportTableFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,7 +1,10 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -2,7 +2,10 @@ import type { VbenFormSchema } from '#/adapter/form'; | |||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| import type { Demo01ContactApi } from '#/api/infra/demo/demo01'; | ||||
| 
 | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -3,8 +3,10 @@ import type { OnActionClickFn, VxeTableGridOptions } from '#/adapter/vxe-table'; | |||
| import type { Demo03StudentApi } from '#/api/infra/demo/demo03/erp'; | ||||
| 
 | ||||
| import { useAccess } from '@vben/access'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| const { hasAccessByCodes } = useAccess(); | ||||
| 
 | ||||
|  |  | |||
|  | @ -3,8 +3,10 @@ import type { OnActionClickFn, VxeTableGridOptions } from '#/adapter/vxe-table'; | |||
| import type { Demo03StudentApi } from '#/api/infra/demo/demo03/inner'; | ||||
| 
 | ||||
| import { useAccess } from '@vben/access'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| const { hasAccessByCodes } = useAccess(); | ||||
| 
 | ||||
|  |  | |||
|  | @ -3,8 +3,10 @@ import type { OnActionClickFn, VxeTableGridOptions } from '#/adapter/vxe-table'; | |||
| import type { Demo03StudentApi } from '#/api/infra/demo/demo03/normal'; | ||||
| 
 | ||||
| import { useAccess } from '@vben/access'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| const { hasAccessByCodes } = useAccess(); | ||||
| 
 | ||||
|  |  | |||
|  | @ -4,6 +4,8 @@ import type { Demo01ContactApi } from '#/api/infra/demo/demo01'; | |||
| import { h, onMounted, reactive, ref } from 'vue'; | ||||
| 
 | ||||
| import { Page, useVbenModal } from '@vben/common-ui'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { Download, Plus, Trash2 } from '@vben/icons'; | ||||
| import { | ||||
|   cloneDeep, | ||||
|  | @ -34,7 +36,7 @@ import { DictTag } from '#/components/dict-tag'; | |||
| import { TableToolbar } from '#/components/table-toolbar'; | ||||
| import { useTableToolbar } from '#/hooks'; | ||||
| import { $t } from '#/locales'; | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| import Demo01ContactForm from './modules/form.vue'; | ||||
| 
 | ||||
|  |  | |||
|  | @ -6,6 +6,8 @@ import type { Demo01ContactApi } from '#/api/infra/demo/demo01'; | |||
| import { computed, ref } from 'vue'; | ||||
| 
 | ||||
| import { useVbenModal } from '@vben/common-ui'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { | ||||
|   DatePicker, | ||||
|  | @ -24,7 +26,6 @@ import { | |||
| import { Tinymce as RichTextarea } from '#/components/tinymce'; | ||||
| import { ImageUpload } from '#/components/upload'; | ||||
| import { $t } from '#/locales'; | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| const emit = defineEmits(['success']); | ||||
| 
 | ||||
|  |  | |||
|  | @ -4,6 +4,8 @@ import type { Demo03StudentApi } from '#/api/infra/demo/demo03/erp'; | |||
| import { h, onMounted, reactive, ref } from 'vue'; | ||||
| 
 | ||||
| import { Page, useVbenModal } from '@vben/common-ui'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { Download, Plus, Trash2 } from '@vben/icons'; | ||||
| import { | ||||
|   cloneDeep, | ||||
|  | @ -35,7 +37,7 @@ import { DictTag } from '#/components/dict-tag'; | |||
| import { TableToolbar } from '#/components/table-toolbar'; | ||||
| import { useTableToolbar } from '#/hooks'; | ||||
| import { $t } from '#/locales'; | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| import Demo03CourseList from './modules/demo03-course-list.vue'; | ||||
| import Demo03GradeList from './modules/demo03-grade-list.vue'; | ||||
|  |  | |||
|  | @ -6,6 +6,8 @@ import type { Demo03StudentApi } from '#/api/infra/demo/demo03/erp'; | |||
| import { computed, ref } from 'vue'; | ||||
| 
 | ||||
| import { useVbenModal } from '@vben/common-ui'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { | ||||
|   DatePicker, | ||||
|  | @ -23,7 +25,6 @@ import { | |||
| } from '#/api/infra/demo/demo03/erp'; | ||||
| import { Tinymce as RichTextarea } from '#/components/tinymce'; | ||||
| import { $t } from '#/locales'; | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| const emit = defineEmits(['success']); | ||||
| 
 | ||||
|  |  | |||
|  | @ -4,6 +4,8 @@ import type { Demo03StudentApi } from '#/api/infra/demo/demo03/normal'; | |||
| import { h, onMounted, reactive, ref } from 'vue'; | ||||
| 
 | ||||
| import { Page, useVbenModal } from '@vben/common-ui'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { Download, Plus, Trash2 } from '@vben/icons'; | ||||
| import { | ||||
|   cloneDeep, | ||||
|  | @ -35,7 +37,7 @@ import { DictTag } from '#/components/dict-tag'; | |||
| import { TableToolbar } from '#/components/table-toolbar'; | ||||
| import { useTableToolbar } from '#/hooks'; | ||||
| import { $t } from '#/locales'; | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| import Demo03CourseList from './modules/demo03-course-list.vue'; | ||||
| import Demo03GradeList from './modules/demo03-grade-list.vue'; | ||||
|  |  | |||
|  | @ -6,6 +6,8 @@ import type { Demo03StudentApi } from '#/api/infra/demo/demo03/normal'; | |||
| import { computed, ref } from 'vue'; | ||||
| 
 | ||||
| import { useVbenModal } from '@vben/common-ui'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { | ||||
|   DatePicker, | ||||
|  | @ -24,7 +26,6 @@ import { | |||
| } from '#/api/infra/demo/demo03/normal'; | ||||
| import { Tinymce as RichTextarea } from '#/components/tinymce'; | ||||
| import { $t } from '#/locales'; | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| import Demo03CourseForm from './demo03-course-form.vue'; | ||||
| import Demo03GradeForm from './demo03-grade-form.vue'; | ||||
|  |  | |||
|  | @ -4,6 +4,8 @@ import type { Demo03StudentApi } from '#/api/infra/demo/demo03/normal'; | |||
| import { h, onMounted, reactive, ref } from 'vue'; | ||||
| 
 | ||||
| import { Page, useVbenModal } from '@vben/common-ui'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { Download, Plus, Trash2 } from '@vben/icons'; | ||||
| import { | ||||
|   cloneDeep, | ||||
|  | @ -34,7 +36,7 @@ import { DictTag } from '#/components/dict-tag'; | |||
| import { TableToolbar } from '#/components/table-toolbar'; | ||||
| import { useTableToolbar } from '#/hooks'; | ||||
| import { $t } from '#/locales'; | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| import Demo03StudentForm from './modules/form.vue'; | ||||
| 
 | ||||
|  |  | |||
|  | @ -6,6 +6,8 @@ import type { Demo03StudentApi } from '#/api/infra/demo/demo03/normal'; | |||
| import { computed, ref } from 'vue'; | ||||
| 
 | ||||
| import { useVbenModal } from '@vben/common-ui'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { | ||||
|   DatePicker, | ||||
|  | @ -24,7 +26,6 @@ import { | |||
| } from '#/api/infra/demo/demo03/normal'; | ||||
| import { Tinymce as RichTextarea } from '#/components/tinymce'; | ||||
| import { $t } from '#/locales'; | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| import Demo03CourseForm from './demo03-course-form.vue'; | ||||
| import Demo03GradeForm from './demo03-grade-form.vue'; | ||||
|  |  | |||
|  | @ -1,7 +1,10 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -4,13 +4,14 @@ import type { DescriptionItemSchema } from '#/components/description'; | |||
| 
 | ||||
| import { h, markRaw } from 'vue'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { formatDateTime } from '@vben/utils'; | ||||
| 
 | ||||
| import { Timeline } from 'ant-design-vue'; | ||||
| 
 | ||||
| import { CronTab } from '#/components/cron-tab'; | ||||
| import { DictTag } from '#/components/dict-tag'; | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -4,12 +4,13 @@ import type { DescriptionItemSchema } from '#/components/description'; | |||
| 
 | ||||
| import { h } from 'vue'; | ||||
| 
 | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { formatDateTime } from '@vben/utils'; | ||||
| 
 | ||||
| import dayjs from 'dayjs'; | ||||
| 
 | ||||
| import { DictTag } from '#/components/dict-tag'; | ||||
| import { DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| /** 列表的搜索表单 */ | ||||
| export function useGridFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,13 +1,11 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeGridPropTypes } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { CommonStatusEnum, DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { z } from '#/adapter/form'; | ||||
| import { | ||||
|   CommonStatusEnum, | ||||
|   DICT_TYPE, | ||||
|   getDictOptions, | ||||
|   getRangePickerDefaultProps, | ||||
| } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -2,11 +2,12 @@ import type { VbenFormSchema } from '#/adapter/form'; | |||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||
| import type { MallCategoryApi } from '#/api/mall/product/category'; | ||||
| 
 | ||||
| import { CommonStatusEnum, DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| import { handleTree } from '@vben/utils'; | ||||
| 
 | ||||
| import { z } from '#/adapter/form'; | ||||
| import { getCategoryList } from '#/api/mall/product/category'; | ||||
| import { CommonStatusEnum, DICT_TYPE, getDictOptions } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,7 +1,10 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeGridPropTypes } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,14 +1,12 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeGridPropTypes } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { CommonStatusEnum, DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { z } from '#/adapter/form'; | ||||
| import { getSimpleArticleCategoryList } from '#/api/mall/promotion/articleCategory'; | ||||
| import { | ||||
|   CommonStatusEnum, | ||||
|   DICT_TYPE, | ||||
|   getDictOptions, | ||||
|   getRangePickerDefaultProps, | ||||
| } from '#/utils'; | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
|  | @ -1,7 +1,10 @@ | |||
| import type { VbenFormSchema } from '#/adapter/form'; | ||||
| import type { VxeGridPropTypes } from '#/adapter/vxe-table'; | ||||
| 
 | ||||
| import { DICT_TYPE, getDictOptions, getRangePickerDefaultProps } from '#/utils'; | ||||
| import { DICT_TYPE } from '@vben/constants'; | ||||
| import { getDictOptions } from '@vben/hooks'; | ||||
| 
 | ||||
| import { getRangePickerDefaultProps } from '#/utils'; | ||||
| 
 | ||||
| /** 新增/修改的表单 */ | ||||
| export function useFormSchema(): VbenFormSchema[] { | ||||
|  |  | |||
Some files were not shown because too many files have changed in this diff Show More
		Loading…
	
		Reference in New Issue
	
	 芋道源码
						芋道源码