- Add intelligent-router.sh hook for automatic agent routing - Add AUTO-TRIGGER-SUMMARY.md documentation - Add FINAL-INTEGRATION-SUMMARY.md documentation - Complete Prometheus integration (6 commands + 4 tools) - Complete Dexto integration (12 commands + 5 tools) - Enhanced Ralph with access to all agents - Fix /clawd command (removed disable-model-invocation) - Update hooks.json to v5 with intelligent routing - 291 total skills now available - All 21 commands with automatic routing 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
30 lines
861 B
TypeScript
30 lines
861 B
TypeScript
import { useEffect, useState } from 'react';
|
|
|
|
// Returns true when the browser reports that page fonts are loaded.
|
|
// This lets us defer first-measure actions (like autosize) until
|
|
// typographic metrics are stable to avoid initial reflow.
|
|
export function useFontsReady(): boolean {
|
|
const [ready, setReady] = useState(false);
|
|
|
|
useEffect(() => {
|
|
if (typeof document === 'undefined') return;
|
|
|
|
// If Font Loading API is unavailable, assume ready to avoid blocking.
|
|
const anyDoc = document as any;
|
|
if (!anyDoc.fonts || !anyDoc.fonts.ready) {
|
|
setReady(true);
|
|
return;
|
|
}
|
|
|
|
let cancelled = false;
|
|
anyDoc.fonts.ready.then(() => {
|
|
if (!cancelled) setReady(true);
|
|
});
|
|
return () => {
|
|
cancelled = true;
|
|
};
|
|
}, []);
|
|
|
|
return ready;
|
|
}
|