mirror of
https://github.com/NousResearch/hermes-agent.git
synced 2026-04-25 00:51:20 +00:00
Hoist turn state from a 286-line hook into $turnState atom + turnController
singleton. createGatewayEventHandler becomes a typed dispatch over the
controller; its ctx shrinks from 30 fields to 5. Event-handler refs and 16
threaded actions are gone.
Fold three createSlash*Handler factories into a data-driven SlashCommand[]
registry under slash/commands/{core,session,ops}.ts. Aliases are data;
findSlashCommand does name+alias lookup. Shared guarded/guardedErr combinator
in slash/guarded.ts.
Split constants.ts + app/helpers.ts into config/ (timing/limits/env),
content/ (faces/placeholders/hotkeys/verbs/charms/fortunes), domain/ (roles/
details/messages/paths/slash/viewport/usage), protocol/ (interpolation/paste).
Type every RPC response in gatewayTypes.ts (26 new interfaces); drop all
`(r: any)` across slash + main app.
Shrink useMainApp from 1216 -> 646 lines by extracting useSessionLifecycle,
useSubmission, useConfigSync. Add <Fg> themed primitive and strip ~50
`as any` color casts.
Tests: 50 passing. Build + type-check clean.
22 lines
718 B
TypeScript
22 lines
718 B
TypeScript
import { GatewayProvider } from './app/gatewayContext.js'
|
|
import { useMainApp } from './app/useMainApp.js'
|
|
import { AppLayout } from './components/appLayout.js'
|
|
import { MOUSE_TRACKING } from './config/env.js'
|
|
import type { GatewayClient } from './gatewayClient.js'
|
|
|
|
export function App({ gw }: { gw: GatewayClient }) {
|
|
const { appActions, appComposer, appProgress, appStatus, appTranscript, gateway } = useMainApp(gw)
|
|
|
|
return (
|
|
<GatewayProvider value={gateway}>
|
|
<AppLayout
|
|
actions={appActions}
|
|
composer={appComposer}
|
|
mouseTracking={MOUSE_TRACKING}
|
|
progress={appProgress}
|
|
status={appStatus}
|
|
transcript={appTranscript}
|
|
/>
|
|
</GatewayProvider>
|
|
)
|
|
}
|