devextreme
Version:
HTML5 JavaScript Component Suite for Responsive Web Development
106 lines (104 loc) • 3.96 kB
JavaScript
/**
* DevExtreme (cjs/ui/scheduler/header/viewSwitcher.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/
*/
;
exports.getViewSwitcher = exports.getDropDownViewSwitcher = void 0;
var _utils = require("./utils");
function _extends() {
_extends = Object.assign || function(target) {
for (var i = 1; i < arguments.length; i++) {
var source = arguments[i];
for (var key in source) {
if (Object.prototype.hasOwnProperty.call(source, key)) {
target[key] = source[key]
}
}
}
return target
};
return _extends.apply(this, arguments)
}
var VIEW_SWITCHER_CLASS = "dx-scheduler-view-switcher";
var VIEW_SWITCHER_DROP_DOWN_BUTTON_CLASS = "dx-scheduler-view-switcher-dropdown-button";
var VIEW_SWITCHER_DROP_DOWN_BUTTON_CONTENT_CLASS = "dx-scheduler-view-switcher-dropdown-button-content";
var getViewsAndSelectedView = function(header) {
var views = (0, _utils.formatViews)(header.views);
var selectedView = (0, _utils.getViewName)(header.currentView);
var isSelectedViewInViews = views.some((function(view) {
return view.name === selectedView
}));
selectedView = isSelectedViewInViews ? selectedView : void 0;
return {
selectedView: selectedView,
views: views
}
};
var getViewSwitcher = function(header, item) {
var _getViewsAndSelectedV = getViewsAndSelectedView(header),
selectedView = _getViewsAndSelectedV.selectedView,
views = _getViewsAndSelectedV.views;
return _extends({
widget: "dxButtonGroup",
locateInMenu: "auto",
cssClass: VIEW_SWITCHER_CLASS,
options: {
items: views,
keyExpr: "name",
selectedItemKeys: [selectedView],
stylingMode: "contained",
onItemClick: function(e) {
var view = e.itemData.view;
header._updateCurrentView(view)
},
onContentReady: function(e) {
var viewSwitcher = e.component;
header._addEvent("currentView", (function(view) {
viewSwitcher.option("selectedItemKeys", [(0, _utils.getViewName)(view)])
}))
}
}
}, item)
};
exports.getViewSwitcher = getViewSwitcher;
var getDropDownViewSwitcher = function(header, item) {
var _getViewsAndSelectedV2 = getViewsAndSelectedView(header),
selectedView = _getViewsAndSelectedV2.selectedView,
views = _getViewsAndSelectedV2.views;
return _extends({
widget: "dxDropDownButton",
locateInMenu: "never",
cssClass: VIEW_SWITCHER_CLASS,
options: {
items: views,
useSelectMode: true,
keyExpr: "name",
selectedItemKey: selectedView,
displayExpr: "text",
elementAttr: {
class: VIEW_SWITCHER_DROP_DOWN_BUTTON_CLASS
},
onItemClick: function(e) {
var view = e.itemData.view;
header._updateCurrentView(view)
},
onContentReady: function(e) {
var viewSwitcher = e.component;
header._addEvent("currentView", (function(view) {
viewSwitcher.option("selectedItemKey", (0, _utils.getViewName)(view))
}))
},
dropDownOptions: {
width: "max-content",
wrapperAttr: {
class: VIEW_SWITCHER_DROP_DOWN_BUTTON_CONTENT_CLASS
}
}
}
}, item)
};
exports.getDropDownViewSwitcher = getDropDownViewSwitcher;