devextreme
Version:
HTML5 JavaScript Component Suite for Responsive Web Development
688 lines (685 loc) • 32.5 kB
JavaScript
/**
* DevExtreme (ui/scheduler/ui.scheduler.subscribes.js)
* Version: 18.2.18
* 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";
var _renderer = require("../../core/renderer");
var _renderer2 = _interopRequireDefault(_renderer);
var _array = require("../../core/utils/array");
var _array2 = _interopRequireDefault(_array);
var _utils = require("./utils.recurrence");
var _utils2 = _interopRequireDefault(_utils);
var _type = require("../../core/utils/type");
var _type2 = _interopRequireDefault(_type);
var _date = require("../../core/utils/date");
var _date2 = _interopRequireDefault(_date);
var _iterator = require("../../core/utils/iterator");
var _translator = require("../../animation/translator");
var _translator2 = _interopRequireDefault(_translator);
var _common = require("../../core/utils/common");
var _extend = require("../../core/utils/extend");
var _date3 = require("../../localization/date");
var _date4 = _interopRequireDefault(_date3);
var _uiScheduler = require("./timezones/ui.scheduler.timezones");
var _uiScheduler2 = _interopRequireDefault(_uiScheduler);
var _deferred = require("../../core/utils/deferred");
function _interopRequireDefault(obj) {
return obj && obj.__esModule ? obj : {
"default": obj
}
}
var MINUTES_IN_HOUR = 60;
var toMs = _date2.default.dateToMilliseconds;
var subscribes = {
isCurrentViewAgenda: function() {
return "agenda" === this.option("currentView")
},
currentViewUpdated: function(currentView) {
this.option("currentView", currentView)
},
currentDateUpdated: function(date) {
this.option("currentDate", date)
},
setCellDataCacheAlias: function(appointment, geometry) {
this._workSpace.setCellDataCacheAlias(appointment, geometry)
},
needCoordinates: function(options) {
var _this = this;
var appointmentData = options.appointmentData,
startDate = options.startDate,
endDate = this._getEndDate(appointmentData),
recurrenceRule = this.fire("getField", "recurrenceRule", appointmentData),
recurrenceException = this._getRecurrenceException(appointmentData),
dateRange = this._workSpace.getDateRange(),
allDay = this.appointmentTakesAllDay(appointmentData),
startViewDate = this.appointmentTakesAllDay(appointmentData) ? _date2.default.trimTime(new Date(dateRange[0])) : dateRange[0],
originalStartDate = options.originalStartDate || startDate,
renderingStrategy = this.getLayoutManager().getRenderingStrategyInstance(),
firstDayOfWeek = this.getFirstDayOfWeek();
var recurrenceOptions = {
rule: recurrenceRule,
exception: recurrenceException,
start: originalStartDate,
end: endDate,
min: startViewDate,
max: dateRange[1],
firstDayOfWeek: firstDayOfWeek
};
var dates = _utils2.default.getDatesByRecurrence(recurrenceOptions),
initialDates = void 0;
if (!dates.length) {
dates.push(startDate);
initialDates = dates
} else {
initialDates = dates;
dates = dates.map(function(date) {
return _date2.default.roundDateByStartDayHour(date, _this._getCurrentViewOption("startDayHour"))
})
}
if (renderingStrategy.needSeparateAppointment(allDay)) {
var datesLength = dates.length,
longParts = [],
resultDates = [];
for (var i = 0; i < datesLength; i++) {
var endDateOfPart = renderingStrategy.endDate(appointmentData, {
startDate: dates[i]
}, !!recurrenceRule);
longParts = _date2.default.getDatesOfInterval(dates[i], endDateOfPart, {
milliseconds: this.getWorkSpace().getIntervalDuration(allDay)
});
resultDates = resultDates.concat(longParts)
}
dates = resultDates
}
var itemResources = this._resourcesManager.getResourcesFromItem(appointmentData);
allDay = this.appointmentTakesAllDay(appointmentData) && this._workSpace.supportAllDayRow();
options.callback(this._getCoordinates(initialDates, dates, itemResources, allDay))
},
isGroupedByDate: function() {
return this.getWorkSpace().isGroupedByDate()
},
showAppointmentTooltip: function(options) {
options.skipDateCalculation = true;
options.$appointment = (0, _renderer2.default)(options.target);
var appointmentData = options.data,
singleAppointmentData = this._getSingleAppointmentData(appointmentData, options);
this.showAppointmentTooltip(appointmentData, options.target, singleAppointmentData)
},
hideAppointmentTooltip: function() {
this.hideAppointmentTooltip()
},
showAddAppointmentPopup: function(appointmentData) {
var processedData = {};
(0, _iterator.each)(["startDate", "endDate", "allDay"], function(_, field) {
if (void 0 !== appointmentData[field]) {
this.fire("setField", field, processedData, appointmentData[field]);
delete appointmentData[field]
}
}.bind(this));
this.showAppointmentPopup((0, _extend.extend)(processedData, appointmentData), true)
},
showEditAppointmentPopup: function(options) {
var appointmentData = options.data;
options.$appointment = (0, _renderer2.default)(options.target);
options.skipHoursProcessing = true;
var singleAppointmentData = this._getSingleAppointmentData(appointmentData, options),
startDate = this.fire("getField", "startDate", singleAppointmentData);
this.showAppointmentPopup(appointmentData, false, singleAppointmentData, startDate)
},
updateAppointmentAfterResize: function(options) {
var targetAppointment = options.target,
singleAppointment = this._getSingleAppointmentData(targetAppointment, options),
startDate = this.fire("getField", "startDate", singleAppointment),
updatedData = (0, _extend.extend)(true, {}, options.data);
this._convertDatesByTimezoneBack(true, updatedData);
this._checkRecurringAppointment(targetAppointment, singleAppointment, startDate, function() {
this._updateAppointment(targetAppointment, updatedData, function() {
this._appointments.moveAppointmentBack()
})
}.bind(this))
},
updateAppointmentAfterDrag: function(options) {
var target = options.data,
updatedData = this._getUpdatedData(options),
newCellIndex = this._workSpace.getDroppableCellIndex(),
oldCellIndex = this._workSpace.getCellIndexByCoordinates(options.coordinates),
becomeAllDay = this.fire("getField", "allDay", updatedData),
wasAllDay = this.fire("getField", "allDay", target);
var appointment = (0, _extend.extend)({}, target, updatedData);
var movedToAllDay = this._workSpace.supportAllDayRow() && becomeAllDay,
cellData = this._workSpace.getCellDataByCoordinates(options.coordinates, movedToAllDay),
movedBetweenAllDayAndSimple = this._workSpace.supportAllDayRow() && (wasAllDay && !becomeAllDay || !wasAllDay && becomeAllDay);
if (newCellIndex !== oldCellIndex || movedBetweenAllDayAndSimple) {
this._checkRecurringAppointment(target, appointment, cellData.startDate, function() {
this._convertDatesByTimezoneBack(true, updatedData, appointment);
this._updateAppointment(target, appointment, function() {
this._appointments.moveAppointmentBack()
})
}.bind(this))
} else {
this._appointments.moveAppointmentBack()
}
},
deleteAppointment: function(options) {
options.$appointment = (0, _renderer2.default)(options.target);
var appointmentData = options.data,
singleAppointmentData = this._getSingleAppointmentData(appointmentData, options),
startDate = this.fire("getField", "startDate", singleAppointmentData);
this._checkRecurringAppointment(appointmentData, singleAppointmentData, startDate, function() {
this.deleteAppointment(appointmentData)
}.bind(this), true)
},
getResourceForPainting: function() {
return this._resourcesManager.getResourceForPainting(this._getCurrentViewOption("groups"))
},
getAppointmentColor: function(options) {
var resourcesManager = this._resourcesManager,
resourceForPainting = resourcesManager.getResourceForPainting(this._getCurrentViewOption("groups")),
response = (new _deferred.Deferred).resolve().promise();
if (resourceForPainting) {
var field = resourcesManager.getField(resourceForPainting),
groupIndex = options.groupIndex,
groups = this._workSpace._getCellGroups(groupIndex),
resourceValues = _array2.default.wrapToArray(resourcesManager.getDataAccessors(field, "getter")(options.itemData)),
groupId = resourceValues.length ? resourceValues[0] : void 0;
for (var i = 0; i < groups.length; i++) {
if (groups[i].name === field) {
groupId = groups[i].id;
break
}
}
response = resourcesManager.getResourceColor(field, groupId)
}
options.callback(response)
},
getHeaderHeight: function() {
return this._header._$element && parseInt(this._header._$element.outerHeight(), 10)
},
getResourcesFromItem: function(options) {
options.callback(this._resourcesManager.getResourcesFromItem(options.itemData))
},
getBoundOffset: function(options) {
options.callback({
top: -this.getWorkSpaceAllDayHeight()
})
},
appointmentTakesAllDay: function(options) {
options.callback(this.appointmentTakesAllDay(options.appointment))
},
appointmentTakesSeveralDays: function(appointment) {
return this._appointmentModel.appointmentTakesSeveralDays(appointment)
},
appointmentFocused: function() {
this._workSpace.restoreScrollTop()
},
getResizableAppointmentArea: function(options) {
var area = void 0,
allDay = options.allDay,
groups = this._getCurrentViewOption("groups"),
isGrouped = groups && groups.length;
if (isGrouped) {
if (allDay || this.getLayoutManager().getRenderingStrategyInstance()._needHorizontalGroupBounds()) {
var horizontalGroupBounds = this._workSpace.getGroupBounds(options.coordinates);
area = {
left: horizontalGroupBounds.left,
right: horizontalGroupBounds.right,
top: 0,
bottom: 0
}
}
if (this.getLayoutManager().getRenderingStrategyInstance()._needVerticalGroupBounds(allDay) && this._workSpace._isVerticalGroupedWorkSpace()) {
var verticalGroupBounds = this._workSpace.getGroupBounds(options.coordinates);
area = {
left: 0,
right: 0,
top: verticalGroupBounds.top,
bottom: verticalGroupBounds.bottom
}
}
}
options.callback(area)
},
needRecalculateResizableArea: function() {
return this.getWorkSpace().needRecalculateResizableArea()
},
getDraggableAppointmentArea: function(options) {
options.callback(this.getWorkSpaceScrollableContainer())
},
getAppointmentGeometry: function(settings) {
return this.getLayoutManager().getRenderingStrategyInstance().getAppointmentGeometry(settings)
},
isAllDay: function(appointmentData) {
return this.getLayoutManager().getRenderingStrategyInstance().isAllDay(appointmentData)
},
getDeltaTime: function(e, initialSize, itemData) {
return this.getLayoutManager().getRenderingStrategyInstance().getDeltaTime(e, initialSize, itemData)
},
getCompactAppointmentGroupMaxWidth: function(isAllDay) {
return this.getLayoutManager().getRenderingStrategyInstance().getCompactAppointmentGroupMaxWidth(this._getViewCountConfig().intervalCount, isAllDay)
},
getStartDate: function(appointmentData, skipNormalize) {
return this._getStartDate(appointmentData, skipNormalize)
},
getCellWidth: function() {
return this._cellWidth
},
getCellHeight: function() {
return this._cellHeight
},
getResizableStep: function() {
var cellWidth = this._cellWidth,
workSpace = this.getWorkSpace();
if (workSpace.isGroupedByDate()) {
return workSpace._getGroupCount() * cellWidth
}
return cellWidth
},
getEndDate: function(appointmentData, skipNormalize) {
return this._getEndDate(appointmentData, skipNormalize)
},
getRenderingStrategy: function() {
return this._getAppointmentsRenderingStrategy()
},
needCorrectAppointmentDates: function() {
return this.getRenderingStrategyInstance().needCorrectAppointmentDates()
},
getRenderingStrategyDirection: function() {
return this.getRenderingStrategyInstance().getDirection()
},
getWorkSpaceDateTableOffset: function() {
return this.getWorkSpaceDateTableOffset()
},
getDateTableWidth: function() {
return this._workSpace.getDateTableWidth()
},
getTimePanelWidth: function() {
return this._workSpace.getTimePanelWidth()
},
correctAppointmentCoordinates: function(options) {
var isAllDay = options.allDay,
containerSign = options.isFixedContainer ? -1 : 1;
var scrollTop = this.getWorkSpaceScrollableScrollTop(isAllDay),
allDayPanelTopOffset = !isAllDay ? this.getWorkSpaceAllDayOffset() : 0,
headerHeight = this.getWorkSpaceHeaderPanelHeight(),
scrollLeft = this.getWorkSpaceScrollableScrollLeft(),
tableLeftOffset = this.getWorkSpaceDateTableOffset();
var topOffset = -scrollTop + allDayPanelTopOffset + headerHeight,
leftOffset = -scrollLeft - tableLeftOffset;
options.callback({
top: options.coordinates.top + containerSign * topOffset,
left: options.coordinates.left + containerSign * leftOffset
})
},
allDayPanelToggled: function() {
this._appointments.updateDraggablesBoundOffsets()
},
formatDates: function(options) {
var startDate = options.startDate,
endDate = options.endDate,
formatType = options.formatType;
var formatTypes = {
DATETIME: function() {
var dateTimeFormat = "mediumdatemediumtime",
startDateString = _date4.default.format(startDate, dateTimeFormat) + " - ";
var endDateString = startDate.getDate() === endDate.getDate() ? _date4.default.format(endDate, "shorttime") : _date4.default.format(endDate, dateTimeFormat);
return startDateString + endDateString
},
TIME: function() {
return _date4.default.format(startDate, "shorttime") + " - " + _date4.default.format(endDate, "shorttime")
},
DATE: function() {
var dateTimeFormat = "monthAndDay",
startDateString = _date4.default.format(startDate, dateTimeFormat),
isDurationMoreThanDay = endDate.getTime() - startDate.getTime() > toMs("day");
var endDateString = isDurationMoreThanDay || endDate.getDate() !== startDate.getDate() ? " - " + _date4.default.format(endDate, dateTimeFormat) : "";
return startDateString + endDateString
}
};
options.callback(formatTypes[formatType]())
},
getFullWeekAppointmentWidth: function(options) {
var groupIndex = options.groupIndex,
groupWidth = this._workSpace.getGroupWidth(groupIndex);
options.callback(groupWidth)
},
getMaxAppointmentWidth: function(options) {
var cellCountToLastViewDate = this._workSpace.getCellCountToLastViewDate(options.date);
options.callback(cellCountToLastViewDate * this._workSpace.getCellWidth())
},
updateAppointmentStartDate: function(options) {
var appointment = options.appointment,
firstViewDate = this._workSpace.getStartViewDate(),
startDate = new Date(options.startDate),
startDayHour = this._getCurrentViewOption("startDayHour"),
updatedStartDate = void 0;
if (this.appointmentTakesAllDay(appointment)) {
updatedStartDate = _date2.default.normalizeDate(startDate, firstViewDate)
} else {
if (startDate < firstViewDate) {
startDate = firstViewDate
}
updatedStartDate = _date2.default.normalizeDate(options.startDate, new Date(startDate))
}
updatedStartDate = _date2.default.roundDateByStartDayHour(updatedStartDate, startDayHour);
options.callback(updatedStartDate)
},
updateAppointmentEndDate: function(options) {
var endDate = new Date(options.endDate),
endDayHour = this._getCurrentViewOption("endDayHour"),
startDayHour = this._getCurrentViewOption("startDayHour"),
updatedEndDate = endDate;
if (endDate.getHours() >= endDayHour) {
updatedEndDate.setHours(endDayHour, 0, 0, 0)
} else {
if (startDayHour > 0 && 60 * endDate.getHours() + endDate.getMinutes() < 60 * startDayHour) {
updatedEndDate = new Date(updatedEndDate.getTime() - toMs("day"));
updatedEndDate.setHours(endDayHour, 0, 0, 0)
}
}
options.callback(updatedEndDate)
},
renderDropDownAppointments: function(options) {
this._dropDownAppointments.render(options, this)
},
supportCompactDropDownAppointments: function() {
return this._workSpace._supportCompactDropDownAppointments()
},
getGroupCount: function() {
return this._workSpace._getGroupCount()
},
mapAppointmentFields: function(config) {
var result = {
appointmentData: config.itemData,
appointmentElement: config.itemElement
};
if (config.itemData) {
result.targetedAppointmentData = this.fire("getTargetedAppointmentData", config.itemData, config.itemElement, config.itemIndex)
}
return result
},
getOffsetByAllDayPanel: function(groupIndex) {
return this._workSpace._getOffsetByAllDayPanel(groupIndex)
},
getGroupTop: function(groupIndex) {
return this._workSpace._getGroupTop(groupIndex)
},
updateResizableArea: function() {
var $allResizableElements = this.$element().find(".dx-scheduler-appointment.dx-resizable");
var horizontalResizables = (0, _common.grep)($allResizableElements, function(el) {
var $el = (0, _renderer2.default)(el),
resizableInst = $el.dxResizable("instance"),
area = resizableInst.option("area");
return (0, _array.inArray)(resizableInst.option("handles"), ["right left", "left right"]) > -1 && _type2.default.isPlainObject(area)
});
(0, _iterator.each)(horizontalResizables, function(_, el) {
var $el = (0, _renderer2.default)(el),
position = _translator2.default.locate($el),
appointmentData = this._appointments._getItemData($el);
var area = this._appointments._calculateResizableArea({
left: position.left
}, appointmentData);
$el.dxResizable("instance").option("area", area)
}.bind(this))
},
recurrenceEditorVisibilityChanged: function(visible) {
this.recurrenceEditorVisibilityChanged(visible)
},
getField: function(field, obj) {
if (!_type2.default.isDefined(this._dataAccessors.getter[field])) {
return
}
return this._dataAccessors.getter[field](obj)
},
setField: function(field, obj, value) {
if (!_type2.default.isDefined(this._dataAccessors.setter[field])) {
return
}
var splitExprStr = this.option(field + "Expr").split("."),
rootField = splitExprStr[0];
if (void 0 === obj[rootField] && splitExprStr.length > 1) {
var emptyChain = function(arr) {
var result = {},
tmp = result,
arrLength = arr.length - 1;
for (var i = 1; i < arrLength; i++) {
tmp = tmp[arr[i]] = {}
}
return result
}(splitExprStr);
obj[rootField] = emptyChain
}
this._dataAccessors.setter[field](obj, value);
return obj
},
prerenderFilter: function() {
var dateRange = this.getWorkSpace().getDateRange(),
resources = this._resourcesManager.getResourcesData(),
allDay = void 0;
if (!this.option("showAllDayPanel") && this._workSpace.supportAllDayRow()) {
allDay = false
}
return this._appointmentModel.filterLoadedAppointments({
startDayHour: this._getCurrentViewOption("startDayHour"),
endDayHour: this._getCurrentViewOption("endDayHour"),
min: dateRange[0],
max: dateRange[1],
resources: resources,
allDay: allDay,
firstDayOfWeek: this.getFirstDayOfWeek(),
recurrenceException: this._getRecurrenceException.bind(this)
}, this._subscribes.convertDateByTimezone.bind(this))
},
dayHasAppointment: function(day, appointment, trimTime) {
return this.dayHasAppointment(day, appointment, trimTime)
},
createResourcesTree: function() {
return this._resourcesManager.createResourcesTree(this._loadedResources)
},
getResourceTreeLeaves: function(tree, appointmentResources) {
return this._resourcesManager.getResourceTreeLeaves(tree, appointmentResources)
},
createReducedResourcesTree: function() {
var tree = this._resourcesManager.createResourcesTree(this._loadedResources);
return this._resourcesManager.reduceResourcesTree(tree, this.getFilteredItems())
},
groupAppointmentsByResources: function(appointments) {
var result = {
0: appointments
},
groups = this._getCurrentViewOption("groups");
if (groups && groups.length && this._resourcesManager.getResourcesData().length) {
result = this._resourcesManager.groupAppointmentsByResources(appointments, this._loadedResources)
}
var totalResourceCount = 0;
(0, _iterator.each)(this._loadedResources, function(i, resource) {
if (!i) {
totalResourceCount = resource.items.length
} else {
totalResourceCount *= resource.items.length
}
});
for (var j = 0; j < totalResourceCount; j++) {
var index = j.toString();
if (result[index]) {
continue
}
result[index] = []
}
return result
},
getAgendaRows: function(options) {
var renderingStrategy = this._layoutManager.getRenderingStrategyInstance(),
calculateRows = renderingStrategy.calculateRows.bind(renderingStrategy),
d = new _deferred.Deferred;
function rowsCalculated(appointments) {
var result = calculateRows(appointments, options.agendaDuration, options.currentDate);
this._dataSourceLoadedCallback.remove(rowsCalculated);
d.resolve(result)
}
this._dataSourceLoadedCallback.add(rowsCalculated);
return d.promise()
},
getAgendaVerticalStepHeight: function() {
return this.getWorkSpace().getAgendaVerticalStepHeight()
},
getAgendaDuration: function() {
return this._getCurrentViewOption("agendaDuration")
},
getStartViewDate: function() {
return this.getStartViewDate()
},
getEndViewDate: function() {
return this.getEndViewDate()
},
getMaxAppointmentsPerCell: function() {
return this.getMaxAppointmentsPerCell()
},
forceMaxAppointmentPerCell: function() {
return this.forceMaxAppointmentPerCell()
},
agendaIsReady: function(rows, innerRowOffset, outerRowOffset) {
var $appts = this.getAppointmentsInstance()._itemElements(),
total = 0;
$appts.css("marginBottom", innerRowOffset);
var applyOffset = function(_, count) {
var index = count + total - 1;
$appts.eq(index).css("marginBottom", outerRowOffset);
total += count
};
for (var i = 0; i < rows.length; i++) {
(0, _iterator.each)(rows[i], applyOffset)
}
},
getTimezone: function() {
return this._getTimezoneOffsetByOption()
},
getClientTimezoneOffset: function(date) {
date = date || new Date;
return _uiScheduler2.default.getClientTimezoneOffset(date)
},
convertDateByTimezone: function(date, appointmentTimezone) {
date = new Date(date);
var tzOffsets = this._subscribes.getComplexOffsets(this, date, appointmentTimezone);
date = this._subscribes.translateDateToAppointmentTimeZone(date, tzOffsets);
date = this._subscribes.translateDateToCommonTimeZone(date, tzOffsets);
return date
},
convertDateByTimezoneBack: function(date, appointmentTimezone) {
date = new Date(date);
var tzOffsets = this._subscribes.getComplexOffsets(this, date, appointmentTimezone);
date = this._subscribes.translateDateToAppointmentTimeZone(date, tzOffsets, true);
date = this._subscribes.translateDateToCommonTimeZone(date, tzOffsets, true);
return date
},
translateDateToAppointmentTimeZone: function(date, offsets, back) {
var operation = back ? -1 : 1;
var dateInUTC = date.getTime() - operation * offsets.client * toMs("hour");
return new Date(dateInUTC + operation * offsets.appointment * toMs("hour"))
},
translateDateToCommonTimeZone: function(date, offsets, back) {
var operation = back ? -1 : 1;
if ("number" === typeof offsets.common) {
var offset = offsets.common - offsets.appointment,
hoursOffset = (offset < 0 ? -1 : 1) * Math.floor(Math.abs(offset)),
minutesOffset = offset % 1;
date.setHours(date.getHours() + operation * hoursOffset);
date.setMinutes(date.getMinutes() + operation * minutesOffset * MINUTES_IN_HOUR)
}
return date
},
getComplexOffsets: function(scheduler, date, appointmentTimezone) {
var clientTimezoneOffset = -this.getClientTimezoneOffset(date) / toMs("hour");
var commonTimezoneOffset = scheduler._getTimezoneOffsetByOption(date);
var appointmentTimezoneOffset = scheduler._calculateTimezoneByValue(appointmentTimezone, date);
if ("number" !== typeof appointmentTimezoneOffset) {
appointmentTimezoneOffset = clientTimezoneOffset
}
return {
client: clientTimezoneOffset,
common: commonTimezoneOffset,
appointment: appointmentTimezoneOffset
}
},
getDaylightOffset: function(startDate, endDate) {
return startDate.getTimezoneOffset() - endDate.getTimezoneOffset()
},
getTimezonesDisplayName: function() {
return _uiScheduler2.default.getTimezonesDisplayName()
},
getTimezoneDisplayNameById: function(id) {
return _uiScheduler2.default.getTimezoneDisplayNameById(id)
},
getSimilarTimezones: function(id) {
return _uiScheduler2.default.getSimilarTimezones(id)
},
getTimezonesIdsByDisplayName: function(displayName) {
return _uiScheduler2.default.getTimezonesIdsByDisplayName(displayName)
},
getTargetedAppointmentData: function(appointmentData, appointmentElement, appointmentIndex, startDate) {
var $appointmentElement = (0, _renderer2.default)(appointmentElement),
recurringData = this._getSingleAppointmentData(appointmentData, {
skipDateCalculation: true,
$appointment: $appointmentElement,
skipHoursProcessing: true,
startDate: startDate
}),
result = {};
(0, _extend.extend)(true, result, appointmentData, recurringData);
this._convertDatesByTimezoneBack(false, result);
if (!_type2.default.isDefined(appointmentIndex)) {
appointmentIndex = $appointmentElement.data(this._appointments._itemIndexKey())
}
appointmentElement && this.setTargetedAppointmentResources(result, appointmentElement, appointmentIndex);
return result
},
getAppointmentDurationInMs: function(options) {
var startDate = options.startDate,
endDate = options.endDate,
allDay = options.allDay,
appointmentDuration = endDate.getTime() - startDate.getTime();
var dayDuration = toMs("day"),
visibleDayDuration = this._workSpace.getVisibleDayDuration(),
result = 0;
if (allDay) {
var ceilQuantityOfDays = Math.ceil(appointmentDuration / dayDuration);
result = ceilQuantityOfDays * visibleDayDuration
} else {
var isDifferentDate = !_date2.default.sameDate(startDate, new Date(endDate.getTime() - 1)),
floorQuantityOfDays = Math.floor(appointmentDuration / dayDuration),
tailDuration = void 0;
if (isDifferentDate) {
var hiddenDayDuration = dayDuration - visibleDayDuration;
tailDuration = appointmentDuration - (floorQuantityOfDays ? floorQuantityOfDays * dayDuration : hiddenDayDuration);
var startDayTime = this.option("startDayHour") * toMs("hour"),
endPartDuration = endDate - _date2.default.trimTime(endDate);
if (endPartDuration < startDayTime) {
if (floorQuantityOfDays) {
tailDuration -= hiddenDayDuration
}
tailDuration += startDayTime - endPartDuration
}
} else {
tailDuration = appointmentDuration % dayDuration
}
if (tailDuration > visibleDayDuration) {
tailDuration = visibleDayDuration
}
result = floorQuantityOfDays * visibleDayDuration + tailDuration
}
options.callback(result)
},
fixWrongEndDate: function(appointment, startDate, endDate) {
return this._appointmentModel.fixWrongEndDate(appointment, startDate, endDate)
},
getEndDayHour: function() {
return this.option("endDayHour")
},
getStartDayHour: function() {
return this.option("startDayHour")
}
};
module.exports = subscribes;