/ components / Settings / Usage.tsx
Usage.tsx
  1  import { c as _c } from "react/compiler-runtime";
  2  import * as React from 'react';
  3  import { useEffect, useState } from 'react';
  4  import { extraUsage as extraUsageCommand } from 'src/commands/extra-usage/index.js';
  5  import { formatCost } from 'src/cost-tracker.js';
  6  import { getSubscriptionType } from 'src/utils/auth.js';
  7  import { useTerminalSize } from '../../hooks/useTerminalSize.js';
  8  import { Box, Text } from '../../ink.js';
  9  import { useKeybinding } from '../../keybindings/useKeybinding.js';
 10  import { type ExtraUsage, fetchUtilization, type RateLimit, type Utilization } from '../../services/api/usage.js';
 11  import { formatResetText } from '../../utils/format.js';
 12  import { logError } from '../../utils/log.js';
 13  import { jsonStringify } from '../../utils/slowOperations.js';
 14  import { ConfigurableShortcutHint } from '../ConfigurableShortcutHint.js';
 15  import { Byline } from '../design-system/Byline.js';
 16  import { ProgressBar } from '../design-system/ProgressBar.js';
 17  import { isEligibleForOverageCreditGrant, OverageCreditUpsell } from '../LogoV2/OverageCreditUpsell.js';
 18  type LimitBarProps = {
 19    title: string;
 20    limit: RateLimit;
 21    maxWidth: number;
 22    showTimeInReset?: boolean;
 23    extraSubtext?: string;
 24  };
 25  function 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  }
174  export 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  }
266  type ExtraUsageSectionProps = {
267    extraUsage: ExtraUsage;
268    maxWidth: number;
269  };
270  const EXTRA_USAGE_SECTION_TITLE = 'Extra usage';
271  function 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":[]}