import { type FormItemRule } from '../wd-form/types'
declare const _default: __VLS_WithTemplateSlots<
  import('vue').DefineComponent<
    {
      label: StringConstructor
      labelWidth: {
        type: import('vue').PropType<string>
        default: string
      }
      disabled: {
        type: BooleanConstructor
        default: boolean
      }
      readonly: BooleanConstructor
      placeholder: StringConstructor
      title: StringConstructor
      alignRight: {
        type: BooleanConstructor
        default: boolean
      }
      error: {
        type: BooleanConstructor
        default: boolean
      }
      required: {
        type: BooleanConstructor
        default: boolean
      }
      useLabelSlot: {
        type: BooleanConstructor
        default: boolean
      }
      useDefaultSlot: {
        type: BooleanConstructor
        default: boolean
      }
      size: StringConstructor
      checkedColor: StringConstructor
      min: {
        type: NumberConstructor
        default: number
      }
      max: {
        type: NumberConstructor
        default: number
      }
      selectSize: StringConstructor
      loading: {
        type: BooleanConstructor
        default: boolean
      }
      loadingColor: {
        type: import('vue').PropType<string>
        default: string
      }
      closeOnClickModal: {
        type: BooleanConstructor
        default: boolean
      }
      modelValue: {
        type: import('vue').PropType<string | number | boolean | (string | number | boolean)[]>
        required: true
      }
      columns: {
        type: import('vue').PropType<Record<string, any>[]>
        default: () => never[]
      }
      type: {
        type: import('vue').PropType<import('./types').SelectPickerType>
        default: import('./types').SelectPickerType
      }
      valueKey: {
        type: import('vue').PropType<string>
        default: string
      }
      labelKey: {
        type: import('vue').PropType<string>
        default: string
      }
      confirmButtonText: StringConstructor
      displayFormat: import('vue').PropType<import('./types').SelectPickerDisplayFormat>
      beforeConfirm: import('vue').PropType<import('./types').SelectPickerBeforeConfirm>
      zIndex: {
        type: NumberConstructor
        default: number
      }
      safeAreaInsetBottom: {
        type: BooleanConstructor
        default: boolean
      }
      filterable: {
        type: BooleanConstructor
        default: boolean
      }
      remoteConfig: {
        type: import('vue').PropType<import('./types').SelectPickerRemote>
      }
      filterPlaceholder: StringConstructor
      ellipsis: {
        type: BooleanConstructor
        default: boolean
      }
      scrollIntoView: {
        type: BooleanConstructor
        default: boolean
      }
      prop: StringConstructor
      rules: {
        type: import('vue').PropType<FormItemRule[]>
        default: () => never[]
      }
      customContentClass: {
        type: import('vue').PropType<string>
        default: string
      }
      customLabelClass: {
        type: import('vue').PropType<string>
        default: string
      }
      customValueClass: {
        type: import('vue').PropType<string>
        default: string
      }
      showConfirm: {
        type: BooleanConstructor
        default: boolean
      }
      defaultLabel: StringConstructor
      customStyle: {
        type: import('vue').PropType<string>
        default: string
      }
      customClass: {
        type: import('vue').PropType<string>
        default: string
      }
    },
    {
      open: () => void
      close: () => void
    },
    unknown,
    {},
    {},
    import('vue').ComponentOptionsMixin,
    import('vue').ComponentOptionsMixin,
    {
      cancel: (...args: any[]) => void
      close: (...args: any[]) => void
      open: (...args: any[]) => void
      'update:modelValue': (...args: any[]) => void
      change: (...args: any[]) => void
      confirm: (...args: any[]) => void
    },
    string,
    import('vue').PublicProps,
    Readonly<
      import('vue').ExtractPropTypes<{
        label: StringConstructor
        labelWidth: {
          type: import('vue').PropType<string>
          default: string
        }
        disabled: {
          type: BooleanConstructor
          default: boolean
        }
        readonly: BooleanConstructor
        placeholder: StringConstructor
        title: StringConstructor
        alignRight: {
          type: BooleanConstructor
          default: boolean
        }
        error: {
          type: BooleanConstructor
          default: boolean
        }
        required: {
          type: BooleanConstructor
          default: boolean
        }
        useLabelSlot: {
          type: BooleanConstructor
          default: boolean
        }
        useDefaultSlot: {
          type: BooleanConstructor
          default: boolean
        }
        size: StringConstructor
        checkedColor: StringConstructor
        min: {
          type: NumberConstructor
          default: number
        }
        max: {
          type: NumberConstructor
          default: number
        }
        selectSize: StringConstructor
        loading: {
          type: BooleanConstructor
          default: boolean
        }
        loadingColor: {
          type: import('vue').PropType<string>
          default: string
        }
        closeOnClickModal: {
          type: BooleanConstructor
          default: boolean
        }
        modelValue: {
          type: import('vue').PropType<string | number | boolean | (string | number | boolean)[]>
          required: true
        }
        columns: {
          type: import('vue').PropType<Record<string, any>[]>
          default: () => never[]
        }
        type: {
          type: import('vue').PropType<import('./types').SelectPickerType>
          default: import('./types').SelectPickerType
        }
        valueKey: {
          type: import('vue').PropType<string>
          default: string
        }
        labelKey: {
          type: import('vue').PropType<string>
          default: string
        }
        confirmButtonText: StringConstructor
        displayFormat: import('vue').PropType<import('./types').SelectPickerDisplayFormat>
        beforeConfirm: import('vue').PropType<import('./types').SelectPickerBeforeConfirm>
        zIndex: {
          type: NumberConstructor
          default: number
        }
        safeAreaInsetBottom: {
          type: BooleanConstructor
          default: boolean
        }
        filterable: {
          type: BooleanConstructor
          default: boolean
        }
        remoteConfig: {
          type: import('vue').PropType<import('./types').SelectPickerRemote>
        }
        filterPlaceholder: StringConstructor
        ellipsis: {
          type: BooleanConstructor
          default: boolean
        }
        scrollIntoView: {
          type: BooleanConstructor
          default: boolean
        }
        prop: StringConstructor
        rules: {
          type: import('vue').PropType<FormItemRule[]>
          default: () => never[]
        }
        customContentClass: {
          type: import('vue').PropType<string>
          default: string
        }
        customLabelClass: {
          type: import('vue').PropType<string>
          default: string
        }
        customValueClass: {
          type: import('vue').PropType<string>
          default: string
        }
        showConfirm: {
          type: BooleanConstructor
          default: boolean
        }
        defaultLabel: StringConstructor
        customStyle: {
          type: import('vue').PropType<string>
          default: string
        }
        customClass: {
          type: import('vue').PropType<string>
          default: string
        }
      }>
    > & {
      onCancel?: ((...args: any[]) => any) | undefined
      onClose?: ((...args: any[]) => any) | undefined
      onOpen?: ((...args: any[]) => any) | undefined
      'onUpdate:modelValue'?: ((...args: any[]) => any) | undefined
      onChange?: ((...args: any[]) => any) | undefined
      onConfirm?: ((...args: any[]) => any) | undefined
    },
    {
      closeOnClickModal: boolean
      zIndex: number
      safeAreaInsetBottom: boolean
      customStyle: string
      customClass: string
      readonly: boolean
      type: import('./types').SelectPickerType
      required: boolean
      max: number
      error: boolean
      disabled: boolean
      loading: boolean
      loadingColor: string
      scrollIntoView: boolean
      rules: FormItemRule[]
      labelWidth: string
      useLabelSlot: boolean
      useDefaultSlot: boolean
      alignRight: boolean
      showConfirm: boolean
      ellipsis: boolean
      customLabelClass: string
      customValueClass: string
      columns: Record<string, any>[]
      customContentClass: string
      min: number
      valueKey: string
      labelKey: string
      filterable: boolean
    },
    {}
  >,
  {
    default?(_: {}): any
    label?(_: {}): any
  }
>
export default _default
type __VLS_WithTemplateSlots<T, S> = T & {
  new (): {
    $slots: S
  }
}
