/** *******************************************************************************************************************
Copyright Amazon.com, Inc. or its affiliates. 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. *
******************************************************************************************************************** */
import React, { ReactNode, FunctionComponent, useCallback, useEffect, useMemo, useState } from 'react';
import Inline from '../../layouts/Inline';
import Stack from '../../layouts/Stack';
import Box from '../../layouts/Box';
import Modal from '../../components/Modal';
import FormField from '../../components/FormField';
import Input from '../../components/Input';
import Button from '../../components/Button';
export type VariantType = 'confirmation' | 'friction';
export interface DeleteConfirmationBaseProps {
/**The variant of the Delete Confirmation Dialog*/
variant?: VariantType;
/**
* Determines whether the Delete Confirmation Dialog is displayed on the screen.
* The Delete Confirmation Dialog is hidden by default. Set this property to true to show it.
*/
visible?: boolean;
/**
* Calls when a user closes the dialog by using the close icon button or clicing the Cancel button.
*/
onCancelClicked?: () => void;
/**
* Calls when a user clicks the Delete button.
*/
onDeleteClicked?: () => void;
/**
* Renders the Delete button as being in a loading state.
*/
loading?: boolean;
/**
* Determines whether the button is enabled. For Delete With Friction Confirmation Dialog, this flag takes effect after the confirmation text is matched.
* */
enabled?: boolean;
/**
* The title of the Delete Confirmation Dialog.
*/
title: string;
/**
* Content displayed below the title and above the input field.
*/
children?: ReactNode;
/**
* Override the Delete button label.
*/
deleteButtonText?: string;
}
export interface DeleteConfirmationWithFrictionProps {
/**
* Overrides the variant props DeleteConfirmationBaseProps to be 'friction'
*/
variant?: 'friction';
/**
* The label of the input field.
*/
label?: ReactNode;
/**
* The placeholder text of the input field.
*/
placeholderText?: string;
/**
* The hint text of the input field.
*/
hintText?: string;
/**
* The confirmation text that is expected from users to type in the input field.
*/
confirmationText?: string;
}
export interface DeleteConfirmationWithConfirmationProps {
/**
* Overrides the variant props DeleteConfirmationBaseProps to be 'confirmation'
*/
variant: 'confirmation';
}
export type DeleteConfirmationDialogProps = DeleteConfirmationBaseProps &
(DeleteConfirmationWithConfirmationProps | DeleteConfirmationWithFrictionProps);
/**
* A model dialog used to verify users truly intend to perform deletion or some kind of destructive action.
* When deleting resources, you can choose between different levels of friction: friction or confirmation.
* */
const DeleteConfirmationDialog: FunctionComponent = ({
visible,
onDeleteClicked,
onCancelClicked,
loading = false,
enabled = true,
title,
children,
deleteButtonText,
...props
}) => {
const [confirmation, setConfirmation] = useState('');
const [isMatched, setIsMatched] = useState(props.variant === 'confirmation');
const confirmationText = (props.variant !== 'confirmation' && props.confirmationText) || 'delete';
const handleDelete = useCallback(() => {
setConfirmation('');
onDeleteClicked?.();
}, [onDeleteClicked]);
const handleCancel = useCallback(() => {
setConfirmation('');
onCancelClicked?.();
}, [onCancelClicked]);
const actions = useMemo(
() => (
),
[deleteButtonText, handleCancel, handleDelete, loading, isMatched, enabled]
);
useEffect(() => {
setIsMatched(props.variant === 'confirmation' || confirmationText === confirmation);
}, [setIsMatched, confirmation, confirmationText, props.variant]);
return (
{children}
{props.variant !== 'confirmation' && (
To confirm deletion, type delete below
>
)
}
controlId="confirmation"
hintText={props.hintText}
>
)}
);
};
export default DeleteConfirmationDialog;