devextreme
Version:
HTML5 JavaScript Component Suite for Responsive Web Development
96 lines (95 loc) • 3.27 kB
JavaScript
/**
* 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;