devextreme
Version:
HTML5 JavaScript Component Suite for Responsive Web Development
95 lines (94 loc) • 3.76 kB
JavaScript
/**
* DevExtreme (esm/renovation/ui/scheduler/appointment_tooltip/appointment_list.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 = ["appointments", "checkAndDeleteAppointment", "focusStateEnabled", "getSingleAppointmentData", "getTextAndFormatDate", "isEditingAllowed", "itemContentTemplate", "onHide", "showAppointmentPopup", "target"];
import {
createComponentVNode,
normalizeProps
} from "inferno";
import {
BaseInfernoComponent
} from "@devextreme/vdom";
import noop from "../../../utils/noop";
import {
List
} from "../../list";
import {
TooltipItemLayout
} from "./item_layout";
import getCurrentAppointment from "./utils/get_current_appointment";
import {
defaultGetTextAndFormatDate,
defaultGetSingleAppointment
} from "./utils/default_functions";
export var viewFunction = viewModel => normalizeProps(createComponentVNode(2, List, _extends({
itemTemplate: _ref => {
var {
index: index,
item: item
} = _ref;
return createComponentVNode(2, TooltipItemLayout, {
item: item,
index: index,
onDelete: viewModel.props.checkAndDeleteAppointment,
onHide: viewModel.props.onHide,
itemContentTemplate: viewModel.props.itemContentTemplate,
getTextAndFormatDate: viewModel.props.getTextAndFormatDate,
singleAppointment: viewModel.props.getSingleAppointmentData(item.data, viewModel.props.target),
showDeleteButton: viewModel.props.isEditingAllowed && !item.data.disabled
})
},
dataSource: viewModel.props.appointments,
focusStateEnabled: viewModel.props.focusStateEnabled,
onItemClick: viewModel.onItemClick
}, viewModel.restAttributes)));
export var AppointmentListProps = {
isEditingAllowed: true,
focusStateEnabled: false,
showAppointmentPopup: noop,
onHide: noop,
checkAndDeleteAppointment: noop,
getTextAndFormatDate: defaultGetTextAndFormatDate,
getSingleAppointmentData: defaultGetSingleAppointment
};
var getTemplate = TemplateProp => TemplateProp && (TemplateProp.defaultProps ? props => normalizeProps(createComponentVNode(2, TemplateProp, _extends({}, props))) : TemplateProp);
export class AppointmentList extends BaseInfernoComponent {
constructor(props) {
super(props);
this.state = {}
}
get onItemClick() {
return _ref2 => {
var {
itemData: itemData
} = _ref2;
var {
showAppointmentPopup: showAppointmentPopup
} = this.props;
null === showAppointmentPopup || void 0 === showAppointmentPopup ? void 0 : showAppointmentPopup(itemData.data, false, getCurrentAppointment(itemData))
}
}
get restAttributes() {
var _this$props = this.props,
restProps = _objectWithoutPropertiesLoose(_this$props, _excluded);
return restProps
}
render() {
var props = this.props;
return viewFunction({
props: _extends({}, props, {
itemContentTemplate: getTemplate(props.itemContentTemplate)
}),
onItemClick: this.onItemClick,
restAttributes: this.restAttributes
})
}
}
AppointmentList.defaultProps = _extends({}, AppointmentListProps);