mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-05 12:50:29 +02:00
57 lines
1.6 KiB
TypeScript
57 lines
1.6 KiB
TypeScript
import { useEffect, useState, useMemo } from 'react';
|
|
const md5 = require('md5');
|
|
|
|
// eslint-disable-next-line @typescript-eslint/ban-types -- Old code before rule was applied
|
|
export default function(frameWindow: any, isReady: boolean, postMessage: Function, html: string) {
|
|
const [loadedHtmlHash, setLoadedHtmlHash] = useState('');
|
|
|
|
const htmlHash = useMemo(() => {
|
|
return md5(html);
|
|
}, [html]);
|
|
|
|
useEffect(() => {
|
|
if (!frameWindow) return () => {};
|
|
|
|
function onMessage(event: any) {
|
|
const data = event.data;
|
|
|
|
if (!data || data.target !== 'UserWebview') return;
|
|
|
|
// eslint-disable-next-line no-console
|
|
console.info('useHtmlLoader: message', data);
|
|
|
|
// We only update if the HTML that was loaded is the same as
|
|
// the active one. Otherwise it means the content has been
|
|
// changed between the moment it was set by the user and the
|
|
// moment it was loaded in the view.
|
|
if (data.message === 'htmlIsSet' && data.hash === htmlHash) {
|
|
setLoadedHtmlHash(data.hash);
|
|
}
|
|
}
|
|
|
|
frameWindow.addEventListener('message', onMessage);
|
|
|
|
return () => {
|
|
if (frameWindow.removeEventListener) frameWindow.removeEventListener('message', onMessage);
|
|
};
|
|
}, [frameWindow, htmlHash]);
|
|
|
|
useEffect(() => {
|
|
// eslint-disable-next-line no-console
|
|
console.info('useHtmlLoader: isReady', isReady);
|
|
|
|
if (!isReady) return;
|
|
|
|
// eslint-disable-next-line no-console
|
|
console.info('useHtmlLoader: setHtml', htmlHash);
|
|
|
|
postMessage('setHtml', {
|
|
hash: htmlHash,
|
|
html: html,
|
|
});
|
|
// eslint-disable-next-line @seiyab/react-hooks/exhaustive-deps -- Old code before rule was applied
|
|
}, [html, htmlHash, isReady]);
|
|
|
|
return loadedHtmlHash;
|
|
}
|