HostBridge 启动时通过真实 host.getRuntime 回读并缓存宿主能力 主 App 订阅宿主能力变化并在回读后刷新能力入口 补充宿主 runtime 回读测试和 App 能力刷新测试 更新 Expo/Tauri 壳方案、HostBridge 协议文档和共享决策记录
59 lines
1.7 KiB
TypeScript
59 lines
1.7 KiB
TypeScript
/* eslint-disable react-refresh/only-export-components */
|
|
|
|
import './index.css';
|
|
|
|
import {StrictMode, Suspense} from 'react';
|
|
import {createRoot} from 'react-dom/client';
|
|
|
|
import {stabilizeMobileViewportKeyboardFocus} from './mobileViewportKeyboardFocus';
|
|
import {lockMobileViewportZoom} from './mobileViewportZoomLock';
|
|
import {resolveAppRoute} from './routing/appRoutes';
|
|
import {RouteImageReadyGate} from './routing/RouteImageReadyGate';
|
|
import {RouteLoadingScreen} from './routing/RouteLoadingScreen';
|
|
import {
|
|
getHostRuntime,
|
|
refreshNativeAppHostRuntime,
|
|
} from './services/host-bridge/hostBridge';
|
|
|
|
type AppRoot = ReturnType<typeof createRoot>;
|
|
|
|
declare global {
|
|
interface Window {
|
|
__tavernRealmsRoot__?: AppRoot;
|
|
}
|
|
}
|
|
|
|
const route = resolveAppRoute(window.location.pathname);
|
|
const rootElement = document.getElementById('root');
|
|
|
|
if (!rootElement) {
|
|
throw new Error('Missing #root container');
|
|
}
|
|
|
|
function markWechatMiniProgramRuntime() {
|
|
if (getHostRuntime().kind === 'wechat_mini_program') {
|
|
document.documentElement.dataset.wechatMiniProgramRuntime = 'true';
|
|
}
|
|
}
|
|
|
|
const root = window.__tavernRealmsRoot__ ??= createRoot(rootElement);
|
|
const RouteComponent = route.Component;
|
|
|
|
lockMobileViewportZoom();
|
|
stabilizeMobileViewportKeyboardFocus();
|
|
markWechatMiniProgramRuntime();
|
|
void refreshNativeAppHostRuntime();
|
|
|
|
root.render(
|
|
<StrictMode>
|
|
<Suspense fallback={<RouteLoadingScreen eyebrow={route.loadingEyebrow} text={route.loadingText} />}>
|
|
<RouteImageReadyGate
|
|
eyebrow={route.loadingEyebrow}
|
|
text={route.loadingText}
|
|
>
|
|
<RouteComponent {...(route.componentProps ?? {})} />
|
|
</RouteImageReadyGate>
|
|
</Suspense>
|
|
</StrictMode>,
|
|
);
|