@orderly.network/vaults 2.8.5 → 2.8.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.mjs CHANGED
@@ -2062,10 +2062,19 @@ var init_parseMarkdownLinks = __esm({
2062
2062
  };
2063
2063
  }
2064
2064
  });
2065
- var VaultCard, VaultInfoItem, LpInfoItem, VaultCardOperation;
2065
+ var formatAllTimeReturn, VaultCard, VaultInfoItem, LpInfoItem, VaultCardOperation;
2066
2066
  var init_vaultCard_ui = __esm({
2067
2067
  "src/components/vault-card/vaultCard.ui.tsx"() {
2068
2068
  init_parseMarkdownLinks();
2069
+ formatAllTimeReturn = (status, vaultAge, lifetimeApy) => {
2070
+ if (status === "pre_launch" || vaultAge !== null && vaultAge < 7) {
2071
+ return "--";
2072
+ }
2073
+ if (lifetimeApy > 100) {
2074
+ return ">10000%";
2075
+ }
2076
+ return new Decimal(lifetimeApy).mul(100).toDecimalPlaces(2, Decimal.ROUND_UP).toFixed(2) + "%";
2077
+ };
2069
2078
  VaultCard = (props) => {
2070
2079
  const {
2071
2080
  title,
@@ -2082,6 +2091,14 @@ var init_vaultCard_ui = __esm({
2082
2091
  } = props;
2083
2092
  const { t } = useTranslation();
2084
2093
  const { isMobile } = useScreen();
2094
+ const formattedAllTimeReturn = useMemo(
2095
+ () => formatAllTimeReturn(
2096
+ vaultInfo.status,
2097
+ vaultInfo.vault_age,
2098
+ vaultInfo.lifetime_apy
2099
+ ),
2100
+ [vaultInfo.status, vaultInfo.vault_age, vaultInfo.lifetime_apy]
2101
+ );
2085
2102
  const getStatusTag = () => {
2086
2103
  const { status } = vaultInfo;
2087
2104
  if (status === "live") {
@@ -2199,14 +2216,14 @@ var init_vaultCard_ui = __esm({
2199
2216
  /* @__PURE__ */ jsx(
2200
2217
  VaultInfoItem,
2201
2218
  {
2202
- label: t("vaults.card.apy"),
2203
- value: vaultInfo.status === "pre_launch" || vaultInfo.vault_age !== null && vaultInfo.vault_age < 30 ? "--" : vaultInfo["30d_apy"] > 100 ? ">10000%" : (vaultInfo["30d_apy"] * 100).toFixed(2) + "%",
2219
+ label: t("vaults.card.allTimeReturn"),
2220
+ value: formattedAllTimeReturn,
2204
2221
  textProps: {
2205
2222
  color: "brand",
2206
2223
  type: "gradient"
2207
2224
  },
2208
- showTooltip: vaultInfo.status === "pre_launch" || vaultInfo.vault_age !== null && vaultInfo.vault_age < 30,
2209
- tooltipContent: "APY is not calculated for vaults that are less than 30 days old."
2225
+ showTooltip: vaultInfo.status === "pre_launch" || vaultInfo.vault_age !== null && vaultInfo.vault_age < 7,
2226
+ tooltipContent: t("vaults.card.allTimeReturnTooltip")
2210
2227
  }
2211
2228
  )
2212
2229
  ] }),
@@ -2365,13 +2382,14 @@ var VaultsList, VaultListRow;
2365
2382
  var init_vaults_list = __esm({
2366
2383
  "src/components/all-vaults/vaults-list.tsx"() {
2367
2384
  init_vaultCard_script();
2385
+ init_vaultCard_ui();
2368
2386
  VaultsList = ({ vaults }) => {
2369
2387
  const { t } = useTranslation();
2370
2388
  const [sortField, setSortField] = useState("apy");
2371
2389
  const [sortDirection, setSortDirection] = useState("desc");
2372
2390
  const shouldShowApyTooltip = useMemo(() => {
2373
2391
  return vaults.some(
2374
- (vault) => vault.status === "pre_launch" || vault.vault_age !== null && vault.vault_age < 30
2392
+ (vault) => vault.status === "pre_launch" || vault.vault_age !== null && vault.vault_age < 7
2375
2393
  );
2376
2394
  }, [vaults]);
2377
2395
  const handleSort = (field) => {
@@ -2392,8 +2410,8 @@ var init_vaults_list = __esm({
2392
2410
  bValue = b.tvl;
2393
2411
  break;
2394
2412
  case "apy":
2395
- aValue = a["30d_apy"];
2396
- bValue = b["30d_apy"];
2413
+ aValue = a.lifetime_apy;
2414
+ bValue = b.lifetime_apy;
2397
2415
  break;
2398
2416
  default:
2399
2417
  return 0;
@@ -2457,7 +2475,7 @@ var init_vaults_list = __esm({
2457
2475
  onClick: () => handleSort("apy"),
2458
2476
  className: "oui-flex oui-items-center oui-text-2xs oui-font-normal oui-text-base-contrast-54 hover:oui-text-base-contrast",
2459
2477
  children: [
2460
- t("vaults.card.apy"),
2478
+ t("vaults.card.allTimeReturn"),
2461
2479
  /* @__PURE__ */ jsx(SortIcon, { field: "apy" })
2462
2480
  ]
2463
2481
  }
@@ -2465,7 +2483,7 @@ var init_vaults_list = __esm({
2465
2483
  shouldShowApyTooltip && /* @__PURE__ */ jsx(
2466
2484
  Tooltip,
2467
2485
  {
2468
- content: "APY is not calculated for vaults that are less than 30 days old.",
2486
+ content: t("vaults.card.allTimeReturnTooltip"),
2469
2487
  delayDuration: 100,
2470
2488
  children: /* @__PURE__ */ jsx("div", { children: /* @__PURE__ */ jsx(
2471
2489
  InfoCircleIcon,
@@ -2553,6 +2571,14 @@ var init_vaults_list = __esm({
2553
2571
  return null;
2554
2572
  };
2555
2573
  const statusTag = getStatusTag();
2574
+ const formattedAllTimeReturn = useMemo(
2575
+ () => formatAllTimeReturn(
2576
+ vaultInfo.status,
2577
+ vaultInfo.vault_age,
2578
+ vaultInfo.lifetime_apy
2579
+ ),
2580
+ [vaultInfo.status, vaultInfo.vault_age, vaultInfo.lifetime_apy]
2581
+ );
2556
2582
  useMemo(() => {
2557
2583
  const chains = Array.isArray(vaultInfo?.supported_chains) ? vaultInfo.supported_chains : [];
2558
2584
  const ICON_SIZE = isMobile ? 18 : 20;
@@ -2627,7 +2653,7 @@ var init_vaults_list = __esm({
2627
2653
  children: vaultInfo.tvl
2628
2654
  }
2629
2655
  ) }),
2630
- /* @__PURE__ */ jsx("div", { className: "oui-relative oui-z-10", children: /* @__PURE__ */ jsx(Text.gradient, { className: "oui-text-sm oui-font-semibold", color: "brand", children: vaultInfo.status === "pre_launch" || vaultInfo.vault_age !== null && vaultInfo.vault_age < 30 ? "--" : vaultInfo["30d_apy"] > 100 ? ">10000%" : `${(vaultInfo["30d_apy"] * 100).toFixed(2)}%` }) }),
2656
+ /* @__PURE__ */ jsx("div", { className: "oui-relative oui-z-10", children: /* @__PURE__ */ jsx(Text.gradient, { className: "oui-text-sm oui-font-semibold", color: "brand", children: formattedAllTimeReturn }) }),
2631
2657
  /* @__PURE__ */ jsx("div", { className: "oui-relative oui-z-10", children: /* @__PURE__ */ jsx(
2632
2658
  Text.numeral,
2633
2659
  {
@@ -2902,6 +2928,6 @@ init_latest_deposit_widget();
2902
2928
  // src/components/vault-operation/index.ts
2903
2929
  init_latest_withdraw();
2904
2930
 
2905
- export { AllVaultsDesktop, AllVaultsWidget, LatestDepositWidget, LatestWithdrawWidget, ORDERLY_ICON, ORDERLY_VAULT_DESCRIPTION, ORDERLY_VAULT_TITLE, OperationType, RoleType, VaultCard, VaultCardWidget, VaultDepositAndWithdraw, VaultDepositAndWithdrawWithDialogId, VaultDepositAndWithdrawWithSheetId, VaultDepositWidget, VaultWithdrawWidget, VaultsHeaderDesktop, VaultsHeaderWidget, VaultsIntroductionWidget, VaultsList, VaultsPage, ViewModeToggle, getBrokerIconUrl, getVaultInfo, getVaultLpInfo, getVaultLpPerformance, getVaultOverallInfo, useVaultCardScript, useVaultInfoActions, useVaultInfoState, useVaultLpInfoActions, useVaultLpInfoArray, useVaultLpInfoById, useVaultLpInfoIds, useVaultLpInfoState, useVaultLpPerformanceActions, useVaultLpPerformanceArray, useVaultLpPerformanceById, useVaultLpPerformanceIds, useVaultLpPerformanceState, useVaultOverallInfoActions, useVaultOverallInfoState, useVaultsHeaderScript, useVaultsStore };
2931
+ export { AllVaultsDesktop, AllVaultsWidget, LatestDepositWidget, LatestWithdrawWidget, ORDERLY_ICON, ORDERLY_VAULT_DESCRIPTION, ORDERLY_VAULT_TITLE, OperationType, RoleType, VaultCard, VaultCardWidget, VaultDepositAndWithdraw, VaultDepositAndWithdrawWithDialogId, VaultDepositAndWithdrawWithSheetId, VaultDepositWidget, VaultWithdrawWidget, VaultsHeaderDesktop, VaultsHeaderWidget, VaultsIntroductionWidget, VaultsList, VaultsPage, ViewModeToggle, formatAllTimeReturn, getBrokerIconUrl, getVaultInfo, getVaultLpInfo, getVaultLpPerformance, getVaultOverallInfo, useVaultCardScript, useVaultInfoActions, useVaultInfoState, useVaultLpInfoActions, useVaultLpInfoArray, useVaultLpInfoById, useVaultLpInfoIds, useVaultLpInfoState, useVaultLpPerformanceActions, useVaultLpPerformanceArray, useVaultLpPerformanceById, useVaultLpPerformanceIds, useVaultLpPerformanceState, useVaultOverallInfoActions, useVaultOverallInfoState, useVaultsHeaderScript, useVaultsStore };
2906
2932
  //# sourceMappingURL=out.js.map
2907
2933
  //# sourceMappingURL=index.mjs.map