| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508 |
- /**
- * DevExtreme (ui/scheduler/rendering_strategies/ui.scheduler.appointments.strategy.vertical.js)
- * Version: 19.1.16
- * Build date: Tue Oct 18 2022
- *
- * Copyright (c) 2012 - 2022 Developer Express Inc. ALL RIGHTS RESERVED
- * Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/
- */
- "use strict";
- function _typeof(obj) {
- "@babel/helpers - typeof";
- return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function(obj) {
- return typeof obj
- } : function(obj) {
- return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj
- }, _typeof(obj)
- }
- var _uiSchedulerAppointmentsStrategy = require("./ui.scheduler.appointments.strategy.base");
- var _uiSchedulerAppointmentsStrategy2 = _interopRequireDefault(_uiSchedulerAppointmentsStrategy);
- var _extend = require("../../../core/utils/extend");
- var _type = require("../../../core/utils/type");
- var _devices = require("../../../core/devices");
- var _devices2 = _interopRequireDefault(_devices);
- var _date = require("../../../core/utils/date");
- var _date2 = _interopRequireDefault(_date);
- function _interopRequireDefault(obj) {
- return obj && obj.__esModule ? obj : {
- "default": obj
- }
- }
- function _classCallCheck(instance, Constructor) {
- if (!(instance instanceof Constructor)) {
- throw new TypeError("Cannot call a class as a function")
- }
- }
- function _defineProperties(target, props) {
- for (var i = 0; i < props.length; i++) {
- var descriptor = props[i];
- descriptor.enumerable = descriptor.enumerable || false;
- descriptor.configurable = true;
- if ("value" in descriptor) {
- descriptor.writable = true
- }
- Object.defineProperty(target, descriptor.key, descriptor)
- }
- }
- function _createClass(Constructor, protoProps, staticProps) {
- if (protoProps) {
- _defineProperties(Constructor.prototype, protoProps)
- }
- if (staticProps) {
- _defineProperties(Constructor, staticProps)
- }
- Object.defineProperty(Constructor, "prototype", {
- writable: false
- });
- return Constructor
- }
- function _get() {
- if ("undefined" !== typeof Reflect && Reflect.get) {
- _get = Reflect.get.bind()
- } else {
- _get = function(target, property, receiver) {
- var base = _superPropBase(target, property);
- if (!base) {
- return
- }
- var desc = Object.getOwnPropertyDescriptor(base, property);
- if (desc.get) {
- return desc.get.call(arguments.length < 3 ? target : receiver)
- }
- return desc.value
- }
- }
- return _get.apply(this, arguments)
- }
- function _superPropBase(object, property) {
- while (!Object.prototype.hasOwnProperty.call(object, property)) {
- object = _getPrototypeOf(object);
- if (null === object) {
- break
- }
- }
- return object
- }
- function _inherits(subClass, superClass) {
- if ("function" !== typeof superClass && null !== superClass) {
- throw new TypeError("Super expression must either be null or a function")
- }
- subClass.prototype = Object.create(superClass && superClass.prototype, {
- constructor: {
- value: subClass,
- writable: true,
- configurable: true
- }
- });
- Object.defineProperty(subClass, "prototype", {
- writable: false
- });
- if (superClass) {
- _setPrototypeOf(subClass, superClass)
- }
- }
- function _setPrototypeOf(o, p) {
- _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function(o, p) {
- o.__proto__ = p;
- return o
- };
- return _setPrototypeOf(o, p)
- }
- function _createSuper(Derived) {
- var hasNativeReflectConstruct = _isNativeReflectConstruct();
- return function() {
- var result, Super = _getPrototypeOf(Derived);
- if (hasNativeReflectConstruct) {
- var NewTarget = _getPrototypeOf(this).constructor;
- result = Reflect.construct(Super, arguments, NewTarget)
- } else {
- result = Super.apply(this, arguments)
- }
- return _possibleConstructorReturn(this, result)
- }
- }
- function _possibleConstructorReturn(self, call) {
- if (call && ("object" === _typeof(call) || "function" === typeof call)) {
- return call
- } else {
- if (void 0 !== call) {
- throw new TypeError("Derived constructors may only return object or undefined")
- }
- }
- return _assertThisInitialized(self)
- }
- function _assertThisInitialized(self) {
- if (void 0 === self) {
- throw new ReferenceError("this hasn't been initialised - super() hasn't been called")
- }
- return self
- }
- function _isNativeReflectConstruct() {
- if ("undefined" === typeof Reflect || !Reflect.construct) {
- return false
- }
- if (Reflect.construct.sham) {
- return false
- }
- if ("function" === typeof Proxy) {
- return true
- }
- try {
- Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function() {}));
- return true
- } catch (e) {
- return false
- }
- }
- function _getPrototypeOf(o) {
- _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function(o) {
- return o.__proto__ || Object.getPrototypeOf(o)
- };
- return _getPrototypeOf(o)
- }
- var WEEK_APPOINTMENT_DEFAULT_OFFSET = 25;
- var WEEK_APPOINTMENT_MOBILE_OFFSET = 50;
- var APPOINTMENT_MIN_WIDTH = 5;
- var ALLDAY_APPOINTMENT_MIN_VERTICAL_OFFSET = 5;
- var ALLDAY_APPOINTMENT_MAX_VERTICAL_OFFSET = 20;
- var toMs = _date2.default.dateToMilliseconds;
- var VerticalRenderingStrategy = function(_BaseAppointmentsStra) {
- _inherits(VerticalRenderingStrategy, _BaseAppointmentsStra);
- var _super = _createSuper(VerticalRenderingStrategy);
- function VerticalRenderingStrategy() {
- _classCallCheck(this, VerticalRenderingStrategy);
- return _super.apply(this, arguments)
- }
- _createClass(VerticalRenderingStrategy, [{
- key: "getDeltaTime",
- value: function(args, initialSize, appointment) {
- var deltaTime = 0;
- if (this.isAllDay(appointment)) {
- deltaTime = this._getDeltaWidth(args, initialSize) * toMs("day")
- } else {
- var deltaHeight = args.height - initialSize.height;
- deltaTime = toMs("minute") * Math.round(deltaHeight / this.getDefaultCellHeight() * this.instance.getAppointmentDurationInMinutes())
- }
- return deltaTime
- }
- }, {
- key: "getAppointmentGeometry",
- value: function(coordinates) {
- var result;
- var allDay = coordinates.allDay;
- if (allDay) {
- result = this._getAllDayAppointmentGeometry(coordinates)
- } else {
- result = this._getVerticalAppointmentGeometry(coordinates)
- }
- return _get(_getPrototypeOf(VerticalRenderingStrategy.prototype), "getAppointmentGeometry", this).call(this, result)
- }
- }, {
- key: "_getItemPosition",
- value: function(item) {
- var allDay = this.isAllDay(item);
- var isRecurring = !!this.instance.fire("getField", "recurrenceRule", item);
- if (allDay) {
- return _get(_getPrototypeOf(VerticalRenderingStrategy.prototype), "_getItemPosition", this).call(this, item)
- }
- var position = this._getAppointmentCoordinates(item);
- var result = [];
- for (var j = 0; j < position.length; j++) {
- var height = this.calculateAppointmentHeight(item, position[j], isRecurring);
- var width = this.calculateAppointmentWidth(item, position[j], isRecurring);
- var resultHeight = height;
- var appointmentReduced = null;
- var multiDaysAppointmentParts = [];
- var currentMaxAllowedPosition = position[j].vMax;
- if (this._isMultiDayAppointment(position[j], height)) {
- appointmentReduced = "head";
- resultHeight = this._reduceMultiDayAppointment(height, {
- top: position[j].top,
- bottom: currentMaxAllowedPosition
- });
- multiDaysAppointmentParts = this._getAppointmentParts({
- sourceAppointmentHeight: height,
- reducedHeight: resultHeight,
- width: width
- }, position[j])
- }(0, _extend.extend)(position[j], {
- height: resultHeight,
- width: width,
- allDay: allDay,
- appointmentReduced: appointmentReduced
- });
- result = this._getAppointmentPartsPosition(multiDaysAppointmentParts, position[j], result)
- }
- return result
- }
- }, {
- key: "_isMultiDayAppointment",
- value: function(position, height) {
- var maxTop = position.vMax;
- var result = height > maxTop - position.top;
- return result
- }
- }, {
- key: "_reduceMultiDayAppointment",
- value: function(sourceAppointmentHeight, bound) {
- sourceAppointmentHeight = bound.bottom - Math.floor(bound.top);
- return sourceAppointmentHeight
- }
- }, {
- key: "_getAppointmentParts",
- value: function(appointmentGeometry, appointmentSettings) {
- var tailHeight = appointmentGeometry.sourceAppointmentHeight - appointmentGeometry.reducedHeight;
- var width = appointmentGeometry.width;
- var result = [];
- var currentPartTop = this.instance.fire("getGroupTop", appointmentSettings.groupIndex);
- var offset = this.instance.fire("isGroupedByDate") ? this.getDefaultCellWidth() * this.instance.fire("getGroupCount") : this.getDefaultCellWidth();
- var left = appointmentSettings.left + offset;
- if (tailHeight) {
- var minHeight = this.getAppointmentMinSize();
- if (tailHeight < minHeight) {
- tailHeight = minHeight
- }
- currentPartTop += this.instance.fire("getOffsetByAllDayPanel", appointmentSettings.groupIndex);
- result.push((0, _extend.extend)(true, {}, appointmentSettings, {
- top: currentPartTop,
- left: left,
- height: tailHeight,
- width: width,
- appointmentReduced: "tail",
- rowIndex: ++appointmentSettings.rowIndex
- }))
- }
- return result
- }
- }, {
- key: "_getMinuteHeight",
- value: function() {
- return this.getDefaultCellHeight() / this.instance.getAppointmentDurationInMinutes()
- }
- }, {
- key: "_getCompactLeftCoordinate",
- value: function(itemLeft, index) {
- var cellBorderSize = 1;
- var cellWidth = this.getDefaultCellWidth() || this.getAppointmentMinSize();
- return itemLeft + (cellBorderSize + cellWidth) * index
- }
- }, {
- key: "_checkLongCompactAppointment",
- value: function(item, result) {
- this._splitLongCompactAppointment(item, result);
- return result
- }
- }, {
- key: "_getVerticalAppointmentGeometry",
- value: function(coordinates) {
- var overlappingMode = this.instance.fire("getMaxAppointmentsPerCell");
- if (overlappingMode) {
- var config = this._calculateVerticalGeometryConfig(coordinates);
- return this._customizeVerticalCoordinates(coordinates, config.width, config.appointmentCountPerCell, config.offset)
- } else {
- var width = this._getAppointmentMaxWidth() / coordinates.count;
- var height = coordinates.height;
- var top = coordinates.top;
- var left = coordinates.left + coordinates.index * width;
- if (width < APPOINTMENT_MIN_WIDTH) {
- width = APPOINTMENT_MIN_WIDTH
- }
- return {
- height: height,
- width: width,
- top: top,
- left: left,
- empty: this._isAppointmentEmpty(height, width)
- }
- }
- }
- }, {
- key: "_customizeVerticalCoordinates",
- value: function(coordinates, width, appointmentCountPerCell, topOffset, isAllDay) {
- var index = coordinates.index;
- var appointmentWidth = Math.max(width / appointmentCountPerCell, width / coordinates.count);
- var height = coordinates.height;
- var appointmentLeft = coordinates.left + coordinates.index * appointmentWidth;
- var top = coordinates.top;
- var compactAppointmentDefaultSize;
- var compactAppointmentDefaultOffset;
- if (coordinates.isCompact) {
- compactAppointmentDefaultSize = this.getCompactAppointmentDefaultWidth();
- compactAppointmentDefaultOffset = this.getCompactAppointmentLeftOffset();
- top = coordinates.top + compactAppointmentDefaultOffset;
- appointmentLeft = coordinates.left + (index - appointmentCountPerCell) * (compactAppointmentDefaultSize + compactAppointmentDefaultOffset) + compactAppointmentDefaultOffset;
- appointmentWidth = compactAppointmentDefaultSize;
- width = compactAppointmentDefaultSize;
- this._markAppointmentAsVirtual(coordinates, isAllDay)
- }
- return {
- height: height,
- width: appointmentWidth,
- top: top,
- left: appointmentLeft,
- empty: this._isAppointmentEmpty(height, width)
- }
- }
- }, {
- key: "_calculateVerticalGeometryConfig",
- value: function(coordinates) {
- var overlappingMode = this.instance.fire("getMaxAppointmentsPerCell");
- var offsets = this._getOffsets();
- var appointmentDefaultOffset = this._getAppointmentDefaultOffset();
- var appointmentCountPerCell = this._getAppointmentCount(overlappingMode, coordinates);
- var ratio = this._getDefaultRatio(coordinates, appointmentCountPerCell);
- var maxWidth = this._getMaxWidth();
- if (!appointmentCountPerCell) {
- appointmentCountPerCell = coordinates.count;
- ratio = (maxWidth - offsets.unlimited) / maxWidth
- }
- var topOffset = (1 - ratio) * maxWidth;
- if ("auto" === overlappingMode || (0, _type.isNumeric)(overlappingMode)) {
- ratio = 1;
- maxWidth -= appointmentDefaultOffset;
- topOffset = 0
- }
- return {
- width: ratio * maxWidth,
- appointmentCountPerCell: appointmentCountPerCell,
- offset: topOffset
- }
- }
- }, {
- key: "_getMaxWidth",
- value: function() {
- return this.getDefaultCellWidth() || this.invoke("getCellWidth")
- }
- }, {
- key: "isAllDay",
- value: function(appointmentData) {
- var allDay = this.instance.fire("getField", "allDay", appointmentData);
- if (allDay) {
- return true
- }
- return this.instance.appointmentTakesAllDay(appointmentData)
- }
- }, {
- key: "_getAppointmentMaxWidth",
- value: function() {
- var offset = "desktop" === _devices2.default.current().deviceType && !this.instance.fire("isAdaptive") ? WEEK_APPOINTMENT_DEFAULT_OFFSET : WEEK_APPOINTMENT_MOBILE_OFFSET;
- var width = this.getDefaultCellWidth() - offset;
- return width > 0 ? width : this.getAppointmentMinSize()
- }
- }, {
- key: "calculateAppointmentWidth",
- value: function(appointment, position, isRecurring) {
- if (!this.isAllDay(appointment)) {
- return 0
- }
- var startDate = new Date(this.startDate(appointment, false, position));
- var endDate = this.endDate(appointment, position, isRecurring);
- var cellWidth = this.getDefaultCellWidth() || this.getAppointmentMinSize();
- startDate = _date2.default.trimTime(startDate);
- var durationInHours = (endDate.getTime() - startDate.getTime()) / toMs("hour");
- var width = Math.ceil(durationInHours / 24) * cellWidth;
- width = this.cropAppointmentWidth(width, cellWidth);
- return width
- }
- }, {
- key: "calculateAppointmentHeight",
- value: function(appointment, position, isRecurring) {
- var endDate = this.endDate(appointment, position, isRecurring);
- var startDate = this.startDate(appointment, false, position);
- var allDay = this.instance.fire("getField", "allDay", appointment);
- if (this.isAllDay(appointment)) {
- return 0
- }
- var fullDuration = this._getAppointmentDurationInMs(startDate, endDate, allDay);
- var durationInMinutes = this._adjustDurationByDaylightDiff(fullDuration, startDate, endDate) / toMs("minute");
- var height = durationInMinutes * this._getMinuteHeight();
- return height
- }
- }, {
- key: "getDirection",
- value: function() {
- return "vertical"
- }
- }, {
- key: "_sortCondition",
- value: function(a, b) {
- var allDayCondition = a.allDay - b.allDay;
- var isAllDay = a.allDay && b.allDay;
- var condition = "vertical" === this.instance._groupOrientation && isAllDay ? this._columnCondition(a, b) : this._rowCondition(a, b);
- return allDayCondition ? allDayCondition : condition
- }
- }, {
- key: "hasAllDayAppointments",
- value: function() {
- return true
- }
- }, {
- key: "_getAllDayAppointmentGeometry",
- value: function(coordinates) {
- var config = this._calculateGeometryConfig(coordinates);
- return this._customizeCoordinates(coordinates, config.height, config.appointmentCountPerCell, config.offset, true)
- }
- }, {
- key: "_calculateGeometryConfig",
- value: function(coordinates) {
- if (!this.instance._allowResizing() || !this.instance._allowAllDayResizing()) {
- coordinates.skipResizing = true
- }
- var config = _get(_getPrototypeOf(VerticalRenderingStrategy.prototype), "_calculateGeometryConfig", this).call(this, coordinates);
- if (coordinates.count <= this._getDynamicAppointmentCountPerCell().allDay) {
- config.offset = 0
- }
- return config
- }
- }, {
- key: "_getAppointmentCount",
- value: function(overlappingMode, coordinates) {
- return "auto" !== overlappingMode && 1 === coordinates.count && !(0, _type.isNumeric)(overlappingMode) ? coordinates.count : this._getMaxAppointmentCountPerCellByType(coordinates.allDay)
- }
- }, {
- key: "_getDefaultRatio",
- value: function(coordinates, appointmentCountPerCell) {
- return coordinates.count > this.instance.option("_appointmentCountPerCell") ? .65 : 1
- }
- }, {
- key: "_getOffsets",
- value: function() {
- return {
- unlimited: ALLDAY_APPOINTMENT_MIN_VERTICAL_OFFSET,
- auto: ALLDAY_APPOINTMENT_MAX_VERTICAL_OFFSET
- }
- }
- }, {
- key: "_getMaxHeight",
- value: function() {
- return this.getDefaultAllDayCellHeight() || this.getAppointmentMinSize()
- }
- }, {
- key: "_needVerticalGroupBounds",
- value: function(allDay) {
- return !allDay
- }
- }, {
- key: "_needHorizontalGroupBounds",
- value: function() {
- return false
- }
- }]);
- return VerticalRenderingStrategy
- }(_uiSchedulerAppointmentsStrategy2.default);
- module.exports = VerticalRenderingStrategy;
|