index.js 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  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 = DecadePanel;
  8. var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
  9. var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
  10. var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
  11. var React = _interopRequireWildcard(require("react"));
  12. var _dateUtil = require("../../utils/dateUtil");
  13. var _context = require("../context");
  14. var _PanelBody = _interopRequireDefault(require("../PanelBody"));
  15. var _PanelHeader = _interopRequireDefault(require("../PanelHeader"));
  16. function DecadePanel(props) {
  17. var prefixCls = props.prefixCls,
  18. locale = props.locale,
  19. generateConfig = props.generateConfig,
  20. pickerValue = props.pickerValue,
  21. disabledDate = props.disabledDate,
  22. onPickerValueChange = props.onPickerValueChange;
  23. var panelPrefixCls = "".concat(prefixCls, "-decade-panel");
  24. // ========================== Base ==========================
  25. var _useInfo = (0, _context.useInfo)(props, 'decade'),
  26. _useInfo2 = (0, _slicedToArray2.default)(_useInfo, 1),
  27. info = _useInfo2[0];
  28. var getStartYear = function getStartYear(date) {
  29. var startYear = Math.floor(generateConfig.getYear(date) / 100) * 100;
  30. return generateConfig.setYear(date, startYear);
  31. };
  32. var getEndYear = function getEndYear(date) {
  33. var startYear = getStartYear(date);
  34. return generateConfig.addYear(startYear, 99);
  35. };
  36. var startYearDate = getStartYear(pickerValue);
  37. var endYearDate = getEndYear(pickerValue);
  38. var baseDate = generateConfig.addYear(startYearDate, -10);
  39. // ========================= Cells ==========================
  40. var getCellDate = function getCellDate(date, offset) {
  41. return generateConfig.addYear(date, offset * 10);
  42. };
  43. var getCellText = function getCellText(date) {
  44. var cellYearFormat = locale.cellYearFormat;
  45. var startYearStr = (0, _dateUtil.formatValue)(date, {
  46. locale: locale,
  47. format: cellYearFormat,
  48. generateConfig: generateConfig
  49. });
  50. var endYearStr = (0, _dateUtil.formatValue)(generateConfig.addYear(date, 9), {
  51. locale: locale,
  52. format: cellYearFormat,
  53. generateConfig: generateConfig
  54. });
  55. return "".concat(startYearStr, "-").concat(endYearStr);
  56. };
  57. var getCellClassName = function getCellClassName(date) {
  58. return (0, _defineProperty2.default)({}, "".concat(prefixCls, "-cell-in-view"), (0, _dateUtil.isSameDecade)(generateConfig, date, startYearDate) || (0, _dateUtil.isSameDecade)(generateConfig, date, endYearDate) || (0, _dateUtil.isInRange)(generateConfig, startYearDate, endYearDate, date));
  59. };
  60. // ======================== Disabled ========================
  61. var mergedDisabledDate = disabledDate ? function (currentDate, disabledInfo) {
  62. // Start
  63. var baseStartDate = generateConfig.setDate(currentDate, 1);
  64. var baseStartMonth = generateConfig.setMonth(baseStartDate, 0);
  65. var baseStartYear = generateConfig.setYear(baseStartMonth, Math.floor(generateConfig.getYear(baseStartMonth) / 10) * 10);
  66. // End
  67. var baseEndYear = generateConfig.addYear(baseStartYear, 10);
  68. var baseEndDate = generateConfig.addDate(baseEndYear, -1);
  69. return disabledDate(baseStartYear, disabledInfo) && disabledDate(baseEndDate, disabledInfo);
  70. } : null;
  71. // ========================= Header =========================
  72. var yearNode = "".concat((0, _dateUtil.formatValue)(startYearDate, {
  73. locale: locale,
  74. format: locale.yearFormat,
  75. generateConfig: generateConfig
  76. }), "-").concat((0, _dateUtil.formatValue)(endYearDate, {
  77. locale: locale,
  78. format: locale.yearFormat,
  79. generateConfig: generateConfig
  80. }));
  81. // ========================= Render =========================
  82. return /*#__PURE__*/React.createElement(_context.PanelContext.Provider, {
  83. value: info
  84. }, /*#__PURE__*/React.createElement("div", {
  85. className: panelPrefixCls
  86. }, /*#__PURE__*/React.createElement(_PanelHeader.default, {
  87. superOffset: function superOffset(distance) {
  88. return generateConfig.addYear(pickerValue, distance * 100);
  89. },
  90. onChange: onPickerValueChange
  91. // Limitation
  92. ,
  93. getStart: getStartYear,
  94. getEnd: getEndYear
  95. }, yearNode), /*#__PURE__*/React.createElement(_PanelBody.default, (0, _extends2.default)({}, props, {
  96. disabledDate: mergedDisabledDate,
  97. colNum: 3,
  98. rowNum: 4,
  99. baseDate: baseDate
  100. // Body
  101. ,
  102. getCellDate: getCellDate,
  103. getCellText: getCellText,
  104. getCellClassName: getCellClassName
  105. }))));
  106. }