π File detail
components/TeleportProgress.tsx
π§© .tsxπ 140 linesπΎ 16,142 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 TeleportProgress and teleportWithProgress β mainly functions, hooks, or classes. Dependencies touch React UI and figures. It composes internal code from ink, 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 figures from 'figures'; import * as React from 'react'; import { useState } from 'react'; import type { Root } from '../ink.js';
π€ Exports (heuristic)
TeleportProgressteleportWithProgress
π External import roots
Package roots from from "β¦" (relative paths omitted).
reactfigures
π₯οΈ Source preview
import { c as _c } from "react/compiler-runtime";
import figures from 'figures';
import * as React from 'react';
import { useState } from 'react';
import type { Root } from '../ink.js';
import { Box, Text, useAnimationFrame } from '../ink.js';
import { AppStateProvider } from '../state/AppState.js';
import { checkOutTeleportedSessionBranch, processMessagesForTeleportResume, type TeleportProgressStep, type TeleportResult, teleportResumeCodeSession } from '../utils/teleport.js';
type Props = {
currentStep: TeleportProgressStep;
sessionId?: string;
};
const SPINNER_FRAMES = ['β', 'β', 'β', 'β'];
const STEPS: {
key: TeleportProgressStep;
label: string;
}[] = [{
key: 'validating',
label: 'Validating session'
}, {
key: 'fetching_logs',
label: 'Fetching session logs'
}, {
key: 'fetching_branch',
label: 'Getting branch info'
}, {
key: 'checking_out',
label: 'Checking out branch'
}];
export function TeleportProgress(t0) {
const $ = _c(16);
const {
currentStep,
sessionId
} = t0;
const [ref, time] = useAnimationFrame(100);
const frame = Math.floor(time / 100) % SPINNER_FRAMES.length;
let t1;
if ($[0] !== currentStep) {
t1 = s => s.key === currentStep;
$[0] = currentStep;
$[1] = t1;
} else {
t1 = $[1];
}
const currentStepIndex = STEPS.findIndex(t1);
const t2 = SPINNER_FRAMES[frame];
let t3;
if ($[2] !== t2) {
t3 = <Box marginBottom={1}><Text bold={true} color="claude">{t2} Teleporting sessionβ¦</Text></Box>;
$[2] = t2;
$[3] = t3;
} else {
t3 = $[3];
}
let t4;
if ($[4] !== sessionId) {
t4 = sessionId && <Box marginBottom={1}><Text dimColor={true}>{sessionId}</Text></Box>;
$[4] = sessionId;
$[5] = t4;
} else {
t4 = $[5];
}
let t5;
if ($[6] !== currentStepIndex || $[7] !== frame) {
t5 = STEPS.map((step, index) => {
const isComplete = index < currentStepIndex;
const isCurrent = index === currentStepIndex;
const isPending = index > currentStepIndex;
let icon;
let color;
if (isComplete) {
icon = figures.tick;
color = "green";
} else {
if (isCurrent) {
icon = SPINNER_FRAMES[frame];
color = "claude";
} else {
icon = figures.circle;
color = undefined;
}
}
return <Box key={step.key} flexDirection="row"><Box width={2}><Text color={color as never} dimColor={isPending}>{icon}</Text></Box><Text dimColor={isPending} bold={isCurrent}>{step.label}</Text></Box>;
});
$[6] = currentStepIndex;
$[7] = frame;
$[8] = t5;
} else {
t5 = $[8];
}
let t6;
if ($[9] !== t5) {
t6 = <Box flexDirection="column" marginLeft={2}>{t5}</Box>;
$[9] = t5;
$[10] = t6;
} else {
t6 = $[10];
}
let t7;
if ($[11] !== ref || $[12] !== t3 || $[13] !== t4 || $[14] !== t6) {
t7 = <Box ref={ref} flexDirection="column" paddingX={1} paddingY={1}>{t3}{t4}{t6}</Box>;
$[11] = ref;
$[12] = t3;
$[13] = t4;
$[14] = t6;
$[15] = t7;
} else {
t7 = $[15];
}
return t7;
}
/**
* Teleports to a remote session with progress UI rendered into the existing root.
* Fetches the session, checks out the branch, and returns the result.
*/
export async function teleportWithProgress(root: Root, sessionId: string): Promise<TeleportResult> {
// Capture the setState function from the rendered component
let setStep: (step: TeleportProgressStep) => void = () => {};
function TeleportProgressWrapper(): React.ReactNode {
const [step, _setStep] = useState<TeleportProgressStep>('validating');
setStep = _setStep;
return <TeleportProgress currentStep={step} sessionId={sessionId} />;
}
root.render(<AppStateProvider>
<TeleportProgressWrapper />
</AppStateProvider>);
const result = await teleportResumeCodeSession(sessionId, setStep);
setStep('checking_out');
const {
branchName,
branchError
} = await checkOutTeleportedSessionBranch(result.branch);
return {
messages: processMessagesForTeleportResume(result.log, branchError),
branchName
};
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["figures","React","useState","Root","Box","Text","useAnimationFrame","AppStateProvider","checkOutTeleportedSessionBranch","processMessagesForTeleportResume","TeleportProgressStep","TeleportResult","teleportResumeCodeSession","Props","currentStep","sessionId","SPINNER_FRAMES","STEPS","key","label","TeleportProgress","t0","$","_c","ref","time","frame","Math","floor","length","t1","s","currentStepIndex","findIndex","t2","t3","t4","t5","map","step","index","isComplete","isCurrent","isPending","icon","color","tick","circle","undefined","t6","t7","teleportWithProgress","root","Promise","setStep","TeleportProgressWrapper","ReactNode","_setStep","render","result","branchName","branchError","branch","messages","log"],"sources":["TeleportProgress.tsx"],"sourcesContent":["import figures from 'figures'\nimport * as React from 'react'\nimport { useState } from 'react'\nimport type { Root } from '../ink.js'\nimport { Box, Text, useAnimationFrame } from '../ink.js'\nimport { AppStateProvider } from '../state/AppState.js'\nimport {\n  checkOutTeleportedSessionBranch,\n  processMessagesForTeleportResume,\n  type TeleportProgressStep,\n  type TeleportResult,\n  teleportResumeCodeSession,\n} from '../utils/teleport.js'\n\ntype Props = {\n  currentStep: TeleportProgressStep\n  sessionId?: string\n}\n\nconst SPINNER_FRAMES = ['◐', '◓', '◑', '◒']\n\nconst STEPS: { key: TeleportProgressStep; label: string }[] = [\n  { key: 'validating', label: 'Validating session' },\n  { key: 'fetching_logs', label: 'Fetching session logs' },\n  { key: 'fetching_branch', label: 'Getting branch info' },\n  { key: 'checking_out', label: 'Checking out branch' },\n]\n\nexport function TeleportProgress({\n  currentStep,\n  sessionId,\n}: Props): React.ReactNode {\n  const [ref, time] = useAnimationFrame(100)\n  const frame = Math.floor(time / 100) % SPINNER_FRAMES.length\n\n  const currentStepIndex = STEPS.findIndex(s => s.key === currentStep)\n\n  return (\n    <Box ref={ref} flexDirection=\"column\" paddingX={1} paddingY={1}>\n      <Box marginBottom={1}>\n        <Text bold color=\"claude\">\n          {SPINNER_FRAMES[frame]} Teleporting session…\n        </Text>\n      </Box>\n\n      {sessionId && (\n        <Box marginBottom={1}>\n          <Text dimColor>{sessionId}</Text>\n        </Box>\n      )}\n\n      <Box flexDirection=\"column\" marginLeft={2}>\n        {STEPS.map((step, index) => {\n          const isComplete = index < currentStepIndex\n          const isCurrent = index === currentStepIndex\n          const isPending = index > currentStepIndex\n\n          let icon: string\n          let color: string | undefined\n\n          if (isComplete) {\n            icon = figures.tick\n            color = 'green'\n          } else if (isCurrent) {\n            icon = SPINNER_FRAMES[frame]!\n            color = 'claude'\n          } else {\n            icon = figures.circle\n            color = undefined\n          }\n\n          return (\n            <Box key={step.key} flexDirection=\"row\">\n              <Box width={2}>\n                <Text color={color as never} dimColor={isPending}>\n                  {icon}\n                </Text>\n              </Box>\n              <Text dimColor={isPending} bold={isCurrent}>\n                {step.label}\n              </Text>\n            </Box>\n          )\n        })}\n      </Box>\n    </Box>\n  )\n}\n\n/**\n * Teleports to a remote session with progress UI rendered into the existing root.\n * Fetches the session, checks out the branch, and returns the result.\n */\nexport async function teleportWithProgress(\n  root: Root,\n  sessionId: string,\n): Promise<TeleportResult> {\n  // Capture the setState function from the rendered component\n  let setStep: (step: TeleportProgressStep) => void = () => {}\n\n  function TeleportProgressWrapper(): React.ReactNode {\n    const [step, _setStep] = useState<TeleportProgressStep>('validating')\n    setStep = _setStep\n    return <TeleportProgress currentStep={step} sessionId={sessionId} />\n  }\n\n  root.render(\n    <AppStateProvider>\n      <TeleportProgressWrapper />\n    </AppStateProvider>,\n  )\n\n  const result = await teleportResumeCodeSession(sessionId, setStep)\n  setStep('checking_out')\n  const { branchName, branchError } = await checkOutTeleportedSessionBranch(\n    result.branch,\n  )\n  return {\n    messages: processMessagesForTeleportResume(result.log, branchError),\n    branchName,\n  }\n}\n"],"mappings":";AAAA,OAAOA,OAAO,MAAM,SAAS;AAC7B,OAAO,KAAKC,KAAK,MAAM,OAAO;AAC9B,SAASC,QAAQ,QAAQ,OAAO;AAChC,cAAcC,IAAI,QAAQ,WAAW;AACrC,SAASC,GAAG,EAAEC,IAAI,EAAEC,iBAAiB,QAAQ,WAAW;AACxD,SAASC,gBAAgB,QAAQ,sBAAsB;AACvD,SACEC,+BAA+B,EAC/BC,gCAAgC,EAChC,KAAKC,oBAAoB,EACzB,KAAKC,cAAc,EACnBC,yBAAyB,QACpB,sBAAsB;AAE7B,KAAKC,KAAK,GAAG;EACXC,WAAW,EAAEJ,oBAAoB;EACjCK,SAAS,CAAC,EAAE,MAAM;AACpB,CAAC;AAED,MAAMC,cAAc,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC;AAE3C,MAAMC,KAAK,EAAE;EAAEC,GAAG,EAAER,oBAAoB;EAAES,KAAK,EAAE,MAAM;AAAC,CAAC,EAAE,GAAG,CAC5D;EAAED,GAAG,EAAE,YAAY;EAAEC,KAAK,EAAE;AAAqB,CAAC,EAClD;EAAED,GAAG,EAAE,eAAe;EAAEC,KAAK,EAAE;AAAwB,CAAC,EACxD;EAAED,GAAG,EAAE,iBAAiB;EAAEC,KAAK,EAAE;AAAsB,CAAC,EACxD;EAAED,GAAG,EAAE,cAAc;EAAEC,KAAK,EAAE;AAAsB,CAAC,CACtD;AAED,OAAO,SAAAC,iBAAAC,EAAA;EAAA,MAAAC,CAAA,GAAAC,EAAA;EAA0B;IAAAT,WAAA;IAAAC;EAAA,IAAAM,EAGzB;EACN,OAAAG,GAAA,EAAAC,IAAA,IAAoBnB,iBAAiB,CAAC,GAAG,CAAC;EAC1C,MAAAoB,KAAA,GAAcC,IAAI,CAAAC,KAAM,CAACH,IAAI,GAAG,GAAG,CAAC,GAAGT,cAAc,CAAAa,MAAO;EAAA,IAAAC,EAAA;EAAA,IAAAR,CAAA,QAAAR,WAAA;IAEnBgB,EAAA,GAAAC,CAAA,IAAKA,CAAC,CAAAb,GAAI,KAAKJ,WAAW;IAAAQ,CAAA,MAAAR,WAAA;IAAAQ,CAAA,MAAAQ,EAAA;EAAA;IAAAA,EAAA,GAAAR,CAAA;EAAA;EAAnE,MAAAU,gBAAA,GAAyBf,KAAK,CAAAgB,SAAU,CAACH,EAA0B,CAAC;EAM3D,MAAAI,EAAA,GAAAlB,cAAc,CAACU,KAAK,CAAC;EAAA,IAAAS,EAAA;EAAA,IAAAb,CAAA,QAAAY,EAAA;IAF1BC,EAAA,IAAC,GAAG,CAAe,YAAC,CAAD,GAAC,CAClB,CAAC,IAAI,CAAC,IAAI,CAAJ,KAAG,CAAC,CAAO,KAAQ,CAAR,QAAQ,CACtB,CAAAD,EAAoB,CAAE,qBACzB,EAFC,IAAI,CAGP,EAJC,GAAG,CAIE;IAAAZ,CAAA,MAAAY,EAAA;IAAAZ,CAAA,MAAAa,EAAA;EAAA;IAAAA,EAAA,GAAAb,CAAA;EAAA;EAAA,IAAAc,EAAA;EAAA,IAAAd,CAAA,QAAAP,SAAA;IAELqB,EAAA,GAAArB,SAIA,IAHC,CAAC,GAAG,CAAe,YAAC,CAAD,GAAC,CAClB,CAAC,IAAI,CAAC,QAAQ,CAAR,KAAO,CAAC,CAAEA,UAAQ,CAAE,EAAzB,IAAI,CACP,EAFC,GAAG,CAGL;IAAAO,CAAA,MAAAP,SAAA;IAAAO,CAAA,MAAAc,EAAA;EAAA;IAAAA,EAAA,GAAAd,CAAA;EAAA;EAAA,IAAAe,EAAA;EAAA,IAAAf,CAAA,QAAAU,gBAAA,IAAAV,CAAA,QAAAI,KAAA;IAGEW,EAAA,GAAApB,KAAK,CAAAqB,GAAI,CAAC,CAAAC,IAAA,EAAAC,KAAA;MACT,MAAAC,UAAA,GAAmBD,KAAK,GAAGR,gBAAgB;MAC3C,MAAAU,SAAA,GAAkBF,KAAK,KAAKR,gBAAgB;MAC5C,MAAAW,SAAA,GAAkBH,KAAK,GAAGR,gBAAgB;MAEtCY,GAAA,CAAAA,IAAA;MACAC,GAAA,CAAAA,KAAA;MAEJ,IAAIJ,UAAU;QACZG,IAAA,CAAAA,CAAA,CAAO5C,OAAO,CAAA8C,IAAK;QACnBD,KAAA,CAAAA,CAAA,CAAQA,OAAO;MAAV;QACA,IAAIH,SAAS;UAClBE,IAAA,CAAAA,CAAA,CAAO5B,cAAc,CAACU,KAAK,CAAC;UAC5BmB,KAAA,CAAAA,CAAA,CAAQA,QAAQ;QAAX;UAELD,IAAA,CAAAA,CAAA,CAAO5C,OAAO,CAAA+C,MAAO;UACrBF,KAAA,CAAAA,CAAA,CAAQG,SAAS;QAAZ;MACN;MAAA,OAGC,CAAC,GAAG,CAAM,GAAQ,CAAR,CAAAT,IAAI,CAAArB,GAAG,CAAC,CAAgB,aAAK,CAAL,KAAK,CACrC,CAAC,GAAG,CAAQ,KAAC,CAAD,GAAC,CACX,CAAC,IAAI,CAAQ,KAAc,CAAd,CAAA2B,KAAK,IAAI,KAAI,CAAC,CAAYF,QAAS,CAATA,UAAQ,CAAC,CAC7CC,KAAG,CACN,EAFC,IAAI,CAGP,EAJC,GAAG,CAKJ,CAAC,IAAI,CAAWD,QAAS,CAATA,UAAQ,CAAC,CAAQD,IAAS,CAATA,UAAQ,CAAC,CACvC,CAAAH,IAAI,CAAApB,KAAK,CACZ,EAFC,IAAI,CAGP,EATC,GAAG,CASE;IAAA,CAET,CAAC;IAAAG,CAAA,MAAAU,gBAAA;IAAAV,CAAA,MAAAI,KAAA;IAAAJ,CAAA,MAAAe,EAAA;EAAA;IAAAA,EAAA,GAAAf,CAAA;EAAA;EAAA,IAAA2B,EAAA;EAAA,IAAA3B,CAAA,QAAAe,EAAA;IAhCJY,EAAA,IAAC,GAAG,CAAe,aAAQ,CAAR,QAAQ,CAAa,UAAC,CAAD,GAAC,CACtC,CAAAZ,EA+BA,CACH,EAjCC,GAAG,CAiCE;IAAAf,CAAA,MAAAe,EAAA;IAAAf,CAAA,OAAA2B,EAAA;EAAA;IAAAA,EAAA,GAAA3B,CAAA;EAAA;EAAA,IAAA4B,EAAA;EAAA,IAAA5B,CAAA,SAAAE,GAAA,IAAAF,CAAA,SAAAa,EAAA,IAAAb,CAAA,SAAAc,EAAA,IAAAd,CAAA,SAAA2B,EAAA;IA9CRC,EAAA,IAAC,GAAG,CAAM1B,GAAG,CAAHA,IAAE,CAAC,CAAgB,aAAQ,CAAR,QAAQ,CAAW,QAAC,CAAD,GAAC,CAAY,QAAC,CAAD,GAAC,CAC5D,CAAAW,EAIK,CAEJ,CAAAC,EAID,CAEA,CAAAa,EAiCK,CACP,EA/CC,GAAG,CA+CE;IAAA3B,CAAA,OAAAE,GAAA;IAAAF,CAAA,OAAAa,EAAA;IAAAb,CAAA,OAAAc,EAAA;IAAAd,CAAA,OAAA2B,EAAA;IAAA3B,CAAA,OAAA4B,EAAA;EAAA;IAAAA,EAAA,GAAA5B,CAAA;EAAA;EAAA,OA/CN4B,EA+CM;AAAA;;AAIV;AACA;AACA;AACA;AACA,OAAO,eAAeC,oBAAoBA,CACxCC,IAAI,EAAEjD,IAAI,EACVY,SAAS,EAAE,MAAM,CAClB,EAAEsC,OAAO,CAAC1C,cAAc,CAAC,CAAC;EACzB;EACA,IAAI2C,OAAO,EAAE,CAACf,IAAI,EAAE7B,oBAAoB,EAAE,GAAG,IAAI,GAAG4C,CAAA,KAAM,CAAC,CAAC;EAE5D,SAASC,uBAAuBA,CAAA,CAAE,EAAEtD,KAAK,CAACuD,SAAS,CAAC;IAClD,MAAM,CAACjB,IAAI,EAAEkB,QAAQ,CAAC,GAAGvD,QAAQ,CAACQ,oBAAoB,CAAC,CAAC,YAAY,CAAC;IACrE4C,OAAO,GAAGG,QAAQ;IAClB,OAAO,CAAC,gBAAgB,CAAC,WAAW,CAAC,CAAClB,IAAI,CAAC,CAAC,SAAS,CAAC,CAACxB,SAAS,CAAC,GAAG;EACtE;EAEAqC,IAAI,CAACM,MAAM,CACT,CAAC,gBAAgB;AACrB,MAAM,CAAC,uBAAuB;AAC9B,IAAI,EAAE,gBAAgB,CACpB,CAAC;EAED,MAAMC,MAAM,GAAG,MAAM/C,yBAAyB,CAACG,SAAS,EAAEuC,OAAO,CAAC;EAClEA,OAAO,CAAC,cAAc,CAAC;EACvB,MAAM;IAAEM,UAAU;IAAEC;EAAY,CAAC,GAAG,MAAMrD,+BAA+B,CACvEmD,MAAM,CAACG,MACT,CAAC;EACD,OAAO;IACLC,QAAQ,EAAEtD,gCAAgC,CAACkD,MAAM,CAACK,GAAG,EAAEH,WAAW,CAAC;IACnED;EACF,CAAC;AACH","ignoreList":[]}