UNPKG

devextreme

Version:

HTML5 JavaScript Component Suite for Responsive Web Development

285 lines (283 loc) • 12.7 kB
/** * DevExtreme (cjs/ui/calendar/ui.calendar.views.js) * Version: 21.2.4 * Build date: Mon Dec 06 2021 * * Copyright (c) 2012 - 2021 Developer Express Inc. ALL RIGHTS RESERVED * Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/ */ "use strict"; exports.default = void 0; var _renderer = _interopRequireDefault(require("../../core/renderer")); var _uiCalendar = _interopRequireDefault(require("./ui.calendar.base_view")); var _common = require("../../core/utils/common"); var _date = _interopRequireDefault(require("../../core/utils/date")); var _extend = require("../../core/utils/extend"); var _date2 = _interopRequireDefault(require("../../localization/date")); var _date_serialization = _interopRequireDefault(require("../../core/utils/date_serialization")); var _type = require("../../core/utils/type"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj } } var CALENDAR_OTHER_MONTH_CLASS = "dx-calendar-other-month"; var CALENDAR_OTHER_VIEW_CLASS = "dx-calendar-other-view"; var Views = { month: _uiCalendar.default.inherit({ _getViewName: function() { return "month" }, _getDefaultOptions: function() { return (0, _extend.extend)(this.callBase(), { firstDayOfWeek: void 0, rowCount: 6, colCount: 7 }) }, _renderImpl: function() { this.callBase(); this._renderHeader() }, _renderBody: function() { this.callBase(); this._$table.find(".".concat(CALENDAR_OTHER_VIEW_CLASS)).addClass(CALENDAR_OTHER_MONTH_CLASS) }, _renderFocusTarget: _common.noop, getCellAriaLabel: function(date) { return _date2.default.format(date, "longdate") }, _renderHeader: function() { var $headerRow = (0, _renderer.default)("<tr>"); var $header = (0, _renderer.default)("<thead>").append($headerRow); this._$table.prepend($header); for (var colIndex = 0, colCount = this.option("colCount"); colIndex < colCount; colIndex++) { this._renderHeaderCell(colIndex, $headerRow) } }, _renderHeaderCell: function(cellIndex, $headerRow) { var _this$_getDayCaption = this._getDayCaption(this._getFirstDayOfWeek() + cellIndex), fullCaption = _this$_getDayCaption.full, abbrCaption = _this$_getDayCaption.abbreviated; var $cell = (0, _renderer.default)("<th>").attr({ scope: "col", abbr: fullCaption }).text(abbrCaption); this._appendCell($headerRow, $cell) }, getNavigatorCaption: function() { return _date2.default.format(this.option("date"), "monthandyear") }, _isTodayCell: function(cellDate) { var today = this.option("_todayDate")(); return _date.default.sameDate(cellDate, today) }, _isDateOutOfRange: function(cellDate) { var minDate = this.option("min"); var maxDate = this.option("max"); return !_date.default.dateInRange(cellDate, minDate, maxDate, "date") }, _isOtherView: function(cellDate) { return cellDate.getMonth() !== this.option("date").getMonth() }, _getCellText: function(cellDate) { return _date2.default.format(cellDate, "d") }, _getDayCaption: function(day) { var daysInWeek = this.option("colCount"); var dayIndex = day % daysInWeek; return { full: _date2.default.getDayNames()[dayIndex], abbreviated: _date2.default.getDayNames("abbreviated")[dayIndex] } }, _getFirstCellData: function() { var firstDay = _date.default.getFirstMonthDate(this.option("date")); var firstMonthDayOffset = this._getFirstDayOfWeek() - firstDay.getDay(); var daysInWeek = this.option("colCount"); if (firstMonthDayOffset >= 0) { firstMonthDayOffset -= daysInWeek } firstDay.setDate(firstDay.getDate() + firstMonthDayOffset); return firstDay }, _getNextCellData: function(date) { date = new Date(date); date.setDate(date.getDate() + 1); return date }, _getFirstDayOfWeek: function() { return (0, _type.isDefined)(this.option("firstDayOfWeek")) ? this.option("firstDayOfWeek") : _date2.default.firstDayOfWeekIndex() }, _getCellByDate: function(date) { return this._$table.find("td[data-value='".concat(_date_serialization.default.serializeDate(date, _date.default.getShortDateFormat()), "']")) }, isBoundary: function(date) { return _date.default.sameMonthAndYear(date, this.option("min")) || _date.default.sameMonthAndYear(date, this.option("max")) }, _getDefaultDisabledDatesHandler: function(disabledDates) { return function(args) { var isDisabledDate = disabledDates.some((function(item) { return _date.default.sameDate(item, args.date) })); if (isDisabledDate) { return true } } } }), year: _uiCalendar.default.inherit({ _getViewName: function() { return "year" }, _isTodayCell: function(cellDate) { var today = this.option("_todayDate")(); return _date.default.sameMonthAndYear(cellDate, today) }, _isDateOutOfRange: function(cellDate) { return !_date.default.dateInRange(cellDate, _date.default.getFirstMonthDate(this.option("min")), _date.default.getLastMonthDate(this.option("max"))) }, _isOtherView: function() { return false }, _getCellText: function(cellDate) { return _date2.default.getMonthNames("abbreviated")[cellDate.getMonth()] }, _getFirstCellData: function() { var currentDate = this.option("date"); var data = new Date(currentDate); data.setDate(1); data.setMonth(0); return data }, _getNextCellData: function(date) { date = new Date(date); date.setMonth(date.getMonth() + 1); return date }, _getCellByDate: function(date) { var foundDate = new Date(date); foundDate.setDate(1); return this._$table.find("td[data-value='".concat(_date_serialization.default.serializeDate(foundDate, _date.default.getShortDateFormat()), "']")) }, getCellAriaLabel: function(date) { return _date2.default.format(date, "monthandyear") }, getNavigatorCaption: function() { return _date2.default.format(this.option("date"), "yyyy") }, isBoundary: function(date) { return _date.default.sameYear(date, this.option("min")) || _date.default.sameYear(date, this.option("max")) } }), decade: _uiCalendar.default.inherit({ _getViewName: function() { return "decade" }, _isTodayCell: function(cellDate) { var today = this.option("_todayDate")(); return _date.default.sameYear(cellDate, today) }, _isDateOutOfRange: function(cellDate) { var min = this.option("min"); var max = this.option("max"); return !_date.default.dateInRange(cellDate.getFullYear(), min && min.getFullYear(), max && max.getFullYear()) }, _isOtherView: function(cellDate) { var date = new Date(cellDate); date.setMonth(1); return !_date.default.sameDecade(date, this.option("date")) }, _getCellText: function(cellDate) { return _date2.default.format(cellDate, "yyyy") }, _getFirstCellData: function() { var year = _date.default.getFirstYearInDecade(this.option("date")) - 1; return _date.default.createDateWithFullYear(year, 0, 1) }, _getNextCellData: function(date) { date = new Date(date); date.setFullYear(date.getFullYear() + 1); return date }, getNavigatorCaption: function() { var currentDate = this.option("date"); var firstYearInDecade = _date.default.getFirstYearInDecade(currentDate); var startDate = new Date(currentDate); var endDate = new Date(currentDate); startDate.setFullYear(firstYearInDecade); endDate.setFullYear(firstYearInDecade + 9); return _date2.default.format(startDate, "yyyy") + "-" + _date2.default.format(endDate, "yyyy") }, _isValueOnCurrentView: function(currentDate, value) { return _date.default.sameDecade(currentDate, value) }, _getCellByDate: function(date) { var foundDate = new Date(date); foundDate.setDate(1); foundDate.setMonth(0); return this._$table.find("td[data-value='".concat(_date_serialization.default.serializeDate(foundDate, _date.default.getShortDateFormat()), "']")) }, isBoundary: function(date) { return _date.default.sameDecade(date, this.option("min")) || _date.default.sameDecade(date, this.option("max")) } }), century: _uiCalendar.default.inherit({ _getViewName: function() { return "century" }, _isTodayCell: function(cellDate) { var today = this.option("_todayDate")(); return _date.default.sameDecade(cellDate, today) }, _isDateOutOfRange: function(cellDate) { var decade = _date.default.getFirstYearInDecade(cellDate); var minDecade = _date.default.getFirstYearInDecade(this.option("min")); var maxDecade = _date.default.getFirstYearInDecade(this.option("max")); return !_date.default.dateInRange(decade, minDecade, maxDecade) }, _isOtherView: function(cellDate) { var date = new Date(cellDate); date.setMonth(1); return !_date.default.sameCentury(date, this.option("date")) }, _getCellText: function(cellDate) { var startDate = _date2.default.format(cellDate, "yyyy"); var endDate = new Date(cellDate); endDate.setFullYear(endDate.getFullYear() + 9); return startDate + " - " + _date2.default.format(endDate, "yyyy") }, _getFirstCellData: function() { var decade = _date.default.getFirstDecadeInCentury(this.option("date")) - 10; return _date.default.createDateWithFullYear(decade, 0, 1) }, _getNextCellData: function(date) { date = new Date(date); date.setFullYear(date.getFullYear() + 10); return date }, _getCellByDate: function(date) { var foundDate = new Date(date); foundDate.setDate(1); foundDate.setMonth(0); foundDate.setFullYear(_date.default.getFirstYearInDecade(foundDate)); return this._$table.find("td[data-value='".concat(_date_serialization.default.serializeDate(foundDate, _date.default.getShortDateFormat()), "']")) }, getNavigatorCaption: function() { var currentDate = this.option("date"); var firstDecadeInCentury = _date.default.getFirstDecadeInCentury(currentDate); var startDate = new Date(currentDate); var endDate = new Date(currentDate); startDate.setFullYear(firstDecadeInCentury); endDate.setFullYear(firstDecadeInCentury + 99); return _date2.default.format(startDate, "yyyy") + "-" + _date2.default.format(endDate, "yyyy") }, isBoundary: function(date) { return _date.default.sameCentury(date, this.option("min")) || _date.default.sameCentury(date, this.option("max")) } }) }; var _default = Views; exports.default = _default; module.exports = exports.default; module.exports.default = exports.default;