UNPKG

@syncfusion/ej2-filemanager

Version:
409 lines (408 loc) 19.1 kB
import { EventHandler, closest, isNullOrUndefined, KeyboardEvents } from '@syncfusion/ej2-base'; import { getValue, addClass, removeClass, remove, createElement } from '@syncfusion/ej2-base'; import { TextBox } from '@syncfusion/ej2-inputs'; import { DropDownButton } from '@syncfusion/ej2-splitbuttons'; import { read } from '../common/operations'; import { getLocaleText, searchWordHandler } from '../common/utility'; import * as events from '../base/constant'; import * as CLS from '../base/classes'; /** * BreadCrumbBar module */ var BreadCrumbBar = /** @class */ (function () { /** * constructor for addressbar module * * @hidden * @param {IFileManager} parent - specifies parent element. * @private * */ function BreadCrumbBar(parent) { this.addressPath = ''; this.addressBarLink = ''; this.searchTimer = null; this.searchWrapWidth = null; this.parent = parent; this.keyConfigs = { enter: 'enter' }; this.render(); } BreadCrumbBar.prototype.onPropertyChanged = function (e) { if (e.module !== this.getModuleName() && e.module !== 'common') { return; } for (var _i = 0, _a = Object.keys(e.newProp); _i < _a.length; _i++) { var prop = _a[_i]; var value = e.newProp.searchSettings; switch (prop) { case 'searchSettings': if (!isNullOrUndefined(value.allowSearchOnTyping)) { this.searchEventBind(value.allowSearchOnTyping); } if (this.parent.breadcrumbbarModule.searchObj.value && this.parent.breadcrumbbarModule.searchObj.value !== '' && !(!isNullOrUndefined(value.allowSearchOnTyping) && isNullOrUndefined(value.filterType) && isNullOrUndefined(value.ignoreCase))) { searchWordHandler(this.parent, this.parent.breadcrumbbarModule.searchObj.value, false); } break; } } }; BreadCrumbBar.prototype.render = function () { this.addEventListener(); }; BreadCrumbBar.prototype.onPathChange = function () { var pathNames = this.parent.pathNames; var paths = this.parent.path.split('/'); var addressbarUL = this.parent.createElement('ul', { className: 'e-addressbar-ul' }); var addressbarLI = null; var pathNamesLen = pathNames.length; if (pathNames.length > 0) { var id = ''; for (var i = 0; i < pathNamesLen; i++) { var addressATag = null; addressbarLI = this.parent.createElement('li', { className: 'e-address-list-item' }); for (var j = 0; j <= i; j++) { id = id + paths[j] + '/'; } addressbarLI.setAttribute('data-utext', id); if (i !== 0) { var icon = createElement('span', { className: CLS.ICONS }); addressbarLI.appendChild(icon); } if (pathNamesLen - i !== 1) { addressATag = createElement('a', { className: CLS.LIST_TEXT }); addressbarLI.setAttribute('tabindex', '0'); } else { addressATag = createElement('span', { className: CLS.LIST_TEXT }); } id = ''; addressATag.innerText = pathNames[i]; addressbarLI.appendChild(addressATag); addressbarUL.appendChild(addressbarLI); } var ulElement = this.parent.breadCrumbBarNavigation.querySelector('.e-addressbar-ul'); if (!isNullOrUndefined(ulElement)) { if (!isNullOrUndefined(this.subMenuObj)) { this.subMenuObj.destroy(); } remove(ulElement); } var searchWrap = this.parent.breadCrumbBarNavigation.querySelector('.e-search-wrap'); if (!searchWrap) { this.parent.breadCrumbBarNavigation.insertBefore(addressbarUL, searchWrap); } else { this.parent.breadCrumbBarNavigation.appendChild(addressbarUL); } this.updateBreadCrumbBar(addressbarUL); } }; /* istanbul ignore next */ BreadCrumbBar.prototype.updateBreadCrumbBar = function (addresBarUL) { var liElements = addresBarUL.querySelectorAll('li'); var ulElement = this.parent.breadCrumbBarNavigation.querySelector('.e-addressbar-ul'); var style = window.getComputedStyle(ulElement, null); var pRight = parseFloat(style.getPropertyValue('padding-right')); var pLeft = parseFloat(style.getPropertyValue('padding-left')); var breadCrumbBarWidth = ulElement.offsetWidth - pRight - pLeft; var addressbarUL = this.parent.createElement('ul', { className: 'e-addressbar-ul' }); var liElementsWidth = 0; var liElementsWidths = []; for (var i = 0; i < liElements.length; i++) { var width = liElements[i].clientWidth; liElementsWidths.push(width); liElementsWidth = liElementsWidth + width; } if (!isNullOrUndefined(ulElement)) { remove(ulElement); } var searchContainer = this.parent.createElement('div'); searchContainer.setAttribute('class', 'e-search-wrap'); var id = this.parent.element.id + CLS.SEARCH_ID; var searchInput = createElement('input', { id: id, attrs: { autocomplete: 'off', 'aria-label': getLocaleText(this.parent, 'Search') } }); searchContainer.appendChild(searchInput); var searchEle = this.parent.breadCrumbBarNavigation.querySelector('.e-search-wrap .e-input'); if (isNullOrUndefined(searchEle)) { this.parent.breadCrumbBarNavigation.appendChild(searchContainer); var span = createElement('span', { className: 'e-icons e-fe-search' }); EventHandler.add(span, 'click', this.onShowInput, this); searchInput.parentElement.insertBefore(span, searchInput); this.searchObj = new TextBox({ value: '', showClearButton: true, placeholder: getLocaleText(this.parent, 'Search'), focus: this.onFocus.bind(this), blur: this.onBlur.bind(this) }); this.searchObj.appendTo('#' + this.parent.element.id + CLS.SEARCH_ID); this.searchEventBind(this.parent.searchSettings.allowSearchOnTyping); var search = this.searchObj.element.nextElementSibling; EventHandler.add(search, 'mousedown', this.searchChangeHandler.bind(this), this); EventHandler.add(this.searchObj.element, 'keyup', this.onKeyUp.bind(this), this); } var searchWrap = this.parent.breadCrumbBarNavigation.querySelector('.e-search-wrap'); breadCrumbBarWidth = breadCrumbBarWidth - (this.searchWrapWidth ? this.searchWrapWidth : searchWrap.offsetWidth); if (liElementsWidth > breadCrumbBarWidth) { var i = liElements.length; while (i--) { var diff = breadCrumbBarWidth - liElementsWidths[i]; if (diff > 40) { addressbarUL.insertBefore(liElements[i], addressbarUL.querySelector('li')); breadCrumbBarWidth = diff; } else { var items = []; for (var j = 0; j <= i; j++) { var liElement = liElements[j]; items.push({ text: liElement.innerText, utext: liElement.getAttribute('data-utext') }); } var subMenuLi = this.parent.createElement('li', { className: 'e-breadcrumb-menu' }); var attributes = { className: 'e-breadcrumb-submenu' }; var subMenuSpan = this.parent.createElement('button', attributes); subMenuLi.appendChild(subMenuSpan); addressbarUL.insertBefore(subMenuLi, addressbarUL.querySelector('li')); this.subMenuObj = new DropDownButton({ items: items, cssClass: 'e-caret-hide e-submenu', iconCss: CLS.ICON_BREADCRUMB, iconPosition: 'Top', enableHtmlSanitizer: this.parent.enableHtmlSanitizer, beforeItemRender: this.addSubMenuAttributes.bind(this), select: this.subMenuSelectOperations.bind(this) }); this.subMenuObj.isStringTemplate = true; this.subMenuObj.appendTo(subMenuSpan); break; } } this.parent.breadCrumbBarNavigation.insertBefore(addressbarUL, searchWrap); } else { this.parent.breadCrumbBarNavigation.insertBefore(addresBarUL, searchWrap); } }; /* istanbul ignore next */ BreadCrumbBar.prototype.onFocus = function () { var wrap = closest(this.searchObj.element, '.e-search-wrap'); wrap.classList.add('e-focus'); }; /* istanbul ignore next */ BreadCrumbBar.prototype.onKeyUp = function () { this.parent.notify(events.pathColumn, { args: this.parent }); }; /* istanbul ignore next */ BreadCrumbBar.prototype.onBlur = function () { var wrap = closest(this.searchObj.element, '.e-search-wrap'); wrap.classList.remove('e-focus'); }; /* istanbul ignore next */ BreadCrumbBar.prototype.subMenuSelectOperations = function (event) { var args = { target: event.element }; this.addressPathClickHandler(args); }; /* istanbul ignore next */ BreadCrumbBar.prototype.addSubMenuAttributes = function (args) { args.element.setAttribute('data-utext', getValue('utext', args.item)); var anchor = this.parent.createElement('a', { className: 'e-list-text' }); args.element.appendChild(anchor); }; BreadCrumbBar.prototype.searchEventBind = function (allow) { if (allow) { this.searchObj.input = this.searchChangeHandler.bind(this); this.searchObj.change = null; } else { this.searchObj.change = this.searchChangeHandler.bind(this); this.searchObj.input = null; } }; BreadCrumbBar.prototype.searchChangeHandler = function (args) { var _this = this; if (!isNullOrUndefined(args.value)) { this.parent.isFiltered = false; if (this.parent.searchSettings.allowSearchOnTyping) { window.clearTimeout(this.searchTimer); this.searchTimer = window.setTimeout(function () { searchWordHandler(_this.parent, args.value, false); }, 300); } else { searchWordHandler(this.parent, args.value, false); } } }; BreadCrumbBar.prototype.addressPathClickHandler = function (e) { var li = e.target; if (li.nodeName === 'LI' || li.nodeName === 'A') { var node = li.nodeName === 'LI' ? li.children[0] : li; if (!isNullOrUndefined(node)) { this.parent.isFiltered = false; var currentPath = this.updatePath(node); this.parent.itemData = [getValue(this.parent.pathId[this.parent.pathId.length - 1], this.parent.feParent)]; this.triggerFileOpen(this.parent.itemData[0]); read(this.parent, events.pathChanged, currentPath); var treeNodeId = this.parent.pathId[this.parent.pathId.length - 1]; this.parent.notify(events.updateTreeSelection, { module: 'treeview', selectedNode: treeNodeId }); } } }; BreadCrumbBar.prototype.triggerFileOpen = function (data) { var eventArgs = { cancel: false, fileDetails: data, module: 'BreadCrumbBar' }; delete eventArgs.cancel; this.parent.trigger('fileOpen', eventArgs); }; /* istanbul ignore next */ BreadCrumbBar.prototype.onShowInput = function () { if (this.parent.isMobile) { if (this.parent.element.classList.contains(CLS.FILTER)) { removeClass([this.parent.element], CLS.FILTER); this.searchWrapWidth = null; } else { var searchWrap = this.parent.breadCrumbBarNavigation.querySelector('.e-search-wrap'); this.searchWrapWidth = searchWrap.offsetWidth; addClass([this.parent.element], CLS.FILTER); this.searchObj.element.focus(); } } }; BreadCrumbBar.prototype.updatePath = function (list) { var li = closest(list, 'li'); var liElementId = li.getAttribute('data-utext'); this.addressBarLink = liElementId; var link = this.addressBarLink.split('/'); var ids = this.parent.pathId; var names = this.parent.pathNames; this.parent.pathId = []; this.parent.pathNames = []; var newpath = ''; for (var i = 0, len = link.length - 1; i < len; i++) { this.parent.pathId.push(ids[i]); this.parent.pathNames.push(names[i]); newpath += link[i] + '/'; } this.parent.setProperties({ path: newpath }, true); return newpath; }; BreadCrumbBar.prototype.onUpdatePath = function () { this.onPathChange(); this.removeSearchValue(); }; BreadCrumbBar.prototype.onCreateEnd = function () { this.onPathChange(); }; BreadCrumbBar.prototype.onRenameEnd = function () { this.onPathChange(); }; /* istanbul ignore next */ BreadCrumbBar.prototype.onDeleteEnd = function () { this.onUpdatePath(); }; /* istanbul ignore next */ BreadCrumbBar.prototype.removeSearchValue = function () { this.parent.isFiltered = false; if (this.searchObj && (this.searchObj.value !== '' || this.searchObj.element.value !== '')) { this.searchObj.value = ''; this.searchObj.element.value = ''; this.searchObj.dataBind(); } }; BreadCrumbBar.prototype.onResize = function () { this.onPathChange(); }; BreadCrumbBar.prototype.onPasteEnd = function () { this.onPathChange(); }; BreadCrumbBar.prototype.addEventListener = function () { this.keyboardModule = new KeyboardEvents(this.parent.breadCrumbBarNavigation, { keyAction: this.keyActionHandler.bind(this), keyConfigs: this.keyConfigs, eventName: 'keydown' }); this.parent.on(events.modelChanged, this.onPropertyChanged, this); EventHandler.add(this.parent.breadCrumbBarNavigation, 'click', this.addressPathClickHandler, this); this.parent.on(events.destroy, this.destroy, this); this.parent.on(events.pathChanged, this.onUpdatePath, this); this.parent.on(events.finalizeEnd, this.onUpdatePath, this); this.parent.on(events.refreshEnd, this.onUpdatePath, this); this.parent.on(events.openEnd, this.onUpdatePath, this); this.parent.on(events.createEnd, this.onCreateEnd, this); this.parent.on(events.renameEnd, this.onRenameEnd, this); this.parent.on(events.deleteEnd, this.onDeleteEnd, this); this.parent.on(events.splitterResize, this.onResize, this); this.parent.on(events.pasteEnd, this.onPasteEnd, this); this.parent.on(events.resizeEnd, this.onResize, this); this.parent.on(events.searchTextChange, this.onSearchTextChange, this); this.parent.on(events.dropInit, this.onDropInit, this); this.parent.on(events.layoutRefresh, this.onResize, this); this.parent.on(events.dropPath, this.onPathChange, this); }; BreadCrumbBar.prototype.keyActionHandler = function (e) { switch (e.action) { case 'enter': this.addressPathClickHandler(e); break; } }; BreadCrumbBar.prototype.removeEventListener = function () { this.keyboardModule.destroy(); this.parent.off(events.pathChanged, this.onUpdatePath); this.parent.off(events.finalizeEnd, this.onUpdatePath); this.parent.off(events.refreshEnd, this.onUpdatePath); this.parent.off(events.openEnd, this.onUpdatePath); this.parent.off(events.pasteEnd, this.onPasteEnd); this.parent.off(events.createEnd, this.onCreateEnd); this.parent.off(events.renameEnd, this.onRenameEnd); this.parent.off(events.deleteEnd, this.onDeleteEnd); this.parent.off(events.splitterResize, this.onResize); this.parent.off(events.resizeEnd, this.onResize); this.parent.off(events.searchTextChange, this.onSearchTextChange); this.parent.off(events.dropInit, this.onDropInit); this.parent.off(events.layoutRefresh, this.onResize); this.parent.off(events.dropPath, this.onPathChange); }; /* istanbul ignore next */ BreadCrumbBar.prototype.onDropInit = function (args) { if (this.parent.targetModule === this.getModuleName()) { var liEle = args.target.closest('li'); this.parent.dropPath = this.updatePath((liEle.children[0])); this.parent.dropData = getValue(this.parent.pathId[this.parent.pathId.length - 1], this.parent.feParent); this.triggerFileOpen(this.parent.dropData); var treeNodeId = this.parent.pathId[this.parent.pathId.length - 1]; this.parent.notify(events.updateTreeSelection, { module: 'treeview', selectedNode: treeNodeId }); } }; /** * For internal use only - Get the module name. * * @returns {string} - returns the module name * @private */ BreadCrumbBar.prototype.getModuleName = function () { return 'breadcrumbbar'; }; BreadCrumbBar.prototype.destroy = function () { if (this.parent.isDestroyed) { return; } this.removeEventListener(); /* istanbul ignore next */ if (!isNullOrUndefined(this.subMenuObj)) { this.subMenuObj.destroy(); } if (!isNullOrUndefined(this.searchObj)) { this.searchObj.destroy(); } }; BreadCrumbBar.prototype.onSearchTextChange = function (args) { this.searchObj.element.placeholder = (this.parent.searchSettings.placeholder != null) ? this.parent.searchSettings.placeholder : getLocaleText(this.parent, 'Search') + ' ' + getLocaleText(this.parent, args.cwd.name.toString()); }; return BreadCrumbBar; }()); export { BreadCrumbBar };