πŸ“„ File detail

components/ThinkingToggle.tsx

🧩 .tsxπŸ“ 153 linesπŸ’Ύ 18,209 bytesπŸ“ text
← Back to All Files

🎯 Use case

This file lives under β€œcomponents/”, which covers shared React UI pieces. On the API surface it exposes Props and ThinkingToggle β€” mainly types, interfaces, or factory objects. Dependencies touch React UI and src. It composes internal code from ink, keybindings, ConfigurableShortcutHint, CustomSelect, and design-system (relative imports).

Generated from folder role, exports, dependency roots, and inline comments β€” not hand-reviewed for every path.

🧠 Inline summary

import { c as _c } from "react/compiler-runtime"; import * as React from 'react'; import { useState } from 'react'; import { useExitOnCtrlCDWithKeybindings } from 'src/hooks/useExitOnCtrlCDWithKeybindings.js'; import { Box, Text } from '../ink.js';

πŸ“€ Exports (heuristic)

  • Props
  • ThinkingToggle

πŸ“š External import roots

Package roots from from "…" (relative paths omitted).

  • react
  • src

πŸ–₯️ Source preview

import { c as _c } from "react/compiler-runtime";
import * as React from 'react';
import { useState } from 'react';
import { useExitOnCtrlCDWithKeybindings } from 'src/hooks/useExitOnCtrlCDWithKeybindings.js';
import { Box, Text } from '../ink.js';
import { useKeybinding } from '../keybindings/useKeybinding.js';
import { ConfigurableShortcutHint } from './ConfigurableShortcutHint.js';
import { Select } from './CustomSelect/index.js';
import { Byline } from './design-system/Byline.js';
import { KeyboardShortcutHint } from './design-system/KeyboardShortcutHint.js';
import { Pane } from './design-system/Pane.js';
export type Props = {
  currentValue: boolean;
  onSelect: (enabled: boolean) => void;
  onCancel?: () => void;
  isMidConversation?: boolean;
};
export function ThinkingToggle(t0) {
  const $ = _c(27);
  const {
    currentValue,
    onSelect,
    onCancel,
    isMidConversation
  } = t0;
  const exitState = useExitOnCtrlCDWithKeybindings();
  const [confirmationPending, setConfirmationPending] = useState(null);
  let t1;
  if ($[0] === Symbol.for("react.memo_cache_sentinel")) {
    t1 = [{
      value: "true",
      label: "Enabled",
      description: "Claude will think before responding"
    }, {
      value: "false",
      label: "Disabled",
      description: "Claude will respond without extended thinking"
    }];
    $[0] = t1;
  } else {
    t1 = $[0];
  }
  const options = t1;
  let t2;
  if ($[1] !== confirmationPending || $[2] !== onCancel) {
    t2 = () => {
      if (confirmationPending !== null) {
        setConfirmationPending(null);
      } else {
        onCancel?.();
      }
    };
    $[1] = confirmationPending;
    $[2] = onCancel;
    $[3] = t2;
  } else {
    t2 = $[3];
  }
  let t3;
  if ($[4] === Symbol.for("react.memo_cache_sentinel")) {
    t3 = {
      context: "Confirmation"
    };
    $[4] = t3;
  } else {
    t3 = $[4];
  }
  useKeybinding("confirm:no", t2, t3);
  let t4;
  if ($[5] !== confirmationPending || $[6] !== onSelect) {
    t4 = () => {
      if (confirmationPending !== null) {
        onSelect(confirmationPending);
      }
    };
    $[5] = confirmationPending;
    $[6] = onSelect;
    $[7] = t4;
  } else {
    t4 = $[7];
  }
  const t5 = confirmationPending !== null;
  let t6;
  if ($[8] !== t5) {
    t6 = {
      context: "Confirmation",
      isActive: t5
    };
    $[8] = t5;
    $[9] = t6;
  } else {
    t6 = $[9];
  }
  useKeybinding("confirm:yes", t4, t6);
  let t7;
  if ($[10] !== currentValue || $[11] !== isMidConversation || $[12] !== onSelect) {
    t7 = function handleSelectChange(value) {
      const selected = value === "true";
      if (isMidConversation && selected !== currentValue) {
        setConfirmationPending(selected);
      } else {
        onSelect(selected);
      }
    };
    $[10] = currentValue;
    $[11] = isMidConversation;
    $[12] = onSelect;
    $[13] = t7;
  } else {
    t7 = $[13];
  }
  const handleSelectChange = t7;
  let t8;
  if ($[14] === Symbol.for("react.memo_cache_sentinel")) {
    t8 = <Box marginBottom={1} flexDirection="column"><Text color="remember" bold={true}>Toggle thinking mode</Text><Text dimColor={true}>Enable or disable thinking for this session.</Text></Box>;
    $[14] = t8;
  } else {
    t8 = $[14];
  }
  let t9;
  if ($[15] !== confirmationPending || $[16] !== currentValue || $[17] !== handleSelectChange || $[18] !== onCancel) {
    t9 = <Box flexDirection="column">{t8}{confirmationPending !== null ? <Box flexDirection="column" marginBottom={1} gap={1}><Text color="warning">Changing thinking mode mid-conversation will increase latency and may reduce quality. For best results, set this at the start of a session.</Text><Text color="warning">Do you want to proceed?</Text></Box> : <Box flexDirection="column" marginBottom={1}><Select defaultValue={currentValue ? "true" : "false"} defaultFocusValue={currentValue ? "true" : "false"} options={options} onChange={handleSelectChange} onCancel={onCancel ?? _temp} visibleOptionCount={2} /></Box>}</Box>;
    $[15] = confirmationPending;
    $[16] = currentValue;
    $[17] = handleSelectChange;
    $[18] = onCancel;
    $[19] = t9;
  } else {
    t9 = $[19];
  }
  let t10;
  if ($[20] !== confirmationPending || $[21] !== exitState.keyName || $[22] !== exitState.pending) {
    t10 = <Text dimColor={true} italic={true}>{exitState.pending ? <>Press {exitState.keyName} again to exit</> : confirmationPending !== null ? <Byline><KeyboardShortcutHint shortcut="Enter" action="confirm" /><ConfigurableShortcutHint action="confirm:no" context="Confirmation" fallback="Esc" description="cancel" /></Byline> : <Byline><KeyboardShortcutHint shortcut="Enter" action="confirm" /><ConfigurableShortcutHint action="confirm:no" context="Confirmation" fallback="Esc" description="exit" /></Byline>}</Text>;
    $[20] = confirmationPending;
    $[21] = exitState.keyName;
    $[22] = exitState.pending;
    $[23] = t10;
  } else {
    t10 = $[23];
  }
  let t11;
  if ($[24] !== t10 || $[25] !== t9) {
    t11 = <Pane color="permission">{t9}{t10}</Pane>;
    $[24] = t10;
    $[25] = t9;
    $[26] = t11;
  } else {
    t11 = $[26];
  }
  return t11;
}
function _temp() {}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useState","useExitOnCtrlCDWithKeybindings","Box","Text","useKeybinding","ConfigurableShortcutHint","Select","Byline","KeyboardShortcutHint","Pane","Props","currentValue","onSelect","enabled","onCancel","isMidConversation","ThinkingToggle","t0","$","_c","exitState","confirmationPending","setConfirmationPending","t1","Symbol","for","value","label","description","options","t2","t3","context","t4","t5","t6","isActive","t7","handleSelectChange","selected","t8","t9","_temp","t10","keyName","pending","t11"],"sources":["ThinkingToggle.tsx"],"sourcesContent":["import * as React from 'react'\nimport { useState } from 'react'\nimport { useExitOnCtrlCDWithKeybindings } from 'src/hooks/useExitOnCtrlCDWithKeybindings.js'\nimport { Box, Text } from '../ink.js'\nimport { useKeybinding } from '../keybindings/useKeybinding.js'\nimport { ConfigurableShortcutHint } from './ConfigurableShortcutHint.js'\nimport { Select } from './CustomSelect/index.js'\nimport { Byline } from './design-system/Byline.js'\nimport { KeyboardShortcutHint } from './design-system/KeyboardShortcutHint.js'\nimport { Pane } from './design-system/Pane.js'\n\nexport type Props = {\n  currentValue: boolean\n  onSelect: (enabled: boolean) => void\n  onCancel?: () => void\n  isMidConversation?: boolean\n}\n\nexport function ThinkingToggle({\n  currentValue,\n  onSelect,\n  onCancel,\n  isMidConversation,\n}: Props): React.ReactNode {\n  const exitState = useExitOnCtrlCDWithKeybindings()\n  const [confirmationPending, setConfirmationPending] = useState<\n    boolean | null\n  >(null)\n\n  const options = [\n    {\n      value: 'true',\n      label: 'Enabled',\n      description: 'Claude will think before responding',\n    },\n    {\n      value: 'false',\n      label: 'Disabled',\n      description: 'Claude will respond without extended thinking',\n    },\n  ]\n\n  // Use configurable keybinding for ESC to cancel/go back\n  useKeybinding(\n    'confirm:no',\n    () => {\n      if (confirmationPending !== null) {\n        setConfirmationPending(null)\n      } else {\n        onCancel?.()\n      }\n    },\n    { context: 'Confirmation' },\n  )\n\n  // Use configurable keybinding for Enter to confirm in confirmation mode\n  useKeybinding(\n    'confirm:yes',\n    () => {\n      if (confirmationPending !== null) {\n        onSelect(confirmationPending)\n      }\n    },\n    { context: 'Confirmation', isActive: confirmationPending !== null },\n  )\n\n  function handleSelectChange(value: string): void {\n    const selected = value === 'true'\n    if (isMidConversation && selected !== currentValue) {\n      setConfirmationPending(selected)\n    } else {\n      onSelect(selected)\n    }\n  }\n\n  return (\n    <Pane color=\"permission\">\n      <Box flexDirection=\"column\">\n        <Box marginBottom={1} flexDirection=\"column\">\n          <Text color=\"remember\" bold>\n            Toggle thinking mode\n          </Text>\n          <Text dimColor>Enable or disable thinking for this session.</Text>\n        </Box>\n\n        {confirmationPending !== null ? (\n          <Box flexDirection=\"column\" marginBottom={1} gap={1}>\n            <Text color=\"warning\">\n              Changing thinking mode mid-conversation will increase latency and\n              may reduce quality. For best results, set this at the start of a\n              session.\n            </Text>\n            <Text color=\"warning\">Do you want to proceed?</Text>\n          </Box>\n        ) : (\n          <Box flexDirection=\"column\" marginBottom={1}>\n            <Select\n              defaultValue={currentValue ? 'true' : 'false'}\n              defaultFocusValue={currentValue ? 'true' : 'false'}\n              options={options}\n              onChange={handleSelectChange}\n              onCancel={onCancel ?? (() => {})}\n              visibleOptionCount={2}\n            />\n          </Box>\n        )}\n      </Box>\n      <Text dimColor italic>\n        {exitState.pending ? (\n          <>Press {exitState.keyName} again to exit</>\n        ) : confirmationPending !== null ? (\n          <Byline>\n            <KeyboardShortcutHint shortcut=\"Enter\" action=\"confirm\" />\n            <ConfigurableShortcutHint\n              action=\"confirm:no\"\n              context=\"Confirmation\"\n              fallback=\"Esc\"\n              description=\"cancel\"\n            />\n          </Byline>\n        ) : (\n          <Byline>\n            <KeyboardShortcutHint shortcut=\"Enter\" action=\"confirm\" />\n            <ConfigurableShortcutHint\n              action=\"confirm:no\"\n              context=\"Confirmation\"\n              fallback=\"Esc\"\n              description=\"exit\"\n            />\n          </Byline>\n        )}\n      </Text>\n    </Pane>\n  )\n}\n"],"mappings":"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","ignoreList":[]}