META-INF.dirigible.dev-tools.resources.StorageItemsView.js Maven / Gradle / Ivy
// Copyright 2017 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
import * as Common from '../common/common.js';
import * as UI from '../ui/ui.js';
export class StorageItemsView extends UI.Widget.VBox {
/**
* @param {string} title
* @param {string} filterName
*/
constructor(title, filterName) {
super(false);
/** @type {?RegExp} */
this._filterRegex = null;
this._refreshButton = this._addButton(Common.UIString.UIString('Refresh'), 'largeicon-refresh', this.refreshItems);
this._mainToolbar = new UI.Toolbar.Toolbar('top-resources-toolbar', this.element);
this._filterItem = new UI.Toolbar.ToolbarInput(Common.UIString.UIString('Filter'), '', 0.4);
this._filterItem.addEventListener(UI.Toolbar.ToolbarInput.Event.TextChanged, this._filterChanged, this);
const toolbarSeparator = new UI.Toolbar.ToolbarSeparator();
this._deleteAllButton =
this._addButton(Common.UIString.UIString('Clear All'), 'largeicon-clear', this.deleteAllItems);
this._deleteSelectedButton =
this._addButton(Common.UIString.UIString('Delete Selected'), 'largeicon-delete', this.deleteSelectedItem);
const toolbarItems =
[this._refreshButton, this._filterItem, toolbarSeparator, this._deleteAllButton, this._deleteSelectedButton];
for (const item of toolbarItems) {
this._mainToolbar.appendToolbarItem(item);
}
}
/**
* @param {!UI.Toolbar.ToolbarItem} item
*/
appendToolbarItem(item) {
this._mainToolbar.appendToolbarItem(item);
}
/**
* @param {string} label
* @param {string} glyph
* @param {!Function} callback
* @return {!UI.Toolbar.ToolbarButton}
*/
_addButton(label, glyph, callback) {
const button = new UI.Toolbar.ToolbarButton(label, glyph);
button.addEventListener(UI.Toolbar.ToolbarButton.Events.Click, callback, this);
return button;
}
/**
* @param {!Common.EventTarget.EventTargetEvent} event
*/
_filterChanged(event) {
const text = /** @type {?string} */ (event.data);
this._filterRegex = text ? new RegExp(text.escapeForRegExp(), 'i') : null;
this.refreshItems();
}
/**
* @param {!Array} items
* @param {function(?Object): string} keyFunction
* @return {!Array}
* @protected
*/
filter(items, keyFunction) {
if (!this._filterRegex) {
return items;
}
return items.filter(item => this._filterRegex.test(keyFunction(item)));
}
/**
* @override
*/
wasShown() {
this.refreshItems();
}
/**
* @param {boolean} enabled
* @protected
*/
setCanDeleteAll(enabled) {
this._deleteAllButton.setEnabled(enabled);
}
/**
* @param {boolean} enabled
* @protected
*/
setCanDeleteSelected(enabled) {
this._deleteSelectedButton.setEnabled(enabled);
}
/**
* @param {boolean} enabled
* @protected
*/
setCanRefresh(enabled) {
this._refreshButton.setEnabled(enabled);
}
/**
* @param {boolean} enabled
* @protected
*/
setCanFilter(enabled) {
this._filterItem.setEnabled(enabled);
}
deleteAllItems() {
}
deleteSelectedItem() {
}
refreshItems() {
}
}