@zoralabs/protocol-sdk 0.7.0 → 0.7.1

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.js CHANGED
@@ -42,8 +42,8 @@ import { parseAbi } from "viem";
42
42
  var ZORA_API_BASE = "https://api.zora.co/";
43
43
  var OPEN_EDITION_MINT_SIZE = BigInt("18446744073709551615");
44
44
  var SUBGRAPH_CONFIG_BASE = "https://api.goldsky.com/api/public/project_clhk16b61ay9t49vm6ntn4mkz/subgraphs";
45
- function getSubgraph(name, version) {
46
- return `${SUBGRAPH_CONFIG_BASE}/${name}/${version}/gn`;
45
+ function getSubgraph(name, version2) {
46
+ return `${SUBGRAPH_CONFIG_BASE}/${name}/${version2}/gn`;
47
47
  }
48
48
  var zora721Abi = parseAbi([
49
49
  "function mintWithRewards(address recipient, uint256 quantity, string calldata comment, address mintReferral) external payable",
@@ -346,7 +346,7 @@ function migratePremintConfigToV2({
346
346
  };
347
347
  }
348
348
  var recoverCreatorFromCreatorAttribution = async ({
349
- creatorAttribution: { version, domainName, structHash, signature },
349
+ creatorAttribution: { version: version2, domainName, structHash, signature },
350
350
  chainId,
351
351
  tokenContract
352
352
  }) => {
@@ -355,7 +355,7 @@ var recoverCreatorFromCreatorAttribution = async ({
355
355
  chainId,
356
356
  name: domainName,
357
357
  verifyingContract: tokenContract,
358
- version
358
+ version: version2
359
359
  },
360
360
  types: {
361
361
  EIP712Domain: [
@@ -391,11 +391,11 @@ var supportedPremintVersions = async ({
391
391
  });
392
392
  };
393
393
  var supportsPremintVersion = async ({
394
- version,
394
+ version: version2,
395
395
  tokenContract,
396
396
  publicClient
397
397
  }) => {
398
- return (await supportedPremintVersions({ tokenContract, publicClient })).includes(version);
398
+ return (await supportedPremintVersions({ tokenContract, publicClient })).includes(version2);
399
399
  };
400
400
  async function getPremintCollectionAddress({
401
401
  publicClient,
@@ -419,7 +419,7 @@ async function getPremintCollectionAddress({
419
419
  }
420
420
  function applyUpdateToPremint({
421
421
  uid,
422
- version,
422
+ version: version2,
423
423
  tokenConfig,
424
424
  tokenConfigUpdates
425
425
  }) {
@@ -430,7 +430,7 @@ function applyUpdateToPremint({
430
430
  const result = {
431
431
  deleted: false,
432
432
  uid,
433
- version: version + 1,
433
+ version: version2 + 1,
434
434
  tokenConfig: updatedTokenConfig
435
435
  };
436
436
  return result;
@@ -1219,13 +1219,19 @@ function makePremintReturn({
1219
1219
  premintConfigVersion
1220
1220
  });
1221
1221
  };
1222
+ const urls = makeUrls({
1223
+ chainId,
1224
+ address: collectionAddress,
1225
+ uid: premintConfig.uid
1226
+ });
1222
1227
  return {
1223
1228
  premintConfig,
1224
1229
  premintConfigVersion,
1225
1230
  typedDataDefinition,
1226
1231
  collectionAddress,
1227
1232
  signAndSubmit,
1228
- submit
1233
+ submit,
1234
+ urls
1229
1235
  };
1230
1236
  }
1231
1237
  async function signPremint({
@@ -2867,13 +2873,13 @@ var unwrapAndForwardEthPermitAndTypedDataDefinition = ({
2867
2873
  chainId,
2868
2874
  tokenIds,
2869
2875
  quantities,
2870
- from,
2876
+ from: from2,
2871
2877
  callWithEth,
2872
2878
  safeTransferData,
2873
2879
  deadline,
2874
2880
  nonce
2875
2881
  }) => makePermitTransferBatchAndTypeData({
2876
- mintsOwner: from,
2882
+ mintsOwner: from2,
2877
2883
  chainId,
2878
2884
  deadline,
2879
2885
  tokenIds,
@@ -2921,6 +2927,1148 @@ function createCollectorClient(params) {
2921
2927
  getMintCosts: (p) => mintClient.getMintCosts(p)
2922
2928
  };
2923
2929
  }
2930
+
2931
+ // src/ipfs/arweave.ts
2932
+ function isArweaveURL(url) {
2933
+ return url && typeof url === "string" ? url.startsWith("ar://") : false;
2934
+ }
2935
+
2936
+ // ../../node_modules/multiformats/esm/vendor/varint.js
2937
+ var encode_1 = encode;
2938
+ var MSB = 128;
2939
+ var REST = 127;
2940
+ var MSBALL = ~REST;
2941
+ var INT = Math.pow(2, 31);
2942
+ function encode(num, out, offset) {
2943
+ out = out || [];
2944
+ offset = offset || 0;
2945
+ var oldOffset = offset;
2946
+ while (num >= INT) {
2947
+ out[offset++] = num & 255 | MSB;
2948
+ num /= 128;
2949
+ }
2950
+ while (num & MSBALL) {
2951
+ out[offset++] = num & 255 | MSB;
2952
+ num >>>= 7;
2953
+ }
2954
+ out[offset] = num | 0;
2955
+ encode.bytes = offset - oldOffset + 1;
2956
+ return out;
2957
+ }
2958
+ var decode = read;
2959
+ var MSB$1 = 128;
2960
+ var REST$1 = 127;
2961
+ function read(buf, offset) {
2962
+ var res = 0, offset = offset || 0, shift = 0, counter = offset, b, l = buf.length;
2963
+ do {
2964
+ if (counter >= l) {
2965
+ read.bytes = 0;
2966
+ throw new RangeError("Could not decode varint");
2967
+ }
2968
+ b = buf[counter++];
2969
+ res += shift < 28 ? (b & REST$1) << shift : (b & REST$1) * Math.pow(2, shift);
2970
+ shift += 7;
2971
+ } while (b >= MSB$1);
2972
+ read.bytes = counter - offset;
2973
+ return res;
2974
+ }
2975
+ var N1 = Math.pow(2, 7);
2976
+ var N2 = Math.pow(2, 14);
2977
+ var N3 = Math.pow(2, 21);
2978
+ var N4 = Math.pow(2, 28);
2979
+ var N5 = Math.pow(2, 35);
2980
+ var N6 = Math.pow(2, 42);
2981
+ var N7 = Math.pow(2, 49);
2982
+ var N8 = Math.pow(2, 56);
2983
+ var N9 = Math.pow(2, 63);
2984
+ var length = function(value) {
2985
+ return value < N1 ? 1 : value < N2 ? 2 : value < N3 ? 3 : value < N4 ? 4 : value < N5 ? 5 : value < N6 ? 6 : value < N7 ? 7 : value < N8 ? 8 : value < N9 ? 9 : 10;
2986
+ };
2987
+ var varint = {
2988
+ encode: encode_1,
2989
+ decode,
2990
+ encodingLength: length
2991
+ };
2992
+ var _brrp_varint = varint;
2993
+ var varint_default = _brrp_varint;
2994
+
2995
+ // ../../node_modules/multiformats/esm/src/varint.js
2996
+ var decode2 = (data, offset = 0) => {
2997
+ const code = varint_default.decode(data, offset);
2998
+ return [
2999
+ code,
3000
+ varint_default.decode.bytes
3001
+ ];
3002
+ };
3003
+ var encodeTo = (int, target, offset = 0) => {
3004
+ varint_default.encode(int, target, offset);
3005
+ return target;
3006
+ };
3007
+ var encodingLength = (int) => {
3008
+ return varint_default.encodingLength(int);
3009
+ };
3010
+
3011
+ // ../../node_modules/multiformats/esm/src/bytes.js
3012
+ var empty = new Uint8Array(0);
3013
+ var equals = (aa, bb) => {
3014
+ if (aa === bb)
3015
+ return true;
3016
+ if (aa.byteLength !== bb.byteLength) {
3017
+ return false;
3018
+ }
3019
+ for (let ii = 0; ii < aa.byteLength; ii++) {
3020
+ if (aa[ii] !== bb[ii]) {
3021
+ return false;
3022
+ }
3023
+ }
3024
+ return true;
3025
+ };
3026
+ var coerce3 = (o) => {
3027
+ if (o instanceof Uint8Array && o.constructor.name === "Uint8Array")
3028
+ return o;
3029
+ if (o instanceof ArrayBuffer)
3030
+ return new Uint8Array(o);
3031
+ if (ArrayBuffer.isView(o)) {
3032
+ return new Uint8Array(o.buffer, o.byteOffset, o.byteLength);
3033
+ }
3034
+ throw new Error("Unknown type, must be binary type");
3035
+ };
3036
+
3037
+ // ../../node_modules/multiformats/esm/src/hashes/digest.js
3038
+ var create = (code, digest) => {
3039
+ const size = digest.byteLength;
3040
+ const sizeOffset = encodingLength(code);
3041
+ const digestOffset = sizeOffset + encodingLength(size);
3042
+ const bytes = new Uint8Array(digestOffset + size);
3043
+ encodeTo(code, bytes, 0);
3044
+ encodeTo(size, bytes, sizeOffset);
3045
+ bytes.set(digest, digestOffset);
3046
+ return new Digest(code, size, digest, bytes);
3047
+ };
3048
+ var decode3 = (multihash) => {
3049
+ const bytes = coerce3(multihash);
3050
+ const [code, sizeOffset] = decode2(bytes);
3051
+ const [size, digestOffset] = decode2(bytes.subarray(sizeOffset));
3052
+ const digest = bytes.subarray(sizeOffset + digestOffset);
3053
+ if (digest.byteLength !== size) {
3054
+ throw new Error("Incorrect length");
3055
+ }
3056
+ return new Digest(code, size, digest, bytes);
3057
+ };
3058
+ var equals2 = (a, b) => {
3059
+ if (a === b) {
3060
+ return true;
3061
+ } else {
3062
+ return a.code === b.code && a.size === b.size && equals(a.bytes, b.bytes);
3063
+ }
3064
+ };
3065
+ var Digest = class {
3066
+ constructor(code, size, digest, bytes) {
3067
+ this.code = code;
3068
+ this.size = size;
3069
+ this.digest = digest;
3070
+ this.bytes = bytes;
3071
+ }
3072
+ };
3073
+
3074
+ // ../../node_modules/multiformats/esm/vendor/base-x.js
3075
+ function base2(ALPHABET, name) {
3076
+ if (ALPHABET.length >= 255) {
3077
+ throw new TypeError("Alphabet too long");
3078
+ }
3079
+ var BASE_MAP = new Uint8Array(256);
3080
+ for (var j = 0; j < BASE_MAP.length; j++) {
3081
+ BASE_MAP[j] = 255;
3082
+ }
3083
+ for (var i = 0; i < ALPHABET.length; i++) {
3084
+ var x = ALPHABET.charAt(i);
3085
+ var xc = x.charCodeAt(0);
3086
+ if (BASE_MAP[xc] !== 255) {
3087
+ throw new TypeError(x + " is ambiguous");
3088
+ }
3089
+ BASE_MAP[xc] = i;
3090
+ }
3091
+ var BASE = ALPHABET.length;
3092
+ var LEADER = ALPHABET.charAt(0);
3093
+ var FACTOR = Math.log(BASE) / Math.log(256);
3094
+ var iFACTOR = Math.log(256) / Math.log(BASE);
3095
+ function encode3(source) {
3096
+ if (source instanceof Uint8Array)
3097
+ ;
3098
+ else if (ArrayBuffer.isView(source)) {
3099
+ source = new Uint8Array(source.buffer, source.byteOffset, source.byteLength);
3100
+ } else if (Array.isArray(source)) {
3101
+ source = Uint8Array.from(source);
3102
+ }
3103
+ if (!(source instanceof Uint8Array)) {
3104
+ throw new TypeError("Expected Uint8Array");
3105
+ }
3106
+ if (source.length === 0) {
3107
+ return "";
3108
+ }
3109
+ var zeroes = 0;
3110
+ var length2 = 0;
3111
+ var pbegin = 0;
3112
+ var pend = source.length;
3113
+ while (pbegin !== pend && source[pbegin] === 0) {
3114
+ pbegin++;
3115
+ zeroes++;
3116
+ }
3117
+ var size = (pend - pbegin) * iFACTOR + 1 >>> 0;
3118
+ var b58 = new Uint8Array(size);
3119
+ while (pbegin !== pend) {
3120
+ var carry = source[pbegin];
3121
+ var i2 = 0;
3122
+ for (var it1 = size - 1; (carry !== 0 || i2 < length2) && it1 !== -1; it1--, i2++) {
3123
+ carry += 256 * b58[it1] >>> 0;
3124
+ b58[it1] = carry % BASE >>> 0;
3125
+ carry = carry / BASE >>> 0;
3126
+ }
3127
+ if (carry !== 0) {
3128
+ throw new Error("Non-zero carry");
3129
+ }
3130
+ length2 = i2;
3131
+ pbegin++;
3132
+ }
3133
+ var it2 = size - length2;
3134
+ while (it2 !== size && b58[it2] === 0) {
3135
+ it2++;
3136
+ }
3137
+ var str = LEADER.repeat(zeroes);
3138
+ for (; it2 < size; ++it2) {
3139
+ str += ALPHABET.charAt(b58[it2]);
3140
+ }
3141
+ return str;
3142
+ }
3143
+ function decodeUnsafe(source) {
3144
+ if (typeof source !== "string") {
3145
+ throw new TypeError("Expected String");
3146
+ }
3147
+ if (source.length === 0) {
3148
+ return new Uint8Array();
3149
+ }
3150
+ var psz = 0;
3151
+ if (source[psz] === " ") {
3152
+ return;
3153
+ }
3154
+ var zeroes = 0;
3155
+ var length2 = 0;
3156
+ while (source[psz] === LEADER) {
3157
+ zeroes++;
3158
+ psz++;
3159
+ }
3160
+ var size = (source.length - psz) * FACTOR + 1 >>> 0;
3161
+ var b256 = new Uint8Array(size);
3162
+ while (source[psz]) {
3163
+ var carry = BASE_MAP[source.charCodeAt(psz)];
3164
+ if (carry === 255) {
3165
+ return;
3166
+ }
3167
+ var i2 = 0;
3168
+ for (var it3 = size - 1; (carry !== 0 || i2 < length2) && it3 !== -1; it3--, i2++) {
3169
+ carry += BASE * b256[it3] >>> 0;
3170
+ b256[it3] = carry % 256 >>> 0;
3171
+ carry = carry / 256 >>> 0;
3172
+ }
3173
+ if (carry !== 0) {
3174
+ throw new Error("Non-zero carry");
3175
+ }
3176
+ length2 = i2;
3177
+ psz++;
3178
+ }
3179
+ if (source[psz] === " ") {
3180
+ return;
3181
+ }
3182
+ var it4 = size - length2;
3183
+ while (it4 !== size && b256[it4] === 0) {
3184
+ it4++;
3185
+ }
3186
+ var vch = new Uint8Array(zeroes + (size - it4));
3187
+ var j2 = zeroes;
3188
+ while (it4 !== size) {
3189
+ vch[j2++] = b256[it4++];
3190
+ }
3191
+ return vch;
3192
+ }
3193
+ function decode5(string) {
3194
+ var buffer = decodeUnsafe(string);
3195
+ if (buffer) {
3196
+ return buffer;
3197
+ }
3198
+ throw new Error(`Non-${name} character`);
3199
+ }
3200
+ return {
3201
+ encode: encode3,
3202
+ decodeUnsafe,
3203
+ decode: decode5
3204
+ };
3205
+ }
3206
+ var src = base2;
3207
+ var _brrp__multiformats_scope_baseX = src;
3208
+ var base_x_default = _brrp__multiformats_scope_baseX;
3209
+
3210
+ // ../../node_modules/multiformats/esm/src/bases/base.js
3211
+ var Encoder = class {
3212
+ constructor(name, prefix, baseEncode) {
3213
+ this.name = name;
3214
+ this.prefix = prefix;
3215
+ this.baseEncode = baseEncode;
3216
+ }
3217
+ encode(bytes) {
3218
+ if (bytes instanceof Uint8Array) {
3219
+ return `${this.prefix}${this.baseEncode(bytes)}`;
3220
+ } else {
3221
+ throw Error("Unknown type, must be binary type");
3222
+ }
3223
+ }
3224
+ };
3225
+ var Decoder = class {
3226
+ constructor(name, prefix, baseDecode) {
3227
+ this.name = name;
3228
+ this.prefix = prefix;
3229
+ if (prefix.codePointAt(0) === void 0) {
3230
+ throw new Error("Invalid prefix character");
3231
+ }
3232
+ this.prefixCodePoint = prefix.codePointAt(0);
3233
+ this.baseDecode = baseDecode;
3234
+ }
3235
+ decode(text) {
3236
+ if (typeof text === "string") {
3237
+ if (text.codePointAt(0) !== this.prefixCodePoint) {
3238
+ throw Error(`Unable to decode multibase string ${JSON.stringify(text)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);
3239
+ }
3240
+ return this.baseDecode(text.slice(this.prefix.length));
3241
+ } else {
3242
+ throw Error("Can only multibase decode strings");
3243
+ }
3244
+ }
3245
+ or(decoder) {
3246
+ return or(this, decoder);
3247
+ }
3248
+ };
3249
+ var ComposedDecoder = class {
3250
+ constructor(decoders) {
3251
+ this.decoders = decoders;
3252
+ }
3253
+ or(decoder) {
3254
+ return or(this, decoder);
3255
+ }
3256
+ decode(input) {
3257
+ const prefix = input[0];
3258
+ const decoder = this.decoders[prefix];
3259
+ if (decoder) {
3260
+ return decoder.decode(input);
3261
+ } else {
3262
+ throw RangeError(`Unable to decode multibase string ${JSON.stringify(input)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`);
3263
+ }
3264
+ }
3265
+ };
3266
+ var or = (left, right) => new ComposedDecoder({
3267
+ ...left.decoders || { [left.prefix]: left },
3268
+ ...right.decoders || { [right.prefix]: right }
3269
+ });
3270
+ var Codec = class {
3271
+ constructor(name, prefix, baseEncode, baseDecode) {
3272
+ this.name = name;
3273
+ this.prefix = prefix;
3274
+ this.baseEncode = baseEncode;
3275
+ this.baseDecode = baseDecode;
3276
+ this.encoder = new Encoder(name, prefix, baseEncode);
3277
+ this.decoder = new Decoder(name, prefix, baseDecode);
3278
+ }
3279
+ encode(input) {
3280
+ return this.encoder.encode(input);
3281
+ }
3282
+ decode(input) {
3283
+ return this.decoder.decode(input);
3284
+ }
3285
+ };
3286
+ var from = ({ name, prefix, encode: encode3, decode: decode5 }) => new Codec(name, prefix, encode3, decode5);
3287
+ var baseX = ({ prefix, name, alphabet }) => {
3288
+ const { encode: encode3, decode: decode5 } = base_x_default(alphabet, name);
3289
+ return from({
3290
+ prefix,
3291
+ name,
3292
+ encode: encode3,
3293
+ decode: (text) => coerce3(decode5(text))
3294
+ });
3295
+ };
3296
+ var decode4 = (string, alphabet, bitsPerChar, name) => {
3297
+ const codes = {};
3298
+ for (let i = 0; i < alphabet.length; ++i) {
3299
+ codes[alphabet[i]] = i;
3300
+ }
3301
+ let end = string.length;
3302
+ while (string[end - 1] === "=") {
3303
+ --end;
3304
+ }
3305
+ const out = new Uint8Array(end * bitsPerChar / 8 | 0);
3306
+ let bits = 0;
3307
+ let buffer = 0;
3308
+ let written = 0;
3309
+ for (let i = 0; i < end; ++i) {
3310
+ const value = codes[string[i]];
3311
+ if (value === void 0) {
3312
+ throw new SyntaxError(`Non-${name} character`);
3313
+ }
3314
+ buffer = buffer << bitsPerChar | value;
3315
+ bits += bitsPerChar;
3316
+ if (bits >= 8) {
3317
+ bits -= 8;
3318
+ out[written++] = 255 & buffer >> bits;
3319
+ }
3320
+ }
3321
+ if (bits >= bitsPerChar || 255 & buffer << 8 - bits) {
3322
+ throw new SyntaxError("Unexpected end of data");
3323
+ }
3324
+ return out;
3325
+ };
3326
+ var encode2 = (data, alphabet, bitsPerChar) => {
3327
+ const pad = alphabet[alphabet.length - 1] === "=";
3328
+ const mask = (1 << bitsPerChar) - 1;
3329
+ let out = "";
3330
+ let bits = 0;
3331
+ let buffer = 0;
3332
+ for (let i = 0; i < data.length; ++i) {
3333
+ buffer = buffer << 8 | data[i];
3334
+ bits += 8;
3335
+ while (bits > bitsPerChar) {
3336
+ bits -= bitsPerChar;
3337
+ out += alphabet[mask & buffer >> bits];
3338
+ }
3339
+ }
3340
+ if (bits) {
3341
+ out += alphabet[mask & buffer << bitsPerChar - bits];
3342
+ }
3343
+ if (pad) {
3344
+ while (out.length * bitsPerChar & 7) {
3345
+ out += "=";
3346
+ }
3347
+ }
3348
+ return out;
3349
+ };
3350
+ var rfc4648 = ({ name, prefix, bitsPerChar, alphabet }) => {
3351
+ return from({
3352
+ prefix,
3353
+ name,
3354
+ encode(input) {
3355
+ return encode2(input, alphabet, bitsPerChar);
3356
+ },
3357
+ decode(input) {
3358
+ return decode4(input, alphabet, bitsPerChar, name);
3359
+ }
3360
+ });
3361
+ };
3362
+
3363
+ // ../../node_modules/multiformats/esm/src/bases/base58.js
3364
+ var base58btc = baseX({
3365
+ name: "base58btc",
3366
+ prefix: "z",
3367
+ alphabet: "123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"
3368
+ });
3369
+ var base58flickr = baseX({
3370
+ name: "base58flickr",
3371
+ prefix: "Z",
3372
+ alphabet: "123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"
3373
+ });
3374
+
3375
+ // ../../node_modules/multiformats/esm/src/bases/base32.js
3376
+ var base32 = rfc4648({
3377
+ prefix: "b",
3378
+ name: "base32",
3379
+ alphabet: "abcdefghijklmnopqrstuvwxyz234567",
3380
+ bitsPerChar: 5
3381
+ });
3382
+ var base32upper = rfc4648({
3383
+ prefix: "B",
3384
+ name: "base32upper",
3385
+ alphabet: "ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",
3386
+ bitsPerChar: 5
3387
+ });
3388
+ var base32pad = rfc4648({
3389
+ prefix: "c",
3390
+ name: "base32pad",
3391
+ alphabet: "abcdefghijklmnopqrstuvwxyz234567=",
3392
+ bitsPerChar: 5
3393
+ });
3394
+ var base32padupper = rfc4648({
3395
+ prefix: "C",
3396
+ name: "base32padupper",
3397
+ alphabet: "ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",
3398
+ bitsPerChar: 5
3399
+ });
3400
+ var base32hex = rfc4648({
3401
+ prefix: "v",
3402
+ name: "base32hex",
3403
+ alphabet: "0123456789abcdefghijklmnopqrstuv",
3404
+ bitsPerChar: 5
3405
+ });
3406
+ var base32hexupper = rfc4648({
3407
+ prefix: "V",
3408
+ name: "base32hexupper",
3409
+ alphabet: "0123456789ABCDEFGHIJKLMNOPQRSTUV",
3410
+ bitsPerChar: 5
3411
+ });
3412
+ var base32hexpad = rfc4648({
3413
+ prefix: "t",
3414
+ name: "base32hexpad",
3415
+ alphabet: "0123456789abcdefghijklmnopqrstuv=",
3416
+ bitsPerChar: 5
3417
+ });
3418
+ var base32hexpadupper = rfc4648({
3419
+ prefix: "T",
3420
+ name: "base32hexpadupper",
3421
+ alphabet: "0123456789ABCDEFGHIJKLMNOPQRSTUV=",
3422
+ bitsPerChar: 5
3423
+ });
3424
+ var base32z = rfc4648({
3425
+ prefix: "h",
3426
+ name: "base32z",
3427
+ alphabet: "ybndrfg8ejkmcpqxot1uwisza345h769",
3428
+ bitsPerChar: 5
3429
+ });
3430
+
3431
+ // ../../node_modules/multiformats/esm/src/cid.js
3432
+ var CID = class _CID {
3433
+ constructor(version2, code, multihash, bytes) {
3434
+ this.code = code;
3435
+ this.version = version2;
3436
+ this.multihash = multihash;
3437
+ this.bytes = bytes;
3438
+ this.byteOffset = bytes.byteOffset;
3439
+ this.byteLength = bytes.byteLength;
3440
+ this.asCID = this;
3441
+ this._baseCache = /* @__PURE__ */ new Map();
3442
+ Object.defineProperties(this, {
3443
+ byteOffset: hidden,
3444
+ byteLength: hidden,
3445
+ code: readonly,
3446
+ version: readonly,
3447
+ multihash: readonly,
3448
+ bytes: readonly,
3449
+ _baseCache: hidden,
3450
+ asCID: hidden
3451
+ });
3452
+ }
3453
+ toV0() {
3454
+ switch (this.version) {
3455
+ case 0: {
3456
+ return this;
3457
+ }
3458
+ default: {
3459
+ const { code, multihash } = this;
3460
+ if (code !== DAG_PB_CODE) {
3461
+ throw new Error("Cannot convert a non dag-pb CID to CIDv0");
3462
+ }
3463
+ if (multihash.code !== SHA_256_CODE) {
3464
+ throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");
3465
+ }
3466
+ return _CID.createV0(multihash);
3467
+ }
3468
+ }
3469
+ }
3470
+ toV1() {
3471
+ switch (this.version) {
3472
+ case 0: {
3473
+ const { code, digest } = this.multihash;
3474
+ const multihash = create(code, digest);
3475
+ return _CID.createV1(this.code, multihash);
3476
+ }
3477
+ case 1: {
3478
+ return this;
3479
+ }
3480
+ default: {
3481
+ throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`);
3482
+ }
3483
+ }
3484
+ }
3485
+ equals(other) {
3486
+ return other && this.code === other.code && this.version === other.version && equals2(this.multihash, other.multihash);
3487
+ }
3488
+ toString(base3) {
3489
+ const { bytes, version: version2, _baseCache } = this;
3490
+ switch (version2) {
3491
+ case 0:
3492
+ return toStringV0(bytes, _baseCache, base3 || base58btc.encoder);
3493
+ default:
3494
+ return toStringV1(bytes, _baseCache, base3 || base32.encoder);
3495
+ }
3496
+ }
3497
+ toJSON() {
3498
+ return {
3499
+ code: this.code,
3500
+ version: this.version,
3501
+ hash: this.multihash.bytes
3502
+ };
3503
+ }
3504
+ get [Symbol.toStringTag]() {
3505
+ return "CID";
3506
+ }
3507
+ [Symbol.for("nodejs.util.inspect.custom")]() {
3508
+ return "CID(" + this.toString() + ")";
3509
+ }
3510
+ static isCID(value) {
3511
+ deprecate(/^0\.0/, IS_CID_DEPRECATION);
3512
+ return !!(value && (value[cidSymbol] || value.asCID === value));
3513
+ }
3514
+ get toBaseEncodedString() {
3515
+ throw new Error("Deprecated, use .toString()");
3516
+ }
3517
+ get codec() {
3518
+ throw new Error('"codec" property is deprecated, use integer "code" property instead');
3519
+ }
3520
+ get buffer() {
3521
+ throw new Error("Deprecated .buffer property, use .bytes to get Uint8Array instead");
3522
+ }
3523
+ get multibaseName() {
3524
+ throw new Error('"multibaseName" property is deprecated');
3525
+ }
3526
+ get prefix() {
3527
+ throw new Error('"prefix" property is deprecated');
3528
+ }
3529
+ static asCID(value) {
3530
+ if (value instanceof _CID) {
3531
+ return value;
3532
+ } else if (value != null && value.asCID === value) {
3533
+ const { version: version2, code, multihash, bytes } = value;
3534
+ return new _CID(version2, code, multihash, bytes || encodeCID(version2, code, multihash.bytes));
3535
+ } else if (value != null && value[cidSymbol] === true) {
3536
+ const { version: version2, multihash, code } = value;
3537
+ const digest = decode3(multihash);
3538
+ return _CID.create(version2, code, digest);
3539
+ } else {
3540
+ return null;
3541
+ }
3542
+ }
3543
+ static create(version2, code, digest) {
3544
+ if (typeof code !== "number") {
3545
+ throw new Error("String codecs are no longer supported");
3546
+ }
3547
+ switch (version2) {
3548
+ case 0: {
3549
+ if (code !== DAG_PB_CODE) {
3550
+ throw new Error(`Version 0 CID must use dag-pb (code: ${DAG_PB_CODE}) block encoding`);
3551
+ } else {
3552
+ return new _CID(version2, code, digest, digest.bytes);
3553
+ }
3554
+ }
3555
+ case 1: {
3556
+ const bytes = encodeCID(version2, code, digest.bytes);
3557
+ return new _CID(version2, code, digest, bytes);
3558
+ }
3559
+ default: {
3560
+ throw new Error("Invalid version");
3561
+ }
3562
+ }
3563
+ }
3564
+ static createV0(digest) {
3565
+ return _CID.create(0, DAG_PB_CODE, digest);
3566
+ }
3567
+ static createV1(code, digest) {
3568
+ return _CID.create(1, code, digest);
3569
+ }
3570
+ static decode(bytes) {
3571
+ const [cid, remainder] = _CID.decodeFirst(bytes);
3572
+ if (remainder.length) {
3573
+ throw new Error("Incorrect length");
3574
+ }
3575
+ return cid;
3576
+ }
3577
+ static decodeFirst(bytes) {
3578
+ const specs = _CID.inspectBytes(bytes);
3579
+ const prefixSize = specs.size - specs.multihashSize;
3580
+ const multihashBytes = coerce3(bytes.subarray(prefixSize, prefixSize + specs.multihashSize));
3581
+ if (multihashBytes.byteLength !== specs.multihashSize) {
3582
+ throw new Error("Incorrect length");
3583
+ }
3584
+ const digestBytes = multihashBytes.subarray(specs.multihashSize - specs.digestSize);
3585
+ const digest = new Digest(specs.multihashCode, specs.digestSize, digestBytes, multihashBytes);
3586
+ const cid = specs.version === 0 ? _CID.createV0(digest) : _CID.createV1(specs.codec, digest);
3587
+ return [
3588
+ cid,
3589
+ bytes.subarray(specs.size)
3590
+ ];
3591
+ }
3592
+ static inspectBytes(initialBytes) {
3593
+ let offset = 0;
3594
+ const next = () => {
3595
+ const [i, length2] = decode2(initialBytes.subarray(offset));
3596
+ offset += length2;
3597
+ return i;
3598
+ };
3599
+ let version2 = next();
3600
+ let codec = DAG_PB_CODE;
3601
+ if (version2 === 18) {
3602
+ version2 = 0;
3603
+ offset = 0;
3604
+ } else if (version2 === 1) {
3605
+ codec = next();
3606
+ }
3607
+ if (version2 !== 0 && version2 !== 1) {
3608
+ throw new RangeError(`Invalid CID version ${version2}`);
3609
+ }
3610
+ const prefixSize = offset;
3611
+ const multihashCode = next();
3612
+ const digestSize = next();
3613
+ const size = offset + digestSize;
3614
+ const multihashSize = size - prefixSize;
3615
+ return {
3616
+ version: version2,
3617
+ codec,
3618
+ multihashCode,
3619
+ digestSize,
3620
+ multihashSize,
3621
+ size
3622
+ };
3623
+ }
3624
+ static parse(source, base3) {
3625
+ const [prefix, bytes] = parseCIDtoBytes(source, base3);
3626
+ const cid = _CID.decode(bytes);
3627
+ cid._baseCache.set(prefix, source);
3628
+ return cid;
3629
+ }
3630
+ };
3631
+ var parseCIDtoBytes = (source, base3) => {
3632
+ switch (source[0]) {
3633
+ case "Q": {
3634
+ const decoder = base3 || base58btc;
3635
+ return [
3636
+ base58btc.prefix,
3637
+ decoder.decode(`${base58btc.prefix}${source}`)
3638
+ ];
3639
+ }
3640
+ case base58btc.prefix: {
3641
+ const decoder = base3 || base58btc;
3642
+ return [
3643
+ base58btc.prefix,
3644
+ decoder.decode(source)
3645
+ ];
3646
+ }
3647
+ case base32.prefix: {
3648
+ const decoder = base3 || base32;
3649
+ return [
3650
+ base32.prefix,
3651
+ decoder.decode(source)
3652
+ ];
3653
+ }
3654
+ default: {
3655
+ if (base3 == null) {
3656
+ throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");
3657
+ }
3658
+ return [
3659
+ source[0],
3660
+ base3.decode(source)
3661
+ ];
3662
+ }
3663
+ }
3664
+ };
3665
+ var toStringV0 = (bytes, cache, base3) => {
3666
+ const { prefix } = base3;
3667
+ if (prefix !== base58btc.prefix) {
3668
+ throw Error(`Cannot string encode V0 in ${base3.name} encoding`);
3669
+ }
3670
+ const cid = cache.get(prefix);
3671
+ if (cid == null) {
3672
+ const cid2 = base3.encode(bytes).slice(1);
3673
+ cache.set(prefix, cid2);
3674
+ return cid2;
3675
+ } else {
3676
+ return cid;
3677
+ }
3678
+ };
3679
+ var toStringV1 = (bytes, cache, base3) => {
3680
+ const { prefix } = base3;
3681
+ const cid = cache.get(prefix);
3682
+ if (cid == null) {
3683
+ const cid2 = base3.encode(bytes);
3684
+ cache.set(prefix, cid2);
3685
+ return cid2;
3686
+ } else {
3687
+ return cid;
3688
+ }
3689
+ };
3690
+ var DAG_PB_CODE = 112;
3691
+ var SHA_256_CODE = 18;
3692
+ var encodeCID = (version2, code, multihash) => {
3693
+ const codeOffset = encodingLength(version2);
3694
+ const hashOffset = codeOffset + encodingLength(code);
3695
+ const bytes = new Uint8Array(hashOffset + multihash.byteLength);
3696
+ encodeTo(version2, bytes, 0);
3697
+ encodeTo(code, bytes, codeOffset);
3698
+ bytes.set(multihash, hashOffset);
3699
+ return bytes;
3700
+ };
3701
+ var cidSymbol = Symbol.for("@ipld/js-cid/CID");
3702
+ var readonly = {
3703
+ writable: false,
3704
+ configurable: false,
3705
+ enumerable: true
3706
+ };
3707
+ var hidden = {
3708
+ writable: false,
3709
+ enumerable: false,
3710
+ configurable: false
3711
+ };
3712
+ var version = "0.0.0-dev";
3713
+ var deprecate = (range, message) => {
3714
+ if (range.test(version)) {
3715
+ console.warn(message);
3716
+ } else {
3717
+ throw new Error(message);
3718
+ }
3719
+ };
3720
+ var IS_CID_DEPRECATION = `CID.isCID(v) is deprecated and will be removed in the next major release.
3721
+ Following code pattern:
3722
+
3723
+ if (CID.isCID(value)) {
3724
+ doSomethingWithCID(value)
3725
+ }
3726
+
3727
+ Is replaced with:
3728
+
3729
+ const cid = CID.asCID(value)
3730
+ if (cid) {
3731
+ // Make sure to use cid instead of value
3732
+ doSomethingWithCID(cid)
3733
+ }
3734
+ `;
3735
+
3736
+ // src/ipfs/ipfs.ts
3737
+ function isCID(str) {
3738
+ if (!str)
3739
+ return false;
3740
+ try {
3741
+ CID.parse(str);
3742
+ return true;
3743
+ } catch (e) {
3744
+ if (/^(bafy|Qm)/.test(str))
3745
+ return true;
3746
+ return false;
3747
+ }
3748
+ }
3749
+ function normalizeIPFSUrl(url) {
3750
+ if (!url || typeof url !== "string")
3751
+ return null;
3752
+ url = url.replace(/"/g, "");
3753
+ if (isNormalizedIPFSURL(url))
3754
+ return url;
3755
+ if (isCID(url))
3756
+ return `ipfs://${url}`;
3757
+ if (!isIPFSUrl(url))
3758
+ return null;
3759
+ if (isGatewayIPFSUrl(url)) {
3760
+ const parsed = new URL(url.replace(/^\/\//, "http://"));
3761
+ parsed.pathname = parsed.pathname.replace(/^\/ipfs\//, "");
3762
+ const cid = parsed.toString().replace(`${parsed.protocol}//${parsed.host}/`, "");
3763
+ return `ipfs://${cid}`;
3764
+ }
3765
+ return null;
3766
+ }
3767
+ function isNormalizedIPFSURL(url) {
3768
+ return url && typeof url === "string" ? url.startsWith("ipfs://") : false;
3769
+ }
3770
+ function isGatewayIPFSUrl(url) {
3771
+ if (url && typeof url === "string") {
3772
+ try {
3773
+ const parsed = new URL(url.replace(/^"|'(.*)"|'$/, "$1"));
3774
+ return !isNormalizedIPFSURL(url) && parsed && parsed.pathname.startsWith("/ipfs/");
3775
+ } catch {
3776
+ return false;
3777
+ }
3778
+ }
3779
+ return false;
3780
+ }
3781
+ function isIPFSUrl(url) {
3782
+ return url ? isNormalizedIPFSURL(url) || isGatewayIPFSUrl(url) : false;
3783
+ }
3784
+ function isNormalizeableIPFSUrl(url) {
3785
+ return url ? isIPFSUrl(url) || isCID(url) : false;
3786
+ }
3787
+
3788
+ // src/ipfs/gateway.ts
3789
+ var IPFS_GATEWAY = "https://magic.decentralized-content.com";
3790
+ var ARWEAVE_GATEWAY = "https://arweave.net";
3791
+ function arweaveGatewayUrl(normalizedArweaveUrl) {
3792
+ if (!normalizedArweaveUrl || typeof normalizedArweaveUrl !== "string")
3793
+ return null;
3794
+ return normalizedArweaveUrl.replace("ar://", `${ARWEAVE_GATEWAY}/`);
3795
+ }
3796
+ function ipfsGatewayUrl(url) {
3797
+ if (!url || typeof url !== "string")
3798
+ return null;
3799
+ const normalizedIPFSUrl = normalizeIPFSUrl(url);
3800
+ if (normalizedIPFSUrl) {
3801
+ return normalizedIPFSUrl.replace("ipfs://", `${IPFS_GATEWAY}/ipfs/`);
3802
+ }
3803
+ return null;
3804
+ }
3805
+ function getFetchableUrl(uri) {
3806
+ if (!uri || typeof uri !== "string")
3807
+ return null;
3808
+ if (uri.startsWith("http://"))
3809
+ return null;
3810
+ if (isNormalizeableIPFSUrl(uri)) {
3811
+ return ipfsGatewayUrl(uri);
3812
+ }
3813
+ if (isArweaveURL(uri)) {
3814
+ return arweaveGatewayUrl(uri);
3815
+ }
3816
+ if (/^(https|data|blob):/.test(uri)) {
3817
+ return uri;
3818
+ }
3819
+ return null;
3820
+ }
3821
+
3822
+ // src/ipfs/mimeTypes.ts
3823
+ var HTML = "text/html";
3824
+ var MARKDOWN = "text/markdown";
3825
+ var MARKDOWN_UTF8 = "text/markdown; charset=utf-8";
3826
+ var TEXT_PLAIN_UTF8 = "text/plain; charset=utf-8";
3827
+ var TEXT_PLAIN = "text/plain";
3828
+ var CSV = "text/csv";
3829
+ var NUMBERS = ".numbers";
3830
+ var EXCEL = ".xlsx";
3831
+ var PDF = "application/pdf";
3832
+ var JPG = "image/jpg";
3833
+ var JPEG = "image/jpeg";
3834
+ var PNG = "image/png";
3835
+ var WEBP = "image/webp";
3836
+ var SVG = "image/svg+xml";
3837
+ var TIFF = "image/tiff";
3838
+ var GIF = "image/gif";
3839
+ var isImage = (mimeType) => {
3840
+ if (!mimeType)
3841
+ return false;
3842
+ return [JPG, JPEG, PNG, WEBP, SVG, TIFF, GIF].includes(mimeType);
3843
+ };
3844
+ var DEFAULT_THUMBNAIL_CID_HASHES = {
3845
+ ["AUDIO" /* AUDIO */]: "bafkreidir5laqi26ta6ivnpe2zpekgrfcyi4tb5x6vhwmwnledmzxshfb4",
3846
+ ["VIDEO" /* VIDEO */]: "bafkreifm4edadl3j5luoyvw4p6elxeqd77la7bulee6vhq5gq4chfk32mu",
3847
+ ["HTML" /* HTML */]: "bafkreifgvi6xfwqy2l6g45csyokejpaib52ee7zrw6etrxl2tas4xkkclq",
3848
+ ["ZIP" /* ZIP */]: "bafkreihe5rr5jbkwzegisjlhxbb7jw22xw5oilfmgd2re6tz6buo4pasdq",
3849
+ // assuming all zip files are html directories
3850
+ ["TEXT" /* TEXT */]: "bafkreiaez25nfgggzrnza2loxf6xueb2esm44pnyjyulwoslnipowrf56q",
3851
+ default: "bafkreihcoahllisbpb4eeypdwtm7go5uh275wxd7wf2tantpxlpjhviok4"
3852
+ };
3853
+ var MP4 = "video/mp4";
3854
+ var QUICKTIME = "video/quicktime";
3855
+ var M4V = "video/x-m4v";
3856
+ var WEBM = "video/webm";
3857
+ var M4A = "audio/x-m4a";
3858
+ var MPEG = "audio/mpeg";
3859
+ var MP3 = "audio/mp3";
3860
+ var WAV = "audio/wav";
3861
+ var VND_WAV = "audio/vnd.wav";
3862
+ var VND_WAVE = "audio/vnd.wave";
3863
+ var WAVE = "audio/wave";
3864
+ var X_WAV = "audio/x-wav";
3865
+ var AIFF = "audio/aiff";
3866
+ var GLTF = "model/gltf+json";
3867
+ var GLB = "model/gltf-binary";
3868
+ var GLTF_EXT = ".gltf";
3869
+ var GLB_EXT = ".glb";
3870
+ var JSON_MIME_TYPE = "application/json";
3871
+ var ZIP = "application/zip";
3872
+ var mimeToMediaType = {
3873
+ [HTML]: "HTML" /* HTML */,
3874
+ [JPG]: "IMAGE" /* IMAGE */,
3875
+ [JPEG]: "IMAGE" /* IMAGE */,
3876
+ [PNG]: "IMAGE" /* IMAGE */,
3877
+ [WEBP]: "IMAGE" /* IMAGE */,
3878
+ [SVG]: "IMAGE" /* IMAGE */,
3879
+ [TIFF]: "TIFF" /* TIFF */,
3880
+ [GIF]: "IMAGE" /* IMAGE */,
3881
+ [MP4]: "VIDEO" /* VIDEO */,
3882
+ [WEBM]: "VIDEO" /* VIDEO */,
3883
+ [QUICKTIME]: "VIDEO" /* VIDEO */,
3884
+ [M4V]: "VIDEO" /* VIDEO */,
3885
+ [MPEG]: "AUDIO" /* AUDIO */,
3886
+ [MP3]: "AUDIO" /* AUDIO */,
3887
+ [M4A]: "AUDIO" /* AUDIO */,
3888
+ [VND_WAV]: "AUDIO" /* AUDIO */,
3889
+ [VND_WAVE]: "AUDIO" /* AUDIO */,
3890
+ [WAV]: "AUDIO" /* AUDIO */,
3891
+ [WAVE]: "AUDIO" /* AUDIO */,
3892
+ [X_WAV]: "AUDIO" /* AUDIO */,
3893
+ [AIFF]: "AUDIO" /* AUDIO */,
3894
+ [TEXT_PLAIN]: "TEXT" /* TEXT */,
3895
+ [TEXT_PLAIN_UTF8]: "TEXT" /* TEXT */,
3896
+ [MARKDOWN]: "TEXT" /* TEXT */,
3897
+ [MARKDOWN_UTF8]: "TEXT" /* TEXT */,
3898
+ [CSV]: "CSV" /* CSV */,
3899
+ [NUMBERS]: "NUMBERS" /* NUMBERS */,
3900
+ [EXCEL]: "EXCEL" /* EXCEL */,
3901
+ [PDF]: "PDF" /* PDF */,
3902
+ [ZIP]: "ZIP" /* ZIP */,
3903
+ [GLTF]: "MODEL" /* MODEL */,
3904
+ [GLTF_EXT]: "MODEL" /* MODEL */,
3905
+ [GLB]: "MODEL" /* MODEL */,
3906
+ // GLTF returns 'application/json' as the mimetype,
3907
+ // and as the only JSON-encoded media we currently support,
3908
+ // we assume that if the mimetype is JSON, it's a GLTF
3909
+ [JSON_MIME_TYPE]: "MODEL" /* MODEL */,
3910
+ [GLB_EXT]: "MODEL" /* MODEL */
3911
+ };
3912
+ function mimeTypeToMedia(mimeType) {
3913
+ if (!mimeType)
3914
+ return "UNKNOWN" /* UNKNOWN */;
3915
+ return mimeToMediaType[mimeType] || "UNKNOWN" /* UNKNOWN */;
3916
+ }
3917
+ async function getMimeType(uri) {
3918
+ if (!uri)
3919
+ return uri;
3920
+ const res = await fetch(uri, { method: "HEAD" });
3921
+ let mimeType = res.headers.get("content-type");
3922
+ return mimeType;
3923
+ }
3924
+
3925
+ // src/ipfs/token-metadata.ts
3926
+ var makeTextTokenMetadata = (parameters) => {
3927
+ const { name, textFileUrl, thumbnailUrl, attributes = [] } = parameters;
3928
+ const content = textFileUrl ? {
3929
+ mime: TEXT_PLAIN,
3930
+ uri: textFileUrl
3931
+ } : null;
3932
+ const image = thumbnailUrl;
3933
+ const animation_url = textFileUrl;
3934
+ return {
3935
+ name,
3936
+ image,
3937
+ animation_url,
3938
+ content,
3939
+ attributes
3940
+ };
3941
+ };
3942
+ var makeMediaTokenMetadata = async ({
3943
+ name,
3944
+ description,
3945
+ attributes = [],
3946
+ mediaUrl,
3947
+ thumbnailUrl
3948
+ }) => {
3949
+ const contentUrl = mediaUrl;
3950
+ const fetchableContentUrl = getFetchableUrl(contentUrl);
3951
+ if (!fetchableContentUrl)
3952
+ throw new Error(`Content url (${contentUrl}) is not fetchable`);
3953
+ const mimeType = await getMimeType(fetchableContentUrl);
3954
+ const mediaType = mimeTypeToMedia(mimeType);
3955
+ let image = void 0;
3956
+ let animation_url = null;
3957
+ if (isImage(mimeType)) {
3958
+ image = contentUrl;
3959
+ } else {
3960
+ image = thumbnailUrl;
3961
+ animation_url = mediaUrl;
3962
+ }
3963
+ if (!image)
3964
+ image = `ipfs://${DEFAULT_THUMBNAIL_CID_HASHES[mediaType] || DEFAULT_THUMBNAIL_CID_HASHES.default}`;
3965
+ const content = contentUrl ? {
3966
+ mime: mimeType || "application/octet-stream",
3967
+ uri: contentUrl
3968
+ } : null;
3969
+ return {
3970
+ name,
3971
+ description,
3972
+ image,
3973
+ animation_url,
3974
+ content,
3975
+ attributes
3976
+ };
3977
+ };
3978
+
3979
+ // src/ipfs/text-metadata.ts
3980
+ var CHAR_LIMIT = 1111;
3981
+ var wrapText = ({
3982
+ ctx,
3983
+ text,
3984
+ x,
3985
+ y,
3986
+ maxWidth,
3987
+ lineHeight
3988
+ }) => {
3989
+ let words = text.replaceAll("\n", " \n ").split(/ +/);
3990
+ let line = "";
3991
+ let testLine = "";
3992
+ let lineArray = [];
3993
+ for (var n = 0; n < words.length; n++) {
3994
+ testLine += `${words[n]} `;
3995
+ let metrics = ctx.measureText(testLine);
3996
+ let testWidth = metrics.width;
3997
+ if (words[n]?.includes("\n") || testWidth > maxWidth && n > 0) {
3998
+ lineArray.push({ text: line, x, y });
3999
+ y += lineHeight;
4000
+ if (words[n]?.includes("\n")) {
4001
+ line = ``;
4002
+ testLine = ``;
4003
+ } else {
4004
+ line = `${words[n]} `;
4005
+ testLine = `${words[n]} `;
4006
+ }
4007
+ } else {
4008
+ line += `${words[n]} `;
4009
+ }
4010
+ if (n === words.length - 1) {
4011
+ lineArray.push({ text: line, x, y });
4012
+ }
4013
+ }
4014
+ return lineArray;
4015
+ };
4016
+ async function generateTextPreview(text) {
4017
+ const trimmedText = text.trim().slice(0, CHAR_LIMIT);
4018
+ const [width, height] = [500, 500];
4019
+ const padding = 20;
4020
+ const dpr = 2;
4021
+ const fontFamily = "Inter";
4022
+ const [fontSize, lineHeight] = [16, 24];
4023
+ const [textColor, backgroundColor] = ["black", "white"];
4024
+ return new Promise((resolve, reject) => {
4025
+ const canvas = document.createElement("canvas");
4026
+ canvas.width = width * dpr;
4027
+ canvas.height = height * dpr;
4028
+ const ctx = canvas.getContext("2d");
4029
+ if (!ctx) {
4030
+ return reject(new Error("Could not create canvas context"));
4031
+ }
4032
+ ctx.fillStyle = backgroundColor;
4033
+ ctx.fillRect(0, 0, width * dpr, width * dpr);
4034
+ ctx.fillStyle = textColor;
4035
+ ctx.font = `${fontSize * dpr}px ${fontFamily}`;
4036
+ const wrapped = wrapText({
4037
+ ctx,
4038
+ text: trimmedText,
4039
+ x: padding * dpr,
4040
+ y: fontSize * dpr + padding * dpr,
4041
+ maxWidth: width * dpr - padding * 2 * dpr,
4042
+ lineHeight: lineHeight * dpr
4043
+ });
4044
+ wrapped.forEach((line) => ctx.fillText(line.text, line.x, line.y));
4045
+ canvas.toBlob((blob) => {
4046
+ if (!blob) {
4047
+ return reject(new Error("Could not create blob"));
4048
+ }
4049
+ resolve(new File([blob], "thumbnail.png", { type: "image/png" }));
4050
+ });
4051
+ });
4052
+ }
4053
+ function generateTextTitle(text) {
4054
+ const firstLine = text.split("\n")[0];
4055
+ const firstSentence = firstLine?.split(". ")[0];
4056
+ if (firstSentence.length > 50) {
4057
+ return firstSentence.slice(0, 50) + "...";
4058
+ }
4059
+ return firstSentence;
4060
+ }
4061
+ var toTextFile = (text) => new File([text], "Untitled.txt", { type: "text/plain" });
4062
+ async function generateTextNftMetadataFiles(text) {
4063
+ const name = generateTextTitle(text);
4064
+ const textFile = toTextFile(text);
4065
+ const thumbnailFile = await generateTextPreview(text);
4066
+ return {
4067
+ name,
4068
+ mediaUrlFile: textFile,
4069
+ thumbnailFile
4070
+ };
4071
+ }
2924
4072
  export {
2925
4073
  Create1155Client,
2926
4074
  Errors,
@@ -2950,6 +4098,7 @@ export {
2950
4098
  encodeCollectOnManager,
2951
4099
  encodePostSignatureInput,
2952
4100
  encodePremintForAPI,
4101
+ generateTextNftMetadataFiles,
2953
4102
  getApiNetworkConfigForChain,
2954
4103
  getDataFromPremintReceipt,
2955
4104
  getDefaultFixedPriceMinterAddress,
@@ -2969,11 +4118,13 @@ export {
2969
4118
  isPremintConfigV2,
2970
4119
  isValidSignature,
2971
4120
  makeCallWithEthSafeTransferData,
4121
+ makeMediaTokenMetadata,
2972
4122
  makeMintRewardsRecipient,
2973
4123
  makeNewPremint,
2974
4124
  makePermitToCollectPremintOrNonPremint,
2975
4125
  makePermitTransferBatchAndTypeData,
2976
4126
  makePermitTransferTypeData,
4127
+ makeTextTokenMetadata,
2977
4128
  makeUrls,
2978
4129
  migratePremintConfigToV2,
2979
4130
  mintWithEthParams,