UNPKG

element-plus

Version:

A Component Library for Vue 3

63 lines (61 loc) 2.45 kB
Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); const require_runtime = require('../../../../_virtual/_rolldown/runtime.js'); const require_utils = require('../utils.js'); let vue = require("vue"); //#region ../../packages/components/time-picker/src/composables/use-time-picker.ts const makeAvailableArr = (disabledList) => { const trueOrNumber = (isDisabled, index) => isDisabled || index; const getNumber = (predicate) => predicate !== true; return disabledList.map(trueOrNumber).filter(getNumber); }; const getTimeLists = (disabledHours, disabledMinutes, disabledSeconds) => { const getHoursList = (role, compare) => { return require_utils.makeList(24, disabledHours && (() => disabledHours?.(role, compare))); }; const getMinutesList = (hour, role, compare) => { return require_utils.makeList(60, disabledMinutes && (() => disabledMinutes?.(hour, role, compare))); }; const getSecondsList = (hour, minute, role, compare) => { return require_utils.makeList(60, disabledSeconds && (() => disabledSeconds?.(hour, minute, role, compare))); }; return { getHoursList, getMinutesList, getSecondsList }; }; const buildAvailableTimeSlotGetter = (disabledHours, disabledMinutes, disabledSeconds) => { const { getHoursList, getMinutesList, getSecondsList } = getTimeLists(disabledHours, disabledMinutes, disabledSeconds); const getAvailableHours = (role, compare) => { return makeAvailableArr(getHoursList(role, compare)); }; const getAvailableMinutes = (hour, role, compare) => { return makeAvailableArr(getMinutesList(hour, role, compare)); }; const getAvailableSeconds = (hour, minute, role, compare) => { return makeAvailableArr(getSecondsList(hour, minute, role, compare)); }; return { getAvailableHours, getAvailableMinutes, getAvailableSeconds }; }; const useOldValue = (props, options) => { const oldValue = (0, vue.ref)(props.parsedValue); (0, vue.watch)(() => props.visible, (val) => { const modelValue = (0, vue.toValue)(options.modelValue); const valueOnClear = (0, vue.toValue)(options.valueOnClear); if (val && modelValue === valueOnClear) { oldValue.value = valueOnClear; return; } if (!val) oldValue.value = props.parsedValue; }); return oldValue; }; //#endregion exports.buildAvailableTimeSlotGetter = buildAvailableTimeSlotGetter; exports.getTimeLists = getTimeLists; exports.useOldValue = useOldValue; //# sourceMappingURL=use-time-picker.js.map