UNPKG

devextreme

Version:

HTML5 JavaScript Component Suite for Responsive Web Development

126 lines (124 loc) 5.27 kB
/** * DevExtreme (cjs/__internal/scheduler/r1/components/base/date_table_cell_base.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.DateTableCellBase = exports.DateTableCallBaseDefaultProps = void 0; var _inferno = require("inferno"); var _inferno2 = require("@devextreme/runtime/inferno"); var _index = require("../../../../core/r1/utils/index"); var _render_utils = require("../../../../core/r1/utils/render_utils"); var _index2 = require("../../utils/index"); var _const = require("../const"); var _cell = require("./cell"); 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 DateTableCallBaseDefaultProps = exports.DateTableCallBaseDefaultProps = _extends({}, _cell.CellBaseDefaultProps, { otherMonth: false, today: false, firstDayOfMonth: false, isSelected: false, isFocused: false }); const ADD_APPOINTMENT_LABEL = "Add appointment"; class DateTableCellBase extends _inferno2.BaseInfernoComponent { constructor() { super(...arguments); this.dataCellTemplateProps = null } getDataCellTemplateProps() { if (null !== this.dataCellTemplateProps) { return this.dataCellTemplateProps } const { allDay: allDay, contentTemplateProps: contentTemplateProps, endDate: endDate, groupIndex: groupIndex, groups: groups, index: index, startDate: startDate } = this.props; this.dataCellTemplateProps = { data: _extends({ startDate: startDate, endDate: endDate, groups: groups, groupIndex: groups ? groupIndex : void 0, text: "", allDay: !!allDay || void 0 }, null === contentTemplateProps || void 0 === contentTemplateProps ? void 0 : contentTemplateProps.data), index: index }; return this.dataCellTemplateProps } componentWillUpdate(nextProps) { if (this.props.allDay !== nextProps.allDay || this.props.contentTemplateProps !== nextProps.contentTemplateProps || this.props.endDate !== nextProps.endDate || this.props.groupIndex !== nextProps.groupIndex || this.props.groups !== nextProps.groups || this.props.index !== nextProps.index || this.props.startDate !== nextProps.startDate) { this.dataCellTemplateProps = null } } render() { const { viewContext: viewContext, allDay: allDay, className: className, isFocused: isFocused, isSelected: isSelected, isFirstGroupCell: isFirstGroupCell, isLastGroupCell: isLastGroupCell, dataCellTemplate: dataCellTemplate, children: children } = this.props; const { view: { type: viewType }, crossScrollingEnabled: crossScrollingEnabled } = viewContext; const cellSizeHorizontalClass = _index2.renderUtils.getCellSizeHorizontalClass(viewType, crossScrollingEnabled); const cellSizeVerticalClass = _index2.renderUtils.getCellSizeVerticalClass(!!allDay); const classes = (0, _render_utils.combineClasses)({ [cellSizeHorizontalClass]: true, [cellSizeVerticalClass]: true, [_const.DATE_TABLE_CELL_CLASS]: !allDay, "dx-state-focused": isSelected, "dx-scheduler-focused-cell": isFocused, [className ?? ""]: true }); const ariaLabel = isSelected ? "Add appointment" : void 0; const dataCellTemplateProps = this.getDataCellTemplateProps(); const DataCellTemplateComponent = (0, _index.getTemplate)(dataCellTemplate); return (0, _inferno.createComponentVNode)(2, _cell.CellBase, { className: classes, viewContext: viewContext, isFirstGroupCell: isFirstGroupCell, isLastGroupCell: isLastGroupCell, ariaLabel: ariaLabel, startDate: _cell.CellBaseDefaultProps.startDate, endDate: _cell.CellBaseDefaultProps.endDate, index: _cell.CellBaseDefaultProps.index, children: (0, _inferno.createFragment)([!DataCellTemplateComponent && children, !!DataCellTemplateComponent && DataCellTemplateComponent({ index: dataCellTemplateProps.index, data: dataCellTemplateProps.data })], 0) }) } } exports.DateTableCellBase = DateTableCellBase; DateTableCellBase.defaultProps = DateTableCallBaseDefaultProps;