@whisk/steakhouse 0.0.6 → 0.0.8

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.
Files changed (53) hide show
  1. package/dist/index.d.ts +1 -6
  2. package/dist/queries/getTvl.d.ts +34 -0
  3. package/dist/queries/getTvl.js +34 -0
  4. package/dist/queries/getTvl.js.map +1 -0
  5. package/dist/queries/index.d.ts +1 -6
  6. package/dist/queries/index.js +1 -8
  7. package/dist/queries/index.js.map +1 -1
  8. package/dist/react/hooks/index.d.ts +3 -10
  9. package/dist/react/hooks/index.js +2 -6
  10. package/dist/react/hooks/index.js.map +1 -1
  11. package/dist/react/hooks/useTvl.d.ts +9 -0
  12. package/dist/react/hooks/useTvl.js +15 -0
  13. package/dist/react/hooks/useTvl.js.map +1 -0
  14. package/dist/react/index.d.ts +3 -10
  15. package/package.json +3 -3
  16. package/src/queries/getTvl.ts +38 -0
  17. package/src/queries/index.ts +1 -10
  18. package/src/react/hooks/index.ts +1 -3
  19. package/src/react/hooks/useTvl.ts +14 -0
  20. package/dist/queries/fragments/vaultDetail.d.ts +0 -265
  21. package/dist/queries/fragments/vaultDetail.js +0 -148
  22. package/dist/queries/fragments/vaultDetail.js.map +0 -1
  23. package/dist/queries/getDetailedVault.d.ts +0 -591
  24. package/dist/queries/getDetailedVault.js +0 -92
  25. package/dist/queries/getDetailedVault.js.map +0 -1
  26. package/dist/queries/getVaults.d.ts +0 -288
  27. package/dist/queries/getVaults.js +0 -47
  28. package/dist/queries/getVaults.js.map +0 -1
  29. package/dist/queries/steakhouseMetadata.d.ts +0 -14
  30. package/dist/queries/steakhouseMetadata.js +0 -12
  31. package/dist/queries/steakhouseMetadata.js.map +0 -1
  32. package/dist/queries/types.d.ts +0 -5
  33. package/dist/queries/types.js +0 -1
  34. package/dist/queries/types.js.map +0 -1
  35. package/dist/react/hooks/useDetailedVault.d.ts +0 -12
  36. package/dist/react/hooks/useDetailedVault.js +0 -16
  37. package/dist/react/hooks/useDetailedVault.js.map +0 -1
  38. package/dist/react/hooks/useSteakhouseQuery.d.ts +0 -11
  39. package/dist/react/hooks/useSteakhouseQuery.js +0 -14
  40. package/dist/react/hooks/useSteakhouseQuery.js.map +0 -1
  41. package/dist/react/hooks/useVaults.d.ts +0 -12
  42. package/dist/react/hooks/useVaults.js +0 -16
  43. package/dist/react/hooks/useVaults.js.map +0 -1
  44. package/src/queries/fragments/vaultDetail.ts +0 -151
  45. package/src/queries/getDetailedVault.test.ts +0 -202
  46. package/src/queries/getDetailedVault.ts +0 -131
  47. package/src/queries/getVaults.test.ts +0 -167
  48. package/src/queries/getVaults.ts +0 -77
  49. package/src/queries/steakhouseMetadata.ts +0 -19
  50. package/src/queries/types.ts +0 -6
  51. package/src/react/hooks/useDetailedVault.ts +0 -19
  52. package/src/react/hooks/useSteakhouseQuery.ts +0 -17
  53. package/src/react/hooks/useVaults.ts +0 -17
package/dist/index.d.ts CHANGED
@@ -1,9 +1,4 @@
1
1
  export { WhiskClient as SteakhouseClient, WhiskClientConfig as SteakhouseClientConfig } from '@whisk/client';
2
- export { VaultDetail, vaultDetailFragment } from './queries/fragments/vaultDetail.js';
3
- export { DetailedVault, GetDetailedVaultResult, GetDetailedVaultVariables, getDetailedVault, vaultQuery, vaultWithHistoricalQuery } from './queries/getDetailedVault.js';
4
- export { GetVaultsResult, GetVaultsVariables, VaultWithMetadata, getVaults, vaultsQuery } from './queries/getVaults.js';
5
- export { SteakhouseMetadata, buildSteakhouseMetadata } from './queries/steakhouseMetadata.js';
6
- export { SteakhouseQueryFn } from './queries/types.js';
2
+ export { GetTvlResult, getTvl, tvlQuery } from './queries/getTvl.js';
7
3
  import 'gql.tada';
8
4
  import '@whisk/graphql';
9
- import './metadata/types.js';
@@ -0,0 +1,34 @@
1
+ import { WhiskClient } from '@whisk/client';
2
+ import * as gql_tada from 'gql.tada';
3
+ import { ResultOf } from '@whisk/graphql';
4
+
5
+ /** GraphQL query for fetching Steakhouse TVL */
6
+ declare const tvlQuery: gql_tada.TadaDocumentNode<{
7
+ steakhouseTvl: {
8
+ totalUsd: number;
9
+ computedAt: number;
10
+ byChain: {
11
+ chain: {
12
+ id: number;
13
+ name: string;
14
+ icon: string;
15
+ };
16
+ tvlUsd: number;
17
+ }[];
18
+ byProtocol: {
19
+ protocol: "generic" | "morpho_v1" | "morpho_v2" | "box";
20
+ tvlUsd: number;
21
+ }[];
22
+ byAssetCategory: {
23
+ category: "Stable" | "Eth" | "Btc";
24
+ tvlUsd: number;
25
+ }[];
26
+ };
27
+ }, {}, void>;
28
+ type GetTvlResult = ResultOf<typeof tvlQuery>["steakhouseTvl"];
29
+ /**
30
+ * Get Steakhouse TVL breakdown by chain, protocol, and asset category.
31
+ */
32
+ declare function getTvl(client: WhiskClient): Promise<GetTvlResult>;
33
+
34
+ export { type GetTvlResult, getTvl, tvlQuery };
@@ -0,0 +1,34 @@
1
+ import { graphql } from "@whisk/graphql";
2
+ const tvlQuery = graphql(`
3
+ query GetSteakhouseTvl {
4
+ steakhouseTvl {
5
+ totalUsd
6
+ computedAt
7
+ byChain {
8
+ chain {
9
+ id
10
+ name
11
+ icon
12
+ }
13
+ tvlUsd
14
+ }
15
+ byProtocol {
16
+ protocol
17
+ tvlUsd
18
+ }
19
+ byAssetCategory {
20
+ category
21
+ tvlUsd
22
+ }
23
+ }
24
+ }
25
+ `);
26
+ async function getTvl(client) {
27
+ const result = await client.query(tvlQuery, {});
28
+ return result.steakhouseTvl;
29
+ }
30
+ export {
31
+ getTvl,
32
+ tvlQuery
33
+ };
34
+ //# sourceMappingURL=getTvl.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/queries/getTvl.ts"],"sourcesContent":["import { graphql, type ResultOf } from \"@whisk/graphql\"\nimport type { SteakhouseClient } from \"../client.js\"\n\n/** GraphQL query for fetching Steakhouse TVL */\nexport const tvlQuery = graphql(`\n query GetSteakhouseTvl {\n steakhouseTvl {\n totalUsd\n computedAt\n byChain {\n chain {\n id\n name\n icon\n }\n tvlUsd\n }\n byProtocol {\n protocol\n tvlUsd\n }\n byAssetCategory {\n category\n tvlUsd\n }\n }\n }\n`)\n\nexport type GetTvlResult = ResultOf<typeof tvlQuery>[\"steakhouseTvl\"]\n\n/**\n * Get Steakhouse TVL breakdown by chain, protocol, and asset category.\n */\nexport async function getTvl(client: SteakhouseClient): Promise<GetTvlResult> {\n const result = await client.query(tvlQuery, {})\n return result.steakhouseTvl\n}\n"],"mappings":"AAAA,SAAS,eAA8B;AAIhC,MAAM,WAAW,QAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,CAuB/B;AAOD,eAAsB,OAAO,QAAiD;AAC5E,QAAM,SAAS,MAAM,OAAO,MAAM,UAAU,CAAC,CAAC;AAC9C,SAAO,OAAO;AAChB;","names":[]}
@@ -1,9 +1,4 @@
1
- export { VaultDetail, vaultDetailFragment } from './fragments/vaultDetail.js';
2
- export { DetailedVault, GetDetailedVaultResult, GetDetailedVaultVariables, getDetailedVault, vaultQuery, vaultWithHistoricalQuery } from './getDetailedVault.js';
3
- export { GetVaultsResult, GetVaultsVariables, VaultWithMetadata, getVaults, vaultsQuery } from './getVaults.js';
4
- export { SteakhouseMetadata, buildSteakhouseMetadata } from './steakhouseMetadata.js';
5
- export { SteakhouseQueryFn } from './types.js';
1
+ export { GetTvlResult, getTvl, tvlQuery } from './getTvl.js';
6
2
  import '@whisk/client';
7
3
  import 'gql.tada';
8
4
  import '@whisk/graphql';
9
- import '../metadata/types.js';
@@ -1,9 +1,2 @@
1
- import { vaultDetailFragment } from "./fragments/vaultDetail.js";
2
- export * from "./getDetailedVault.js";
3
- export * from "./getVaults.js";
4
- import { buildSteakhouseMetadata } from "./steakhouseMetadata.js";
5
- export {
6
- buildSteakhouseMetadata,
7
- vaultDetailFragment
8
- };
1
+ export * from "./getTvl.js";
9
2
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/queries/index.ts"],"sourcesContent":["// Fragments\nexport { type VaultDetail, vaultDetailFragment } from \"./fragments/vaultDetail.js\"\n// Queries\nexport * from \"./getDetailedVault.js\"\nexport * from \"./getVaults.js\"\n// Shared\nexport { buildSteakhouseMetadata, type SteakhouseMetadata } from \"./steakhouseMetadata.js\"\n\n// Types\nexport type { SteakhouseQueryFn } from \"./types.js\"\n"],"mappings":"AACA,SAA2B,2BAA2B;AAEtD,cAAc;AACd,cAAc;AAEd,SAAS,+BAAwD;","names":[]}
1
+ {"version":3,"sources":["../../src/queries/index.ts"],"sourcesContent":["export * from \"./getTvl.js\"\n"],"mappings":"AAAA,cAAc;","names":[]}
@@ -1,13 +1,6 @@
1
- export { useDetailedVault } from './useDetailedVault.js';
2
- export { useSteakhouseQuery } from './useSteakhouseQuery.js';
3
- export { useVaults } from './useVaults.js';
1
+ export { useTvl } from './useTvl.js';
4
2
  import '@tanstack/react-query';
5
- import '../../queries/getDetailedVault.js';
6
- import 'gql.tada';
3
+ import '../../queries/getTvl.js';
7
4
  import '@whisk/client';
8
- import '../../metadata/types.js';
5
+ import 'gql.tada';
9
6
  import '@whisk/graphql';
10
- import '../../queries/fragments/vaultDetail.js';
11
- import '../../queries/steakhouseMetadata.js';
12
- import '../../queries/types.js';
13
- import '../../queries/getVaults.js';
@@ -1,9 +1,5 @@
1
- import { useDetailedVault } from "./useDetailedVault.js";
2
- import { useSteakhouseQuery } from "./useSteakhouseQuery.js";
3
- import { useVaults } from "./useVaults.js";
1
+ import { useTvl } from "./useTvl.js";
4
2
  export {
5
- useDetailedVault,
6
- useSteakhouseQuery,
7
- useVaults
3
+ useTvl
8
4
  };
9
5
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/react/hooks/index.ts"],"sourcesContent":["export { useDetailedVault } from \"./useDetailedVault.js\"\nexport { useSteakhouseQuery } from \"./useSteakhouseQuery.js\"\nexport { useVaults } from \"./useVaults.js\"\n"],"mappings":"AAAA,SAAS,wBAAwB;AACjC,SAAS,0BAA0B;AACnC,SAAS,iBAAiB;","names":[]}
1
+ {"version":3,"sources":["../../../src/react/hooks/index.ts"],"sourcesContent":["export { useTvl } from \"./useTvl.js\"\n"],"mappings":"AAAA,SAAS,cAAc;","names":[]}
@@ -0,0 +1,9 @@
1
+ import { UseQueryResult } from '@tanstack/react-query';
2
+ import { GetTvlResult } from '../../queries/getTvl.js';
3
+ import '@whisk/client';
4
+ import 'gql.tada';
5
+ import '@whisk/graphql';
6
+
7
+ declare function useTvl(): UseQueryResult<GetTvlResult, Error>;
8
+
9
+ export { useTvl };
@@ -0,0 +1,15 @@
1
+ "use client";
2
+ import { useQuery } from "@tanstack/react-query";
3
+ import { getTvl } from "../../queries/getTvl.js";
4
+ import { useSteakhouse } from "../provider.js";
5
+ function useTvl() {
6
+ const { client } = useSteakhouse();
7
+ return useQuery({
8
+ queryKey: ["steakhouse", "tvl"],
9
+ queryFn: () => getTvl(client)
10
+ });
11
+ }
12
+ export {
13
+ useTvl
14
+ };
15
+ //# sourceMappingURL=useTvl.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/react/hooks/useTvl.ts"],"sourcesContent":["\"use client\"\n\nimport type { UseQueryResult } from \"@tanstack/react-query\"\nimport { useQuery } from \"@tanstack/react-query\"\nimport { type GetTvlResult, getTvl } from \"../../queries/getTvl.js\"\nimport { useSteakhouse } from \"../provider.js\"\n\nexport function useTvl(): UseQueryResult<GetTvlResult, Error> {\n const { client } = useSteakhouse()\n return useQuery({\n queryKey: [\"steakhouse\", \"tvl\"],\n queryFn: () => getTvl(client),\n })\n}\n"],"mappings":";AAGA,SAAS,gBAAgB;AACzB,SAA4B,cAAc;AAC1C,SAAS,qBAAqB;AAEvB,SAAS,SAA8C;AAC5D,QAAM,EAAE,OAAO,IAAI,cAAc;AACjC,SAAO,SAAS;AAAA,IACd,UAAU,CAAC,cAAc,KAAK;AAAA,IAC9B,SAAS,MAAM,OAAO,MAAM;AAAA,EAC9B,CAAC;AACH;","names":[]}
@@ -1,15 +1,8 @@
1
- export { useDetailedVault } from './hooks/useDetailedVault.js';
2
- export { useSteakhouseQuery } from './hooks/useSteakhouseQuery.js';
3
- export { useVaults } from './hooks/useVaults.js';
1
+ export { useTvl } from './hooks/useTvl.js';
4
2
  export { SteakhouseContextValue, SteakhouseProvider, SteakhouseProviderProps, useSteakhouse } from './provider.js';
5
3
  import '@tanstack/react-query';
6
- import '../queries/getDetailedVault.js';
7
- import 'gql.tada';
4
+ import '../queries/getTvl.js';
8
5
  import '@whisk/client';
9
- import '../metadata/types.js';
6
+ import 'gql.tada';
10
7
  import '@whisk/graphql';
11
- import '../queries/fragments/vaultDetail.js';
12
- import '../queries/steakhouseMetadata.js';
13
- import '../queries/types.js';
14
- import '../queries/getVaults.js';
15
8
  import 'react';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@whisk/steakhouse",
3
- "version": "0.0.6",
3
+ "version": "0.0.8",
4
4
  "repository": {
5
5
  "type": "git",
6
6
  "url": "https://github.com/office-supply-ventures/whisk-sdk.git",
@@ -36,8 +36,8 @@
36
36
  "dependencies": {
37
37
  "@urql/core": "6.0.1",
38
38
  "gql.tada": "1.9.0",
39
- "@whisk/client": "0.0.10",
40
- "@whisk/graphql": "0.0.10"
39
+ "@whisk/client": "0.0.11",
40
+ "@whisk/graphql": "0.0.11"
41
41
  },
42
42
  "peerDependencies": {
43
43
  "@tanstack/react-query": ">=5",
@@ -0,0 +1,38 @@
1
+ import { graphql, type ResultOf } from "@whisk/graphql"
2
+ import type { SteakhouseClient } from "../client.js"
3
+
4
+ /** GraphQL query for fetching Steakhouse TVL */
5
+ export const tvlQuery = graphql(`
6
+ query GetSteakhouseTvl {
7
+ steakhouseTvl {
8
+ totalUsd
9
+ computedAt
10
+ byChain {
11
+ chain {
12
+ id
13
+ name
14
+ icon
15
+ }
16
+ tvlUsd
17
+ }
18
+ byProtocol {
19
+ protocol
20
+ tvlUsd
21
+ }
22
+ byAssetCategory {
23
+ category
24
+ tvlUsd
25
+ }
26
+ }
27
+ }
28
+ `)
29
+
30
+ export type GetTvlResult = ResultOf<typeof tvlQuery>["steakhouseTvl"]
31
+
32
+ /**
33
+ * Get Steakhouse TVL breakdown by chain, protocol, and asset category.
34
+ */
35
+ export async function getTvl(client: SteakhouseClient): Promise<GetTvlResult> {
36
+ const result = await client.query(tvlQuery, {})
37
+ return result.steakhouseTvl
38
+ }
@@ -1,10 +1 @@
1
- // Fragments
2
- export { type VaultDetail, vaultDetailFragment } from "./fragments/vaultDetail.js"
3
- // Queries
4
- export * from "./getDetailedVault.js"
5
- export * from "./getVaults.js"
6
- // Shared
7
- export { buildSteakhouseMetadata, type SteakhouseMetadata } from "./steakhouseMetadata.js"
8
-
9
- // Types
10
- export type { SteakhouseQueryFn } from "./types.js"
1
+ export * from "./getTvl.js"
@@ -1,3 +1 @@
1
- export { useDetailedVault } from "./useDetailedVault.js"
2
- export { useSteakhouseQuery } from "./useSteakhouseQuery.js"
3
- export { useVaults } from "./useVaults.js"
1
+ export { useTvl } from "./useTvl.js"
@@ -0,0 +1,14 @@
1
+ "use client"
2
+
3
+ import type { UseQueryResult } from "@tanstack/react-query"
4
+ import { useQuery } from "@tanstack/react-query"
5
+ import { type GetTvlResult, getTvl } from "../../queries/getTvl.js"
6
+ import { useSteakhouse } from "../provider.js"
7
+
8
+ export function useTvl(): UseQueryResult<GetTvlResult, Error> {
9
+ const { client } = useSteakhouse()
10
+ return useQuery({
11
+ queryKey: ["steakhouse", "tvl"],
12
+ queryFn: () => getTvl(client),
13
+ })
14
+ }
@@ -1,265 +0,0 @@
1
- import * as gql_tada from 'gql.tada';
2
- import { FragmentOf } from '@whisk/graphql';
3
-
4
- /**
5
- * Full fragment for vault detail view.
6
- * Uses inline fragments to handle both MorphoVault (v1) and MorphoVaultV2.
7
- */
8
- declare const vaultDetailFragment: gql_tada.TadaDocumentNode<{
9
- __typename?: "MorphoVault";
10
- chain: {
11
- id: number;
12
- name: string;
13
- icon: string;
14
- };
15
- vaultAddress: `0x${string}`;
16
- name: string;
17
- symbol: string;
18
- decimals: number;
19
- asset: {
20
- address: `0x${string}`;
21
- symbol: string;
22
- name: string;
23
- icon: string | null;
24
- priceUsd: number | null;
25
- decimals: number;
26
- };
27
- totalAssets: {
28
- raw: bigint;
29
- formatted: string;
30
- usd: number | null;
31
- };
32
- apy: {
33
- base: number;
34
- total: number;
35
- rewards: {
36
- asset: {
37
- symbol: string;
38
- icon: string | null;
39
- };
40
- apr: number;
41
- }[];
42
- fee: number;
43
- };
44
- totalLiquidity: {
45
- formatted: string;
46
- usd: number | null;
47
- };
48
- v1PerformanceFee: number;
49
- feeRecipientAddress: `0x${string}` | null;
50
- ownerAddress: `0x${string}`;
51
- curatorAddress: `0x${string}`;
52
- guardianAddress: `0x${string}`;
53
- metadata: {
54
- description: string | null;
55
- image: string | null;
56
- forumLink: string | null;
57
- curator: {
58
- name: string;
59
- image: string;
60
- url: string;
61
- } | null;
62
- curators: {
63
- name: string;
64
- image: string;
65
- url: string;
66
- }[];
67
- } | null;
68
- marketAllocations: {
69
- market: {
70
- marketId: `0x${string}`;
71
- name: string;
72
- loanAsset: {
73
- symbol: string;
74
- icon: string | null;
75
- };
76
- collateralAsset: {
77
- symbol: string;
78
- icon: string | null;
79
- } | null;
80
- isIdle: boolean;
81
- };
82
- enabled: boolean;
83
- supplyCap: {
84
- formatted: string;
85
- usd: number | null;
86
- };
87
- vaultSupplyShare: number;
88
- marketSupplyShare: number;
89
- position: {
90
- supplyAmount: {
91
- formatted: string;
92
- usd: number | null;
93
- };
94
- };
95
- }[];
96
- riskAssessment: {
97
- steakhouse: {
98
- score: number;
99
- rating: string;
100
- } | null;
101
- };
102
- } | {
103
- __typename?: "MorphoVaultV2";
104
- chain: {
105
- id: number;
106
- name: string;
107
- icon: string;
108
- };
109
- vaultAddress: `0x${string}`;
110
- name: string;
111
- symbol: string;
112
- decimals: number;
113
- asset: {
114
- address: `0x${string}`;
115
- symbol: string;
116
- name: string;
117
- icon: string | null;
118
- priceUsd: number | null;
119
- decimals: number;
120
- };
121
- totalAssets: {
122
- raw: bigint;
123
- formatted: string;
124
- usd: number | null;
125
- };
126
- apy: {
127
- base: number;
128
- total: number;
129
- rewards: {
130
- asset: {
131
- symbol: string;
132
- icon: string | null;
133
- };
134
- apr: number;
135
- }[];
136
- fee: number;
137
- };
138
- curatorAddress: `0x${string}`;
139
- ownerAddress: `0x${string}`;
140
- metadata: {
141
- description: string | null;
142
- image: string | null;
143
- forumLink: string | null;
144
- curator: {
145
- name: string;
146
- image: string;
147
- url: string;
148
- } | null;
149
- curators: {
150
- name: string;
151
- image: string;
152
- url: string;
153
- }[];
154
- } | null;
155
- liquidityAssets: {
156
- formatted: string;
157
- usd: number | null;
158
- };
159
- idleAssets: {
160
- formatted: string;
161
- usd: number | null;
162
- };
163
- v2PerformanceFee: {
164
- formatted: string;
165
- };
166
- managementFee: {
167
- formatted: string;
168
- };
169
- adapters: ({
170
- __typename?: "MarketV1Adapter";
171
- adapterAddress: `0x${string}`;
172
- name: string | null;
173
- } | {
174
- __typename?: "BoxVaultAdapter";
175
- } | {
176
- __typename?: "UnknownAdapter";
177
- } | {
178
- __typename?: "VaultV1Adapter";
179
- })[];
180
- riskAssessment: {
181
- steakhouse: {
182
- score: number;
183
- rating: string;
184
- } | null;
185
- };
186
- } | {
187
- __typename?: "BoxVault";
188
- chain: {
189
- id: number;
190
- name: string;
191
- icon: string;
192
- };
193
- vaultAddress: `0x${string}`;
194
- name: string;
195
- symbol: string;
196
- decimals: number;
197
- asset: {
198
- address: `0x${string}`;
199
- symbol: string;
200
- name: string;
201
- icon: string | null;
202
- priceUsd: number | null;
203
- decimals: number;
204
- };
205
- totalAssets: {
206
- raw: bigint;
207
- formatted: string;
208
- usd: number | null;
209
- };
210
- apy: {
211
- base: number;
212
- total: number;
213
- rewards: {
214
- asset: {
215
- symbol: string;
216
- icon: string | null;
217
- };
218
- apr: number;
219
- }[];
220
- fee: number;
221
- };
222
- } | {
223
- __typename?: "GenericErc4626Vault";
224
- chain: {
225
- id: number;
226
- name: string;
227
- icon: string;
228
- };
229
- vaultAddress: `0x${string}`;
230
- name: string;
231
- symbol: string;
232
- decimals: number;
233
- asset: {
234
- address: `0x${string}`;
235
- symbol: string;
236
- name: string;
237
- icon: string | null;
238
- priceUsd: number | null;
239
- decimals: number;
240
- };
241
- totalAssets: {
242
- raw: bigint;
243
- formatted: string;
244
- usd: number | null;
245
- };
246
- apy: {
247
- base: number;
248
- total: number;
249
- rewards: {
250
- asset: {
251
- symbol: string;
252
- icon: string | null;
253
- };
254
- apr: number;
255
- }[];
256
- fee: number;
257
- };
258
- }, {}, {
259
- fragment: "VaultDetailFragment";
260
- on: "Erc4626Vault";
261
- masked: false;
262
- }>;
263
- type VaultDetail = FragmentOf<typeof vaultDetailFragment>;
264
-
265
- export { type VaultDetail, vaultDetailFragment };