๐Ÿ“„ File detail

components/TeleportRepoMismatchDialog.tsx

๐Ÿงฉ .tsx๐Ÿ“ 104 lines๐Ÿ’พ 13,046 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 TeleportRepoMismatchDialog โ€” mainly types, interfaces, or factory objects. Dependencies touch React UI. It composes internal code from ink, utils, CustomSelect, design-system, and Spinner (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, { useCallback, useState } from 'react'; import { Box, Text } from '../ink.js'; import { getDisplayPath } from '../utils/file.js'; import { removePathFromRepo, validateRepoAtPath } from '../utils/githubRepoPathMapping.js';

๐Ÿ“ค Exports (heuristic)

  • TeleportRepoMismatchDialog

๐Ÿ“š External import roots

Package roots from from "โ€ฆ" (relative paths omitted).

  • react

๐Ÿ–ฅ๏ธ Source preview

import { c as _c } from "react/compiler-runtime";
import React, { useCallback, useState } from 'react';
import { Box, Text } from '../ink.js';
import { getDisplayPath } from '../utils/file.js';
import { removePathFromRepo, validateRepoAtPath } from '../utils/githubRepoPathMapping.js';
import { Select } from './CustomSelect/index.js';
import { Dialog } from './design-system/Dialog.js';
import { Spinner } from './Spinner.js';
type Props = {
  targetRepo: string;
  initialPaths: string[];
  onSelectPath: (path: string) => void;
  onCancel: () => void;
};
export function TeleportRepoMismatchDialog(t0) {
  const $ = _c(18);
  const {
    targetRepo,
    initialPaths,
    onSelectPath,
    onCancel
  } = t0;
  const [availablePaths, setAvailablePaths] = useState(initialPaths);
  const [errorMessage, setErrorMessage] = useState(null);
  const [validating, setValidating] = useState(false);
  let t1;
  if ($[0] !== availablePaths || $[1] !== onCancel || $[2] !== onSelectPath || $[3] !== targetRepo) {
    t1 = async value => {
      if (value === "cancel") {
        onCancel();
        return;
      }
      setValidating(true);
      setErrorMessage(null);
      const isValid = await validateRepoAtPath(value, targetRepo);
      if (isValid) {
        onSelectPath(value);
        return;
      }
      removePathFromRepo(targetRepo, value);
      const updatedPaths = availablePaths.filter(p => p !== value);
      setAvailablePaths(updatedPaths);
      setValidating(false);
      setErrorMessage(`${getDisplayPath(value)} no longer contains the correct repository. Select another path.`);
    };
    $[0] = availablePaths;
    $[1] = onCancel;
    $[2] = onSelectPath;
    $[3] = targetRepo;
    $[4] = t1;
  } else {
    t1 = $[4];
  }
  const handleChange = t1;
  let t2;
  if ($[5] !== availablePaths) {
    let t3;
    if ($[7] === Symbol.for("react.memo_cache_sentinel")) {
      t3 = {
        label: "Cancel",
        value: "cancel"
      };
      $[7] = t3;
    } else {
      t3 = $[7];
    }
    t2 = [...availablePaths.map(_temp), t3];
    $[5] = availablePaths;
    $[6] = t2;
  } else {
    t2 = $[6];
  }
  const options = t2;
  let t3;
  if ($[8] !== availablePaths.length || $[9] !== errorMessage || $[10] !== handleChange || $[11] !== options || $[12] !== targetRepo || $[13] !== validating) {
    t3 = availablePaths.length > 0 ? <><Box flexDirection="column" gap={1}>{errorMessage && <Text color="error">{errorMessage}</Text>}<Text>Open Claude Code in <Text bold={true}>{targetRepo}</Text>:</Text></Box>{validating ? <Box><Spinner /><Text> Validating repositoryโ€ฆ</Text></Box> : <Select options={options} onChange={value_0 => void handleChange(value_0)} />}</> : <Box flexDirection="column" gap={1}>{errorMessage && <Text color="error">{errorMessage}</Text>}<Text dimColor={true}>Run claude --teleport from a checkout of {targetRepo}</Text></Box>;
    $[8] = availablePaths.length;
    $[9] = errorMessage;
    $[10] = handleChange;
    $[11] = options;
    $[12] = targetRepo;
    $[13] = validating;
    $[14] = t3;
  } else {
    t3 = $[14];
  }
  let t4;
  if ($[15] !== onCancel || $[16] !== t3) {
    t4 = <Dialog title="Teleport to Repo" onCancel={onCancel} color="background">{t3}</Dialog>;
    $[15] = onCancel;
    $[16] = t3;
    $[17] = t4;
  } else {
    t4 = $[17];
  }
  return t4;
}
function _temp(path) {
  return {
    label: <Text>Use <Text bold={true}>{getDisplayPath(path)}</Text></Text>,
    value: path
  };
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useCallback","useState","Box","Text","getDisplayPath","removePathFromRepo","validateRepoAtPath","Select","Dialog","Spinner","Props","targetRepo","initialPaths","onSelectPath","path","onCancel","TeleportRepoMismatchDialog","t0","$","_c","availablePaths","setAvailablePaths","errorMessage","setErrorMessage","validating","setValidating","t1","value","isValid","updatedPaths","filter","p","handleChange","t2","t3","Symbol","for","label","map","_temp","options","length","value_0","t4"],"sources":["TeleportRepoMismatchDialog.tsx"],"sourcesContent":["import React, { useCallback, useState } from 'react'\nimport { Box, Text } from '../ink.js'\nimport { getDisplayPath } from '../utils/file.js'\nimport {\n  removePathFromRepo,\n  validateRepoAtPath,\n} from '../utils/githubRepoPathMapping.js'\nimport { Select } from './CustomSelect/index.js'\nimport { Dialog } from './design-system/Dialog.js'\nimport { Spinner } from './Spinner.js'\n\ntype Props = {\n  targetRepo: string\n  initialPaths: string[]\n  onSelectPath: (path: string) => void\n  onCancel: () => void\n}\n\nexport function TeleportRepoMismatchDialog({\n  targetRepo,\n  initialPaths,\n  onSelectPath,\n  onCancel,\n}: Props): React.ReactNode {\n  const [availablePaths, setAvailablePaths] = useState<string[]>(initialPaths)\n  const [errorMessage, setErrorMessage] = useState<string | null>(null)\n  const [validating, setValidating] = useState(false)\n\n  const handleChange = useCallback(\n    async (value: string): Promise<void> => {\n      if (value === 'cancel') {\n        onCancel()\n        return\n      }\n\n      setValidating(true)\n      setErrorMessage(null)\n\n      const isValid = await validateRepoAtPath(value, targetRepo)\n\n      if (isValid) {\n        onSelectPath(value)\n        return\n      }\n\n      // Path is invalid - remove it from config and update state\n      removePathFromRepo(targetRepo, value)\n      const updatedPaths = availablePaths.filter(p => p !== value)\n      setAvailablePaths(updatedPaths)\n      setValidating(false)\n\n      setErrorMessage(\n        `${getDisplayPath(value)} no longer contains the correct repository. Select another path.`,\n      )\n    },\n    [targetRepo, availablePaths, onSelectPath, onCancel],\n  )\n\n  const options = [\n    ...availablePaths.map(path => ({\n      label: (\n        <Text>\n          Use <Text bold>{getDisplayPath(path)}</Text>\n        </Text>\n      ),\n      value: path,\n    })),\n    { label: 'Cancel', value: 'cancel' },\n  ]\n\n  return (\n    <Dialog title=\"Teleport to Repo\" onCancel={onCancel} color=\"background\">\n      {availablePaths.length > 0 ? (\n        <>\n          <Box flexDirection=\"column\" gap={1}>\n            {errorMessage && <Text color=\"error\">{errorMessage}</Text>}\n            <Text>\n              Open Claude Code in <Text bold>{targetRepo}</Text>:\n            </Text>\n          </Box>\n\n          {validating ? (\n            <Box>\n              <Spinner />\n              <Text> Validating repository…</Text>\n            </Box>\n          ) : (\n            <Select\n              options={options}\n              onChange={value => void handleChange(value)}\n            />\n          )}\n        </>\n      ) : (\n        <Box flexDirection=\"column\" gap={1}>\n          {errorMessage && <Text color=\"error\">{errorMessage}</Text>}\n          <Text dimColor>\n            Run claude --teleport from a checkout of {targetRepo}\n          </Text>\n        </Box>\n      )}\n    </Dialog>\n  )\n}\n"],"mappings":";AAAA,OAAOA,KAAK,IAAIC,WAAW,EAAEC,QAAQ,QAAQ,OAAO;AACpD,SAASC,GAAG,EAAEC,IAAI,QAAQ,WAAW;AACrC,SAASC,cAAc,QAAQ,kBAAkB;AACjD,SACEC,kBAAkB,EAClBC,kBAAkB,QACb,mCAAmC;AAC1C,SAASC,MAAM,QAAQ,yBAAyB;AAChD,SAASC,MAAM,QAAQ,2BAA2B;AAClD,SAASC,OAAO,QAAQ,cAAc;AAEtC,KAAKC,KAAK,GAAG;EACXC,UAAU,EAAE,MAAM;EAClBC,YAAY,EAAE,MAAM,EAAE;EACtBC,YAAY,EAAE,CAACC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI;EACpCC,QAAQ,EAAE,GAAG,GAAG,IAAI;AACtB,CAAC;AAED,OAAO,SAAAC,2BAAAC,EAAA;EAAA,MAAAC,CAAA,GAAAC,EAAA;EAAoC;IAAAR,UAAA;IAAAC,YAAA;IAAAC,YAAA;IAAAE;EAAA,IAAAE,EAKnC;EACN,OAAAG,cAAA,EAAAC,iBAAA,IAA4CpB,QAAQ,CAAWW,YAAY,CAAC;EAC5E,OAAAU,YAAA,EAAAC,eAAA,IAAwCtB,QAAQ,CAAgB,IAAI,CAAC;EACrE,OAAAuB,UAAA,EAAAC,aAAA,IAAoCxB,QAAQ,CAAC,KAAK,CAAC;EAAA,IAAAyB,EAAA;EAAA,IAAAR,CAAA,QAAAE,cAAA,IAAAF,CAAA,QAAAH,QAAA,IAAAG,CAAA,QAAAL,YAAA,IAAAK,CAAA,QAAAP,UAAA;IAGjDe,EAAA,SAAAC,KAAA;MACE,IAAIA,KAAK,KAAK,QAAQ;QACpBZ,QAAQ,CAAC,CAAC;QAAA;MAAA;MAIZU,aAAa,CAAC,IAAI,CAAC;MACnBF,eAAe,CAAC,IAAI,CAAC;MAErB,MAAAK,OAAA,GAAgB,MAAMtB,kBAAkB,CAACqB,KAAK,EAAEhB,UAAU,CAAC;MAE3D,IAAIiB,OAAO;QACTf,YAAY,CAACc,KAAK,CAAC;QAAA;MAAA;MAKrBtB,kBAAkB,CAACM,UAAU,EAAEgB,KAAK,CAAC;MACrC,MAAAE,YAAA,GAAqBT,cAAc,CAAAU,MAAO,CAACC,CAAA,IAAKA,CAAC,KAAKJ,KAAK,CAAC;MAC5DN,iBAAiB,CAACQ,YAAY,CAAC;MAC/BJ,aAAa,CAAC,KAAK,CAAC;MAEpBF,eAAe,CACb,GAAGnB,cAAc,CAACuB,KAAK,CAAC,kEAC1B,CAAC;IAAA,CACF;IAAAT,CAAA,MAAAE,cAAA;IAAAF,CAAA,MAAAH,QAAA;IAAAG,CAAA,MAAAL,YAAA;IAAAK,CAAA,MAAAP,UAAA;IAAAO,CAAA,MAAAQ,EAAA;EAAA;IAAAA,EAAA,GAAAR,CAAA;EAAA;EA1BH,MAAAc,YAAA,GAAqBN,EA4BpB;EAAA,IAAAO,EAAA;EAAA,IAAAf,CAAA,QAAAE,cAAA;IAAA,IAAAc,EAAA;IAAA,IAAAhB,CAAA,QAAAiB,MAAA,CAAAC,GAAA;MAWCF,EAAA;QAAAG,KAAA,EAAS,QAAQ;QAAAV,KAAA,EAAS;MAAS,CAAC;MAAAT,CAAA,MAAAgB,EAAA;IAAA;MAAAA,EAAA,GAAAhB,CAAA;IAAA;IATtBe,EAAA,OACXb,cAAc,CAAAkB,GAAI,CAACC,KAOpB,CAAC,EACHL,EAAoC,CACrC;IAAAhB,CAAA,MAAAE,cAAA;IAAAF,CAAA,MAAAe,EAAA;EAAA;IAAAA,EAAA,GAAAf,CAAA;EAAA;EAVD,MAAAsB,OAAA,GAAgBP,EAUf;EAAA,IAAAC,EAAA;EAAA,IAAAhB,CAAA,QAAAE,cAAA,CAAAqB,MAAA,IAAAvB,CAAA,QAAAI,YAAA,IAAAJ,CAAA,SAAAc,YAAA,IAAAd,CAAA,SAAAsB,OAAA,IAAAtB,CAAA,SAAAP,UAAA,IAAAO,CAAA,SAAAM,UAAA;IAIIU,EAAA,GAAAd,cAAc,CAAAqB,MAAO,GAAG,CA4BxB,GA5BA,EAEG,CAAC,GAAG,CAAe,aAAQ,CAAR,QAAQ,CAAM,GAAC,CAAD,GAAC,CAC/B,CAAAnB,YAAyD,IAAzC,CAAC,IAAI,CAAO,KAAO,CAAP,OAAO,CAAEA,aAAW,CAAE,EAAjC,IAAI,CAAmC,CACzD,CAAC,IAAI,CAAC,oBACgB,CAAC,IAAI,CAAC,IAAI,CAAJ,KAAG,CAAC,CAAEX,WAAS,CAAE,EAAtB,IAAI,CAAyB,CACpD,EAFC,IAAI,CAGP,EALC,GAAG,CAOH,CAAAa,UAAU,GACT,CAAC,GAAG,CACF,CAAC,OAAO,GACR,CAAC,IAAI,CAAC,uBAAuB,EAA5B,IAAI,CACP,EAHC,GAAG,CASL,GAJC,CAAC,MAAM,CACIgB,OAAO,CAAPA,QAAM,CAAC,CACN,QAAiC,CAAjC,CAAAE,OAAA,IAAS,KAAKV,YAAY,CAACL,OAAK,EAAC,GAE/C,CAAC,GASJ,GANC,CAAC,GAAG,CAAe,aAAQ,CAAR,QAAQ,CAAM,GAAC,CAAD,GAAC,CAC/B,CAAAL,YAAyD,IAAzC,CAAC,IAAI,CAAO,KAAO,CAAP,OAAO,CAAEA,aAAW,CAAE,EAAjC,IAAI,CAAmC,CACzD,CAAC,IAAI,CAAC,QAAQ,CAAR,KAAO,CAAC,CAAC,yCAC6BX,WAAS,CACrD,EAFC,IAAI,CAGP,EALC,GAAG,CAML;IAAAO,CAAA,MAAAE,cAAA,CAAAqB,MAAA;IAAAvB,CAAA,MAAAI,YAAA;IAAAJ,CAAA,OAAAc,YAAA;IAAAd,CAAA,OAAAsB,OAAA;IAAAtB,CAAA,OAAAP,UAAA;IAAAO,CAAA,OAAAM,UAAA;IAAAN,CAAA,OAAAgB,EAAA;EAAA;IAAAA,EAAA,GAAAhB,CAAA;EAAA;EAAA,IAAAyB,EAAA;EAAA,IAAAzB,CAAA,SAAAH,QAAA,IAAAG,CAAA,SAAAgB,EAAA;IA7BHS,EAAA,IAAC,MAAM,CAAO,KAAkB,CAAlB,kBAAkB,CAAW5B,QAAQ,CAARA,SAAO,CAAC,CAAQ,KAAY,CAAZ,YAAY,CACpE,CAAAmB,EA4BD,CACF,EA9BC,MAAM,CA8BE;IAAAhB,CAAA,OAAAH,QAAA;IAAAG,CAAA,OAAAgB,EAAA;IAAAhB,CAAA,OAAAyB,EAAA;EAAA;IAAAA,EAAA,GAAAzB,CAAA;EAAA;EAAA,OA9BTyB,EA8BS;AAAA;AAnFN,SAAAJ,MAAAzB,IAAA;EAAA,OAyC4B;IAAAuB,KAAA,EAE3B,CAAC,IAAI,CAAC,IACA,CAAC,IAAI,CAAC,IAAI,CAAJ,KAAG,CAAC,CAAE,CAAAjC,cAAc,CAACU,IAAI,EAAE,EAAhC,IAAI,CACX,EAFC,IAAI,CAEE;IAAAa,KAAA,EAEFb;EACT,CAAC;AAAA","ignoreList":[]}