@swapkit/helpers 1.0.0-rc.22 → 1.0.0-rc.24

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.es.js CHANGED
@@ -1,19 +1,19 @@
1
- var gt = Object.defineProperty;
2
- var bt = (s, t, e) => t in s ? gt(s, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : s[t] = e;
3
- var f = (s, t, e) => (bt(s, typeof t != "symbol" ? t + "" : t, e), e), yt = (s, t, e) => {
4
- if (!t.has(s))
1
+ var bt = Object.defineProperty;
2
+ var yt = (r, t, e) => t in r ? bt(r, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : r[t] = e;
3
+ var f = (r, t, e) => (yt(r, typeof t != "symbol" ? t + "" : t, e), e), wt = (r, t, e) => {
4
+ if (!t.has(r))
5
5
  throw TypeError("Cannot " + e);
6
6
  };
7
- var y = (s, t, e) => {
8
- if (t.has(s))
7
+ var y = (r, t, e) => {
8
+ if (t.has(r))
9
9
  throw TypeError("Cannot add the same private member more than once");
10
- t instanceof WeakSet ? t.add(s) : t.set(s, e);
10
+ t instanceof WeakSet ? t.add(r) : t.set(r, e);
11
11
  };
12
- var m = (s, t, e) => (yt(s, t, "access private method"), e);
13
- import { FeeOption as L, BaseDecimal as d, Chain as o, ChainToRPC as wt, MemoType as g } from "@swapkit/types";
14
- const At = "0x313ce567", nt = async ({ chain: s, to: t }) => {
12
+ var m = (r, t, e) => (wt(r, t, "access private method"), e);
13
+ import { FeeOption as L, BaseDecimal as d, Chain as o, EVMChainList as At, ChainToRPC as vt, MemoType as g } from "@swapkit/types";
14
+ const Tt = "0x313ce567", nt = async ({ chain: r, to: t }) => {
15
15
  try {
16
- const { result: e } = await Qt.post(wt[s], {
16
+ const { result: e } = await Zt.post(vt[r], {
17
17
  headers: {
18
18
  accept: "*/*",
19
19
  "content-type": "application/json",
@@ -23,38 +23,38 @@ const At = "0x313ce567", nt = async ({ chain: s, to: t }) => {
23
23
  id: 44,
24
24
  jsonrpc: "2.0",
25
25
  method: "eth_call",
26
- params: [{ to: t.toLowerCase(), data: At }, "latest"]
26
+ params: [{ to: t.toLowerCase(), data: Tt }, "latest"]
27
27
  })
28
28
  });
29
29
  return parseInt(BigInt(e).toString());
30
30
  } catch (e) {
31
- return console.error(e), d[s];
31
+ return console.error(e), d[r];
32
32
  }
33
- }, Tt = async (s) => {
34
- if (s === o.Ethereum)
33
+ }, $t = async (r) => {
34
+ if (r === o.Ethereum)
35
35
  return d.ETH;
36
- const [, t] = s.split("-");
36
+ const [, t] = r.split("-");
37
37
  return t != null && t.startsWith("0x") ? nt({ chain: o.Ethereum, to: t }) : d.ETH;
38
- }, vt = async (s) => {
39
- const [, t] = s.split("-");
38
+ }, Rt = async (r) => {
39
+ const [, t] = r.split("-");
40
40
  return t != null && t.startsWith("0x") ? nt({ chain: o.Avalanche, to: t.toLowerCase() }) : d.AVAX;
41
- }, $t = async (s) => s === o.BinanceSmartChain ? d.BSC : d.BSC, Rt = async ({ chain: s, symbol: t }) => {
42
- switch (s) {
41
+ }, St = async (r) => r === o.BinanceSmartChain ? d.BSC : d.BSC, Ct = async ({ chain: r, symbol: t }) => {
42
+ switch (r) {
43
43
  case o.Ethereum:
44
- return Tt(t);
44
+ return $t(t);
45
45
  case o.Avalanche:
46
- return vt(t);
46
+ return Rt(t);
47
47
  case o.BinanceSmartChain:
48
- return $t(t);
48
+ return St(t);
49
49
  default:
50
- return d[s];
50
+ return d[r];
51
51
  }
52
- }, re = {
52
+ }, ne = {
53
53
  [L.Average]: 1.2,
54
54
  [L.Fast]: 1.5,
55
55
  [L.Fastest]: 2
56
- }, St = ({ chain: s, symbol: t }) => {
57
- switch (s) {
56
+ }, it = ({ chain: r, symbol: t }) => {
57
+ switch (r) {
58
58
  case o.Bitcoin:
59
59
  case o.BitcoinCash:
60
60
  case o.Litecoin:
@@ -62,7 +62,7 @@ const At = "0x313ce567", nt = async ({ chain: s, to: t }) => {
62
62
  case o.Binance:
63
63
  case o.Ethereum:
64
64
  case o.Avalanche:
65
- return t === s;
65
+ return t === r;
66
66
  case o.Arbitrum:
67
67
  case o.Optimism:
68
68
  return t === "ETH";
@@ -79,18 +79,18 @@ const At = "0x313ce567", nt = async ({ chain: s, to: t }) => {
79
79
  case o.THORChain:
80
80
  return t === "RUNE";
81
81
  }
82
- }, Ct = (s) => {
83
- switch (s) {
82
+ }, It = (r) => {
83
+ switch (r) {
84
84
  case "ETH.THOR":
85
85
  return { identifier: "ETH.THOR-0xa5f2211b9b8170f694421f2046281775e8468044", decimal: 18 };
86
86
  case "ETH.vTHOR":
87
87
  return { identifier: "ETH.vTHOR-0x815c23eca83261b6ec689b60cc4a58b54bc24d8d", decimal: 18 };
88
88
  case o.Cosmos:
89
- return { identifier: "GAIA.ATOM", decimal: d[s] };
89
+ return { identifier: "GAIA.ATOM", decimal: d[r] };
90
90
  case o.THORChain:
91
- return { identifier: "THOR.RUNE", decimal: d[s] };
91
+ return { identifier: "THOR.RUNE", decimal: d[r] };
92
92
  case o.BinanceSmartChain:
93
- return { identifier: "BSC.BNB", decimal: d[s] };
93
+ return { identifier: "BSC.BNB", decimal: d[r] };
94
94
  case o.Maya:
95
95
  return { identifier: "MAYA.CACAO", decimal: d.MAYA };
96
96
  case "MAYA.MAYA":
@@ -106,12 +106,12 @@ const At = "0x313ce567", nt = async ({ chain: s, to: t }) => {
106
106
  case o.Polygon:
107
107
  case o.Bitcoin:
108
108
  case o.Ethereum:
109
- return { identifier: `${s}.${s}`, decimal: d[s] };
109
+ return { identifier: `${r}.${r}`, decimal: d[r] };
110
110
  }
111
- }, It = ({ chain: s, symbol: t }) => {
111
+ }, Et = ({ chain: r, symbol: t }) => {
112
112
  if (t.includes("/"))
113
113
  return "Synth";
114
- switch (s) {
114
+ switch (r) {
115
115
  case o.Bitcoin:
116
116
  case o.BitcoinCash:
117
117
  case o.Dogecoin:
@@ -138,127 +138,134 @@ const At = "0x313ce567", nt = async ({ chain: s, to: t }) => {
138
138
  case o.Optimism:
139
139
  return [o.Ethereum, o.Optimism].includes(t) ? "Native" : "OPTIMISM";
140
140
  }
141
- }, se = (s) => {
141
+ }, ie = (r) => {
142
142
  var c;
143
- const [t, ...e] = s.split("."), r = s.includes("/"), n = e.join("."), i = (c = n == null ? void 0 : n.split("-")) == null ? void 0 : c[0];
144
- return { chain: t, symbol: n, ticker: i, synth: r };
145
- }, Et = new RegExp(
143
+ const [t, ...e] = r.split("."), s = r.includes("/"), n = e.join("."), i = (c = n == null ? void 0 : n.split("-")) == null ? void 0 : c[0];
144
+ return { chain: t, symbol: n, ticker: i, synth: s };
145
+ }, Ot = new RegExp(
146
146
  /(.)\1{6}|\.ORG|\.NET|\.FINANCE|\.COM|WWW|HTTP|\\\\|\/\/|[\s$%:[\]]/,
147
147
  "gmi"
148
- ), ne = (s) => s.filter(
149
- (t) => !Et.test(t.toString()) && !t.toString().includes("undefined")
150
- ), Ot = ({
151
- liquidityUnits: s,
148
+ ), Bt = (r) => {
149
+ const [t, e] = r.split(".");
150
+ if (!At.includes(t))
151
+ return !0;
152
+ const [, s] = e.split("-");
153
+ return it({ chain: t, symbol: e }) || !!s;
154
+ }, oe = (r) => r.filter((t) => {
155
+ const e = `${t.chain}.${t.symbol}`;
156
+ return !Ot.test(e) && Bt(e);
157
+ }), Mt = ({
158
+ liquidityUnits: r,
152
159
  poolUnits: t,
153
160
  runeDepth: e
154
161
  }) => {
155
- const r = p(s), n = p(t), i = p(e), c = r.mul(i), a = n.mul(n).mul(2), u = n.mul(r).mul(2), l = r.mul(r), h = n.mul(n).mul(n);
162
+ const s = p(r), n = p(t), i = p(e), c = s.mul(i), a = n.mul(n).mul(2), u = n.mul(s).mul(2), l = s.mul(s), h = n.mul(n).mul(n);
156
163
  return c.mul(a.sub(u).add(l)).div(h);
157
- }, Bt = ({
158
- liquidityUnits: s,
164
+ }, Vt = ({
165
+ liquidityUnits: r,
159
166
  poolUnits: t,
160
167
  assetDepth: e
161
168
  }) => {
162
- const r = p(s), n = p(t), i = p(e), c = r.mul(i), a = n.mul(n).mul(2), u = n.mul(r).mul(2), l = r.mul(r), h = c.mul(a.sub(u).add(l)), _ = n.mul(n).mul(n);
169
+ const s = p(r), n = p(t), i = p(e), c = s.mul(i), a = n.mul(n).mul(2), u = n.mul(s).mul(2), l = s.mul(s), h = c.mul(a.sub(u).add(l)), _ = n.mul(n).mul(n);
163
170
  return h.div(_);
164
- }, ie = ({
165
- percent: s,
171
+ }, ae = ({
172
+ percent: r,
166
173
  runeDepth: t,
167
174
  liquidityUnits: e,
168
- poolUnits: r
169
- }) => Ot({ runeDepth: t, liquidityUnits: e, poolUnits: r }).mul(s), oe = ({
170
- percent: s,
175
+ poolUnits: s
176
+ }) => Mt({ runeDepth: t, liquidityUnits: e, poolUnits: s }).mul(r), ce = ({
177
+ percent: r,
171
178
  assetDepth: t,
172
179
  liquidityUnits: e,
173
- poolUnits: r
174
- }) => Bt({ assetDepth: t, liquidityUnits: e, poolUnits: r }).mul(s), p = (s) => b.fromBigInt(BigInt(s), d.THOR), Mt = ({
175
- liquidityUnits: s,
180
+ poolUnits: s
181
+ }) => Vt({ assetDepth: t, liquidityUnits: e, poolUnits: s }).mul(r), p = (r) => b.fromBigInt(BigInt(r), d.THOR), qt = ({
182
+ liquidityUnits: r,
176
183
  poolUnits: t,
177
184
  runeDepth: e,
178
- assetDepth: r
185
+ assetDepth: s
179
186
  }) => ({
180
- assetAmount: p(r).mul(s).div(t),
181
- runeAmount: p(e).mul(s).div(t)
182
- }), ae = ({
183
- liquidityUnits: s,
187
+ assetAmount: p(s).mul(r).div(t),
188
+ runeAmount: p(e).mul(r).div(t)
189
+ }), ue = ({
190
+ liquidityUnits: r,
184
191
  poolUnits: t,
185
192
  runeDepth: e,
186
- assetDepth: r,
193
+ assetDepth: s,
187
194
  percent: n
188
195
  }) => Object.fromEntries(
189
- Object.entries(Mt({ liquidityUnits: s, poolUnits: t, runeDepth: e, assetDepth: r })).map(
196
+ Object.entries(qt({ liquidityUnits: r, poolUnits: t, runeDepth: e, assetDepth: s })).map(
190
197
  ([i, c]) => [i, c.mul(n)]
191
198
  )
192
- ), ce = ({
193
- runeDepth: s,
199
+ ), le = ({
200
+ runeDepth: r,
194
201
  poolUnits: t,
195
202
  assetDepth: e,
196
- liquidityUnits: r,
203
+ liquidityUnits: s,
197
204
  runeAmount: n,
198
205
  assetAmount: i
199
206
  }) => {
200
- const c = new b({ value: s, decimal: 8 }), a = new b({ value: e, decimal: 8 }), u = new b({ value: t, decimal: 8 }), l = new b({ value: n, decimal: 8 }), h = new b({ value: i, decimal: 8 }), _ = l.mul(a), v = h.mul(c), j = l.mul(h), mt = c.mul(a), pt = u.mul(_.add(v.add(j.mul(2)))), ft = _.add(v.add(mt.mul(2))), Q = pt.div(ft), H = p(r).add(Q);
207
+ const c = new b({ value: r, decimal: 8 }), a = new b({ value: e, decimal: 8 }), u = new b({ value: t, decimal: 8 }), l = new b({ value: n, decimal: 8 }), h = new b({ value: i, decimal: 8 }), _ = l.mul(a), T = h.mul(c), j = l.mul(h), pt = c.mul(a), ft = u.mul(_.add(T.add(j.mul(2)))), _t = _.add(T.add(pt.mul(2))), Q = ft.div(_t), H = p(s).add(Q);
201
208
  if (Q.getBaseValue("number") === 0)
202
209
  return H.div(u).getBaseValue("number");
203
- const _t = u.add(H);
204
- return H.div(_t).getBaseValue("number");
205
- }, ue = ({
206
- runeAmount: s,
210
+ const gt = u.add(H);
211
+ return H.div(gt).getBaseValue("number");
212
+ }, he = ({
213
+ runeAmount: r,
207
214
  assetAmount: t,
208
215
  runeDepth: e,
209
- assetDepth: r
216
+ assetDepth: s
210
217
  }) => {
211
- if (s === "0" || t === "0" || e === "0" || r === "0")
218
+ if (r === "0" || t === "0" || e === "0" || s === "0")
212
219
  return 0;
213
- const n = p(e), i = p(r), c = p(t), a = p(s), u = c.mul(n).sub(i.mul(a)), l = i.mul(a).add(n.mul(i));
220
+ const n = p(e), i = p(s), c = p(t), a = p(r), u = c.mul(n).sub(i.mul(a)), l = i.mul(a).add(n.mul(i));
214
221
  return Math.abs(u.div(l).getBaseValue("number"));
215
- }, Vt = ({
216
- symbol: s,
222
+ }, kt = ({
223
+ symbol: r,
217
224
  ticker: t,
218
225
  chain: e
219
- }) => e === "ETH" && t !== "ETH" ? `${t}-${s.slice(-3)}` : s, le = (s, t) => {
220
- switch (s) {
226
+ }) => e === "ETH" && t !== "ETH" ? `${t}-${r.slice(-3)}` : r, de = (r, t) => {
227
+ switch (r) {
221
228
  case g.LEAVE:
222
229
  case g.BOND: {
223
230
  const { address: e } = t;
224
- return `${s}:${e}`;
231
+ return `${r}:${e}`;
225
232
  }
226
233
  case g.UNBOND: {
227
- const { address: e, unbondAmount: r } = t;
228
- return `${s}:${e}:${r * 10 ** 8}`;
234
+ const { address: e, unbondAmount: s } = t;
235
+ return `${r}:${e}:${s * 10 ** 8}`;
229
236
  }
230
237
  case g.THORNAME_REGISTER: {
231
- const { name: e, chain: r, address: n, owner: i } = t;
232
- return `${s}:${e}:${r}:${n}${i ? `:${i}` : ""}`;
238
+ const { name: e, chain: s, address: n, owner: i } = t;
239
+ return `${r}:${e}:${s}:${n}${i ? `:${i}` : ""}`;
233
240
  }
234
241
  case g.DEPOSIT: {
235
- const { chain: e, symbol: r, address: n, singleSide: i } = t;
236
- return i ? `${s}:${e}/${r}::t:0` : `${s}:${e}.${r}:${n || ""}:t:0`;
242
+ const { chain: e, symbol: s, address: n, singleSide: i } = t;
243
+ return i ? `${r}:${e}/${s}::t:0` : `${r}:${e}.${s}:${n || ""}:t:0`;
237
244
  }
238
245
  case g.WITHDRAW: {
239
- const { chain: e, ticker: r, symbol: n, basisPoints: i, targetAssetString: c, singleSide: a } = t, u = !a && c ? `:${c}` : "", l = Vt({ chain: e, symbol: n, ticker: r });
240
- return `${s}:${e}${a ? "/" : "."}${l}:${i}${u}`;
246
+ const { chain: e, ticker: s, symbol: n, basisPoints: i, targetAssetString: c, singleSide: a } = t, u = !a && c ? `:${c}` : "", l = kt({ chain: e, symbol: n, ticker: s });
247
+ return `${r}:${e}${a ? "/" : "."}${l}:${i}${u}`;
241
248
  }
242
249
  case g.OPEN_LOAN:
243
250
  case g.CLOSE_LOAN: {
244
- const { asset: e, address: r } = t;
245
- return `${s}:${e}:${r}`;
251
+ const { asset: e, address: s } = t;
252
+ return `${r}:${e}:${s}`;
246
253
  }
247
254
  default:
248
255
  return "";
249
256
  }
250
- }, he = (s) => {
251
- if (s < 0)
257
+ }, me = (r) => {
258
+ if (r < 0)
252
259
  throw new Error("Invalid number of year");
253
- return 10 + s;
254
- }, de = (s) => {
255
- if (s.length > 30)
260
+ return 10 + r;
261
+ }, pe = (r) => {
262
+ if (r.length > 30)
256
263
  return !1;
257
264
  const t = /^[a-zA-Z0-9+_-]+$/g;
258
- return !!s.match(t);
259
- }, me = ([s, t, e, r, n]) => `${s}'/${t}'/${e}'/${r}${typeof n != "number" ? "" : `/${n}`}`;
265
+ return !!r.match(t);
266
+ }, fe = ([r, t, e, s, n]) => `${r}'/${t}'/${e}'/${s}${typeof n != "number" ? "" : `/${n}`}`;
260
267
  class X extends Error {
261
- constructor(t, e, r) {
268
+ constructor(t, e, s) {
262
269
  const n = t.status || t.status === 0 ? t.status : "", i = t.statusText || "", c = `${n} ${i}`.trim(), a = c ? `status code ${c}` : "an unknown error";
263
270
  super(`Request failed with ${a}`), Object.defineProperty(this, "response", {
264
271
  enumerable: !0,
@@ -275,10 +282,10 @@ class X extends Error {
275
282
  configurable: !0,
276
283
  writable: !0,
277
284
  value: void 0
278
- }), this.name = "HTTPError", this.response = t, this.request = e, this.options = r;
285
+ }), this.name = "HTTPError", this.response = t, this.request = e, this.options = s;
279
286
  }
280
287
  }
281
- class it extends Error {
288
+ class ot extends Error {
282
289
  constructor(t) {
283
290
  super("Request timed out"), Object.defineProperty(this, "request", {
284
291
  enumerable: !0,
@@ -288,45 +295,45 @@ class it extends Error {
288
295
  }), this.name = "TimeoutError", this.request = t;
289
296
  }
290
297
  }
291
- const V = (s) => s !== null && typeof s == "object", M = (...s) => {
292
- for (const t of s)
298
+ const V = (r) => r !== null && typeof r == "object", M = (...r) => {
299
+ for (const t of r)
293
300
  if ((!V(t) || Array.isArray(t)) && t !== void 0)
294
301
  throw new TypeError("The `options` argument must be an object");
295
- return J({}, ...s);
296
- }, ot = (s = {}, t = {}) => {
297
- const e = new globalThis.Headers(s), r = t instanceof globalThis.Headers, n = new globalThis.Headers(t);
302
+ return J({}, ...r);
303
+ }, at = (r = {}, t = {}) => {
304
+ const e = new globalThis.Headers(r), s = t instanceof globalThis.Headers, n = new globalThis.Headers(t);
298
305
  for (const [i, c] of n.entries())
299
- r && c === "undefined" || c === void 0 ? e.delete(i) : e.set(i, c);
306
+ s && c === "undefined" || c === void 0 ? e.delete(i) : e.set(i, c);
300
307
  return e;
301
- }, J = (...s) => {
308
+ }, J = (...r) => {
302
309
  let t = {}, e = {};
303
- for (const r of s)
304
- if (Array.isArray(r))
305
- Array.isArray(t) || (t = []), t = [...t, ...r];
306
- else if (V(r)) {
307
- for (let [n, i] of Object.entries(r))
310
+ for (const s of r)
311
+ if (Array.isArray(s))
312
+ Array.isArray(t) || (t = []), t = [...t, ...s];
313
+ else if (V(s)) {
314
+ for (let [n, i] of Object.entries(s))
308
315
  V(i) && n in t && (i = J(t[n], i)), t = { ...t, [n]: i };
309
- V(r.headers) && (e = ot(e, r.headers), t.headers = e);
316
+ V(s.headers) && (e = at(e, s.headers), t.headers = e);
310
317
  }
311
318
  return t;
312
- }, kt = (() => {
313
- let s = !1, t = !1;
314
- const e = typeof globalThis.ReadableStream == "function", r = typeof globalThis.Request == "function";
315
- return e && r && (t = new globalThis.Request("https://empty.invalid", {
319
+ }, xt = (() => {
320
+ let r = !1, t = !1;
321
+ const e = typeof globalThis.ReadableStream == "function", s = typeof globalThis.Request == "function";
322
+ return e && s && (t = new globalThis.Request("https://empty.invalid", {
316
323
  body: new globalThis.ReadableStream(),
317
324
  method: "POST",
318
325
  // @ts-expect-error - Types are outdated.
319
326
  get duplex() {
320
- return s = !0, "half";
327
+ return r = !0, "half";
321
328
  }
322
- }).headers.has("Content-Type")), s && !t;
323
- })(), qt = typeof globalThis.AbortController == "function", xt = typeof globalThis.ReadableStream == "function", Pt = typeof globalThis.FormData == "function", at = ["get", "post", "put", "patch", "head", "delete"], Nt = {
329
+ }).headers.has("Content-Type")), r && !t;
330
+ })(), Pt = typeof globalThis.AbortController == "function", Nt = typeof globalThis.ReadableStream == "function", jt = typeof globalThis.FormData == "function", ct = ["get", "post", "put", "patch", "head", "delete"], Ht = {
324
331
  json: "application/json",
325
332
  text: "text/*",
326
333
  formData: "multipart/form-data",
327
334
  arrayBuffer: "*/*",
328
335
  blob: "*/*"
329
- }, D = 2147483647, ct = Symbol("stop"), jt = {
336
+ }, D = 2147483647, ut = Symbol("stop"), Lt = {
330
337
  json: !0,
331
338
  parseJson: !0,
332
339
  searchParams: !0,
@@ -337,7 +344,7 @@ const V = (s) => s !== null && typeof s == "object", M = (...s) => {
337
344
  throwHttpErrors: !0,
338
345
  onDownloadProgress: !0,
339
346
  fetch: !0
340
- }, Ht = {
347
+ }, Dt = {
341
348
  method: !0,
342
349
  headers: !0,
343
350
  body: !0,
@@ -353,86 +360,86 @@ const V = (s) => s !== null && typeof s == "object", M = (...s) => {
353
360
  window: !0,
354
361
  dispatcher: !0,
355
362
  duplex: !0
356
- }, Lt = (s) => at.includes(s) ? s.toUpperCase() : s, Dt = ["get", "put", "head", "delete", "options", "trace"], Ut = [408, 413, 429, 500, 502, 503, 504], ut = [413, 429, 503], Z = {
363
+ }, Ut = (r) => ct.includes(r) ? r.toUpperCase() : r, Ft = ["get", "put", "head", "delete", "options", "trace"], Wt = [408, 413, 429, 500, 502, 503, 504], lt = [413, 429, 503], Z = {
357
364
  limit: 2,
358
- methods: Dt,
359
- statusCodes: Ut,
360
- afterStatusCodes: ut,
365
+ methods: Ft,
366
+ statusCodes: Wt,
367
+ afterStatusCodes: lt,
361
368
  maxRetryAfter: Number.POSITIVE_INFINITY,
362
369
  backoffLimit: Number.POSITIVE_INFINITY,
363
- delay: (s) => 0.3 * 2 ** (s - 1) * 1e3
364
- }, Ft = (s = {}) => {
365
- if (typeof s == "number")
370
+ delay: (r) => 0.3 * 2 ** (r - 1) * 1e3
371
+ }, Gt = (r = {}) => {
372
+ if (typeof r == "number")
366
373
  return {
367
374
  ...Z,
368
- limit: s
375
+ limit: r
369
376
  };
370
- if (s.methods && !Array.isArray(s.methods))
377
+ if (r.methods && !Array.isArray(r.methods))
371
378
  throw new Error("retry.methods must be an array");
372
- if (s.statusCodes && !Array.isArray(s.statusCodes))
379
+ if (r.statusCodes && !Array.isArray(r.statusCodes))
373
380
  throw new Error("retry.statusCodes must be an array");
374
381
  return {
375
382
  ...Z,
376
- ...s,
377
- afterStatusCodes: ut
383
+ ...r,
384
+ afterStatusCodes: lt
378
385
  };
379
386
  };
380
- async function Wt(s, t, e, r) {
387
+ async function Yt(r, t, e, s) {
381
388
  return new Promise((n, i) => {
382
389
  const c = setTimeout(() => {
383
- e && e.abort(), i(new it(s));
384
- }, r.timeout);
385
- r.fetch(s, t).then(n).catch(i).then(() => {
390
+ e && e.abort(), i(new ot(r));
391
+ }, s.timeout);
392
+ s.fetch(r, t).then(n).catch(i).then(() => {
386
393
  clearTimeout(c);
387
394
  });
388
395
  });
389
396
  }
390
- async function Gt(s, { signal: t }) {
391
- return new Promise((e, r) => {
397
+ async function zt(r, { signal: t }) {
398
+ return new Promise((e, s) => {
392
399
  t && (t.throwIfAborted(), t.addEventListener("abort", n, { once: !0 }));
393
400
  function n() {
394
- clearTimeout(i), r(t.reason);
401
+ clearTimeout(i), s(t.reason);
395
402
  }
396
403
  const i = setTimeout(() => {
397
404
  t == null || t.removeEventListener("abort", n), e();
398
- }, s);
405
+ }, r);
399
406
  });
400
407
  }
401
- const Yt = (s, t) => {
408
+ const Jt = (r, t) => {
402
409
  const e = {};
403
- for (const r in t)
404
- !(r in Ht) && !(r in jt) && !(r in s) && (e[r] = t[r]);
410
+ for (const s in t)
411
+ !(s in Dt) && !(s in Lt) && !(s in r) && (e[s] = t[s]);
405
412
  return e;
406
413
  };
407
- class q {
414
+ class k {
408
415
  static create(t, e) {
409
- const r = new q(t, e), n = async () => {
410
- if (typeof r._options.timeout == "number" && r._options.timeout > D)
416
+ const s = new k(t, e), n = async () => {
417
+ if (typeof s._options.timeout == "number" && s._options.timeout > D)
411
418
  throw new RangeError(`The \`timeout\` option cannot be greater than ${D}`);
412
419
  await Promise.resolve();
413
- let a = await r._fetch();
414
- for (const u of r._options.hooks.afterResponse) {
415
- const l = await u(r.request, r._options, r._decorateResponse(a.clone()));
420
+ let a = await s._fetch();
421
+ for (const u of s._options.hooks.afterResponse) {
422
+ const l = await u(s.request, s._options, s._decorateResponse(a.clone()));
416
423
  l instanceof globalThis.Response && (a = l);
417
424
  }
418
- if (r._decorateResponse(a), !a.ok && r._options.throwHttpErrors) {
419
- let u = new X(a, r.request, r._options);
420
- for (const l of r._options.hooks.beforeError)
425
+ if (s._decorateResponse(a), !a.ok && s._options.throwHttpErrors) {
426
+ let u = new X(a, s.request, s._options);
427
+ for (const l of s._options.hooks.beforeError)
421
428
  u = await l(u);
422
429
  throw u;
423
430
  }
424
- if (r._options.onDownloadProgress) {
425
- if (typeof r._options.onDownloadProgress != "function")
431
+ if (s._options.onDownloadProgress) {
432
+ if (typeof s._options.onDownloadProgress != "function")
426
433
  throw new TypeError("The `onDownloadProgress` option must be a function");
427
- if (!xt)
434
+ if (!Nt)
428
435
  throw new Error("Streams are not supported in your environment. `ReadableStream` is missing.");
429
- return r._stream(a.clone(), r._options.onDownloadProgress);
436
+ return s._stream(a.clone(), s._options.onDownloadProgress);
430
437
  }
431
438
  return a;
432
- }, c = r._options.retry.methods.includes(r.request.method.toLowerCase()) ? r._retry(n) : n();
433
- for (const [a, u] of Object.entries(Nt))
439
+ }, c = s._options.retry.methods.includes(s.request.method.toLowerCase()) ? s._retry(n) : n();
440
+ for (const [a, u] of Object.entries(Ht))
434
441
  c[a] = async () => {
435
- r.request.headers.set("accept", r.request.headers.get("accept") || u);
442
+ s.request.headers.set("accept", s.request.headers.get("accept") || u);
436
443
  const h = (await c).clone();
437
444
  if (a === "json") {
438
445
  if (h.status === 204 || (await h.clone().arrayBuffer()).byteLength === 0)
@@ -475,17 +482,17 @@ class q {
475
482
  // TODO: credentials can be removed when the spec change is implemented in all browsers. Context: https://www.chromestatus.com/feature/4539473312350208
476
483
  credentials: this._input.credentials || "same-origin",
477
484
  ...e,
478
- headers: ot(this._input.headers, e.headers),
485
+ headers: at(this._input.headers, e.headers),
479
486
  hooks: J({
480
487
  beforeRequest: [],
481
488
  beforeRetry: [],
482
489
  beforeError: [],
483
490
  afterResponse: []
484
491
  }, e.hooks),
485
- method: Lt(e.method ?? this._input.method),
492
+ method: Ut(e.method ?? this._input.method),
486
493
  // eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing
487
494
  prefixUrl: String(e.prefixUrl || ""),
488
- retry: Ft(e.retry),
495
+ retry: Gt(e.retry),
489
496
  throwHttpErrors: e.throwHttpErrors !== !1,
490
497
  timeout: e.timeout ?? 1e4,
491
498
  fetch: e.fetch ?? globalThis.fetch.bind(globalThis)
@@ -496,30 +503,30 @@ class q {
496
503
  throw new Error("`input` must not begin with a slash when using `prefixUrl`");
497
504
  this._options.prefixUrl.endsWith("/") || (this._options.prefixUrl += "/"), this._input = this._options.prefixUrl + this._input;
498
505
  }
499
- if (qt) {
506
+ if (Pt) {
500
507
  if (this.abortController = new globalThis.AbortController(), this._options.signal) {
501
- const r = this._options.signal;
508
+ const s = this._options.signal;
502
509
  this._options.signal.addEventListener("abort", () => {
503
- this.abortController.abort(r.reason);
510
+ this.abortController.abort(s.reason);
504
511
  });
505
512
  }
506
513
  this._options.signal = this.abortController.signal;
507
514
  }
508
- if (kt && (this._options.duplex = "half"), this.request = new globalThis.Request(this._input, this._options), this._options.searchParams) {
515
+ if (xt && (this._options.duplex = "half"), this.request = new globalThis.Request(this._input, this._options), this._options.searchParams) {
509
516
  const n = "?" + (typeof this._options.searchParams == "string" ? this._options.searchParams.replace(/^\?/, "") : new URLSearchParams(this._options.searchParams).toString()), i = this.request.url.replace(/(?:\?.*?)?(?=#|$)/, n);
510
- (Pt && this._options.body instanceof globalThis.FormData || this._options.body instanceof URLSearchParams) && !(this._options.headers && this._options.headers["content-type"]) && this.request.headers.delete("content-type"), this.request = new globalThis.Request(new globalThis.Request(i, { ...this.request }), this._options);
517
+ (jt && this._options.body instanceof globalThis.FormData || this._options.body instanceof URLSearchParams) && !(this._options.headers && this._options.headers["content-type"]) && this.request.headers.delete("content-type"), this.request = new globalThis.Request(new globalThis.Request(i, { ...this.request }), this._options);
511
518
  }
512
519
  this._options.json !== void 0 && (this._options.body = JSON.stringify(this._options.json), this.request.headers.set("content-type", this._options.headers.get("content-type") ?? "application/json"), this.request = new globalThis.Request(this.request, { body: this._options.body }));
513
520
  }
514
521
  _calculateRetryDelay(t) {
515
- if (this._retryCount++, this._retryCount < this._options.retry.limit && !(t instanceof it)) {
522
+ if (this._retryCount++, this._retryCount < this._options.retry.limit && !(t instanceof ot)) {
516
523
  if (t instanceof X) {
517
524
  if (!this._options.retry.statusCodes.includes(t.response.status))
518
525
  return 0;
519
- const r = t.response.headers.get("Retry-After");
520
- if (r && this._options.retry.afterStatusCodes.includes(t.response.status)) {
521
- let n = Number(r);
522
- return Number.isNaN(n) ? n = Date.parse(r) - Date.now() : n *= 1e3, this._options.retry.maxRetryAfter !== void 0 && n > this._options.retry.maxRetryAfter ? 0 : n;
526
+ const s = t.response.headers.get("Retry-After");
527
+ if (s && this._options.retry.afterStatusCodes.includes(t.response.status)) {
528
+ let n = Number(s);
529
+ return Number.isNaN(n) ? n = Date.parse(s) - Date.now() : n *= 1e3, this._options.retry.maxRetryAfter !== void 0 && n > this._options.retry.maxRetryAfter ? 0 : n;
523
530
  }
524
531
  if (t.response.status === 413)
525
532
  return 0;
@@ -536,16 +543,16 @@ class q {
536
543
  try {
537
544
  return await t();
538
545
  } catch (e) {
539
- const r = Math.min(this._calculateRetryDelay(e), D);
540
- if (r !== 0 && this._retryCount > 0) {
541
- await Gt(r, { signal: this._options.signal });
546
+ const s = Math.min(this._calculateRetryDelay(e), D);
547
+ if (s !== 0 && this._retryCount > 0) {
548
+ await zt(s, { signal: this._options.signal });
542
549
  for (const n of this._options.hooks.beforeRetry)
543
550
  if (await n({
544
551
  request: this.request,
545
552
  options: this._options,
546
553
  error: e,
547
554
  retryCount: this._retryCount
548
- }) === ct)
555
+ }) === ut)
549
556
  return;
550
557
  return this._retry(t);
551
558
  }
@@ -554,29 +561,29 @@ class q {
554
561
  }
555
562
  async _fetch() {
556
563
  for (const e of this._options.hooks.beforeRequest) {
557
- const r = await e(this.request, this._options);
558
- if (r instanceof Request) {
559
- this.request = r;
564
+ const s = await e(this.request, this._options);
565
+ if (s instanceof Request) {
566
+ this.request = s;
560
567
  break;
561
568
  }
562
- if (r instanceof Response)
563
- return r;
569
+ if (s instanceof Response)
570
+ return s;
564
571
  }
565
- const t = Yt(this.request, this._options);
566
- return this._options.timeout === !1 ? this._options.fetch(this.request.clone(), t) : Wt(this.request.clone(), t, this.abortController, this._options);
572
+ const t = Jt(this.request, this._options);
573
+ return this._options.timeout === !1 ? this._options.fetch(this.request.clone(), t) : Yt(this.request.clone(), t, this.abortController, this._options);
567
574
  }
568
575
  /* istanbul ignore next */
569
576
  _stream(t, e) {
570
- const r = Number(t.headers.get("content-length")) || 0;
577
+ const s = Number(t.headers.get("content-length")) || 0;
571
578
  let n = 0;
572
- return t.status === 204 ? (e && e({ percent: 1, totalBytes: r, transferredBytes: n }, new Uint8Array()), new globalThis.Response(null, {
579
+ return t.status === 204 ? (e && e({ percent: 1, totalBytes: s, transferredBytes: n }, new Uint8Array()), new globalThis.Response(null, {
573
580
  status: t.status,
574
581
  statusText: t.statusText,
575
582
  headers: t.headers
576
583
  })) : new globalThis.Response(new globalThis.ReadableStream({
577
584
  async start(i) {
578
585
  const c = t.body.getReader();
579
- e && e({ percent: 0, transferredBytes: 0, totalBytes: r }, new Uint8Array());
586
+ e && e({ percent: 0, transferredBytes: 0, totalBytes: s }, new Uint8Array());
580
587
  async function a() {
581
588
  const { done: u, value: l } = await c.read();
582
589
  if (u) {
@@ -585,8 +592,8 @@ class q {
585
592
  }
586
593
  if (e) {
587
594
  n += l.byteLength;
588
- const h = r === 0 ? 0 : n / r;
589
- e({ percent: h, transferredBytes: n, totalBytes: r }, l);
595
+ const h = s === 0 ? 0 : n / s;
596
+ e({ percent: h, transferredBytes: n, totalBytes: s }, l);
590
597
  }
591
598
  i.enqueue(l), await a();
592
599
  }
@@ -600,57 +607,57 @@ class q {
600
607
  }
601
608
  }
602
609
  /*! MIT License © Sindre Sorhus */
603
- const F = (s) => {
604
- const t = (e, r) => q.create(e, M(s, r));
605
- for (const e of at)
606
- t[e] = (r, n) => q.create(r, M(s, n, { method: e }));
607
- return t.create = (e) => F(M(e)), t.extend = (e) => F(M(s, e)), t.stop = ct, t;
608
- }, zt = F(), Jt = zt, Kt = typeof window < "u" ? {} : { referrer: "https://sk.thorswap.net", referer: "https://sk.thorswap.net" }, tt = Jt.create({ headers: Kt }), Qt = {
609
- get: (s, t) => tt.get(s, t).json(),
610
- post: (s, t) => tt.post(s, t).json()
611
- }, et = Object.values(o), Xt = (s = "") => {
612
- const t = s.toUpperCase(), [e] = t.split(".");
610
+ const F = (r) => {
611
+ const t = (e, s) => k.create(e, M(r, s));
612
+ for (const e of ct)
613
+ t[e] = (s, n) => k.create(s, M(r, n, { method: e }));
614
+ return t.create = (e) => F(M(e)), t.extend = (e) => F(M(r, e)), t.stop = ut, t;
615
+ }, Kt = F(), Qt = Kt, Xt = typeof window < "u" ? {} : { referrer: "https://sk.thorswap.net", referer: "https://sk.thorswap.net" }, tt = Qt.create({ headers: Xt }), Zt = {
616
+ get: (r, t) => tt.get(r, t).json(),
617
+ post: (r, t) => tt.post(r, t).json()
618
+ }, et = Object.values(o), te = (r = "") => {
619
+ const t = r.toUpperCase(), [e] = t.split(".");
613
620
  if (et.includes(e))
614
621
  return !0;
615
- const [r] = t.split("/");
616
- if (et.includes(r))
622
+ const [s] = t.split("/");
623
+ if (et.includes(s))
617
624
  return !0;
618
625
  throw new Error(
619
- `Invalid identifier: ${s}. Expected format: <Chain>.<Ticker> or <Chain>.<Ticker>-<ContractAddress>`
626
+ `Invalid identifier: ${r}. Expected format: <Chain>.<Ticker> or <Chain>.<Ticker>-<ContractAddress>`
620
627
  );
621
- }, I = 8, $ = (s) => 10n ** BigInt(s), R = (s) => Math.log10(parseFloat(s.toString()));
628
+ }, I = 8, $ = (r) => 10n ** BigInt(r), R = (r) => Math.log10(parseFloat(r.toString()));
622
629
  function x({
623
- value: s,
630
+ value: r,
624
631
  bigIntDecimal: t = I,
625
632
  decimal: e = I
626
633
  }) {
627
- const r = s < 0n;
628
- let n = s.toString().substring(r ? 1 : 0);
634
+ const s = r < 0n;
635
+ let n = r.toString().substring(s ? 1 : 0);
629
636
  const i = e - (n.length - 1);
630
637
  i > 0 && (n = "0".repeat(i) + n);
631
638
  const c = n.length - e;
632
639
  let a = n.slice(-e);
633
- return parseInt(a[t]) >= 5 ? a = `${a.substring(0, t - 1)}${(parseInt(a[t - 1]) + 1).toString()}` : a = a.substring(0, t), `${r ? "-" : ""}${n.slice(0, c)}.${a}`.replace(
640
+ return parseInt(a[t]) >= 5 ? a = `${a.substring(0, t - 1)}${(parseInt(a[t - 1]) + 1).toString()}` : a = a.substring(0, t), `${s ? "-" : ""}${n.slice(0, c)}.${a}`.replace(
634
641
  /\.?0*$/,
635
642
  ""
636
643
  );
637
644
  }
638
- var A, S, P, lt, N, ht, O, W, T, C, B, G;
645
+ var A, S, P, ht, N, dt, O, W, v, C, B, G;
639
646
  const K = class K {
640
647
  constructor(t) {
641
648
  y(this, A);
642
649
  y(this, P);
643
650
  y(this, N);
644
651
  y(this, O);
645
- y(this, T);
652
+ y(this, v);
646
653
  y(this, B);
647
654
  f(this, "decimalMultiplier", 10n ** 8n);
648
655
  f(this, "bigIntValue", 0n);
649
656
  f(this, "decimal");
650
657
  const e = U(t);
651
658
  this.decimal = typeof t == "object" ? t.decimal : void 0, this.decimalMultiplier = $(
652
- Math.max(m(this, B, G).call(this, m(this, T, C).call(this, e)), this.decimal || 0)
653
- ), m(this, P, lt).call(this, e);
659
+ Math.max(m(this, B, G).call(this, m(this, v, C).call(this, e)), this.decimal || 0)
660
+ ), m(this, P, ht).call(this, e);
654
661
  }
655
662
  static fromBigInt(t, e) {
656
663
  return new K({
@@ -661,11 +668,11 @@ const K = class K {
661
668
  static shiftDecimals({
662
669
  value: t,
663
670
  from: e,
664
- to: r
671
+ to: s
665
672
  }) {
666
673
  return this.fromBigInt(
667
- t.getBaseValue("bigint") * $(r) / $(e),
668
- r
674
+ t.getBaseValue("bigint") * $(s) / $(e),
675
+ s
669
676
  );
670
677
  }
671
678
  set(t) {
@@ -713,35 +720,35 @@ const K = class K {
713
720
  }
714
721
  }
715
722
  getBaseValue(t) {
716
- const e = this.decimalMultiplier / $(this.decimal || d.THOR), r = this.bigIntValue / e;
723
+ const e = this.decimalMultiplier / $(this.decimal || d.THOR), s = this.bigIntValue / e;
717
724
  switch (t) {
718
725
  case "number":
719
- return Number(r);
726
+ return Number(s);
720
727
  case "string":
721
- return r.toString();
728
+ return s.toString();
722
729
  default:
723
- return r;
730
+ return s;
724
731
  }
725
732
  }
726
733
  getBigIntValue(t, e) {
727
734
  if (!e && typeof t == "object")
728
735
  return t.bigIntValue;
729
- const r = U(t), n = m(this, T, C).call(this, r);
736
+ const s = U(t), n = m(this, v, C).call(this, s);
730
737
  return n === "0" || n === "undefined" ? 0n : m(this, O, W).call(this, n, e);
731
738
  }
732
739
  formatBigIntToSafeValue(t, e) {
733
- const r = e || this.decimal || I, n = Math.max(
734
- r,
740
+ const s = e || this.decimal || I, n = Math.max(
741
+ s,
735
742
  R(this.decimalMultiplier)
736
743
  ), i = t < 0n, c = t.toString().substring(i ? 1 : 0), a = n - (c.length - 1), u = a > 0 ? "0".repeat(a) + c : c, l = u.length - n;
737
744
  let h = u.slice(-n);
738
- return parseInt(h[r]) >= 5 ? h = `${h.substring(0, r - 1)}${(parseInt(h[r - 1]) + 1).toString()}` : h = h.substring(0, r), `${i ? "-" : ""}${u.slice(
745
+ return parseInt(h[s]) >= 5 ? h = `${h.substring(0, s - 1)}${(parseInt(h[s - 1]) + 1).toString()}` : h = h.substring(0, s), `${i ? "-" : ""}${u.slice(
739
746
  0,
740
747
  l
741
748
  )}.${h}`.replace(/\.?0*$/, "");
742
749
  }
743
750
  toSignificant(t = 6) {
744
- const [e, r] = this.getValue("string").split("."), n = e || "", i = r || "";
751
+ const [e, s] = this.getValue("string").split("."), n = e || "", i = s || "";
745
752
  if ((parseInt(n) ? n.length + i.length : i.length) <= t)
746
753
  return this.getValue("string");
747
754
  if (n.length >= t)
@@ -758,7 +765,7 @@ const K = class K {
758
765
  )}`;
759
766
  }
760
767
  toFixed(t = 6) {
761
- const [e, r] = this.getValue("string").split("."), n = e || "", i = r || "";
768
+ const [e, s] = this.getValue("string").split("."), n = e || "", i = s || "";
762
769
  if (parseInt(n))
763
770
  return `${n}.${i.slice(0, t)}`.padEnd(t, "0");
764
771
  const c = parseInt(i), a = `${c}`.slice(0, t);
@@ -768,7 +775,7 @@ const K = class K {
768
775
  )}`;
769
776
  }
770
777
  toAbbreviation(t = 2) {
771
- const e = this.getValue("number"), r = ["", "K", "M", "B", "T", "Q", "Qi", "S"], n = Math.floor(Math.log10(Math.abs(e)) / 3), i = r[n];
778
+ const e = this.getValue("number"), s = ["", "K", "M", "B", "T", "Q", "Qi", "S"], n = Math.floor(Math.log10(Math.abs(e)) / 3), i = s[n];
772
779
  if (!i)
773
780
  return this.getValue("string");
774
781
  const c = 10 ** (n * 3);
@@ -776,18 +783,18 @@ const K = class K {
776
783
  }
777
784
  toCurrency(t = "$", {
778
785
  currencyPosition: e = "start",
779
- decimal: r = 2,
786
+ decimal: s = 2,
780
787
  decimalSeparator: n = ".",
781
788
  thousandSeparator: i = ","
782
789
  } = {}) {
783
- const c = this.getValue("number"), [a, u = ""] = c.toFixed(6).split("."), l = a.replace(/\B(?=(\d{3})+(?!\d))/g, i), h = !a && !u ? "0.00" : a === "0" ? `${parseFloat(`0.${u}`)}`.replace(".", n) : `${l}${u ? `${n}${u.slice(0, r)}` : ""}`;
790
+ const c = this.getValue("number"), [a, u = ""] = c.toFixed(6).split("."), l = a.replace(/\B(?=(\d{3})+(?!\d))/g, i), h = !a && !u ? "0.00" : a === "0" ? `${parseFloat(`0.${u}`)}`.replace(".", n) : `${l}${u ? `${n}${u.slice(0, s)}` : ""}`;
784
791
  return `${e === "start" ? t : ""}${h}${e === "end" ? t : ""}`;
785
792
  }
786
793
  };
787
794
  A = new WeakSet(), S = function(t, ...e) {
788
- const r = m(this, N, ht).call(this, this, ...e), n = $(r), i = e.reduce(
795
+ const s = m(this, N, dt).call(this, this, ...e), n = $(s), i = e.reduce(
789
796
  (a, u) => {
790
- const l = this.getBigIntValue(u, r);
797
+ const l = this.getBigIntValue(u, s);
791
798
  switch (t) {
792
799
  case "add":
793
800
  return a + l;
@@ -807,50 +814,51 @@ A = new WeakSet(), S = function(t, ...e) {
807
814
  //normalize is to precision multiplier base
808
815
  this.bigIntValue * n / this.decimalMultiplier
809
816
  ), c = x({
810
- bigIntDecimal: r,
811
- decimal: Math.max(r, R(this.decimalMultiplier)),
817
+ bigIntDecimal: s,
818
+ decimal: Math.max(s, R(this.decimalMultiplier)),
812
819
  value: i
813
820
  });
814
821
  return new this.constructor({ decimal: this.decimal, value: c, identifier: this.toString() });
815
- }, P = new WeakSet(), lt = function(t) {
816
- const e = m(this, T, C).call(this, t) || "0";
822
+ }, P = new WeakSet(), ht = function(t) {
823
+ const e = m(this, v, C).call(this, t) || "0";
817
824
  this.bigIntValue = m(this, O, W).call(this, e);
818
- }, N = new WeakSet(), ht = function(...t) {
825
+ }, N = new WeakSet(), dt = function(...t) {
819
826
  const e = t.map(
820
- (r) => typeof r == "object" ? r.decimal || R(r.decimalMultiplier) : m(this, B, G).call(this, m(this, T, C).call(this, r))
827
+ (s) => typeof s == "object" ? s.decimal || R(s.decimalMultiplier) : m(this, B, G).call(this, m(this, v, C).call(this, s))
821
828
  ).filter(Boolean);
822
829
  return Math.max(...e, I);
823
830
  }, O = new WeakSet(), W = function(t, e) {
824
- const r = e ? $(e) : this.decimalMultiplier, n = R(r), [i = "", c = ""] = t.split(".");
831
+ const s = e ? $(e) : this.decimalMultiplier, n = R(s), [i = "", c = ""] = t.split(".");
825
832
  return BigInt(`${i}${c.padEnd(n, "0")}`);
826
- }, T = new WeakSet(), C = function(t) {
827
- const r = `${typeof t == "number" ? Number(t).toLocaleString("fullwide", {
833
+ }, v = new WeakSet(), C = function(t) {
834
+ const s = `${typeof t == "number" ? Number(t).toLocaleString("fullwide", {
828
835
  useGrouping: !1,
829
836
  maximumFractionDigits: 20
830
837
  }) : U(t)}`.replaceAll(",", ".").split(".");
831
- return r.length > 1 ? `${r.slice(0, -1).join("")}.${r.at(-1)}` : r[0];
838
+ return s.length > 1 ? `${s.slice(0, -1).join("")}.${s.at(-1)}` : s[0];
832
839
  }, B = new WeakSet(), G = function(t) {
833
- var r;
834
- const e = ((r = t.split(".")[1]) == null ? void 0 : r.length) || 0;
840
+ var s;
841
+ const e = ((s = t.split(".")[1]) == null ? void 0 : s.length) || 0;
835
842
  return Math.max(e, I);
836
843
  };
837
844
  let E = K;
838
- function U(s) {
839
- return typeof s == "object" ? "getValue" in s ? s.getValue("string") : s.value : s;
845
+ function U(r) {
846
+ return typeof r == "object" ? "getValue" in r ? r.getValue("string") : r.value : r;
840
847
  }
841
- const k = (s, t) => typeof s == "bigint" ? x({ value: s, bigIntDecimal: t, decimal: t }) : s;
848
+ const q = (r, t) => typeof r == "bigint" ? x({ value: r, bigIntDecimal: t, decimal: t }) : r;
842
849
  let Y;
843
- const rt = (s) => {
850
+ const st = (r) => {
844
851
  if (!Y)
845
852
  throw new Error("Static assets not loaded, call await AssetValue.loadStaticAssets() first");
846
- return Y.get(s.toUpperCase()) || { decimal: d.THOR, identifier: "" };
847
- }, st = async (s, t = 0) => {
848
- Xt(s);
849
- const e = await Rt(z(s)), r = k(t, e);
850
- return new w({ decimal: e, value: r, identifier: s });
853
+ return Y.get(r.toUpperCase()) || { decimal: d.THOR, identifier: "" };
854
+ }, rt = async (r, t = 0) => {
855
+ te(r);
856
+ const e = await Ct(z(r)), s = q(t, e);
857
+ return new w({ decimal: e, value: s, identifier: r });
851
858
  };
852
859
  class w extends E {
853
860
  constructor(e) {
861
+ const s = "identifier" in e ? e.identifier : `${e.chain}.${e.symbol}`;
854
862
  super(
855
863
  e.value instanceof E ? e.value : { decimal: e.decimal, value: e.value }
856
864
  );
@@ -861,45 +869,45 @@ class w extends E {
861
869
  f(this, "symbol");
862
870
  f(this, "ticker");
863
871
  f(this, "type");
864
- const r = "identifier" in e ? e.identifier : `${e.chain}.${e.symbol}`, n = z(r);
865
- this.type = It(n), this.chain = n.chain, this.ticker = n.ticker, this.symbol = n.symbol, this.address = n.address, this.isSynthetic = n.isSynthetic, this.isGasAsset = n.isGasAsset;
872
+ const n = z(s);
873
+ this.type = Et(n), this.chain = n.chain, this.ticker = n.ticker, this.symbol = n.symbol, this.address = n.address, this.isSynthetic = n.isSynthetic, this.isGasAsset = n.isGasAsset;
866
874
  }
867
875
  get assetValue() {
868
876
  return `${this.getValue("string")} ${this.ticker}`;
869
877
  }
870
878
  toString(e = !1) {
871
- const r = this.isSynthetic ? this.symbol.split("-")[0] : `${this.chain}.${this.ticker}`;
872
- return e ? r : (
879
+ const s = this.isSynthetic ? this.symbol.split("-")[0] : `${this.chain}.${this.ticker}`;
880
+ return e ? s : (
873
881
  // THOR.ETH/ETH | ETH.USDT-0x1234567890
874
882
  `${this.chain}.${this.symbol}`
875
883
  );
876
884
  }
877
- eq({ chain: e, symbol: r }) {
878
- return this.chain === e && this.symbol === r;
885
+ eq({ chain: e, symbol: s }) {
886
+ return this.chain === e && this.symbol === s;
879
887
  }
880
- static async fromString(e, r = 0) {
881
- return st(e, r);
888
+ static async fromString(e, s = 0) {
889
+ return rt(e, s);
882
890
  }
883
- static fromStringSync(e, r = 0) {
884
- const { isSynthetic: n } = z(e), { decimal: i, identifier: c } = rt(
891
+ static fromStringSync(e, s = 0) {
892
+ const { isSynthetic: n } = z(e), { decimal: i, identifier: c } = st(
885
893
  e
886
- ), a = k(r, i);
894
+ ), a = q(s, i);
887
895
  return c ? new w({ decimal: i, identifier: c, value: a }) : n ? new w({ decimal: 8, identifier: e, value: a }) : void 0;
888
896
  }
889
- static async fromIdentifier(e, r = 0) {
890
- return st(e, r);
897
+ static async fromIdentifier(e, s = 0) {
898
+ return rt(e, s);
891
899
  }
892
- static fromIdentifierSync(e, r = 0) {
893
- const { decimal: n, identifier: i } = rt(e), c = k(r, n);
900
+ static fromIdentifierSync(e, s = 0) {
901
+ const { decimal: n, identifier: i } = st(e), c = q(s, n);
894
902
  return new w({ decimal: n, identifier: i, value: c });
895
903
  }
896
- static fromChainOrSignature(e, r = 0) {
897
- const { decimal: n, identifier: i } = Ct(e), c = k(r, n);
904
+ static fromChainOrSignature(e, s = 0) {
905
+ const { decimal: n, identifier: i } = It(e), c = q(s, n);
898
906
  return new w({ value: c, decimal: n, identifier: i });
899
907
  }
900
908
  static async loadStaticAssets() {
901
909
  return new Promise(
902
- async (e, r) => {
910
+ async (e, s) => {
903
911
  try {
904
912
  const {
905
913
  // Omit ThorchainList from import to avoid decimals conflict (TC uses 8 for all)
@@ -909,14 +917,14 @@ class w extends E {
909
917
  ...c
910
918
  } = await import("@swapkit/tokens");
911
919
  Y = [i, ...Object.values(c)].reduce(
912
- (u, { tokens: l }) => (l.forEach(({ identifier: h, chain: _, ...v }) => {
913
- const j = "decimals" in v ? v.decimals : d[_];
920
+ (u, { tokens: l }) => (l.forEach(({ identifier: h, chain: _, ...T }) => {
921
+ const j = "decimals" in T ? T.decimals : d[_];
914
922
  u.set(h, { identifier: h, decimal: j });
915
923
  }), u),
916
924
  /* @__PURE__ */ new Map()
917
925
  ), e({ ok: !0 });
918
926
  } catch (n) {
919
- console.error(n), r({
927
+ console.error(n), s({
920
928
  ok: !1,
921
929
  error: n,
922
930
  message: "Couldn't load static assets. Ensure you have installed @swapkit/tokens package"
@@ -926,9 +934,9 @@ class w extends E {
926
934
  );
927
935
  }
928
936
  }
929
- const pe = (s) => {
930
- const t = w.fromChainOrSignature(s);
931
- switch (s) {
937
+ const _e = (r) => {
938
+ const t = w.fromChainOrSignature(r);
939
+ switch (r) {
932
940
  case o.Bitcoin:
933
941
  case o.Litecoin:
934
942
  case o.BitcoinCash:
@@ -944,17 +952,17 @@ const pe = (s) => {
944
952
  default:
945
953
  return t.set(1e-8);
946
954
  }
947
- }, z = (s) => {
948
- const t = s.slice(0, 14).includes("/"), [e, r] = s.split(".").pop().split("/"), n = s.includes(".") && !t ? s : `${o.THORChain}.${r}`, [i, c] = n.split("."), [a, u] = (t ? r : c).split("-");
955
+ }, z = (r) => {
956
+ const t = r.slice(0, 14).includes("/"), [e, s] = r.split(".").pop().split("/"), n = r.includes(".") && !t ? r : `${o.THORChain}.${s}`, [i, c] = n.split("."), [a, u] = (t ? s : c).split("-");
949
957
  return {
950
958
  address: u == null ? void 0 : u.toLowerCase(),
951
959
  chain: i,
952
- isGasAsset: St({ chain: i, symbol: c }),
960
+ isGasAsset: it({ chain: i, symbol: c }),
953
961
  isSynthetic: t,
954
962
  symbol: (t ? `${e}/` : "") + (u ? `${a}-${(u == null ? void 0 : u.toLowerCase()) ?? ""}` : c),
955
963
  ticker: a
956
964
  };
957
- }, Zt = {
965
+ }, ee = {
958
966
  /**
959
967
  * Core
960
968
  */
@@ -1011,9 +1019,9 @@ const pe = (s) => {
1011
1019
  */
1012
1020
  helpers_number_different_decimals: 99101
1013
1021
  };
1014
- class dt extends Error {
1022
+ class mt extends Error {
1015
1023
  constructor(t, e) {
1016
- console.error(e), super(t, { cause: { code: Zt[t], message: t } }), Object.setPrototypeOf(this, dt.prototype);
1024
+ console.error(e), super(t, { cause: { code: ee[t], message: t } }), Object.setPrototypeOf(this, mt.prototype);
1017
1025
  }
1018
1026
  }
1019
1027
  class b extends E {
@@ -1030,28 +1038,28 @@ class b extends E {
1030
1038
  export {
1031
1039
  w as AssetValue,
1032
1040
  E as BigIntArithmetics,
1033
- Qt as RequestClient,
1034
- dt as SwapKitError,
1041
+ Zt as RequestClient,
1042
+ mt as SwapKitError,
1035
1043
  b as SwapKitNumber,
1036
- se as assetFromString,
1037
- me as derivationPathToString,
1038
- ne as filterAssets,
1044
+ ie as assetFromString,
1045
+ fe as derivationPathToString,
1046
+ oe as filterAssets,
1039
1047
  x as formatBigIntToSafeValue,
1040
- re as gasFeeMultiplier,
1041
- It as getAssetType,
1042
- Bt as getAsymmetricAssetShare,
1043
- oe as getAsymmetricAssetWithdrawAmount,
1044
- Ot as getAsymmetricRuneShare,
1045
- ie as getAsymmetricRuneWithdrawAmount,
1046
- Ct as getCommonAssetInfo,
1047
- Rt as getDecimal,
1048
- ce as getEstimatedPoolShare,
1049
- ue as getLiquiditySlippage,
1050
- le as getMemoFor,
1051
- pe as getMinAmountByChain,
1052
- Mt as getSymmetricPoolShare,
1053
- ae as getSymmetricWithdraw,
1054
- he as getTHORNameCost,
1055
- St as isGasAsset,
1056
- de as validateTHORName
1048
+ ne as gasFeeMultiplier,
1049
+ Et as getAssetType,
1050
+ Vt as getAsymmetricAssetShare,
1051
+ ce as getAsymmetricAssetWithdrawAmount,
1052
+ Mt as getAsymmetricRuneShare,
1053
+ ae as getAsymmetricRuneWithdrawAmount,
1054
+ It as getCommonAssetInfo,
1055
+ Ct as getDecimal,
1056
+ le as getEstimatedPoolShare,
1057
+ he as getLiquiditySlippage,
1058
+ de as getMemoFor,
1059
+ _e as getMinAmountByChain,
1060
+ qt as getSymmetricPoolShare,
1061
+ ue as getSymmetricWithdraw,
1062
+ me as getTHORNameCost,
1063
+ it as isGasAsset,
1064
+ pe as validateTHORName
1057
1065
  };