mirror of
https://github.com/responsively-org/responsively-app
synced 2024-11-10 14:54:12 +00:00
Persisting the simulation across navigations
This commit is contained in:
parent
f6558e91e6
commit
101fb1b6e5
1 changed files with 33 additions and 2 deletions
|
@ -1,6 +1,6 @@
|
|||
import { Icon } from '@iconify/react';
|
||||
import cx from 'classnames';
|
||||
import { useState } from 'react';
|
||||
import { useCallback, useEffect, useState } from 'react';
|
||||
import { DropDown } from 'renderer/components/DropDown';
|
||||
|
||||
const redgreen = ['Deuteranopia', 'Deuteranomaly', 'Protanopia', 'Protanomaly'];
|
||||
|
@ -12,6 +12,7 @@ const sunlight = ['Solarize'];
|
|||
interface InjectedCss {
|
||||
key: string;
|
||||
css: string;
|
||||
js: string | null;
|
||||
name: string;
|
||||
}
|
||||
|
||||
|
@ -61,6 +62,21 @@ const MenuItemHeader = ({ label }: { label: string }) => {
|
|||
export const ColorBlindnessTools = ({ webview }: Props) => {
|
||||
const [injectCss, setInjectCss] = useState<InjectedCss>();
|
||||
|
||||
const reApplyCss = useCallback(async () => {
|
||||
if (webview === null) {
|
||||
return;
|
||||
}
|
||||
if (injectCss === undefined) {
|
||||
return;
|
||||
}
|
||||
const key = await webview.insertCSS(injectCss.css);
|
||||
if (injectCss.js != null) {
|
||||
await webview.executeJavaScript(injectCss.js);
|
||||
}
|
||||
|
||||
setInjectCss({ ...injectCss, key });
|
||||
}, [webview, injectCss, setInjectCss]);
|
||||
|
||||
const applyCss = async (
|
||||
debugType: string,
|
||||
css: string,
|
||||
|
@ -88,10 +104,10 @@ export const ColorBlindnessTools = ({ webview }: Props) => {
|
|||
|
||||
try {
|
||||
const key = await webview.insertCSS(css);
|
||||
setInjectCss({ key, css, name: debugType });
|
||||
if (js !== null) {
|
||||
await webview.executeJavaScript(js);
|
||||
}
|
||||
setInjectCss({ key, css, name: debugType, js });
|
||||
} catch (error) {
|
||||
// eslint-disable-next-line no-console
|
||||
console.error('Error inserting css', error);
|
||||
|
@ -111,6 +127,21 @@ export const ColorBlindnessTools = ({ webview }: Props) => {
|
|||
setInjectCss(undefined);
|
||||
};
|
||||
|
||||
useEffect(() => {
|
||||
if (webview === null) {
|
||||
return () => {};
|
||||
}
|
||||
const handler = async () => {
|
||||
reApplyCss();
|
||||
};
|
||||
|
||||
webview.addEventListener('did-navigate', handler);
|
||||
|
||||
return () => {
|
||||
webview.removeEventListener('did-navigate', handler);
|
||||
};
|
||||
}, [webview, reApplyCss]);
|
||||
|
||||
const applyColorDeficiency = async (colorDeficiency: string) => {
|
||||
const xsltPath =
|
||||
'';
|
||||
|
|
Loading…
Reference in a new issue