@elastic/eui
Version:
Elastic UI Component Library
92 lines (91 loc) • 4.14 kB
JavaScript
import _extends from "@babel/runtime/helpers/extends";
import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
var _excluded = ["children", "title", "titleProps", "onCancel", "onConfirm", "cancelButtonText", "confirmButtonText", "confirmButtonDisabled", "className", "buttonColor", "defaultFocusedButton", "isLoading"];
/*
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
* or more contributor license agreements. Licensed under the Elastic License
* 2.0 and the Server Side Public License, v 1; you may not use this file except
* in compliance with, at your election, the Elastic License 2.0 or the Server
* Side Public License, v 1.
*/
import React, { useEffect, useRef } from 'react';
import classnames from 'classnames';
import { EuiModal } from './modal';
import { EuiModalFooter } from './modal_footer';
import { EuiModalHeader } from './modal_header';
import { EuiModalHeaderTitle } from './modal_header_title';
import { EuiModalBody } from './modal_body';
import { useEuiTheme } from '../../services';
import { euiModalStyles } from './modal.styles';
import { EuiButton, EuiButtonEmpty } from '../button';
import { EuiText } from '../text';
import { jsx as ___EmotionJSX } from "@emotion/react";
export var CONFIRM_BUTTON = 'confirm';
export var CANCEL_BUTTON = 'cancel';
export var EuiConfirmModal = function EuiConfirmModal(_ref) {
var children = _ref.children,
title = _ref.title,
titleProps = _ref.titleProps,
onCancel = _ref.onCancel,
onConfirm = _ref.onConfirm,
cancelButtonText = _ref.cancelButtonText,
confirmButtonText = _ref.confirmButtonText,
confirmButtonDisabled = _ref.confirmButtonDisabled,
className = _ref.className,
_ref$buttonColor = _ref.buttonColor,
buttonColor = _ref$buttonColor === void 0 ? 'primary' : _ref$buttonColor,
defaultFocusedButton = _ref.defaultFocusedButton,
isLoading = _ref.isLoading,
rest = _objectWithoutProperties(_ref, _excluded);
var cancelButtonRef = useRef(null);
var confirmButtonRef = useRef(null);
useEffect(function () {
// We have to do this instead of using `autoFocus` because React's polyfill for auto-focusing
// elements conflicts with the focus-trap logic we have on EuiModal.
// Wait a beat for the focus-trap to complete, and then set focus to the right button. Check that
// the buttons exist first, because it's possible the modal has been closed already.
setTimeout(function () {
if (defaultFocusedButton === CANCEL_BUTTON && cancelButtonRef.current) {
cancelButtonRef.current.focus();
} else if (defaultFocusedButton === CONFIRM_BUTTON && confirmButtonRef.current) {
confirmButtonRef.current.focus();
}
});
}, [defaultFocusedButton, cancelButtonRef, confirmButtonRef]);
var classes = classnames('euiModal--confirmation', className);
var euiTheme = useEuiTheme();
var styles = euiModalStyles(euiTheme);
var cssStyles = [styles.confirmation];
var modalTitle;
if (title) {
modalTitle = ___EmotionJSX(EuiModalHeader, null, ___EmotionJSX(EuiModalHeaderTitle, _extends({
"data-test-subj": "confirmModalTitleText"
}, titleProps), title));
}
var message;
if (typeof children === 'string' && children.length > 0) {
message = ___EmotionJSX("p", null, children);
} else {
message = children;
}
return ___EmotionJSX(EuiModal, _extends({
className: classes,
css: cssStyles,
onClose: onCancel,
role: "alertdialog"
}, rest), modalTitle, message && ___EmotionJSX(EuiModalBody, null, ___EmotionJSX(EuiText, {
"data-test-subj": "confirmModalBodyText"
}, message)), ___EmotionJSX(EuiModalFooter, null, ___EmotionJSX(EuiButtonEmpty, {
"data-test-subj": "confirmModalCancelButton",
onClick: onCancel,
buttonRef: cancelButtonRef
}, cancelButtonText), ___EmotionJSX(EuiButton, {
"data-test-subj": "confirmModalConfirmButton",
onClick: onConfirm,
isLoading: isLoading,
fill: true,
buttonRef: confirmButtonRef,
color: buttonColor,
isDisabled: confirmButtonDisabled
}, confirmButtonText)));
};