Dashboard sipadu mbip
選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。

ModalHeader.js 1.4KB

123456789101112131415161718192021222324252627282930313233343536373839
  1. import _extends from "@babel/runtime/helpers/esm/extends";
  2. import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
  3. import classNames from 'classnames';
  4. import React, { useContext } from 'react';
  5. import useEventCallback from '@restart/hooks/useEventCallback';
  6. import { useBootstrapPrefix } from './ThemeProvider';
  7. import CloseButton from './CloseButton';
  8. import ModalContext from './ModalContext';
  9. var defaultProps = {
  10. closeLabel: 'Close',
  11. closeButton: false
  12. };
  13. var ModalHeader = React.forwardRef(function (_ref, ref) {
  14. var bsPrefix = _ref.bsPrefix,
  15. closeLabel = _ref.closeLabel,
  16. closeButton = _ref.closeButton,
  17. onHide = _ref.onHide,
  18. className = _ref.className,
  19. children = _ref.children,
  20. props = _objectWithoutPropertiesLoose(_ref, ["bsPrefix", "closeLabel", "closeButton", "onHide", "className", "children"]);
  21. bsPrefix = useBootstrapPrefix(bsPrefix, 'modal-header');
  22. var context = useContext(ModalContext);
  23. var handleClick = useEventCallback(function () {
  24. if (context) context.onHide();
  25. if (onHide) onHide();
  26. });
  27. return React.createElement("div", _extends({
  28. ref: ref
  29. }, props, {
  30. className: classNames(className, bsPrefix)
  31. }), children, closeButton && React.createElement(CloseButton, {
  32. label: closeLabel,
  33. onClick: handleClick
  34. }));
  35. });
  36. ModalHeader.displayName = 'ModalHeader';
  37. ModalHeader.defaultProps = defaultProps;
  38. export default ModalHeader;