import { type ColumnItem } from '../wd-picker-view/types'
import { type FormItemRule } from '../wd-form/types'
declare const _default: __VLS_WithTemplateSlots<
  import('vue').DefineComponent<
    {
      customLabelClass: {
        type: import('vue').PropType<string>
        default: string
      }
      customValueClass: {
        type: import('vue').PropType<string>
        default: string
      }
      customViewClass: {
        type: import('vue').PropType<string>
        default: string
      }
      label: StringConstructor
      placeholder: StringConstructor
      disabled: {
        type: BooleanConstructor
        default: boolean
      }
      readonly: {
        type: BooleanConstructor
        default: boolean
      }
      loading: {
        type: BooleanConstructor
        default: boolean
      }
      loadingColor: {
        type: import('vue').PropType<string>
        default: string
      }
      title: StringConstructor
      cancelButtonText: StringConstructor
      confirmButtonText: StringConstructor
      required: {
        type: BooleanConstructor
        default: boolean
      }
      size: StringConstructor
      labelWidth: StringConstructor
      useDefaultSlot: {
        type: BooleanConstructor
        default: boolean
      }
      useLabelSlot: {
        type: BooleanConstructor
        default: boolean
      }
      error: {
        type: BooleanConstructor
        default: boolean
      }
      alignRight: {
        type: BooleanConstructor
        default: boolean
      }
      beforeConfirm: import('vue').PropType<import('./types').PickerBeforeConfirm>
      closeOnClickModal: {
        type: BooleanConstructor
        default: boolean
      }
      safeAreaInsetBottom: {
        type: BooleanConstructor
        default: boolean
      }
      ellipsis: {
        type: BooleanConstructor
        default: boolean
      }
      columnsHeight: {
        type: NumberConstructor
        default: number
      }
      valueKey: {
        type: import('vue').PropType<string>
        default: string
      }
      labelKey: {
        type: import('vue').PropType<string>
        default: string
      }
      modelValue: {
        type: import('vue').PropType<string | number | Array<string> | Array<number>>
        default: string
      }
      columns: {
        type: import('vue').PropType<
          Array<string | number | ColumnItem | Array<string | number | ColumnItem>>
        >
        default: () => never[]
      }
      columnChange: import('vue').PropType<import('../wd-picker-view/types').PickerViewColumnChange>
      displayFormat: import('vue').PropType<import('./types').PickerDisplayFormat>
      zIndex: {
        type: NumberConstructor
        default: number
      }
      prop: StringConstructor
      rules: {
        type: import('vue').PropType<FormItemRule[]>
        default: () => never[]
      }
      immediateChange: {
        type: BooleanConstructor
        default: boolean
      }
      customStyle: {
        type: import('vue').PropType<string>
        default: string
      }
      customClass: {
        type: import('vue').PropType<string>
        default: string
      }
    },
    {
      open: () => void
      close: () => void
      setLoading: (loading: boolean) => void
    },
    unknown,
    {},
    {},
    import('vue').ComponentOptionsMixin,
    import('vue').ComponentOptionsMixin,
    {
      cancel: (...args: any[]) => void
      open: (...args: any[]) => void
      'update:modelValue': (...args: any[]) => void
      confirm: (...args: any[]) => void
    },
    string,
    import('vue').PublicProps,
    Readonly<
      import('vue').ExtractPropTypes<{
        customLabelClass: {
          type: import('vue').PropType<string>
          default: string
        }
        customValueClass: {
          type: import('vue').PropType<string>
          default: string
        }
        customViewClass: {
          type: import('vue').PropType<string>
          default: string
        }
        label: StringConstructor
        placeholder: StringConstructor
        disabled: {
          type: BooleanConstructor
          default: boolean
        }
        readonly: {
          type: BooleanConstructor
          default: boolean
        }
        loading: {
          type: BooleanConstructor
          default: boolean
        }
        loadingColor: {
          type: import('vue').PropType<string>
          default: string
        }
        title: StringConstructor
        cancelButtonText: StringConstructor
        confirmButtonText: StringConstructor
        required: {
          type: BooleanConstructor
          default: boolean
        }
        size: StringConstructor
        labelWidth: StringConstructor
        useDefaultSlot: {
          type: BooleanConstructor
          default: boolean
        }
        useLabelSlot: {
          type: BooleanConstructor
          default: boolean
        }
        error: {
          type: BooleanConstructor
          default: boolean
        }
        alignRight: {
          type: BooleanConstructor
          default: boolean
        }
        beforeConfirm: import('vue').PropType<import('./types').PickerBeforeConfirm>
        closeOnClickModal: {
          type: BooleanConstructor
          default: boolean
        }
        safeAreaInsetBottom: {
          type: BooleanConstructor
          default: boolean
        }
        ellipsis: {
          type: BooleanConstructor
          default: boolean
        }
        columnsHeight: {
          type: NumberConstructor
          default: number
        }
        valueKey: {
          type: import('vue').PropType<string>
          default: string
        }
        labelKey: {
          type: import('vue').PropType<string>
          default: string
        }
        modelValue: {
          type: import('vue').PropType<string | number | Array<string> | Array<number>>
          default: string
        }
        columns: {
          type: import('vue').PropType<
            Array<string | number | ColumnItem | Array<string | number | ColumnItem>>
          >
          default: () => never[]
        }
        columnChange: import('vue').PropType<
          import('../wd-picker-view/types').PickerViewColumnChange
        >
        displayFormat: import('vue').PropType<import('./types').PickerDisplayFormat>
        zIndex: {
          type: NumberConstructor
          default: number
        }
        prop: StringConstructor
        rules: {
          type: import('vue').PropType<FormItemRule[]>
          default: () => never[]
        }
        immediateChange: {
          type: BooleanConstructor
          default: boolean
        }
        customStyle: {
          type: import('vue').PropType<string>
          default: string
        }
        customClass: {
          type: import('vue').PropType<string>
          default: string
        }
      }>
    > & {
      onCancel?: ((...args: any[]) => any) | undefined
      onOpen?: ((...args: any[]) => any) | undefined
      'onUpdate:modelValue'?: ((...args: any[]) => any) | undefined
      onConfirm?: ((...args: any[]) => any) | undefined
    },
    {
      modelValue: string | number | string[] | number[]
      closeOnClickModal: boolean
      zIndex: number
      safeAreaInsetBottom: boolean
      customStyle: string
      customClass: string
      readonly: boolean
      required: boolean
      error: boolean
      disabled: boolean
      loading: boolean
      loadingColor: string
      immediateChange: boolean
      rules: FormItemRule[]
      useLabelSlot: boolean
      useDefaultSlot: boolean
      alignRight: boolean
      ellipsis: boolean
      customViewClass: string
      customLabelClass: string
      customValueClass: string
      columns: (string | number | ColumnItem | (string | number | ColumnItem)[])[]
      columnsHeight: number
      valueKey: string
      labelKey: string
    },
    {}
  >,
  {
    default?(_: {}): any
    label?(_: {}): any
  }
>
export default _default
type __VLS_WithTemplateSlots<T, S> = T & {
  new (): {
    $slots: S
  }
}
