UNPKG

devextreme

Version:

HTML5 JavaScript Component Suite for Responsive Web Development

360 lines (359 loc) • 16.5 kB
/** * DevExtreme (esm/ui/scheduler/appointmentPopup/form.js) * Version: 22.1.9 * Build date: Tue Apr 18 2023 * * Copyright (c) 2012 - 2023 Developer Express Inc. ALL RIGHTS RESERVED * Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/ */ import _extends from "@babel/runtime/helpers/esm/extends"; import $ from "../../../core/renderer"; import Form from "../../form"; import dateSerialization from "../../../core/utils/date_serialization"; import messageLocalization from "../../../localization/message"; import devices from "../../../core/devices"; import DataSource from "../../../data/data_source"; import timeZoneDataUtils from "../timezones/utils.timezones_data"; import { extend } from "../../../core/utils/extend"; import dateUtils from "../../../core/utils/date"; import { Semaphore } from "../../../renovation/ui/scheduler/utils/semaphore/semaphore"; import "../recurrence_editor"; import "../../text_area"; import "../../tag_box"; import "../../switch"; import "../../select_box"; var SCREEN_SIZE_OF_SINGLE_COLUMN = 600; export var APPOINTMENT_FORM_GROUP_NAMES = { Main: "mainGroup", Recurrence: "recurrenceGroup" }; var getStartDateWithStartHour = (startDate, startDayHour) => new Date(new Date(startDate).setHours(startDayHour)); var validateAppointmentFormDate = (editor, value, previousValue) => { var isCurrentDateCorrect = null === value || !!value; var isPreviousDateCorrect = null === previousValue || !!previousValue; if (!isCurrentDateCorrect && isPreviousDateCorrect) { editor.option("value", previousValue) } }; var updateRecurrenceItemVisibility = (recurrenceRuleExpr, value, form) => { var _form$getEditor; form.itemOption(APPOINTMENT_FORM_GROUP_NAMES.Recurrence, "visible", value); !value && form.updateData(recurrenceRuleExpr, ""); null === (_form$getEditor = form.getEditor(recurrenceRuleExpr)) || void 0 === _form$getEditor ? void 0 : _form$getEditor.changeValueByVisibility(value) }; var createDateBoxEditor = (dataField, colSpan, firstDayOfWeek, label, onValueChanged) => ({ editorType: "dxDateBox", dataField: dataField, colSpan: colSpan, label: { text: messageLocalization.format(label) }, validationRules: [{ type: "required" }], editorOptions: { width: "100%", calendarOptions: { firstDayOfWeek: firstDayOfWeek }, onValueChanged: onValueChanged, useMaskBehavior: true } }); export class AppointmentForm { constructor(scheduler) { this.scheduler = scheduler; this.form = null; this.semaphore = new Semaphore } get dxForm() { return this.form } set readOnly(value) { this.form.option("readOnly", value); var { recurrenceRuleExpr: recurrenceRuleExpr } = this.scheduler.getDataAccessors().expr; var recurrenceEditor = this.form.getEditor(recurrenceRuleExpr); null === recurrenceEditor || void 0 === recurrenceEditor ? void 0 : recurrenceEditor.option("readOnly", value) } get formData() { return this.form.option("formData") } set formData(value) { this.form.option("formData", value) } create(triggerResize, changeSize, formData) { var allowTimeZoneEditing = this.scheduler.getEditingConfig().allowTimeZoneEditing; var { expr: expr } = this.scheduler.getDataAccessors(); var recurrenceEditorVisibility = !!formData[expr.recurrenceRuleExpr]; var colSpan = recurrenceEditorVisibility ? 1 : 2; var mainItems = [...this._createMainItems(expr, triggerResize, changeSize, allowTimeZoneEditing), ...this.scheduler.createResourceEditorModel()]; changeSize(recurrenceEditorVisibility); var items = [{ itemType: "group", name: APPOINTMENT_FORM_GROUP_NAMES.Main, colCountByScreen: { lg: 2, xs: 1 }, colSpan: colSpan, items: mainItems }, { itemType: "group", name: APPOINTMENT_FORM_GROUP_NAMES.Recurrence, visible: recurrenceEditorVisibility, colSpan: colSpan, items: this._createRecurrenceEditor(expr) }]; var element = $("<div>"); this.form = this.scheduler.createComponent(element, Form, { items: items, showValidationSummary: true, scrollingEnabled: true, colCount: "auto", colCountByScreen: { lg: 2, xs: 1 }, formData: formData, showColonAfterLabel: false, labelLocation: "top", customizeItem: e => { if (this.form && "group" === e.itemType) { var dataExprs = this.scheduler.getDataAccessors().expr; var startDate = new Date(this.formData[dataExprs.startDateExpr]); var endDate = new Date(this.formData[dataExprs.endDateExpr]); var startTimeZoneEditor = e.items.find(i => i.dataField === dataExprs.startDateTimeZoneExpr); var endTimeZoneEditor = e.items.find(i => i.dataField === dataExprs.endDateTimeZoneExpr); if (startTimeZoneEditor) { startTimeZoneEditor.editorOptions.dataSource = this.createTimeZoneDataSource(startDate) } if (endTimeZoneEditor) { endTimeZoneEditor.editorOptions.dataSource = this.createTimeZoneDataSource(endDate) } } }, screenByWidth: width => width < SCREEN_SIZE_OF_SINGLE_COLUMN || "desktop" !== devices.current().deviceType ? "xs" : "lg" }) } createTimeZoneDataSource(date) { return new DataSource({ store: timeZoneDataUtils.getDisplayedTimeZones(date), paginate: true, pageSize: 10 }) } _dateBoxValueChanged(args, dateExpr, isNeedCorrect) { validateAppointmentFormDate(args.component, args.value, args.previousValue); var value = dateSerialization.deserializeDate(args.value); var previousValue = dateSerialization.deserializeDate(args.previousValue); var dateEditor = this.form.getEditor(dateExpr); var dateValue = dateSerialization.deserializeDate(dateEditor.option("value")); if (this.semaphore.isFree() && dateValue && value && isNeedCorrect(dateValue, value)) { var duration = previousValue ? dateValue.getTime() - previousValue.getTime() : 0; dateEditor.option("value", new Date(value.getTime() + duration)) } } _createTimezoneEditor(timeZoneExpr, secondTimeZoneExpr, visibleIndex, colSpan, isMainTimeZone) { var visible = arguments.length > 5 && void 0 !== arguments[5] ? arguments[5] : false; var noTzTitle = messageLocalization.format("dxScheduler-noTimezoneTitle"); return { dataField: timeZoneExpr, editorType: "dxSelectBox", visibleIndex: visibleIndex, colSpan: colSpan, label: { text: " " }, editorOptions: { displayExpr: "title", valueExpr: "id", placeholder: noTzTitle, searchEnabled: true, onValueChanged: args => { var form = this.form; var secondTimezoneEditor = form.getEditor(secondTimeZoneExpr); if (isMainTimeZone) { secondTimezoneEditor.option("value", args.value) } } }, visible: visible } } _createDateBoxItems(dataExprs, allowTimeZoneEditing) { var colSpan = allowTimeZoneEditing ? 2 : 1; var firstDayOfWeek = this.scheduler.getFirstDayOfWeek(); return [createDateBoxEditor(dataExprs.startDateExpr, colSpan, firstDayOfWeek, "dxScheduler-editorLabelStartDate", args => { this._dateBoxValueChanged(args, dataExprs.endDateExpr, (endValue, startValue) => endValue < startValue) }), this._createTimezoneEditor(dataExprs.startDateTimeZoneExpr, dataExprs.endDateTimeZoneExpr, 1, colSpan, true, allowTimeZoneEditing), createDateBoxEditor(dataExprs.endDateExpr, colSpan, firstDayOfWeek, "dxScheduler-editorLabelEndDate", args => { this._dateBoxValueChanged(args, dataExprs.startDateExpr, (startValue, endValue) => endValue < startValue) }), this._createTimezoneEditor(dataExprs.endDateTimeZoneExpr, dataExprs.startDateTimeZoneExpr, 3, colSpan, false, allowTimeZoneEditing)] } _changeFormItemDateType(itemPath, isAllDay) { var itemEditorOptions = this.form.itemOption(itemPath).editorOptions; var type = isAllDay ? "date" : "datetime"; var newEditorOption = _extends({}, itemEditorOptions, { type: type }); this.form.itemOption(itemPath, "editorOptions", newEditorOption) } _createMainItems(dataExprs, triggerResize, changeSize, allowTimeZoneEditing) { return [{ dataField: dataExprs.textExpr, editorType: "dxTextBox", colSpan: 2, label: { text: messageLocalization.format("dxScheduler-editorLabelTitle") } }, { itemType: "group", colSpan: 2, colCountByScreen: { lg: 2, xs: 1 }, items: this._createDateBoxItems(dataExprs, allowTimeZoneEditing) }, { itemType: "group", colCountByScreen: { lg: 3, xs: 3 }, colSpan: 2, items: [{ dataField: dataExprs.allDayExpr, cssClass: "dx-appointment-form-switch", editorType: "dxSwitch", label: { text: messageLocalization.format("dxScheduler-allDay"), location: "right" }, editorOptions: { onValueChanged: args => { var value = args.value; var startDateEditor = this.form.getEditor(dataExprs.startDateExpr); var endDateEditor = this.form.getEditor(dataExprs.endDateExpr); var startDate = dateSerialization.deserializeDate(startDateEditor.option("value")); if (this.semaphore.isFree() && startDate) { if (value) { var allDayStartDate = dateUtils.trimTime(startDate); startDateEditor.option("value", new Date(allDayStartDate)); endDateEditor.option("value", new Date(allDayStartDate)) } else { var startDateWithStartHour = getStartDateWithStartHour(startDate, this.scheduler.getStartDayHour()); var endDate = this.scheduler.getCalculatedEndDate(startDateWithStartHour); startDateEditor.option("value", startDateWithStartHour); endDateEditor.option("value", endDate) } } var startDateItemPath = "".concat(APPOINTMENT_FORM_GROUP_NAMES.Main, ".").concat(dataExprs.startDateExpr); var endDateItemPath = "".concat(APPOINTMENT_FORM_GROUP_NAMES.Main, ".").concat(dataExprs.endDateExpr); this._changeFormItemDateType(startDateItemPath, value); this._changeFormItemDateType(endDateItemPath, value) } } }, { editorType: "dxSwitch", dataField: "repeat", cssClass: "dx-appointment-form-switch", name: "visibilityChanged", label: { text: messageLocalization.format("dxScheduler-editorLabelRecurrence"), location: "right" }, editorOptions: { onValueChanged: args => { var form = this.form; var colSpan = args.value ? 1 : 2; form.itemOption(APPOINTMENT_FORM_GROUP_NAMES.Main, "colSpan", colSpan); form.itemOption(APPOINTMENT_FORM_GROUP_NAMES.Recurrence, "colSpan", colSpan); updateRecurrenceItemVisibility(dataExprs.recurrenceRuleExpr, args.value, form); changeSize(args.value); triggerResize() } } }] }, { itemType: "empty", colSpan: 2 }, { dataField: dataExprs.descriptionExpr, editorType: "dxTextArea", colSpan: 2, label: { text: messageLocalization.format("dxScheduler-editorLabelDescription") } }, { itemType: "empty", colSpan: 2 }] } _createRecurrenceEditor(dataExprs) { return [{ dataField: dataExprs.recurrenceRuleExpr, editorType: "dxRecurrenceEditor", editorOptions: { firstDayOfWeek: this.scheduler.getFirstDayOfWeek() }, label: { text: " ", visible: false } }] } setEditorsType(allDay) { var { startDateExpr: startDateExpr, endDateExpr: endDateExpr } = this.scheduler.getDataAccessors().expr; var startDateItemPath = "".concat(APPOINTMENT_FORM_GROUP_NAMES.Main, ".").concat(startDateExpr); var endDateItemPath = "".concat(APPOINTMENT_FORM_GROUP_NAMES.Main, ".").concat(endDateExpr); var startDateFormItem = this.form.itemOption(startDateItemPath); var endDateFormItem = this.form.itemOption(endDateItemPath); if (startDateFormItem && endDateFormItem) { var startDateEditorOptions = startDateFormItem.editorOptions; var endDateEditorOptions = endDateFormItem.editorOptions; startDateEditorOptions.type = endDateEditorOptions.type = allDay ? "date" : "datetime"; this.form.itemOption(startDateItemPath, "editorOptions", startDateEditorOptions); this.form.itemOption(endDateItemPath, "editorOptions", endDateEditorOptions) } } updateRecurrenceEditorStartDate(date, expression) { var options = { startDate: date }; this.setEditorOptions(expression, "Recurrence", options) } setEditorOptions(name, groupName, options) { var editorPath = "".concat(APPOINTMENT_FORM_GROUP_NAMES.groupName, ".").concat(name); var editor = this.form.itemOption(editorPath); editor && this.form.itemOption(editorPath, "editorOptions", extend({}, editor.editorOptions, options)) } setTimeZoneEditorDataSource(date, path) { var dataSource = this.createTimeZoneDataSource(date); this.setEditorOptions(path, "Main", { dataSource: dataSource }) } updateFormData(formData) { this.semaphore.take(); this.form.option("formData", formData); var dataExprs = this.scheduler.getDataAccessors().expr; var allDay = formData[dataExprs.allDayExpr]; var startDate = new Date(formData[dataExprs.startDateExpr]); var endDate = new Date(formData[dataExprs.endDateExpr]); this.setTimeZoneEditorDataSource(startDate, dataExprs.startDateTimeZoneExpr); this.setTimeZoneEditorDataSource(endDate, dataExprs.endDateTimeZoneExpr); this.updateRecurrenceEditorStartDate(startDate, dataExprs.recurrenceRuleExpr); this.setEditorsType(allDay); this.semaphore.release() } }