devextreme
Version:
HTML5 JavaScript Component Suite for Responsive Web Development
296 lines (295 loc) • 14.1 kB
JavaScript
/**
* DevExtreme (esm/ui/file_manager/ui.file_manager.notification.progress_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 {
extend
} from "../../core/utils/extend";
import {
ensureDefined
} from "../../core/utils/common";
import {
getImageContainer
} from "../../core/utils/icon";
import messageLocalization from "../../localization/message";
import Widget from "../widget/ui.widget";
import ProgressBar from "../progress_bar";
import Button from "../button";
import ScrollView from "../scroll_view";
var FILE_MANAGER_PROGRESS_PANEL_CLASS = "dx-filemanager-progress-panel";
var FILE_MANAGER_PROGRESS_PANEL_CONTAINER_CLASS = "".concat(FILE_MANAGER_PROGRESS_PANEL_CLASS, "-container");
var FILE_MANAGER_PROGRESS_PANEL_TITLE_CLASS = "".concat(FILE_MANAGER_PROGRESS_PANEL_CLASS, "-title");
var FILE_MANAGER_PROGRESS_PANEL_TITLE_TEXT_CLASS = "".concat(FILE_MANAGER_PROGRESS_PANEL_CLASS, "-title-text");
var FILE_MANAGER_PROGRESS_PANEL_CLOSE_BUTTON_CLASS = "".concat(FILE_MANAGER_PROGRESS_PANEL_CLASS, "-close-button");
var FILE_MANAGER_PROGRESS_PANEL_INFOS_CONTAINER_CLASS = "".concat(FILE_MANAGER_PROGRESS_PANEL_CLASS, "-infos-container");
var FILE_MANAGER_PROGRESS_PANEL_SEPARATOR_CLASS = "".concat(FILE_MANAGER_PROGRESS_PANEL_CLASS, "-separator");
var FILE_MANAGER_PROGRESS_PANEL_INFO_CLASS = "".concat(FILE_MANAGER_PROGRESS_PANEL_CLASS, "-info");
var FILE_MANAGER_PROGRESS_PANEL_COMMON_CLASS = "".concat(FILE_MANAGER_PROGRESS_PANEL_CLASS, "-common");
var FILE_MANAGER_PROGRESS_PANEL_INFO_WITH_DETAILS_CLASS = "".concat(FILE_MANAGER_PROGRESS_PANEL_CLASS, "-info-with-details");
var FILE_MANAGER_PROGRESS_PANEL_DETAILS_CLASS = "".concat(FILE_MANAGER_PROGRESS_PANEL_CLASS, "-details");
var FILE_MANAGER_PROGRESS_BOX_CLASS = "dx-filemanager-progress-box";
var FILE_MANAGER_PROGRESS_BOX_ERROR_CLASS = "".concat(FILE_MANAGER_PROGRESS_BOX_CLASS, "-error");
var FILE_MANAGER_PROGRESS_BOX_WITHOUT_CLOSE_BUTTON_CLASS = "".concat(FILE_MANAGER_PROGRESS_BOX_CLASS, "-without-close-button");
var FILE_MANAGER_PROGRESS_BOX_IMAGE_CLASS = "".concat(FILE_MANAGER_PROGRESS_BOX_CLASS, "-image");
var FILE_MANAGER_PROGRESS_BOX_WRAPPER_CLASS = "".concat(FILE_MANAGER_PROGRESS_BOX_CLASS, "-wrapper");
var FILE_MANAGER_PROGRESS_BOX_COMMON_CLASS = "".concat(FILE_MANAGER_PROGRESS_BOX_CLASS, "-common");
var FILE_MANAGER_PROGRESS_BOX_PROGRESS_BAR_CLASS = "".concat(FILE_MANAGER_PROGRESS_BOX_CLASS, "-progress-bar");
var FILE_MANAGER_PROGRESS_BOX_CLOSE_BUTTON_CLASS = "".concat(FILE_MANAGER_PROGRESS_BOX_CLASS, "-close-button");
var DX_CARD_CLASS = "dx-card";
class FileManagerProgressPanel extends Widget {
_initMarkup() {
super._initMarkup();
this._initActions();
this._operationCount = 0;
this.$element().addClass(FILE_MANAGER_PROGRESS_PANEL_CLASS);
var $scrollView = $("<div>").appendTo(this.$element());
var $container = $("<div>").addClass(FILE_MANAGER_PROGRESS_PANEL_CONTAINER_CLASS).appendTo($scrollView);
this._scrollView = this._createComponent($scrollView, ScrollView, {
scrollByContent: true,
scrollByThumb: true,
showScrollbar: "onScroll"
});
var $title = $("<div>").addClass(FILE_MANAGER_PROGRESS_PANEL_TITLE_CLASS).appendTo($container);
$("<div>").text(messageLocalization.format("dxFileManager-notificationProgressPanelTitle")).addClass(FILE_MANAGER_PROGRESS_PANEL_TITLE_TEXT_CLASS).appendTo($title);
var $closeButton = $("<div>").addClass(FILE_MANAGER_PROGRESS_PANEL_CLOSE_BUTTON_CLASS).appendTo($title);
this._createComponent($closeButton, Button, {
icon: "close",
stylingMode: "text",
onClick: () => this._raisePanelClosed()
});
this._$infosContainer = $("<div>").addClass(FILE_MANAGER_PROGRESS_PANEL_INFOS_CONTAINER_CLASS).appendTo($container);
this._renderEmptyListText()
}
_getDefaultOptions() {
return extend(super._getDefaultOptions(), {
onOperationClosed: null,
onOperationCanceled: null,
onOperationItemCanceled: null,
onPanelClosed: null
})
}
_initActions() {
this._actions = {
onOperationClosed: this._createActionByOption("onOperationClosed"),
onOperationCanceled: this._createActionByOption("onOperationCanceled"),
onOperationItemCanceled: this._createActionByOption("onOperationItemCanceled"),
onPanelClosed: this._createActionByOption("onPanelClosed")
}
}
_optionChanged(args) {
var name = args.name;
switch (name) {
case "test":
break;
case "onOperationClosed":
case "onOperationCanceled":
case "onOperationItemCanceled":
this._actions[name] = this._createActionByOption(name);
break;
default:
super._optionChanged(args)
}
}
addOperation(commonText, showCloseButtonAlways, allowProgressAutoUpdate) {
if (this._operationCount) {
$("<div>").addClass(FILE_MANAGER_PROGRESS_PANEL_SEPARATOR_CLASS).prependTo(this._$infosContainer)
} else {
this._$infosContainer.empty()
}
this._operationCount++;
var info = {
customCloseHandling: showCloseButtonAlways,
allowProgressAutoUpdate: ensureDefined(allowProgressAutoUpdate, true)
};
var $info = $("<div>").addClass(FILE_MANAGER_PROGRESS_PANEL_INFO_CLASS).prependTo(this._$infosContainer);
info.$info = $info;
var $common = $("<div>").addClass(FILE_MANAGER_PROGRESS_PANEL_COMMON_CLASS).appendTo($info);
info.common = this._createProgressBox($common, {
commonText: commonText,
showCloseButton: true,
showCloseButtonAlways: showCloseButtonAlways,
onCloseButtonClick: () => this._closeOperation(info)
});
return info
}
addOperationDetails(info, details, showCloseButton) {
info.$info.addClass(FILE_MANAGER_PROGRESS_PANEL_INFO_WITH_DETAILS_CLASS);
var $details = $("<div>").addClass(FILE_MANAGER_PROGRESS_PANEL_DETAILS_CLASS).appendTo(info.$info);
info.details = details.map((itemInfo, index) => {
itemInfo.info = info;
return this._createDetailsItem($details, itemInfo, index, false, showCloseButton)
})
}
_createDetailsItem($container, item, itemIndex, skipProgressBox, showCloseButton) {
var $detailsItem = $("<div>").appendTo($container);
if (-1 !== itemIndex) {
$detailsItem.addClass(DX_CARD_CLASS)
}
return this._createProgressBox($detailsItem, {
commonText: item.commonText,
imageUrl: item.imageUrl,
skipProgressBox: skipProgressBox,
showCloseButton: showCloseButton,
showCloseButtonAlways: showCloseButton,
onCloseButtonClick: () => this._cancelOperationItem(item, itemIndex)
})
}
completeOperationItem(operationInfo, itemIndex, commonProgress) {
if (operationInfo.allowProgressAutoUpdate) {
this.updateOperationItemProgress(operationInfo, itemIndex, 100, commonProgress)
}
this._setCloseButtonVisible(operationInfo.details[itemIndex], false)
}
updateOperationItemProgress(operationInfo, itemIndex, itemProgress, commonProgress) {
operationInfo.common.progressBar.option("value", commonProgress);
if (operationInfo.details) {
var detailsItem = operationInfo.details[itemIndex];
detailsItem.progressBar.option("value", itemProgress)
}
}
completeOperation(info, commonText, isError, statusText) {
info.completed = true;
info.common.$commonText.text(commonText);
if (isError) {
this._removeProgressBar(info.common)
} else if (info.allowProgressAutoUpdate) {
info.common.progressBar.option("value", 100)
}
if (statusText) {
this._setProgressBarText(info.common, statusText)
}
this._setCloseButtonVisible(info.common, true)
}
completeSingleOperationWithError(info, errorText) {
var _info$details;
var detailsItem = null === (_info$details = info.details) || void 0 === _info$details ? void 0 : _info$details[0];
info.completed = true;
this._renderOperationError(detailsItem || info.common, errorText);
this._setCloseButtonVisible(info.common, true);
if (detailsItem) {
this._setCloseButtonVisible(detailsItem, false)
}
}
addOperationDetailsError(info, index, errorText) {
var detailsItem = info.details[index];
this._renderOperationError(detailsItem, errorText);
this._setCloseButtonVisible(detailsItem, false)
}
_renderError($container, $target, errorText) {
$("<div>").text(errorText).addClass(FILE_MANAGER_PROGRESS_BOX_ERROR_CLASS).appendTo($container)
}
_renderEmptyListText() {
this._$infosContainer.text(messageLocalization.format("dxFileManager-notificationProgressPanelEmptyListText"))
}
_renderOperationError(info, errorText) {
this._removeProgressBar(info);
this._renderError(info.$wrapper, info.$commonText, errorText)
}
_removeProgressBar(progressBox) {
if (progressBox.progressBar) {
progressBox.progressBar.dispose();
progressBox.progressBar.$element().remove();
progressBox.progressBar = null
}
}
_createProgressBox($container, options) {
$container.addClass(FILE_MANAGER_PROGRESS_BOX_CLASS);
if (!options.showCloseButtonAlways) {
$container.addClass(FILE_MANAGER_PROGRESS_BOX_WITHOUT_CLOSE_BUTTON_CLASS)
}
if (options.imageUrl) {
getImageContainer(options.imageUrl).addClass(FILE_MANAGER_PROGRESS_BOX_IMAGE_CLASS).appendTo($container)
}
var $wrapper = $("<div>").addClass(FILE_MANAGER_PROGRESS_BOX_WRAPPER_CLASS).appendTo($container);
var $commonText = $("<div>").addClass(FILE_MANAGER_PROGRESS_BOX_COMMON_CLASS).text(options.commonText).appendTo($wrapper);
var progressBar = null;
if (!options.skipProgressBox) {
var $progressBar = $("<div>").addClass(FILE_MANAGER_PROGRESS_BOX_PROGRESS_BAR_CLASS).appendTo($wrapper);
progressBar = this._createComponent($progressBar, ProgressBar, {
min: 0,
max: 100,
width: "100%",
validationMessageMode: "always",
statusFormat: (ratio, value) => this._getStatusString(ratio, value)
})
}
var closeButton = null;
if (options.showCloseButton) {
var $button = $("<div>").addClass(FILE_MANAGER_PROGRESS_BOX_CLOSE_BUTTON_CLASS).appendTo($container);
closeButton = this._createComponent($button, Button, {
icon: "dx-filemanager-i dx-filemanager-i-cancel",
stylingMode: "text",
visible: options.showCloseButtonAlways,
onClick: options.onCloseButtonClick
})
}
return {
$commonText: $commonText,
progressBar: progressBar,
$element: $container,
$wrapper: $wrapper,
closeButton: closeButton
}
}
_setCloseButtonVisible(progressBox, visible) {
if (progressBox.closeButton) {
progressBox.$element.toggleClass(FILE_MANAGER_PROGRESS_BOX_WITHOUT_CLOSE_BUTTON_CLASS, !visible);
progressBox.closeButton.option("visible", visible)
}
}
_setProgressBarText(progressBox, text) {
progressBox.progressBar.option("statusFormat", () => text)
}
_closeOperation(info) {
if (info.customCloseHandling && !info.completed) {
this._raiseOperationCanceled(info);
this._setCloseButtonVisible(info.common, false);
info.details.forEach(item => this._displayClosedOperationItem(item))
} else {
this._raiseOperationClosed(info);
info.$info.next(".".concat(FILE_MANAGER_PROGRESS_PANEL_SEPARATOR_CLASS)).remove();
info.$info.remove();
this._operationCount--;
if (!this._operationCount) {
this._renderEmptyListText()
}
}
}
_cancelOperationItem(item, itemIndex) {
this._raiseOperationItemCanceled(item, itemIndex);
var itemInfo = item.info.details[itemIndex];
this._displayClosedOperationItem(itemInfo)
}
_displayClosedOperationItem(itemInfo) {
this._setProgressBarText(itemInfo, messageLocalization.format("dxFileManager-notificationProgressPanelOperationCanceled"));
this._setCloseButtonVisible(itemInfo, false)
}
_getStatusString(ratio, value) {
return 1 === ratio ? messageLocalization.format("Done") : Math.round(100 * ratio) + "%"
}
_raiseOperationClosed(info) {
this._actions.onOperationClosed({
info: info
})
}
_raiseOperationCanceled(info) {
this._actions.onOperationCanceled({
info: info
})
}
_raiseOperationItemCanceled(item, itemIndex) {
this._actions.onOperationItemCanceled({
item: item,
itemIndex: itemIndex
})
}
_raisePanelClosed() {
this._actions.onPanelClosed()
}
}
export default FileManagerProgressPanel;