UNPKG

devextreme

Version:

HTML5 JavaScript Component Suite for Responsive Web Development

121 lines (118 loc) 5.21 kB
/** * DevExtreme (cjs/__internal/scheduler/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.utils = void 0; var _element = require("../../core/element"); var _renderer = _interopRequireDefault(require("../../core/renderer")); var _data = require("../../core/utils/data"); var _date_serialization = _interopRequireDefault(require("../../core/utils/date_serialization")); var _iterator = require("../../core/utils/iterator"); var _size = require("../../core/utils/size"); var _m_constants = require("./m_constants"); function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e } } function _extends() { return _extends = Object.assign ? Object.assign.bind() : function(n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) { ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]) } } return n }, _extends.apply(null, arguments) } const utils = exports.utils = { dataAccessors: { getAppointmentSettings: element => (0, _renderer.default)(element).data(_m_constants.APPOINTMENT_SETTINGS_KEY), getAppointmentInfo: element => { const settings = utils.dataAccessors.getAppointmentSettings(element); return null === settings || void 0 === settings ? void 0 : settings.info }, create: (fields, currentDataAccessors, forceIsoDateParsing, dateSerializationFormat) => { const dataAccessors = currentDataAccessors ? _extends({}, currentDataAccessors) : { getter: {}, setter: {}, expr: {} }; (0, _iterator.each)(fields, ((name, expr) => { if (expr) { const getter = (0, _data.compileGetter)(expr); const setter = (0, _data.compileSetter)(expr); let dateGetter; let dateSetter; let serializationFormat; if (field = name, "startDate" === field || "endDate" === field) { dateGetter = object => { let value = getter(object); if (forceIsoDateParsing) { value = _date_serialization.default.deserializeDate(value) } return value }; dateSetter = (object, value) => { if (dateSerializationFormat) { serializationFormat = dateSerializationFormat } else if (forceIsoDateParsing && !serializationFormat) { const oldValue = getter(object); serializationFormat = _date_serialization.default.getDateSerializationFormat(oldValue) } const newValue = _date_serialization.default.serializeDate(value, serializationFormat); setter(object, newValue) } } dataAccessors.getter[name] = dateGetter || getter; dataAccessors.setter[name] = dateSetter || setter; dataAccessors.expr[`${name}Expr`] = expr } else { delete dataAccessors.getter[name]; delete dataAccessors.setter[name]; delete dataAccessors.expr[`${name}Expr`] } var field })); return dataAccessors } }, DOM: { getHeaderHeight: header => header ? header._$element && parseInt((0, _size.getOuterHeight)(header._$element), 10) : 0 }, renovation: { renderComponent: (widget, parentElement, componentClass, componentName, viewModel) => { let component = widget[componentName]; if (!component) { const container = (0, _element.getPublicElement)(parentElement); component = widget._createComponent(container, componentClass, viewModel); widget[componentName] = component } else { const $element = component.$element(); const elementStyle = $element.get(0).style; const { height: height } = elementStyle; const { width: width } = elementStyle; component.option(viewModel); if (height) { (0, _size.setHeight)($element, height) } if (width) { (0, _size.setWidth)($element, width) } } } } };