UNPKG

devextreme

Version:

HTML5 JavaScript Component Suite for Responsive Web Development

96 lines (95 loc) 3.27 kB
/** * DevExtreme (esm/renovation/ui/scheduler/appointment/layout.js) * Version: 21.2.4 * Build date: Mon Dec 06 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 = ["appointmentTemplate", "appointments", "isAllDay", "overflowIndicatorTemplate", "overflowIndicators"]; import { createVNode, createComponentVNode, normalizeProps } from "inferno"; import { InfernoWrapperComponent } from "@devextreme/runtime/inferno"; import { Appointment } from "./appointment"; import { OverflowIndicator } from "./overflow_indicator/layout"; import { combineClasses } from "../../../utils/combine_classes"; export var viewFunction = _ref => { var { classes: classes, props: { appointmentTemplate: appointmentTemplate, appointments: appointments, overflowIndicatorTemplate: overflowIndicatorTemplate, overflowIndicators: overflowIndicators } } = _ref; return createVNode(1, "div", classes, [appointments.map((item, index) => createComponentVNode(2, Appointment, { viewModel: item, appointmentTemplate: appointmentTemplate, index: index }, item.key)), overflowIndicators.map(item => createComponentVNode(2, OverflowIndicator, { viewModel: item, overflowIndicatorTemplate: overflowIndicatorTemplate }, item.key))], 0) }; export var AppointmentLayoutProps = { isAllDay: false, get appointments() { return [] }, get overflowIndicators() { return [] } }; import { createReRenderEffect } from "@devextreme/runtime/inferno"; var getTemplate = TemplateProp => TemplateProp && (TemplateProp.defaultProps ? props => normalizeProps(createComponentVNode(2, TemplateProp, _extends({}, props))) : TemplateProp); export class AppointmentLayout extends InfernoWrapperComponent { constructor(props) { super(props); this.state = {} } createEffects() { return [createReRenderEffect()] } get classes() { var { isAllDay: isAllDay } = this.props; return combineClasses({ "dx-scheduler-scrollable-appointments": !isAllDay, "dx-scheduler-all-day-appointments": isAllDay }) } get restAttributes() { var _this$props = this.props, restProps = _objectWithoutPropertiesLoose(_this$props, _excluded); return restProps } render() { var props = this.props; return viewFunction({ props: _extends({}, props, { appointmentTemplate: getTemplate(props.appointmentTemplate), overflowIndicatorTemplate: getTemplate(props.overflowIndicatorTemplate) }), classes: this.classes, restAttributes: this.restAttributes }) } } AppointmentLayout.defaultProps = AppointmentLayoutProps;