generateSinglePicker.js 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. exports.default = generateSinglePicker;
  7. var _vue = require("vue");
  8. var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
  9. var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
  10. var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
  11. var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
  12. var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
  13. var _CalendarOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/CalendarOutlined"));
  14. var _ClockCircleOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/ClockCircleOutlined"));
  15. var _CloseCircleFilled = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/CloseCircleFilled"));
  16. var _vcPicker = _interopRequireDefault(require("../../vc-picker"));
  17. var _en_US = _interopRequireDefault(require("../locale/en_US"));
  18. var _util = require("../util");
  19. var _LocaleReceiver = require("../../locale-provider/LocaleReceiver");
  20. var _ = require(".");
  21. var _useConfigInject2 = _interopRequireDefault(require("../../_util/hooks/useConfigInject"));
  22. var _classNames2 = _interopRequireDefault(require("../../_util/classNames"));
  23. var _props2 = require("./props");
  24. var _devWarning = _interopRequireDefault(require("../../vc-util/devWarning"));
  25. var _FormItemContext = require("../../form/FormItemContext");
  26. var _excluded = ["bordered", "placeholder", "suffixIcon", "showToday", "transitionName", "allowClear", "dateRender", "renderExtraFooter", "monthCellRender", "clearIcon", "id"];
  27. function generateSinglePicker(generateConfig, extraProps) {
  28. function getPicker(picker, displayName) {
  29. var comProps = (0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)({}, (0, _props2.commonProps)()), (0, _props2.datePickerProps)()), extraProps);
  30. return (0, _vue.defineComponent)({
  31. compatConfig: {
  32. MODE: 3
  33. },
  34. name: displayName,
  35. inheritAttrs: false,
  36. props: comProps,
  37. slots: ['suffixIcon',
  38. // 'clearIcon',
  39. 'prevIcon', 'nextIcon', 'superPrevIcon', 'superNextIcon',
  40. // 'panelRender',
  41. 'dateRender', 'renderExtraFooter', 'monthCellRender'],
  42. setup: function setup(_props, _ref) {
  43. var slots = _ref.slots,
  44. expose = _ref.expose,
  45. attrs = _ref.attrs,
  46. emit = _ref.emit;
  47. // 兼容 vue 3.2.7
  48. var props = _props;
  49. var formItemContext = (0, _FormItemContext.useInjectFormItemContext)();
  50. (0, _devWarning.default)(!(props.monthCellContentRender || slots.monthCellContentRender), 'DatePicker', '`monthCellContentRender` is deprecated. Please use `monthCellRender"` instead.');
  51. (0, _devWarning.default)(!attrs.getCalendarContainer, 'DatePicker', '`getCalendarContainer` is deprecated. Please use `getPopupContainer"` instead.');
  52. var _useConfigInject = (0, _useConfigInject2.default)('picker', props),
  53. prefixCls = _useConfigInject.prefixCls,
  54. direction = _useConfigInject.direction,
  55. getPopupContainer = _useConfigInject.getPopupContainer,
  56. size = _useConfigInject.size,
  57. rootPrefixCls = _useConfigInject.rootPrefixCls;
  58. var pickerRef = (0, _vue.ref)();
  59. expose({
  60. focus: function focus() {
  61. var _pickerRef$value;
  62. (_pickerRef$value = pickerRef.value) === null || _pickerRef$value === void 0 ? void 0 : _pickerRef$value.focus();
  63. },
  64. blur: function blur() {
  65. var _pickerRef$value2;
  66. (_pickerRef$value2 = pickerRef.value) === null || _pickerRef$value2 === void 0 ? void 0 : _pickerRef$value2.blur();
  67. }
  68. });
  69. var maybeToString = function maybeToString(date) {
  70. return props.valueFormat ? generateConfig.toString(date, props.valueFormat) : date;
  71. };
  72. var onChange = function onChange(date, dateString) {
  73. var value = maybeToString(date);
  74. emit('update:value', value);
  75. emit('change', value, dateString);
  76. formItemContext.onFieldChange();
  77. };
  78. var onOpenChange = function onOpenChange(open) {
  79. emit('update:open', open);
  80. emit('openChange', open);
  81. };
  82. var onFocus = function onFocus(e) {
  83. emit('focus', e);
  84. };
  85. var onBlur = function onBlur(e) {
  86. emit('blur', e);
  87. formItemContext.onFieldBlur();
  88. };
  89. var onPanelChange = function onPanelChange(date, mode) {
  90. var value = maybeToString(date);
  91. emit('panelChange', value, mode);
  92. };
  93. var onOk = function onOk(date) {
  94. var value = maybeToString(date);
  95. emit('ok', value);
  96. };
  97. var _useLocaleReceiver = (0, _LocaleReceiver.useLocaleReceiver)('DatePicker', _en_US.default),
  98. _useLocaleReceiver2 = (0, _slicedToArray2.default)(_useLocaleReceiver, 1),
  99. contextLocale = _useLocaleReceiver2[0];
  100. var value = (0, _vue.computed)(function () {
  101. if (props.value) {
  102. return props.valueFormat ? generateConfig.toDate(props.value, props.valueFormat) : props.value;
  103. }
  104. return props.value === '' ? undefined : props.value;
  105. });
  106. var defaultValue = (0, _vue.computed)(function () {
  107. if (props.defaultValue) {
  108. return props.valueFormat ? generateConfig.toDate(props.defaultValue, props.valueFormat) : props.defaultValue;
  109. }
  110. return props.defaultValue === '' ? undefined : props.defaultValue;
  111. });
  112. var defaultPickerValue = (0, _vue.computed)(function () {
  113. if (props.defaultPickerValue) {
  114. return props.valueFormat ? generateConfig.toDate(props.defaultPickerValue, props.valueFormat) : props.defaultPickerValue;
  115. }
  116. return props.defaultPickerValue === '' ? undefined : props.defaultPickerValue;
  117. });
  118. return function () {
  119. var _slots$suffixIcon, _slots$clearIcon, _classNames, _slots$prevIcon, _slots$nextIcon, _slots$superPrevIcon, _slots$superNextIcon;
  120. var locale = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, contextLocale.value), props.locale);
  121. var p = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, props), attrs);
  122. var _p$bordered = p.bordered,
  123. bordered = _p$bordered === void 0 ? true : _p$bordered,
  124. placeholder = p.placeholder,
  125. _p$suffixIcon = p.suffixIcon,
  126. suffixIcon = _p$suffixIcon === void 0 ? (_slots$suffixIcon = slots.suffixIcon) === null || _slots$suffixIcon === void 0 ? void 0 : _slots$suffixIcon.call(slots) : _p$suffixIcon,
  127. _p$showToday = p.showToday,
  128. showToday = _p$showToday === void 0 ? true : _p$showToday,
  129. transitionName = p.transitionName,
  130. _p$allowClear = p.allowClear,
  131. allowClear = _p$allowClear === void 0 ? true : _p$allowClear,
  132. _p$dateRender = p.dateRender,
  133. dateRender = _p$dateRender === void 0 ? slots.dateRender : _p$dateRender,
  134. _p$renderExtraFooter = p.renderExtraFooter,
  135. renderExtraFooter = _p$renderExtraFooter === void 0 ? slots.renderExtraFooter : _p$renderExtraFooter,
  136. _p$monthCellRender = p.monthCellRender,
  137. monthCellRender = _p$monthCellRender === void 0 ? slots.monthCellRender || props.monthCellContentRender || slots.monthCellContentRender : _p$monthCellRender,
  138. _p$clearIcon = p.clearIcon,
  139. clearIcon = _p$clearIcon === void 0 ? (_slots$clearIcon = slots.clearIcon) === null || _slots$clearIcon === void 0 ? void 0 : _slots$clearIcon.call(slots) : _p$clearIcon,
  140. _p$id = p.id,
  141. id = _p$id === void 0 ? formItemContext.id.value : _p$id,
  142. restProps = (0, _objectWithoutProperties2.default)(p, _excluded);
  143. var showTime = p.showTime === '' ? true : p.showTime;
  144. var format = p.format;
  145. var additionalOverrideProps = {};
  146. if (picker) {
  147. additionalOverrideProps.picker = picker;
  148. }
  149. var mergedPicker = picker || p.picker || 'date';
  150. additionalOverrideProps = (0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)({}, additionalOverrideProps), showTime ? (0, _.getTimeProps)((0, _objectSpread2.default)({
  151. format: format,
  152. picker: mergedPicker
  153. }, (0, _typeof2.default)(showTime) === 'object' ? showTime : {})) : {}), mergedPicker === 'time' ? (0, _.getTimeProps)((0, _objectSpread2.default)((0, _objectSpread2.default)({
  154. format: format
  155. }, restProps), {}, {
  156. picker: mergedPicker
  157. })) : {});
  158. var pre = prefixCls.value;
  159. return (0, _vue.createVNode)(_vcPicker.default, (0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)({
  160. "monthCellRender": monthCellRender,
  161. "dateRender": dateRender,
  162. "renderExtraFooter": renderExtraFooter,
  163. "ref": pickerRef,
  164. "placeholder": (0, _util.getPlaceholder)(mergedPicker, locale, placeholder),
  165. "suffixIcon": suffixIcon || (mergedPicker === 'time' ? (0, _vue.createVNode)(_ClockCircleOutlined.default, null, null) : (0, _vue.createVNode)(_CalendarOutlined.default, null, null)),
  166. "clearIcon": clearIcon || (0, _vue.createVNode)(_CloseCircleFilled.default, null, null),
  167. "allowClear": allowClear,
  168. "transitionName": transitionName || "".concat(rootPrefixCls.value, "-slide-up")
  169. }, restProps), additionalOverrideProps), {}, {
  170. "id": id,
  171. "picker": mergedPicker,
  172. "value": value.value,
  173. "defaultValue": defaultValue.value,
  174. "defaultPickerValue": defaultPickerValue.value,
  175. "showToday": showToday,
  176. "locale": locale.lang,
  177. "class": (0, _classNames2.default)((_classNames = {}, (0, _defineProperty2.default)(_classNames, "".concat(pre, "-").concat(size.value), size.value), (0, _defineProperty2.default)(_classNames, "".concat(pre, "-borderless"), !bordered), _classNames), attrs.class),
  178. "prefixCls": pre,
  179. "getPopupContainer": attrs.getCalendarContainer || getPopupContainer.value,
  180. "generateConfig": generateConfig,
  181. "prevIcon": ((_slots$prevIcon = slots.prevIcon) === null || _slots$prevIcon === void 0 ? void 0 : _slots$prevIcon.call(slots)) || (0, _vue.createVNode)("span", {
  182. "class": "".concat(pre, "-prev-icon")
  183. }, null),
  184. "nextIcon": ((_slots$nextIcon = slots.nextIcon) === null || _slots$nextIcon === void 0 ? void 0 : _slots$nextIcon.call(slots)) || (0, _vue.createVNode)("span", {
  185. "class": "".concat(pre, "-next-icon")
  186. }, null),
  187. "superPrevIcon": ((_slots$superPrevIcon = slots.superPrevIcon) === null || _slots$superPrevIcon === void 0 ? void 0 : _slots$superPrevIcon.call(slots)) || (0, _vue.createVNode)("span", {
  188. "class": "".concat(pre, "-super-prev-icon")
  189. }, null),
  190. "superNextIcon": ((_slots$superNextIcon = slots.superNextIcon) === null || _slots$superNextIcon === void 0 ? void 0 : _slots$superNextIcon.call(slots)) || (0, _vue.createVNode)("span", {
  191. "class": "".concat(pre, "-super-next-icon")
  192. }, null),
  193. "components": _.Components,
  194. "direction": direction.value,
  195. "onChange": onChange,
  196. "onOpenChange": onOpenChange,
  197. "onFocus": onFocus,
  198. "onBlur": onBlur,
  199. "onPanelChange": onPanelChange,
  200. "onOk": onOk
  201. }), null);
  202. };
  203. }
  204. });
  205. }
  206. var DatePicker = getPicker(undefined, 'ADatePicker');
  207. var WeekPicker = getPicker('week', 'AWeekPicker');
  208. var MonthPicker = getPicker('month', 'AMonthPicker');
  209. var YearPicker = getPicker('year', 'AYearPicker');
  210. var TimePicker = getPicker('time', 'TimePicker'); // 给独立组件 TimePicker 使用,此处名称不用更改
  211. var QuarterPicker = getPicker('quarter', 'AQuarterPicker');
  212. return {
  213. DatePicker: DatePicker,
  214. WeekPicker: WeekPicker,
  215. MonthPicker: MonthPicker,
  216. YearPicker: YearPicker,
  217. TimePicker: TimePicker,
  218. QuarterPicker: QuarterPicker
  219. };
  220. }