UNPKG

devextreme

Version:

JavaScript/TypeScript Component Suite for Responsive Web Development

82 lines (81 loc) 3.01 kB
/** * DevExtreme (esm/__internal/scheduler/r1/components/base/header_panel.js) * Version: 25.2.7 * Build date: Tue May 05 2026 * * Copyright (c) 2012 - 2026 Developer Express Inc. ALL RIGHTS RESERVED * Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/ */ import { createVNode, createComponentVNode } from "inferno"; import { createReRenderEffect, InfernoWrapperComponent } from "../../../../core/r1/runtime/inferno/index"; import { PublicTemplate } from "../../../../scheduler/r1/components/templates/index"; import { isHorizontalGroupingApplied } from "../../utils/index"; import { DateHeader } from "./date_header"; import { GroupPanel, GroupPanelDefaultProps } from "./group_panel"; export const HeaderPanelDefaultProps = Object.assign({}, GroupPanelDefaultProps, { isRenderDateHeader: true, dateHeaderTemplate: DateHeader }); export class HeaderPanel extends InfernoWrapperComponent { createEffects() { return [createReRenderEffect()] } render() { const { viewContext: viewContext, dateHeaderData: dateHeaderData, groupByDate: groupByDate, groupOrientation: groupOrientation, groupPanelData: groupPanelData, groups: groups, isRenderDateHeader: isRenderDateHeader, dateCellTemplate: dateCellTemplate, dateHeaderTemplate: dateHeaderTemplate, resourceCellTemplate: resourceCellTemplate, timeCellTemplate: timeCellTemplate } = this.props; const isHorizontalGrouping = isHorizontalGroupingApplied(groups.length, groupOrientation); return createVNode(1, "thead", null, [isHorizontalGrouping && !groupByDate && createComponentVNode(2, GroupPanel, { viewContext: viewContext, groupPanelData: groupPanelData, groups: groups, groupByDate: groupByDate, groupOrientation: groupOrientation, resourceCellTemplate: resourceCellTemplate }), isRenderDateHeader && createComponentVNode(2, PublicTemplate, { template: dateHeaderTemplate, templateProps: { viewContext: viewContext, groupByDate: groupByDate, dateHeaderData: dateHeaderData, groupOrientation: groupOrientation, groups: groups, dateCellTemplate: dateCellTemplate, timeCellTemplate: timeCellTemplate } }), groupByDate && createComponentVNode(2, GroupPanel, { viewContext: viewContext, groupPanelData: groupPanelData, groups: groups, groupByDate: groupByDate, groupOrientation: groupOrientation, resourceCellTemplate: resourceCellTemplate })], 0) } } HeaderPanel.defaultProps = HeaderPanelDefaultProps;