tdesign-vue
Version:
389 lines (385 loc) • 14.4 kB
JavaScript
/**
* tdesign v1.12.1
* (c) 2025 tdesign
* @license MIT
*/
import _defineProperty from '@babel/runtime/helpers/defineProperty';
import _toConsumableArray from '@babel/runtime/helpers/toConsumableArray';
import { defineComponent, ref, computed } from '@vue/composition-api';
import { PaginationMini } from '../../pagination/index.js';
import { Select } from '../../select/index.js';
import { usePrefixClass } from '../../hooks/useConfig.js';
import { useConfig } from '../../config-provider/useConfig.js';
import '../../pagination/pagination.js';
import '../../_chunks/dep-323b993c.js';
import '@babel/runtime/helpers/typeof';
import 'tdesign-icons-vue';
import '../../utils/mixins.js';
import 'vue';
import '../../config-provider/config-receiver.js';
import 'lodash-es';
import '../../config-provider/context.js';
import '../../_common/js/global-config/default-config.js';
import '../../_common/js/global-config/locale/zh_CN.js';
import '../../_chunks/dep-c44a474d.js';
import '../../_chunks/dep-d639fbd7.js';
import 'dayjs';
import '../../_chunks/dep-3c66615e.js';
import '../../config-provider/type.js';
import '../../_common/js/global-config/t.js';
import '@babel/runtime/helpers/slicedToArray';
import '../../input-number/index.js';
import '../../input-number/input-number.js';
import '../../button/index.js';
import '../../button/button.js';
import '../../loading/index.js';
import '../../loading/directive.js';
import '../../loading/plugin.js';
import '../../loading/loading.js';
import '../../loading/icon/gradient.js';
import '../../_common/js/loading/circle-adapter.js';
import '../../_common/js/utils/setStyle.js';
import '../../_common/js/utils/helper.js';
import '@babel/runtime/helpers/objectWithoutProperties';
import '../../utils/dom.js';
import 'raf';
import '../../utils/easing.js';
import '../../utils/render-tnode.js';
import '@babel/runtime/helpers/readOnlyError';
import '../../utils/transfer-dom.js';
import '../../loading/props.js';
import '../../config.js';
import '../../utils/withInstall.js';
import './style/css.js';
import '../../loading/type.js';
import '../../button/props.js';
import '../../utils/ripple.js';
import '../../button/type.js';
import '../../input/index.js';
import '../../input/input.js';
import '../../utils/helper.js';
import '../../utils/event.js';
import '../../input/props.js';
import '../../_common/js/log/index.js';
import '../../_common/js/log/log.js';
import '../../input/input-group.js';
import '../../utils/map-props.js';
import '../../input/type.js';
import '../../input-number/props.js';
import '../../input-number/useInputNumber.js';
import '../../hooks/useCommonClassName.js';
import '../../hooks/useVModel.js';
import '../../_common/js/input-number/number.js';
import '../../_common/js/input-number/large-number.js';
import '../../hooks/useFormDisabled.js';
import '../../hooks/useGlobalIcon.js';
import '../../input-number/type.js';
import '../../input-adornment/index.js';
import '../../input-adornment/input-adornment.js';
import '../../input-adornment/props.js';
import '../../input-adornment/type.js';
import '../../pagination/props.js';
import '../../select/select.js';
import '../../hooks/useDefaultValue.js';
import '../../hooks/tnode.js';
import '../../hooks/render-tnode.js';
import '../../select/props.js';
import '../../popup/index.js';
import '../../popup/popup.js';
import '@popperjs/core';
import '../../popup/props.js';
import '../../popup/container.js';
import '../../popup/utils.js';
import '../../popup/type.js';
import '../../popup/plugin.js';
import '../../tag/index.js';
import '../../tag/tag.js';
import 'tinycolor2';
import '../../tag/props.js';
import '../../tag/check-tag.js';
import '../../tag/check-tag-props.js';
import '../../_common/js/common.js';
import '../../hooks/index.js';
import '../../hooks/slots.js';
import '../../hooks/useDestroyOnClose.js';
import '../../hooks/useElementLazyRender.js';
import '../../_common/js/utils/observe.js';
import '../../hooks/useLazyLoad.js';
import '../../hooks/useResizeObserver.js';
import '../../hooks/useVirtualScrollNew.js';
import '../../hooks/useImagePreviewUrl.js';
import '../../_common/js/upload/utils.js';
import '../../tag/check-tag-group.js';
import '../../tag/check-tag-group-props.js';
import '../../tag/type.js';
import '../../select-input/index.js';
import '../../select-input/select-input.js';
import '../../select-input/props.js';
import '../../select-input/useSingle.js';
import '../../select-input/useMultiple.js';
import '../../tag-input/index.js';
import '../../tag-input/tag-input.js';
import '../../tag-input/props.js';
import '../../tag-input/hooks/useTagScroll.js';
import '../../tag-input/useTagList.js';
import '../../tag-input/hooks/useHover.js';
import '../../tag-input/hooks/useDragSorter.js';
import '../../tag-input/type.js';
import '../../tag-input/interface.js';
import '../../select-input/useOverlayInnerStyle.js';
import '../../select-input/type.js';
import '../../common-components/fake-arrow.js';
import '../../select/option.js';
import '../../select/option-props.js';
import '../../checkbox/index.js';
import '../../checkbox/group.js';
import '../../checkbox/checkbox.js';
import '../../checkbox/props.js';
import '../../checkbox/constants.js';
import '../../checkbox/store.js';
import '@babel/runtime/helpers/classCallCheck';
import '@babel/runtime/helpers/createClass';
import '../../checkbox/hooks/useKeyboardEvent.js';
import '../../checkbox/checkbox-group-props.js';
import '../../checkbox/type.js';
import '../../select/util.js';
import '../../select/select-panel.js';
import '../../select/optionGroup.js';
import '../../select/option-group-props.js';
import '../../hooks/useVirtualScroll.js';
import '../../select/hooks/useSelectOptions.js';
import '../../select/type.js';
import '../../pagination/pagination-mini.js';
import '../../pagination/pagination-mini-props.js';
import '../../pagination/type.js';
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
var TDateHeader = defineComponent({
name: "TDatePickerHeader",
props: {
mode: {
type: String,
"default": "date"
},
year: Number,
month: Number,
onMonthChange: Function,
onYearChange: Function,
onJumperClick: Function
},
setup: function setup(props) {
var _useConfig = useConfig("classPrefix"),
classPrefix = _useConfig.classPrefix;
var COMPONENT_NAME = usePrefixClass("date-picker__header");
var _useConfig2 = useConfig("datePicker"),
global = _useConfig2.global;
var yearOptions = ref(initOptions(props.year));
var showMonthPicker = props.mode === "date" || props.mode === "week";
var nearestYear = computed(function () {
var _yearOptions$value$fi;
return ((_yearOptions$value$fi = yearOptions.value.find(function (option) {
return option.value - props.year <= 9 && option.value - props.year >= 0;
})) === null || _yearOptions$value$fi === void 0 ? void 0 : _yearOptions$value$fi.value) || props.year;
});
var monthOptions = computed(function () {
return global.value.months.map(function (item, index) {
return {
label: item,
value: index
};
});
});
function initOptions(year) {
var options = [];
if (props.mode === "year") {
var extraYear = year % 10;
var minYear = year - extraYear - 100;
var maxYear = year - extraYear + 100;
for (var i = minYear; i <= maxYear; i += 10) {
options.push({
label: "".concat(i, " - ").concat(i + 9),
value: i + 9
});
}
} else {
options.push({
label: "".concat(year),
value: year
});
for (var _i = 1; _i <= 10; _i++) {
options.push({
label: "".concat(year + _i),
value: year + _i
});
options.unshift({
label: "".concat(year - _i),
value: year - _i
});
}
}
return options;
}
function loadMoreYear(year, type) {
var options = [];
if (props.mode === "year") {
var extraYear = year % 10;
if (type === "add") {
for (var i = year - extraYear + 10; i <= year - extraYear + 50; i += 10) {
options.push({
label: "".concat(i, " - ").concat(i + 9),
value: i
});
}
} else {
for (var _i2 = year - extraYear - 1; _i2 > year - extraYear - 50; _i2 -= 10) {
options.unshift({
label: "".concat(_i2 - 9, " - ").concat(_i2),
value: _i2
});
}
}
} else if (type === "add") {
for (var _i3 = year + 1; _i3 <= year + 10; _i3++) {
options.push({
label: "".concat(_i3),
value: _i3
});
}
} else {
for (var _i4 = year - 1; _i4 > year - 10; _i4--) {
options.unshift({
label: "".concat(_i4),
value: _i4
});
}
}
return options;
}
var labelMap = {
year: {
prev: global.value.preDecade,
current: global.value.now,
next: global.value.nextDecade
},
month: {
prev: global.value.preYear,
current: global.value.now,
next: global.value.nextYear
},
date: {
prev: global.value.preMonth,
current: global.value.now,
next: global.value.nextMonth
}
};
function handlePanelTopClick(e) {
var _e$stopPropagation;
e === null || e === void 0 || (_e$stopPropagation = e.stopPropagation) === null || _e$stopPropagation === void 0 || _e$stopPropagation.call(e);
var firstYear = yearOptions.value[0].value;
var options = loadMoreYear(firstYear, "reduce");
yearOptions.value = [].concat(_toConsumableArray(options), _toConsumableArray(yearOptions.value));
}
function handlePanelBottomClick(e) {
var _e$stopPropagation2;
e === null || e === void 0 || (_e$stopPropagation2 = e.stopPropagation) === null || _e$stopPropagation2 === void 0 || _e$stopPropagation2.call(e);
var lastYear = yearOptions.value.slice(-1)[0].value;
var options = loadMoreYear(lastYear, "add");
yearOptions.value = [].concat(_toConsumableArray(yearOptions.value), _toConsumableArray(options));
}
function handleScroll(_ref) {
var e = _ref.e;
if (e.target.scrollTop === 0) {
handlePanelTopClick(e);
} else if (e.target.scrollTop === e.target.scrollHeight - e.target.clientHeight) {
handlePanelBottomClick(e);
}
}
return {
COMPONENT_NAME: COMPONENT_NAME,
labelMap: labelMap,
nearestYear: nearestYear,
classPrefix: classPrefix,
monthOptions: monthOptions,
yearOptions: yearOptions,
showMonthPicker: showMonthPicker,
handleScroll: handleScroll,
handlePanelTopClick: handlePanelTopClick,
handlePanelBottomClick: handlePanelBottomClick
};
},
render: function render() {
var _this = this;
var h = arguments[0];
var COMPONENT_NAME = this.COMPONENT_NAME,
labelMap = this.labelMap,
nearestYear = this.nearestYear,
classPrefix = this.classPrefix,
monthOptions = this.monthOptions,
yearOptions = this.yearOptions,
showMonthPicker = this.showMonthPicker,
handlePanelTopClick = this.handlePanelTopClick,
handlePanelBottomClick = this.handlePanelBottomClick;
return h("div", {
"class": COMPONENT_NAME
}, [h("div", {
"class": "".concat(COMPONENT_NAME, "-controller")
}, [showMonthPicker && h(Select, {
"class": "".concat(COMPONENT_NAME, "-controller-month"),
"props": _objectSpread({}, {
value: this.month,
options: monthOptions,
onChange: function onChange(val) {
var _this$onMonthChange;
return (_this$onMonthChange = _this.onMonthChange) === null || _this$onMonthChange === void 0 ? void 0 : _this$onMonthChange.call(_this, val);
},
popupProps: {
attach: function attach(triggerElement) {
return triggerElement.parentNode;
},
overlayClassName: "".concat(COMPONENT_NAME, "-controller-month-popup")
}
})
}), h(Select, {
"class": "".concat(COMPONENT_NAME, "-controller-year"),
"props": _objectSpread({}, {
value: this.mode === "year" ? nearestYear : this.year,
options: yearOptions,
onChange: function onChange(val) {
var _this$onYearChange;
return (_this$onYearChange = _this.onYearChange) === null || _this$onYearChange === void 0 ? void 0 : _this$onYearChange.call(_this, val);
},
popupProps: {
onScroll: this.handleScroll,
attach: function attach(triggerElement) {
return triggerElement.parentNode;
},
overlayClassName: "".concat(COMPONENT_NAME, "-controller-year-popup")
},
panelTopContent: function panelTopContent() {
return h("div", {
"class": "".concat(classPrefix, "-select-option"),
"on": {
"click": handlePanelTopClick
}
}, ["..."]);
},
panelBottomContent: function panelBottomContent() {
return h("div", {
"class": "".concat(classPrefix, "-select-option"),
"on": {
"click": handlePanelBottomClick
}
}, ["..."]);
}
})
})]), h(PaginationMini, {
"props": _objectSpread({}, {
tips: labelMap[this.mode],
onChange: this.onJumperClick,
size: "small"
})
})]);
}
});
export { TDateHeader as default };
//# sourceMappingURL=Header.js.map