mirror of
				https://github.com/owncast/owncast.git
				synced 2025-11-04 13:27:21 +08:00 
			
		
		
		
	* Change iframe style to block - this removes the double scrollbar issue that was occurring * Change and Add default modal sizes
		
			
				
	
	
		
			95 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			95 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
import { Spin, Skeleton, Modal as AntModal } from 'antd';
 | 
						|
import React, { FC, ReactNode, useState } from 'react';
 | 
						|
import styles from './Modal.module.scss';
 | 
						|
 | 
						|
export type ModalProps = {
 | 
						|
  title: string;
 | 
						|
  url?: string;
 | 
						|
  open: boolean;
 | 
						|
  handleOk?: () => void;
 | 
						|
  handleCancel?: () => void;
 | 
						|
  afterClose?: () => void;
 | 
						|
  children?: ReactNode;
 | 
						|
  height?: string;
 | 
						|
  width?: string;
 | 
						|
};
 | 
						|
 | 
						|
export const Modal: FC<ModalProps> = ({
 | 
						|
  title,
 | 
						|
  url,
 | 
						|
  open,
 | 
						|
  handleOk,
 | 
						|
  handleCancel,
 | 
						|
  afterClose,
 | 
						|
  height,
 | 
						|
  width,
 | 
						|
  children,
 | 
						|
}) => {
 | 
						|
  const [loading, setLoading] = useState(!!url);
 | 
						|
 | 
						|
  let defaultHeight = '100%';
 | 
						|
  let defaultWidth = '520px';
 | 
						|
  if (url) {
 | 
						|
    defaultHeight = '70vh';
 | 
						|
    defaultWidth = '900px';
 | 
						|
  }
 | 
						|
 | 
						|
  const modalStyle = {
 | 
						|
    padding: '0px',
 | 
						|
    minHeight: height,
 | 
						|
    height: height ?? defaultHeight,
 | 
						|
  };
 | 
						|
 | 
						|
  const iframe = url && (
 | 
						|
    <iframe
 | 
						|
      title={title}
 | 
						|
      src={url}
 | 
						|
      width="100%"
 | 
						|
      height="100%"
 | 
						|
      sandbox="allow-same-origin allow-scripts allow-popups allow-forms"
 | 
						|
      frameBorder="0"
 | 
						|
      allowFullScreen
 | 
						|
      style={{ display: 'block' }}
 | 
						|
      // eslint-disable-next-line react/no-unknown-property
 | 
						|
      onLoad={() => setLoading(false)}
 | 
						|
    />
 | 
						|
  );
 | 
						|
 | 
						|
  const iframeDisplayStyle = loading ? 'none' : 'inline';
 | 
						|
 | 
						|
  return (
 | 
						|
    <AntModal
 | 
						|
      title={title}
 | 
						|
      open={open}
 | 
						|
      onOk={handleOk}
 | 
						|
      onCancel={handleCancel}
 | 
						|
      afterClose={afterClose}
 | 
						|
      bodyStyle={modalStyle}
 | 
						|
      width={width ?? defaultWidth}
 | 
						|
      zIndex={999}
 | 
						|
      footer={null}
 | 
						|
      centered
 | 
						|
      destroyOnClose
 | 
						|
    >
 | 
						|
      <>
 | 
						|
        {loading && (
 | 
						|
          <Skeleton active={loading} style={{ padding: '10px' }} paragraph={{ rows: 10 }} />
 | 
						|
        )}
 | 
						|
 | 
						|
        {iframe && <div style={{ display: iframeDisplayStyle }}>{iframe}</div>}
 | 
						|
        {children && <div className={styles.content}>{children}</div>}
 | 
						|
        {loading && <Spin className={styles.spinner} spinning={loading} size="large" />}
 | 
						|
      </>
 | 
						|
    </AntModal>
 | 
						|
  );
 | 
						|
};
 | 
						|
export default Modal;
 | 
						|
 | 
						|
Modal.defaultProps = {
 | 
						|
  url: undefined,
 | 
						|
  children: undefined,
 | 
						|
  handleOk: undefined,
 | 
						|
  handleCancel: undefined,
 | 
						|
  afterClose: undefined,
 | 
						|
};
 |