UNPKG

devextreme

Version:

HTML5 JavaScript Component Suite for Responsive Web Development

97 lines (96 loc) 3.3 kB
/** * DevExtreme (esm/renovation/ui/scheduler/workspaces/base/group_panel/group_panel.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 = ["baseColSpan", "className", "columnCountPerGroup", "groupByDate", "groupOrientation", "groups", "height", "resourceCellTemplate"]; import { createComponentVNode, normalizeProps } from "inferno"; import { InfernoWrapperComponent } from "@devextreme/vdom"; import { isVerticalGroupOrientation } from "../../utils"; import { GroupPanelProps } from "./group_panel_props"; import { GroupPanelVerticalLayout } from "./vertical/layout"; import { GroupPanelHorizontalLayout } from "./horizontal/layout"; import { getGroupsRenderData } from "./utils"; export var viewFunction = _ref => { var { groupsRenderData: groupsRenderData, layout: Layout, props: { baseColSpan: baseColSpan, className: className, groupByDate: groupByDate, groups: groups, height: height, resourceCellTemplate: resourceCellTemplate }, restAttributes: restAttributes } = _ref; return createComponentVNode(2, Layout, { groups: groups, height: height, resourceCellTemplate: resourceCellTemplate, groupByDate: groupByDate, className: className, groupsRenderData: groupsRenderData, baseColSpan: baseColSpan, styles: restAttributes.style }) }; var getTemplate = TemplateProp => TemplateProp && (TemplateProp.defaultProps ? props => normalizeProps(createComponentVNode(2, TemplateProp, _extends({}, props))) : TemplateProp); export class GroupPanel extends InfernoWrapperComponent { constructor(props) { super(props); this.state = {} } get layout() { var { groupOrientation: groupOrientation } = this.props; return isVerticalGroupOrientation(groupOrientation) ? GroupPanelVerticalLayout : GroupPanelHorizontalLayout } get groupsRenderData() { var { columnCountPerGroup: columnCountPerGroup, groupByDate: groupByDate, groups: groups } = this.props; return getGroupsRenderData(groups, columnCountPerGroup, groupByDate) } get restAttributes() { var _this$props = this.props, restProps = _objectWithoutPropertiesLoose(_this$props, _excluded); return restProps } render() { var props = this.props; return viewFunction({ props: _extends({}, props, { resourceCellTemplate: getTemplate(props.resourceCellTemplate) }), layout: this.layout, groupsRenderData: this.groupsRenderData, restAttributes: this.restAttributes }) } } GroupPanel.defaultProps = _extends({}, GroupPanelProps);