86 lines
2.3 KiB
Vue
86 lines
2.3 KiB
Vue
import YearHeader from './YearHeader';
|
|
import YearBody, { YEAR_COL_COUNT } from './YearBody';
|
|
import type { PanelSharedProps, PanelMode } from '../../interface';
|
|
import { createKeydownHandler } from '../../utils/uiUtil';
|
|
import useMergeProps from '../../hooks/useMergeProps';
|
|
|
|
export type YearPanelProps<DateType> = {
|
|
sourceMode: PanelMode;
|
|
} & PanelSharedProps<DateType>;
|
|
|
|
export const YEAR_DECADE_COUNT = 10;
|
|
|
|
function YearPanel<DateType>(_props: YearPanelProps<DateType>) {
|
|
const props = useMergeProps(_props);
|
|
const {
|
|
prefixCls,
|
|
operationRef,
|
|
onViewDateChange,
|
|
generateConfig,
|
|
value,
|
|
viewDate,
|
|
sourceMode,
|
|
onSelect,
|
|
onPanelChange,
|
|
} = props;
|
|
|
|
const panelPrefixCls = `${prefixCls}-year-panel`;
|
|
|
|
// ======================= Keyboard =======================
|
|
operationRef.value = {
|
|
onKeydown: (event: KeyboardEvent) =>
|
|
createKeydownHandler(event, {
|
|
onLeftRight: diff => {
|
|
onSelect(generateConfig.addYear(value || viewDate, diff), 'key');
|
|
},
|
|
onCtrlLeftRight: diff => {
|
|
onSelect(generateConfig.addYear(value || viewDate, diff * YEAR_DECADE_COUNT), 'key');
|
|
},
|
|
onUpDown: diff => {
|
|
onSelect(generateConfig.addYear(value || viewDate, diff * YEAR_COL_COUNT), 'key');
|
|
},
|
|
onEnter: () => {
|
|
onPanelChange(sourceMode === 'date' ? 'date' : 'month', value || viewDate);
|
|
},
|
|
}),
|
|
};
|
|
|
|
// ==================== View Operation ====================
|
|
const onDecadeChange = (diff: number) => {
|
|
const newDate = generateConfig.addYear(viewDate, diff * 10);
|
|
onViewDateChange(newDate);
|
|
onPanelChange(null, newDate);
|
|
};
|
|
|
|
return (
|
|
<div class={panelPrefixCls}>
|
|
<YearHeader
|
|
{...props}
|
|
prefixCls={prefixCls}
|
|
onPrevDecade={() => {
|
|
onDecadeChange(-1);
|
|
}}
|
|
onNextDecade={() => {
|
|
onDecadeChange(1);
|
|
}}
|
|
onDecadeClick={() => {
|
|
onPanelChange('decade', viewDate);
|
|
}}
|
|
/>
|
|
<YearBody
|
|
{...props}
|
|
prefixCls={prefixCls}
|
|
onSelect={date => {
|
|
onPanelChange(sourceMode === 'date' ? 'date' : 'month', date);
|
|
onSelect(date, 'mouse');
|
|
}}
|
|
/>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
YearPanel.displayName = 'YearPanel';
|
|
YearPanel.inheritAttrs = false;
|
|
|
|
export default YearPanel;
|