πŸ“„ File detail

components/IdeOnboardingDialog.tsx

🧩 .tsxπŸ“ 167 linesπŸ’Ύ 16,399 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 IdeOnboardingDialog and hasIdeOnboardingDialogBeenShown β€” mainly functions, hooks, or classes. Dependencies touch React UI and src. It composes internal code from ink, keybindings, utils, 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 React from 'react'; import { envDynamic } from 'src/utils/envDynamic.js'; import { Box, Text } from '../ink.js'; import { useKeybindings } from '../keybindings/useKeybinding.js';

πŸ“€ Exports (heuristic)

  • IdeOnboardingDialog
  • hasIdeOnboardingDialogBeenShown

πŸ“š External import roots

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

  • react
  • src

πŸ–₯️ Source preview

import { c as _c } from "react/compiler-runtime";
import React from 'react';
import { envDynamic } from 'src/utils/envDynamic.js';
import { Box, Text } from '../ink.js';
import { useKeybindings } from '../keybindings/useKeybinding.js';
import { getGlobalConfig, saveGlobalConfig } from '../utils/config.js';
import { env } from '../utils/env.js';
import { getTerminalIdeType, type IDEExtensionInstallationStatus, isJetBrainsIde, toIDEDisplayName } from '../utils/ide.js';
import { Dialog } from './design-system/Dialog.js';
interface Props {
  onDone: () => void;
  installationStatus: IDEExtensionInstallationStatus | null;
}
export function IdeOnboardingDialog(t0) {
  const $ = _c(23);
  const {
    onDone,
    installationStatus
  } = t0;
  markDialogAsShown();
  let t1;
  if ($[0] !== onDone) {
    t1 = {
      "confirm:yes": onDone,
      "confirm:no": onDone
    };
    $[0] = onDone;
    $[1] = t1;
  } else {
    t1 = $[1];
  }
  let t2;
  if ($[2] === Symbol.for("react.memo_cache_sentinel")) {
    t2 = {
      context: "Confirmation"
    };
    $[2] = t2;
  } else {
    t2 = $[2];
  }
  useKeybindings(t1, t2);
  let t3;
  if ($[3] !== installationStatus?.ideType) {
    t3 = installationStatus?.ideType ?? getTerminalIdeType();
    $[3] = installationStatus?.ideType;
    $[4] = t3;
  } else {
    t3 = $[4];
  }
  const ideType = t3;
  const isJetBrains = isJetBrainsIde(ideType);
  let t4;
  if ($[5] !== ideType) {
    t4 = toIDEDisplayName(ideType);
    $[5] = ideType;
    $[6] = t4;
  } else {
    t4 = $[6];
  }
  const ideName = t4;
  const installedVersion = installationStatus?.installedVersion;
  const pluginOrExtension = isJetBrains ? "plugin" : "extension";
  const mentionShortcut = env.platform === "darwin" ? "Cmd+Option+K" : "Ctrl+Alt+K";
  let t5;
  if ($[7] === Symbol.for("react.memo_cache_sentinel")) {
    t5 = <Text color="claude">✻ </Text>;
    $[7] = t5;
  } else {
    t5 = $[7];
  }
  let t6;
  if ($[8] !== ideName) {
    t6 = <>{t5}<Text>Welcome to Claude Code for {ideName}</Text></>;
    $[8] = ideName;
    $[9] = t6;
  } else {
    t6 = $[9];
  }
  const t7 = installedVersion ? `installed ${pluginOrExtension} v${installedVersion}` : undefined;
  let t8;
  if ($[10] === Symbol.for("react.memo_cache_sentinel")) {
    t8 = <Text color="suggestion">⧉ open files</Text>;
    $[10] = t8;
  } else {
    t8 = $[10];
  }
  let t9;
  if ($[11] === Symbol.for("react.memo_cache_sentinel")) {
    t9 = <Text>β€’ Claude has context of {t8}{" "}and <Text color="suggestion">⧉ selected lines</Text></Text>;
    $[11] = t9;
  } else {
    t9 = $[11];
  }
  let t10;
  if ($[12] === Symbol.for("react.memo_cache_sentinel")) {
    t10 = <Text color="diffAddedWord">+11</Text>;
    $[12] = t10;
  } else {
    t10 = $[12];
  }
  let t11;
  if ($[13] === Symbol.for("react.memo_cache_sentinel")) {
    t11 = <Text>β€’ Review Claude Code's changes{" "}{t10}{" "}<Text color="diffRemovedWord">-22</Text> in the comfort of your IDE</Text>;
    $[13] = t11;
  } else {
    t11 = $[13];
  }
  let t12;
  if ($[14] === Symbol.for("react.memo_cache_sentinel")) {
    t12 = <Text>β€’ Cmd+Esc<Text dimColor={true}> for Quick Launch</Text></Text>;
    $[14] = t12;
  } else {
    t12 = $[14];
  }
  let t13;
  if ($[15] === Symbol.for("react.memo_cache_sentinel")) {
    t13 = <Box flexDirection="column" gap={1}>{t9}{t11}{t12}<Text>β€’ {mentionShortcut}<Text dimColor={true}> to reference files or lines in your input</Text></Text></Box>;
    $[15] = t13;
  } else {
    t13 = $[15];
  }
  let t14;
  if ($[16] !== onDone || $[17] !== t6 || $[18] !== t7) {
    t14 = <Dialog title={t6} subtitle={t7} color="ide" onCancel={onDone} hideInputGuide={true}>{t13}</Dialog>;
    $[16] = onDone;
    $[17] = t6;
    $[18] = t7;
    $[19] = t14;
  } else {
    t14 = $[19];
  }
  let t15;
  if ($[20] === Symbol.for("react.memo_cache_sentinel")) {
    t15 = <Box paddingX={1}><Text dimColor={true} italic={true}>Press Enter to continue</Text></Box>;
    $[20] = t15;
  } else {
    t15 = $[20];
  }
  let t16;
  if ($[21] !== t14) {
    t16 = <>{t14}{t15}</>;
    $[21] = t14;
    $[22] = t16;
  } else {
    t16 = $[22];
  }
  return t16;
}
export function hasIdeOnboardingDialogBeenShown(): boolean {
  const config = getGlobalConfig();
  const terminal = envDynamic.terminal || 'unknown';
  return config.hasIdeOnboardingBeenShown?.[terminal] === true;
}
function markDialogAsShown(): void {
  if (hasIdeOnboardingDialogBeenShown()) {
    return;
  }
  const terminal = envDynamic.terminal || 'unknown';
  saveGlobalConfig(current => ({
    ...current,
    hasIdeOnboardingBeenShown: {
      ...current.hasIdeOnboardingBeenShown,
      [terminal]: true
    }
  }));
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","envDynamic","Box","Text","useKeybindings","getGlobalConfig","saveGlobalConfig","env","getTerminalIdeType","IDEExtensionInstallationStatus","isJetBrainsIde","toIDEDisplayName","Dialog","Props","onDone","installationStatus","IdeOnboardingDialog","t0","$","_c","markDialogAsShown","t1","t2","Symbol","for","context","t3","ideType","isJetBrains","t4","ideName","installedVersion","pluginOrExtension","mentionShortcut","platform","t5","t6","t7","undefined","t8","t9","t10","t11","t12","t13","t14","t15","t16","hasIdeOnboardingDialogBeenShown","config","terminal","hasIdeOnboardingBeenShown","current"],"sources":["IdeOnboardingDialog.tsx"],"sourcesContent":["import React from 'react'\nimport { envDynamic } from 'src/utils/envDynamic.js'\nimport { Box, Text } from '../ink.js'\nimport { useKeybindings } from '../keybindings/useKeybinding.js'\nimport { getGlobalConfig, saveGlobalConfig } from '../utils/config.js'\nimport { env } from '../utils/env.js'\nimport {\n  getTerminalIdeType,\n  type IDEExtensionInstallationStatus,\n  isJetBrainsIde,\n  toIDEDisplayName,\n} from '../utils/ide.js'\nimport { Dialog } from './design-system/Dialog.js'\n\ninterface Props {\n  onDone: () => void\n  installationStatus: IDEExtensionInstallationStatus | null\n}\n\nexport function IdeOnboardingDialog({\n  onDone,\n  installationStatus,\n}: Props): React.ReactNode {\n  markDialogAsShown()\n\n  // Handle Enter/Escape to dismiss\n  useKeybindings(\n    {\n      'confirm:yes': onDone,\n      'confirm:no': onDone,\n    },\n    { context: 'Confirmation' },\n  )\n\n  const ideType = installationStatus?.ideType ?? getTerminalIdeType()\n  const isJetBrains = isJetBrainsIde(ideType)\n\n  const ideName = toIDEDisplayName(ideType)\n  const installedVersion = installationStatus?.installedVersion\n  const pluginOrExtension = isJetBrains ? 'plugin' : 'extension'\n  const mentionShortcut =\n    env.platform === 'darwin' ? 'Cmd+Option+K' : 'Ctrl+Alt+K'\n\n  return (\n    <>\n      <Dialog\n        title={\n          <>\n            <Text color=\"claude\">✻ </Text>\n            <Text>Welcome to Claude Code for {ideName}</Text>\n          </>\n        }\n        subtitle={\n          installedVersion\n            ? `installed ${pluginOrExtension} v${installedVersion}`\n            : undefined\n        }\n        color=\"ide\"\n        onCancel={onDone}\n        hideInputGuide\n      >\n        <Box flexDirection=\"column\" gap={1}>\n          <Text>\n            • Claude has context of <Text color=\"suggestion\">⧉ open files</Text>{' '}\n            and <Text color=\"suggestion\">⧉ selected lines</Text>\n          </Text>\n          <Text>\n            • Review Claude Code&apos;s changes{' '}\n            <Text color=\"diffAddedWord\">+11</Text>{' '}\n            <Text color=\"diffRemovedWord\">-22</Text> in the comfort of your IDE\n          </Text>\n          <Text>\n            • Cmd+Esc<Text dimColor> for Quick Launch</Text>\n          </Text>\n          <Text>\n            • {mentionShortcut}\n            <Text dimColor> to reference files or lines in your input</Text>\n          </Text>\n        </Box>\n      </Dialog>\n      <Box paddingX={1}>\n        <Text dimColor italic>\n          Press Enter to continue\n        </Text>\n      </Box>\n    </>\n  )\n}\n\nexport function hasIdeOnboardingDialogBeenShown(): boolean {\n  const config = getGlobalConfig()\n  const terminal = envDynamic.terminal || 'unknown'\n  return config.hasIdeOnboardingBeenShown?.[terminal] === true\n}\n\nfunction markDialogAsShown(): void {\n  if (hasIdeOnboardingDialogBeenShown()) {\n    return\n  }\n  const terminal = envDynamic.terminal || 'unknown'\n  saveGlobalConfig(current => ({\n    ...current,\n    hasIdeOnboardingBeenShown: {\n      ...current.hasIdeOnboardingBeenShown,\n      [terminal]: true,\n    },\n  }))\n}\n"],"mappings":"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","ignoreList":[]}