mirror of
https://github.com/whscullin/apple2js.git
synced 2024-01-12 14:14:38 +00:00
c7a7bcd19b
* Simple Preact download
93 lines
2.7 KiB
TypeScript
93 lines
2.7 KiB
TypeScript
import { h } from 'preact';
|
|
import { useCallback, useState } from 'preact/hooks';
|
|
import cs from 'classnames';
|
|
import Disk2 from '../cards/disk2';
|
|
import { ErrorModal } from './ErrorModal';
|
|
import { FileModal } from './FileModal';
|
|
|
|
import styles from './css/DiskII.module.css';
|
|
import { DiskDragTarget } from './DiskDragTarget';
|
|
import { NIBBLE_FORMATS } from 'js/formats/types';
|
|
import { DownloadModal } from './DownloadModal';
|
|
|
|
/**
|
|
* Storage structure for Disk II state returned via callbacks.
|
|
*/
|
|
export interface DiskIIData {
|
|
number: 1 | 2;
|
|
on: boolean;
|
|
name: string;
|
|
side?: string | undefined;
|
|
}
|
|
|
|
/**
|
|
* Interface for Disk II component.
|
|
*/
|
|
export interface DiskIIProps extends DiskIIData {
|
|
disk2: Disk2;
|
|
}
|
|
|
|
/**
|
|
* Disk II component
|
|
*
|
|
* Includes drive light, disk name and side, and UI for loading disks.
|
|
*
|
|
* @param disk2 Disk2 object
|
|
* @param number Drive 1 or 2
|
|
* @param on Active state
|
|
* @param name Disk name identifier
|
|
* @param side Disk side identifier
|
|
* @returns DiskII component
|
|
*/
|
|
export const DiskII = ({ disk2, number, on, name, side }: DiskIIProps) => {
|
|
const label = side ? `${name} - ${side}` : name;
|
|
const [modalOpen, setModalOpen] = useState(false);
|
|
const [downloadModalOpen, setDownloadModalOpen] = useState(false);
|
|
const [error, setError] = useState<unknown>();
|
|
|
|
const doClose = useCallback(() => {
|
|
setModalOpen(false);
|
|
}, []);
|
|
|
|
const onOpenModal = useCallback(() => {
|
|
setModalOpen(true);
|
|
}, []);
|
|
|
|
const doCloseDownload = useCallback(() => {
|
|
setDownloadModalOpen(false);
|
|
}, []);
|
|
|
|
const onOpenDownloadModal = useCallback(() => {
|
|
setDownloadModalOpen(true);
|
|
}, []);
|
|
|
|
return (
|
|
<DiskDragTarget
|
|
className={styles.disk}
|
|
storage={disk2}
|
|
drive={number}
|
|
formats={NIBBLE_FORMATS}
|
|
onError={setError}
|
|
>
|
|
<FileModal disk2={disk2} number={number} onClose={doClose} isOpen={modalOpen} />
|
|
<DownloadModal
|
|
number={number}
|
|
massStorage={disk2}
|
|
isOpen={downloadModalOpen}
|
|
onClose={doCloseDownload}
|
|
/>
|
|
<ErrorModal error={error} setError={setError} />
|
|
<div className={cs(styles.diskLight, { [styles.on]: on })} />
|
|
<button title="Load Disk" onClick={onOpenModal}>
|
|
<i className="fas fa-folder-open" />
|
|
</button>
|
|
<button title="Save Disk" onClick={onOpenDownloadModal}>
|
|
<i className="fas fa-save" />
|
|
</button>
|
|
<div className={styles.diskLabel}>
|
|
{label}
|
|
</div>
|
|
</DiskDragTarget>
|
|
);
|
|
};
|