/ hooks / notifs / useRateLimitWarningNotification.tsx
useRateLimitWarningNotification.tsx
  1  import { c as _c } from "react/compiler-runtime";
  2  import * as React from 'react';
  3  import { useEffect, useMemo, useRef, useState } from 'react';
  4  import { useNotifications } from 'src/context/notifications.js';
  5  import { Text } from 'src/ink.js';
  6  import { getRateLimitWarning, getUsingOverageText } from 'src/services/claudeAiLimits.js';
  7  import { useClaudeAiLimits } from 'src/services/claudeAiLimitsHook.js';
  8  import { getSubscriptionType } from 'src/utils/auth.js';
  9  import { hasClaudeAiBillingAccess } from 'src/utils/billing.js';
 10  import { getIsRemoteMode } from '../../bootstrap/state.js';
 11  export function useRateLimitWarningNotification(model) {
 12    const $ = _c(17);
 13    const {
 14      addNotification
 15    } = useNotifications();
 16    const claudeAiLimits = useClaudeAiLimits();
 17    let t0;
 18    if ($[0] !== claudeAiLimits || $[1] !== model) {
 19      t0 = getRateLimitWarning(claudeAiLimits, model);
 20      $[0] = claudeAiLimits;
 21      $[1] = model;
 22      $[2] = t0;
 23    } else {
 24      t0 = $[2];
 25    }
 26    const rateLimitWarning = t0;
 27    let t1;
 28    if ($[3] !== claudeAiLimits) {
 29      t1 = getUsingOverageText(claudeAiLimits);
 30      $[3] = claudeAiLimits;
 31      $[4] = t1;
 32    } else {
 33      t1 = $[4];
 34    }
 35    const usingOverageText = t1;
 36    const shownWarningRef = useRef(null);
 37    let t2;
 38    if ($[5] === Symbol.for("react.memo_cache_sentinel")) {
 39      t2 = getSubscriptionType();
 40      $[5] = t2;
 41    } else {
 42      t2 = $[5];
 43    }
 44    const subscriptionType = t2;
 45    let t3;
 46    if ($[6] === Symbol.for("react.memo_cache_sentinel")) {
 47      t3 = hasClaudeAiBillingAccess();
 48      $[6] = t3;
 49    } else {
 50      t3 = $[6];
 51    }
 52    const hasBillingAccess = t3;
 53    const isTeamOrEnterprise = subscriptionType === "team" || subscriptionType === "enterprise";
 54    const [hasShownOverageNotification, setHasShownOverageNotification] = useState(false);
 55    let t4;
 56    let t5;
 57    if ($[7] !== addNotification || $[8] !== claudeAiLimits.isUsingOverage || $[9] !== hasShownOverageNotification || $[10] !== usingOverageText) {
 58      t4 = () => {
 59        if (getIsRemoteMode()) {
 60          return;
 61        }
 62        if (claudeAiLimits.isUsingOverage && !hasShownOverageNotification && (!isTeamOrEnterprise || hasBillingAccess)) {
 63          addNotification({
 64            key: "limit-reached",
 65            text: usingOverageText,
 66            priority: "immediate"
 67          });
 68          setHasShownOverageNotification(true);
 69        } else {
 70          if (!claudeAiLimits.isUsingOverage && hasShownOverageNotification) {
 71            setHasShownOverageNotification(false);
 72          }
 73        }
 74      };
 75      t5 = [claudeAiLimits.isUsingOverage, usingOverageText, hasShownOverageNotification, addNotification, hasBillingAccess, isTeamOrEnterprise];
 76      $[7] = addNotification;
 77      $[8] = claudeAiLimits.isUsingOverage;
 78      $[9] = hasShownOverageNotification;
 79      $[10] = usingOverageText;
 80      $[11] = t4;
 81      $[12] = t5;
 82    } else {
 83      t4 = $[11];
 84      t5 = $[12];
 85    }
 86    useEffect(t4, t5);
 87    let t6;
 88    let t7;
 89    if ($[13] !== addNotification || $[14] !== rateLimitWarning) {
 90      t6 = () => {
 91        if (getIsRemoteMode()) {
 92          return;
 93        }
 94        if (rateLimitWarning && rateLimitWarning !== shownWarningRef.current) {
 95          shownWarningRef.current = rateLimitWarning;
 96          addNotification({
 97            key: "rate-limit-warning",
 98            jsx: <Text><Text color="warning">{rateLimitWarning}</Text></Text>,
 99            priority: "high"
100          });
101        }
102      };
103      t7 = [rateLimitWarning, addNotification];
104      $[13] = addNotification;
105      $[14] = rateLimitWarning;
106      $[15] = t6;
107      $[16] = t7;
108    } else {
109      t6 = $[15];
110      t7 = $[16];
111    }
112    useEffect(t6, t7);
113  }
114  //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSZWFjdCIsInVzZUVmZmVjdCIsInVzZU1lbW8iLCJ1c2VSZWYiLCJ1c2VTdGF0ZSIsInVzZU5vdGlmaWNhdGlvbnMiLCJUZXh0IiwiZ2V0UmF0ZUxpbWl0V2FybmluZyIsImdldFVzaW5nT3ZlcmFnZVRleHQiLCJ1c2VDbGF1ZGVBaUxpbWl0cyIsImdldFN1YnNjcmlwdGlvblR5cGUiLCJoYXNDbGF1ZGVBaUJpbGxpbmdBY2Nlc3MiLCJnZXRJc1JlbW90ZU1vZGUiLCJ1c2VSYXRlTGltaXRXYXJuaW5nTm90aWZpY2F0aW9uIiwibW9kZWwiLCIkIiwiX2MiLCJhZGROb3RpZmljYXRpb24iLCJjbGF1ZGVBaUxpbWl0cyIsInQwIiwicmF0ZUxpbWl0V2FybmluZyIsInQxIiwidXNpbmdPdmVyYWdlVGV4dCIsInNob3duV2FybmluZ1JlZiIsInQyIiwiU3ltYm9sIiwiZm9yIiwic3Vic2NyaXB0aW9uVHlwZSIsInQzIiwiaGFzQmlsbGluZ0FjY2VzcyIsImlzVGVhbU9yRW50ZXJwcmlzZSIsImhhc1Nob3duT3ZlcmFnZU5vdGlmaWNhdGlvbiIsInNldEhhc1Nob3duT3ZlcmFnZU5vdGlmaWNhdGlvbiIsInQ0IiwidDUiLCJpc1VzaW5nT3ZlcmFnZSIsImtleSIsInRleHQiLCJwcmlvcml0eSIsInQ2IiwidDciLCJjdXJyZW50IiwianN4Il0sInNvdXJjZXMiOlsidXNlUmF0ZUxpbWl0V2FybmluZ05vdGlmaWNhdGlvbi50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VFZmZlY3QsIHVzZU1lbW8sIHVzZVJlZiwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZU5vdGlmaWNhdGlvbnMgfSBmcm9tICdzcmMvY29udGV4dC9ub3RpZmljYXRpb25zLmpzJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJ3NyYy9pbmsuanMnXG5pbXBvcnQge1xuICBnZXRSYXRlTGltaXRXYXJuaW5nLFxuICBnZXRVc2luZ092ZXJhZ2VUZXh0LFxufSBmcm9tICdzcmMvc2VydmljZXMvY2xhdWRlQWlMaW1pdHMuanMnXG5pbXBvcnQgeyB1c2VDbGF1ZGVBaUxpbWl0cyB9IGZyb20gJ3NyYy9zZXJ2aWNlcy9jbGF1ZGVBaUxpbWl0c0hvb2suanMnXG5pbXBvcnQgeyBnZXRTdWJzY3JpcHRpb25UeXBlIH0gZnJvbSAnc3JjL3V0aWxzL2F1dGguanMnXG5pbXBvcnQgeyBoYXNDbGF1ZGVBaUJpbGxpbmdBY2Nlc3MgfSBmcm9tICdzcmMvdXRpbHMvYmlsbGluZy5qcydcbmltcG9ydCB7IGdldElzUmVtb3RlTW9kZSB9IGZyb20gJy4uLy4uL2Jvb3RzdHJhcC9zdGF0ZS5qcydcblxuZXhwb3J0IGZ1bmN0aW9uIHVzZVJhdGVMaW1pdFdhcm5pbmdOb3RpZmljYXRpb24obW9kZWw6IHN0cmluZyk6IHZvaWQge1xuICBjb25zdCB7IGFkZE5vdGlmaWNhdGlvbiB9ID0gdXNlTm90aWZpY2F0aW9ucygpXG4gIGNvbnN0IGNsYXVkZUFpTGltaXRzID0gdXNlQ2xhdWRlQWlMaW1pdHMoKVxuICAvLyBjbGF1ZGVBaUxpbWl0cyByZWZlcmVuY2UgaXMgc3RhYmxlIHVudGlsIHN0YXR1c0xpc3RlbmVycyBmaXJlIChBUElcbiAgLy8gcmVzcG9uc2UpLCBzbyB0aGVzZSBza2lwIHRoZSBJbnRsIGZvcm1hdHRpbmcgd29yayBvbiBtb3N0IFJFUEwgcmVuZGVycy5cbiAgY29uc3QgcmF0ZUxpbWl0V2FybmluZyA9IHVzZU1lbW8oXG4gICAgKCkgPT4gZ2V0UmF0ZUxpbWl0V2FybmluZyhjbGF1ZGVBaUxpbWl0cywgbW9kZWwpLFxuICAgIFtjbGF1ZGVBaUxpbWl0cywgbW9kZWxdLFxuICApXG4gIGNvbnN0IHVzaW5nT3ZlcmFnZVRleHQgPSB1c2VNZW1vKFxuICAgICgpID0+IGdldFVzaW5nT3ZlcmFnZVRleHQoY2xhdWRlQWlMaW1pdHMpLFxuICAgIFtjbGF1ZGVBaUxpbWl0c10sXG4gIClcbiAgY29uc3Qgc2hvd25XYXJuaW5nUmVmID0gdXNlUmVmPHN0cmluZyB8IG51bGw+KG51bGwpXG4gIGNvbnN0IHN1YnNjcmlwdGlvblR5cGUgPSBnZXRTdWJzY3JpcHRpb25UeXBlKClcbiAgY29uc3QgaGFzQmlsbGluZ0FjY2VzcyA9IGhhc0NsYXVkZUFpQmlsbGluZ0FjY2VzcygpXG4gIGNvbnN0IGlzVGVhbU9yRW50ZXJwcmlzZSA9XG4gICAgc3Vic2NyaXB0aW9uVHlwZSA9PT0gJ3RlYW0nIHx8IHN1YnNjcmlwdGlvblR5cGUgPT09ICdlbnRlcnByaXNlJ1xuXG4gIC8vIFRyYWNrIG92ZXJhZ2UgbW9kZSB0cmFuc2l0aW9uc1xuICBjb25zdCBbaGFzU2hvd25PdmVyYWdlTm90aWZpY2F0aW9uLCBzZXRIYXNTaG93bk92ZXJhZ2VOb3RpZmljYXRpb25dID1cbiAgICB1c2VTdGF0ZShmYWxzZSlcblxuICAvLyBTaG93IGltbWVkaWF0ZSBub3RpZmljYXRpb24gd2hlbiBlbnRlcmluZyBvdmVyYWdlIG1vZGVcbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAoZ2V0SXNSZW1vdGVNb2RlKCkpIHJldHVyblxuICAgIGlmIChcbiAgICAgIGNsYXVkZUFpTGltaXRzLmlzVXNpbmdPdmVyYWdlICYmXG4gICAgICAhaGFzU2hvd25PdmVyYWdlTm90aWZpY2F0aW9uICYmXG4gICAgICAoIWlzVGVhbU9yRW50ZXJwcmlzZSB8fCBoYXNCaWxsaW5nQWNjZXNzKVxuICAgICkge1xuICAgICAgYWRkTm90aWZpY2F0aW9uKHtcbiAgICAgICAga2V5OiAnbGltaXQtcmVhY2hlZCcsXG4gICAgICAgIHRleHQ6IHVzaW5nT3ZlcmFnZVRleHQsXG4gICAgICAgIHByaW9yaXR5OiAnaW1tZWRpYXRlJyxcbiAgICAgIH0pXG4gICAgICBzZXRIYXNTaG93bk92ZXJhZ2VOb3RpZmljYXRpb24odHJ1ZSlcbiAgICB9IGVsc2UgaWYgKCFjbGF1ZGVBaUxpbWl0cy5pc1VzaW5nT3ZlcmFnZSAmJiBoYXNTaG93bk92ZXJhZ2VOb3RpZmljYXRpb24pIHtcbiAgICAgIC8vIFJlc2V0IHdoZW4gbm8gbG9uZ2VyIGluIG92ZXJhZ2UgbW9kZVxuICAgICAgc2V0SGFzU2hvd25PdmVyYWdlTm90aWZpY2F0aW9uKGZhbHNlKVxuICAgIH1cbiAgfSwgW1xuICAgIGNsYXVkZUFpTGltaXRzLmlzVXNpbmdPdmVyYWdlLFxuICAgIHVzaW5nT3ZlcmFnZVRleHQsXG4gICAgaGFzU2hvd25PdmVyYWdlTm90aWZpY2F0aW9uLFxuICAgIGFkZE5vdGlmaWNhdGlvbixcbiAgICBoYXNCaWxsaW5nQWNjZXNzLFxuICAgIGlzVGVhbU9yRW50ZXJwcmlzZSxcbiAgXSlcblxuICAvLyBTaG93IHdhcm5pbmcgbm90aWZpY2F0aW9uIGZvciBhcHByb2FjaGluZyBsaW1pdHNcbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAoZ2V0SXNSZW1vdGVNb2RlKCkpIHJldHVyblxuICAgIGlmIChyYXRlTGltaXRXYXJuaW5nICYmIHJhdGVMaW1pdFdhcm5pbmcgIT09IHNob3duV2FybmluZ1JlZi5jdXJyZW50KSB7XG4gICAgICBzaG93bldhcm5pbmdSZWYuY3VycmVudCA9IHJhdGVMaW1pdFdhcm5pbmdcbiAgICAgIGFkZE5vdGlmaWNhdGlvbih7XG4gICAgICAgIGtleTogJ3JhdGUtbGltaXQtd2FybmluZycsXG4gICAgICAgIGpzeDogKFxuICAgICAgICAgIDxUZXh0PlxuICAgICAgICAgICAgPFRleHQgY29sb3I9XCJ3YXJuaW5nXCI+e3JhdGVMaW1pdFdhcm5pbmd9PC9UZXh0PlxuICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgKSxcbiAgICAgICAgcHJpb3JpdHk6ICdoaWdoJyxcbiAgICAgIH0pXG4gICAgfVxuICB9LCBbcmF0ZUxpbWl0V2FybmluZywgYWRkTm90aWZpY2F0aW9uXSlcbn1cbiJdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sS0FBS0EsS0FBSyxNQUFNLE9BQU87QUFDOUIsU0FBU0MsU0FBUyxFQUFFQyxPQUFPLEVBQUVDLE1BQU0sRUFBRUMsUUFBUSxRQUFRLE9BQU87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LENBQUM7UUFBQTtNQUN0QztJQUFBLENBQ0Y7SUFBRUUsRUFBQSxJQUNEaEIsY0FBYyxDQUFBaUIsY0FBZSxFQUM3QmIsZ0JBQWdCLEVBQ2hCUywyQkFBMkIsRUFDM0JkLGVBQWUsRUFDZlksZ0JBQWdCLEVBQ2hCQyxrQkFBa0IsQ0FDbkI7SUFBQWYsQ0FBQSxNQUFBRSxlQUFBO0lBQUFGLENBQUEsTUFBQUcsY0FBQSxDQUFBaUIsY0FBQTtJQUFBcEIsQ0FBQSxNQUFBZ0IsMkJBQUE7SUFBQWhCLENBQUEsT0FBQU8sZ0JBQUE7SUFBQVAsQ0FBQSxPQUFBa0IsRUFBQTtJQUFBbEIsQ0FBQSxPQUFBbUIsRUFBQTtFQUFBO0lBQUFELEVBQUEsR0FBQWxCLENBQUE7SUFBQW1CLEVBQUEsR0FBQW5CLENBQUE7RUFBQTtFQXhCRGQsU0FBUyxDQUFDZ0MsRUFpQlQsRUFBRUMsRUFPRixDQUFDO0VBQUEsSUFBQUssRUFBQTtFQUFBLElBQUFDLEVBQUE7RUFBQSxJQUFBekIsQ0FBQSxTQUFBRSxlQUFBLElBQUFGLENBQUEsU0FBQUssZ0JBQUE7SUFHUW1CLEVBQUEsR0FBQUEsQ0FBQTtNQUNSLElBQUkzQixlQUFlLENBQUMsQ0FBQztRQUFBO01BQUE7TUFDckIsSUFBSVEsZ0JBQWdFLElBQTVDQSxnQkFBZ0IsS0FBS0csZUFBZSxDQUFBa0IsT0FBUTtRQUNsRWxCLGVBQWUsQ0FBQWtCLE9BQUEsR0FBV3JCLGdCQUFIO1FBQ3ZCSCxlQUFlLENBQUM7VUFBQW1CLEdBQUEsRUFDVCxvQkFBb0I7VUFBQU0sR0FBQSxFQUV2QixDQUFDLElBQUksQ0FDSCxDQUFDLElBQUksQ0FBTyxLQUFTLENBQVQsU0FBUyxDQUFFdEIsaUJBQWUsQ0FBRSxFQUF2QyxJQUFJLENBQ1AsRUFGQyxJQUFJLENBRUU7VUFBQWtCLFFBQUEsRUFFQztRQUNaLENBQUMsQ0FBQztNQUFBO0lBQ0gsQ0FDRjtJQUFFRSxFQUFBLElBQUNwQixnQkFBZ0IsRUFBRUgsZUFBZSxDQUFDO0lBQUFGLENBQUEsT0FBQUUsZUFBQTtJQUFBRixDQUFBLE9BQUFLLGdCQUFBO0lBQUFMLENBQUEsT0FBQXdCLEVBQUE7SUFBQXhCLENBQUEsT0FBQXlCLEVBQUE7RUFBQTtJQUFBRCxFQUFBLEdBQUF4QixDQUFBO0lBQUF5QixFQUFBLEdBQUF6QixDQUFBO0VBQUE7RUFkdENkLFNBQVMsQ0FBQ3NDLEVBY1QsRUFBRUMsRUFBbUMsQ0FBQztBQUFBIiwiaWdub3JlTGlzdCI6W119