114 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Vue
		
	
	
			
		
		
	
	
			114 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Vue
		
	
	
| import type { ColProps } from '../grid/Col';
 | |
| import Col from '../grid/Col';
 | |
| import { useProvideForm, useInjectForm, useProvideFormItemPrefix } from './context';
 | |
| import ErrorList from './ErrorList';
 | |
| import classNames from '../_util/classNames';
 | |
| import type { ValidateStatus } from './FormItem';
 | |
| import type { CustomSlotsType, VueNode } from '../_util/type';
 | |
| import type { HTMLAttributes } from 'vue';
 | |
| import { computed, defineComponent } from 'vue';
 | |
| import { filterEmpty } from '../_util/props-util';
 | |
| 
 | |
| export interface FormItemInputMiscProps {
 | |
|   prefixCls: string;
 | |
|   errors: VueNode[];
 | |
|   hasFeedback?: boolean;
 | |
|   validateStatus?: ValidateStatus;
 | |
| }
 | |
| 
 | |
| export interface FormItemInputProps {
 | |
|   wrapperCol?: ColProps;
 | |
|   help?: VueNode;
 | |
|   extra?: VueNode;
 | |
|   status?: ValidateStatus;
 | |
| }
 | |
| 
 | |
| const FormItemInput = defineComponent({
 | |
|   compatConfig: { MODE: 3 },
 | |
|   slots: Object as CustomSlotsType<{
 | |
|     help: any;
 | |
|     errors: any;
 | |
|     extra: any;
 | |
|     default: any;
 | |
|   }>,
 | |
|   inheritAttrs: false,
 | |
|   props: [
 | |
|     'prefixCls',
 | |
|     'errors',
 | |
|     'hasFeedback',
 | |
|     'onDomErrorVisibleChange',
 | |
|     'wrapperCol',
 | |
|     'help',
 | |
|     'extra',
 | |
|     'status',
 | |
|     'marginBottom',
 | |
|     'onErrorVisibleChanged',
 | |
|   ],
 | |
|   setup(props, { slots }) {
 | |
|     const formContext = useInjectForm();
 | |
|     const { wrapperCol: contextWrapperCol } = formContext;
 | |
| 
 | |
|     // Pass to sub FormItem should not with col info
 | |
|     const subFormContext = { ...formContext };
 | |
|     delete subFormContext.labelCol;
 | |
|     delete subFormContext.wrapperCol;
 | |
|     useProvideForm(subFormContext);
 | |
|     useProvideFormItemPrefix({
 | |
|       prefixCls: computed(() => props.prefixCls),
 | |
|       status: computed(() => props.status),
 | |
|     });
 | |
| 
 | |
|     return () => {
 | |
|       const {
 | |
|         prefixCls,
 | |
|         wrapperCol,
 | |
|         marginBottom,
 | |
|         onErrorVisibleChanged,
 | |
|         help = slots.help?.(),
 | |
|         errors = filterEmpty(slots.errors?.()),
 | |
|         // hasFeedback,
 | |
|         // status,
 | |
|         extra = slots.extra?.(),
 | |
|       } = props;
 | |
|       const baseClassName = `${prefixCls}-item`;
 | |
| 
 | |
|       const mergedWrapperCol: ColProps & HTMLAttributes =
 | |
|         wrapperCol || contextWrapperCol?.value || {};
 | |
| 
 | |
|       const className = classNames(`${baseClassName}-control`, mergedWrapperCol.class);
 | |
| 
 | |
|       // Should provides additional icon if `hasFeedback`
 | |
|       // const IconNode = status && iconMap[status];
 | |
|       return (
 | |
|         <Col
 | |
|           {...mergedWrapperCol}
 | |
|           class={className}
 | |
|           v-slots={{
 | |
|             default: () => (
 | |
|               <>
 | |
|                 <div class={`${baseClassName}-control-input`}>
 | |
|                   <div class={`${baseClassName}-control-input-content`}>{slots.default?.()}</div>
 | |
|                 </div>
 | |
|                 {marginBottom !== null || errors.length ? (
 | |
|                   <div style={{ display: 'flex', flexWrap: 'nowrap' }}>
 | |
|                     <ErrorList
 | |
|                       errors={errors}
 | |
|                       help={help}
 | |
|                       class={`${baseClassName}-explain-connected`}
 | |
|                       onErrorVisibleChanged={onErrorVisibleChanged}
 | |
|                     />
 | |
|                     {!!marginBottom && <div style={{ width: 0, height: `${marginBottom}px` }} />}
 | |
|                   </div>
 | |
|                 ) : null}
 | |
|                 {extra ? <div class={`${baseClassName}-extra`}>{extra}</div> : null}
 | |
|               </>
 | |
|             ),
 | |
|           }}
 | |
|         ></Col>
 | |
|       );
 | |
|     };
 | |
|   },
 | |
| });
 | |
| 
 | |
| export default FormItemInput;
 |