/** * ============LICENSE_START======================================================================== * ONAP : ccsdk feature sdnr wt odlux * ================================================================================================= * Copyright (C) 2019 highstreet technologies GmbH Intellectual Property. All rights reserved. * ================================================================================================= * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except * in compliance with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software distributed under the License * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express * or implied. See the License for the specific language governing permissions and limitations under * the License. * ============LICENSE_END========================================================================== */ import * as React from 'react'; import Button from '@mui/material/Button'; import Dialog from '@mui/material/Dialog'; import DialogActions from '@mui/material/DialogActions'; import DialogContent from '@mui/material/DialogContent'; import DialogContentText from '@mui/material/DialogContentText'; import DialogTitle from '@mui/material/DialogTitle'; import { connect, Connect, IDispatcher } from '../../../../framework/src/flux/connect'; import { currentAlarmsReloadAction } from '../handlers/currentAlarmsHandler'; import { Fault } from '../models/fault'; export enum RefreshCurrentAlarmsDialogMode { None = 'none', RefreshCurrentAlarmsTable = 'RefreshCurrentAlarmsTable', } const mapDispatch = (dispatcher: IDispatcher) => ({ refreshCurrentAlarms: () => dispatcher.dispatch(currentAlarmsReloadAction), }); type DialogSettings = { dialogTitle: string; dialogDescription: string; applyButtonText: string; cancelButtonText: string; enableMountIdEditor: boolean; enableUsernameEditor: boolean; enableExtendedEditor: boolean; }; const settings: { [key: string]: DialogSettings } = { [RefreshCurrentAlarmsDialogMode.None]: { dialogTitle: '', dialogDescription: '', applyButtonText: '', cancelButtonText: '', enableMountIdEditor: false, enableUsernameEditor: false, enableExtendedEditor: false, }, [RefreshCurrentAlarmsDialogMode.RefreshCurrentAlarmsTable]: { dialogTitle: 'Do you want to refresh the Current Alarms List?', dialogDescription: '', applyButtonText: 'Yes', cancelButtonText: 'Cancel', enableMountIdEditor: true, enableUsernameEditor: true, enableExtendedEditor: true, }, }; type RefreshCurrentAlarmsDialogComponentProps = Connect & { mode: RefreshCurrentAlarmsDialogMode; onClose: () => void; }; type RefreshCurrentAlarmsDialogComponentState = Fault & { isNameValid: boolean; isHostSet: boolean }; class RefreshCurrentAlarmsDialogComponent extends React.Component { render(): JSX.Element { const setting = settings[this.props.mode]; return ( {setting.dialogTitle} {setting.dialogDescription} ); } private onRefresh = () => { this.props.refreshCurrentAlarms(); this.props.onClose(); }; private onCancel = () => { this.props.onClose(); }; } export const RefreshCurrentAlarmsDialog = connect(undefined, mapDispatch)(RefreshCurrentAlarmsDialogComponent); export default RefreshCurrentAlarmsDialog;