index.js 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. exports.default = void 0;
  7. var _vue = require("vue");
  8. var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
  9. var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
  10. var _DateBody = _interopRequireDefault(require("./DateBody"));
  11. var _DateHeader = _interopRequireDefault(require("./DateHeader"));
  12. var _dateUtil = require("../../utils/dateUtil");
  13. var _uiUtil = require("../../utils/uiUtil");
  14. var _classNames = _interopRequireDefault(require("../../../_util/classNames"));
  15. var _useMergeProps = _interopRequireDefault(require("../../hooks/useMergeProps"));
  16. const DATE_ROW_COUNT = 6;
  17. function DatePanel(_props) {
  18. const props = (0, _useMergeProps.default)(_props);
  19. const {
  20. prefixCls,
  21. panelName = 'date',
  22. keyboardConfig,
  23. active,
  24. operationRef,
  25. generateConfig,
  26. value,
  27. viewDate,
  28. onViewDateChange,
  29. onPanelChange,
  30. onSelect
  31. } = props;
  32. const panelPrefixCls = `${prefixCls}-${panelName}-panel`;
  33. // ======================= Keyboard =======================
  34. operationRef.value = {
  35. onKeydown: event => (0, _uiUtil.createKeydownHandler)(event, (0, _extends2.default)({
  36. onLeftRight: diff => {
  37. onSelect(generateConfig.addDate(value || viewDate, diff), 'key');
  38. },
  39. onCtrlLeftRight: diff => {
  40. onSelect(generateConfig.addYear(value || viewDate, diff), 'key');
  41. },
  42. onUpDown: diff => {
  43. onSelect(generateConfig.addDate(value || viewDate, diff * _dateUtil.WEEK_DAY_COUNT), 'key');
  44. },
  45. onPageUpDown: diff => {
  46. onSelect(generateConfig.addMonth(value || viewDate, diff), 'key');
  47. }
  48. }, keyboardConfig))
  49. };
  50. // ==================== View Operation ====================
  51. const onYearChange = diff => {
  52. const newDate = generateConfig.addYear(viewDate, diff);
  53. onViewDateChange(newDate);
  54. onPanelChange(null, newDate);
  55. };
  56. const onMonthChange = diff => {
  57. const newDate = generateConfig.addMonth(viewDate, diff);
  58. onViewDateChange(newDate);
  59. onPanelChange(null, newDate);
  60. };
  61. return (0, _vue.createVNode)("div", {
  62. "class": (0, _classNames.default)(panelPrefixCls, {
  63. [`${panelPrefixCls}-active`]: active
  64. })
  65. }, [(0, _vue.createVNode)(_DateHeader.default, (0, _objectSpread2.default)((0, _objectSpread2.default)({}, props), {}, {
  66. "prefixCls": prefixCls,
  67. "value": value,
  68. "viewDate": viewDate,
  69. "onPrevYear": () => {
  70. onYearChange(-1);
  71. },
  72. "onNextYear": () => {
  73. onYearChange(1);
  74. },
  75. "onPrevMonth": () => {
  76. onMonthChange(-1);
  77. },
  78. "onNextMonth": () => {
  79. onMonthChange(1);
  80. },
  81. "onMonthClick": () => {
  82. onPanelChange('month', viewDate);
  83. },
  84. "onYearClick": () => {
  85. onPanelChange('year', viewDate);
  86. }
  87. }), null), (0, _vue.createVNode)(_DateBody.default, (0, _objectSpread2.default)((0, _objectSpread2.default)({}, props), {}, {
  88. "onSelect": date => onSelect(date, 'mouse'),
  89. "prefixCls": prefixCls,
  90. "value": value,
  91. "viewDate": viewDate,
  92. "rowCount": DATE_ROW_COUNT
  93. }), null)]);
  94. }
  95. DatePanel.displayName = 'DatePanel';
  96. DatePanel.inheritAttrs = false;
  97. var _default = exports.default = DatePanel;