UNPKG

devextreme

Version:

HTML5 JavaScript Component Suite for Responsive Web Development

125 lines (123 loc) 4.45 kB
/** * DevExtreme (cjs/__internal/scheduler/header/m_view_switcher.js) * Version: 25.1.3 * Build date: Wed Jun 25 2025 * * Copyright (c) 2012 - 2025 Developer Express Inc. ALL RIGHTS RESERVED * Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/ */ "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.getTabViewSwitcher = exports.getDropDownViewSwitcher = void 0; var _themes = require("../../../ui/themes"); var _m_utils = require("./m_utils"); function _extends() { return _extends = Object.assign ? Object.assign.bind() : function(n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) { ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]) } } return n }, _extends.apply(null, arguments) } const ClASS = { container: "dx-scheduler-view-switcher", dropDownButton: "dx-scheduler-view-switcher-dropdown-button", dropDownButtonContent: "dx-scheduler-view-switcher-dropdown-button-content" }; const getViewsAndSelectedView = header => { const views = (0, _m_utils.formatViews)(header.views); let selectedView = (0, _m_utils.getViewName)(header.currentView); const isSelectedViewInViews = views.some((view => view.name === selectedView)); selectedView = isSelectedViewInViews ? selectedView : void 0; return { selectedView: selectedView, views: views } }; const getTabViewSwitcher = (header, item) => { const { selectedView: selectedView, views: views } = getViewsAndSelectedView(header); const stylingMode = (0, _themes.isFluent)() ? "outlined" : "contained"; return _extends({ widget: "dxButtonGroup", locateInMenu: "auto", location: "after", name: "viewSwitcher", cssClass: ClASS.container, options: { items: views, keyExpr: "name", selectedItemKeys: [selectedView], stylingMode: stylingMode, onItemClick: e => { const { view: view } = e.itemData; header._updateCurrentView(view) }, onContentReady: e => { const viewSwitcher = e.component; header._addEvent("currentView", (view => { viewSwitcher.option("selectedItemKeys", [(0, _m_utils.getViewName)(view)]) })) } } }, item) }; exports.getTabViewSwitcher = getTabViewSwitcher; const getDropDownViewSwitcher = (header, item) => { const { selectedView: selectedView, views: views } = getViewsAndSelectedView(header); const oneView = (0, _m_utils.isOneView)(views, selectedView); return _extends({ widget: "dxDropDownButton", locateInMenu: "never", location: "after", name: "viewSwitcher", cssClass: ClASS.container, options: { items: views, useSelectMode: true, keyExpr: "name", selectedItemKey: selectedView, displayExpr: "text", showArrowIcon: !oneView, elementAttr: { class: ClASS.dropDownButton }, onItemClick: e => { const { view: view } = e.itemData; header._updateCurrentView(view) }, onContentReady: e => { const viewSwitcher = e.component; header._addEvent("currentView", (view => { const currentViews = (0, _m_utils.formatViews)(header.views); viewSwitcher.option("showArrowIcon", !(0, _m_utils.isOneView)(currentViews, view)); viewSwitcher.option("selectedItemKey", (0, _m_utils.getViewName)(view)) })) }, dropDownOptions: { onShowing: e => { if (oneView) { e.cancel = true } }, width: "max-content", _wrapperClassExternal: ClASS.dropDownButtonContent } } }, item) }; exports.getDropDownViewSwitcher = getDropDownViewSwitcher;