devextreme
Version:
HTML5 JavaScript Component Suite for Responsive Web Development
143 lines (142 loc) • 4.96 kB
JavaScript
/**
* DevExtreme (esm/ui/grid_core/ui.grid_core.header_panel.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 $ from "../../core/renderer";
import Toolbar from "../toolbar";
import {
ColumnsView
} from "./ui.grid_core.columns_view";
import {
noop
} from "../../core/utils/common";
import {
isDefined
} from "../../core/utils/type";
import {
triggerResizeEvent
} from "../../events/visibility_change";
import messageLocalization from "../../localization/message";
import "../drop_down_menu";
var HEADER_PANEL_CLASS = "header-panel";
var TOOLBAR_BUTTON_CLASS = "toolbar-button";
var TOOLBAR_ARIA_LABEL = "-ariaToolbar";
var HeaderPanel = ColumnsView.inherit({
_getToolbarItems: function() {
return []
},
_getButtonContainer: function() {
return $("<div>").addClass(this.addWidgetPrefix(TOOLBAR_BUTTON_CLASS))
},
_getToolbarButtonClass: function(specificClass) {
var secondClass = specificClass ? " " + specificClass : "";
return this.addWidgetPrefix(TOOLBAR_BUTTON_CLASS) + secondClass
},
_getToolbarOptions: function() {
var options = {
toolbarOptions: {
items: this._getToolbarItems(),
onItemRendered: function(e) {
var itemRenderedCallback = e.itemData.onItemRendered;
if (itemRenderedCallback) {
itemRenderedCallback(e)
}
}
}
};
this.executeAction("onToolbarPreparing", options);
if (options.toolbarOptions && !isDefined(options.toolbarOptions.visible)) {
var toolbarItems = options.toolbarOptions.items;
options.toolbarOptions.visible = !!(toolbarItems && toolbarItems.length)
}
return options.toolbarOptions
},
_renderCore: function() {
if (!this._toolbar) {
var $headerPanel = this.element();
$headerPanel.addClass(this.addWidgetPrefix(HEADER_PANEL_CLASS));
var label = messageLocalization.format(this.component.NAME + TOOLBAR_ARIA_LABEL);
var $toolbar = $("<div>").attr("aria-label", label).appendTo($headerPanel);
this._toolbar = this._createComponent($toolbar, Toolbar, this._toolbarOptions)
} else {
this._toolbar.option(this._toolbarOptions)
}
},
_columnOptionChanged: noop,
_handleDataChanged: function() {
if (this._requireReady) {
this.render()
}
},
init: function() {
this.callBase();
this.createAction("onToolbarPreparing", {
excludeValidators: ["disabled", "readOnly"]
})
},
render: function() {
this._toolbarOptions = this._getToolbarOptions();
this.callBase.apply(this, arguments)
},
setToolbarItemDisabled: function(name, optionValue) {
var toolbarInstance = this._toolbar;
if (toolbarInstance) {
var items = toolbarInstance.option("items") || [];
var itemIndex = items.indexOf(items.filter((function(item) {
return item.name === name
}))[0]);
if (itemIndex >= 0) {
var itemOptionPrefix = "items[" + itemIndex + "]";
if (toolbarInstance.option(itemOptionPrefix + ".options")) {
toolbarInstance.option(itemOptionPrefix + ".options.disabled", optionValue)
} else {
toolbarInstance.option(itemOptionPrefix + ".disabled", optionValue)
}
}
}
},
updateToolbarDimensions: function() {
if (this._toolbar) {
triggerResizeEvent(this.getHeaderPanel())
}
},
getHeaderPanel: function() {
return this.element()
},
getHeight: function() {
return this.getElementHeight()
},
optionChanged: function(args) {
if ("onToolbarPreparing" === args.name) {
this._invalidate();
args.handled = true
}
this.callBase(args)
},
isVisible: function() {
return this._toolbarOptions && this._toolbarOptions.visible
},
allowDragging: noop
});
export var headerPanelModule = {
defaultOptions: function() {
return {}
},
views: {
headerPanel: HeaderPanel
},
extenders: {
controllers: {
resizing: {
_updateDimensionsCore: function() {
this.callBase.apply(this, arguments);
this.getView("headerPanel").updateToolbarDimensions()
}
}
}
}
};