devextreme
Version:
HTML5 JavaScript Component Suite for Responsive Web Development
202 lines (200 loc) • 8.58 kB
JavaScript
/**
* DevExtreme (cjs/ui/file_manager/ui.file_manager.item_list.thumbnails.js)
* Version: 24.2.6
* Build date: Mon Mar 17 2025
*
* Copyright (c) 2012 - 2025 Developer Express Inc. ALL RIGHTS RESERVED
* Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/
*/
"use strict";
exports.default = void 0;
var _renderer = _interopRequireDefault(require("../../core/renderer"));
var _extend = require("../../core/utils/extend");
var _type = require("../../core/utils/type");
var _deferred = require("../../core/utils/deferred");
var _events_engine = _interopRequireDefault(require("../../common/core/events/core/events_engine"));
var _index = require("../../common/core/events/utils/index");
var _contextmenu = require("../../common/core/events/contextmenu");
var _uiFile_manager = require("./ui.file_manager.common");
var _message = _interopRequireDefault(require("../../common/core/localization/message"));
var _uiFile_managerItems_listThumbnails = _interopRequireDefault(require("./ui.file_manager.items_list.thumbnails.list_box"));
var _uiFile_manager2 = _interopRequireDefault(require("./ui.file_manager.item_list"));
var _file_items_controller = require("./file_items_controller");
function _interopRequireDefault(e) {
return e && e.__esModule ? e : {
default: e
}
}
const FILE_MANAGER_THUMBNAILS_ITEM_LIST_CLASS = "dx-filemanager-thumbnails";
const FILE_MANAGER_THUMBNAILS_ITEM_CLASS = "dx-filemanager-thumbnails-item";
const FILE_MANAGER_THUMBNAILS_ITEM_THUMBNAIL_CLASS = "dx-filemanager-thumbnails-item-thumbnail";
const FILE_MANAGER_THUMBNAILS_EVENT_NAMESPACE = "dxFileManager_thumbnails";
class FileManagerThumbnailsItemList extends _uiFile_manager2.default {
_initMarkup() {
super._initMarkup();
this.$element().addClass("dx-filemanager-thumbnails");
const contextMenuEvent = (0, _index.addNamespace)(_contextmenu.name, "dxFileManager_thumbnails");
_events_engine.default.on(this.$element(), contextMenuEvent, this._onContextMenu.bind(this));
this._createItemList()
}
_createItemList() {
const selectionMode = this._isMultipleSelectionMode() ? "multiple" : "single";
const $itemListContainer = (0, _renderer.default)("<div>").appendTo(this.$element());
this._itemList = this._createComponent($itemListContainer, _uiFile_managerItems_listThumbnails.default, {
dataSource: this._createDataSource(),
selectionMode: selectionMode,
selectedItemKeys: this.option("selectedItemKeys"),
focusedItemKey: this.option("focusedItemKey"),
activeStateEnabled: true,
hoverStateEnabled: true,
loopItemFocus: false,
focusStateEnabled: true,
onItemEnterKeyPressed: this._tryOpen.bind(this),
itemThumbnailTemplate: this._getItemThumbnailContainer.bind(this),
getTooltipText: this._getTooltipText.bind(this),
onSelectionChanged: this._onItemListSelectionChanged.bind(this),
onFocusedItemChanged: this._onItemListFocusedItemChanged.bind(this),
onContentReady: this._onContentReady.bind(this)
})
}
_onContextMenu(e) {
e.preventDefault();
e.stopPropagation();
if (!this._isDesktop()) {
return
}
let items = null;
const targetItemElement = (0, _renderer.default)(e.target).closest(this._getItemSelector());
let targetItem = null;
if (targetItemElement.length > 0) {
targetItem = this._itemList.getItemByItemElement(targetItemElement);
this._itemList.selectItem(targetItem);
items = this._getFileItemsForContextMenu(targetItem)
}
const target = {
itemData: targetItem,
itemElement: targetItemElement.length ? targetItemElement : void 0
};
this._showContextMenu(items, e.target, e, target)
}
_getItemThumbnailCssClass() {
return "dx-filemanager-thumbnails-item-thumbnail"
}
_getItemSelector() {
return ".dx-filemanager-thumbnails-item"
}
_getTooltipText(fileItemInfo) {
const item = fileItemInfo.fileItem;
if (item.tooltipText) {
return item.tooltipText
}
let text = `${item.name}\r\n`;
if (!item.isDirectory) {
text += `${_message.default.format("dxFileManager-listThumbnailsTooltipTextSize")}: ${(0,_uiFile_manager.getDisplayFileSize)(item.size)}\r\n`
}
text += `${_message.default.format("dxFileManager-listThumbnailsTooltipTextDateModified")}: ${item.dateModified}`;
return text
}
_onItemDblClick(e) {
const $item = (0, _renderer.default)(e.currentTarget);
const item = this._itemList.getItemByItemElement($item);
this._tryOpen(item)
}
_tryOpen(item) {
if (item) {
this._raiseSelectedItemOpened(item)
}
}
_getItemsInternal() {
return super._getItemsInternal().then((items => {
const deferred = new _deferred.Deferred;
setTimeout((() => deferred.resolve(items)));
return deferred.promise()
}))
}
_disableDragging() {
return false
}
_getDefaultOptions() {
return (0, _extend.extend)(super._getDefaultOptions(), {
focusStateEnabled: true
})
}
_onItemListSelectionChanged(_ref) {
let {
addedItemKeys: addedItemKeys,
removedItemKeys: removedItemKeys
} = _ref;
const selectedItemInfos = this.getSelectedItems();
const selectedItems = selectedItemInfos.map((itemInfo => itemInfo.fileItem));
const selectedItemKeys = selectedItems.map((item => item.key));
this._tryRaiseSelectionChanged({
selectedItemInfos: selectedItemInfos,
selectedItems: selectedItems,
selectedItemKeys: selectedItemKeys,
currentSelectedItemKeys: addedItemKeys,
currentDeselectedItemKeys: removedItemKeys
})
}
_onItemListFocusedItemChanged(_ref2) {
let {
item: item,
itemElement: itemElement
} = _ref2;
if (!this._isMultipleSelectionMode()) {
this._selectItemSingleSelection(item)
}
const fileSystemItem = (null === item || void 0 === item ? void 0 : item.fileItem) || null;
this._onFocusedItemChanged({
item: fileSystemItem,
itemKey: null === fileSystemItem || void 0 === fileSystemItem ? void 0 : fileSystemItem.key,
itemElement: itemElement || void 0
})
}
_getScrollable() {
return this._itemList.getScrollable()
}
_setSelectedItemKeys(itemKeys) {
this._itemList.option("selectedItemKeys", itemKeys)
}
_setFocusedItemKey(itemKey) {
this._itemList.option("focusedItemKey", itemKey)
}
refresh(options, operation) {
const actualOptions = {
dataSource: this._createDataSource()
};
if (options && Object.prototype.hasOwnProperty.call(options, "focusedItemKey")) {
actualOptions.focusedItemKey = options.focusedItemKey
}
if (options && Object.prototype.hasOwnProperty.call(options, "selectedItemKeys")) {
actualOptions.selectedItemKeys = options.selectedItemKeys
}
if (!(0, _type.isDefined)(actualOptions.focusedItemKey) && operation === _file_items_controller.OPERATIONS.NAVIGATION) {
this._needResetScrollPosition = true
}
this._itemList.option(actualOptions);
this._refreshDeferred = new _deferred.Deferred;
return this._refreshDeferred.promise()
}
_deselectItem(item) {
const itemElement = this._itemList.getItemElementByItem(item);
this._itemList.unselectItem(itemElement)
}
_selectItemSingleSelection(item) {
if (item) {
this._itemList.selectItem(item)
} else {
this._itemList.clearSelection()
}
}
clearSelection() {
this._itemList.clearSelection()
}
getSelectedItems() {
return this._itemList.getSelectedItems()
}
}
var _default = exports.default = FileManagerThumbnailsItemList;
module.exports = exports.default;
module.exports.default = exports.default;