Current Path : /var/www/www-root/data/www.catalog.monolith-realty.ru/bitrix/js/ui/actionpanel/ |
Current File : /var/www/www-root/data/www.catalog.monolith-realty.ru/bitrix/js/ui/actionpanel/panel.js |
;(function() { 'use strict'; BX.namespace('BX.UI'); BX.UI.ActionPanel = function(options) { this.groupActions = options.groupActions; this.layout = { container: null, itemContainer: null, more: null, reset: null, totalSelected: null, totalSelectedItem: null }; this.itemContainer = null; this.className = options.className; this.renderTo = options.renderTo; this.darkMode = options.darkMode; this.floatMode = typeof options.floatMode === 'undefined' ? true : options.floatMode; this.alignItems = options.alignItems; this.items = []; this.hiddenItems = []; this.grid = null; this.tileGrid = null; this.maxHeight = options.maxHeight; this.params = options.params || {}; this.parentPosition = options.parentPosition; this.mutationObserver = null; this.panelIsFixed = null; this.removeLeftPosition = options.removeLeftPosition; this.pinnedMode = typeof options.pinnedMode === 'undefined' ? false : options.pinnedMode; this.autoHide = typeof options.autoHide === 'undefined' ? true : options.autoHide; this.showTotalSelectedBlock = typeof options.showTotalSelectedBlock === 'undefined' ? true : options.showTotalSelectedBlock; this.showResetAllBlock = typeof options.showResetAllBlock === 'undefined' ? (this.pinnedMode ? false : true) : options.showResetAllBlock; this.buildPanelContainer(); if (this.pinnedMode) { this.buildPanelByGroup(); } BX.onCustomEvent('BX.UI.ActionPanel:created', [this]); }; BX.UI.ActionPanel.prototype = { bindEvents: function() { if (this.params.tileGridId) { BX.addCustomEvent('BX.TileGrid.Grid::ready', this.handleTileGridReady.bind(this)); BX.addCustomEvent(window, 'BX.TileGrid.Grid:selectItem', this.handleTileSelectItem.bind(this)); BX.addCustomEvent(window, 'BX.TileGrid.Grid:checkItem', this.handleTileSelectItem.bind(this)); BX.addCustomEvent(window, 'BX.TileGrid.Grid:unSelectItem', this.handleTileUnSelectItem.bind(this)); BX.addCustomEvent(window, 'BX.TileGrid.Grid:redraw', this.hidePanel.bind(this)); BX.addCustomEvent(window, 'BX.TileGrid.Grid:defineEscapeKey', this.hidePanel.bind(this)); BX.addCustomEvent(window, 'BX.TileGrid.Grid:lastSelectedItem', this.hidePanel.bind(this)); BX.addCustomEvent(window, 'BX.TileGrid.Grid:multiSelectModeOff', this.hidePanel.bind(this)); } if (this.params.gridId) { BX.addCustomEvent('Grid::ready', this.handleGridReady.bind(this)); BX.addCustomEvent('Grid::thereSelectedRows', this.handleGridSelectItem.bind(this)); BX.addCustomEvent('Grid::allRowsSelected', this.handleGridSelectItem.bind(this)); BX.addCustomEvent('Grid::updated', this.hidePanel.bind(this)); BX.addCustomEvent('Grid::noSelectedRows', this.hidePanel.bind(this)); BX.addCustomEvent('Grid::allRowsUnselected', this.hidePanel.bind(this)); } if (this.autoHide) { BX.bind(window, 'click', this.handleOuterClick.bind(this)); } if (this.floatMode) { BX.bind(window, 'scroll', BX.throttle(this.handleScroll, 50, this)); } BX.addCustomEvent(this, 'BX.UI.ActionPanel:clickResetAllBlock', this.hidePanel.bind(this)); BX.bind(window, 'resize', BX.throttle(this.handleResize, 20, this)); this.getMutationObserver().observe(document.body, this.getMutationObserverParam()); }, getMutationObserver: function() { if(this.mutationObserver) return this.mutationObserver; this.mutationObserver = new MutationObserver(BX.throttle(this.adjustPanelStyle, 20, this)); return this.mutationObserver; }, getMutationObserverParam: function() { return { attributes: true, characterData: true, childList: true, subtree: true, attributeOldValue: true, characterDataOldValue: true } }, /** * @param {String }id * @return {BX.UI.ActionPanel.Item} */ getItemById: function(id) { return this.items.find(function (item) { return item.id === id; }); }, addItems: function(items) { items.forEach(function (item) { this.appendItem(item); }.bind(this)); this.fillHiddenItems(); if (this.hiddenItems.length > 0 && !this.layout.more) { this.appendMoreBlock(); } else if (this.layout.more) { this.removeMoreBlock() } }, buildItem: function(options) { options.actionPanel = this; return new BX.UI.ActionPanel.Item(options); }, appendItem: function(options) { if(options.hiddenInPanel !== true) { var item = this.buildItem(options); this.items.push(item); this.layout.itemContainer.appendChild(item.render()); } }, addHiddenItem: function(item) { this.hiddenItems.push(item); }, removeHiddenItem: function(item) { for (var i = 0; i < this.hiddenItems.length; i++) { if (this.hiddenItems[i].id === item.id) { delete this.hiddenItems[i]; this.hiddenItems.splice(i, 1); return; } } }, fillHiddenItems: function() { this.hiddenItems = []; this.items.forEach( function (item) { if (item.isNotFit()) { this.addHiddenItem(item); } }, this ); }, removeItems: function () { this.items.forEach(function (item) { item.destroy(); }); this.items = []; this.hiddenItems = []; }, getMoreBlock: function() { if (!this.layout.more) { this.layout.more = BX.create("div", { props: { className: "ui-action-panel-more" }, text: BX.message('JS_UI_ACTIONPANEL_MORE_BLOCK'), events: { click: this.handleClickMoreBlock.bind(this) } }); } return this.layout.more; }, appendMoreBlock: function() { this.layout.container.appendChild(this.getMoreBlock()); this.fillHiddenItems(); }, getResetAllBlock: function() { this.layout.reset = BX.create("div", { props: { className: "ui-action-panel-reset" } }); this.removeLeftPosition ? BX.addClass(this.layout.reset, "ui-action-panel-reset-ordert-first") : null; BX.bind(this.layout.reset, "click", function() { BX.onCustomEvent(this, 'BX.UI.ActionPanel:clickResetAllBlock'); this.resetAllSection(); }.bind(this)); return this.layout.reset }, resetAllSection: function() { if (this.grid) { this.grid.getRows().unselectAll(); this.grid.adjustCheckAllCheckboxes(); } else if (this.tileGrid) { this.tileGrid.resetSetMultiSelectMode(); this.tileGrid.resetSelectAllItems(); this.tileGrid.resetFromToItems(); } }, handleScroll: function () { if (this.getDistanceFromTop() > 0) { if(this.panelIsFixed) this.unfixPanel(); } else { if(!this.panelIsFixed) this.fixPanel(); } var moreMenu = BX.PopupMenu.getMenuById('ui-action-panel-item-popup-menu'); if (moreMenu) { moreMenu.popupWindow.adjustPosition(); } }, handleOuterClick: function (event) { var target = BX.getEventTarget(event); if (BX.hasClass(target, "ui-action-panel")) { return; } if (BX.findParent(target, {className: "ui-action-panel"})) { return; } if (BX.findParent(target, {className: "main-grid-container"})) { return; } if (BX.findParent(target, {className: "ui-grid-tile-item"})) { return; } if (BX.findParent(target, {className: "main-kanban-item"})) { return; } this.hidePanel(); if (this.grid) { this.resetAllSection(); } }, handleClickMoreBlock: function (event) { for (var i = 0; i < this.hiddenItems.length; i++) { if (this.hiddenItems[i].buttonIconClass && this.hiddenItems[i].text.length === 0) { this.hiddenItems[i].className = "menu-popup-no-icon ui-btn ui-btn-link " + this.hiddenItems[i].buttonIconClass; this.hiddenItems[i].html = '<span></span>' } } var popupMenu = new BX.PopupMenuWindow({ bindElement: this.getMoreBlock(), className: "ui-action-panel-item-popup-menu", angle: true, offsetLeft: this.getMoreBlock().offsetWidth / 2, closeByEsc: true, items: this.hiddenItems, events: { onPopupShow: function() { BX.bind(popupMenu.popupWindow.popupContainer, 'click', function(event) { var target = BX.getEventTarget(event); var item = BX.findParent(target, { className: 'menu-popup-item' }, 10); if (!item || !item.dataset.preventCloseContextMenu) { popupMenu.close(); } }); }, onPopupClose: function() { popupMenu.destroy(); BX.removeClass(this.getMoreBlock(), "ui-action-panel-item-active"); }.bind(this) } }); popupMenu.layout.menuContainer.setAttribute("data-tile-grid", "tile-grid-stop-close"); popupMenu.show(); }, removeMoreBlock: function() { if(!this.layout.more) return; this.layout.more.parentNode.removeChild(this.layout.more); this.layout.more = null; }, getDistanceFromTop: function() { return this.resolveRenderContainer().getBoundingClientRect().top; }, fixPanel: function() { BX.addClass(this.layout.container, "ui-action-panel-fixed"); this.panelIsFixed = true; }, unfixPanel: function() { BX.removeClass(this.layout.container, "ui-action-panel-fixed"); this.panelIsFixed = null; }, buildPanelContainer: function() { this.layout.container = BX.create("div", { attrs: { className: ['ui-action-panel', this.darkMode ? 'ui-action-panel-darkmode' : '', this.className].join(' ') }, dataset: { tileGrid: "tile-grid-stop-close" }, children: [ this.showTotalSelectedBlock? this.getTotalSelectedBlock() : null, this.getItemContainer(), this.showResetAllBlock? this.getResetAllBlock() : null ] }); this.maxHeight ? this.layout.container.style.maxHeight = this.maxHeight + "px" : null; }, getItemContainer: function() { return this.layout.itemContainer = BX.create('div', { props: { className: 'ui-action-panel-wrapper' }, style: { textAlign: this.alignItems ? this.alignItems : null } }) }, getTotalSelectedBlock: function() { return this.layout.totalSelected = BX.create('div', { props: { className: this.removeLeftPosition ? 'ui-action-panel-total ui-action-panel-total-without-border' : 'ui-action-panel-total' }, dataset: { role: 'action-panel-total' }, children: [ BX.create('span', { props: { className: 'ui-action-panel-total-label' }, text: BX.message('JS_UI_ACTIONPANEL_IS_SELECTED') }), this.layout.totalSelectedItem = BX.create('span', { props: { className: 'ui-action-panel-total-param' }, dataset: { role: 'action-panel-total-param' } }) ] }) }, getPanelContainer: function() { return this.layout.container }, adjustPanelStyle: function() { var parentContainerParam = BX.pos(this.resolveRenderContainer()); var offsetTop = 0; if(this.maxHeight) { offsetTop = parentContainerParam.height - this.maxHeight; } this.layout.container.style.width = parentContainerParam.width + "px"; this.layout.container.style.top = (parentContainerParam.top + offsetTop) + "px"; this.panelIsFixed ? this.layout.container.style.left = this.resolveRenderContainer().getBoundingClientRect().left + 'px' : this.layout.container.style.left = parentContainerParam.left + "px"; }, handleResize: function() { this.adjustPanelStyle(); this.fillHiddenItems(); if (this.hiddenItems.length > 0) { this.layout.more || this.appendMoreBlock(); } else { !this.layout.more || this.removeMoreBlock(); } }, /** * @param {BX.Main.grid} grid */ handleGridReady: function(grid) { if (!this.grid && grid.getContainerId() === this.params.gridId) { this.grid = grid; } }, /** * @param {BX.TileGrid.Grid} tileGrid */ handleTileGridReady: function(tileGrid) { if (!this.tileGrid && tileGrid.getId() === this.params.tileGridId) { this.tileGrid = tileGrid; } }, /** * @param {BX.Grid.Row} item * @param {BX.Main.grid} grid */ handleGridUnSelectItem: function(item, grid) { if (grid.getRows().getSelectedIds().length === 1) { this.buildPanelByItem(grid.getRows().getSelected().pop()); } }, /** * @param {BX.Disk.TileGrid.Item} item * @param {BX.TileGrid.Grid} tileGrid */ handleTileUnSelectItem: function(item, tileGrid) { if (this.showTotalSelectedBlock) { this.setTotalSelectedItems(tileGrid.getSelectedItems().length); } if (tileGrid.getSelectedItems().length === 1) { this.buildPanelByItem(tileGrid.getSelectedItems().pop()); } }, handleGridSelectItem: function() { if (this.showTotalSelectedBlock) { this.setTotalSelectedItems(this.grid.getRows().getSelectedIds().length); } if (this.grid.getRows().getSelectedIds().length > 1) { this.buildPanelByGroup(); } else { this.buildPanelByItem(this.grid.getRows().getSelected().pop()); } }, /** * @param {BX.Disk.TileGrid.Item} item * @param {BX.TileGrid.Grid} tileGrid */ handleTileSelectItem: function(item, tileGrid) { if (this.showTotalSelectedBlock) { this.setTotalSelectedItems(tileGrid.getSelectedItems().length); } if (tileGrid.isMultiSelectMode() && tileGrid.getSelectedItems().length > 1) { this.buildPanelByGroup(); } else { this.buildPanelByItem(item); } }, /** * @param {BX.Disk.TileGrid.Item|BX.Grid.Row} item */ buildPanelByItem: function(item) { var actions = item.getActions(); var buttons = []; actions.forEach(function (action) { if (!action.hideInActionPanel) { buttons.push(action); } }.bind(this)); this.removeItems(); this.addItems(buttons); this.showPanel(); if(this.hiddenItems.length <= 0) this.removeMoreBlock(); }, buildPanelByGroup: function() { if (!this.groupActions) { return; } var buttons = this.extractButtonsFromGroupActions(this.groupActions); this.removeItems(); this.addItems(buttons); this.showPanel(); }, setTotalSelectedItems: function(totalSelectedItems) { if (this.layout.totalSelectedItem) { this.layout.totalSelectedItem.innerHTML = totalSelectedItems; } }, extractButtonsFromGroupActions: function (groupActions) { var clonedGroupActions = BX.clone(groupActions); if (!clonedGroupActions['GROUPS'] || !clonedGroupActions['GROUPS'][0] || !clonedGroupActions['GROUPS'][0]['ITEMS']) { return []; } var buttons = []; var items = clonedGroupActions['GROUPS'][0]['ITEMS']; items.forEach(function (item) { if (item.TYPE === 'BUTTON') { var onclick = item.ONCHANGE.pop(); if (onclick && onclick.ACTION === 'CALLBACK') { var firstHandler = onclick.DATA.pop(); buttons.push({ id: item.ID || item.VALUE, text: item.TEXT || item.NAME, title: item.TITLE, iconOnly: item.ICON_ONLY, additionalClassForPanel: item.ADDITIONAL_CLASS_FOR_PANEL, hiddenInPanel: item.HIDDEN_IN_PANEL, icon: item.ICON, disabled: item.DISABLED, onclick: firstHandler.JS }); } } else if (item.TYPE === 'DROPDOWN') { buttons.push({ id: item.ID || item.VALUE, text: item.TEXT || item.NAME, title: item.TITLE, iconOnly: item.ICON_ONLY, additionalClassForPanel: item.ADDITIONAL_CLASS_FOR_PANEL, hiddenInPanel: item.HIDDEN_IN_PANEL, icon: item.ICON, submenuOptions: item.SUBMENU_OPTIONS || {}, disabled: item.DISABLED, items: item.ITEMS }); } }); return buttons; }, showPanel: function() { BX.onCustomEvent(this, 'BX.UI.ActionPanel:showPanel', [this]); if (this.pinnedMode) { this.activatePanelItems(); } if (BX.hasClass(this.layout.container, "ui-action-panel-show")) return; BX.addClass(this.layout.container, "ui-action-panel-show"); BX.addClass(this.layout.container, "ui-action-panel-show-animate"); var parentContainerParam = BX.pos(this.resolveRenderContainer()); this.layout.container.style.setProperty('height', parentContainerParam.height + 'px'); BX.addClass(document.body, 'ui-action-panel-shown'); setTimeout(function() { BX.removeClass(this.layout.container, "ui-action-panel-show-animate"); }.bind(this), 300) }, disableActionItems: function () { this.items.forEach(function (item) { this.disableItem(item); }, this); }, hidePanel: function() { BX.onCustomEvent(this, 'BX.UI.ActionPanel:hidePanel', [this]); if (this.pinnedMode) { this.disablePanelItems(); return; } BX.removeClass(this.layout.container, "ui-action-panel-show"); BX.removeClass(this.layout.container, "ui-action-panel-show-animate"); BX.addClass(this.layout.container, "ui-action-panel-hide-animate"); BX.removeClass(document.body, 'ui-action-panel-shown'); setTimeout(function() { BX.removeClass(this.layout.container, "ui-action-panel-hide-animate"); }.bind(this), 300) }, activatePanelItems: function () { if (this.layout.totalSelected) { this.layout.totalSelected.classList.remove('ui-action-panel-item-is-disabled'); } }, disablePanelItems: function () { this.disableActionItems(); if (this.layout.totalSelected) { this.layout.totalSelected.classList.add('ui-action-panel-item-is-disabled'); } var totalSelectedCounter = document.querySelector('[data-role="action-panel-total-param"]'); if (totalSelectedCounter) { totalSelectedCounter.textContent = '0'; } }, resolveRenderContainer: function () { if (BX.type.isDomNode(this.renderTo)) { return this.renderTo; } if (BX.type.isFunction(this.renderTo)) { var node = this.renderTo.call(); if (BX.type.isDomNode(node)) { return node; } } throw new Error("BX.UI.ActionPanel: 'this.renderTo' has to be DomNode or function which returns DomNode"); }, draw: function() { this.bindEvents(); document.body.appendChild(this.getPanelContainer()); this.adjustPanelStyle(); if (this.pinnedMode) { this.disablePanelItems(); } setTimeout(function() { this.handleResize(); }.bind(this)) }, disableItem: function (item) { if (item) { item.disable(); } } } })();