@fleet-sdk/common 0.1.2 → 0.2.0
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/CHANGELOG.md +23 -0
- package/README.md +1 -1
- package/dist/index.d.mts +268 -0
- package/dist/index.d.ts +268 -0
- package/dist/index.js +604 -0
- package/dist/index.js.map +1 -0
- package/dist/index.mjs +551 -0
- package/dist/index.mjs.map +1 -0
- package/package.json +9 -9
- package/src/index.ts +1 -0
- package/src/models/collection.ts +107 -0
- package/src/models/index.ts +1 -0
- package/src/types/boxes.ts +2 -2
- package/src/types/common.ts +10 -3
- package/src/types/inputs.ts +3 -3
- package/src/utils/{arrayUtils.ts → array.ts} +26 -21
- package/src/utils/assertions.ts +90 -0
- package/src/utils/{bigIntUtils.ts → bigInt.ts} +28 -65
- package/src/utils/bytes.bench.ts +43 -0
- package/src/utils/bytes.ts +34 -0
- package/src/utils/index.ts +6 -6
- package/src/utils/object.ts +28 -0
- package/src/utils/{boxUtils.ts → utxo.ts} +27 -5
- package/dist/cjs/index.d.ts +0 -2
- package/dist/cjs/index.js +0 -19
- package/dist/cjs/index.js.map +0 -1
- package/dist/cjs/types/boxes.d.ts +0 -22
- package/dist/cjs/types/boxes.js +0 -3
- package/dist/cjs/types/boxes.js.map +0 -1
- package/dist/cjs/types/common.d.ts +0 -18
- package/dist/cjs/types/common.js +0 -15
- package/dist/cjs/types/common.js.map +0 -1
- package/dist/cjs/types/contextExtension.d.ts +0 -4
- package/dist/cjs/types/contextExtension.js +0 -3
- package/dist/cjs/types/contextExtension.js.map +0 -1
- package/dist/cjs/types/index.d.ts +0 -8
- package/dist/cjs/types/index.js +0 -25
- package/dist/cjs/types/index.js.map +0 -1
- package/dist/cjs/types/inputs.d.ts +0 -37
- package/dist/cjs/types/inputs.js +0 -3
- package/dist/cjs/types/inputs.js.map +0 -1
- package/dist/cjs/types/proverResult.d.ts +0 -6
- package/dist/cjs/types/proverResult.js +0 -3
- package/dist/cjs/types/proverResult.js.map +0 -1
- package/dist/cjs/types/registers.d.ts +0 -9
- package/dist/cjs/types/registers.js +0 -3
- package/dist/cjs/types/registers.js.map +0 -1
- package/dist/cjs/types/token.d.ts +0 -18
- package/dist/cjs/types/token.js +0 -3
- package/dist/cjs/types/token.js.map +0 -1
- package/dist/cjs/types/transactions.d.ts +0 -22
- package/dist/cjs/types/transactions.js +0 -3
- package/dist/cjs/types/transactions.js.map +0 -1
- package/dist/cjs/utils/arrayUtils.d.ts +0 -26
- package/dist/cjs/utils/arrayUtils.js +0 -151
- package/dist/cjs/utils/arrayUtils.js.map +0 -1
- package/dist/cjs/utils/bigIntLiterals.d.ts +0 -7
- package/dist/cjs/utils/bigIntLiterals.js +0 -12
- package/dist/cjs/utils/bigIntLiterals.js.map +0 -1
- package/dist/cjs/utils/bigIntUtils.d.ts +0 -51
- package/dist/cjs/utils/bigIntUtils.js +0 -158
- package/dist/cjs/utils/bigIntUtils.js.map +0 -1
- package/dist/cjs/utils/boxUtils.d.ts +0 -21
- package/dist/cjs/utils/boxUtils.js +0 -110
- package/dist/cjs/utils/boxUtils.js.map +0 -1
- package/dist/cjs/utils/index.d.ts +0 -6
- package/dist/cjs/utils/index.js +0 -23
- package/dist/cjs/utils/index.js.map +0 -1
- package/dist/cjs/utils/objectUtils.d.ts +0 -3
- package/dist/cjs/utils/objectUtils.js +0 -23
- package/dist/cjs/utils/objectUtils.js.map +0 -1
- package/dist/cjs/utils/stringUtils.d.ts +0 -7
- package/dist/cjs/utils/stringUtils.js +0 -21
- package/dist/cjs/utils/stringUtils.js.map +0 -1
- package/dist/esm/index.d.ts +0 -2
- package/dist/esm/index.js +0 -3
- package/dist/esm/index.js.map +0 -1
- package/dist/esm/types/boxes.d.ts +0 -22
- package/dist/esm/types/boxes.js +0 -2
- package/dist/esm/types/boxes.js.map +0 -1
- package/dist/esm/types/common.d.ts +0 -18
- package/dist/esm/types/common.js +0 -12
- package/dist/esm/types/common.js.map +0 -1
- package/dist/esm/types/contextExtension.d.ts +0 -4
- package/dist/esm/types/contextExtension.js +0 -2
- package/dist/esm/types/contextExtension.js.map +0 -1
- package/dist/esm/types/index.d.ts +0 -8
- package/dist/esm/types/index.js +0 -9
- package/dist/esm/types/index.js.map +0 -1
- package/dist/esm/types/inputs.d.ts +0 -37
- package/dist/esm/types/inputs.js +0 -2
- package/dist/esm/types/inputs.js.map +0 -1
- package/dist/esm/types/proverResult.d.ts +0 -6
- package/dist/esm/types/proverResult.js +0 -2
- package/dist/esm/types/proverResult.js.map +0 -1
- package/dist/esm/types/registers.d.ts +0 -9
- package/dist/esm/types/registers.js +0 -2
- package/dist/esm/types/registers.js.map +0 -1
- package/dist/esm/types/token.d.ts +0 -18
- package/dist/esm/types/token.js +0 -2
- package/dist/esm/types/token.js.map +0 -1
- package/dist/esm/types/transactions.d.ts +0 -22
- package/dist/esm/types/transactions.js +0 -2
- package/dist/esm/types/transactions.js.map +0 -1
- package/dist/esm/utils/arrayUtils.d.ts +0 -26
- package/dist/esm/utils/arrayUtils.js +0 -135
- package/dist/esm/utils/arrayUtils.js.map +0 -1
- package/dist/esm/utils/bigIntLiterals.d.ts +0 -7
- package/dist/esm/utils/bigIntLiterals.js +0 -9
- package/dist/esm/utils/bigIntLiterals.js.map +0 -1
- package/dist/esm/utils/bigIntUtils.d.ts +0 -51
- package/dist/esm/utils/bigIntUtils.js +0 -148
- package/dist/esm/utils/bigIntUtils.js.map +0 -1
- package/dist/esm/utils/boxUtils.d.ts +0 -21
- package/dist/esm/utils/boxUtils.js +0 -103
- package/dist/esm/utils/boxUtils.js.map +0 -1
- package/dist/esm/utils/index.d.ts +0 -6
- package/dist/esm/utils/index.js +0 -7
- package/dist/esm/utils/index.js.map +0 -1
- package/dist/esm/utils/objectUtils.d.ts +0 -3
- package/dist/esm/utils/objectUtils.js +0 -17
- package/dist/esm/utils/objectUtils.js.map +0 -1
- package/dist/esm/utils/stringUtils.d.ts +0 -7
- package/dist/esm/utils/stringUtils.js +0 -16
- package/dist/esm/utils/stringUtils.js.map +0 -1
- package/dist/tsconfig.esm.tsbuildinfo +0 -1
- package/dist/tsconfig.tsbuildinfo +0 -1
- package/src/utils/bigIntLiterals.ts +0 -9
- package/src/utils/objectUtils.ts +0 -19
- package/src/utils/stringUtils.ts +0 -18
package/dist/index.js
ADDED
@@ -0,0 +1,604 @@
|
|
1
|
+
'use strict';
|
2
|
+
|
3
|
+
// src/utils/assertions.ts
|
4
|
+
function assert(condition, error) {
|
5
|
+
if (condition)
|
6
|
+
return;
|
7
|
+
let err = void 0;
|
8
|
+
switch (typeof error) {
|
9
|
+
case "string":
|
10
|
+
err = new Error(error);
|
11
|
+
break;
|
12
|
+
case "function":
|
13
|
+
err = new Error(error());
|
14
|
+
break;
|
15
|
+
default:
|
16
|
+
err = error;
|
17
|
+
}
|
18
|
+
throw err;
|
19
|
+
}
|
20
|
+
function assertTypeOf(obj, expected) {
|
21
|
+
const type = typeof obj;
|
22
|
+
if (type !== expected) {
|
23
|
+
throw new Error(`Expected an object of type '${expected}', got '${type}'.`);
|
24
|
+
}
|
25
|
+
}
|
26
|
+
var toString = (value) => Object.prototype.toString.call(value);
|
27
|
+
function getTypeName(value) {
|
28
|
+
if (value === null)
|
29
|
+
return "null";
|
30
|
+
const type = typeof value;
|
31
|
+
return type === "object" || type === "function" ? toString(value).slice(8, -1) : type;
|
32
|
+
}
|
33
|
+
function assertInstanceOf(obj, expected) {
|
34
|
+
const condition = obj instanceof expected;
|
35
|
+
if (!condition) {
|
36
|
+
throw new Error(`Expected an instance of '${expected.name}', got '${getTypeName(obj)}'.`);
|
37
|
+
}
|
38
|
+
}
|
39
|
+
function isEmpty(obj) {
|
40
|
+
if (!obj)
|
41
|
+
return true;
|
42
|
+
return Array.isArray(obj) ? obj.length === 0 : Object.keys(obj).length === 0;
|
43
|
+
}
|
44
|
+
function some(obj) {
|
45
|
+
return !isEmpty(obj);
|
46
|
+
}
|
47
|
+
function isTruthy(value) {
|
48
|
+
return !!value;
|
49
|
+
}
|
50
|
+
function isFalsy(value) {
|
51
|
+
return !value;
|
52
|
+
}
|
53
|
+
function isUndefined(v) {
|
54
|
+
return v === void 0 || v === null || Number.isNaN(v);
|
55
|
+
}
|
56
|
+
function isDefined(v) {
|
57
|
+
return !isUndefined(v);
|
58
|
+
}
|
59
|
+
function hasKey(o, key) {
|
60
|
+
return Object.prototype.hasOwnProperty.call(o, key);
|
61
|
+
}
|
62
|
+
|
63
|
+
// src/utils/array.ts
|
64
|
+
function first(array) {
|
65
|
+
if (!array)
|
66
|
+
return void 0;
|
67
|
+
assert(array.length > 0, "Empty array.");
|
68
|
+
return array[0];
|
69
|
+
}
|
70
|
+
function last(array) {
|
71
|
+
if (!array)
|
72
|
+
return void 0;
|
73
|
+
assert(array.length > 0, "Empty array.");
|
74
|
+
return at(array, -1);
|
75
|
+
}
|
76
|
+
function at(array, index) {
|
77
|
+
const len = array?.length;
|
78
|
+
if (!len)
|
79
|
+
return void 0;
|
80
|
+
if (index < 0) {
|
81
|
+
index += len;
|
82
|
+
}
|
83
|
+
return array[index];
|
84
|
+
}
|
85
|
+
function hasDuplicates(array) {
|
86
|
+
return array.some((item, index) => {
|
87
|
+
return array.indexOf(item) !== index;
|
88
|
+
});
|
89
|
+
}
|
90
|
+
function hasDuplicatesBy(array, selector) {
|
91
|
+
return array.some((item, index) => {
|
92
|
+
return array.findIndex((x) => selector(x) === selector(item)) !== index;
|
93
|
+
});
|
94
|
+
}
|
95
|
+
function chunk(array, size) {
|
96
|
+
if (array.length <= size) {
|
97
|
+
return [array];
|
98
|
+
}
|
99
|
+
const chunks = [];
|
100
|
+
for (let i = 0; i < array.length; i += size) {
|
101
|
+
chunks.push(array.slice(i, i + size));
|
102
|
+
}
|
103
|
+
return chunks;
|
104
|
+
}
|
105
|
+
function orderBy(array, iteratee, order = "asc") {
|
106
|
+
return [...array].sort((a, b) => {
|
107
|
+
if (iteratee(a) > iteratee(b)) {
|
108
|
+
return order === "asc" ? 1 : -1;
|
109
|
+
} else if (iteratee(a) < iteratee(b)) {
|
110
|
+
return order === "asc" ? -1 : 1;
|
111
|
+
} else {
|
112
|
+
return 0;
|
113
|
+
}
|
114
|
+
});
|
115
|
+
}
|
116
|
+
function areEqual(array1, array2) {
|
117
|
+
if (array1 === array2) {
|
118
|
+
return true;
|
119
|
+
}
|
120
|
+
if (array1.length != array2.length) {
|
121
|
+
return false;
|
122
|
+
}
|
123
|
+
for (let i = 0; i < array1.length; i++) {
|
124
|
+
if (array1[i] !== array2[i]) {
|
125
|
+
return false;
|
126
|
+
}
|
127
|
+
}
|
128
|
+
return true;
|
129
|
+
}
|
130
|
+
function areEqualBy(array1, array2, selector) {
|
131
|
+
if (array1 === array2) {
|
132
|
+
return true;
|
133
|
+
}
|
134
|
+
if (array1.length != array2.length) {
|
135
|
+
return false;
|
136
|
+
}
|
137
|
+
for (let i = 0; i < array1.length; i++) {
|
138
|
+
if (selector(array1[i]) !== selector(array2[i])) {
|
139
|
+
return false;
|
140
|
+
}
|
141
|
+
}
|
142
|
+
return true;
|
143
|
+
}
|
144
|
+
function startsWith(array, target) {
|
145
|
+
if (array === target) {
|
146
|
+
return true;
|
147
|
+
}
|
148
|
+
if (target.length > array.length) {
|
149
|
+
return false;
|
150
|
+
}
|
151
|
+
for (let i = 0; i < target.length; i++) {
|
152
|
+
if (target[i] !== array[i]) {
|
153
|
+
return false;
|
154
|
+
}
|
155
|
+
}
|
156
|
+
return true;
|
157
|
+
}
|
158
|
+
function endsWith(array, target) {
|
159
|
+
if (array === target) {
|
160
|
+
return true;
|
161
|
+
}
|
162
|
+
if (target.length > array.length) {
|
163
|
+
return false;
|
164
|
+
}
|
165
|
+
const offset = array.length - target.length;
|
166
|
+
for (let i = target.length - 1; i >= 0; i--) {
|
167
|
+
if (target[i] !== array[i + offset]) {
|
168
|
+
return false;
|
169
|
+
}
|
170
|
+
}
|
171
|
+
return true;
|
172
|
+
}
|
173
|
+
function uniq(array) {
|
174
|
+
if (isEmpty(array)) {
|
175
|
+
return array;
|
176
|
+
}
|
177
|
+
return Array.from(new Set(array));
|
178
|
+
}
|
179
|
+
function uniqBy(array, selector, selection = "keep-first") {
|
180
|
+
if (isEmpty(array)) {
|
181
|
+
return array;
|
182
|
+
}
|
183
|
+
return Array.from(
|
184
|
+
array.reduce((map, e) => {
|
185
|
+
const key = selector(e);
|
186
|
+
if (selection === "keep-first" && map.has(key)) {
|
187
|
+
return map;
|
188
|
+
}
|
189
|
+
return map.set(key, e);
|
190
|
+
}, /* @__PURE__ */ new Map()).values()
|
191
|
+
);
|
192
|
+
}
|
193
|
+
function depthOf(array) {
|
194
|
+
return Array.isArray(array) ? 1 + Math.max(0, ...array.map(depthOf)) : 0;
|
195
|
+
}
|
196
|
+
|
197
|
+
// src/utils/bigInt.ts
|
198
|
+
var _0n = BigInt(0);
|
199
|
+
var _1n = BigInt(1);
|
200
|
+
var _7n = BigInt(7);
|
201
|
+
var _10n = BigInt(10);
|
202
|
+
var _63n = BigInt(63);
|
203
|
+
var _127n = BigInt(127);
|
204
|
+
var _128n = BigInt(128);
|
205
|
+
function ensureBigInt(number) {
|
206
|
+
return typeof number === "bigint" ? number : BigInt(number);
|
207
|
+
}
|
208
|
+
function undecimalize(decimalStr, options) {
|
209
|
+
if (!decimalStr) {
|
210
|
+
return _0n;
|
211
|
+
}
|
212
|
+
options = typeof options == "number" ? { decimals: options } : options;
|
213
|
+
if (isUndefined(options)) {
|
214
|
+
options = {};
|
215
|
+
}
|
216
|
+
options.decimals = options.decimals || 0;
|
217
|
+
options.decimalMark = options.decimalMark || ".";
|
218
|
+
const fragments = decimalStr.split(options.decimalMark);
|
219
|
+
if (fragments.length > 2) {
|
220
|
+
throw new Error("Invalid numeric string.");
|
221
|
+
}
|
222
|
+
let [integer, decimal] = fragments;
|
223
|
+
integer = _removeLeadingZeros(integer);
|
224
|
+
const negative = integer.startsWith("-") ? "-" : "";
|
225
|
+
if (!decimal) {
|
226
|
+
decimal = "0".repeat(options.decimals);
|
227
|
+
} else if (decimal.length < options.decimals) {
|
228
|
+
decimal = decimal.padEnd(options.decimals, "0");
|
229
|
+
}
|
230
|
+
return BigInt(negative + _stripNonDigits(integer + decimal));
|
231
|
+
}
|
232
|
+
function _stripNonDigits(value) {
|
233
|
+
return value.replace(/\D/g, "");
|
234
|
+
}
|
235
|
+
function decimalize(value, options) {
|
236
|
+
value = ensureBigInt(value);
|
237
|
+
if (!options) {
|
238
|
+
return value.toString();
|
239
|
+
}
|
240
|
+
options = typeof options == "number" ? { decimals: options } : options;
|
241
|
+
options.decimals = options.decimals || 0;
|
242
|
+
options.decimalMark = options.decimalMark || ".";
|
243
|
+
const pow = _10n ** BigInt(options.decimals);
|
244
|
+
const integer = value / pow;
|
245
|
+
const decimal = value - integer * pow;
|
246
|
+
return _buildFormattedDecimal(integer.toString(10), decimal.toString(10), options);
|
247
|
+
}
|
248
|
+
function percent(value, percentage, precision = 2n) {
|
249
|
+
return value * percentage / 10n ** precision;
|
250
|
+
}
|
251
|
+
function _buildFormattedDecimal(integer, decimal, options) {
|
252
|
+
const integerPart = _addThousandMarks(integer, options.thousandMark);
|
253
|
+
const decimalPart = _stripTrailingZeros(decimal.padStart(options.decimals, "0"));
|
254
|
+
if (decimalPart) {
|
255
|
+
return `${integerPart}${options.decimalMark}${decimalPart}`;
|
256
|
+
} else {
|
257
|
+
return integerPart;
|
258
|
+
}
|
259
|
+
}
|
260
|
+
function _addThousandMarks(value, mark) {
|
261
|
+
if (!mark) {
|
262
|
+
return value;
|
263
|
+
}
|
264
|
+
return value.replace(/\B(?=(\d{3})+(?!\d))/g, mark);
|
265
|
+
}
|
266
|
+
function _stripTrailingZeros(value) {
|
267
|
+
if (!value.endsWith("0")) {
|
268
|
+
return value;
|
269
|
+
}
|
270
|
+
return value.replace(/\.?0+$/, "");
|
271
|
+
}
|
272
|
+
function _removeLeadingZeros(value) {
|
273
|
+
if (!value.startsWith("0")) {
|
274
|
+
return value;
|
275
|
+
}
|
276
|
+
return value.replace(/^0+\.?/, "");
|
277
|
+
}
|
278
|
+
function sumBy(collection, iteratee, condition) {
|
279
|
+
let acc = _0n;
|
280
|
+
if (isEmpty(collection)) {
|
281
|
+
return acc;
|
282
|
+
}
|
283
|
+
for (const item of collection) {
|
284
|
+
if (isUndefined(condition) || condition(item)) {
|
285
|
+
acc += iteratee(item);
|
286
|
+
}
|
287
|
+
}
|
288
|
+
return acc;
|
289
|
+
}
|
290
|
+
function min(...numbers) {
|
291
|
+
let min2 = first(numbers);
|
292
|
+
for (const num of numbers) {
|
293
|
+
if (num < min2) {
|
294
|
+
min2 = num;
|
295
|
+
}
|
296
|
+
}
|
297
|
+
return min2;
|
298
|
+
}
|
299
|
+
function max(...numbers) {
|
300
|
+
let max2 = first(numbers);
|
301
|
+
for (const num of numbers) {
|
302
|
+
if (num > max2) {
|
303
|
+
max2 = num;
|
304
|
+
}
|
305
|
+
}
|
306
|
+
return max2;
|
307
|
+
}
|
308
|
+
|
309
|
+
// src/utils/utxo.ts
|
310
|
+
var NANOERGS_TOKEN_ID = "nanoErgs";
|
311
|
+
function utxoSum(boxes, tokenId) {
|
312
|
+
const balances = {};
|
313
|
+
for (const box of boxes) {
|
314
|
+
if (isUndefined(tokenId) || tokenId === NANOERGS_TOKEN_ID) {
|
315
|
+
balances[NANOERGS_TOKEN_ID] = (balances[NANOERGS_TOKEN_ID] || _0n) + ensureBigInt(box.value);
|
316
|
+
}
|
317
|
+
if (tokenId !== NANOERGS_TOKEN_ID) {
|
318
|
+
for (const token of box.assets) {
|
319
|
+
if (isDefined(tokenId) && tokenId !== token.tokenId) {
|
320
|
+
continue;
|
321
|
+
}
|
322
|
+
balances[token.tokenId] = (balances[token.tokenId] || _0n) + ensureBigInt(token.amount);
|
323
|
+
}
|
324
|
+
}
|
325
|
+
}
|
326
|
+
if (isDefined(tokenId)) {
|
327
|
+
return balances[tokenId] || _0n;
|
328
|
+
}
|
329
|
+
return {
|
330
|
+
nanoErgs: balances[NANOERGS_TOKEN_ID] || _0n,
|
331
|
+
tokens: Object.keys(balances).filter((x) => x !== NANOERGS_TOKEN_ID).map((tokenId2) => ({ tokenId: tokenId2, amount: balances[tokenId2] }))
|
332
|
+
};
|
333
|
+
}
|
334
|
+
function utxoDiff(minuend, subtrahend) {
|
335
|
+
if (Array.isArray(minuend)) {
|
336
|
+
minuend = utxoSum(minuend);
|
337
|
+
}
|
338
|
+
if (Array.isArray(subtrahend)) {
|
339
|
+
subtrahend = utxoSum(subtrahend);
|
340
|
+
}
|
341
|
+
const tokens = [];
|
342
|
+
const nanoErgs = minuend.nanoErgs - subtrahend.nanoErgs;
|
343
|
+
for (const token of minuend.tokens) {
|
344
|
+
const balance = token.amount - (subtrahend.tokens.find((t) => t.tokenId === token.tokenId)?.amount || _0n);
|
345
|
+
if (balance !== _0n) {
|
346
|
+
tokens.push({ tokenId: token.tokenId, amount: balance });
|
347
|
+
}
|
348
|
+
}
|
349
|
+
return { nanoErgs, tokens };
|
350
|
+
}
|
351
|
+
var MIN_NON_MANDATORY_REGISTER_INDEX = 4;
|
352
|
+
var MAX_NON_MANDATORY_REGISTER_INDEX = 9;
|
353
|
+
function areRegistersDenselyPacked(registers) {
|
354
|
+
let lastIndex = 0;
|
355
|
+
for (let i = MIN_NON_MANDATORY_REGISTER_INDEX; i <= MAX_NON_MANDATORY_REGISTER_INDEX; i++) {
|
356
|
+
const key = `R${i}`;
|
357
|
+
if (registers[key]) {
|
358
|
+
if (i === MIN_NON_MANDATORY_REGISTER_INDEX) {
|
359
|
+
lastIndex = i;
|
360
|
+
continue;
|
361
|
+
}
|
362
|
+
if (i - lastIndex > 1) {
|
363
|
+
return false;
|
364
|
+
}
|
365
|
+
lastIndex = i;
|
366
|
+
}
|
367
|
+
}
|
368
|
+
return true;
|
369
|
+
}
|
370
|
+
function utxoFilter(utxos, filterParams) {
|
371
|
+
if (isEmpty(filterParams) || isEmpty(utxos)) {
|
372
|
+
return utxos;
|
373
|
+
}
|
374
|
+
const { by, max: max2 } = filterParams;
|
375
|
+
let filtered = utxos;
|
376
|
+
if (by) {
|
377
|
+
filtered = utxos.filter(by);
|
378
|
+
if (isEmpty(filtered)) {
|
379
|
+
return filtered;
|
380
|
+
}
|
381
|
+
}
|
382
|
+
if (!max2) {
|
383
|
+
return filtered;
|
384
|
+
}
|
385
|
+
if (isDefined(max2.aggregatedDistinctTokens)) {
|
386
|
+
const tokenIds = _getDistinctTokenIds(filtered, max2.aggregatedDistinctTokens);
|
387
|
+
filtered = filtered.filter(
|
388
|
+
(utxo) => isEmpty(utxo.assets) || utxo.assets.every((token) => tokenIds.has(token.tokenId))
|
389
|
+
);
|
390
|
+
}
|
391
|
+
if (isDefined(max2.count) && filtered.length > max2.count) {
|
392
|
+
filtered = filtered.slice(0, max2.count);
|
393
|
+
}
|
394
|
+
return filtered;
|
395
|
+
}
|
396
|
+
function _getDistinctTokenIds(utxos, max2) {
|
397
|
+
const tokenIds = /* @__PURE__ */ new Set();
|
398
|
+
for (let i = 0; i < utxos.length && tokenIds.size < max2; i++) {
|
399
|
+
if (isEmpty(utxos[i].assets) || utxos[i].assets.length > max2) {
|
400
|
+
continue;
|
401
|
+
}
|
402
|
+
for (const token of utxos[i].assets) {
|
403
|
+
tokenIds.add(token.tokenId);
|
404
|
+
}
|
405
|
+
}
|
406
|
+
return tokenIds;
|
407
|
+
}
|
408
|
+
function ensureUTxOBigInt(box) {
|
409
|
+
return {
|
410
|
+
...box,
|
411
|
+
value: ensureBigInt(box.value),
|
412
|
+
assets: box.assets.map((token) => ({
|
413
|
+
tokenId: token.tokenId,
|
414
|
+
amount: ensureBigInt(token.amount)
|
415
|
+
}))
|
416
|
+
};
|
417
|
+
}
|
418
|
+
|
419
|
+
// src/utils/object.ts
|
420
|
+
function clearUndefined(value) {
|
421
|
+
const result = {};
|
422
|
+
for (const key in value) {
|
423
|
+
const val = value[key];
|
424
|
+
if (!isUndefined(val)) {
|
425
|
+
result[key] = val;
|
426
|
+
}
|
427
|
+
}
|
428
|
+
return result;
|
429
|
+
}
|
430
|
+
function ensureDefaults(options, defaults) {
|
431
|
+
if (isEmpty(options))
|
432
|
+
return defaults;
|
433
|
+
const newObj = { ...defaults, ...options };
|
434
|
+
for (const key in newObj) {
|
435
|
+
newObj[key] = options[key] ?? defaults[key];
|
436
|
+
}
|
437
|
+
return newObj;
|
438
|
+
}
|
439
|
+
|
440
|
+
// src/utils/bytes.ts
|
441
|
+
function concatBytes(...arrays) {
|
442
|
+
const r = new Uint8Array(arrays.reduce((sum, a) => sum + a.length, 0));
|
443
|
+
let pad = 0;
|
444
|
+
for (const bytes of arrays) {
|
445
|
+
assertInstanceOf(bytes, Uint8Array);
|
446
|
+
r.set(bytes, pad);
|
447
|
+
pad += bytes.length;
|
448
|
+
}
|
449
|
+
return r;
|
450
|
+
}
|
451
|
+
function isHex(value) {
|
452
|
+
if (!value || value.length % 2)
|
453
|
+
return false;
|
454
|
+
if (!value.startsWith("0x")) {
|
455
|
+
value = "0x" + value;
|
456
|
+
}
|
457
|
+
return !isNaN(Number(value));
|
458
|
+
}
|
459
|
+
function byteSizeOf(hex) {
|
460
|
+
return hex.length / 2;
|
461
|
+
}
|
462
|
+
|
463
|
+
// src/types/common.ts
|
464
|
+
var Network = /* @__PURE__ */ ((Network2) => {
|
465
|
+
Network2[Network2["Mainnet"] = 0] = "Mainnet";
|
466
|
+
Network2[Network2["Testnet"] = 16] = "Testnet";
|
467
|
+
return Network2;
|
468
|
+
})(Network || {});
|
469
|
+
var AddressType = /* @__PURE__ */ ((AddressType2) => {
|
470
|
+
AddressType2[AddressType2["P2PK"] = 1] = "P2PK";
|
471
|
+
AddressType2[AddressType2["P2SH"] = 2] = "P2SH";
|
472
|
+
AddressType2[AddressType2["P2S"] = 3] = "P2S";
|
473
|
+
return AddressType2;
|
474
|
+
})(AddressType || {});
|
475
|
+
var ergoTreeHeaderFlags = {
|
476
|
+
sizeInclusion: 8,
|
477
|
+
constantSegregation: 16
|
478
|
+
};
|
479
|
+
|
480
|
+
// src/models/collection.ts
|
481
|
+
var Collection = class {
|
482
|
+
_items;
|
483
|
+
constructor() {
|
484
|
+
this._items = [];
|
485
|
+
}
|
486
|
+
_isIndexOutOfBounds(index) {
|
487
|
+
return index < 0 || index >= this._items.length;
|
488
|
+
}
|
489
|
+
[Symbol.iterator]() {
|
490
|
+
let counter = 0;
|
491
|
+
return {
|
492
|
+
next: () => {
|
493
|
+
return {
|
494
|
+
done: counter >= this.length,
|
495
|
+
value: this._items[counter++]
|
496
|
+
};
|
497
|
+
}
|
498
|
+
};
|
499
|
+
}
|
500
|
+
get length() {
|
501
|
+
return this._items.length;
|
502
|
+
}
|
503
|
+
get isEmpty() {
|
504
|
+
return this.length === 0;
|
505
|
+
}
|
506
|
+
at(index) {
|
507
|
+
if (this._isIndexOutOfBounds(index)) {
|
508
|
+
throw new RangeError(`Index '${index}' is out of range.`);
|
509
|
+
}
|
510
|
+
return this._items[index];
|
511
|
+
}
|
512
|
+
add(items, options) {
|
513
|
+
return this._addOneOrMore(items, options);
|
514
|
+
}
|
515
|
+
_addOne(item, options) {
|
516
|
+
if (isDefined(options) && isDefined(options.index)) {
|
517
|
+
if (options.index === this.length) {
|
518
|
+
this._items.push(this._map(item));
|
519
|
+
return this.length;
|
520
|
+
}
|
521
|
+
if (this._isIndexOutOfBounds(options.index)) {
|
522
|
+
throw new RangeError(`Index '${options.index}' is out of range.`);
|
523
|
+
}
|
524
|
+
this._items.splice(options.index, 0, this._map(item));
|
525
|
+
return this.length;
|
526
|
+
}
|
527
|
+
this._items.push(this._map(item));
|
528
|
+
return this._items.length;
|
529
|
+
}
|
530
|
+
_addOneOrMore(items, options) {
|
531
|
+
if (Array.isArray(items)) {
|
532
|
+
if (isDefined(options) && isDefined(options.index)) {
|
533
|
+
items = items.reverse();
|
534
|
+
}
|
535
|
+
for (const item of items) {
|
536
|
+
this._addOne(item, options);
|
537
|
+
}
|
538
|
+
} else {
|
539
|
+
this._addOne(items, options);
|
540
|
+
}
|
541
|
+
return this.length;
|
542
|
+
}
|
543
|
+
toArray() {
|
544
|
+
return [...this._items];
|
545
|
+
}
|
546
|
+
reduce(callbackFn, initialValue) {
|
547
|
+
return this._items.reduce(callbackFn, initialValue);
|
548
|
+
}
|
549
|
+
};
|
550
|
+
|
551
|
+
exports.AddressType = AddressType;
|
552
|
+
exports.Collection = Collection;
|
553
|
+
exports.Network = Network;
|
554
|
+
exports._0n = _0n;
|
555
|
+
exports._10n = _10n;
|
556
|
+
exports._127n = _127n;
|
557
|
+
exports._128n = _128n;
|
558
|
+
exports._1n = _1n;
|
559
|
+
exports._63n = _63n;
|
560
|
+
exports._7n = _7n;
|
561
|
+
exports.areEqual = areEqual;
|
562
|
+
exports.areEqualBy = areEqualBy;
|
563
|
+
exports.areRegistersDenselyPacked = areRegistersDenselyPacked;
|
564
|
+
exports.assert = assert;
|
565
|
+
exports.assertInstanceOf = assertInstanceOf;
|
566
|
+
exports.assertTypeOf = assertTypeOf;
|
567
|
+
exports.at = at;
|
568
|
+
exports.byteSizeOf = byteSizeOf;
|
569
|
+
exports.chunk = chunk;
|
570
|
+
exports.clearUndefined = clearUndefined;
|
571
|
+
exports.concatBytes = concatBytes;
|
572
|
+
exports.decimalize = decimalize;
|
573
|
+
exports.depthOf = depthOf;
|
574
|
+
exports.endsWith = endsWith;
|
575
|
+
exports.ensureBigInt = ensureBigInt;
|
576
|
+
exports.ensureDefaults = ensureDefaults;
|
577
|
+
exports.ensureUTxOBigInt = ensureUTxOBigInt;
|
578
|
+
exports.ergoTreeHeaderFlags = ergoTreeHeaderFlags;
|
579
|
+
exports.first = first;
|
580
|
+
exports.hasDuplicates = hasDuplicates;
|
581
|
+
exports.hasDuplicatesBy = hasDuplicatesBy;
|
582
|
+
exports.hasKey = hasKey;
|
583
|
+
exports.isDefined = isDefined;
|
584
|
+
exports.isEmpty = isEmpty;
|
585
|
+
exports.isFalsy = isFalsy;
|
586
|
+
exports.isHex = isHex;
|
587
|
+
exports.isTruthy = isTruthy;
|
588
|
+
exports.isUndefined = isUndefined;
|
589
|
+
exports.last = last;
|
590
|
+
exports.max = max;
|
591
|
+
exports.min = min;
|
592
|
+
exports.orderBy = orderBy;
|
593
|
+
exports.percent = percent;
|
594
|
+
exports.some = some;
|
595
|
+
exports.startsWith = startsWith;
|
596
|
+
exports.sumBy = sumBy;
|
597
|
+
exports.undecimalize = undecimalize;
|
598
|
+
exports.uniq = uniq;
|
599
|
+
exports.uniqBy = uniqBy;
|
600
|
+
exports.utxoDiff = utxoDiff;
|
601
|
+
exports.utxoFilter = utxoFilter;
|
602
|
+
exports.utxoSum = utxoSum;
|
603
|
+
//# sourceMappingURL=out.js.map
|
604
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"sources":["../src/utils/assertions.ts","../src/utils/array.ts","../src/utils/bigInt.ts","../src/utils/utxo.ts","../src/utils/object.ts","../src/utils/bytes.ts","../src/types/common.ts","../src/models/collection.ts"],"names":["min","max","tokenId","Network","AddressType"],"mappings":"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","sourcesContent":["export type AssertErrorMessageInput = string | Error | (() => string);\n\n// eslint-disable-next-line @typescript-eslint/ban-types\ntype Constructable = Function;\n\ntype JSPrimitiveTypes =\n | \"string\"\n | \"number\"\n | \"bigint\"\n | \"boolean\"\n | \"symbol\"\n | \"undefined\"\n | \"object\"\n | \"function\";\n\nexport function assert(condition: boolean, error: AssertErrorMessageInput): asserts condition {\n if (condition) return;\n\n let err: Error | undefined = undefined;\n switch (typeof error) {\n case \"string\":\n err = new Error(error);\n break;\n case \"function\":\n err = new Error(error());\n break;\n default:\n err = error;\n }\n\n throw err;\n}\n\nexport function assertTypeOf<T>(obj: T, expected: JSPrimitiveTypes): asserts obj {\n const type = typeof obj;\n\n if (type !== expected) {\n throw new Error(`Expected an object of type '${expected}', got '${type}'.`);\n }\n}\n\nconst toString = (value: unknown) => Object.prototype.toString.call(value);\nfunction getTypeName(value: unknown): string {\n if (value === null) return \"null\";\n const type = typeof value;\n\n return type === \"object\" || type === \"function\" ? toString(value).slice(8, -1) : type;\n}\n\nexport function assertInstanceOf<T>(obj: T, expected: Constructable): asserts obj {\n const condition = obj instanceof expected;\n\n if (!condition) {\n throw new Error(`Expected an instance of '${expected.name}', got '${getTypeName(obj)}'.`);\n }\n}\n\nexport function isEmpty<T extends object>(obj?: T): obj is undefined;\nexport function isEmpty<T>(array?: T[]): array is undefined;\nexport function isEmpty<T>(obj?: T[] | object): obj is undefined {\n if (!obj) return true;\n\n return Array.isArray(obj) ? obj.length === 0 : Object.keys(obj).length === 0;\n}\n\nexport function some<T extends object>(obj?: T): obj is T;\nexport function some<T>(array?: T[]): array is T[];\nexport function some<T>(obj?: T[] | object): boolean {\n return !isEmpty(obj);\n}\n\nexport function isTruthy<T>(value?: T): value is NonNullable<T> {\n return !!value;\n}\n\nexport function isFalsy<T>(value?: T): value is undefined {\n return !value;\n}\n\nexport function isUndefined(v: unknown): v is undefined {\n return v === undefined || v === null || Number.isNaN(v);\n}\n\nexport function isDefined<T>(v: T | undefined): v is T {\n return !isUndefined(v);\n}\n\nexport function hasKey(o: unknown, key: PropertyKey): boolean {\n return Object.prototype.hasOwnProperty.call(o, key);\n}\n","import { SortingDirection, SortingSelector } from \"../types\";\nimport { assert, isEmpty } from \"./assertions\";\n\ntype ObjectSelector<T> = (item: T) => T[keyof T];\n\nexport function first(array: undefined): undefined;\nexport function first<T>(array: ArrayLike<T>): T;\nexport function first<T>(array: ArrayLike<T> | undefined): T | number | undefined {\n if (!array) return undefined;\n assert(array.length > 0, \"Empty array.\");\n\n return array[0];\n}\n\nexport function last(array: undefined): undefined;\nexport function last<T>(array: ArrayLike<T>): T;\nexport function last<T>(array: ArrayLike<T> | undefined): T | undefined {\n if (!array) return undefined;\n assert(array.length > 0, \"Empty array.\");\n\n return at(array, -1);\n}\n\nexport function at(array: undefined, index: number): undefined;\nexport function at<T>(array: ArrayLike<T>, index: number): T;\nexport function at<T>(array: ArrayLike<T> | undefined, index: number): T | undefined {\n const len = array?.length;\n if (!len) return undefined;\n\n if (index < 0) {\n index += len;\n }\n\n return array[index];\n}\n\n/**\n * Check for duplicate elements using the equality operator\n */\nexport function hasDuplicates<T>(array: T[]): boolean {\n return array.some((item, index) => {\n return array.indexOf(item) !== index;\n });\n}\n\n/**\n * Check for duplicate keys in complex elements\n */\nexport function hasDuplicatesBy<T>(array: T[], selector: ObjectSelector<T>): boolean {\n return array.some((item, index) => {\n return array.findIndex((x) => selector(x) === selector(item)) !== index;\n });\n}\n\nexport function chunk<T>(array: T[], size: number): T[][] {\n if (array.length <= size) {\n return [array];\n }\n\n const chunks: T[][] = [];\n for (let i = 0; i < array.length; i += size) {\n chunks.push(array.slice(i, i + size));\n }\n\n return chunks;\n}\n\nexport function orderBy<T>(\n array: T[],\n iteratee: SortingSelector<T>,\n order: SortingDirection = \"asc\"\n): T[] {\n return [...array].sort((a: T, b: T) => {\n if (iteratee(a) > iteratee(b)) {\n return order === \"asc\" ? 1 : -1;\n } else if (iteratee(a) < iteratee(b)) {\n return order === \"asc\" ? -1 : 1;\n } else {\n return 0;\n }\n });\n}\n\nexport function areEqual<T>(array1: ArrayLike<T>, array2: ArrayLike<T>): boolean {\n if (array1 === array2) {\n return true;\n }\n\n if (array1.length != array2.length) {\n return false;\n }\n\n for (let i = 0; i < array1.length; i++) {\n if (array1[i] !== array2[i]) {\n return false;\n }\n }\n\n return true;\n}\n\nexport function areEqualBy<T>(\n array1: ArrayLike<T>,\n array2: ArrayLike<T>,\n selector: ObjectSelector<T>\n): boolean {\n if (array1 === array2) {\n return true;\n }\n\n if (array1.length != array2.length) {\n return false;\n }\n\n for (let i = 0; i < array1.length; i++) {\n if (selector(array1[i]) !== selector(array2[i])) {\n return false;\n }\n }\n\n return true;\n}\n\nexport function startsWith<T>(array: ArrayLike<T>, target: ArrayLike<T>): boolean {\n if (array === target) {\n return true;\n }\n\n if (target.length > array.length) {\n return false;\n }\n\n for (let i = 0; i < target.length; i++) {\n if (target[i] !== array[i]) {\n return false;\n }\n }\n\n return true;\n}\n\nexport function endsWith<T>(array: ArrayLike<T>, target: ArrayLike<T>): boolean {\n if (array === target) {\n return true;\n }\n\n if (target.length > array.length) {\n return false;\n }\n\n const offset = array.length - target.length;\n\n for (let i = target.length - 1; i >= 0; i--) {\n if (target[i] !== array[i + offset]) {\n return false;\n }\n }\n\n return true;\n}\n\nexport function uniq<T>(array: Array<T>): Array<T> {\n if (isEmpty(array)) {\n return array;\n }\n\n return Array.from(new Set(array));\n}\n\nexport function uniqBy<T>(\n array: Array<T>,\n selector: ObjectSelector<T>,\n selection: \"keep-first\" | \"keep-last\" = \"keep-first\"\n): Array<T> {\n if (isEmpty(array)) {\n return array;\n }\n\n return Array.from(\n array\n .reduce((map, e) => {\n const key = selector(e);\n\n if (selection === \"keep-first\" && map.has(key)) {\n return map;\n }\n\n return map.set(key, e);\n }, new Map())\n .values()\n );\n}\n\nexport function depthOf(array: unknown | unknown[]): number {\n return Array.isArray(array) ? 1 + Math.max(0, ...array.map(depthOf)) : 0;\n}\n","import { Amount } from \"../types\";\nimport { first } from \"./array\";\nimport { isEmpty, isUndefined } from \"./assertions\";\n\ntype NumberLike = string | number | bigint | boolean;\n\nexport const _0n = BigInt(0);\nexport const _1n = BigInt(1);\nexport const _7n = BigInt(7);\nexport const _10n = BigInt(10);\nexport const _63n = BigInt(63);\nexport const _127n = BigInt(127);\nexport const _128n = BigInt(128);\n\nexport function ensureBigInt(number: NumberLike): bigint {\n return typeof number === \"bigint\" ? number : BigInt(number);\n}\n\ntype ParsingOptions = {\n /**\n * Number of decimals.\n */\n decimals?: number;\n\n /**\n * Thousand mark char.\n * Default: `.`\n */\n decimalMark?: string;\n};\n\nexport function undecimalize(decimalStr: string, options?: ParsingOptions | number): bigint {\n if (!decimalStr) {\n return _0n;\n }\n\n options = typeof options == \"number\" ? { decimals: options } : options;\n if (isUndefined(options)) {\n options = {};\n }\n\n options.decimals = options.decimals || 0;\n options.decimalMark = options.decimalMark || \".\";\n\n const fragments = decimalStr.split(options.decimalMark);\n if (fragments.length > 2) {\n throw new Error(\"Invalid numeric string.\");\n }\n\n let [integer, decimal] = fragments;\n integer = _removeLeadingZeros(integer);\n const negative = integer.startsWith(\"-\") ? \"-\" : \"\";\n\n if (!decimal) {\n decimal = \"0\".repeat(options.decimals);\n } else if (decimal.length < options.decimals) {\n decimal = decimal.padEnd(options.decimals, \"0\");\n }\n\n return BigInt(negative + _stripNonDigits(integer + decimal));\n}\n\nfunction _stripNonDigits(value: string): string {\n return value.replace(/\\D/g, \"\");\n}\n\ntype FormattingOptions = {\n /**\n * Number of decimals.\n */\n decimals: number;\n\n /**\n * Thousand mark char.\n */\n thousandMark?: string;\n\n /**\n * Decimal mark char.\n * Default: `.`\n */\n decimalMark?: string;\n};\n\nexport function decimalize(value: Amount, options?: FormattingOptions | number): string {\n value = ensureBigInt(value);\n if (!options) {\n return value.toString();\n }\n\n options = typeof options == \"number\" ? { decimals: options } : options;\n options.decimals = options.decimals || 0;\n options.decimalMark = options.decimalMark || \".\";\n\n const pow = _10n ** BigInt(options.decimals);\n const integer = value / pow;\n const decimal = value - integer * pow;\n\n return _buildFormattedDecimal(integer.toString(10), decimal.toString(10), options);\n}\n\nexport function percent(value: bigint, percentage: bigint, precision = 2n) {\n return (value * percentage) / 10n ** precision;\n}\n\nfunction _buildFormattedDecimal(\n integer: string,\n decimal: string,\n options: FormattingOptions\n): string {\n const integerPart = _addThousandMarks(integer, options.thousandMark);\n const decimalPart = _stripTrailingZeros(decimal.padStart(options.decimals, \"0\"));\n\n if (decimalPart) {\n return `${integerPart}${options.decimalMark}${decimalPart}`;\n } else {\n return integerPart;\n }\n}\n\nfunction _addThousandMarks(value: string, mark?: string): string {\n if (!mark) {\n return value;\n }\n\n return value.replace(/\\B(?=(\\d{3})+(?!\\d))/g, mark);\n}\n\nfunction _stripTrailingZeros(value: string): string {\n if (!value.endsWith(\"0\")) {\n return value;\n }\n\n return value.replace(/\\.?0+$/, \"\");\n}\n\nfunction _removeLeadingZeros(value: string): string {\n if (!value.startsWith(\"0\")) {\n return value;\n }\n\n return value.replace(/^0+\\.?/, \"\");\n}\n\nexport function sumBy<T>(\n collection: readonly T[],\n iteratee: (value: T) => bigint,\n condition?: (value: T) => boolean\n): bigint {\n let acc = _0n;\n if (isEmpty(collection)) {\n return acc;\n }\n\n for (const item of collection) {\n if (isUndefined(condition) || condition(item)) {\n acc += iteratee(item);\n }\n }\n\n return acc;\n}\n\nexport function min<T extends bigint | number>(...numbers: T[]): T {\n let min = first(numbers);\n\n for (const num of numbers) {\n if (num < min) {\n min = num;\n }\n }\n\n return min;\n}\n\nexport function max<T extends bigint | number>(...numbers: T[]): T {\n let max = first(numbers);\n\n for (const num of numbers) {\n if (num > max) {\n max = num;\n }\n }\n\n return max;\n}\n","import {\n Amount,\n AmountType,\n Box,\n BoxCandidate,\n NonMandatoryRegisters,\n TokenAmount,\n TokenId\n} from \"../types\";\nimport { isDefined, isEmpty, isUndefined } from \"./assertions\";\nimport { ensureBigInt } from \"./bigInt\";\nimport { _0n } from \"./bigInt\";\n\nconst NANOERGS_TOKEN_ID = \"nanoErgs\";\n\nexport function utxoSum(boxes: MinimalBoxAmounts): BoxSummary;\nexport function utxoSum(boxes: MinimalBoxAmounts, tokenId: TokenId): bigint;\nexport function utxoSum(boxes: MinimalBoxAmounts, tokenId?: TokenId): BoxSummary | bigint {\n const balances: { [tokenId: string]: bigint } = {};\n\n for (const box of boxes) {\n if (isUndefined(tokenId) || tokenId === NANOERGS_TOKEN_ID) {\n balances[NANOERGS_TOKEN_ID] = (balances[NANOERGS_TOKEN_ID] || _0n) + ensureBigInt(box.value);\n }\n\n if (tokenId !== NANOERGS_TOKEN_ID) {\n for (const token of box.assets) {\n if (isDefined(tokenId) && tokenId !== token.tokenId) {\n continue;\n }\n\n balances[token.tokenId] = (balances[token.tokenId] || _0n) + ensureBigInt(token.amount);\n }\n }\n }\n\n if (isDefined(tokenId)) {\n return balances[tokenId] || _0n;\n }\n\n return {\n nanoErgs: balances[NANOERGS_TOKEN_ID] || _0n,\n tokens: Object.keys(balances)\n .filter((x) => x !== NANOERGS_TOKEN_ID)\n .map((tokenId) => ({ tokenId, amount: balances[tokenId] }))\n };\n}\n\nexport function utxoDiff(\n minuend: BoxSummary | Box<Amount>[],\n subtrahend: BoxSummary | Box<Amount>[]\n): BoxSummary {\n if (Array.isArray(minuend)) {\n minuend = utxoSum(minuend);\n }\n\n if (Array.isArray(subtrahend)) {\n subtrahend = utxoSum(subtrahend);\n }\n\n const tokens: TokenAmount<bigint>[] = [];\n const nanoErgs = minuend.nanoErgs - subtrahend.nanoErgs;\n\n for (const token of minuend.tokens) {\n const balance =\n token.amount - (subtrahend.tokens.find((t) => t.tokenId === token.tokenId)?.amount || _0n);\n\n if (balance !== _0n) {\n tokens.push({ tokenId: token.tokenId, amount: balance });\n }\n }\n\n return { nanoErgs, tokens };\n}\n\nconst MIN_NON_MANDATORY_REGISTER_INDEX = 4;\nconst MAX_NON_MANDATORY_REGISTER_INDEX = 9;\n\nexport function areRegistersDenselyPacked(registers: NonMandatoryRegisters): boolean {\n let lastIndex = 0;\n for (let i = MIN_NON_MANDATORY_REGISTER_INDEX; i <= MAX_NON_MANDATORY_REGISTER_INDEX; i++) {\n const key = `R${i}` as keyof NonMandatoryRegisters;\n if (registers[key]) {\n if (i === MIN_NON_MANDATORY_REGISTER_INDEX) {\n lastIndex = i;\n continue;\n }\n\n if (i - lastIndex > 1) {\n return false;\n }\n\n lastIndex = i;\n }\n }\n\n return true;\n}\n\nexport function utxoFilter<T extends AmountType>(\n utxos: Box<T>[],\n filterParams: UTxOFilterParams<T>\n) {\n if (isEmpty(filterParams) || isEmpty(utxos)) {\n return utxos;\n }\n\n const { by, max } = filterParams;\n let filtered = utxos;\n\n if (by) {\n filtered = utxos.filter(by);\n if (isEmpty(filtered)) {\n return filtered;\n }\n }\n\n if (!max) {\n return filtered;\n }\n\n if (isDefined(max.aggregatedDistinctTokens)) {\n const tokenIds = _getDistinctTokenIds(filtered, max.aggregatedDistinctTokens);\n filtered = filtered.filter(\n (utxo) => isEmpty(utxo.assets) || utxo.assets.every((token) => tokenIds.has(token.tokenId))\n );\n }\n\n if (isDefined(max.count) && filtered.length > max.count) {\n filtered = filtered.slice(0, max.count);\n }\n\n return filtered;\n}\n\nfunction _getDistinctTokenIds(utxos: Box<AmountType>[], max: number): Set<string> {\n const tokenIds = new Set<string>();\n\n for (let i = 0; i < utxos.length && tokenIds.size < max; i++) {\n if (isEmpty(utxos[i].assets) || utxos[i].assets.length > max) {\n continue;\n }\n\n for (const token of utxos[i].assets) {\n tokenIds.add(token.tokenId);\n }\n }\n\n return tokenIds;\n}\n\nexport type UTxOFilterParams<T extends AmountType> = {\n by?: (utxo: Box<T>) => boolean;\n max?: {\n count?: number;\n aggregatedDistinctTokens?: number;\n };\n};\n\nexport type BoxSummary = {\n nanoErgs: bigint;\n tokens: TokenAmount<bigint>[];\n};\n\nexport type MinimalBoxAmounts = readonly {\n value: Amount;\n assets: TokenAmount<Amount>[];\n}[];\n\nexport function ensureUTxOBigInt(box: Box<Amount>): Box<bigint>;\nexport function ensureUTxOBigInt(candidate: BoxCandidate<Amount>): BoxCandidate<bigint>;\nexport function ensureUTxOBigInt(\n box: Box<Amount> | BoxCandidate<Amount>\n): BoxCandidate<bigint> | Box<bigint> {\n return {\n ...box,\n value: ensureBigInt(box.value),\n assets: box.assets.map((token) => ({\n tokenId: token.tokenId,\n amount: ensureBigInt(token.amount)\n }))\n };\n}\n","import { isEmpty, isUndefined } from \"./assertions\";\n\nexport function clearUndefined(value: Record<string, unknown>) {\n const result: Record<string, unknown> = {};\n for (const key in value) {\n const val = value[key];\n if (!isUndefined(val)) {\n result[key] = val;\n }\n }\n\n return result;\n}\n\nexport function ensureDefaults<T extends Partial<R>, R extends object = Required<T>>(\n options: T | undefined,\n defaults: R\n): R & T {\n if (isEmpty(options)) return defaults as R & T;\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const newObj: any = { ...defaults, ...options };\n for (const key in newObj) {\n newObj[key as keyof object] = options[key as keyof R] ?? defaults[key as keyof R];\n }\n\n return newObj;\n}\n","import { assertInstanceOf } from \".\";\n\nexport function concatBytes(...arrays: Uint8Array[]): Uint8Array {\n const r = new Uint8Array(arrays.reduce((sum, a) => sum + a.length, 0));\n\n let pad = 0;\n for (const bytes of arrays) {\n assertInstanceOf(bytes, Uint8Array);\n\n r.set(bytes, pad);\n pad += bytes.length;\n }\n\n return r;\n}\n\nexport function isHex(value?: string) {\n if (!value || value.length % 2) return false;\n\n if (!value.startsWith(\"0x\")) {\n value = \"0x\" + value;\n }\n\n return !isNaN(Number(value));\n}\n\n/**\n * Get hex string size in bytes\n * @param hex\n * @returns the byte size if the hex string\n */\nexport function byteSizeOf(hex: string): number {\n return hex.length / 2;\n}\n","export type HexString = string;\nexport type ErgoTreeHex = string;\nexport type Base58String = string;\nexport type Amount = string | bigint;\n\nexport type OneOrMore<T> = T | T[];\n\nexport type SortingSelector<T> = (item: T) => string | number | bigint;\nexport type SortingDirection = \"asc\" | \"desc\";\n\nexport type FilterPredicate<T> = (item: T) => boolean;\n\nexport type BuildOutputType = \"default\" | \"EIP-12\";\n\nexport enum Network {\n Mainnet = 0x00,\n Testnet = 0x10\n}\n\nexport enum AddressType {\n P2PK = 1,\n P2SH = 2,\n P2S = 3\n}\n\nexport const ergoTreeHeaderFlags = {\n sizeInclusion: 0x08,\n constantSegregation: 0x10\n} as const;\n\nexport type ErgoTreeHeaderFlag = (typeof ergoTreeHeaderFlags)[keyof typeof ergoTreeHeaderFlags];\n","import { OneOrMore } from \"../types\";\nimport { isDefined } from \"../utils\";\n\nexport type CollectionAddOptions = { index?: number };\n\nexport abstract class Collection<InternalType, ExternalType> implements Iterable<InternalType> {\n protected readonly _items: InternalType[];\n\n constructor() {\n this._items = [];\n }\n\n protected _isIndexOutOfBounds(index: number): boolean {\n return index < 0 || index >= this._items.length;\n }\n\n [Symbol.iterator](): Iterator<InternalType> {\n let counter = 0;\n\n return {\n next: () => {\n return {\n done: counter >= this.length,\n value: this._items[counter++]\n };\n }\n };\n }\n\n public get length(): number {\n return this._items.length;\n }\n\n public get isEmpty(): boolean {\n return this.length === 0;\n }\n\n public at(index: number): InternalType {\n if (this._isIndexOutOfBounds(index)) {\n throw new RangeError(`Index '${index}' is out of range.`);\n }\n\n return this._items[index];\n }\n\n public add(items: OneOrMore<ExternalType>, options?: CollectionAddOptions): number {\n return this._addOneOrMore(items, options);\n }\n\n abstract remove(item: unknown): number;\n\n protected abstract _map(item: ExternalType | InternalType): InternalType;\n\n protected _addOne(item: InternalType | ExternalType, options?: CollectionAddOptions): number {\n if (isDefined(options) && isDefined(options.index)) {\n if (options.index === this.length) {\n this._items.push(this._map(item));\n\n return this.length;\n }\n\n if (this._isIndexOutOfBounds(options.index)) {\n throw new RangeError(`Index '${options.index}' is out of range.`);\n }\n\n this._items.splice(options.index, 0, this._map(item));\n\n return this.length;\n }\n\n this._items.push(this._map(item));\n\n return this._items.length;\n }\n\n protected _addOneOrMore(items: OneOrMore<ExternalType>, options?: CollectionAddOptions): number {\n if (Array.isArray(items)) {\n if (isDefined(options) && isDefined(options.index)) {\n items = items.reverse();\n }\n\n for (const item of items) {\n this._addOne(item, options);\n }\n } else {\n this._addOne(items, options);\n }\n\n return this.length;\n }\n\n public toArray(): InternalType[] {\n return [...this._items];\n }\n\n public reduce<U>(\n callbackFn: (\n accumulator: U,\n currentValue: InternalType,\n currentIndex: number,\n array: InternalType[]\n ) => U,\n initialValue: U\n ): U {\n return this._items.reduce(callbackFn, initialValue);\n }\n}\n"]}
|