source dump of claude code
at main 189 lines 19 kB view raw
1import { c as _c } from "react/compiler-runtime"; 2import React, { useCallback, useEffect, useState } from 'react'; 3import { checkIsGitClean, checkNeedsClaudeAiLogin } from 'src/utils/background/remote/preconditions.js'; 4import { gracefulShutdownSync } from 'src/utils/gracefulShutdown.js'; 5import { Box, Text } from '../ink.js'; 6import { ConsoleOAuthFlow } from './ConsoleOAuthFlow.js'; 7import { Select } from './CustomSelect/index.js'; 8import { Dialog } from './design-system/Dialog.js'; 9import { TeleportStash } from './TeleportStash.js'; 10export type TeleportLocalErrorType = 'needsLogin' | 'needsGitStash'; 11type TeleportErrorProps = { 12 onComplete: () => void; 13 errorsToIgnore?: ReadonlySet<TeleportLocalErrorType>; 14}; 15 16// Module-level sentinel so the default parameter has stable identity. 17// Previously `= new Set()` created a fresh Set every render, which put 18// a new object in checkErrors' deps and caused the mount effect to 19// re-fire on every render. 20const EMPTY_ERRORS_TO_IGNORE: ReadonlySet<TeleportLocalErrorType> = new Set(); 21export function TeleportError(t0) { 22 const $ = _c(18); 23 const { 24 onComplete, 25 errorsToIgnore: t1 26 } = t0; 27 const errorsToIgnore = t1 === undefined ? EMPTY_ERRORS_TO_IGNORE : t1; 28 const [currentError, setCurrentError] = useState(null); 29 const [isLoggingIn, setIsLoggingIn] = useState(false); 30 let t2; 31 if ($[0] !== errorsToIgnore || $[1] !== onComplete) { 32 t2 = async () => { 33 const currentErrors = await getTeleportErrors(); 34 const filteredErrors = new Set(Array.from(currentErrors).filter(error => !errorsToIgnore.has(error))); 35 if (filteredErrors.size === 0) { 36 onComplete(); 37 return; 38 } 39 if (filteredErrors.has("needsLogin")) { 40 setCurrentError("needsLogin"); 41 } else { 42 if (filteredErrors.has("needsGitStash")) { 43 setCurrentError("needsGitStash"); 44 } 45 } 46 }; 47 $[0] = errorsToIgnore; 48 $[1] = onComplete; 49 $[2] = t2; 50 } else { 51 t2 = $[2]; 52 } 53 const checkErrors = t2; 54 let t3; 55 let t4; 56 if ($[3] !== checkErrors) { 57 t3 = () => { 58 checkErrors(); 59 }; 60 t4 = [checkErrors]; 61 $[3] = checkErrors; 62 $[4] = t3; 63 $[5] = t4; 64 } else { 65 t3 = $[4]; 66 t4 = $[5]; 67 } 68 useEffect(t3, t4); 69 const onCancel = _temp; 70 let t5; 71 if ($[6] !== checkErrors) { 72 t5 = () => { 73 setIsLoggingIn(false); 74 checkErrors(); 75 }; 76 $[6] = checkErrors; 77 $[7] = t5; 78 } else { 79 t5 = $[7]; 80 } 81 const handleLoginComplete = t5; 82 let t6; 83 if ($[8] === Symbol.for("react.memo_cache_sentinel")) { 84 t6 = () => { 85 setIsLoggingIn(true); 86 }; 87 $[8] = t6; 88 } else { 89 t6 = $[8]; 90 } 91 const handleLoginWithClaudeAI = t6; 92 let t7; 93 if ($[9] === Symbol.for("react.memo_cache_sentinel")) { 94 t7 = value => { 95 if (value === "login") { 96 handleLoginWithClaudeAI(); 97 } else { 98 onCancel(); 99 } 100 }; 101 $[9] = t7; 102 } else { 103 t7 = $[9]; 104 } 105 const handleLoginDialogSelect = t7; 106 let t8; 107 if ($[10] !== checkErrors) { 108 t8 = () => { 109 checkErrors(); 110 }; 111 $[10] = checkErrors; 112 $[11] = t8; 113 } else { 114 t8 = $[11]; 115 } 116 const handleStashComplete = t8; 117 if (!currentError) { 118 return null; 119 } 120 switch (currentError) { 121 case "needsGitStash": 122 { 123 let t9; 124 if ($[12] !== handleStashComplete) { 125 t9 = <TeleportStash onStashAndContinue={handleStashComplete} onCancel={onCancel} />; 126 $[12] = handleStashComplete; 127 $[13] = t9; 128 } else { 129 t9 = $[13]; 130 } 131 return t9; 132 } 133 case "needsLogin": 134 { 135 if (isLoggingIn) { 136 let t9; 137 if ($[14] !== handleLoginComplete) { 138 t9 = <ConsoleOAuthFlow onDone={handleLoginComplete} mode="login" forceLoginMethod="claudeai" />; 139 $[14] = handleLoginComplete; 140 $[15] = t9; 141 } else { 142 t9 = $[15]; 143 } 144 return t9; 145 } 146 let t9; 147 if ($[16] === Symbol.for("react.memo_cache_sentinel")) { 148 t9 = <Box flexDirection="column"><Text dimColor={true}>Teleport requires a Claude.ai account.</Text><Text dimColor={true}>Your Claude Pro/Max subscription will be used by Claude Code.</Text></Box>; 149 $[16] = t9; 150 } else { 151 t9 = $[16]; 152 } 153 let t10; 154 if ($[17] === Symbol.for("react.memo_cache_sentinel")) { 155 t10 = <Dialog title="Log in to Claude" onCancel={onCancel}>{t9}<Select options={[{ 156 label: "Login with Claude account", 157 value: "login" 158 }, { 159 label: "Exit", 160 value: "exit" 161 }]} onChange={handleLoginDialogSelect} /></Dialog>; 162 $[17] = t10; 163 } else { 164 t10 = $[17]; 165 } 166 return t10; 167 } 168 } 169} 170 171/** 172 * Gets current teleport errors that need to be resolved 173 * @returns Set of teleport error types that need to be handled 174 */ 175function _temp() { 176 gracefulShutdownSync(0); 177} 178export async function getTeleportErrors(): Promise<Set<TeleportLocalErrorType>> { 179 const errors = new Set<TeleportLocalErrorType>(); 180 const [needsLogin, isGitClean] = await Promise.all([checkNeedsClaudeAiLogin(), checkIsGitClean()]); 181 if (needsLogin) { 182 errors.add('needsLogin'); 183 } 184 if (!isGitClean) { 185 errors.add('needsGitStash'); 186 } 187 return errors; 188} 189//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useCallback","useEffect","useState","checkIsGitClean","checkNeedsClaudeAiLogin","gracefulShutdownSync","Box","Text","ConsoleOAuthFlow","Select","Dialog","TeleportStash","TeleportLocalErrorType","TeleportErrorProps","onComplete","errorsToIgnore","ReadonlySet","EMPTY_ERRORS_TO_IGNORE","Set","TeleportError","t0","$","_c","t1","undefined","currentError","setCurrentError","isLoggingIn","setIsLoggingIn","t2","currentErrors","getTeleportErrors","filteredErrors","Array","from","filter","error","has","size","checkErrors","t3","t4","onCancel","_temp","t5","handleLoginComplete","t6","Symbol","for","handleLoginWithClaudeAI","t7","value","handleLoginDialogSelect","t8","handleStashComplete","t9","t10","label","Promise","errors","needsLogin","isGitClean","all","add"],"sources":["TeleportError.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useState } from 'react'\nimport {\n  checkIsGitClean,\n  checkNeedsClaudeAiLogin,\n} from 'src/utils/background/remote/preconditions.js'\nimport { gracefulShutdownSync } from 'src/utils/gracefulShutdown.js'\nimport { Box, Text } from '../ink.js'\nimport { ConsoleOAuthFlow } from './ConsoleOAuthFlow.js'\nimport { Select } from './CustomSelect/index.js'\nimport { Dialog } from './design-system/Dialog.js'\nimport { TeleportStash } from './TeleportStash.js'\n\nexport type TeleportLocalErrorType = 'needsLogin' | 'needsGitStash'\n\ntype TeleportErrorProps = {\n  onComplete: () => void\n  errorsToIgnore?: ReadonlySet<TeleportLocalErrorType>\n}\n\n// Module-level sentinel so the default parameter has stable identity.\n// Previously `= new Set()` created a fresh Set every render, which put\n// a new object in checkErrors' deps and caused the mount effect to\n// re-fire on every render.\nconst EMPTY_ERRORS_TO_IGNORE: ReadonlySet<TeleportLocalErrorType> = new Set()\n\nexport function TeleportError({\n  onComplete,\n  errorsToIgnore = EMPTY_ERRORS_TO_IGNORE,\n}: TeleportErrorProps): React.ReactNode {\n  const [currentError, setCurrentError] =\n    useState<TeleportLocalErrorType | null>(null)\n  const [isLoggingIn, setIsLoggingIn] = useState<boolean>(false)\n\n  // Check for errors on mount and when error resolution occurs\n  const checkErrors = useCallback(async () => {\n    const currentErrors = await getTeleportErrors()\n    const filteredErrors = new Set(\n      Array.from(currentErrors).filter(\n        (error: TeleportLocalErrorType) => !errorsToIgnore.has(error),\n      ),\n    )\n\n    // If no errors remain, call onComplete\n    if (filteredErrors.size === 0) {\n      onComplete()\n      return\n    }\n\n    // Set current error to handle (prioritize login over git)\n    if (filteredErrors.has('needsLogin')) {\n      setCurrentError('needsLogin')\n    } else if (filteredErrors.has('needsGitStash')) {\n      setCurrentError('needsGitStash')\n    }\n  }, [onComplete, errorsToIgnore])\n\n  // Check errors on mount\n  useEffect(() => {\n    void checkErrors()\n  }, [checkErrors])\n\n  const onCancel = useCallback(() => {\n    gracefulShutdownSync(0)\n  }, [])\n\n  const handleLoginComplete = useCallback(() => {\n    setIsLoggingIn(false)\n    void checkErrors()\n  }, [checkErrors])\n\n  const handleLoginWithClaudeAI = useCallback(() => {\n    setIsLoggingIn(true)\n  }, [setIsLoggingIn])\n\n  const handleLoginDialogSelect = useCallback(\n    (value: string) => {\n      if (value === 'login') {\n        handleLoginWithClaudeAI()\n      } else {\n        // User selected exit\n        onCancel()\n      }\n    },\n    [handleLoginWithClaudeAI, onCancel],\n  )\n\n  const handleStashComplete = useCallback(() => {\n    void checkErrors()\n  }, [checkErrors])\n\n  // Don't render anything if no current error (onComplete will be called)\n  if (!currentError) {\n    return null\n  }\n\n  switch (currentError) {\n    case 'needsGitStash':\n      return (\n        <TeleportStash\n          onStashAndContinue={handleStashComplete}\n          onCancel={onCancel}\n        />\n      )\n\n    case 'needsLogin': {\n      if (isLoggingIn) {\n        return (\n          <ConsoleOAuthFlow\n            onDone={handleLoginComplete}\n            mode=\"login\"\n            forceLoginMethod=\"claudeai\"\n          />\n        )\n      }\n\n      return (\n        <Dialog title=\"Log in to Claude\" onCancel={onCancel}>\n          <Box flexDirection=\"column\">\n            <Text dimColor>Teleport requires a Claude.ai account.</Text>\n            <Text dimColor>\n              Your Claude Pro/Max subscription will be used by Claude Code.\n            </Text>\n          </Box>\n          <Select\n            options={[\n              { label: 'Login with Claude account', value: 'login' },\n              { label: 'Exit', value: 'exit' },\n            ]}\n            onChange={handleLoginDialogSelect}\n          />\n        </Dialog>\n      )\n    }\n  }\n}\n\n/**\n * Gets current teleport errors that need to be resolved\n * @returns Set of teleport error types that need to be handled\n */\nexport async function getTeleportErrors(): Promise<\n  Set<TeleportLocalErrorType>\n> {\n  const errors = new Set<TeleportLocalErrorType>()\n\n  const [needsLogin, isGitClean] = await Promise.all([\n    checkNeedsClaudeAiLogin(),\n    checkIsGitClean(),\n  ])\n\n  if (needsLogin) {\n    errors.add('needsLogin')\n  }\n  if (!isGitClean) {\n    errors.add('needsGitStash')\n  }\n\n  return errors\n}\n"],"mappings":"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","ignoreList":[]}