diff --git a/packages/devextreme/js/__internal/scheduler/appointment_popup/m_form.ts b/packages/devextreme/js/__internal/scheduler/appointment_popup/m_form.ts index c703fef11887..22f88ec1f774 100644 --- a/packages/devextreme/js/__internal/scheduler/appointment_popup/m_form.ts +++ b/packages/devextreme/js/__internal/scheduler/appointment_popup/m_form.ts @@ -27,7 +27,7 @@ export const APPOINTMENT_FORM_GROUP_NAMES = { const getStylingModeFunc = (): string | undefined => (isFluent(current()) ? 'filled' : undefined); -const getDateWithStartHour = (date, startDayHour) => new Date(new Date(date).setHours(startDayHour)); +const getStartDateWithStartHour = (startDate, startDayHour) => new Date(new Date(startDate).setHours(startDayHour)); const validateAppointmentFormDate = (editor, value, previousValue) => { const isCurrentDateCorrect = value === null || !!value; @@ -310,20 +310,17 @@ export class AppointmentForm { const startDateEditor = this.form.getEditor(dataExprs.startDateExpr); const endDateEditor = this.form.getEditor(dataExprs.endDateExpr); const startDate = dateSerialization.deserializeDate(startDateEditor.option('value')); - const endDate = dateSerialization.deserializeDate(endDateEditor.option('value')); if (this.semaphore.isFree() && startDate) { if (value) { const allDayStartDate = dateUtils.trimTime(startDate); - const allDayEndDate = dateUtils.trimTime(endDate); startDateEditor.option('value', new Date(allDayStartDate)); - endDateEditor.option('value', new Date(allDayEndDate)); + endDateEditor.option('value', new Date(allDayStartDate)); } else { - const startDateWithStartHour = getDateWithStartHour(startDate, this.scheduler.getStartDayHour()); - const endDateWithStartHour = getDateWithStartHour(endDate, this.scheduler.getStartDayHour()); - const calculatedEndDate = this.scheduler.getCalculatedEndDate(endDateWithStartHour); + const startDateWithStartHour = getStartDateWithStartHour(startDate, this.scheduler.getStartDayHour()); + const endDate = this.scheduler.getCalculatedEndDate(startDateWithStartHour); startDateEditor.option('value', startDateWithStartHour); - endDateEditor.option('value', calculatedEndDate); + endDateEditor.option('value', endDate); } } diff --git a/packages/devextreme/js/__internal/scheduler/m_scheduler.ts b/packages/devextreme/js/__internal/scheduler/m_scheduler.ts index d0d094a87385..3cf2c3e60a0b 100644 --- a/packages/devextreme/js/__internal/scheduler/m_scheduler.ts +++ b/packages/devextreme/js/__internal/scheduler/m_scheduler.ts @@ -1363,7 +1363,7 @@ class Scheduler extends Widget { getFirstDayOfWeek: () => this.option('firstDayOfWeek'), getStartDayHour: () => this.option('startDayHour'), - getCalculatedEndDate: (date) => this._workSpace.calculateEndDate(date), + getCalculatedEndDate: (startDateWithStartHour) => this._workSpace.calculateEndDate(startDateWithStartHour), getTimeZoneCalculator: () => this.timeZoneCalculator, }; diff --git a/packages/devextreme/testing/tests/DevExpress.ui.widgets.scheduler/appointmentPopup.tests.js b/packages/devextreme/testing/tests/DevExpress.ui.widgets.scheduler/appointmentPopup.tests.js index 0771af5574a4..6ab1cafe7068 100644 --- a/packages/devextreme/testing/tests/DevExpress.ui.widgets.scheduler/appointmentPopup.tests.js +++ b/packages/devextreme/testing/tests/DevExpress.ui.widgets.scheduler/appointmentPopup.tests.js @@ -1189,7 +1189,7 @@ QUnit.module('Appointment Popup Content', moduleOptions, () => { assert.equal(allDayEditor.option('value'), true, 'value is right'); }); - QUnit.test('allDay changing should switch type, but not date in editors', function(assert) { + QUnit.test('allDay changing should switch date & type in editors', function(assert) { const scheduler = createInstance({ startDayHour: 5, }); @@ -1211,7 +1211,7 @@ QUnit.module('Appointment Popup Content', moduleOptions, () => { assert.deepEqual(startDate.option('value'), new Date(2015, 1, 1), 'value is right'); assert.equal(startDate.option('type'), 'date', 'type is right'); - assert.deepEqual(endDate.option('value'), new Date(2015, 1, 2), 'value is right'); + assert.deepEqual(endDate.option('value'), new Date(2015, 1, 1), 'value is right'); assert.equal(endDate.option('type'), 'date', 'type is right'); allDayEditor.option('value', false); @@ -1219,7 +1219,7 @@ QUnit.module('Appointment Popup Content', moduleOptions, () => { assert.equal(startDate.option('type'), 'datetime', 'type is right after turning off allDay'); assert.equal(endDate.option('type'), 'datetime', 'type is right after turning off allDay'); assert.deepEqual(startDate.option('value'), new Date(2015, 1, 1, 5), 'startdate is OK'); - assert.deepEqual(endDate.option('value'), new Date(2015, 1, 2, 5, 30), 'enddate is OK'); + assert.deepEqual(endDate.option('value'), new Date(2015, 1, 1, 5, 30), 'enddate is OK'); }); QUnit.test('allDay changing should switch only type in editors, if startDate is undefined', function(assert) {