UNPKG

devextreme

Version:

HTML5 JavaScript Component Suite for Responsive Web Development

196 lines (195 loc) • 8.55 kB
/** * DevExtreme (esm/ui/scheduler/rendering_strategies/ui.scheduler.appointments.strategy.agenda.js) * Version: 21.1.4 * Build date: Mon Jun 21 2021 * * Copyright (c) 2012 - 2021 Developer Express Inc. ALL RIGHTS RESERVED * Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/ */ import dateUtils from "../../../core/utils/date"; import { each } from "../../../core/utils/iterator"; import { merge } from "../../../core/utils/array"; import BaseRenderingStrategy from "./ui.scheduler.appointments.strategy.base"; class AgendaRenderingStrategy extends BaseRenderingStrategy { getAppointmentMinSize() {} getDeltaTime() {} keepAppointmentSettings() { return true } getAppointmentGeometry(geometry) { return geometry } createTaskPositionMap(appointments) { var height; var appointmentsByResources; if (appointments.length) { height = this.instance.fire("getAgendaVerticalStepHeight"); appointmentsByResources = this.instance.fire("groupAppointmentsByResources", appointments); var groupedAppts = []; each(appointmentsByResources, function(i, appts) { var additionalAppointments = []; var recurrentIndexes = []; each(appts, function(index, appointment) { var recurrenceBatch = this.instance.getAppointmentsInstance()._processRecurrenceAppointment(appointment, index); var appointmentBatch = null; if (!recurrenceBatch.indexes.length) { appointmentBatch = { parts: [] }; appointmentBatch = this.instance.getAppointmentsInstance()._processLongAppointment(appointment); additionalAppointments = additionalAppointments.concat(appointmentBatch.parts) } additionalAppointments = additionalAppointments.concat(recurrenceBatch.parts); recurrentIndexes = recurrentIndexes.concat(recurrenceBatch.indexes) }.bind(this)); this.instance.getAppointmentsInstance()._reduceRecurrenceAppointments(recurrentIndexes, appts); this.instance.getAppointmentsInstance()._combineAppointments(appts, additionalAppointments); groupedAppts = groupedAppts.concat(appts) }.bind(this)); Array.prototype.splice.apply(appointments, [0, appointments.length].concat(groupedAppts)) } var result = []; var sortedIndex = 0; appointments.forEach(function(appt, index) { result.push([{ height: height, width: "100%", sortedIndex: sortedIndex++, groupIndex: this._calculateGroupIndex(index, appointmentsByResources), agendaSettings: appt.settings }]); delete appt.settings }.bind(this)); return result } _calculateGroupIndex(apptIndex, appointmentsByResources) { var resultInd; var counter = 0; for (var i in appointmentsByResources) { var countApptInGroup = appointmentsByResources[i].length; if (apptIndex >= counter && apptIndex < counter + countApptInGroup) { resultInd = Number(i); break } counter += countApptInGroup } return resultInd } _getDeltaWidth() {} _getAppointmentMaxWidth() { return this.getDefaultCellWidth() } _needVerifyItemSize() { return false } _isRtl() { return this.instance.option("rtlEnabled") } _getAppointmentParts() {} _reduceMultiWeekAppointment() {} calculateAppointmentHeight() { return 0 } calculateAppointmentWidth() { return 0 } isAppointmentGreaterThan() {} isAllDay() { return false } _sortCondition() {} _rowCondition() {} _columnCondition() {} _findIndexByKey() {} _markAppointmentAsVirtual() {} getDropDownAppointmentWidth() {} getDefaultCellWidth() { return this._defaultWidth } getCollectorLeftOffset() {} getCollectorTopOffset() {} calculateRows(appointments, agendaDuration, currentDate, needClearSettings) { this._rows = []; var groupedAppointments = this.instance.fire("groupAppointmentsByResources", appointments); currentDate = dateUtils.trimTime(new Date(currentDate)); each(groupedAppointments, function(groupIndex, currentAppointments) { var groupResult = []; var appts = { indexes: [], parts: [] }; if (!currentAppointments.length) { this._rows.push([]); return true } each(currentAppointments, function(index, appointment) { var startDate = this.instance.fire("getField", "startDate", appointment); var endDate = this.instance.fire("getField", "endDate", appointment); this.instance.fire("replaceWrongEndDate", appointment, startDate, endDate); needClearSettings && delete appointment.settings; var result = this.instance.getAppointmentsInstance()._processRecurrenceAppointment(appointment, index, false); appts.parts = appts.parts.concat(result.parts); appts.indexes = appts.indexes.concat(result.indexes) }.bind(this)); this.instance.getAppointmentsInstance()._reduceRecurrenceAppointments(appts.indexes, currentAppointments); merge(currentAppointments, appts.parts); var appointmentCount = currentAppointments.length; for (var i = 0; i < agendaDuration; i++) { var day = new Date(currentDate); day.setMilliseconds(day.getMilliseconds() + 864e5 * i); if (void 0 === groupResult[i]) { groupResult[i] = 0 } for (var j = 0; j < appointmentCount; j++) { var appointmentData = currentAppointments[j].settings || currentAppointments[j]; var appointmentIsLong = this.instance.fire("appointmentTakesSeveralDays", currentAppointments[j]); var appointmentIsRecurrence = this.instance.fire("getField", "recurrenceRule", currentAppointments[j]); if (this.instance.fire("dayHasAppointment", day, appointmentData, true) || !appointmentIsRecurrence && appointmentIsLong && this.instance.fire("dayHasAppointment", day, currentAppointments[j], true)) { groupResult[i] += 1 } } } this._rows.push(groupResult) }.bind(this)); return this._rows } _iterateRow(row, obj, index) { for (var i = 0; i < row.length; i++) { obj.counter = obj.counter + row[i]; if (obj.counter >= index) { obj.indexInRow = i; break } } } getDateByIndex(index, rows, startViewDate) { var obj = { counter: 0, indexInRow: 0 }; index++; for (var i = 0; i < rows.length; i++) { this._iterateRow(rows[i], obj, index); if (obj.indexInRow) { break } } return new Date(new Date(startViewDate).setDate(startViewDate.getDate() + obj.indexInRow)) } getAppointmentDataCalculator() { return function($appointment, originalStartDate) { var apptIndex = $appointment.index(); var startViewDate = this.instance.getStartViewDate(); var calculatedStartDate = this.getDateByIndex(apptIndex, this._rows, startViewDate); var wrappedOriginalStartDate = new Date(originalStartDate); return { startDate: new Date(calculatedStartDate.setHours(wrappedOriginalStartDate.getHours(), wrappedOriginalStartDate.getMinutes(), wrappedOriginalStartDate.getSeconds(), wrappedOriginalStartDate.getMilliseconds())) } }.bind(this) } } export default AgendaRenderingStrategy;