import type { ExtractPropTypes, PropType } from '@vue/runtime-core'; import type { Mutable } from './types'; declare const wrapperKey: unique symbol; export declare type PropWrapper = { [wrapperKey]: T; }; export declare const propKey = "__elPropsReservedKey"; declare type ResolveProp = ExtractPropTypes<{ key: { type: T; required: true; }; }>['key']; declare type ResolvePropType = ResolveProp extends { type: infer V; } ? V : ResolveProp; declare type ResolvePropTypeWithReadonly = Readonly extends Readonly> ? ResolvePropType : ResolvePropType; declare type IfUnknown = [unknown] extends [T] ? V : T; export declare type BuildPropOption, R, V, C> = { type?: T; values?: readonly V[]; required?: R; default?: R extends true ? never : D extends Record | Array ? () => D : (() => D) | D; validator?: ((val: any) => val is C) | ((val: any) => boolean); }; declare type _BuildPropType = (T extends PropWrapper ? T[typeof wrapperKey] : [V] extends [never] ? ResolvePropTypeWithReadonly : never) | V | C; export declare type BuildPropType = _BuildPropType, IfUnknown, IfUnknown>; declare type _BuildPropDefault = [T] extends [ Record | Array | Function ] ? D : D extends () => T ? ReturnType : D; export declare type BuildPropDefault = R extends true ? { readonly default?: undefined; } : { readonly default: Exclude extends never ? undefined : Exclude<_BuildPropDefault, undefined>; }; export declare type BuildPropReturn = { readonly type: PropType>; readonly required: IfUnknown; readonly validator: ((val: unknown) => boolean) | undefined; [propKey]: true; } & BuildPropDefault, IfUnknown, IfUnknown>; /** * @description Build prop. It can better optimize prop types * @description 生成 prop,能更好地优化类型 * @example // limited options // the type will be PropType<'light' | 'dark'> buildProp({ type: String, values: ['light', 'dark'], } as const) * @example // limited options and other types // the type will be PropType<'small' | 'large' | number> buildProp({ type: [String, Number], values: ['small', 'large'], validator: (val: unknown): val is number => typeof val === 'number', } as const) @link see more: https://github.com/element-plus/element-plus/pull/3341 */ export declare function buildProp = never, R extends boolean = false, V = never, C = never>(option: BuildPropOption, key?: string): BuildPropReturn; declare type NativePropType = [ ((...args: any) => any) | { new (...args: any): any; } | undefined | null ]; export declare const buildProps: ? O[K] : [O[K]] extends NativePropType ? O[K] : O[K] extends BuildPropOption ? D extends BuildPropType ? BuildPropOption : never : never; }>(props: O) => { [K_1 in keyof O]: O[K_1] extends { __elPropsReservedKey: boolean; } ? O[K_1] : [O[K_1]] extends NativePropType ? O[K_1] : O[K_1] extends BuildPropOption ? BuildPropReturn : never; }; export declare const definePropType: (val: any) => PropWrapper; export declare const keyOf: (arr: T) => (keyof T)[]; export declare const mutable: >(val: T) => Mutable; export declare const componentSize: readonly ["large", "default", "small"]; export {};