source dump of claude code
at main 200 lines 24 kB view raw
1import { c as _c } from "react/compiler-runtime"; 2import { feature } from 'bun:bundle'; 3import React, { useContext, useEffect, useEffectEvent, useState, useSyncExternalStore } from 'react'; 4import { MailboxProvider } from '../context/mailbox.js'; 5import { useSettingsChange } from '../hooks/useSettingsChange.js'; 6import { logForDebugging } from '../utils/debug.js'; 7import { createDisabledBypassPermissionsContext, isBypassPermissionsModeDisabled } from '../utils/permissions/permissionSetup.js'; 8import { applySettingsChange } from '../utils/settings/applySettingsChange.js'; 9import type { SettingSource } from '../utils/settings/constants.js'; 10import { createStore } from './store.js'; 11 12// DCE: voice context is ant-only. External builds get a passthrough. 13/* eslint-disable @typescript-eslint/no-require-imports */ 14const VoiceProvider: (props: { 15 children: React.ReactNode; 16}) => React.ReactNode = feature('VOICE_MODE') ? require('../context/voice.js').VoiceProvider : ({ 17 children 18}) => children; 19 20/* eslint-enable @typescript-eslint/no-require-imports */ 21import { type AppState, type AppStateStore, getDefaultAppState } from './AppStateStore.js'; 22 23// TODO: Remove these re-exports once all callers import directly from 24// ./AppStateStore.js. Kept for back-compat during migration so .ts callers 25// can incrementally move off the .tsx import and stop pulling React. 26export { type AppState, type AppStateStore, type CompletionBoundary, getDefaultAppState, IDLE_SPECULATION_STATE, type SpeculationResult, type SpeculationState } from './AppStateStore.js'; 27export const AppStoreContext = React.createContext<AppStateStore | null>(null); 28type Props = { 29 children: React.ReactNode; 30 initialState?: AppState; 31 onChangeAppState?: (args: { 32 newState: AppState; 33 oldState: AppState; 34 }) => void; 35}; 36const HasAppStateContext = React.createContext<boolean>(false); 37export function AppStateProvider(t0) { 38 const $ = _c(13); 39 const { 40 children, 41 initialState, 42 onChangeAppState 43 } = t0; 44 const hasAppStateContext = useContext(HasAppStateContext); 45 if (hasAppStateContext) { 46 throw new Error("AppStateProvider can not be nested within another AppStateProvider"); 47 } 48 let t1; 49 if ($[0] !== initialState || $[1] !== onChangeAppState) { 50 t1 = () => createStore(initialState ?? getDefaultAppState(), onChangeAppState); 51 $[0] = initialState; 52 $[1] = onChangeAppState; 53 $[2] = t1; 54 } else { 55 t1 = $[2]; 56 } 57 const [store] = useState(t1); 58 let t2; 59 if ($[3] !== store) { 60 t2 = () => { 61 const { 62 toolPermissionContext 63 } = store.getState(); 64 if (toolPermissionContext.isBypassPermissionsModeAvailable && isBypassPermissionsModeDisabled()) { 65 logForDebugging("Disabling bypass permissions mode on mount (remote settings loaded before mount)"); 66 store.setState(_temp); 67 } 68 }; 69 $[3] = store; 70 $[4] = t2; 71 } else { 72 t2 = $[4]; 73 } 74 let t3; 75 if ($[5] === Symbol.for("react.memo_cache_sentinel")) { 76 t3 = []; 77 $[5] = t3; 78 } else { 79 t3 = $[5]; 80 } 81 useEffect(t2, t3); 82 let t4; 83 if ($[6] !== store.setState) { 84 t4 = source => applySettingsChange(source, store.setState); 85 $[6] = store.setState; 86 $[7] = t4; 87 } else { 88 t4 = $[7]; 89 } 90 const onSettingsChange = useEffectEvent(t4); 91 useSettingsChange(onSettingsChange); 92 let t5; 93 if ($[8] !== children) { 94 t5 = <MailboxProvider><VoiceProvider>{children}</VoiceProvider></MailboxProvider>; 95 $[8] = children; 96 $[9] = t5; 97 } else { 98 t5 = $[9]; 99 } 100 let t6; 101 if ($[10] !== store || $[11] !== t5) { 102 t6 = <HasAppStateContext.Provider value={true}><AppStoreContext.Provider value={store}>{t5}</AppStoreContext.Provider></HasAppStateContext.Provider>; 103 $[10] = store; 104 $[11] = t5; 105 $[12] = t6; 106 } else { 107 t6 = $[12]; 108 } 109 return t6; 110} 111function _temp(prev) { 112 return { 113 ...prev, 114 toolPermissionContext: createDisabledBypassPermissionsContext(prev.toolPermissionContext) 115 }; 116} 117function useAppStore(): AppStateStore { 118 // eslint-disable-next-line react-hooks/rules-of-hooks 119 const store = useContext(AppStoreContext); 120 if (!store) { 121 throw new ReferenceError('useAppState/useSetAppState cannot be called outside of an <AppStateProvider />'); 122 } 123 return store; 124} 125 126/** 127 * Subscribe to a slice of AppState. Only re-renders when the selected value 128 * changes (compared via Object.is). 129 * 130 * For multiple independent fields, call the hook multiple times: 131 * ``` 132 * const verbose = useAppState(s => s.verbose) 133 * const model = useAppState(s => s.mainLoopModel) 134 * ``` 135 * 136 * Do NOT return new objects from the selector -- Object.is will always see 137 * them as changed. Instead, select an existing sub-object reference: 138 * ``` 139 * const { text, promptId } = useAppState(s => s.promptSuggestion) // good 140 * ``` 141 */ 142export function useAppState(selector) { 143 const $ = _c(3); 144 const store = useAppStore(); 145 let t0; 146 if ($[0] !== selector || $[1] !== store) { 147 t0 = () => { 148 const state = store.getState(); 149 const selected = selector(state); 150 if (false && state === selected) { 151 throw new Error(`Your selector in \`useAppState(${selector.toString()})\` returned the original state, which is not allowed. You must instead return a property for optimised rendering.`); 152 } 153 return selected; 154 }; 155 $[0] = selector; 156 $[1] = store; 157 $[2] = t0; 158 } else { 159 t0 = $[2]; 160 } 161 const get = t0; 162 return useSyncExternalStore(store.subscribe, get, get); 163} 164 165/** 166 * Get the setAppState updater without subscribing to any state. 167 * Returns a stable reference that never changes -- components using only 168 * this hook will never re-render from state changes. 169 */ 170export function useSetAppState() { 171 return useAppStore().setState; 172} 173 174/** 175 * Get the store directly (for passing getState/setState to non-React code). 176 */ 177export function useAppStateStore() { 178 return useAppStore(); 179} 180const NOOP_SUBSCRIBE = () => () => {}; 181 182/** 183 * Safe version of useAppState that returns undefined if called outside of AppStateProvider. 184 * Useful for components that may be rendered in contexts where AppStateProvider isn't available. 185 */ 186export function useAppStateMaybeOutsideOfProvider(selector) { 187 const $ = _c(3); 188 const store = useContext(AppStoreContext); 189 let t0; 190 if ($[0] !== selector || $[1] !== store) { 191 t0 = () => store ? selector(store.getState()) : undefined; 192 $[0] = selector; 193 $[1] = store; 194 $[2] = t0; 195 } else { 196 t0 = $[2]; 197 } 198 return useSyncExternalStore(store ? store.subscribe : NOOP_SUBSCRIBE, t0); 199} 200//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["feature","React","useContext","useEffect","useEffectEvent","useState","useSyncExternalStore","MailboxProvider","useSettingsChange","logForDebugging","createDisabledBypassPermissionsContext","isBypassPermissionsModeDisabled","applySettingsChange","SettingSource","createStore","VoiceProvider","props","children","ReactNode","require","AppState","AppStateStore","getDefaultAppState","CompletionBoundary","IDLE_SPECULATION_STATE","SpeculationResult","SpeculationState","AppStoreContext","createContext","Props","initialState","onChangeAppState","args","newState","oldState","HasAppStateContext","AppStateProvider","t0","$","_c","hasAppStateContext","Error","t1","store","t2","toolPermissionContext","getState","isBypassPermissionsModeAvailable","setState","_temp","t3","Symbol","for","t4","source","onSettingsChange","t5","t6","prev","useAppStore","ReferenceError","useAppState","selector","state","selected","toString","get","subscribe","useSetAppState","useAppStateStore","NOOP_SUBSCRIBE","useAppStateMaybeOutsideOfProvider","undefined"],"sources":["AppState.tsx"],"sourcesContent":["import { feature } from 'bun:bundle'\nimport React, {\n  useContext,\n  useEffect,\n  useEffectEvent,\n  useState,\n  useSyncExternalStore,\n} from 'react'\nimport { MailboxProvider } from '../context/mailbox.js'\nimport { useSettingsChange } from '../hooks/useSettingsChange.js'\nimport { logForDebugging } from '../utils/debug.js'\nimport {\n  createDisabledBypassPermissionsContext,\n  isBypassPermissionsModeDisabled,\n} from '../utils/permissions/permissionSetup.js'\nimport { applySettingsChange } from '../utils/settings/applySettingsChange.js'\nimport type { SettingSource } from '../utils/settings/constants.js'\nimport { createStore } from './store.js'\n\n// DCE: voice context is ant-only. External builds get a passthrough.\n/* eslint-disable @typescript-eslint/no-require-imports */\nconst VoiceProvider: (props: { children: React.ReactNode }) => React.ReactNode =\n  feature('VOICE_MODE')\n    ? require('../context/voice.js').VoiceProvider\n    : ({ children }) => children\n\n/* eslint-enable @typescript-eslint/no-require-imports */\nimport {\n  type AppState,\n  type AppStateStore,\n  getDefaultAppState,\n} from './AppStateStore.js'\n\n// TODO: Remove these re-exports once all callers import directly from\n// ./AppStateStore.js. Kept for back-compat during migration so .ts callers\n// can incrementally move off the .tsx import and stop pulling React.\nexport {\n  type AppState,\n  type AppStateStore,\n  type CompletionBoundary,\n  getDefaultAppState,\n  IDLE_SPECULATION_STATE,\n  type SpeculationResult,\n  type SpeculationState,\n} from './AppStateStore.js'\n\nexport const AppStoreContext = React.createContext<AppStateStore | null>(null)\n\ntype Props = {\n  children: React.ReactNode\n  initialState?: AppState\n  onChangeAppState?: (args: { newState: AppState; oldState: AppState }) => void\n}\n\nconst HasAppStateContext = React.createContext<boolean>(false)\n\nexport function AppStateProvider({\n  children,\n  initialState,\n  onChangeAppState,\n}: Props): React.ReactNode {\n  // Don't allow nested AppStateProviders.\n  const hasAppStateContext = useContext(HasAppStateContext)\n  if (hasAppStateContext) {\n    throw new Error(\n      'AppStateProvider can not be nested within another AppStateProvider',\n    )\n  }\n\n  // Store is created once and never changes -- stable context value means\n  // the provider never triggers re-renders. Consumers subscribe to slices\n  // via useSyncExternalStore in useAppState(selector).\n  const [store] = useState(() =>\n    createStore<AppState>(\n      initialState ?? getDefaultAppState(),\n      onChangeAppState,\n    ),\n  )\n\n  // Check on mount if bypass mode should be disabled\n  // This handles the race condition where remote settings load BEFORE this component mounts,\n  // meaning the settings change notification was sent when no listeners were subscribed.\n  // On subsequent sessions, the cached remote-settings.json is read during initial setup,\n  // but on the first session the remote fetch may complete before React mounts.\n  useEffect(() => {\n    const { toolPermissionContext } = store.getState()\n    if (\n      toolPermissionContext.isBypassPermissionsModeAvailable &&\n      isBypassPermissionsModeDisabled()\n    ) {\n      logForDebugging(\n        'Disabling bypass permissions mode on mount (remote settings loaded before mount)',\n      )\n      store.setState(prev => ({\n        ...prev,\n        toolPermissionContext: createDisabledBypassPermissionsContext(\n          prev.toolPermissionContext,\n        ),\n      }))\n    }\n    // biome-ignore lint/correctness/useExhaustiveDependencies: intentional mount-only effect\n  }, [])\n\n  // Listen for external settings changes and sync to AppState.\n  // This ensures file watcher changes propagate through the app --\n  // shared with the headless/SDK path via applySettingsChange.\n  const onSettingsChange = useEffectEvent((source: SettingSource) =>\n    applySettingsChange(source, store.setState),\n  )\n  useSettingsChange(onSettingsChange)\n\n  return (\n    <HasAppStateContext.Provider value={true}>\n      <AppStoreContext.Provider value={store}>\n        <MailboxProvider>\n          <VoiceProvider>{children}</VoiceProvider>\n        </MailboxProvider>\n      </AppStoreContext.Provider>\n    </HasAppStateContext.Provider>\n  )\n}\n\nfunction useAppStore(): AppStateStore {\n  // eslint-disable-next-line react-hooks/rules-of-hooks\n  const store = useContext(AppStoreContext)\n  if (!store) {\n    throw new ReferenceError(\n      'useAppState/useSetAppState cannot be called outside of an <AppStateProvider />',\n    )\n  }\n  return store\n}\n\n/**\n * Subscribe to a slice of AppState. Only re-renders when the selected value\n * changes (compared via Object.is).\n *\n * For multiple independent fields, call the hook multiple times:\n * ```\n * const verbose = useAppState(s => s.verbose)\n * const model = useAppState(s => s.mainLoopModel)\n * ```\n *\n * Do NOT return new objects from the selector -- Object.is will always see\n * them as changed. Instead, select an existing sub-object reference:\n * ```\n * const { text, promptId } = useAppState(s => s.promptSuggestion) // good\n * ```\n */\nexport function useAppState<T>(selector: (state: AppState) => T): T {\n  const store = useAppStore()\n\n  const get = () => {\n    const state = store.getState()\n    const selected = selector(state)\n\n    if (\"external\" === 'ant' && state === selected) {\n      throw new Error(\n        `Your selector in \\`useAppState(${selector.toString()})\\` returned the original state, which is not allowed. You must instead return a property for optimised rendering.`,\n      )\n    }\n\n    return selected\n  }\n\n  return useSyncExternalStore(store.subscribe, get, get)\n}\n\n/**\n * Get the setAppState updater without subscribing to any state.\n * Returns a stable reference that never changes -- components using only\n * this hook will never re-render from state changes.\n */\nexport function useSetAppState(): (\n  updater: (prev: AppState) => AppState,\n) => void {\n  return useAppStore().setState\n}\n\n/**\n * Get the store directly (for passing getState/setState to non-React code).\n */\nexport function useAppStateStore(): AppStateStore {\n  return useAppStore()\n}\n\nconst NOOP_SUBSCRIBE = () => () => {}\n\n/**\n * Safe version of useAppState that returns undefined if called outside of AppStateProvider.\n * Useful for components that may be rendered in contexts where AppStateProvider isn't available.\n */\nexport function useAppStateMaybeOutsideOfProvider<T>(\n  selector: (state: AppState) => T,\n): T | undefined {\n  const store = useContext(AppStoreContext)\n  return useSyncExternalStore(store ? store.subscribe : NOOP_SUBSCRIBE, () =>\n    store ? selector(store.getState()) : undefined,\n  )\n}\n"],"mappings":"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","ignoreList":[]}