From e9e2c30025b889552bc4baf1fd31213af0cddcf1 Mon Sep 17 00:00:00 2001 From: robo-mop Date: Wed, 5 Jul 2023 17:35:54 +0530 Subject: [PATCH] Replace Context with shared functions --- src/client/lazy-app/Compress/index.tsx | 106 +++++++++++-------------- src/client/lazy-app/Modal/index.tsx | 64 ++++++++------- 2 files changed, 81 insertions(+), 89 deletions(-) diff --git a/src/client/lazy-app/Compress/index.tsx b/src/client/lazy-app/Compress/index.tsx index d9edbf398..672516471 100644 --- a/src/client/lazy-app/Compress/index.tsx +++ b/src/client/lazy-app/Compress/index.tsx @@ -32,9 +32,7 @@ import WorkerBridge from '../worker-bridge'; import { resize } from 'features/processors/resize/client'; import type SnackBarElement from 'shared/custom-els/snack-bar'; import { drawableToImageData } from '../util/canvas'; -import Modal, { ModalMessage } from '../Modal'; -import ModalContext from '../Modal/modal-context'; -import { linkRef } from 'shared/prerendered-app/util'; +import Modal from '../Modal'; export type OutputType = EncoderType | 'identity'; @@ -327,8 +325,6 @@ export default class Compress extends Component { /** For debouncing calls to updateImage for each side. */ private updateImageTimeout?: number; - private modal?: Modal; - constructor(props: Props) { super(props); this.widthQuery.addListener(this.onMobileWidthChange); @@ -920,12 +916,6 @@ export default class Compress extends Component { }); } - private showModal(modalMessage: ModalMessage) { - if (!this.modal) return; - - this.modal.showModal(modalMessage); - } - render( { onBack }: Props, { loading, sides, source, mobileView, preprocessorState }: State, @@ -979,55 +969,51 @@ export default class Compress extends Component { return (
- this.showModal(message)} - > - - - {mobileView ? ( -
- -
{results[0]}
-
{options[0]}
-
{results[1]}
-
{options[1]}
-
-
- ) : ( - [ -
- {options[0]} - {results[0]} -
, -
- {options[1]} - {results[1]} -
, - ] - )} -
- + + + {mobileView ? ( +
+ +
{results[0]}
+
{options[0]}
+
{results[1]}
+
{options[1]}
+
+
+ ) : ( + [ +
+ {options[0]} + {results[0]} +
, +
+ {options[1]} + {results[1]} +
, + ] + )} +
); } diff --git a/src/client/lazy-app/Modal/index.tsx b/src/client/lazy-app/Modal/index.tsx index 0d8d891b1..38beeb86d 100644 --- a/src/client/lazy-app/Modal/index.tsx +++ b/src/client/lazy-app/Modal/index.tsx @@ -2,6 +2,7 @@ import { h, Component, VNode, Fragment } from 'preact'; import * as style from './style.css'; import 'add-css:./style.css'; import { linkRef } from 'shared/prerendered-app/util'; +import { cleanSet } from '../util/clean-modify'; interface Props {} @@ -26,34 +27,45 @@ export default class Modal extends Component { shown: false, }; - private modal?: HTMLDialogElement; + private dialogElement!: HTMLDialogElement; + static modalInstance?: Modal | undefined; componentDidMount() { // Once a transition ends, check if the modal should be closed (not just hidden) // dialog.close() instantly hides the modal, so we call it AFTER fading it out i.e. on transition end - this.modal?.addEventListener( + this.dialogElement.addEventListener( 'transitionend', this._closeOnTransitionEnd.bind(this), ); - this.modal?.setAttribute('inert', 'enabled'); + this.dialogElement.setAttribute('inert', 'enabled'); + + Modal.modalInstance = this; } private _closeOnTransitionEnd() { // If modal does not exist // Or if it's not being closed at the moment - if (!this.modal || !this.modal.classList.contains(style.modalClosing)) + if ( + !this.dialogElement || + !this.dialogElement.classList.contains(style.modalClosing) + ) return; - this.modal.close(); - this.modal.classList.remove(style.modalClosing); - this.modal.setAttribute('inert', 'enabled'); + this.dialogElement.close(); + this.dialogElement.classList.remove(style.modalClosing); + this.dialogElement.setAttribute('inert', 'enabled'); + } + + static showModal(message: ModalMessage) { + Modal.modalInstance?._showModal(message); } - /** - * Function to set up the modal and show it - */ - showModal(message: ModalMessage) { - if (!this.modal) return; + static hideModal() { + Modal.modalInstance?._hideModal(); + } + + private _showModal(message: ModalMessage) { + if (!this.dialogElement) throw Error('Modal missing'); this.setState({ message: message, @@ -61,31 +73,25 @@ export default class Modal extends Component { }); // Actually show the modal - this.modal.removeAttribute('inert'); - this.modal.showModal(); + this.dialogElement.removeAttribute('inert'); + this.dialogElement.showModal(); } - /** - * Function to hide the modal with a fade-out transition - * Adds the `modal--closing` class which is removed on transition end - */ - hideModal() { - if (!this.modal || !this.modal.open) return; + private _hideModal() { + if (!this.dialogElement || !this.dialogElement.open) + throw Error('Modal missing / hidden'); // Make the modal fade out - this.modal.classList.add(style.modalClosing); + this.dialogElement.classList.add(style.modalClosing); - this.setState({ - message: { ...this.state.message }, - shown: false, - }); + this.setState(cleanSet(this.state, 'shown', false)); } private _onKeyDown(e: KeyboardEvent) { // Default behaviour of closes it instantly when you press Esc // So we hijack it to smoothly hide the modal - if (e.key === 'Escape' || e.keyCode == 27) { - this.hideModal(); + if (e.key === 'Escape') { + this._hideModal(); e.preventDefault(); e.stopImmediatePropagation(); } @@ -94,13 +100,13 @@ export default class Modal extends Component { render({}: Props, { message, shown }: State) { return ( this._onKeyDown(e)} >
{message.icon} {message.title} -