UNPKG

@lark-project/ui-kit-plugin

Version:

Lark Project UI Kit Plugin

41 lines (40 loc) 1.81 kB
/** * Copyright (c) 2024 Lark Technologies Pte. Ltd. * * Permission to use, copy, modify, and/or distribute this software for any purpose with or without fee is hereby granted,provided that the above copyright notice and this permission notice appear in all copies. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS * IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO * EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS * ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */ import { CSSProperties, ReactNode } from 'react'; import type { ISelectOption } from '../../../../trigger'; interface IOptionProps { value: string; label: string; index?: number; selected?: boolean; } export interface IBaseOptionProps<DATA extends Record<string, any> = Record<string, any>> { children?: (optionProps: IOptionProps) => ReactNode; value?: string[]; focused?: boolean; onSelect?: (value: string, option: ISelectOption<DATA>) => void; } export interface ISelectListProps<DATA extends Record<string, any> = Record<string, any>> extends IBaseOptionProps<DATA> { className?: string; style?: CSSProperties; options?: ISelectOption<DATA>[]; disabledIds?: string[]; /** * 列表元素高亮索引,0位:列表元素,1位:列表元素为分组元素时,分组子元素的高亮索引 */ activeIndex: number[]; setActiveIndex?: (activeIndex: number[]) => void; maxHeight: number; } export {};