/ hooks / notifs / usePluginInstallationStatus.tsx
usePluginInstallationStatus.tsx
  1  import { c as _c } from "react/compiler-runtime";
  2  import * as React from 'react';
  3  import { useEffect, useMemo } from 'react';
  4  import { getIsRemoteMode } from '../../bootstrap/state.js';
  5  import { useNotifications } from '../../context/notifications.js';
  6  import { Text } from '../../ink.js';
  7  import { useAppState } from '../../state/AppState.js';
  8  import { logForDebugging } from '../../utils/debug.js';
  9  import { plural } from '../../utils/stringUtils.js';
 10  export function usePluginInstallationStatus() {
 11    const $ = _c(20);
 12    const {
 13      addNotification
 14    } = useNotifications();
 15    const installationStatus = useAppState(_temp);
 16    let t0;
 17    bb0: {
 18      if (!installationStatus) {
 19        let t1;
 20        if ($[0] === Symbol.for("react.memo_cache_sentinel")) {
 21          t1 = {
 22            totalFailed: 0,
 23            failedMarketplacesCount: 0,
 24            failedPluginsCount: 0
 25          };
 26          $[0] = t1;
 27        } else {
 28          t1 = $[0];
 29        }
 30        t0 = t1;
 31        break bb0;
 32      }
 33      let t1;
 34      if ($[1] !== installationStatus.marketplaces) {
 35        t1 = installationStatus.marketplaces.filter(_temp2);
 36        $[1] = installationStatus.marketplaces;
 37        $[2] = t1;
 38      } else {
 39        t1 = $[2];
 40      }
 41      const failedMarketplaces = t1;
 42      let t2;
 43      if ($[3] !== installationStatus.plugins) {
 44        t2 = installationStatus.plugins.filter(_temp3);
 45        $[3] = installationStatus.plugins;
 46        $[4] = t2;
 47      } else {
 48        t2 = $[4];
 49      }
 50      const failedPlugins = t2;
 51      const t3 = failedMarketplaces.length + failedPlugins.length;
 52      let t4;
 53      if ($[5] !== failedMarketplaces.length || $[6] !== failedPlugins.length || $[7] !== t3) {
 54        t4 = {
 55          totalFailed: t3,
 56          failedMarketplacesCount: failedMarketplaces.length,
 57          failedPluginsCount: failedPlugins.length
 58        };
 59        $[5] = failedMarketplaces.length;
 60        $[6] = failedPlugins.length;
 61        $[7] = t3;
 62        $[8] = t4;
 63      } else {
 64        t4 = $[8];
 65      }
 66      t0 = t4;
 67    }
 68    const {
 69      totalFailed,
 70      failedMarketplacesCount,
 71      failedPluginsCount
 72    } = t0;
 73    let t1;
 74    if ($[9] !== addNotification || $[10] !== failedMarketplacesCount || $[11] !== failedPluginsCount || $[12] !== installationStatus || $[13] !== totalFailed) {
 75      t1 = () => {
 76        if (getIsRemoteMode()) {
 77          return;
 78        }
 79        if (!installationStatus) {
 80          logForDebugging("No installation status to monitor");
 81          return;
 82        }
 83        if (totalFailed === 0) {
 84          return;
 85        }
 86        logForDebugging(`Plugin installation status: ${failedMarketplacesCount} failed marketplaces, ${failedPluginsCount} failed plugins`);
 87        if (totalFailed === 0) {
 88          return;
 89        }
 90        logForDebugging(`Adding notification for ${totalFailed} failed installations`);
 91        addNotification({
 92          key: "plugin-install-failed",
 93          jsx: <><Text color="error">{totalFailed} {plural(totalFailed, "plugin")} failed to install</Text><Text dimColor={true}> ยท /plugin for details</Text></>,
 94          priority: "medium"
 95        });
 96      };
 97      $[9] = addNotification;
 98      $[10] = failedMarketplacesCount;
 99      $[11] = failedPluginsCount;
100      $[12] = installationStatus;
101      $[13] = totalFailed;
102      $[14] = t1;
103    } else {
104      t1 = $[14];
105    }
106    let t2;
107    if ($[15] !== addNotification || $[16] !== failedMarketplacesCount || $[17] !== failedPluginsCount || $[18] !== totalFailed) {
108      t2 = [addNotification, totalFailed, failedMarketplacesCount, failedPluginsCount];
109      $[15] = addNotification;
110      $[16] = failedMarketplacesCount;
111      $[17] = failedPluginsCount;
112      $[18] = totalFailed;
113      $[19] = t2;
114    } else {
115      t2 = $[19];
116    }
117    useEffect(t1, t2);
118  }
119  function _temp3(p) {
120    return p.status === "failed";
121  }
122  function _temp2(m) {
123    return m.status === "failed";
124  }
125  function _temp(s) {
126    return s.plugins.installationStatus;
127  }
128  //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useEffect","useMemo","getIsRemoteMode","useNotifications","Text","useAppState","logForDebugging","plural","usePluginInstallationStatus","$","_c","addNotification","installationStatus","_temp","t0","bb0","t1","Symbol","for","totalFailed","failedMarketplacesCount","failedPluginsCount","marketplaces","filter","_temp2","failedMarketplaces","t2","plugins","_temp3","failedPlugins","t3","length","t4","key","jsx","priority","p","status","m","s"],"sources":["usePluginInstallationStatus.tsx"],"sourcesContent":["import * as React from 'react'\nimport { useEffect, useMemo } from 'react'\nimport { getIsRemoteMode } from '../../bootstrap/state.js'\nimport { useNotifications } from '../../context/notifications.js'\nimport { Text } from '../../ink.js'\nimport { useAppState } from '../../state/AppState.js'\nimport { logForDebugging } from '../../utils/debug.js'\nimport { plural } from '../../utils/stringUtils.js'\n\nexport function usePluginInstallationStatus(): void {\n  const { addNotification } = useNotifications()\n  const installationStatus = useAppState(s => s.plugins.installationStatus)\n\n  // Memoize the failed counts to prevent unnecessary effect triggers\n  const { totalFailed, failedMarketplacesCount, failedPluginsCount } =\n    useMemo(() => {\n      if (!installationStatus) {\n        return {\n          totalFailed: 0,\n          failedMarketplacesCount: 0,\n          failedPluginsCount: 0,\n        }\n      }\n\n      const failedMarketplaces = installationStatus.marketplaces.filter(\n        m => m.status === 'failed',\n      )\n      const failedPlugins = installationStatus.plugins.filter(\n        p => p.status === 'failed',\n      )\n\n      return {\n        totalFailed: failedMarketplaces.length + failedPlugins.length,\n        failedMarketplacesCount: failedMarketplaces.length,\n        failedPluginsCount: failedPlugins.length,\n      }\n    }, [installationStatus])\n\n  useEffect(() => {\n    if (getIsRemoteMode()) return\n    if (!installationStatus) {\n      logForDebugging('No installation status to monitor')\n      return\n    }\n\n    if (totalFailed === 0) {\n      return\n    }\n\n    logForDebugging(\n      `Plugin installation status: ${failedMarketplacesCount} failed marketplaces, ${failedPluginsCount} failed plugins`,\n    )\n\n    if (totalFailed === 0) {\n      return\n    }\n\n    // Add notification for failures\n    logForDebugging(\n      `Adding notification for ${totalFailed} failed installations`,\n    )\n    addNotification({\n      key: 'plugin-install-failed',\n      jsx: (\n        <>\n          <Text color=\"error\">\n            {totalFailed} {plural(totalFailed, 'plugin')} failed to install\n          </Text>\n          <Text dimColor> · /plugin for details</Text>\n        </>\n      ),\n      priority: 'medium',\n    })\n  }, [\n    addNotification,\n    totalFailed,\n    failedMarketplacesCount,\n    failedPluginsCount,\n  ])\n}\n"],"mappings":"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","ignoreList":[]}