useRangeViewDates.js 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. "use strict";
  2. Object.defineProperty(exports, "__esModule", {
  3. value: true
  4. });
  5. exports.default = useRangeViewDates;
  6. var _miscUtil = require("../utils/miscUtil");
  7. var _dateUtil = require("../utils/dateUtil");
  8. var _vue = require("vue");
  9. function getStartEndDistance(startDate, endDate, picker, generateConfig) {
  10. var startNext = (0, _dateUtil.getClosingViewDate)(startDate, picker, generateConfig, 1);
  11. function getDistance(compareFunc) {
  12. if (compareFunc(startDate, endDate)) {
  13. return 'same';
  14. }
  15. if (compareFunc(startNext, endDate)) {
  16. return 'closing';
  17. }
  18. return 'far';
  19. }
  20. switch (picker) {
  21. case 'year':
  22. return getDistance(function (start, end) {
  23. return (0, _dateUtil.isSameDecade)(generateConfig, start, end);
  24. });
  25. case 'quarter':
  26. case 'month':
  27. return getDistance(function (start, end) {
  28. return (0, _dateUtil.isSameYear)(generateConfig, start, end);
  29. });
  30. default:
  31. return getDistance(function (start, end) {
  32. return (0, _dateUtil.isSameMonth)(generateConfig, start, end);
  33. });
  34. }
  35. }
  36. function getRangeViewDate(values, index, picker, generateConfig) {
  37. var startDate = (0, _miscUtil.getValue)(values, 0);
  38. var endDate = (0, _miscUtil.getValue)(values, 1);
  39. if (index === 0) {
  40. return startDate;
  41. }
  42. if (startDate && endDate) {
  43. var distance = getStartEndDistance(startDate, endDate, picker, generateConfig);
  44. switch (distance) {
  45. case 'same':
  46. return startDate;
  47. case 'closing':
  48. return startDate;
  49. default:
  50. return (0, _dateUtil.getClosingViewDate)(endDate, picker, generateConfig, -1);
  51. }
  52. }
  53. return startDate;
  54. }
  55. function useRangeViewDates(_ref) {
  56. var values = _ref.values,
  57. picker = _ref.picker,
  58. defaultDates = _ref.defaultDates,
  59. generateConfig = _ref.generateConfig;
  60. var defaultViewDates = (0, _vue.ref)([(0, _miscUtil.getValue)(defaultDates, 0), (0, _miscUtil.getValue)(defaultDates, 1)]);
  61. var viewDates = (0, _vue.ref)(null);
  62. var startDate = (0, _vue.computed)(function () {
  63. return (0, _miscUtil.getValue)(values.value, 0);
  64. });
  65. var endDate = (0, _vue.computed)(function () {
  66. return (0, _miscUtil.getValue)(values.value, 1);
  67. });
  68. var getViewDate = function getViewDate(index) {
  69. // If set default view date, use it
  70. if (defaultViewDates.value[index]) {
  71. return defaultViewDates.value[index];
  72. }
  73. return (0, _miscUtil.getValue)(viewDates.value, index) || getRangeViewDate(values.value, index, picker.value, generateConfig.value) || startDate.value || endDate.value || generateConfig.value.getNow();
  74. };
  75. var startViewDate = (0, _vue.ref)(null);
  76. var endViewDate = (0, _vue.ref)(null);
  77. (0, _vue.watchEffect)(function () {
  78. startViewDate.value = getViewDate(0);
  79. endViewDate.value = getViewDate(1);
  80. });
  81. function setViewDate(viewDate, index) {
  82. if (viewDate) {
  83. var newViewDates = (0, _miscUtil.updateValues)(viewDates.value, viewDate, index);
  84. // Set view date will clean up default one
  85. // Should always be an array
  86. defaultViewDates.value = (0, _miscUtil.updateValues)(defaultViewDates.value, null, index) || [null, null];
  87. // Reset another one when not have value
  88. var anotherIndex = (index + 1) % 2;
  89. if (!(0, _miscUtil.getValue)(values.value, anotherIndex)) {
  90. newViewDates = (0, _miscUtil.updateValues)(newViewDates, viewDate, anotherIndex);
  91. }
  92. viewDates.value = newViewDates;
  93. } else if (startDate.value || endDate.value) {
  94. // Reset all when has values when `viewDate` is `null` which means from open trigger
  95. viewDates.value = null;
  96. }
  97. }
  98. return [startViewDate, endViewDate, setViewDate];
  99. }