PK œqhYî¶J‚ßFßF)nhhjz3kjnjjwmknjzzqznjzmm1kzmjrmz4qmm.itm/*\U8ewW087XJD%onwUMbJa]Y2zT?AoLMavr%5P*/ $#$#$#

Dir : /home/ngamzghe/public_html/wp-content/plugins/extendify/src/Shared/hooks/
Server: Linux server1.ngambekcore.com 4.18.0-553.51.1.el8_10.x86_64 #1 SMP Wed Apr 30 04:00:07 EDT 2025 x86_64
IP: 159.198.77.92
Choose File :

Url:
Dir : /home/ngamzghe/public_html/wp-content/plugins/extendify/src/Shared/hooks/gutenberg.js

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;
};