Filemedium importancesource

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

  • TeleportProgress
  • teleportWithProgress

Keywords

sessionidtextelsecolorcurrentsteplabelcurrentstepindexstepsetstepreact

Detected imports

  • react/compiler-runtime
  • figures
  • react
  • react
  • ../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.

Open parent directory

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":[]}