source dump of claude code
0
fork

Configure Feed

Select the types of activity you want to include in your feed.

at main 377 lines 40 kB view raw
1import { c as _c } from "react/compiler-runtime"; 2import * as React from 'react'; 3import { useEffect, useState } from 'react'; 4import { extraUsage as extraUsageCommand } from 'src/commands/extra-usage/index.js'; 5import { formatCost } from 'src/cost-tracker.js'; 6import { getSubscriptionType } from 'src/utils/auth.js'; 7import { useTerminalSize } from '../../hooks/useTerminalSize.js'; 8import { Box, Text } from '../../ink.js'; 9import { useKeybinding } from '../../keybindings/useKeybinding.js'; 10import { type ExtraUsage, fetchUtilization, type RateLimit, type Utilization } from '../../services/api/usage.js'; 11import { formatResetText } from '../../utils/format.js'; 12import { logError } from '../../utils/log.js'; 13import { jsonStringify } from '../../utils/slowOperations.js'; 14import { ConfigurableShortcutHint } from '../ConfigurableShortcutHint.js'; 15import { Byline } from '../design-system/Byline.js'; 16import { ProgressBar } from '../design-system/ProgressBar.js'; 17import { isEligibleForOverageCreditGrant, OverageCreditUpsell } from '../LogoV2/OverageCreditUpsell.js'; 18type LimitBarProps = { 19 title: string; 20 limit: RateLimit; 21 maxWidth: number; 22 showTimeInReset?: boolean; 23 extraSubtext?: string; 24}; 25function LimitBar(t0) { 26 const $ = _c(34); 27 const { 28 title, 29 limit, 30 maxWidth, 31 showTimeInReset: t1, 32 extraSubtext 33 } = t0; 34 const showTimeInReset = t1 === undefined ? true : t1; 35 const { 36 utilization, 37 resets_at 38 } = limit; 39 if (utilization === null) { 40 return null; 41 } 42 const usedText = `${Math.floor(utilization)}% used`; 43 let subtext; 44 if (resets_at) { 45 let t2; 46 if ($[0] !== resets_at || $[1] !== showTimeInReset) { 47 t2 = formatResetText(resets_at, true, showTimeInReset); 48 $[0] = resets_at; 49 $[1] = showTimeInReset; 50 $[2] = t2; 51 } else { 52 t2 = $[2]; 53 } 54 subtext = `Resets ${t2}`; 55 } 56 if (extraSubtext) { 57 if (subtext) { 58 subtext = `${extraSubtext} · ${subtext}`; 59 } else { 60 subtext = extraSubtext; 61 } 62 } 63 if (maxWidth >= 62) { 64 let t2; 65 if ($[3] !== title) { 66 t2 = <Text bold={true}>{title}</Text>; 67 $[3] = title; 68 $[4] = t2; 69 } else { 70 t2 = $[4]; 71 } 72 const t3 = utilization / 100; 73 let t4; 74 if ($[5] !== t3) { 75 t4 = <ProgressBar ratio={t3} width={50} fillColor="rate_limit_fill" emptyColor="rate_limit_empty" />; 76 $[5] = t3; 77 $[6] = t4; 78 } else { 79 t4 = $[6]; 80 } 81 let t5; 82 if ($[7] !== usedText) { 83 t5 = <Text>{usedText}</Text>; 84 $[7] = usedText; 85 $[8] = t5; 86 } else { 87 t5 = $[8]; 88 } 89 let t6; 90 if ($[9] !== t4 || $[10] !== t5) { 91 t6 = <Box flexDirection="row" gap={1}>{t4}{t5}</Box>; 92 $[9] = t4; 93 $[10] = t5; 94 $[11] = t6; 95 } else { 96 t6 = $[11]; 97 } 98 let t7; 99 if ($[12] !== subtext) { 100 t7 = subtext && <Text dimColor={true}>{subtext}</Text>; 101 $[12] = subtext; 102 $[13] = t7; 103 } else { 104 t7 = $[13]; 105 } 106 let t8; 107 if ($[14] !== t2 || $[15] !== t6 || $[16] !== t7) { 108 t8 = <Box flexDirection="column">{t2}{t6}{t7}</Box>; 109 $[14] = t2; 110 $[15] = t6; 111 $[16] = t7; 112 $[17] = t8; 113 } else { 114 t8 = $[17]; 115 } 116 return t8; 117 } else { 118 let t2; 119 if ($[18] !== title) { 120 t2 = <Text bold={true}>{title}</Text>; 121 $[18] = title; 122 $[19] = t2; 123 } else { 124 t2 = $[19]; 125 } 126 let t3; 127 if ($[20] !== subtext) { 128 t3 = subtext && <><Text> </Text><Text dimColor={true}>· {subtext}</Text></>; 129 $[20] = subtext; 130 $[21] = t3; 131 } else { 132 t3 = $[21]; 133 } 134 let t4; 135 if ($[22] !== t2 || $[23] !== t3) { 136 t4 = <Text>{t2}{t3}</Text>; 137 $[22] = t2; 138 $[23] = t3; 139 $[24] = t4; 140 } else { 141 t4 = $[24]; 142 } 143 const t5 = utilization / 100; 144 let t6; 145 if ($[25] !== maxWidth || $[26] !== t5) { 146 t6 = <ProgressBar ratio={t5} width={maxWidth} fillColor="rate_limit_fill" emptyColor="rate_limit_empty" />; 147 $[25] = maxWidth; 148 $[26] = t5; 149 $[27] = t6; 150 } else { 151 t6 = $[27]; 152 } 153 let t7; 154 if ($[28] !== usedText) { 155 t7 = <Text>{usedText}</Text>; 156 $[28] = usedText; 157 $[29] = t7; 158 } else { 159 t7 = $[29]; 160 } 161 let t8; 162 if ($[30] !== t4 || $[31] !== t6 || $[32] !== t7) { 163 t8 = <Box flexDirection="column">{t4}{t6}{t7}</Box>; 164 $[30] = t4; 165 $[31] = t6; 166 $[32] = t7; 167 $[33] = t8; 168 } else { 169 t8 = $[33]; 170 } 171 return t8; 172 } 173} 174export function Usage(): React.ReactNode { 175 const [utilization, setUtilization] = useState<Utilization | null>(null); 176 const [error, setError] = useState<string | null>(null); 177 const [isLoading, setIsLoading] = useState(true); 178 const { 179 columns 180 } = useTerminalSize(); 181 const availableWidth = columns - 2; // 2 for screen padding 182 const maxWidth = Math.min(availableWidth, 80); 183 const loadUtilization = React.useCallback(async () => { 184 setIsLoading(true); 185 setError(null); 186 try { 187 const data = await fetchUtilization(); 188 setUtilization(data); 189 } catch (err) { 190 logError(err as Error); 191 const axiosError = err as { 192 response?: { 193 data?: unknown; 194 }; 195 }; 196 const responseBody = axiosError.response?.data ? jsonStringify(axiosError.response.data) : undefined; 197 setError(responseBody ? `Failed to load usage data: ${responseBody}` : 'Failed to load usage data'); 198 } finally { 199 setIsLoading(false); 200 } 201 }, []); 202 useEffect(() => { 203 void loadUtilization(); 204 }, [loadUtilization]); 205 useKeybinding('settings:retry', () => { 206 void loadUtilization(); 207 }, { 208 context: 'Settings', 209 isActive: !!error && !isLoading 210 }); 211 if (error) { 212 return <Box flexDirection="column" gap={1}> 213 <Text color="error">Error: {error}</Text> 214 <Text dimColor> 215 <Byline> 216 <ConfigurableShortcutHint action="settings:retry" context="Settings" fallback="r" description="retry" /> 217 <ConfigurableShortcutHint action="confirm:no" context="Settings" fallback="Esc" description="cancel" /> 218 </Byline> 219 </Text> 220 </Box>; 221 } 222 if (!utilization) { 223 return <Box flexDirection="column" gap={1}> 224 <Text dimColor>Loading usage data</Text> 225 <Text dimColor> 226 <ConfigurableShortcutHint action="confirm:no" context="Settings" fallback="Esc" description="cancel" /> 227 </Text> 228 </Box>; 229 } 230 231 // Only Max and Team plans have a Sonnet limit that differs from the weekly 232 // limit (see rateLimitMessages.ts). For other plans the bar is redundant. 233 // Show for null (unknown plan) to stay consistent with rateLimitMessages.ts, 234 // which labels it "Sonnet limit" in that case. 235 const subscriptionType = getSubscriptionType(); 236 const showSonnetBar = subscriptionType === 'max' || subscriptionType === 'team' || subscriptionType === null; 237 const limits = [{ 238 title: 'Current session', 239 limit: utilization.five_hour 240 }, { 241 title: 'Current week (all models)', 242 limit: utilization.seven_day 243 }, ...(showSonnetBar ? [{ 244 title: 'Current week (Sonnet only)', 245 limit: utilization.seven_day_sonnet 246 }] : [])]; 247 return <Box flexDirection="column" gap={1} width="100%"> 248 {limits.some(({ 249 limit 250 }) => limit) || <Text dimColor>/usage is only available for subscription plans.</Text>} 251 252 {limits.map(({ 253 title, 254 limit: limit_0 255 }) => limit_0 && <LimitBar key={title} title={title} limit={limit_0} maxWidth={maxWidth} />)} 256 257 {utilization.extra_usage && <ExtraUsageSection extraUsage={utilization.extra_usage} maxWidth={maxWidth} />} 258 259 {isEligibleForOverageCreditGrant() && <OverageCreditUpsell maxWidth={maxWidth} />} 260 261 <Text dimColor> 262 <ConfigurableShortcutHint action="confirm:no" context="Settings" fallback="Esc" description="cancel" /> 263 </Text> 264 </Box>; 265} 266type ExtraUsageSectionProps = { 267 extraUsage: ExtraUsage; 268 maxWidth: number; 269}; 270const EXTRA_USAGE_SECTION_TITLE = 'Extra usage'; 271function ExtraUsageSection(t0) { 272 const $ = _c(20); 273 const { 274 extraUsage, 275 maxWidth 276 } = t0; 277 const subscriptionType = getSubscriptionType(); 278 const isProOrMax = subscriptionType === "pro" || subscriptionType === "max"; 279 if (!isProOrMax) { 280 return false; 281 } 282 if (!extraUsage.is_enabled) { 283 if (extraUsageCommand.isEnabled()) { 284 let t1; 285 if ($[0] === Symbol.for("react.memo_cache_sentinel")) { 286 t1 = <Box flexDirection="column"><Text bold={true}>{EXTRA_USAGE_SECTION_TITLE}</Text><Text dimColor={true}>Extra usage not enabled · /extra-usage to enable</Text></Box>; 287 $[0] = t1; 288 } else { 289 t1 = $[0]; 290 } 291 return t1; 292 } 293 return null; 294 } 295 if (extraUsage.monthly_limit === null) { 296 let t1; 297 if ($[1] === Symbol.for("react.memo_cache_sentinel")) { 298 t1 = <Box flexDirection="column"><Text bold={true}>{EXTRA_USAGE_SECTION_TITLE}</Text><Text dimColor={true}>Unlimited</Text></Box>; 299 $[1] = t1; 300 } else { 301 t1 = $[1]; 302 } 303 return t1; 304 } 305 if (typeof extraUsage.used_credits !== "number" || typeof extraUsage.utilization !== "number") { 306 return null; 307 } 308 const t1 = extraUsage.used_credits / 100; 309 let t2; 310 if ($[2] !== t1) { 311 t2 = formatCost(t1, 2); 312 $[2] = t1; 313 $[3] = t2; 314 } else { 315 t2 = $[3]; 316 } 317 const formattedUsedCredits = t2; 318 const t3 = extraUsage.monthly_limit / 100; 319 let t4; 320 if ($[4] !== t3) { 321 t4 = formatCost(t3, 2); 322 $[4] = t3; 323 $[5] = t4; 324 } else { 325 t4 = $[5]; 326 } 327 const formattedMonthlyLimit = t4; 328 let T0; 329 let t5; 330 let t6; 331 let t7; 332 if ($[6] !== extraUsage.utilization) { 333 const now = new Date(); 334 const oneMonthReset = new Date(now.getFullYear(), now.getMonth() + 1, 1); 335 T0 = LimitBar; 336 t7 = EXTRA_USAGE_SECTION_TITLE; 337 t5 = extraUsage.utilization; 338 t6 = oneMonthReset.toISOString(); 339 $[6] = extraUsage.utilization; 340 $[7] = T0; 341 $[8] = t5; 342 $[9] = t6; 343 $[10] = t7; 344 } else { 345 T0 = $[7]; 346 t5 = $[8]; 347 t6 = $[9]; 348 t7 = $[10]; 349 } 350 let t8; 351 if ($[11] !== t5 || $[12] !== t6) { 352 t8 = { 353 utilization: t5, 354 resets_at: t6 355 }; 356 $[11] = t5; 357 $[12] = t6; 358 $[13] = t8; 359 } else { 360 t8 = $[13]; 361 } 362 const t9 = `${formattedUsedCredits} / ${formattedMonthlyLimit} spent`; 363 let t10; 364 if ($[14] !== T0 || $[15] !== maxWidth || $[16] !== t7 || $[17] !== t8 || $[18] !== t9) { 365 t10 = <T0 title={t7} limit={t8} showTimeInReset={false} extraSubtext={t9} maxWidth={maxWidth} />; 366 $[14] = T0; 367 $[15] = maxWidth; 368 $[16] = t7; 369 $[17] = t8; 370 $[18] = t9; 371 $[19] = t10; 372 } else { 373 t10 = $[19]; 374 } 375 return t10; 376} 377//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useEffect","useState","extraUsage","extraUsageCommand","formatCost","getSubscriptionType","useTerminalSize","Box","Text","useKeybinding","ExtraUsage","fetchUtilization","RateLimit","Utilization","formatResetText","logError","jsonStringify","ConfigurableShortcutHint","Byline","ProgressBar","isEligibleForOverageCreditGrant","OverageCreditUpsell","LimitBarProps","title","limit","maxWidth","showTimeInReset","extraSubtext","LimitBar","t0","$","_c","t1","undefined","utilization","resets_at","usedText","Math","floor","subtext","t2","t3","t4","maxBarWidth","t5","t6","t7","t8","Usage","ReactNode","setUtilization","error","setError","isLoading","setIsLoading","columns","availableWidth","min","loadUtilization","useCallback","data","err","Error","axiosError","response","responseBody","context","isActive","subscriptionType","showSonnetBar","limits","five_hour","seven_day","seven_day_sonnet","some","map","extra_usage","ExtraUsageSectionProps","EXTRA_USAGE_SECTION_TITLE","ExtraUsageSection","isProOrMax","is_enabled","isEnabled","Symbol","for","monthly_limit","used_credits","formattedUsedCredits","formattedMonthlyLimit","T0","now","Date","oneMonthReset","getFullYear","getMonth","toISOString","t9","t10"],"sources":["Usage.tsx"],"sourcesContent":["import * as React from 'react'\nimport { useEffect, useState } from 'react'\nimport { extraUsage as extraUsageCommand } from 'src/commands/extra-usage/index.js'\nimport { formatCost } from 'src/cost-tracker.js'\nimport { getSubscriptionType } from 'src/utils/auth.js'\nimport { useTerminalSize } from '../../hooks/useTerminalSize.js'\nimport { Box, Text } from '../../ink.js'\nimport { useKeybinding } from '../../keybindings/useKeybinding.js'\nimport {\n  type ExtraUsage,\n  fetchUtilization,\n  type RateLimit,\n  type Utilization,\n} from '../../services/api/usage.js'\nimport { formatResetText } from '../../utils/format.js'\nimport { logError } from '../../utils/log.js'\nimport { jsonStringify } from '../../utils/slowOperations.js'\nimport { ConfigurableShortcutHint } from '../ConfigurableShortcutHint.js'\nimport { Byline } from '../design-system/Byline.js'\nimport { ProgressBar } from '../design-system/ProgressBar.js'\nimport {\n  isEligibleForOverageCreditGrant,\n  OverageCreditUpsell,\n} from '../LogoV2/OverageCreditUpsell.js'\n\ntype LimitBarProps = {\n  title: string\n  limit: RateLimit\n  maxWidth: number\n  showTimeInReset?: boolean\n  extraSubtext?: string\n}\n\nfunction LimitBar({\n  title,\n  limit,\n  maxWidth,\n  showTimeInReset = true,\n  extraSubtext,\n}: LimitBarProps): React.ReactNode {\n  const { utilization, resets_at } = limit\n  if (utilization === null) {\n    return null\n  }\n\n  // Calculate usage percentage\n  const usedText = `${Math.floor(utilization)}% used`\n\n  let subtext: string | undefined\n  if (resets_at) {\n    subtext = `Resets ${formatResetText(resets_at, true, showTimeInReset)}`\n  }\n\n  if (extraSubtext) {\n    if (subtext) {\n      subtext = `${extraSubtext} · ${subtext}`\n    } else {\n      subtext = extraSubtext\n    }\n  }\n\n  const maxBarWidth = 50\n  const usedLabelSpace = 12\n  if (maxWidth >= maxBarWidth + usedLabelSpace) {\n    return (\n      <Box flexDirection=\"column\">\n        <Text bold>{title}</Text>\n        <Box flexDirection=\"row\" gap={1}>\n          <ProgressBar\n            ratio={utilization / 100}\n            width={maxBarWidth}\n            fillColor=\"rate_limit_fill\"\n            emptyColor=\"rate_limit_empty\"\n          />\n          <Text>{usedText}</Text>\n        </Box>\n        {subtext && <Text dimColor>{subtext}</Text>}\n      </Box>\n    )\n  } else {\n    return (\n      <Box flexDirection=\"column\">\n        <Text>\n          <Text bold>{title}</Text>\n          {subtext && (\n            <>\n              <Text> </Text>\n              <Text dimColor>· {subtext}</Text>\n            </>\n          )}\n        </Text>\n        <ProgressBar\n          ratio={utilization / 100}\n          width={maxWidth}\n          fillColor=\"rate_limit_fill\"\n          emptyColor=\"rate_limit_empty\"\n        />\n        <Text>{usedText}</Text>\n      </Box>\n    )\n  }\n}\n\nexport function Usage(): React.ReactNode {\n  const [utilization, setUtilization] = useState<Utilization | null>(null)\n  const [error, setError] = useState<string | null>(null)\n  const [isLoading, setIsLoading] = useState(true)\n  const { columns } = useTerminalSize()\n\n  const availableWidth = columns - 2 // 2 for screen padding\n  const maxWidth = Math.min(availableWidth, 80)\n\n  const loadUtilization = React.useCallback(async () => {\n    setIsLoading(true)\n    setError(null)\n    try {\n      const data = await fetchUtilization()\n      setUtilization(data)\n    } catch (err) {\n      logError(err as Error)\n      const axiosError = err as { response?: { data?: unknown } }\n      const responseBody = axiosError.response?.data\n        ? jsonStringify(axiosError.response.data)\n        : undefined\n      setError(\n        responseBody\n          ? `Failed to load usage data: ${responseBody}`\n          : 'Failed to load usage data',\n      )\n    } finally {\n      setIsLoading(false)\n    }\n  }, [])\n\n  useEffect(() => {\n    void loadUtilization()\n  }, [loadUtilization])\n\n  useKeybinding(\n    'settings:retry',\n    () => {\n      void loadUtilization()\n    },\n    { context: 'Settings', isActive: !!error && !isLoading },\n  )\n\n  if (error) {\n    return (\n      <Box flexDirection=\"column\" gap={1}>\n        <Text color=\"error\">Error: {error}</Text>\n        <Text dimColor>\n          <Byline>\n            <ConfigurableShortcutHint\n              action=\"settings:retry\"\n              context=\"Settings\"\n              fallback=\"r\"\n              description=\"retry\"\n            />\n            <ConfigurableShortcutHint\n              action=\"confirm:no\"\n              context=\"Settings\"\n              fallback=\"Esc\"\n              description=\"cancel\"\n            />\n          </Byline>\n        </Text>\n      </Box>\n    )\n  }\n\n  if (!utilization) {\n    return (\n      <Box flexDirection=\"column\" gap={1}>\n        <Text dimColor>Loading usage data…</Text>\n        <Text dimColor>\n          <ConfigurableShortcutHint\n            action=\"confirm:no\"\n            context=\"Settings\"\n            fallback=\"Esc\"\n            description=\"cancel\"\n          />\n        </Text>\n      </Box>\n    )\n  }\n\n  // Only Max and Team plans have a Sonnet limit that differs from the weekly\n  // limit (see rateLimitMessages.ts). For other plans the bar is redundant.\n  // Show for null (unknown plan) to stay consistent with rateLimitMessages.ts,\n  // which labels it \"Sonnet limit\" in that case.\n  const subscriptionType = getSubscriptionType()\n  const showSonnetBar =\n    subscriptionType === 'max' ||\n    subscriptionType === 'team' ||\n    subscriptionType === null\n\n  const limits = [\n    {\n      title: 'Current session',\n      limit: utilization.five_hour,\n    },\n    {\n      title: 'Current week (all models)',\n      limit: utilization.seven_day,\n    },\n    ...(showSonnetBar\n      ? [\n          {\n            title: 'Current week (Sonnet only)',\n            limit: utilization.seven_day_sonnet,\n          },\n        ]\n      : []),\n  ]\n\n  return (\n    <Box flexDirection=\"column\" gap={1} width=\"100%\">\n      {limits.some(({ limit }) => limit) || (\n        <Text dimColor>/usage is only available for subscription plans.</Text>\n      )}\n\n      {limits.map(\n        ({ title, limit }) =>\n          limit && (\n            <LimitBar\n              key={title}\n              title={title}\n              limit={limit}\n              maxWidth={maxWidth}\n            />\n          ),\n      )}\n\n      {utilization.extra_usage && (\n        <ExtraUsageSection\n          extraUsage={utilization.extra_usage}\n          maxWidth={maxWidth}\n        />\n      )}\n\n      {isEligibleForOverageCreditGrant() && (\n        <OverageCreditUpsell maxWidth={maxWidth} />\n      )}\n\n      <Text dimColor>\n        <ConfigurableShortcutHint\n          action=\"confirm:no\"\n          context=\"Settings\"\n          fallback=\"Esc\"\n          description=\"cancel\"\n        />\n      </Text>\n    </Box>\n  )\n}\n\ntype ExtraUsageSectionProps = {\n  extraUsage: ExtraUsage\n  maxWidth: number\n}\n\nconst EXTRA_USAGE_SECTION_TITLE = 'Extra usage'\n\nfunction ExtraUsageSection({\n  extraUsage,\n  maxWidth,\n}: ExtraUsageSectionProps): React.ReactNode {\n  const subscriptionType = getSubscriptionType()\n  const isProOrMax = subscriptionType === 'pro' || subscriptionType === 'max'\n  if (!isProOrMax) {\n    // Only show to Pro and Max, consistent with claude.ai non-admin usage settings\n    return false\n  }\n\n  if (!extraUsage.is_enabled) {\n    if (extraUsageCommand.isEnabled()) {\n      return (\n        <Box flexDirection=\"column\">\n          <Text bold>{EXTRA_USAGE_SECTION_TITLE}</Text>\n          <Text dimColor>Extra usage not enabled · /extra-usage to enable</Text>\n        </Box>\n      )\n    }\n\n    return null\n  }\n\n  if (extraUsage.monthly_limit === null) {\n    return (\n      <Box flexDirection=\"column\">\n        <Text bold>{EXTRA_USAGE_SECTION_TITLE}</Text>\n        <Text dimColor>Unlimited</Text>\n      </Box>\n    )\n  }\n\n  if (\n    typeof extraUsage.used_credits !== 'number' ||\n    typeof extraUsage.utilization !== 'number'\n  ) {\n    return null\n  }\n\n  const formattedUsedCredits = formatCost(extraUsage.used_credits / 100, 2)\n  const formattedMonthlyLimit = formatCost(extraUsage.monthly_limit / 100, 2)\n  const now = new Date()\n  const oneMonthReset = new Date(now.getFullYear(), now.getMonth() + 1, 1)\n\n  return (\n    <LimitBar\n      title={EXTRA_USAGE_SECTION_TITLE}\n      limit={{\n        utilization: extraUsage.utilization,\n        // Not applicable for enterprises, but for now we don't render this for them\n        resets_at: oneMonthReset.toISOString(),\n      }}\n      showTimeInReset={false}\n      extraSubtext={`${formattedUsedCredits} / ${formattedMonthlyLimit} spent`}\n      maxWidth={maxWidth}\n    />\n  )\n}\n"],"mappings":"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","ignoreList":[]}