UNPKG

devextreme

Version:

HTML5 JavaScript Component Suite for Responsive Web Development

338 lines (335 loc) • 13.4 kB
/** * DevExtreme (cjs/__internal/ui/date_box/m_date_view.js) * Version: 24.2.6 * Build date: Mon Mar 17 2025 * * Copyright (c) 2012 - 2025 Developer Express Inc. ALL RIGHTS RESERVED * Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/ */ "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _date = _interopRequireDefault(require("../../../common/core/localization/date")); var _component_registrator = _interopRequireDefault(require("../../../core/component_registrator")); var _renderer = _interopRequireDefault(require("../../../core/renderer")); var _date2 = _interopRequireDefault(require("../../../core/utils/date")); var _iterator = require("../../../core/utils/iterator"); var _editor = _interopRequireDefault(require("../../ui/editor/editor")); var _m_date_utils = _interopRequireDefault(require("./m_date_utils")); var _m_date_view_roller = _interopRequireDefault(require("./m_date_view_roller")); function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e } } function _extends() { return _extends = Object.assign ? Object.assign.bind() : function(n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) { ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]) } } return n }, _extends.apply(null, arguments) } const DATEVIEW_CLASS = "dx-dateview"; const DATEVIEW_COMPACT_CLASS = "dx-dateview-compact"; const DATEVIEW_WRAPPER_CLASS = "dx-dateview-wrapper"; const DATEVIEW_ROLLER_CONTAINER_CLASS = "dx-dateview-rollers"; const DATEVIEW_ROLLER_CLASS = "dx-dateviewroller"; const TYPE = { date: "date", datetime: "datetime", time: "time" }; const ROLLER_TYPE = { year: "year", month: "month", day: "day", hours: "hours" }; class DateView extends _editor.default { _valueOption() { const { value: value } = this.option(); const date = new Date(value); return !value || isNaN(date) ? this._getDefaultDate() : date } _getDefaultDate() { const date = new Date; const { type: type } = this.option(); if (type === TYPE.date) { return new Date(date.getFullYear(), date.getMonth(), date.getDate()) } return date } _getDefaultOptions() { return _extends({}, super._getDefaultOptions(), { minDate: _m_date_utils.default.MIN_DATEVIEW_DEFAULT_DATE, maxDate: _m_date_utils.default.MAX_DATEVIEW_DEFAULT_DATE, type: TYPE.date, value: new Date, applyCompactClass: false }) } _defaultOptionsRules() { return super._defaultOptionsRules().concat([{ device: device => "desktop" !== device.deviceType, options: { applyCompactClass: true } }]) } _render() { super._render(); this.$element().addClass("dx-dateview"); const { type: type } = this.option(); this._toggleFormatClasses(type); this._toggleCompactClass() } _toggleFormatClasses(currentFormat, previousFormat) { this.$element().addClass(`dx-dateview-${currentFormat}`); previousFormat && this.$element().removeClass(`dx-dateview-${previousFormat}`) } _toggleCompactClass() { const { applyCompactClass: applyCompactClass } = this.option(); this.$element().toggleClass("dx-dateview-compact", applyCompactClass) } _wrapper() { return this._$wrapper } _renderContentImpl() { this._$wrapper = (0, _renderer.default)("<div>").addClass("dx-dateview-wrapper"); this._renderRollers(); this._$wrapper.appendTo(this.$element()) } _renderRollers() { if (!this._$rollersContainer) { this._$rollersContainer = (0, _renderer.default)("<div>").addClass("dx-dateview-rollers") } this._$rollersContainer.empty(); this._createRollerConfigs(); this._rollers = {}; const that = this; (0, _iterator.each)(that._rollerConfigs, (name => { const $roller = (0, _renderer.default)("<div>").appendTo(that._$rollersContainer).addClass(`dx-dateviewroller-${that._rollerConfigs[name].type}`); that._rollers[that._rollerConfigs[name].type] = that._createComponent($roller, _m_date_view_roller.default, { items: that._rollerConfigs[name].displayItems, selectedIndex: that._rollerConfigs[name].selectedIndex, showScrollbar: "never", scrollByContent: true, onStart(e) { const roller = e.component; roller._toggleActive(true); that._setActiveRoller(that._rollerConfigs[name]) }, onEnd(e) { const roller = e.component; roller._toggleActive(false) }, onClick(e) { const roller = e.component; roller._toggleActive(true); that._setActiveRoller(that._rollerConfigs[name]); that._setRollerState(that._rollerConfigs[name], roller.option("selectedIndex")); roller._toggleActive(false) }, onSelectedIndexChanged(e) { const roller = e.component; that._setRollerState(that._rollerConfigs[name], roller.option("selectedIndex")) } }) })); that._$rollersContainer.appendTo(that._wrapper()) } _createRollerConfigs(type) { const that = this; type = type || that.option("type"); that._rollerConfigs = {}; _date.default.getFormatParts(_m_date_utils.default.FORMATS_MAP[type]).forEach((partName => { that._createRollerConfig(partName) })) } _createRollerConfig(componentName) { const componentInfo = _m_date_utils.default.DATE_COMPONENTS_INFO[componentName]; const valueRange = this._calculateRollerConfigValueRange(componentName); const { startValue: startValue } = valueRange; const { endValue: endValue } = valueRange; const { formatter: formatter } = componentInfo; const curDate = this._getCurrentDate(); const config = { type: componentName, setValue: componentInfo.setter, valueItems: [], displayItems: [], getIndex: value => value[componentInfo.getter]() - startValue }; for (let i = startValue; i <= endValue; i++) { config.valueItems.push(i); config.displayItems.push(formatter(i, curDate)) } config.selectedIndex = config.getIndex(curDate); this._rollerConfigs[componentName] = config } _setActiveRoller(currentRoller) { const activeRoller = currentRoller && this._rollers[currentRoller.type]; (0, _iterator.each)(this._rollers, (function() { this.toggleActiveState(this === activeRoller) })) } _updateRollersPosition() { const that = this; (0, _iterator.each)(this._rollers, (function(type) { const correctIndex = that._rollerConfigs[type].getIndex(that._getCurrentDate()); this.option("selectedIndex", correctIndex) })) } _setRollerState(roller, selectedIndex) { if (selectedIndex !== roller.selectedIndex) { const rollerValue = roller.valueItems[selectedIndex]; const { setValue: setValue } = roller; let currentValue = new Date(this._getCurrentDate()); let currentDate = currentValue.getDate(); const minDate = this.option("minDate"); const maxDate = this.option("maxDate"); if (roller.type === ROLLER_TYPE.month) { currentDate = Math.min(currentDate, _m_date_utils.default.getMaxMonthDay(currentValue.getFullYear(), rollerValue)) } else if (roller.type === ROLLER_TYPE.year) { currentDate = Math.min(currentDate, _m_date_utils.default.getMaxMonthDay(rollerValue, currentValue.getMonth())) } currentValue.setDate(currentDate); currentValue[setValue](rollerValue); const normalizedDate = _date2.default.normalizeDate(currentValue, minDate, maxDate); currentValue = _m_date_utils.default.mergeDates(normalizedDate, currentValue, "time"); currentValue = _date2.default.normalizeDate(currentValue, minDate, maxDate); this.option("value", currentValue); roller.selectedIndex = selectedIndex } if (roller.type === ROLLER_TYPE.year) { this._refreshRollers() } if (roller.type === ROLLER_TYPE.month) { this._refreshRoller(ROLLER_TYPE.day); this._refreshRoller(ROLLER_TYPE.hours) } } _refreshRoller(rollerType) { const roller = this._rollers[rollerType]; if (roller) { this._createRollerConfig(rollerType); const rollerConfig = this._rollerConfigs[rollerType]; if (rollerType === ROLLER_TYPE.day || rollerConfig.displayItems.toString() !== roller.option("items").toString()) { roller.option({ items: rollerConfig.displayItems, selectedIndex: rollerConfig.selectedIndex }) } } } _getCurrentDate() { const curDate = this._valueOption(); const minDate = this.option("minDate"); const maxDate = this.option("maxDate"); return _date2.default.normalizeDate(curDate, minDate, maxDate) } _calculateRollerConfigValueRange(componentName) { const curDate = this._getCurrentDate(); const { minDate: minDate, maxDate: maxDate } = this.option(); const minYear = _date2.default.sameYear(curDate, minDate); const minMonth = minYear && curDate.getMonth() === minDate.getMonth(); const maxYear = _date2.default.sameYear(curDate, maxDate); const maxMonth = maxYear && curDate.getMonth() === maxDate.getMonth(); const minHour = minMonth && curDate.getDate() === minDate.getDate(); const maxHour = maxMonth && curDate.getDate() === maxDate.getDate(); const componentInfo = _m_date_utils.default.DATE_COMPONENTS_INFO[componentName]; let { startValue: startValue } = componentInfo; let { endValue: endValue } = componentInfo; if (componentName === ROLLER_TYPE.year) { startValue = minDate.getFullYear(); endValue = maxDate.getFullYear() } if (componentName === ROLLER_TYPE.month) { if (minYear) { startValue = minDate.getMonth() } if (maxYear) { endValue = maxDate.getMonth() } } if (componentName === ROLLER_TYPE.day) { endValue = _m_date_utils.default.getMaxMonthDay(curDate.getFullYear(), curDate.getMonth()); if (minYear && minMonth) { startValue = minDate.getDate() } if (maxYear && maxMonth) { endValue = maxDate.getDate() } } if (componentName === ROLLER_TYPE.hours) { startValue = minHour ? minDate.getHours() : startValue; endValue = maxHour ? maxDate.getHours() : endValue } return { startValue: startValue, endValue: endValue } } _refreshRollers() { this._refreshRoller(ROLLER_TYPE.month); this._refreshRoller(ROLLER_TYPE.day); this._refreshRoller(ROLLER_TYPE.hours) } _optionChanged(args) { switch (args.name) { case "minDate": case "maxDate": case "type": this._renderRollers(); this._toggleFormatClasses(args.value, args.previousValue); break; case "visible": super._optionChanged(args); if (args.value) { this._renderRollers() } break; case "value": this.option("value", this._valueOption()); this._refreshRollers(); this._updateRollersPosition(); break; default: super._optionChanged(args) } } _clean() { super._clean(); delete this._$rollersContainer } }(0, _component_registrator.default)("dxDateView", DateView); var _default = exports.default = DateView;