import { IconValue } from '../../composables/icons.js'; import type { InjectionKey, PropType } from 'vue'; import type { GroupProvide } from '../../composables/group.js'; import type { GenericProps } from '../../util/index.js'; export declare const VSlideGroupSymbol: InjectionKey; interface SlideGroupSlot { next: GroupProvide['next']; prev: GroupProvide['prev']; select: GroupProvide['select']; isSelected: GroupProvide['isSelected']; } export type VSlideGroupSlots = { default: SlideGroupSlot; prev: SlideGroupSlot; next: SlideGroupSlot; }; export declare const makeVSlideGroupProps: (defaults?: Defaults | undefined) => { class: unknown extends Defaults["class"] ? PropType : { type: PropType; default: unknown extends Defaults["class"] ? any : any; }; style: unknown extends Defaults["style"] ? { type: PropType; default: null; } : Omit<{ type: PropType; default: null; }, "default" | "type"> & { type: PropType; default: unknown extends Defaults["style"] ? import("vue").StyleValue : Defaults["style"] | NonNullable; }; mobile: unknown extends Defaults["mobile"] ? Omit<{ type: PropType; default: boolean; }, "default" | "type"> & { type: PropType; default: NonNullable | null; } : Omit; default: boolean; }, "default" | "type"> & { type: PropType; default: NonNullable | null; }, "default" | "type"> & { type: PropType; default: unknown extends Defaults["mobile"] ? boolean | null : Defaults["mobile"] | NonNullable; }; mobileBreakpoint: unknown extends Defaults["mobileBreakpoint"] ? PropType : { type: PropType; default: unknown extends Defaults["mobileBreakpoint"] ? number | import("../../types.js").DisplayBreakpoint : Defaults["mobileBreakpoint"] | NonNullable; }; tag: unknown extends Defaults["tag"] ? { type: PropType; default: string; } : Omit<{ type: PropType; default: string; }, "default" | "type"> & { type: PropType; default: unknown extends Defaults["tag"] ? string | import("../../util/index.js").JSXComponent : Defaults["tag"] | NonNullable; }; modelValue: unknown extends Defaults["modelValue"] ? { type: null; default: undefined; } : Omit<{ type: null; default: undefined; }, "default" | "type"> & { type: PropType; default: unknown extends Defaults["modelValue"] ? any : any; }; multiple: unknown extends Defaults["multiple"] ? BooleanConstructor : { type: PropType; default: unknown extends Defaults["multiple"] ? boolean : boolean | Defaults["multiple"]; }; mandatory: unknown extends Defaults["mandatory"] ? PropType<"force" | boolean> : { type: PropType; default: unknown extends Defaults["mandatory"] ? "force" | boolean : Defaults["mandatory"] | NonNullable<"force" | boolean>; }; max: unknown extends Defaults["max"] ? NumberConstructor : { type: PropType; default: unknown extends Defaults["max"] ? number : number | Defaults["max"]; }; selectedClass: unknown extends Defaults["selectedClass"] ? { type: PropType; default: string; } : Omit<{ type: PropType; default: string; }, "default" | "type"> & { type: PropType; default: unknown extends Defaults["selectedClass"] ? string : string | Defaults["selectedClass"]; }; disabled: unknown extends Defaults["disabled"] ? BooleanConstructor : { type: PropType; default: unknown extends Defaults["disabled"] ? boolean : boolean | Defaults["disabled"]; }; centerActive: unknown extends Defaults["centerActive"] ? BooleanConstructor : { type: PropType; default: unknown extends Defaults["centerActive"] ? boolean : boolean | Defaults["centerActive"]; }; scrollToActive: unknown extends Defaults["scrollToActive"] ? { type: BooleanConstructor; default: boolean; } : Omit<{ type: BooleanConstructor; default: boolean; }, "default" | "type"> & { type: PropType; default: unknown extends Defaults["scrollToActive"] ? boolean : boolean | Defaults["scrollToActive"]; }; contentClass: unknown extends Defaults["contentClass"] ? null : { type: PropType; default: unknown extends Defaults["contentClass"] ? any : any; }; direction: unknown extends Defaults["direction"] ? { type: PropType<'horizontal' | 'vertical'>; default: string; } : Omit<{ type: PropType<'horizontal' | 'vertical'>; default: string; }, "default" | "type"> & { type: PropType; default: unknown extends Defaults["direction"] ? "horizontal" | "vertical" : Defaults["direction"] | NonNullable<"horizontal" | "vertical">; }; symbol: unknown extends Defaults["symbol"] ? { type: null; default: InjectionKey; } : Omit<{ type: null; default: InjectionKey; }, "default" | "type"> & { type: PropType; default: unknown extends Defaults["symbol"] ? any : any; }; nextIcon: unknown extends Defaults["nextIcon"] ? { type: PropType; default: string; } : Omit<{ type: PropType; default: string; }, "default" | "type"> & { type: PropType; default: unknown extends Defaults["nextIcon"] ? IconValue : Defaults["nextIcon"] | NonNullable; }; prevIcon: unknown extends Defaults["prevIcon"] ? { type: PropType; default: string; } : Omit<{ type: PropType; default: string; }, "default" | "type"> & { type: PropType; default: unknown extends Defaults["prevIcon"] ? IconValue : Defaults["prevIcon"] | NonNullable; }; showArrows: unknown extends Defaults["showArrows"] ? { type: (BooleanConstructor | StringConstructor)[]; validator: (v: any) => boolean; } : Omit<{ type: (BooleanConstructor | StringConstructor)[]; validator: (v: any) => boolean; }, "default" | "type"> & { type: PropType; default: unknown extends Defaults["showArrows"] ? string | boolean : Defaults["showArrows"] | NonNullable; }; }; export declare const VSlideGroup: { new (...args: any[]): import("vue").CreateComponentPublicInstanceWithMixins<{ style: string | false | import("vue").StyleValue[] | import("vue").CSSProperties | null; mobile: boolean | null; tag: string | import("../../util/index.js").JSXComponent; multiple: boolean; selectedClass: string; disabled: boolean; centerActive: boolean; scrollToActive: boolean; direction: "horizontal" | "vertical"; symbol: any; nextIcon: IconValue; prevIcon: IconValue; } & { class?: any; mobileBreakpoint?: number | import("../../types.js").DisplayBreakpoint | undefined; mandatory?: "force" | boolean | undefined; max?: number | undefined; contentClass?: any; showArrows?: string | boolean | undefined; } & {}, { selected: import("vue").Ref; scrollTo: (location: 'prev' | 'next') => void; scrollOffset: import("vue").ShallowRef; focus: (location?: 'next' | 'prev' | 'first' | 'last') => void; hasPrev: import("vue").ComputedRef; hasNext: import("vue").ComputedRef; }, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, Omit<{ 'update:modelValue': (value: any) => true; }, "$children" | "modelValue" | "update:modelValue" | "v-slot:default" | "v-slot:next" | "v-slot:prev" | "v-slots">, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, { style: import("vue").StyleValue; mobile: boolean | null; tag: string | import("../../util/index.js").JSXComponent; multiple: boolean; selectedClass: string; disabled: boolean; centerActive: boolean; scrollToActive: boolean; direction: "horizontal" | "vertical"; symbol: any; nextIcon: IconValue; prevIcon: IconValue; }, true, {}, import("vue").SlotsType import("vue").VNode[]; prev: (arg: SlideGroupSlot) => import("vue").VNode[]; next: (arg: SlideGroupSlot) => import("vue").VNode[]; }>>, import("vue").GlobalComponents, import("vue").GlobalDirectives, string, {}, any, import("vue").ComponentProvideOptions, { P: {}; B: {}; D: {}; C: {}; M: {}; Defaults: {}; }, { style: string | false | import("vue").StyleValue[] | import("vue").CSSProperties | null; mobile: boolean | null; tag: string | import("../../util/index.js").JSXComponent; multiple: boolean; selectedClass: string; disabled: boolean; centerActive: boolean; scrollToActive: boolean; direction: "horizontal" | "vertical"; symbol: any; nextIcon: IconValue; prevIcon: IconValue; } & { class?: any; mobileBreakpoint?: number | import("../../types.js").DisplayBreakpoint | undefined; mandatory?: "force" | boolean | undefined; max?: number | undefined; contentClass?: any; showArrows?: string | boolean | undefined; } & {}, { selected: import("vue").Ref; scrollTo: (location: 'prev' | 'next') => void; scrollOffset: import("vue").ShallowRef; focus: (location?: 'next' | 'prev' | 'first' | 'last') => void; hasPrev: import("vue").ComputedRef; hasNext: import("vue").ComputedRef; }, {}, {}, {}, { style: import("vue").StyleValue; mobile: boolean | null; tag: string | import("../../util/index.js").JSXComponent; multiple: boolean; selectedClass: string; disabled: boolean; centerActive: boolean; scrollToActive: boolean; direction: "horizontal" | "vertical"; symbol: any; nextIcon: IconValue; prevIcon: IconValue; }>; __isFragment?: never; __isTeleport?: never; __isSuspense?: never; } & import("vue").ComponentOptionsBase<{ style: string | false | import("vue").StyleValue[] | import("vue").CSSProperties | null; mobile: boolean | null; tag: string | import("../../util/index.js").JSXComponent; multiple: boolean; selectedClass: string; disabled: boolean; centerActive: boolean; scrollToActive: boolean; direction: "horizontal" | "vertical"; symbol: any; nextIcon: IconValue; prevIcon: IconValue; } & { class?: any; mobileBreakpoint?: number | import("../../types.js").DisplayBreakpoint | undefined; mandatory?: "force" | boolean | undefined; max?: number | undefined; contentClass?: any; showArrows?: string | boolean | undefined; } & {}, { selected: import("vue").Ref; scrollTo: (location: 'prev' | 'next') => void; scrollOffset: import("vue").ShallowRef; focus: (location?: 'next' | 'prev' | 'first' | 'last') => void; hasPrev: import("vue").ComputedRef; hasNext: import("vue").ComputedRef; }, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, Omit<{ 'update:modelValue': (value: any) => true; }, "$children" | "modelValue" | "update:modelValue" | "v-slot:default" | "v-slot:next" | "v-slot:prev" | "v-slots">, string, { style: import("vue").StyleValue; mobile: boolean | null; tag: string | import("../../util/index.js").JSXComponent; multiple: boolean; selectedClass: string; disabled: boolean; centerActive: boolean; scrollToActive: boolean; direction: "horizontal" | "vertical"; symbol: any; nextIcon: IconValue; prevIcon: IconValue; }, {}, string, import("vue").SlotsType import("vue").VNode[]; prev: (arg: SlideGroupSlot) => import("vue").VNode[]; next: (arg: SlideGroupSlot) => import("vue").VNode[]; }>>, import("vue").GlobalComponents, import("vue").GlobalDirectives, string, import("vue").ComponentProvideOptions> & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps & (new (props: { modelValue?: T; 'onUpdate:modelValue'?: (value: T) => void; }, slots: VSlideGroupSlots) => GenericProps) & import("../../util/index.js").FilterPropsOptions<{ class: PropType; style: { type: PropType; default: null; }; mobile: Omit<{ type: PropType; default: boolean; }, "default" | "type"> & { type: PropType; default: NonNullable | null; }; mobileBreakpoint: PropType; tag: { type: PropType; default: string; }; modelValue: { type: null; default: undefined; }; multiple: BooleanConstructor; mandatory: PropType; max: NumberConstructor; selectedClass: { type: PropType; default: string; }; disabled: BooleanConstructor; centerActive: BooleanConstructor; scrollToActive: { type: BooleanConstructor; default: boolean; }; contentClass: null; direction: { type: PropType<'horizontal' | 'vertical'>; default: string; }; symbol: { type: null; default: InjectionKey; }; nextIcon: { type: PropType; default: string; }; prevIcon: { type: PropType; default: string; }; showArrows: { type: (BooleanConstructor | StringConstructor)[]; validator: (v: any) => boolean; }; }, import("vue").ExtractPropTypes<{ class: PropType; style: { type: PropType; default: null; }; mobile: Omit<{ type: PropType; default: boolean; }, "default" | "type"> & { type: PropType; default: NonNullable | null; }; mobileBreakpoint: PropType; tag: { type: PropType; default: string; }; modelValue: { type: null; default: undefined; }; multiple: BooleanConstructor; mandatory: PropType; max: NumberConstructor; selectedClass: { type: PropType; default: string; }; disabled: BooleanConstructor; centerActive: BooleanConstructor; scrollToActive: { type: BooleanConstructor; default: boolean; }; contentClass: null; direction: { type: PropType<'horizontal' | 'vertical'>; default: string; }; symbol: { type: null; default: InjectionKey; }; nextIcon: { type: PropType; default: string; }; prevIcon: { type: PropType; default: string; }; showArrows: { type: (BooleanConstructor | StringConstructor)[]; validator: (v: any) => boolean; }; }>>; export type VSlideGroup = InstanceType;