πŸ“„ File detail

components/ThemePicker.tsx

🧩 .tsxπŸ“ 333 linesπŸ’Ύ 35,662 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 ThemePickerProps and ThemePicker β€” mainly types, interfaces, or factory objects. Dependencies touch React UI and bun:bundle. It composes internal code from hooks, ink, keybindings, state, and utils (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 { feature } from 'bun:bundle'; import * as React from 'react'; import { useExitOnCtrlCDWithKeybindings } from '../hooks/useExitOnCtrlCDWithKeybindings.js'; import { useTerminalSize } from '../hooks/useTerminalSize.js';

πŸ“€ Exports (heuristic)

  • ThemePickerProps
  • ThemePicker

πŸ“š External import roots

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

  • react
  • bun:bundle

πŸ–₯️ Source preview

import { c as _c } from "react/compiler-runtime";
import { feature } from 'bun:bundle';
import * as React from 'react';
import { useExitOnCtrlCDWithKeybindings } from '../hooks/useExitOnCtrlCDWithKeybindings.js';
import { useTerminalSize } from '../hooks/useTerminalSize.js';
import { Box, Text, usePreviewTheme, useTheme, useThemeSetting } from '../ink.js';
import { useRegisterKeybindingContext } from '../keybindings/KeybindingContext.js';
import { useKeybinding } from '../keybindings/useKeybinding.js';
import { useShortcutDisplay } from '../keybindings/useShortcutDisplay.js';
import { useAppState, useSetAppState } from '../state/AppState.js';
import { gracefulShutdown } from '../utils/gracefulShutdown.js';
import { updateSettingsForSource } from '../utils/settings/settings.js';
import type { ThemeSetting } from '../utils/theme.js';
import { Select } from './CustomSelect/index.js';
import { Byline } from './design-system/Byline.js';
import { KeyboardShortcutHint } from './design-system/KeyboardShortcutHint.js';
import { getColorModuleUnavailableReason, getSyntaxTheme } from './StructuredDiff/colorDiff.js';
import { StructuredDiff } from './StructuredDiff.js';
export type ThemePickerProps = {
  onThemeSelect: (setting: ThemeSetting) => void;
  showIntroText?: boolean;
  helpText?: string;
  showHelpTextBelow?: boolean;
  hideEscToCancel?: boolean;
  /** Skip exit handling when running in a context that already has it (e.g., onboarding) */
  skipExitHandling?: boolean;
  /** Called when the user cancels (presses Escape). If skipExitHandling is true and this is provided, it will be called instead of just saving the preview. */
  onCancel?: () => void;
};
export function ThemePicker(t0) {
  const $ = _c(59);
  const {
    onThemeSelect,
    showIntroText: t1,
    helpText: t2,
    showHelpTextBelow: t3,
    hideEscToCancel: t4,
    skipExitHandling: t5,
    onCancel: onCancelProp
  } = t0;
  const showIntroText = t1 === undefined ? false : t1;
  const helpText = t2 === undefined ? "" : t2;
  const showHelpTextBelow = t3 === undefined ? false : t3;
  const hideEscToCancel = t4 === undefined ? false : t4;
  const skipExitHandling = t5 === undefined ? false : t5;
  const [theme] = useTheme();
  const themeSetting = useThemeSetting();
  const {
    columns
  } = useTerminalSize();
  let t6;
  if ($[0] === Symbol.for("react.memo_cache_sentinel")) {
    t6 = getColorModuleUnavailableReason();
    $[0] = t6;
  } else {
    t6 = $[0];
  }
  const colorModuleUnavailableReason = t6;
  let t7;
  if ($[1] !== theme) {
    t7 = colorModuleUnavailableReason === null ? getSyntaxTheme(theme) : null;
    $[1] = theme;
    $[2] = t7;
  } else {
    t7 = $[2];
  }
  const syntaxTheme = t7;
  const {
    setPreviewTheme,
    savePreview,
    cancelPreview
  } = usePreviewTheme();
  const syntaxHighlightingDisabled = useAppState(_temp) ?? false;
  const setAppState = useSetAppState();
  useRegisterKeybindingContext("ThemePicker");
  const syntaxToggleShortcut = useShortcutDisplay("theme:toggleSyntaxHighlighting", "ThemePicker", "ctrl+t");
  let t8;
  if ($[3] !== setAppState || $[4] !== syntaxHighlightingDisabled) {
    t8 = () => {
      if (colorModuleUnavailableReason === null) {
        const newValue = !syntaxHighlightingDisabled;
        updateSettingsForSource("userSettings", {
          syntaxHighlightingDisabled: newValue
        });
        setAppState(prev => ({
          ...prev,
          settings: {
            ...prev.settings,
            syntaxHighlightingDisabled: newValue
          }
        }));
      }
    };
    $[3] = setAppState;
    $[4] = syntaxHighlightingDisabled;
    $[5] = t8;
  } else {
    t8 = $[5];
  }
  let t9;
  if ($[6] === Symbol.for("react.memo_cache_sentinel")) {
    t9 = {
      context: "ThemePicker"
    };
    $[6] = t9;
  } else {
    t9 = $[6];
  }
  useKeybinding("theme:toggleSyntaxHighlighting", t8, t9);
  const exitState = useExitOnCtrlCDWithKeybindings(skipExitHandling ? _temp2 : undefined);
  let t10;
  if ($[7] === Symbol.for("react.memo_cache_sentinel")) {
    t10 = [...(feature("AUTO_THEME") ? [{
      label: "Auto (match terminal)",
      value: "auto" as const
    }] : []), {
      label: "Dark mode",
      value: "dark"
    }, {
      label: "Light mode",
      value: "light"
    }, {
      label: "Dark mode (colorblind-friendly)",
      value: "dark-daltonized"
    }, {
      label: "Light mode (colorblind-friendly)",
      value: "light-daltonized"
    }, {
      label: "Dark mode (ANSI colors only)",
      value: "dark-ansi"
    }, {
      label: "Light mode (ANSI colors only)",
      value: "light-ansi"
    }];
    $[7] = t10;
  } else {
    t10 = $[7];
  }
  const themeOptions = t10;
  let t11;
  if ($[8] !== showIntroText) {
    t11 = showIntroText ? <Text>Let's get started.</Text> : <Text bold={true} color="permission">Theme</Text>;
    $[8] = showIntroText;
    $[9] = t11;
  } else {
    t11 = $[9];
  }
  let t12;
  if ($[10] === Symbol.for("react.memo_cache_sentinel")) {
    t12 = <Text bold={true}>Choose the text style that looks best with your terminal</Text>;
    $[10] = t12;
  } else {
    t12 = $[10];
  }
  let t13;
  if ($[11] !== helpText || $[12] !== showHelpTextBelow) {
    t13 = helpText && !showHelpTextBelow && <Text dimColor={true}>{helpText}</Text>;
    $[11] = helpText;
    $[12] = showHelpTextBelow;
    $[13] = t13;
  } else {
    t13 = $[13];
  }
  let t14;
  if ($[14] !== t13) {
    t14 = <Box flexDirection="column">{t12}{t13}</Box>;
    $[14] = t13;
    $[15] = t14;
  } else {
    t14 = $[15];
  }
  let t15;
  if ($[16] !== setPreviewTheme) {
    t15 = setting => {
      setPreviewTheme(setting as ThemeSetting);
    };
    $[16] = setPreviewTheme;
    $[17] = t15;
  } else {
    t15 = $[17];
  }
  let t16;
  if ($[18] !== onThemeSelect || $[19] !== savePreview) {
    t16 = setting_0 => {
      savePreview();
      onThemeSelect(setting_0 as ThemeSetting);
    };
    $[18] = onThemeSelect;
    $[19] = savePreview;
    $[20] = t16;
  } else {
    t16 = $[20];
  }
  let t17;
  if ($[21] !== cancelPreview || $[22] !== onCancelProp || $[23] !== skipExitHandling) {
    t17 = skipExitHandling ? () => {
      cancelPreview();
      onCancelProp?.();
    } : async () => {
      cancelPreview();
      await gracefulShutdown(0);
    };
    $[21] = cancelPreview;
    $[22] = onCancelProp;
    $[23] = skipExitHandling;
    $[24] = t17;
  } else {
    t17 = $[24];
  }
  let t18;
  if ($[25] !== t15 || $[26] !== t16 || $[27] !== t17 || $[28] !== themeSetting) {
    t18 = <Select options={themeOptions} onFocus={t15} onChange={t16} onCancel={t17} visibleOptionCount={themeOptions.length} defaultValue={themeSetting} defaultFocusValue={themeSetting} />;
    $[25] = t15;
    $[26] = t16;
    $[27] = t17;
    $[28] = themeSetting;
    $[29] = t18;
  } else {
    t18 = $[29];
  }
  let t19;
  if ($[30] !== t11 || $[31] !== t14 || $[32] !== t18) {
    t19 = <Box flexDirection="column" gap={1}>{t11}{t14}{t18}</Box>;
    $[30] = t11;
    $[31] = t14;
    $[32] = t18;
    $[33] = t19;
  } else {
    t19 = $[33];
  }
  let t20;
  if ($[34] === Symbol.for("react.memo_cache_sentinel")) {
    t20 = {
      oldStart: 1,
      newStart: 1,
      oldLines: 3,
      newLines: 3,
      lines: [" function greet() {", "-  console.log(\"Hello, World!\");", "+  console.log(\"Hello, Claude!\");", " }"]
    };
    $[34] = t20;
  } else {
    t20 = $[34];
  }
  let t21;
  if ($[35] !== columns) {
    t21 = <Box flexDirection="column" borderTop={true} borderBottom={true} borderLeft={false} borderRight={false} borderStyle="dashed" borderColor="subtle"><StructuredDiff patch={t20} dim={false} filePath="demo.js" firstLine={null} width={columns} /></Box>;
    $[35] = columns;
    $[36] = t21;
  } else {
    t21 = $[36];
  }
  const t22 = colorModuleUnavailableReason === "env" ? `Syntax highlighting disabled (via CLAUDE_CODE_SYNTAX_HIGHLIGHT=${process.env.CLAUDE_CODE_SYNTAX_HIGHLIGHT})` : syntaxHighlightingDisabled ? `Syntax highlighting disabled (${syntaxToggleShortcut} to enable)` : syntaxTheme ? `Syntax theme: ${syntaxTheme.theme}${syntaxTheme.source ? ` (from ${syntaxTheme.source})` : ""} (${syntaxToggleShortcut} to disable)` : `Syntax highlighting enabled (${syntaxToggleShortcut} to disable)`;
  let t23;
  if ($[37] !== t22) {
    t23 = <Text dimColor={true}>{" "}{t22}</Text>;
    $[37] = t22;
    $[38] = t23;
  } else {
    t23 = $[38];
  }
  let t24;
  if ($[39] !== t21 || $[40] !== t23) {
    t24 = <Box flexDirection="column" width="100%">{t21}{t23}</Box>;
    $[39] = t21;
    $[40] = t23;
    $[41] = t24;
  } else {
    t24 = $[41];
  }
  let t25;
  if ($[42] !== t19 || $[43] !== t24) {
    t25 = <Box flexDirection="column" gap={1}>{t19}{t24}</Box>;
    $[42] = t19;
    $[43] = t24;
    $[44] = t25;
  } else {
    t25 = $[44];
  }
  const content = t25;
  if (!showIntroText) {
    let t26;
    if ($[45] !== content) {
      t26 = <Box flexDirection="column">{content}</Box>;
      $[45] = content;
      $[46] = t26;
    } else {
      t26 = $[46];
    }
    let t27;
    if ($[47] !== helpText || $[48] !== showHelpTextBelow) {
      t27 = showHelpTextBelow && helpText && <Box marginLeft={3}><Text dimColor={true}>{helpText}</Text></Box>;
      $[47] = helpText;
      $[48] = showHelpTextBelow;
      $[49] = t27;
    } else {
      t27 = $[49];
    }
    let t28;
    if ($[50] !== exitState || $[51] !== hideEscToCancel) {
      t28 = !hideEscToCancel && <Box><Text dimColor={true} italic={true}>{exitState.pending ? <>Press {exitState.keyName} again to exit</> : <Byline><KeyboardShortcutHint shortcut="Enter" action="select" /><KeyboardShortcutHint shortcut="Esc" action="cancel" /></Byline>}</Text></Box>;
      $[50] = exitState;
      $[51] = hideEscToCancel;
      $[52] = t28;
    } else {
      t28 = $[52];
    }
    let t29;
    if ($[53] !== t27 || $[54] !== t28) {
      t29 = <Box marginTop={1}>{t27}{t28}</Box>;
      $[53] = t27;
      $[54] = t28;
      $[55] = t29;
    } else {
      t29 = $[55];
    }
    let t30;
    if ($[56] !== t26 || $[57] !== t29) {
      t30 = <>{t26}{t29}</>;
      $[56] = t26;
      $[57] = t29;
      $[58] = t30;
    } else {
      t30 = $[58];
    }
    return t30;
  }
  return content;
}
function _temp2() {}
function _temp(s) {
  return s.settings.syntaxHighlightingDisabled;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["feature","React","useExitOnCtrlCDWithKeybindings","useTerminalSize","Box","Text","usePreviewTheme","useTheme","useThemeSetting","useRegisterKeybindingContext","useKeybinding","useShortcutDisplay","useAppState","useSetAppState","gracefulShutdown","updateSettingsForSource","ThemeSetting","Select","Byline","KeyboardShortcutHint","getColorModuleUnavailableReason","getSyntaxTheme","StructuredDiff","ThemePickerProps","onThemeSelect","setting","showIntroText","helpText","showHelpTextBelow","hideEscToCancel","skipExitHandling","onCancel","ThemePicker","t0","$","_c","t1","t2","t3","t4","t5","onCancelProp","undefined","theme","themeSetting","columns","t6","Symbol","for","colorModuleUnavailableReason","t7","syntaxTheme","setPreviewTheme","savePreview","cancelPreview","syntaxHighlightingDisabled","_temp","setAppState","syntaxToggleShortcut","t8","newValue","prev","settings","t9","context","exitState","_temp2","t10","label","value","const","themeOptions","t11","t12","t13","t14","t15","t16","setting_0","t17","t18","length","t19","t20","oldStart","newStart","oldLines","newLines","lines","t21","t22","process","env","CLAUDE_CODE_SYNTAX_HIGHLIGHT","source","t23","t24","t25","content","t26","t27","t28","pending","keyName","t29","t30","s"],"sources":["ThemePicker.tsx"],"sourcesContent":["import { feature } from 'bun:bundle'\nimport * as React from 'react'\nimport { useExitOnCtrlCDWithKeybindings } from '../hooks/useExitOnCtrlCDWithKeybindings.js'\nimport { useTerminalSize } from '../hooks/useTerminalSize.js'\nimport {\n  Box,\n  Text,\n  usePreviewTheme,\n  useTheme,\n  useThemeSetting,\n} from '../ink.js'\nimport { useRegisterKeybindingContext } from '../keybindings/KeybindingContext.js'\nimport { useKeybinding } from '../keybindings/useKeybinding.js'\nimport { useShortcutDisplay } from '../keybindings/useShortcutDisplay.js'\nimport { useAppState, useSetAppState } from '../state/AppState.js'\nimport { gracefulShutdown } from '../utils/gracefulShutdown.js'\nimport { updateSettingsForSource } from '../utils/settings/settings.js'\nimport type { ThemeSetting } from '../utils/theme.js'\nimport { Select } from './CustomSelect/index.js'\nimport { Byline } from './design-system/Byline.js'\nimport { KeyboardShortcutHint } from './design-system/KeyboardShortcutHint.js'\nimport {\n  getColorModuleUnavailableReason,\n  getSyntaxTheme,\n} from './StructuredDiff/colorDiff.js'\nimport { StructuredDiff } from './StructuredDiff.js'\n\nexport type ThemePickerProps = {\n  onThemeSelect: (setting: ThemeSetting) => void\n  showIntroText?: boolean\n  helpText?: string\n  showHelpTextBelow?: boolean\n  hideEscToCancel?: boolean\n  /** Skip exit handling when running in a context that already has it (e.g., onboarding) */\n  skipExitHandling?: boolean\n  /** Called when the user cancels (presses Escape). If skipExitHandling is true and this is provided, it will be called instead of just saving the preview. */\n  onCancel?: () => void\n}\n\nexport function ThemePicker({\n  onThemeSelect,\n  showIntroText = false,\n  helpText = '',\n  showHelpTextBelow = false,\n  hideEscToCancel = false,\n  skipExitHandling = false,\n  onCancel: onCancelProp,\n}: ThemePickerProps): React.ReactNode {\n  const [theme] = useTheme()\n  const themeSetting = useThemeSetting()\n  const { columns } = useTerminalSize()\n  const colorModuleUnavailableReason = getColorModuleUnavailableReason()\n  const syntaxTheme =\n    colorModuleUnavailableReason === null ? getSyntaxTheme(theme) : null\n  const { setPreviewTheme, savePreview, cancelPreview } = usePreviewTheme()\n  const syntaxHighlightingDisabled =\n    useAppState(s => s.settings.syntaxHighlightingDisabled) ?? false\n  const setAppState = useSetAppState()\n\n  // Register ThemePicker context so its keybindings take precedence over Global\n  useRegisterKeybindingContext('ThemePicker')\n\n  const syntaxToggleShortcut = useShortcutDisplay(\n    'theme:toggleSyntaxHighlighting',\n    'ThemePicker',\n    'ctrl+t',\n  )\n\n  useKeybinding(\n    'theme:toggleSyntaxHighlighting',\n    () => {\n      if (colorModuleUnavailableReason === null) {\n        const newValue = !syntaxHighlightingDisabled\n        updateSettingsForSource('userSettings', {\n          syntaxHighlightingDisabled: newValue,\n        })\n        setAppState(prev => ({\n          ...prev,\n          settings: { ...prev.settings, syntaxHighlightingDisabled: newValue },\n        }))\n      }\n    },\n    { context: 'ThemePicker' },\n  )\n  // Always call the hook to follow React rules, but conditionally assign the exit handler\n  const exitState = useExitOnCtrlCDWithKeybindings(\n    skipExitHandling ? () => {} : undefined,\n  )\n\n  const themeOptions: { label: string; value: ThemeSetting }[] = [\n    ...(feature('AUTO_THEME')\n      ? [{ label: 'Auto (match terminal)', value: 'auto' as const }]\n      : []),\n    { label: 'Dark mode', value: 'dark' },\n    { label: 'Light mode', value: 'light' },\n    {\n      label: 'Dark mode (colorblind-friendly)',\n      value: 'dark-daltonized',\n    },\n    {\n      label: 'Light mode (colorblind-friendly)',\n      value: 'light-daltonized',\n    },\n    {\n      label: 'Dark mode (ANSI colors only)',\n      value: 'dark-ansi',\n    },\n    {\n      label: 'Light mode (ANSI colors only)',\n      value: 'light-ansi',\n    },\n  ]\n\n  const content = (\n    <Box flexDirection=\"column\" gap={1}>\n      <Box flexDirection=\"column\" gap={1}>\n        {showIntroText ? (\n          <Text>Let&apos;s get started.</Text>\n        ) : (\n          <Text bold color=\"permission\">\n            Theme\n          </Text>\n        )}\n        <Box flexDirection=\"column\">\n          <Text bold>\n            Choose the text style that looks best with your terminal\n          </Text>\n          {helpText && !showHelpTextBelow && <Text dimColor>{helpText}</Text>}\n        </Box>\n        <Select\n          options={themeOptions}\n          onFocus={setting => {\n            setPreviewTheme(setting as ThemeSetting)\n          }}\n          onChange={(setting: string) => {\n            savePreview()\n            onThemeSelect(setting as ThemeSetting)\n          }}\n          onCancel={\n            skipExitHandling\n              ? () => {\n                  cancelPreview()\n                  onCancelProp?.()\n                }\n              : async () => {\n                  cancelPreview()\n                  await gracefulShutdown(0)\n                }\n          }\n          visibleOptionCount={themeOptions.length}\n          defaultValue={themeSetting}\n          defaultFocusValue={themeSetting}\n        />\n      </Box>\n      <Box flexDirection=\"column\" width=\"100%\">\n        <Box\n          flexDirection=\"column\"\n          borderTop\n          borderBottom\n          borderLeft={false}\n          borderRight={false}\n          borderStyle=\"dashed\"\n          borderColor=\"subtle\"\n        >\n          <StructuredDiff\n            patch={{\n              oldStart: 1,\n              newStart: 1,\n              oldLines: 3,\n              newLines: 3,\n              lines: [\n                ' function greet() {',\n                '-  console.log(\"Hello, World!\");',\n                '+  console.log(\"Hello, Claude!\");',\n                ' }',\n              ],\n            }}\n            dim={false}\n            filePath=\"demo.js\"\n            firstLine={null}\n            width={columns}\n          />\n        </Box>\n        <Text dimColor>\n          {' '}\n          {colorModuleUnavailableReason === 'env'\n            ? `Syntax highlighting disabled (via CLAUDE_CODE_SYNTAX_HIGHLIGHT=${process.env.CLAUDE_CODE_SYNTAX_HIGHLIGHT})`\n            : syntaxHighlightingDisabled\n              ? `Syntax highlighting disabled (${syntaxToggleShortcut} to enable)`\n              : syntaxTheme\n                ? `Syntax theme: ${syntaxTheme.theme}${syntaxTheme.source ? ` (from ${syntaxTheme.source})` : ''} (${syntaxToggleShortcut} to disable)`\n                : `Syntax highlighting enabled (${syntaxToggleShortcut} to disable)`}\n        </Text>\n      </Box>\n    </Box>\n  )\n\n  // Only wrap in a box when not in onboarding\n  if (!showIntroText) {\n    return (\n      <>\n        <Box flexDirection=\"column\">{content}</Box>\n        <Box marginTop={1}>\n          {showHelpTextBelow && helpText && (\n            <Box marginLeft={3}>\n              <Text dimColor>{helpText}</Text>\n            </Box>\n          )}\n          {!hideEscToCancel && (\n            <Box>\n              <Text dimColor italic>\n                {exitState.pending ? (\n                  <>Press {exitState.keyName} again to exit</>\n                ) : (\n                  <Byline>\n                    <KeyboardShortcutHint shortcut=\"Enter\" action=\"select\" />\n                    <KeyboardShortcutHint shortcut=\"Esc\" action=\"cancel\" />\n                  </Byline>\n                )}\n              </Text>\n            </Box>\n          )}\n        </Box>\n      </>\n    )\n  }\n\n  return content\n}\n"],"mappings":"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","ignoreList":[]}