import type { VNode } from 'vue'; import type { AppConfig } from '@nuxt/schema'; import theme from '#build/b24ui/dashboard-search'; import type { UseFuseOptions } from '@vueuse/integrations/useFuse'; import type { ButtonProps, ModalProps, CommandPaletteProps, CommandPaletteSlots, CommandPaletteGroup, CommandPaletteItem, LinkPropsKeys } from '../types'; import type { ComponentConfig } from '../types/tv'; type DashboardSearch = ComponentConfig; /** * @memo not use loadingIcon */ export interface DashboardSearchProps extends Pick, Pick, T>, 'icon' | 'placeholder' | 'autofocus' | 'loading' | 'closeIcon' | 'groups'> { /** * @defaultValue 'md' */ size?: DashboardSearch['variants']['size']; /** * Display a close button in the input (useful when inside a Modal for example). * `{ size: 'sm', color: 'air-tertiary-no-accent' }`{lang="ts-type"} * @emits 'update:open' * @defaultValue true */ close?: boolean | Omit; /** * Keyboard shortcut to open the search (used by [`defineShortcuts`](https://bitrix24.github.io/b24ui/docs/composables/define-shortcuts/)) * @defaultValue 'meta_k' */ shortcut?: string; /** * Options for [useFuse](https://vueuse.org/integrations/useFuse) passed to the [CommandPalette](https://bitrix24.github.io/b24ui/docs/components/command-palette/). * @defaultValue { fuseOptions: { ignoreLocation: true, useTokenSearch: true, threshold: 0.1, keys: ['label', 'description', 'suffix'] }, resultLimit: 12, matchAllWhenSearchEmpty: true } */ fuse?: UseFuseOptions; /** * Delay (in milliseconds) before the search term is passed to Fuse (debounced). * Useful for large datasets where running fuzzy search on every keystroke is the bottleneck — the input stays responsive while Fuse only re-runs after typing settles. * Set to `0` to disable. * @defaultValue 100 */ searchDelay?: number; /** * When `true`, the theme command will be added to the groups. * @defaultValue true */ colorMode?: boolean; class?: any; b24ui?: DashboardSearch['slots'] & CommandPaletteProps, CommandPaletteItem>['b24ui']; } export type DashboardSearchSlots = CommandPaletteSlots & { content?(props: { close: () => void; }): VNode; }; declare const _default: typeof __VLS_export; export default _default; declare const __VLS_export: __VLS_WithSlots & { open?: boolean; searchTerm?: string; }, { commandPaletteRef: Readonly>; }, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, { "update:open": (value: boolean) => any; "update:searchTerm": (value: string) => any; }, string, import("vue").PublicProps, Readonly & { open?: boolean; searchTerm?: string; }> & Readonly<{ "onUpdate:open"?: ((value: boolean) => any) | undefined; "onUpdate:searchTerm"?: ((value: string) => any) | undefined; }>, { close: boolean | Omit; colorMode: boolean; searchDelay: number; fullscreen: boolean; shortcut: string; }, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>, DashboardSearchSlots>; type __VLS_WithSlots = T & { new (): { $slots: S; }; };