<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha1/dist/css/bootstrap.min.css" rel="stylesheet"
        integrity="sha384-GLhlTQ8iRABdZLl6O3oVMWSktQOp6b7In1Zl3/Jr59b6EGGoI1aFkw7cmDA6j6gD" crossorigin="anonymous">
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.3.0/css/all.min.css"
        integrity="sha512-SzlrxWUlpfuzQ+pcUCosxcglQRNAq/DZjVsC0lE40xsADsfeQoEypE+enwcOiGjk/bSuGGKHEyjSoQ1zVisanQ=="
        crossorigin="anonymous" referrerpolicy="no-referrer" />
</head>
</html>
import { store as blockEditorStore } from '@wordpress/block-editor';
import { subscribe, useSelect } from '@wordpress/data';
import { store as editorStore } from '@wordpress/editor';
import { useEffect, useState } from '@wordpress/element';

//** This hook checks if the editor is interactive yet */
export const useEditorReady = () => {
	const [isEditorReady, setIsEditorReady] = useState(false);
	const blocksReady = useSelect(
		(select) =>
			select(blockEditorStore).__unstableIsEditorReady ||
			select(blockEditorStore).getBlockCount() > 0 ||
			select(blockEditorStore).getSelectedBlockClientId(),
	);
	const editorReady = useSelect(
		(select) =>
			select(editorStore).__unstableIsEditorReady ||
			select(editorStore).isCleanNewPost(),
	);
	// TODO: do we need to wait on the iframe?

	useEffect(() => {
		const unsubscribe = subscribe(() => {
			if (blocksReady || editorReady) {
				setIsEditorReady(true);
				unsubscribe();
			}
		});
	}, [blocksReady, editorReady]);

	return isEditorReady;
};
