@lark-project/ui-kit-plugin
Version:
Lark Project UI Kit Plugin
42 lines (41 loc) • 1.95 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 type { IDateTriggerProps } from '../../trigger';
export type DateValue = Date | string | number | undefined;
export type PresetItem = {
text?: string;
start?: Date;
end?: Date;
};
export interface IDatePickerProps extends Pick<IDateTriggerProps, 'className' | 'style' | 'showClear' | 'disabled' | 'inputReadOnly' | 'onClear' | 'placeholder'> {
showTime?: boolean;
format?: string;
presets?: PresetItem[];
weekStartsOn?: number;
defaultValue?: DateValue;
value?: DateValue;
onChange?: (date: Date | undefined, dateStr: string | undefined) => void;
onPresetClick?: (preset: PresetItem) => void;
onFocus?: () => void;
onBlur?: () => void;
disabledDate?: (date: Date) => boolean;
}
export interface IDatePickerContext extends Pick<IDatePickerProps, 'format' | 'weekStartsOn' | 'presets' | 'inputReadOnly'> {
type: 'date' | 'dateTime' | 'month';
triggerValue: string;
setTriggerValue: (value: string) => void;
handleDisabledDate: (timestamp: number) => boolean;
handlePresetClick: (item: PresetItem) => void;
closePanel: () => void;
}