UNPKG

devextreme

Version:

HTML5 JavaScript Component Suite for Responsive Web Development

127 lines (126 loc) 4.56 kB
/** * DevExtreme (esm/renovation/ui/scheduler/workspaces/base/header_panel/date_header/cell.js) * Version: 21.1.4 * Build date: Mon Jun 21 2021 * * Copyright (c) 2012 - 2021 Developer Express Inc. ALL RIGHTS RESERVED * Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/ */ import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose"; import _extends from "@babel/runtime/helpers/esm/extends"; var _excluded = ["allDay", "children", "className", "colSpan", "contentTemplate", "contentTemplateProps", "dateCellTemplate", "endDate", "groupIndex", "groups", "index", "isFirstGroupCell", "isLastGroupCell", "isTimeCellTemplate", "isWeekDayCell", "startDate", "text", "timeCellTemplate", "today"]; import { createVNode, createFragment, createComponentVNode, normalizeProps } from "inferno"; import { Fragment } from "inferno"; import { BaseInfernoComponent } from "@devextreme/vdom"; import { CellBaseProps } from "../../cell"; import { combineClasses } from "../../../../../../utils/combine_classes"; import { getGroupCellClasses } from "../../../utils"; export var viewFunction = _ref => { var { classes: classes, props: { colSpan: colSpan, dateCellTemplate: DateCellTemplate, groupIndex: groupIndex, groups: groups, index: index, isTimeCellTemplate: isTimeCellTemplate, startDate: startDate, text: text, timeCellTemplate: TimeCellTemplate }, useTemplate: useTemplate } = _ref; return createVNode(1, "th", classes, useTemplate ? createFragment([isTimeCellTemplate && TimeCellTemplate && TimeCellTemplate({ data: { date: startDate, text: text, groups: groups, groupIndex: groupIndex }, index: index }), !isTimeCellTemplate && DateCellTemplate && DateCellTemplate({ data: { date: startDate, text: text, groups: groups, groupIndex: groupIndex }, index: index })], 0) : text, 0, { colSpan: colSpan, title: text }) }; export var DateHeaderCellProps = _extends({}, CellBaseProps, { today: false, colSpan: 1, isWeekDayCell: false, isTimeCellTemplate: false }); var getTemplate = TemplateProp => TemplateProp && (TemplateProp.defaultProps ? props => normalizeProps(createComponentVNode(2, TemplateProp, _extends({}, props))) : TemplateProp); export class DateHeaderCell extends BaseInfernoComponent { constructor(props) { super(props); this.state = {} } get classes() { var { className: className, isFirstGroupCell: isFirstGroupCell, isLastGroupCell: isLastGroupCell, isWeekDayCell: isWeekDayCell, today: today } = this.props; var cellClasses = combineClasses({ "dx-scheduler-header-panel-cell": true, "dx-scheduler-cell-sizes-horizontal": true, "dx-scheduler-header-panel-current-time-cell": today, "dx-scheduler-header-panel-week-cell": isWeekDayCell, [className]: !!className }); return getGroupCellClasses(isFirstGroupCell, isLastGroupCell, cellClasses) } get useTemplate() { var { dateCellTemplate: dateCellTemplate, isTimeCellTemplate: isTimeCellTemplate, timeCellTemplate: timeCellTemplate } = this.props; return !isTimeCellTemplate && !!dateCellTemplate || isTimeCellTemplate && !!timeCellTemplate } get restAttributes() { var _this$props = this.props, restProps = _objectWithoutPropertiesLoose(_this$props, _excluded); return restProps } render() { var props = this.props; return viewFunction({ props: _extends({}, props, { timeCellTemplate: getTemplate(props.timeCellTemplate), dateCellTemplate: getTemplate(props.dateCellTemplate), contentTemplate: getTemplate(props.contentTemplate) }), classes: this.classes, useTemplate: this.useTemplate, restAttributes: this.restAttributes }) } } DateHeaderCell.defaultProps = _extends({}, DateHeaderCellProps);