useTimeInfo.js 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. "use strict";
  2. var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
  3. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
  4. Object.defineProperty(exports, "__esModule", {
  5. value: true
  6. });
  7. exports.default = useTimeInfo;
  8. var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
  9. var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
  10. var _rcUtil = require("rc-util");
  11. var React = _interopRequireWildcard(require("react"));
  12. var _util = require("../PickerPanel/TimePanel/TimePanelBody/util");
  13. var _miscUtil = require("../utils/miscUtil");
  14. function emptyDisabled() {
  15. return [];
  16. }
  17. function generateUnits(start, end) {
  18. var step = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 1;
  19. var hideDisabledOptions = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
  20. var disabledUnits = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : [];
  21. var pad = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : 2;
  22. var units = [];
  23. var integerStep = step >= 1 ? step | 0 : 1;
  24. for (var i = start; i <= end; i += integerStep) {
  25. var disabled = disabledUnits.includes(i);
  26. if (!disabled || !hideDisabledOptions) {
  27. units.push({
  28. label: (0, _miscUtil.leftPad)(i, pad),
  29. value: i,
  30. disabled: disabled
  31. });
  32. }
  33. }
  34. return units;
  35. }
  36. /**
  37. * Parse time props to get util info
  38. */
  39. function useTimeInfo(generateConfig) {
  40. var props = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
  41. var date = arguments.length > 2 ? arguments[2] : undefined;
  42. var _ref = props || {},
  43. use12Hours = _ref.use12Hours,
  44. _ref$hourStep = _ref.hourStep,
  45. hourStep = _ref$hourStep === void 0 ? 1 : _ref$hourStep,
  46. _ref$minuteStep = _ref.minuteStep,
  47. minuteStep = _ref$minuteStep === void 0 ? 1 : _ref$minuteStep,
  48. _ref$secondStep = _ref.secondStep,
  49. secondStep = _ref$secondStep === void 0 ? 1 : _ref$secondStep,
  50. _ref$millisecondStep = _ref.millisecondStep,
  51. millisecondStep = _ref$millisecondStep === void 0 ? 100 : _ref$millisecondStep,
  52. hideDisabledOptions = _ref.hideDisabledOptions,
  53. disabledTime = _ref.disabledTime,
  54. disabledHours = _ref.disabledHours,
  55. disabledMinutes = _ref.disabledMinutes,
  56. disabledSeconds = _ref.disabledSeconds;
  57. var mergedDate = React.useMemo(function () {
  58. return date || generateConfig.getNow();
  59. }, [date, generateConfig]);
  60. // ======================== Warnings ========================
  61. if (process.env.NODE_ENV !== 'production') {
  62. var isHourStepValid = 24 % hourStep === 0;
  63. var isMinuteStepValid = 60 % minuteStep === 0;
  64. var isSecondStepValid = 60 % secondStep === 0;
  65. (0, _rcUtil.warning)(isHourStepValid, "`hourStep` ".concat(hourStep, " is invalid. It should be a factor of 24."));
  66. (0, _rcUtil.warning)(isMinuteStepValid, "`minuteStep` ".concat(minuteStep, " is invalid. It should be a factor of 60."));
  67. (0, _rcUtil.warning)(isSecondStepValid, "`secondStep` ".concat(secondStep, " is invalid. It should be a factor of 60."));
  68. }
  69. // ======================== Disabled ========================
  70. var getDisabledTimes = React.useCallback(function (targetDate) {
  71. var disabledConfig = (disabledTime === null || disabledTime === void 0 ? void 0 : disabledTime(targetDate)) || {};
  72. return [disabledConfig.disabledHours || disabledHours || emptyDisabled, disabledConfig.disabledMinutes || disabledMinutes || emptyDisabled, disabledConfig.disabledSeconds || disabledSeconds || emptyDisabled, disabledConfig.disabledMilliseconds || emptyDisabled];
  73. }, [disabledTime, disabledHours, disabledMinutes, disabledSeconds]);
  74. var _React$useMemo = React.useMemo(function () {
  75. return getDisabledTimes(mergedDate);
  76. }, [mergedDate, getDisabledTimes]),
  77. _React$useMemo2 = (0, _slicedToArray2.default)(_React$useMemo, 4),
  78. mergedDisabledHours = _React$useMemo2[0],
  79. mergedDisabledMinutes = _React$useMemo2[1],
  80. mergedDisabledSeconds = _React$useMemo2[2],
  81. mergedDisabledMilliseconds = _React$useMemo2[3];
  82. // ========================= Column =========================
  83. var getAllUnits = React.useCallback(function (getDisabledHours, getDisabledMinutes, getDisabledSeconds, getDisabledMilliseconds) {
  84. var hours = generateUnits(0, 23, hourStep, hideDisabledOptions, getDisabledHours());
  85. // Hours
  86. var rowHourUnits = use12Hours ? hours.map(function (unit) {
  87. return (0, _objectSpread2.default)((0, _objectSpread2.default)({}, unit), {}, {
  88. label: (0, _miscUtil.leftPad)(unit.value % 12 || 12, 2)
  89. });
  90. }) : hours;
  91. // Minutes
  92. var getMinuteUnits = function getMinuteUnits(nextHour) {
  93. return generateUnits(0, 59, minuteStep, hideDisabledOptions, getDisabledMinutes(nextHour));
  94. };
  95. // Seconds
  96. var getSecondUnits = function getSecondUnits(nextHour, nextMinute) {
  97. return generateUnits(0, 59, secondStep, hideDisabledOptions, getDisabledSeconds(nextHour, nextMinute));
  98. };
  99. // Milliseconds
  100. var getMillisecondUnits = function getMillisecondUnits(nextHour, nextMinute, nextSecond) {
  101. return generateUnits(0, 999, millisecondStep, hideDisabledOptions, getDisabledMilliseconds(nextHour, nextMinute, nextSecond), 3);
  102. };
  103. return [rowHourUnits, getMinuteUnits, getSecondUnits, getMillisecondUnits];
  104. }, [hideDisabledOptions, hourStep, use12Hours, millisecondStep, minuteStep, secondStep]);
  105. var _React$useMemo3 = React.useMemo(function () {
  106. return getAllUnits(mergedDisabledHours, mergedDisabledMinutes, mergedDisabledSeconds, mergedDisabledMilliseconds);
  107. }, [getAllUnits, mergedDisabledHours, mergedDisabledMinutes, mergedDisabledSeconds, mergedDisabledMilliseconds]),
  108. _React$useMemo4 = (0, _slicedToArray2.default)(_React$useMemo3, 4),
  109. rowHourUnits = _React$useMemo4[0],
  110. getMinuteUnits = _React$useMemo4[1],
  111. getSecondUnits = _React$useMemo4[2],
  112. getMillisecondUnits = _React$useMemo4[3];
  113. // ======================== Validate ========================
  114. /**
  115. * Get validate time with `disabledTime`, `certainDate` to specific the date need to check
  116. */
  117. var getValidTime = function getValidTime(nextTime, certainDate) {
  118. var getCheckHourUnits = function getCheckHourUnits() {
  119. return rowHourUnits;
  120. };
  121. var getCheckMinuteUnits = getMinuteUnits;
  122. var getCheckSecondUnits = getSecondUnits;
  123. var getCheckMillisecondUnits = getMillisecondUnits;
  124. if (certainDate) {
  125. var _getDisabledTimes = getDisabledTimes(certainDate),
  126. _getDisabledTimes2 = (0, _slicedToArray2.default)(_getDisabledTimes, 4),
  127. targetDisabledHours = _getDisabledTimes2[0],
  128. targetDisabledMinutes = _getDisabledTimes2[1],
  129. targetDisabledSeconds = _getDisabledTimes2[2],
  130. targetDisabledMilliseconds = _getDisabledTimes2[3];
  131. var _getAllUnits = getAllUnits(targetDisabledHours, targetDisabledMinutes, targetDisabledSeconds, targetDisabledMilliseconds),
  132. _getAllUnits2 = (0, _slicedToArray2.default)(_getAllUnits, 4),
  133. targetRowHourUnits = _getAllUnits2[0],
  134. targetGetMinuteUnits = _getAllUnits2[1],
  135. targetGetSecondUnits = _getAllUnits2[2],
  136. targetGetMillisecondUnits = _getAllUnits2[3];
  137. getCheckHourUnits = function getCheckHourUnits() {
  138. return targetRowHourUnits;
  139. };
  140. getCheckMinuteUnits = targetGetMinuteUnits;
  141. getCheckSecondUnits = targetGetSecondUnits;
  142. getCheckMillisecondUnits = targetGetMillisecondUnits;
  143. }
  144. var validateDate = (0, _util.findValidateTime)(nextTime, getCheckHourUnits, getCheckMinuteUnits, getCheckSecondUnits, getCheckMillisecondUnits, generateConfig);
  145. return validateDate;
  146. };
  147. return [
  148. // getValidTime
  149. getValidTime,
  150. // Units
  151. rowHourUnits, getMinuteUnits, getSecondUnits, getMillisecondUnits];
  152. }