import { TdSwitchProps } from './type';
import './style';
export * from './type';
export declare type SwitchProps = TdSwitchProps;
export declare const Switch: {
    new (...args: any[]): {
        $: import("vue").ComponentInternalInstance;
        $data: {};
        $props: {
            value?: import("./type").SwitchValue;
            loading?: boolean;
            label?: (string | ((h: typeof import("vue").h) => import("..").SlotReturnValue))[] | ((h: typeof import("vue").h, props: {
                value: import("./type").SwitchValue;
            }) => import("..").SlotReturnValue);
            disabled?: boolean;
            size?: "small" | "medium" | "large";
            modelValue?: import("./type").SwitchValue;
            key?: string | number | symbol;
            style?: unknown;
            readonly onChange?: (value: import("./type").SwitchValue, context: {
                e: MouseEvent;
            }) => void;
            class?: unknown;
            ref?: import("vue").VNodeRef;
            ref_for?: boolean;
            ref_key?: string;
            readonly defaultValue?: import("./type").SwitchValue;
            onVnodeBeforeMount?: ((vnode: import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
                [key: string]: any;
            }>) => void) | ((vnode: import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
                [key: string]: any;
            }>) => void)[];
            onVnodeMounted?: ((vnode: import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
                [key: string]: any;
            }>) => void) | ((vnode: import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
                [key: string]: any;
            }>) => void)[];
            onVnodeBeforeUpdate?: ((vnode: import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
                [key: string]: any;
            }>, oldVNode: import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
                [key: string]: any;
            }>) => void) | ((vnode: import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
                [key: string]: any;
            }>, oldVNode: import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
                [key: string]: any;
            }>) => void)[];
            onVnodeUpdated?: ((vnode: import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
                [key: string]: any;
            }>, oldVNode: import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
                [key: string]: any;
            }>) => void) | ((vnode: import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
                [key: string]: any;
            }>, oldVNode: import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
                [key: string]: any;
            }>) => void)[];
            onVnodeBeforeUnmount?: ((vnode: import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
                [key: string]: any;
            }>) => void) | ((vnode: import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
                [key: string]: any;
            }>) => void)[];
            onVnodeUnmounted?: ((vnode: import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
                [key: string]: any;
            }>) => void) | ((vnode: import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
                [key: string]: any;
            }>) => void)[];
            readonly customValue?: import("./type").SwitchValue[];
        };
        $attrs: {
            [x: string]: unknown;
        };
        $refs: {
            [x: string]: unknown;
        };
        $slots: Readonly<{
            [name: string]: import("vue").Slot<any>;
        }>;
        $root: import("vue").ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, import("vue").ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string, {}>, {}, {}>;
        $parent: import("vue").ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, import("vue").ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string, {}>, {}, {}>;
        $emit: (event: string, ...args: any[]) => void;
        $el: any;
        $options: import("vue").ComponentOptionsBase<Readonly<import("vue").ExtractPropTypes<{
            customValue: {
                type: import("vue").PropType<import("./type").SwitchValue[]>;
            };
            disabled: {
                type: BooleanConstructor;
                default: any;
            };
            label: {
                type: import("vue").PropType<(string | ((h: typeof import("vue").h) => import("..").SlotReturnValue))[] | ((h: typeof import("vue").h, props: {
                    value: import("./type").SwitchValue;
                }) => import("..").SlotReturnValue)>;
                default: () => (string | ((h: typeof import("vue").h) => import("..").SlotReturnValue))[] | ((h: typeof import("vue").h, props: {
                    value: import("./type").SwitchValue;
                }) => import("..").SlotReturnValue);
            };
            loading: BooleanConstructor;
            size: {
                type: import("vue").PropType<"small" | "medium" | "large">;
                default: "small" | "medium" | "large";
                validator(val: "small" | "medium" | "large"): boolean;
            };
            value: {
                type: import("vue").PropType<import("./type").SwitchValue>;
                default: import("./type").SwitchValue;
            };
            modelValue: {
                type: import("vue").PropType<import("./type").SwitchValue>;
                default: import("./type").SwitchValue;
            };
            defaultValue: {
                type: import("vue").PropType<import("./type").SwitchValue>;
            };
            onChange: import("vue").PropType<(value: import("./type").SwitchValue, context: {
                e: MouseEvent;
            }) => void>;
        }>>, () => JSX.Element, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, {
            value: import("./type").SwitchValue;
            loading: boolean;
            label: (string | ((h: typeof import("vue").h) => import("..").SlotReturnValue))[] | ((h: typeof import("vue").h, props: {
                value: import("./type").SwitchValue;
            }) => import("..").SlotReturnValue);
            disabled: boolean;
            size: "small" | "medium" | "large";
            modelValue: import("./type").SwitchValue;
        }, {}, string, {}> & {
            beforeCreate?: (() => void) | (() => void)[];
            created?: (() => void) | (() => void)[];
            beforeMount?: (() => void) | (() => void)[];
            mounted?: (() => void) | (() => void)[];
            beforeUpdate?: (() => void) | (() => void)[];
            updated?: (() => void) | (() => void)[];
            activated?: (() => void) | (() => void)[];
            deactivated?: (() => void) | (() => void)[];
            beforeDestroy?: (() => void) | (() => void)[];
            beforeUnmount?: (() => void) | (() => void)[];
            destroyed?: (() => void) | (() => void)[];
            unmounted?: (() => void) | (() => void)[];
            renderTracked?: ((e: import("vue").DebuggerEvent) => void) | ((e: import("vue").DebuggerEvent) => void)[];
            renderTriggered?: ((e: import("vue").DebuggerEvent) => void) | ((e: import("vue").DebuggerEvent) => void)[];
            errorCaptured?: ((err: unknown, instance: import("vue").ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, import("vue").ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string, {}>, {}, {}>, info: string) => boolean | void) | ((err: unknown, instance: import("vue").ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, import("vue").ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string, {}>, {}, {}>, info: string) => boolean | void)[];
        };
        $forceUpdate: () => void;
        $nextTick: typeof import("vue").nextTick;
        $watch<T extends string | ((...args: any) => any)>(source: T, cb: T extends (...args: any) => infer R ? (args_0: R, args_1: R) => any : (...args: any) => any, options?: import("vue").WatchOptions<boolean>): import("vue").WatchStopHandle;
    } & Readonly<import("vue").ExtractPropTypes<{
        customValue: {
            type: import("vue").PropType<import("./type").SwitchValue[]>;
        };
        disabled: {
            type: BooleanConstructor;
            default: any;
        };
        label: {
            type: import("vue").PropType<(string | ((h: typeof import("vue").h) => import("..").SlotReturnValue))[] | ((h: typeof import("vue").h, props: {
                value: import("./type").SwitchValue;
            }) => import("..").SlotReturnValue)>;
            default: () => (string | ((h: typeof import("vue").h) => import("..").SlotReturnValue))[] | ((h: typeof import("vue").h, props: {
                value: import("./type").SwitchValue;
            }) => import("..").SlotReturnValue);
        };
        loading: BooleanConstructor;
        size: {
            type: import("vue").PropType<"small" | "medium" | "large">;
            default: "small" | "medium" | "large";
            validator(val: "small" | "medium" | "large"): boolean;
        };
        value: {
            type: import("vue").PropType<import("./type").SwitchValue>;
            default: import("./type").SwitchValue;
        };
        modelValue: {
            type: import("vue").PropType<import("./type").SwitchValue>;
            default: import("./type").SwitchValue;
        };
        defaultValue: {
            type: import("vue").PropType<import("./type").SwitchValue>;
        };
        onChange: import("vue").PropType<(value: import("./type").SwitchValue, context: {
            e: MouseEvent;
        }) => void>;
    }>> & import("vue").ShallowUnwrapRef<() => JSX.Element> & {} & import("vue").ComponentCustomProperties & {};
    __isFragment?: never;
    __isTeleport?: never;
    __isSuspense?: never;
} & import("vue").ComponentOptionsBase<Readonly<import("vue").ExtractPropTypes<{
    customValue: {
        type: import("vue").PropType<import("./type").SwitchValue[]>;
    };
    disabled: {
        type: BooleanConstructor;
        default: any;
    };
    label: {
        type: import("vue").PropType<(string | ((h: typeof import("vue").h) => import("..").SlotReturnValue))[] | ((h: typeof import("vue").h, props: {
            value: import("./type").SwitchValue;
        }) => import("..").SlotReturnValue)>;
        default: () => (string | ((h: typeof import("vue").h) => import("..").SlotReturnValue))[] | ((h: typeof import("vue").h, props: {
            value: import("./type").SwitchValue;
        }) => import("..").SlotReturnValue);
    };
    loading: BooleanConstructor;
    size: {
        type: import("vue").PropType<"small" | "medium" | "large">;
        default: "small" | "medium" | "large";
        validator(val: "small" | "medium" | "large"): boolean;
    };
    value: {
        type: import("vue").PropType<import("./type").SwitchValue>;
        default: import("./type").SwitchValue;
    };
    modelValue: {
        type: import("vue").PropType<import("./type").SwitchValue>;
        default: import("./type").SwitchValue;
    };
    defaultValue: {
        type: import("vue").PropType<import("./type").SwitchValue>;
    };
    onChange: import("vue").PropType<(value: import("./type").SwitchValue, context: {
        e: MouseEvent;
    }) => void>;
}>>, () => JSX.Element, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, {
    value: import("./type").SwitchValue;
    loading: boolean;
    label: (string | ((h: typeof import("vue").h) => import("..").SlotReturnValue))[] | ((h: typeof import("vue").h, props: {
        value: import("./type").SwitchValue;
    }) => import("..").SlotReturnValue);
    disabled: boolean;
    size: "small" | "medium" | "large";
    modelValue: import("./type").SwitchValue;
}, {}, string, {}> & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps & import("vue").Plugin<any[]>;
export default Switch;
