TeleportProgress.tsx
components/TeleportProgress.tsx
140
Lines
16142
Bytes
2
Exports
8
Imports
10
Keywords
What this is
This page documents one file from the repository and includes its full source so you can read it without leaving the docs site.
Beginner explanation
This file is one piece of the larger system. Its name, directory, imports, and exports show where it fits. Start by reading the exports and related files first.
How it is used
Start from the exports list and related files. Those are the easiest clues for where this file fits into the system.
Expert explanation
Architecturally, this file intersects with ui-flow. It contains 140 lines, 8 detected imports, and 2 detected exports.
Important relationships
Detected exports
TeleportProgressteleportWithProgress
Keywords
sessionidtextelsecolorcurrentsteplabelcurrentstepindexstepsetstepreact
Detected imports
react/compiler-runtimefiguresreactreact../ink.js../ink.js../state/AppState.js../utils/teleport.js
Source notes
This page embeds the full file contents. Small or leaf files are still indexed honestly instead of being over-explained.
Full source
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":"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","ignoreList":[]}