/ commands / fast / fast.tsx
fast.tsx
  1  import { c as _c } from "react/compiler-runtime";
  2  import * as React from 'react';
  3  import { useState } from 'react';
  4  import type { CommandResultDisplay, LocalJSXCommandContext } from '../../commands.js';
  5  import { Dialog } from '../../components/design-system/Dialog.js';
  6  import { FastIcon, getFastIconString } from '../../components/FastIcon.js';
  7  import { Box, Link, Text } from '../../ink.js';
  8  import { useKeybindings } from '../../keybindings/useKeybinding.js';
  9  import { type AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS, logEvent } from '../../services/analytics/index.js';
 10  import { type AppState, useAppState, useSetAppState } from '../../state/AppState.js';
 11  import type { LocalJSXCommandOnDone } from '../../types/command.js';
 12  import { clearFastModeCooldown, FAST_MODE_MODEL_DISPLAY, getFastModeModel, getFastModeRuntimeState, getFastModeUnavailableReason, isFastModeEnabled, isFastModeSupportedByModel, prefetchFastModeStatus } from '../../utils/fastMode.js';
 13  import { formatDuration } from '../../utils/format.js';
 14  import { formatModelPricing, getOpus46CostTier } from '../../utils/modelCost.js';
 15  import { updateSettingsForSource } from '../../utils/settings/settings.js';
 16  function applyFastMode(enable: boolean, setAppState: (f: (prev: AppState) => AppState) => void): void {
 17    clearFastModeCooldown();
 18    updateSettingsForSource('userSettings', {
 19      fastMode: enable ? true : undefined
 20    });
 21    if (enable) {
 22      setAppState(prev => {
 23        // Only switch model if current model doesn't support fast mode
 24        const needsModelSwitch = !isFastModeSupportedByModel(prev.mainLoopModel);
 25        return {
 26          ...prev,
 27          ...(needsModelSwitch ? {
 28            mainLoopModel: getFastModeModel(),
 29            mainLoopModelForSession: null
 30          } : {}),
 31          fastMode: true
 32        };
 33      });
 34    } else {
 35      setAppState(prev => ({
 36        ...prev,
 37        fastMode: false
 38      }));
 39    }
 40  }
 41  export function FastModePicker(t0) {
 42    const $ = _c(30);
 43    const {
 44      onDone,
 45      unavailableReason
 46    } = t0;
 47    const model = useAppState(_temp);
 48    const initialFastMode = useAppState(_temp2);
 49    const setAppState = useSetAppState();
 50    const [enableFastMode, setEnableFastMode] = useState(initialFastMode ?? false);
 51    let t1;
 52    if ($[0] === Symbol.for("react.memo_cache_sentinel")) {
 53      t1 = getFastModeRuntimeState();
 54      $[0] = t1;
 55    } else {
 56      t1 = $[0];
 57    }
 58    const runtimeState = t1;
 59    const isCooldown = runtimeState.status === "cooldown";
 60    const isUnavailable = unavailableReason !== null;
 61    let t2;
 62    if ($[1] === Symbol.for("react.memo_cache_sentinel")) {
 63      t2 = formatModelPricing(getOpus46CostTier(true));
 64      $[1] = t2;
 65    } else {
 66      t2 = $[1];
 67    }
 68    const pricing = t2;
 69    let t3;
 70    if ($[2] !== enableFastMode || $[3] !== isUnavailable || $[4] !== model || $[5] !== onDone || $[6] !== setAppState) {
 71      t3 = function handleConfirm() {
 72        if (isUnavailable) {
 73          return;
 74        }
 75        applyFastMode(enableFastMode, setAppState);
 76        logEvent("tengu_fast_mode_toggled", {
 77          enabled: enableFastMode,
 78          source: "picker" as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS
 79        });
 80        if (enableFastMode) {
 81          const fastIcon = getFastIconString(enableFastMode);
 82          const modelUpdated = !isFastModeSupportedByModel(model) ? ` · model set to ${FAST_MODE_MODEL_DISPLAY}` : "";
 83          onDone(`${fastIcon} Fast mode ON${modelUpdated} · ${pricing}`);
 84        } else {
 85          setAppState(_temp3);
 86          onDone("Fast mode OFF");
 87        }
 88      };
 89      $[2] = enableFastMode;
 90      $[3] = isUnavailable;
 91      $[4] = model;
 92      $[5] = onDone;
 93      $[6] = setAppState;
 94      $[7] = t3;
 95    } else {
 96      t3 = $[7];
 97    }
 98    const handleConfirm = t3;
 99    let t4;
100    if ($[8] !== initialFastMode || $[9] !== isUnavailable || $[10] !== onDone || $[11] !== setAppState) {
101      t4 = function handleCancel() {
102        if (isUnavailable) {
103          if (initialFastMode) {
104            applyFastMode(false, setAppState);
105          }
106          onDone("Fast mode OFF", {
107            display: "system"
108          });
109          return;
110        }
111        const message = initialFastMode ? `${getFastIconString()} Kept Fast mode ON` : "Kept Fast mode OFF";
112        onDone(message, {
113          display: "system"
114        });
115      };
116      $[8] = initialFastMode;
117      $[9] = isUnavailable;
118      $[10] = onDone;
119      $[11] = setAppState;
120      $[12] = t4;
121    } else {
122      t4 = $[12];
123    }
124    const handleCancel = t4;
125    let t5;
126    if ($[13] !== isUnavailable) {
127      t5 = function handleToggle() {
128        if (isUnavailable) {
129          return;
130        }
131        setEnableFastMode(_temp4);
132      };
133      $[13] = isUnavailable;
134      $[14] = t5;
135    } else {
136      t5 = $[14];
137    }
138    const handleToggle = t5;
139    let t6;
140    if ($[15] !== handleConfirm || $[16] !== handleToggle) {
141      t6 = {
142        "confirm:yes": handleConfirm,
143        "confirm:nextField": handleToggle,
144        "confirm:next": handleToggle,
145        "confirm:previous": handleToggle,
146        "confirm:cycleMode": handleToggle,
147        "confirm:toggle": handleToggle
148      };
149      $[15] = handleConfirm;
150      $[16] = handleToggle;
151      $[17] = t6;
152    } else {
153      t6 = $[17];
154    }
155    let t7;
156    if ($[18] === Symbol.for("react.memo_cache_sentinel")) {
157      t7 = {
158        context: "Confirmation"
159      };
160      $[18] = t7;
161    } else {
162      t7 = $[18];
163    }
164    useKeybindings(t6, t7);
165    let t8;
166    if ($[19] === Symbol.for("react.memo_cache_sentinel")) {
167      t8 = <Text><FastIcon cooldown={isCooldown} /> Fast mode (research preview)</Text>;
168      $[19] = t8;
169    } else {
170      t8 = $[19];
171    }
172    const title = t8;
173    let t9;
174    if ($[20] !== isUnavailable) {
175      t9 = exitState => exitState.pending ? <Text>Press {exitState.keyName} again to exit</Text> : isUnavailable ? <Text>Esc to cancel</Text> : <Text>Tab to toggle · Enter to confirm · Esc to cancel</Text>;
176      $[20] = isUnavailable;
177      $[21] = t9;
178    } else {
179      t9 = $[21];
180    }
181    let t10;
182    if ($[22] !== enableFastMode || $[23] !== unavailableReason) {
183      t10 = unavailableReason ? <Box marginLeft={2}><Text color="error">{unavailableReason}</Text></Box> : <><Box flexDirection="column" gap={0} marginLeft={2}><Box flexDirection="row" gap={2}><Text bold={true}>Fast mode</Text><Text color={enableFastMode ? "fastMode" : undefined} bold={enableFastMode}>{enableFastMode ? "ON " : "OFF"}</Text><Text dimColor={true}>{pricing}</Text></Box></Box>{isCooldown && runtimeState.status === "cooldown" && <Box marginLeft={2}><Text color="warning">{runtimeState.reason === "overloaded" ? "Fast mode overloaded and is temporarily unavailable" : "You've hit your fast limit"}{" \xB7 resets in "}{formatDuration(runtimeState.resetAt - Date.now(), {
184              hideTrailingZeros: true
185            })}</Text></Box>}</>;
186      $[22] = enableFastMode;
187      $[23] = unavailableReason;
188      $[24] = t10;
189    } else {
190      t10 = $[24];
191    }
192    let t11;
193    if ($[25] === Symbol.for("react.memo_cache_sentinel")) {
194      t11 = <Text dimColor={true}>Learn more:{" "}<Link url="https://code.claude.com/docs/en/fast-mode">https://code.claude.com/docs/en/fast-mode</Link></Text>;
195      $[25] = t11;
196    } else {
197      t11 = $[25];
198    }
199    let t12;
200    if ($[26] !== handleCancel || $[27] !== t10 || $[28] !== t9) {
201      t12 = <Dialog title={title} subtitle={`High-speed mode for ${FAST_MODE_MODEL_DISPLAY}. Billed as extra usage at a premium rate. Separate rate limits apply.`} onCancel={handleCancel} color="fastMode" inputGuide={t9}>{t10}{t11}</Dialog>;
202      $[26] = handleCancel;
203      $[27] = t10;
204      $[28] = t9;
205      $[29] = t12;
206    } else {
207      t12 = $[29];
208    }
209    return t12;
210  }
211  function _temp4(prev_0) {
212    return !prev_0;
213  }
214  function _temp3(prev) {
215    return {
216      ...prev,
217      fastMode: false
218    };
219  }
220  function _temp2(s_0) {
221    return s_0.fastMode;
222  }
223  function _temp(s) {
224    return s.mainLoopModel;
225  }
226  async function handleFastModeShortcut(enable: boolean, getAppState: () => AppState, setAppState: (f: (prev: AppState) => AppState) => void): Promise<string> {
227    const unavailableReason = getFastModeUnavailableReason();
228    if (unavailableReason) {
229      return `Fast mode unavailable: ${unavailableReason}`;
230    }
231    const {
232      mainLoopModel
233    } = getAppState();
234    applyFastMode(enable, setAppState);
235    logEvent('tengu_fast_mode_toggled', {
236      enabled: enable,
237      source: 'shortcut' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS
238    });
239    if (enable) {
240      const fastIcon = getFastIconString(true);
241      const modelUpdated = !isFastModeSupportedByModel(mainLoopModel) ? ` · model set to ${FAST_MODE_MODEL_DISPLAY}` : '';
242      const pricing = formatModelPricing(getOpus46CostTier(true));
243      return `${fastIcon} Fast mode ON${modelUpdated} · ${pricing}`;
244    } else {
245      return `Fast mode OFF`;
246    }
247  }
248  export async function call(onDone: LocalJSXCommandOnDone, context: LocalJSXCommandContext, args?: string): Promise<React.ReactNode | null> {
249    if (!isFastModeEnabled()) {
250      return null;
251    }
252  
253    // Fetch org fast mode status before showing the picker. We must know
254    // whether the org has disabled fast mode before allowing any toggle.
255    // If a startup prefetch is already in flight, this awaits it.
256    await prefetchFastModeStatus();
257    const arg = args?.trim().toLowerCase();
258    if (arg === 'on' || arg === 'off') {
259      const result = await handleFastModeShortcut(arg === 'on', context.getAppState, context.setAppState);
260      onDone(result);
261      return null;
262    }
263    const unavailableReason = getFastModeUnavailableReason();
264    logEvent('tengu_fast_mode_picker_shown', {
265      unavailable_reason: (unavailableReason ?? '') as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS
266    });
267    return <FastModePicker onDone={onDone} unavailableReason={unavailableReason} />;
268  }
269  //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useState","CommandResultDisplay","LocalJSXCommandContext","Dialog","FastIcon","getFastIconString","Box","Link","Text","useKeybindings","AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS","logEvent","AppState","useAppState","useSetAppState","LocalJSXCommandOnDone","clearFastModeCooldown","FAST_MODE_MODEL_DISPLAY","getFastModeModel","getFastModeRuntimeState","getFastModeUnavailableReason","isFastModeEnabled","isFastModeSupportedByModel","prefetchFastModeStatus","formatDuration","formatModelPricing","getOpus46CostTier","updateSettingsForSource","applyFastMode","enable","setAppState","f","prev","fastMode","undefined","needsModelSwitch","mainLoopModel","mainLoopModelForSession","FastModePicker","t0","$","_c","onDone","unavailableReason","model","_temp","initialFastMode","_temp2","enableFastMode","setEnableFastMode","t1","Symbol","for","runtimeState","isCooldown","status","isUnavailable","t2","pricing","t3","handleConfirm","enabled","source","fastIcon","modelUpdated","_temp3","t4","handleCancel","display","message","t5","handleToggle","_temp4","t6","t7","context","t8","title","t9","exitState","pending","keyName","t10","reason","resetAt","Date","now","hideTrailingZeros","t11","t12","prev_0","s_0","s","handleFastModeShortcut","getAppState","Promise","call","args","ReactNode","arg","trim","toLowerCase","result","unavailable_reason"],"sources":["fast.tsx"],"sourcesContent":["import * as React from 'react'\nimport { useState } from 'react'\nimport type {\n  CommandResultDisplay,\n  LocalJSXCommandContext,\n} from '../../commands.js'\nimport { Dialog } from '../../components/design-system/Dialog.js'\nimport { FastIcon, getFastIconString } from '../../components/FastIcon.js'\nimport { Box, Link, Text } from '../../ink.js'\nimport { useKeybindings } from '../../keybindings/useKeybinding.js'\nimport {\n  type AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n  logEvent,\n} from '../../services/analytics/index.js'\nimport {\n  type AppState,\n  useAppState,\n  useSetAppState,\n} from '../../state/AppState.js'\nimport type { LocalJSXCommandOnDone } from '../../types/command.js'\nimport {\n  clearFastModeCooldown,\n  FAST_MODE_MODEL_DISPLAY,\n  getFastModeModel,\n  getFastModeRuntimeState,\n  getFastModeUnavailableReason,\n  isFastModeEnabled,\n  isFastModeSupportedByModel,\n  prefetchFastModeStatus,\n} from '../../utils/fastMode.js'\nimport { formatDuration } from '../../utils/format.js'\nimport { formatModelPricing, getOpus46CostTier } from '../../utils/modelCost.js'\nimport { updateSettingsForSource } from '../../utils/settings/settings.js'\n\nfunction applyFastMode(\n  enable: boolean,\n  setAppState: (f: (prev: AppState) => AppState) => void,\n): void {\n  clearFastModeCooldown()\n  updateSettingsForSource('userSettings', {\n    fastMode: enable ? true : undefined,\n  })\n  if (enable) {\n    setAppState(prev => {\n      // Only switch model if current model doesn't support fast mode\n      const needsModelSwitch = !isFastModeSupportedByModel(prev.mainLoopModel)\n      return {\n        ...prev,\n        ...(needsModelSwitch\n          ? { mainLoopModel: getFastModeModel(), mainLoopModelForSession: null }\n          : {}),\n        fastMode: true,\n      }\n    })\n  } else {\n    setAppState(prev => ({ ...prev, fastMode: false }))\n  }\n}\n\nexport function FastModePicker({\n  onDone,\n  unavailableReason,\n}: {\n  onDone: (\n    result?: string,\n    options?: { display?: CommandResultDisplay },\n  ) => void\n  unavailableReason: string | null\n}): React.ReactNode {\n  const model = useAppState(s => s.mainLoopModel)\n  const initialFastMode = useAppState(s => s.fastMode)\n  const setAppState = useSetAppState()\n  const [enableFastMode, setEnableFastMode] = useState(initialFastMode ?? false)\n  const runtimeState = getFastModeRuntimeState()\n  const isCooldown = runtimeState.status === 'cooldown'\n  const isUnavailable = unavailableReason !== null\n  const pricing = formatModelPricing(getOpus46CostTier(true))\n\n  function handleConfirm(): void {\n    if (isUnavailable) return\n    applyFastMode(enableFastMode, setAppState)\n    logEvent('tengu_fast_mode_toggled', {\n      enabled: enableFastMode,\n      source:\n        'picker' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n    })\n    if (enableFastMode) {\n      const fastIcon = getFastIconString(enableFastMode)\n      const modelUpdated = !isFastModeSupportedByModel(model)\n        ? ` · model set to ${FAST_MODE_MODEL_DISPLAY}`\n        : ''\n      onDone(`${fastIcon} Fast mode ON${modelUpdated} · ${pricing}`)\n    } else {\n      setAppState(prev => ({ ...prev, fastMode: false }))\n      onDone(`Fast mode OFF`)\n    }\n  }\n\n  function handleCancel(): void {\n    if (isUnavailable) {\n      // Ensure fast mode is off if the org has disabled it\n      if (initialFastMode) {\n        applyFastMode(false, setAppState)\n      }\n      onDone('Fast mode OFF', { display: 'system' })\n      return\n    }\n    const message = initialFastMode\n      ? `${getFastIconString()} Kept Fast mode ON`\n      : `Kept Fast mode OFF`\n    onDone(message, { display: 'system' })\n  }\n\n  function handleToggle(): void {\n    if (isUnavailable) return\n    setEnableFastMode(prev => !prev)\n  }\n\n  useKeybindings(\n    {\n      'confirm:yes': handleConfirm,\n      'confirm:nextField': handleToggle,\n      'confirm:next': handleToggle,\n      'confirm:previous': handleToggle,\n      'confirm:cycleMode': handleToggle,\n      'confirm:toggle': handleToggle,\n    },\n    { context: 'Confirmation' },\n  )\n\n  const title = (\n    <Text>\n      <FastIcon cooldown={isCooldown} /> Fast mode (research preview)\n    </Text>\n  )\n\n  return (\n    <Dialog\n      title={title}\n      subtitle={`High-speed mode for ${FAST_MODE_MODEL_DISPLAY}. Billed as extra usage at a premium rate. Separate rate limits apply.`}\n      onCancel={handleCancel}\n      color=\"fastMode\"\n      inputGuide={exitState =>\n        exitState.pending ? (\n          <Text>Press {exitState.keyName} again to exit</Text>\n        ) : isUnavailable ? (\n          <Text>Esc to cancel</Text>\n        ) : (\n          <Text>Tab to toggle · Enter to confirm · Esc to cancel</Text>\n        )\n      }\n    >\n      {unavailableReason ? (\n        <Box marginLeft={2}>\n          <Text color=\"error\">{unavailableReason}</Text>\n        </Box>\n      ) : (\n        <>\n          <Box flexDirection=\"column\" gap={0} marginLeft={2}>\n            <Box flexDirection=\"row\" gap={2}>\n              <Text bold>Fast mode</Text>\n              <Text\n                color={enableFastMode ? 'fastMode' : undefined}\n                bold={enableFastMode}\n              >\n                {enableFastMode ? 'ON ' : 'OFF'}\n              </Text>\n              <Text dimColor>{pricing}</Text>\n            </Box>\n          </Box>\n\n          {isCooldown && runtimeState.status === 'cooldown' && (\n            <Box marginLeft={2}>\n              <Text color=\"warning\">\n                {runtimeState.reason === 'overloaded'\n                  ? 'Fast mode overloaded and is temporarily unavailable'\n                  : \"You've hit your fast limit\"}\n                {' · resets in '}\n                {formatDuration(runtimeState.resetAt - Date.now(), {\n                  hideTrailingZeros: true,\n                })}\n              </Text>\n            </Box>\n          )}\n        </>\n      )}\n      <Text dimColor>\n        Learn more:{' '}\n        <Link url=\"https://code.claude.com/docs/en/fast-mode\">\n          https://code.claude.com/docs/en/fast-mode\n        </Link>\n      </Text>\n    </Dialog>\n  )\n}\n\nasync function handleFastModeShortcut(\n  enable: boolean,\n  getAppState: () => AppState,\n  setAppState: (f: (prev: AppState) => AppState) => void,\n): Promise<string> {\n  const unavailableReason = getFastModeUnavailableReason()\n  if (unavailableReason) {\n    return `Fast mode unavailable: ${unavailableReason}`\n  }\n\n  const { mainLoopModel } = getAppState()\n  applyFastMode(enable, setAppState)\n  logEvent('tengu_fast_mode_toggled', {\n    enabled: enable,\n    source:\n      'shortcut' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n  })\n\n  if (enable) {\n    const fastIcon = getFastIconString(true)\n    const modelUpdated = !isFastModeSupportedByModel(mainLoopModel)\n      ? ` · model set to ${FAST_MODE_MODEL_DISPLAY}`\n      : ''\n    const pricing = formatModelPricing(getOpus46CostTier(true))\n    return `${fastIcon} Fast mode ON${modelUpdated} · ${pricing}`\n  } else {\n    return `Fast mode OFF`\n  }\n}\n\nexport async function call(\n  onDone: LocalJSXCommandOnDone,\n  context: LocalJSXCommandContext,\n  args?: string,\n): Promise<React.ReactNode | null> {\n  if (!isFastModeEnabled()) {\n    return null\n  }\n\n  // Fetch org fast mode status before showing the picker. We must know\n  // whether the org has disabled fast mode before allowing any toggle.\n  // If a startup prefetch is already in flight, this awaits it.\n  await prefetchFastModeStatus()\n\n  const arg = args?.trim().toLowerCase()\n  if (arg === 'on' || arg === 'off') {\n    const result = await handleFastModeShortcut(\n      arg === 'on',\n      context.getAppState,\n      context.setAppState,\n    )\n    onDone(result)\n    return null\n  }\n\n  const unavailableReason = getFastModeUnavailableReason()\n  logEvent('tengu_fast_mode_picker_shown', {\n    unavailable_reason: (unavailableReason ??\n      '') as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n  })\n  return (\n    <FastModePicker onDone={onDone} unavailableReason={unavailableReason} />\n  )\n}\n"],"mappings":"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","ignoreList":[]}