@lark-project/ui-kit-plugin
Version:
Lark Project UI Kit Plugin
41 lines (40 loc) • 1.81 kB
TypeScript
/**
* 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 {};