-
Notifications
You must be signed in to change notification settings - Fork 138
/
useRangePanelState.ts
84 lines (69 loc) 路 2.44 KB
/
useRangePanelState.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
/**
* @license
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://github.com/IDuxFE/idux/blob/main/LICENSE
*/
import type { DateRangePanelProps } from '../types'
import type { DateConfig } from '@idux/components/config'
import { type ComputedRef, computed, watch } from 'vue'
import { callEmit, convertArray, useState } from '@idux/cdk/utils'
import { adjustRangeValue, sortRangeValue } from '@idux/components/utils'
import { convertPickerTypeToConfigType } from '../utils'
export interface RangePanelStateContext {
panelValue: ComputedRef<(Date | undefined)[] | undefined>
isSelecting: ComputedRef<boolean>
handleChange: (value: Date[] | undefined) => void
handleDatePanelCellClick: (value: Date) => void
handleDatePanelCellMouseenter: (value: Date) => void
}
export function useRangePanelState(props: DateRangePanelProps, dateConfig: DateConfig): RangePanelStateContext {
const [selectingDates, setSelectingDates] = useState<(Date | undefined)[] | undefined>(props.value)
const [isSelecting, setIsSelecting] = useState<boolean>(false)
watch(
() => props.visible,
visible => {
setIsSelecting(false)
if (!visible) {
callEmit(props.onSelect, props.value)
}
},
)
const panelValue = computed(() => {
if (isSelecting.value) {
return sortRangeValue(dateConfig, [...convertArray(selectingDates.value)], 'date')
}
return convertArray(props.value)
})
const handleChange = (value: Date[] | undefined) => {
callEmit(props.onChange, value)
callEmit(props.onSelect, value)
}
const handleDatePanelCellClick = (value: Date) => {
if (!isSelecting.value) {
setIsSelecting(true)
setSelectingDates([value, undefined])
callEmit(props.onSelect, [value, undefined])
} else {
const propsValue = convertArray(props.value)
const sortedValue = sortRangeValue(dateConfig, [selectingDates.value![0], value], 'date') as Date[]
handleChange(
adjustRangeValue(dateConfig, sortedValue, propsValue, convertPickerTypeToConfigType(props.type)) as Date[],
)
setIsSelecting(false)
}
}
const handleDatePanelCellMouseenter = (value: Date) => {
if (!isSelecting.value) {
return
}
setSelectingDates([selectingDates.value?.[0], value])
}
return {
panelValue,
isSelecting,
handleChange,
handleDatePanelCellClick,
handleDatePanelCellMouseenter,
}
}