| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100 |
- "use strict";
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.default = useRangeViewDates;
- var _miscUtil = require("../utils/miscUtil");
- var _dateUtil = require("../utils/dateUtil");
- var _vue = require("vue");
- function getStartEndDistance(startDate, endDate, picker, generateConfig) {
- var startNext = (0, _dateUtil.getClosingViewDate)(startDate, picker, generateConfig, 1);
- function getDistance(compareFunc) {
- if (compareFunc(startDate, endDate)) {
- return 'same';
- }
- if (compareFunc(startNext, endDate)) {
- return 'closing';
- }
- return 'far';
- }
- switch (picker) {
- case 'year':
- return getDistance(function (start, end) {
- return (0, _dateUtil.isSameDecade)(generateConfig, start, end);
- });
- case 'quarter':
- case 'month':
- return getDistance(function (start, end) {
- return (0, _dateUtil.isSameYear)(generateConfig, start, end);
- });
- default:
- return getDistance(function (start, end) {
- return (0, _dateUtil.isSameMonth)(generateConfig, start, end);
- });
- }
- }
- function getRangeViewDate(values, index, picker, generateConfig) {
- var startDate = (0, _miscUtil.getValue)(values, 0);
- var endDate = (0, _miscUtil.getValue)(values, 1);
- if (index === 0) {
- return startDate;
- }
- if (startDate && endDate) {
- var distance = getStartEndDistance(startDate, endDate, picker, generateConfig);
- switch (distance) {
- case 'same':
- return startDate;
- case 'closing':
- return startDate;
- default:
- return (0, _dateUtil.getClosingViewDate)(endDate, picker, generateConfig, -1);
- }
- }
- return startDate;
- }
- function useRangeViewDates(_ref) {
- var values = _ref.values,
- picker = _ref.picker,
- defaultDates = _ref.defaultDates,
- generateConfig = _ref.generateConfig;
- var defaultViewDates = (0, _vue.ref)([(0, _miscUtil.getValue)(defaultDates, 0), (0, _miscUtil.getValue)(defaultDates, 1)]);
- var viewDates = (0, _vue.ref)(null);
- var startDate = (0, _vue.computed)(function () {
- return (0, _miscUtil.getValue)(values.value, 0);
- });
- var endDate = (0, _vue.computed)(function () {
- return (0, _miscUtil.getValue)(values.value, 1);
- });
- var getViewDate = function getViewDate(index) {
- // If set default view date, use it
- if (defaultViewDates.value[index]) {
- return defaultViewDates.value[index];
- }
- return (0, _miscUtil.getValue)(viewDates.value, index) || getRangeViewDate(values.value, index, picker.value, generateConfig.value) || startDate.value || endDate.value || generateConfig.value.getNow();
- };
- var startViewDate = (0, _vue.ref)(null);
- var endViewDate = (0, _vue.ref)(null);
- (0, _vue.watchEffect)(function () {
- startViewDate.value = getViewDate(0);
- endViewDate.value = getViewDate(1);
- });
- function setViewDate(viewDate, index) {
- if (viewDate) {
- var newViewDates = (0, _miscUtil.updateValues)(viewDates.value, viewDate, index);
- // Set view date will clean up default one
- // Should always be an array
- defaultViewDates.value = (0, _miscUtil.updateValues)(defaultViewDates.value, null, index) || [null, null];
- // Reset another one when not have value
- var anotherIndex = (index + 1) % 2;
- if (!(0, _miscUtil.getValue)(values.value, anotherIndex)) {
- newViewDates = (0, _miscUtil.updateValues)(newViewDates, viewDate, anotherIndex);
- }
- viewDates.value = newViewDates;
- } else if (startDate.value || endDate.value) {
- // Reset all when has values when `viewDate` is `null` which means from open trigger
- viewDates.value = null;
- }
- }
- return [startViewDate, endViewDate, setViewDate];
- }
|