Externalize modal dialogs

This commit is contained in:
Rene Pfeuffer
2019-10-01 17:03:27 +02:00
parent 7f657e5360
commit 3abf9815f3
6 changed files with 185 additions and 143 deletions

View File

@@ -0,0 +1,41 @@
// @flow
import React from "react";
import MultiPluginActionModal from "./MultiPluginActionModal";
import type {PendingPlugins} from "@scm-manager/ui-types";
import waitForRestart from "./waitForRestart";
import {apiClient, Notification} from "@scm-manager/ui-components";
import {translate} from "react-i18next";
type Props = {
onClose: () => void,
pendingPlugins: PendingPlugins,
// context props
t: string => string
};
class ExecutePendingActionModal extends React.Component<Props> {
render() {
const {onClose, pendingPlugins, t} = this.props;
return <MultiPluginActionModal
description={t("plugins.modal.executePending")} label={t("plugins.modal.executeAndRestart")}
onClose={onClose} pendingPlugins={pendingPlugins} execute={this.executeAndRestart}>
<Notification type="warning">
{t("plugins.modal.restartNotification")}
</Notification>
</MultiPluginActionModal>;
}
executeAndRestart = () => {
const {pendingPlugins} = this.props;
return apiClient
.post(pendingPlugins._links.execute.href)
.then(waitForRestart);
};
}
export default translate("admin")(ExecutePendingActionModal);