UNPKG

devextreme

Version:

HTML5 JavaScript Component Suite for Responsive Web Development

122 lines (120 loc) 6.92 kB
/** * DevExtreme (cjs/__internal/scheduler/appointments/data_provider/m_utils.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.sortAppointmentsByStartDate = exports.replaceWrongEndDate = exports.getRecurrenceException = exports.getAppointmentTakesSeveralDays = exports.compareDateWithStartDayHour = exports.compareDateWithEndDayHour = exports._isEndDateWrong = exports._convertRecurrenceException = exports._appointmentPartInInterval = void 0; var _date = _interopRequireDefault(require("../../../../core/utils/date")); var _date_serialization = _interopRequireDefault(require("../../../../core/utils/date_serialization")); var _m_expression_utils = require("../../m_expression_utils"); var _m_utils_time_zone = _interopRequireDefault(require("../../m_utils_time_zone")); function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e } } const toMs = _date.default.dateToMilliseconds; const FULL_DATE_FORMAT = "yyyyMMddTHHmmss"; const compareDateWithStartDayHour = (startDate, endDate, startDayHour, allDay, severalDays) => { const startTime = _date.default.dateTimeFromDecimal(startDayHour); const result = startDate.getHours() >= startTime.hours && startDate.getMinutes() >= startTime.minutes || endDate.getHours() === startTime.hours && endDate.getMinutes() > startTime.minutes || endDate.getHours() > startTime.hours || severalDays || allDay; return result }; exports.compareDateWithStartDayHour = compareDateWithStartDayHour; const compareDateWithEndDayHour = options => { const { startDate: startDate, endDate: endDate, startDayHour: startDayHour, endDayHour: endDayHour, viewStartDayHour: viewStartDayHour, viewEndDayHour: viewEndDayHour, allDay: allDay, severalDays: severalDays, min: min, max: max, checkIntersectViewport: checkIntersectViewport } = options; const hiddenInterval = (24 - viewEndDayHour + viewStartDayHour) * toMs("hour"); const apptDuration = endDate.getTime() - startDate.getTime(); const delta = (hiddenInterval - apptDuration) / toMs("hour"); const apptStartHour = startDate.getHours(); const apptStartMinutes = startDate.getMinutes(); let result; const endTime = _date.default.dateTimeFromDecimal(endDayHour); const startTime = _date.default.dateTimeFromDecimal(startDayHour); const apptIntersectViewport = startDate < max && endDate > min; result = checkIntersectViewport && apptIntersectViewport || apptStartHour < endTime.hours || apptStartHour === endTime.hours && apptStartMinutes < endTime.minutes || allDay && startDate <= max || severalDays && apptIntersectViewport && (apptStartHour < endTime.hours || 60 * endDate.getHours() + endDate.getMinutes() > 60 * startTime.hours); if (apptDuration < hiddenInterval) { if (apptStartHour > endTime.hours && apptStartMinutes > endTime.minutes && delta <= apptStartHour - endDayHour) { result = false } } return result }; exports.compareDateWithEndDayHour = compareDateWithEndDayHour; const getAppointmentTakesSeveralDays = adapter => !_date.default.sameDate(adapter.startDate, adapter.endDate); exports.getAppointmentTakesSeveralDays = getAppointmentTakesSeveralDays; const _isEndDateWrong = (startDate, endDate) => !endDate || isNaN(endDate.getTime()) || startDate.getTime() > endDate.getTime(); exports._isEndDateWrong = _isEndDateWrong; const _appointmentPartInInterval = (startDate, endDate, startDayHour, endDayHour) => { const apptStartDayHour = startDate.getHours(); const apptEndDayHour = endDate.getHours(); return apptStartDayHour <= startDayHour && apptEndDayHour <= endDayHour && apptEndDayHour >= startDayHour || apptEndDayHour >= endDayHour && apptStartDayHour <= endDayHour && apptStartDayHour >= startDayHour }; exports._appointmentPartInInterval = _appointmentPartInInterval; const getRecurrenceException = (appointmentAdapter, timeZoneCalculator, timeZone) => { const { recurrenceException: recurrenceException } = appointmentAdapter; if (recurrenceException) { const exceptions = recurrenceException.split(","); for (let i = 0; i < exceptions.length; i++) { exceptions[i] = _convertRecurrenceException(exceptions[i], appointmentAdapter.startDate, timeZoneCalculator, timeZone) } return exceptions.join() } return recurrenceException }; exports.getRecurrenceException = getRecurrenceException; const _convertRecurrenceException = (exceptionString, startDate, timeZoneCalculator, timeZone) => { exceptionString = exceptionString.replace(/\s/g, ""); const getConvertedToTimeZone = date => timeZoneCalculator.createDate(date, { path: "toGrid" }); const exceptionDate = _date_serialization.default.deserializeDate(exceptionString); const convertedStartDate = getConvertedToTimeZone(startDate); let convertedExceptionDate = getConvertedToTimeZone(exceptionDate); convertedExceptionDate = _m_utils_time_zone.default.correctRecurrenceExceptionByTimezone(convertedExceptionDate, convertedStartDate, timeZone); exceptionString = _date_serialization.default.serializeDate(convertedExceptionDate, FULL_DATE_FORMAT); return exceptionString }; exports._convertRecurrenceException = _convertRecurrenceException; const replaceWrongEndDate = (rawAppointment, startDate, endDate, appointmentDuration, dataAccessors) => { if (_isEndDateWrong(startDate, endDate)) { const isAllDay = _m_expression_utils.ExpressionUtils.getField(dataAccessors, "allDay", rawAppointment); const calculatedEndDate = ((isAllDay, startDate) => { if (isAllDay) { return _date.default.setToDayEnd(new Date(startDate)) } return new Date(startDate.getTime() + appointmentDuration * toMs("minute")) })(isAllDay, startDate); dataAccessors.setter.endDate(rawAppointment, calculatedEndDate) } }; exports.replaceWrongEndDate = replaceWrongEndDate; const sortAppointmentsByStartDate = (appointments, dataAccessors) => { appointments.sort(((a, b) => { const firstDate = new Date(_m_expression_utils.ExpressionUtils.getField(dataAccessors, "startDate", a.settings || a)); const secondDate = new Date(_m_expression_utils.ExpressionUtils.getField(dataAccessors, "startDate", b.settings || b)); return Math.sign(firstDate.getTime() - secondDate.getTime()) })) }; exports.sortAppointmentsByStartDate = sortAppointmentsByStartDate;