mirror of
				https://github.com/continew-org/continew-admin-ui.git
				synced 2025-10-26 20:57:14 +08:00 
			
		
		
		
	refactor: GiForm 新增动态禁用配置项
This commit is contained in:
		| @@ -8,8 +8,14 @@ | ||||
|           v-bind="item.col || item.span ? item.col : options.col" | ||||
|           v-show="index <= (options.fold?.index || 0) || (index >= (options.fold?.index || 0) && !collapsed)" | ||||
|         > | ||||
|           <a-form-item v-bind="item.item" :label="item.label" :field="item.field" :rules="item.rules"> | ||||
|             <slot :name="item.field"> | ||||
|           <a-form-item | ||||
|             v-bind="item.item" | ||||
|             :label="item.label" | ||||
|             :field="item.field" | ||||
|             :rules="item.rules" | ||||
|             :disabled="isDisabled(item.disabled)" | ||||
|           > | ||||
|             <slot :name="item.field" v-bind="{ disabled: isDisabled(item.disabled) }"> | ||||
|               <template v-if="item.type === 'input'"> | ||||
|                 <a-input | ||||
|                   :placeholder="`请输入${item.label}`" | ||||
| @@ -165,9 +171,9 @@ | ||||
| </template> | ||||
|  | ||||
| <script setup lang="ts"> | ||||
| import type { Options, Columns, ColumnsItemHide, ColumnsItem } from './type' | ||||
| import type { Options, Columns, ColumnsItemHide, ColumnsItemDisabled, ColumnsItem } from './type' | ||||
| import type * as A from '@arco-design/web-vue' | ||||
| import _ from 'lodash' | ||||
| import { cloneDeep } from 'lodash-es' | ||||
|  | ||||
| interface Props { | ||||
|   modelValue: any | ||||
| @@ -199,6 +205,14 @@ const isHide = (hide?: ColumnsItemHide<boolean | object>) => { | ||||
|   } | ||||
| } | ||||
|  | ||||
| const isDisabled = (disabled?: ColumnsItemDisabled<boolean | object>) => { | ||||
|   if (disabled === undefined) return false | ||||
|   if (typeof disabled === 'boolean') return disabled | ||||
|   if (typeof disabled === 'function') { | ||||
|     return disabled(props.modelValue) | ||||
|   } | ||||
| } | ||||
|  | ||||
| const dicData: Record<string, any> = reactive({}) | ||||
| props.columns.forEach((item) => { | ||||
|   if (item.request && typeof item.request === 'function' && item?.init) { | ||||
| @@ -219,7 +233,7 @@ props.columns.forEach((item) => { | ||||
| }) | ||||
|  | ||||
| // 要深克隆,否则无法监听新旧值变化 | ||||
| const cloneForm = computed(() => _.cloneDeep(props.modelValue)) | ||||
| const cloneForm = computed(() => cloneDeep(props.modelValue)) | ||||
|  | ||||
| watch(cloneForm as any, (newVal, oldVal) => { | ||||
|   hasCascaderColumns.forEach((item) => { | ||||
|   | ||||
| @@ -1,10 +1,10 @@ | ||||
| import { reactive } from 'vue' | ||||
| import _ from 'lodash' | ||||
| import { cloneDeep } from 'lodash-es' | ||||
| import type { Columns, ColumnsItem, ColumnsItemPropsKey } from './type' | ||||
| import { Message } from '@arco-design/web-vue' | ||||
|  | ||||
| export function useGiForm(initValue: Columns) { | ||||
|   const getInitValue = () => _.cloneDeep(initValue) | ||||
|   const getInitValue = () => cloneDeep(initValue) | ||||
|  | ||||
|   const columns = reactive(getInitValue()) | ||||
|  | ||||
|   | ||||
| @@ -31,6 +31,7 @@ export type ColumnsItemPropsKey = | ||||
|   | keyof A.TreeSelectInstance['$props'] | ||||
|  | ||||
| export type ColumnsItemHide<F> = boolean | ((form: F) => boolean) | ||||
| export type ColumnsItemDisabled<F> = boolean | ((form: F) => boolean) | ||||
| export type ColumnsItemRequest<F = any> = (form: F) => Promise<any> | ||||
| export type ColumnsItemFormat<T = any> = ( | ||||
|   res: T | ||||
| @@ -49,8 +50,8 @@ export type ColumnsItemOptionsOrData = | ||||
|   | A.TreeSelectInstance['$props']['data'] | ||||
|  | ||||
| export interface ColumnsItem<F = any> { | ||||
|   type: FormType // 类型 | ||||
|   label: A.FormItemInstance['label'] // 标签 | ||||
|   type?: FormType // 类型 | ||||
|   label?: A.FormItemInstance['label'] // 标签 | ||||
|   field: A.FormItemInstance['field'] // 字段(必须唯一) | ||||
|   span?: number // 栅格占位格数 | ||||
|   col?: A.ColProps // a-col的props, 响应式布局, 优先级大于span | ||||
| @@ -79,6 +80,7 @@ export interface ColumnsItem<F = any> { | ||||
|   // 下拉树组件的data | ||||
|   data?: A.TreeSelectInstance['$props']['data'] | ||||
|   hide?: ColumnsItemHide<F> // 是否隐藏 | ||||
|   disabled?: ColumnsItemDisabled<F> // 是否禁用 | ||||
|   request?: ColumnsItemRequest<F> // 接口请求api | ||||
|   resultFormat?: ColumnsItemFormat // 结果集格式化 | ||||
|   init?: boolean // 初始化请求 | ||||
|   | ||||
		Reference in New Issue
	
	Block a user