@campnetwork/origin 1.2.0-1 → 1.2.0-3

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.
@@ -3284,7 +3284,7 @@ function registerIpNFT(source, deadline, licenseTerms, metadata, fileKey, parent
3284
3284
  paymentToken: licenseTerms.paymentToken,
3285
3285
  },
3286
3286
  metadata,
3287
- parentId: parents || [],
3287
+ parentId: parents ? parents.map((p) => p.toString()) : [],
3288
3288
  };
3289
3289
  if (fileKey !== undefined) {
3290
3290
  body.fileKey = fileKey;
@@ -3478,6 +3478,46 @@ function approveIfNeeded(_a) {
3478
3478
  });
3479
3479
  }
3480
3480
 
3481
+ /**
3482
+ * Enum representing the status of data in the system.
3483
+ * * - ACTIVE: The data is currently active and available.
3484
+ * * - PENDING_DELETE: The data is scheduled for deletion but not yet removed.
3485
+ * * - DELETED: The data has been deleted and is no longer available.
3486
+ */
3487
+ var DataStatus;
3488
+ (function (DataStatus) {
3489
+ DataStatus[DataStatus["ACTIVE"] = 0] = "ACTIVE";
3490
+ DataStatus[DataStatus["PENDING_DELETE"] = 1] = "PENDING_DELETE";
3491
+ DataStatus[DataStatus["DELETED"] = 2] = "DELETED";
3492
+ })(DataStatus || (DataStatus = {}));
3493
+ /**
3494
+ * Creates license terms for a digital asset.
3495
+ * @param price The price of the asset in wei.
3496
+ * @param duration The duration of the license in seconds.
3497
+ * @param royaltyBps The royalty percentage in basis points (0-10000).
3498
+ * @param paymentToken The address of the payment token (ERC20 / address(0) for native currency).
3499
+ * @returns The created license terms.
3500
+ */
3501
+ const createLicenseTerms = (price, duration, royaltyBps, paymentToken) => {
3502
+ if (royaltyBps < constants.MIN_ROYALTY_BPS ||
3503
+ royaltyBps > constants.MAX_ROYALTY_BPS) {
3504
+ throw new Error(`Royalty basis points must be between ${constants.MIN_ROYALTY_BPS} and ${constants.MAX_ROYALTY_BPS}`);
3505
+ }
3506
+ if (duration < constants.MIN_LICENSE_DURATION ||
3507
+ duration > constants.MAX_LICENSE_DURATION) {
3508
+ throw new Error(`Duration must be between ${constants.MIN_LICENSE_DURATION} and ${constants.MAX_LICENSE_DURATION} seconds`);
3509
+ }
3510
+ if (price < constants.MIN_PRICE) {
3511
+ throw new Error(`Price must be at least ${constants.MIN_PRICE} wei`);
3512
+ }
3513
+ return {
3514
+ price,
3515
+ duration,
3516
+ royaltyBps,
3517
+ paymentToken,
3518
+ };
3519
+ };
3520
+
3481
3521
  var _Origin_instances, _Origin_generateURL, _Origin_setOriginStatus, _Origin_waitForTxReceipt, _Origin_ensureChainId, _Origin_getCurrentAccount, _Origin_resolveWalletAddress;
3482
3522
  /**
3483
3523
  * The Origin class
@@ -4115,6 +4155,11 @@ _Origin_instances = new WeakSet(), _Origin_generateURL = function _Origin_genera
4115
4155
  if (!this.viemClient) {
4116
4156
  throw new Error("WalletClient not connected. Please connect a wallet.");
4117
4157
  }
4158
+ // If account is already set on the client, return it directly
4159
+ if (this.viemClient.account) {
4160
+ return this.viemClient.account.address;
4161
+ }
4162
+ // Otherwise request accounts (browser wallet flow)
4118
4163
  const accounts = yield this.viemClient.request({
4119
4164
  method: "eth_requestAccounts",
4120
4165
  params: [],
@@ -4148,7 +4193,210 @@ _Origin_instances = new WeakSet(), _Origin_generateURL = function _Origin_genera
4148
4193
  });
4149
4194
  };
4150
4195
 
4151
- var _Auth_instances, _Auth_triggers, _Auth_trigger, _Auth_loadAuthStatusFromStorage, _Auth_requestAccount, _Auth_fetchNonce, _Auth_verifySignature, _Auth_createMessage;
4196
+ /**
4197
+ * Adapter for viem WalletClient
4198
+ */
4199
+ class ViemSignerAdapter {
4200
+ constructor(signer) {
4201
+ this.type = "viem";
4202
+ this.signer = signer;
4203
+ }
4204
+ getAddress() {
4205
+ return __awaiter(this, void 0, void 0, function* () {
4206
+ if (this.signer.account) {
4207
+ return this.signer.account.address;
4208
+ }
4209
+ const accounts = yield this.signer.request({
4210
+ method: "eth_requestAccounts",
4211
+ params: [],
4212
+ });
4213
+ if (!accounts || accounts.length === 0) {
4214
+ throw new Error("No accounts found in viem wallet client");
4215
+ }
4216
+ return accounts[0];
4217
+ });
4218
+ }
4219
+ signMessage(message) {
4220
+ return __awaiter(this, void 0, void 0, function* () {
4221
+ const address = yield this.getAddress();
4222
+ return yield this.signer.signMessage({
4223
+ account: address,
4224
+ message,
4225
+ });
4226
+ });
4227
+ }
4228
+ getChainId() {
4229
+ return __awaiter(this, void 0, void 0, function* () {
4230
+ var _a;
4231
+ return ((_a = this.signer.chain) === null || _a === void 0 ? void 0 : _a.id) || 1;
4232
+ });
4233
+ }
4234
+ }
4235
+ /**
4236
+ * Adapter for ethers Signer (v5 and v6)
4237
+ */
4238
+ class EthersSignerAdapter {
4239
+ constructor(signer) {
4240
+ this.type = "ethers";
4241
+ this.signer = signer;
4242
+ }
4243
+ getAddress() {
4244
+ return __awaiter(this, void 0, void 0, function* () {
4245
+ // Works for both ethers v5 and v6
4246
+ if (typeof this.signer.getAddress === "function") {
4247
+ return yield this.signer.getAddress();
4248
+ }
4249
+ if (this.signer.address) {
4250
+ return this.signer.address;
4251
+ }
4252
+ throw new Error("Unable to get address from ethers signer");
4253
+ });
4254
+ }
4255
+ signMessage(message) {
4256
+ return __awaiter(this, void 0, void 0, function* () {
4257
+ if (typeof this.signer.signMessage !== "function") {
4258
+ throw new Error("Signer does not support signMessage");
4259
+ }
4260
+ return yield this.signer.signMessage(message);
4261
+ });
4262
+ }
4263
+ getChainId() {
4264
+ return __awaiter(this, void 0, void 0, function* () {
4265
+ // Try ethers v6 first
4266
+ if (this.signer.provider &&
4267
+ typeof this.signer.provider.getNetwork === "function") {
4268
+ const network = yield this.signer.provider.getNetwork();
4269
+ // ethers v6 returns bigint, v5 returns number
4270
+ return typeof network.chainId === "bigint"
4271
+ ? Number(network.chainId)
4272
+ : network.chainId;
4273
+ }
4274
+ // Fallback for ethers v5
4275
+ if (typeof this.signer.getChainId === "function") {
4276
+ return yield this.signer.getChainId();
4277
+ }
4278
+ // Default to mainnet if we can't determine
4279
+ return 484;
4280
+ });
4281
+ }
4282
+ }
4283
+ /**
4284
+ * Adapter for custom signer implementations
4285
+ */
4286
+ class CustomSignerAdapter {
4287
+ constructor(signer) {
4288
+ this.type = "custom";
4289
+ this.signer = signer;
4290
+ }
4291
+ getAddress() {
4292
+ return __awaiter(this, void 0, void 0, function* () {
4293
+ if (typeof this.signer.getAddress === "function") {
4294
+ return yield this.signer.getAddress();
4295
+ }
4296
+ if (this.signer.address) {
4297
+ return this.signer.address;
4298
+ }
4299
+ throw new Error("Custom signer must implement getAddress() or have address property");
4300
+ });
4301
+ }
4302
+ signMessage(message) {
4303
+ return __awaiter(this, void 0, void 0, function* () {
4304
+ if (typeof this.signer.signMessage !== "function") {
4305
+ throw new Error("Custom signer must implement signMessage()");
4306
+ }
4307
+ return yield this.signer.signMessage(message);
4308
+ });
4309
+ }
4310
+ getChainId() {
4311
+ return __awaiter(this, void 0, void 0, function* () {
4312
+ if (typeof this.signer.getChainId === "function") {
4313
+ const chainId = yield this.signer.getChainId();
4314
+ return typeof chainId === "bigint" ? Number(chainId) : chainId;
4315
+ }
4316
+ if (this.signer.chainId !== undefined) {
4317
+ return typeof this.signer.chainId === "bigint"
4318
+ ? Number(this.signer.chainId)
4319
+ : this.signer.chainId;
4320
+ }
4321
+ // Default to mainnet
4322
+ return 484;
4323
+ });
4324
+ }
4325
+ }
4326
+ /**
4327
+ * Factory function to create appropriate adapter based on signer type
4328
+ */
4329
+ function createSignerAdapter(signer) {
4330
+ // Check for viem WalletClient
4331
+ if (signer.transport &&
4332
+ signer.chain &&
4333
+ typeof signer.signMessage === "function") {
4334
+ return new ViemSignerAdapter(signer);
4335
+ }
4336
+ // Check for ethers signer (v5 or v6)
4337
+ if (signer._isSigner ||
4338
+ (signer.provider && typeof signer.signMessage === "function")) {
4339
+ return new EthersSignerAdapter(signer);
4340
+ }
4341
+ // Try custom adapter
4342
+ return new CustomSignerAdapter(signer);
4343
+ }
4344
+
4345
+ /**
4346
+ * Browser localStorage adapter
4347
+ */
4348
+ class BrowserStorage {
4349
+ getItem(key) {
4350
+ return __awaiter(this, void 0, void 0, function* () {
4351
+ if (typeof localStorage === "undefined") {
4352
+ return null;
4353
+ }
4354
+ return localStorage.getItem(key);
4355
+ });
4356
+ }
4357
+ setItem(key, value) {
4358
+ return __awaiter(this, void 0, void 0, function* () {
4359
+ if (typeof localStorage !== "undefined") {
4360
+ localStorage.setItem(key, value);
4361
+ }
4362
+ });
4363
+ }
4364
+ removeItem(key) {
4365
+ return __awaiter(this, void 0, void 0, function* () {
4366
+ if (typeof localStorage !== "undefined") {
4367
+ localStorage.removeItem(key);
4368
+ }
4369
+ });
4370
+ }
4371
+ }
4372
+ /**
4373
+ * In-memory storage adapter for Node.js
4374
+ */
4375
+ class MemoryStorage {
4376
+ constructor() {
4377
+ this.storage = new Map();
4378
+ }
4379
+ getItem(key) {
4380
+ return __awaiter(this, void 0, void 0, function* () {
4381
+ return this.storage.get(key) || null;
4382
+ });
4383
+ }
4384
+ setItem(key, value) {
4385
+ return __awaiter(this, void 0, void 0, function* () {
4386
+ this.storage.set(key, value);
4387
+ });
4388
+ }
4389
+ removeItem(key) {
4390
+ return __awaiter(this, void 0, void 0, function* () {
4391
+ this.storage.delete(key);
4392
+ });
4393
+ }
4394
+ clear() {
4395
+ this.storage.clear();
4396
+ }
4397
+ }
4398
+
4399
+ var _Auth_instances, _Auth_triggers, _Auth_isNodeEnvironment, _Auth_signerAdapter, _Auth_storage, _Auth_trigger, _Auth_loadAuthStatusFromStorage, _Auth_requestAccount, _Auth_fetchNonce, _Auth_verifySignature, _Auth_createMessage;
4152
4400
  const createRedirectUriObject = (redirectUri) => {
4153
4401
  const keys = ["twitter", "spotify"];
4154
4402
  if (typeof redirectUri === "object") {
@@ -4185,17 +4433,24 @@ class Auth {
4185
4433
  * @param {string} options.clientId The client ID.
4186
4434
  * @param {string|object} options.redirectUri The redirect URI used for oauth. Leave empty if you want to use the current URL. If you want different redirect URIs for different socials, pass an object with the socials as keys and the redirect URIs as values.
4187
4435
  * @param {("DEVELOPMENT"|"PRODUCTION")} [options.environment="DEVELOPMENT"] The environment to use.
4436
+ * @param {StorageAdapter} [options.storage] Custom storage adapter. Defaults to localStorage in browser, memory storage in Node.js.
4188
4437
  * @throws {APIError} - Throws an error if the clientId is not provided.
4189
4438
  */
4190
- constructor({ clientId, redirectUri, environment = "DEVELOPMENT", }) {
4439
+ constructor({ clientId, redirectUri, environment = "DEVELOPMENT", storage, }) {
4191
4440
  _Auth_instances.add(this);
4192
4441
  _Auth_triggers.set(this, void 0);
4442
+ _Auth_isNodeEnvironment.set(this, void 0);
4443
+ _Auth_signerAdapter.set(this, void 0);
4444
+ _Auth_storage.set(this, void 0);
4193
4445
  if (!clientId) {
4194
4446
  throw new Error("clientId is required");
4195
4447
  }
4196
4448
  if (["PRODUCTION", "DEVELOPMENT"].indexOf(environment) === -1) {
4197
4449
  throw new Error("Invalid environment, must be DEVELOPMENT or PRODUCTION");
4198
4450
  }
4451
+ __classPrivateFieldSet(this, _Auth_isNodeEnvironment, typeof window === "undefined", "f");
4452
+ __classPrivateFieldSet(this, _Auth_storage, storage ||
4453
+ (__classPrivateFieldGet(this, _Auth_isNodeEnvironment, "f") ? new MemoryStorage() : new BrowserStorage()), "f");
4199
4454
  this.viem = null;
4200
4455
  this.environment = ENVIRONMENTS[environment];
4201
4456
  this.redirectUri = createRedirectUriObject(redirectUri);
@@ -4206,9 +4461,12 @@ class Auth {
4206
4461
  this.walletAddress = null;
4207
4462
  this.userId = null;
4208
4463
  __classPrivateFieldSet(this, _Auth_triggers, {}, "f");
4209
- providerStore.subscribe((providers) => {
4210
- __classPrivateFieldGet(this, _Auth_instances, "m", _Auth_trigger).call(this, "providers", providers);
4211
- });
4464
+ // only subscribe to providers in browser environment
4465
+ if (!__classPrivateFieldGet(this, _Auth_isNodeEnvironment, "f")) {
4466
+ providerStore.subscribe((providers) => {
4467
+ __classPrivateFieldGet(this, _Auth_instances, "m", _Auth_trigger).call(this, "providers", providers);
4468
+ });
4469
+ }
4212
4470
  __classPrivateFieldGet(this, _Auth_instances, "m", _Auth_loadAuthStatusFromStorage).call(this);
4213
4471
  }
4214
4472
  /**
@@ -4270,7 +4528,7 @@ class Auth {
4270
4528
  // TODO: only use one of these
4271
4529
  __classPrivateFieldGet(this, _Auth_instances, "m", _Auth_trigger).call(this, "viem", this.viem);
4272
4530
  __classPrivateFieldGet(this, _Auth_instances, "m", _Auth_trigger).call(this, "provider", { provider, info });
4273
- localStorage.setItem("camp-sdk:provider", JSON.stringify(info));
4531
+ __classPrivateFieldGet(this, _Auth_storage, "f").setItem("camp-sdk:provider", JSON.stringify(info));
4274
4532
  }
4275
4533
  /**
4276
4534
  * Set the wallet address. This is useful for edge cases where the provider can't return the wallet address. Don't use this unless you know what you're doing.
@@ -4291,7 +4549,11 @@ class Auth {
4291
4549
  console.warn("No wallet address found in local storage. Please connect your wallet again.");
4292
4550
  return;
4293
4551
  }
4294
- const lastProvider = JSON.parse(localStorage.getItem("camp-sdk:provider") || "{}");
4552
+ const providerJson = yield __classPrivateFieldGet(this, _Auth_storage, "f").getItem("camp-sdk:provider");
4553
+ if (!providerJson) {
4554
+ return;
4555
+ }
4556
+ const lastProvider = JSON.parse(providerJson);
4295
4557
  let provider;
4296
4558
  const providers = (_a = providerStore.value()) !== null && _a !== void 0 ? _a : [];
4297
4559
  // first pass: try to find provider by UUID/name and check if it has the right address
@@ -4390,10 +4652,11 @@ class Auth {
4390
4652
  this.userId = null;
4391
4653
  this.jwt = null;
4392
4654
  this.origin = null;
4393
- localStorage.removeItem("camp-sdk:wallet-address");
4394
- localStorage.removeItem("camp-sdk:user-id");
4395
- localStorage.removeItem("camp-sdk:jwt");
4396
- localStorage.removeItem("camp-sdk:environment");
4655
+ __classPrivateFieldSet(this, _Auth_signerAdapter, undefined, "f");
4656
+ yield __classPrivateFieldGet(this, _Auth_storage, "f").removeItem("camp-sdk:wallet-address");
4657
+ yield __classPrivateFieldGet(this, _Auth_storage, "f").removeItem("camp-sdk:user-id");
4658
+ yield __classPrivateFieldGet(this, _Auth_storage, "f").removeItem("camp-sdk:jwt");
4659
+ yield __classPrivateFieldGet(this, _Auth_storage, "f").removeItem("camp-sdk:environment");
4397
4660
  });
4398
4661
  }
4399
4662
  /**
@@ -4421,10 +4684,72 @@ class Auth {
4421
4684
  this.userId = res.userId;
4422
4685
  this.jwt = res.token;
4423
4686
  this.origin = new Origin(this.jwt, this.environment, this.viem);
4424
- localStorage.setItem("camp-sdk:jwt", this.jwt);
4425
- localStorage.setItem("camp-sdk:wallet-address", this.walletAddress);
4426
- localStorage.setItem("camp-sdk:user-id", this.userId);
4427
- localStorage.setItem("camp-sdk:environment", this.environment.NAME);
4687
+ yield __classPrivateFieldGet(this, _Auth_storage, "f").setItem("camp-sdk:jwt", this.jwt);
4688
+ yield __classPrivateFieldGet(this, _Auth_storage, "f").setItem("camp-sdk:wallet-address", this.walletAddress);
4689
+ yield __classPrivateFieldGet(this, _Auth_storage, "f").setItem("camp-sdk:user-id", this.userId);
4690
+ yield __classPrivateFieldGet(this, _Auth_storage, "f").setItem("camp-sdk:environment", this.environment.NAME);
4691
+ __classPrivateFieldGet(this, _Auth_instances, "m", _Auth_trigger).call(this, "state", "authenticated");
4692
+ return {
4693
+ success: true,
4694
+ message: "Successfully authenticated",
4695
+ walletAddress: this.walletAddress,
4696
+ };
4697
+ }
4698
+ else {
4699
+ this.isAuthenticated = false;
4700
+ __classPrivateFieldGet(this, _Auth_instances, "m", _Auth_trigger).call(this, "state", "unauthenticated");
4701
+ throw new APIError("Failed to authenticate");
4702
+ }
4703
+ }
4704
+ catch (e) {
4705
+ this.isAuthenticated = false;
4706
+ __classPrivateFieldGet(this, _Auth_instances, "m", _Auth_trigger).call(this, "state", "unauthenticated");
4707
+ throw new APIError(e);
4708
+ }
4709
+ });
4710
+ }
4711
+ /**
4712
+ * Connect with a custom signer (for Node.js or custom wallet implementations).
4713
+ * This method bypasses browser wallet interactions and uses the provided signer directly.
4714
+ * @param {any} signer The signer instance (viem WalletClient, ethers Signer, or custom signer).
4715
+ * @param {object} [options] Optional configuration.
4716
+ * @param {string} [options.domain] The domain to use in SIWE message (defaults to 'localhost').
4717
+ * @param {string} [options.uri] The URI to use in SIWE message (defaults to 'http://localhost').
4718
+ * @returns {Promise<{ success: boolean; message: string; walletAddress: string }>} A promise that resolves with the authentication result.
4719
+ * @throws {APIError} - Throws an error if authentication fails.
4720
+ * @example
4721
+ * // Using with ethers
4722
+ * const signer = new ethers.Wallet(privateKey, provider);
4723
+ * await auth.connectWithSigner(signer, { domain: 'myapp.com', uri: 'https://myapp.com' });
4724
+ *
4725
+ * // Using with viem
4726
+ * const account = privateKeyToAccount('0x...');
4727
+ * const client = createWalletClient({ account, chain: mainnet, transport: http() });
4728
+ * await auth.connectWithSigner(client);
4729
+ */
4730
+ connectWithSigner(signer, options) {
4731
+ return __awaiter(this, void 0, void 0, function* () {
4732
+ __classPrivateFieldGet(this, _Auth_instances, "m", _Auth_trigger).call(this, "state", "loading");
4733
+ try {
4734
+ __classPrivateFieldSet(this, _Auth_signerAdapter, createSignerAdapter(signer), "f");
4735
+ this.walletAddress = checksumAddress((yield __classPrivateFieldGet(this, _Auth_signerAdapter, "f").getAddress()));
4736
+ // store the signer as viem client if it's a viem client, otherwise keep adapter
4737
+ if (__classPrivateFieldGet(this, _Auth_signerAdapter, "f").type === "viem") {
4738
+ this.viem = signer;
4739
+ }
4740
+ const nonce = yield __classPrivateFieldGet(this, _Auth_instances, "m", _Auth_fetchNonce).call(this);
4741
+ const message = __classPrivateFieldGet(this, _Auth_instances, "m", _Auth_createMessage).call(this, nonce, options === null || options === void 0 ? void 0 : options.domain, options === null || options === void 0 ? void 0 : options.uri);
4742
+ const signature = yield __classPrivateFieldGet(this, _Auth_signerAdapter, "f").signMessage(message);
4743
+ const res = yield __classPrivateFieldGet(this, _Auth_instances, "m", _Auth_verifySignature).call(this, message, signature);
4744
+ if (res.success) {
4745
+ this.isAuthenticated = true;
4746
+ this.userId = res.userId;
4747
+ this.jwt = res.token;
4748
+ this.origin = new Origin(this.jwt, this.environment, this.viem);
4749
+ yield __classPrivateFieldGet(this, _Auth_storage, "f").setItem("camp-sdk:jwt", this.jwt);
4750
+ yield __classPrivateFieldGet(this, _Auth_storage, "f").setItem("camp-sdk:wallet-address", this.walletAddress);
4751
+ yield __classPrivateFieldGet(this, _Auth_storage, "f").setItem("camp-sdk:user-id", this.userId);
4752
+ yield __classPrivateFieldGet(this, _Auth_storage, "f").setItem("camp-sdk:environment", this.environment.NAME);
4428
4753
  __classPrivateFieldGet(this, _Auth_instances, "m", _Auth_trigger).call(this, "state", "authenticated");
4429
4754
  return {
4430
4755
  success: true,
@@ -4440,6 +4765,7 @@ class Auth {
4440
4765
  }
4441
4766
  catch (e) {
4442
4767
  this.isAuthenticated = false;
4768
+ __classPrivateFieldSet(this, _Auth_signerAdapter, undefined, "f");
4443
4769
  __classPrivateFieldGet(this, _Auth_instances, "m", _Auth_trigger).call(this, "state", "unauthenticated");
4444
4770
  throw new APIError(e);
4445
4771
  }
@@ -4481,39 +4807,48 @@ class Auth {
4481
4807
  /**
4482
4808
  * Link the user's Twitter account.
4483
4809
  * @returns {Promise<void>}
4484
- * @throws {Error} - Throws an error if the user is not authenticated.
4810
+ * @throws {Error} - Throws an error if the user is not authenticated or in Node.js environment.
4485
4811
  */
4486
4812
  linkTwitter() {
4487
4813
  return __awaiter(this, void 0, void 0, function* () {
4488
4814
  if (!this.isAuthenticated) {
4489
4815
  throw new Error("User needs to be authenticated");
4490
4816
  }
4817
+ if (__classPrivateFieldGet(this, _Auth_isNodeEnvironment, "f")) {
4818
+ throw new Error("Social linking requires browser environment for OAuth flow");
4819
+ }
4491
4820
  window.location.href = `${this.environment.AUTH_HUB_BASE_API}/twitter/connect?clientId=${this.clientId}&userId=${this.userId}&redirect_url=${this.redirectUri["twitter"]}`;
4492
4821
  });
4493
4822
  }
4494
4823
  /**
4495
4824
  * Link the user's Discord account.
4496
4825
  * @returns {Promise<void>}
4497
- * @throws {Error} - Throws an error if the user is not authenticated.
4826
+ * @throws {Error} - Throws an error if the user is not authenticated or in Node.js environment.
4498
4827
  */
4499
4828
  linkDiscord() {
4500
4829
  return __awaiter(this, void 0, void 0, function* () {
4501
4830
  if (!this.isAuthenticated) {
4502
4831
  throw new Error("User needs to be authenticated");
4503
4832
  }
4833
+ if (__classPrivateFieldGet(this, _Auth_isNodeEnvironment, "f")) {
4834
+ throw new Error("Social linking requires browser environment for OAuth flow");
4835
+ }
4504
4836
  window.location.href = `${this.environment.AUTH_HUB_BASE_API}/discord/connect?clientId=${this.clientId}&userId=${this.userId}&redirect_url=${this.redirectUri["discord"]}`;
4505
4837
  });
4506
4838
  }
4507
4839
  /**
4508
4840
  * Link the user's Spotify account.
4509
4841
  * @returns {Promise<void>}
4510
- * @throws {Error} - Throws an error if the user is not authenticated.
4842
+ * @throws {Error} - Throws an error if the user is not authenticated or in Node.js environment.
4511
4843
  */
4512
4844
  linkSpotify() {
4513
4845
  return __awaiter(this, void 0, void 0, function* () {
4514
4846
  if (!this.isAuthenticated) {
4515
4847
  throw new Error("User needs to be authenticated");
4516
4848
  }
4849
+ if (__classPrivateFieldGet(this, _Auth_isNodeEnvironment, "f")) {
4850
+ throw new Error("Social linking requires browser environment for OAuth flow");
4851
+ }
4517
4852
  window.location.href = `${this.environment.AUTH_HUB_BASE_API}/spotify/connect?clientId=${this.clientId}&userId=${this.userId}&redirect_url=${this.redirectUri["spotify"]}`;
4518
4853
  });
4519
4854
  }
@@ -4782,19 +5117,16 @@ class Auth {
4782
5117
  });
4783
5118
  }
4784
5119
  }
4785
- _Auth_triggers = new WeakMap(), _Auth_instances = new WeakSet(), _Auth_trigger = function _Auth_trigger(event, data) {
5120
+ _Auth_triggers = new WeakMap(), _Auth_isNodeEnvironment = new WeakMap(), _Auth_signerAdapter = new WeakMap(), _Auth_storage = new WeakMap(), _Auth_instances = new WeakSet(), _Auth_trigger = function _Auth_trigger(event, data) {
4786
5121
  if (__classPrivateFieldGet(this, _Auth_triggers, "f")[event]) {
4787
5122
  __classPrivateFieldGet(this, _Auth_triggers, "f")[event].forEach((callback) => callback(data));
4788
5123
  }
4789
5124
  }, _Auth_loadAuthStatusFromStorage = function _Auth_loadAuthStatusFromStorage(provider) {
4790
5125
  return __awaiter(this, void 0, void 0, function* () {
4791
- if (typeof localStorage === "undefined") {
4792
- return;
4793
- }
4794
- const walletAddress = localStorage === null || localStorage === void 0 ? void 0 : localStorage.getItem("camp-sdk:wallet-address");
4795
- const userId = localStorage === null || localStorage === void 0 ? void 0 : localStorage.getItem("camp-sdk:user-id");
4796
- const jwt = localStorage === null || localStorage === void 0 ? void 0 : localStorage.getItem("camp-sdk:jwt");
4797
- const lastEnvironment = localStorage === null || localStorage === void 0 ? void 0 : localStorage.getItem("camp-sdk:environment");
5126
+ const walletAddress = yield __classPrivateFieldGet(this, _Auth_storage, "f").getItem("camp-sdk:wallet-address");
5127
+ const userId = yield __classPrivateFieldGet(this, _Auth_storage, "f").getItem("camp-sdk:user-id");
5128
+ const jwt = yield __classPrivateFieldGet(this, _Auth_storage, "f").getItem("camp-sdk:jwt");
5129
+ const lastEnvironment = yield __classPrivateFieldGet(this, _Auth_storage, "f").getItem("camp-sdk:environment");
4798
5130
  if (walletAddress &&
4799
5131
  userId &&
4800
5132
  jwt &&
@@ -4813,7 +5145,7 @@ _Auth_triggers = new WeakMap(), _Auth_instances = new WeakSet(), _Auth_trigger =
4813
5145
  address: walletAddress,
4814
5146
  });
4815
5147
  }
4816
- else {
5148
+ else if (!__classPrivateFieldGet(this, _Auth_isNodeEnvironment, "f")) {
4817
5149
  console.warn("No matching provider was given for the stored wallet address. Trying to recover provider.");
4818
5150
  yield this.recoverProvider();
4819
5151
  }
@@ -4882,14 +5214,16 @@ _Auth_triggers = new WeakMap(), _Auth_instances = new WeakSet(), _Auth_trigger =
4882
5214
  throw new APIError(e);
4883
5215
  }
4884
5216
  });
4885
- }, _Auth_createMessage = function _Auth_createMessage(nonce) {
5217
+ }, _Auth_createMessage = function _Auth_createMessage(nonce, domain, uri) {
4886
5218
  return createSiweMessage({
4887
- domain: window.location.host,
5219
+ domain: domain ||
5220
+ (__classPrivateFieldGet(this, _Auth_isNodeEnvironment, "f") ? "localhost" : window.location.host),
4888
5221
  address: this.walletAddress,
4889
5222
  statement: constants.SIWE_MESSAGE_STATEMENT,
4890
- uri: window.location.origin,
5223
+ uri: uri ||
5224
+ (__classPrivateFieldGet(this, _Auth_isNodeEnvironment, "f") ? "http://localhost" : window.location.origin),
4891
5225
  version: "1",
4892
- chainId: this.viem.chain.id,
5226
+ chainId: this.environment.CHAIN.id,
4893
5227
  nonce: nonce,
4894
5228
  });
4895
5229
  };
@@ -5380,46 +5714,6 @@ const useWalletConnectProvider = (projectId, chain) => {
5380
5714
  return walletConnectProvider;
5381
5715
  };
5382
5716
 
5383
- /**
5384
- * Enum representing the status of data in the system.
5385
- * * - ACTIVE: The data is currently active and available.
5386
- * * - PENDING_DELETE: The data is scheduled for deletion but not yet removed.
5387
- * * - DELETED: The data has been deleted and is no longer available.
5388
- */
5389
- var DataStatus;
5390
- (function (DataStatus) {
5391
- DataStatus[DataStatus["ACTIVE"] = 0] = "ACTIVE";
5392
- DataStatus[DataStatus["PENDING_DELETE"] = 1] = "PENDING_DELETE";
5393
- DataStatus[DataStatus["DELETED"] = 2] = "DELETED";
5394
- })(DataStatus || (DataStatus = {}));
5395
- /**
5396
- * Creates license terms for a digital asset.
5397
- * @param price The price of the asset in wei.
5398
- * @param duration The duration of the license in seconds.
5399
- * @param royaltyBps The royalty percentage in basis points (0-10000).
5400
- * @param paymentToken The address of the payment token (ERC20 / address(0) for native currency).
5401
- * @returns The created license terms.
5402
- */
5403
- const createLicenseTerms = (price, duration, royaltyBps, paymentToken) => {
5404
- if (royaltyBps < constants.MIN_ROYALTY_BPS ||
5405
- royaltyBps > constants.MAX_ROYALTY_BPS) {
5406
- throw new Error(`Royalty basis points must be between ${constants.MIN_ROYALTY_BPS} and ${constants.MAX_ROYALTY_BPS}`);
5407
- }
5408
- if (duration < constants.MIN_LICENSE_DURATION ||
5409
- duration > constants.MAX_LICENSE_DURATION) {
5410
- throw new Error(`Duration must be between ${constants.MIN_LICENSE_DURATION} and ${constants.MAX_LICENSE_DURATION} seconds`);
5411
- }
5412
- if (price < constants.MIN_PRICE) {
5413
- throw new Error(`Price must be at least ${constants.MIN_PRICE} wei`);
5414
- }
5415
- return {
5416
- price,
5417
- duration,
5418
- royaltyBps,
5419
- paymentToken,
5420
- };
5421
- };
5422
-
5423
5717
  var css_248z = ".buttons-module_button__4Ogad{background-color:#ff6f00;border:none;border-radius:0;box-shadow:inset 0 2px 0 hsla(0,0%,100%,.15),inset 0 -2px 4px rgba(0,0,0,.05),0 1px 1px rgba(46,54,80,.075);color:#fff;font-family:Geist Mono,monospace;font-size:1rem;font-size:.875rem;font-weight:600;height:2.5rem;margin-bottom:.75rem;margin-top:1rem;padding:1rem;padding-block:0;position:relative;text-transform:uppercase;width:100%}.buttons-module_button__4Ogad:hover{background-color:#cc4e02;cursor:pointer}.buttons-module_button__4Ogad:disabled{background-color:#ccc;cursor:not-allowed}.buttons-module_connect-button__CJhUa{background-color:#ff6f00;border:none;box-shadow:inset 0 2px 0 hsla(0,0%,100%,.15),inset 0 -2px 4px rgba(0,0,0,.05),0 1px 1px rgba(46,54,80,.075);color:#fff;font-family:Geist Mono,monospace;font-size:1rem;font-weight:600;height:2.75rem;line-height:1.333rem;padding-inline:2.5rem;padding-left:5rem;position:relative;text-transform:uppercase;transition:background-color .15s;width:13rem}.buttons-module_connect-button__CJhUa .buttons-module_button-icon__JM4-2{background:hsla(0,0%,100%,.75);box-shadow:inset 0 2px 0 hsla(0,0%,100%,.15),inset 0 -2px 4px rgba(0,0,0,.05);display:grid;height:100%;left:0;margin-right:.5rem;place-items:center;position:absolute;top:50%;transform:translateY(-50%);transition:background-color .15s;width:3rem}.buttons-module_connect-button__CJhUa .buttons-module_button-icon__JM4-2 svg{height:1.25rem;width:1.25rem}.buttons-module_connect-button__CJhUa:hover{background-color:#cc4e02;border-color:#cc4e02;cursor:pointer}.buttons-module_connect-button__CJhUa:hover .buttons-module_button-icon__JM4-2{background:hsla(0,0%,100%,.675)}.buttons-module_connect-button__CJhUa:focus{outline:none}.buttons-module_connect-button__CJhUa:disabled{background-color:#ccc;cursor:not-allowed}.buttons-module_provider-button__6JY7s{align-items:center;border:1px solid #ddd;display:flex;gap:.5rem;justify-content:flex-start;padding:.5rem;position:relative;transition:border-color .15s;width:100%}.buttons-module_provider-button__6JY7s:focus{outline:1px solid #ff6f00;outline-offset:2px}.buttons-module_provider-button__6JY7s:hover{border-color:#ff6f00}.buttons-module_provider-button__6JY7s:hover:not(:disabled){cursor:pointer}.buttons-module_provider-button__6JY7s img{height:2rem;width:2rem}.buttons-module_provider-button__6JY7s .buttons-module_provider-icon__MOhr8{border-radius:.2rem}.buttons-module_provider-button__6JY7s span{line-height:1rem;margin-left:.5rem}.buttons-module_provider-button__6JY7s span.buttons-module_provider-name__tHWO2{color:#333;font-size:.875rem}.buttons-module_provider-button__6JY7s span.buttons-module_provider-label__CEGRr{color:#777;font-family:Geist Mono,monospace;font-size:.7rem;text-transform:uppercase}.buttons-module_link-button-default__EcKUT{background-color:#ff6f00;border:none;box-shadow:inset 0 2px 0 hsla(0,0%,100%,.15),inset 0 -2px 4px rgba(0,0,0,.05),0 1px 1px rgba(46,54,80,.075);box-sizing:border-box;cursor:pointer;height:2.6rem;position:relative;width:7rem}.buttons-module_link-button-default__EcKUT:disabled{background-color:#b8b8b8;cursor:not-allowed}.buttons-module_link-button-default__EcKUT:after{background-color:transparent;border-radius:.75rem;bottom:0;content:\"\";left:0;position:absolute;right:0;top:0;transition:background-color .15s}.buttons-module_link-button-default__EcKUT:disabled:after{background-color:rgba(0,0,0,.35);border-radius:.35rem;color:#fff;content:\"Not connected\";display:grid;font-size:.75rem;height:2rem;left:0;opacity:0;padding:.25rem;place-items:center;position:absolute;right:0;top:-2.7rem;transform:translateY(-.5rem);transition:all .25s;-webkit-user-select:none;-moz-user-select:none;user-select:none;visibility:hidden}.buttons-module_link-button-default__EcKUT:disabled:hover:after{opacity:1;transform:translateY(0);visibility:visible}.buttons-module_link-button-default__EcKUT:not(:disabled):hover:after{background-color:rgba(0,0,0,.1)}.buttons-module_link-button-default__EcKUT:not(:disabled).buttons-module_twitter__9sRaz{background-color:#1da1f2}.buttons-module_link-button-default__EcKUT:not(:disabled).buttons-module_spotify__-fiKQ{background-color:#1db954}.buttons-module_link-button-default__EcKUT:not(:disabled).buttons-module_discord__I-YjZ{background-color:#7289da}.buttons-module_link-button-default__EcKUT:not(:disabled).buttons-module_tiktok__a80-0{background-color:#000}.buttons-module_link-button-default__EcKUT:not(:disabled).buttons-module_telegram__ExOTS{background-color:#08c}.buttons-module_link-button-default__EcKUT .buttons-module_button-container__-oPqd{align-items:center;display:flex;flex-direction:row;gap:.5rem;justify-content:center;padding:.5rem}.buttons-module_button-container__-oPqd .buttons-module_social-icon__DPdPe{align-items:center;color:#fff;display:flex;height:1.5rem;justify-content:center;width:1.5rem}.buttons-module_button-container__-oPqd .buttons-module_social-icon__DPdPe svg{fill:#fff!important;height:1.5rem;width:1.5rem}.buttons-module_button-container__-oPqd .buttons-module_social-icon__DPdPe svg path{fill:#fff!important}.buttons-module_button-container__-oPqd .buttons-module_link-icon__8V8FP{align-items:center;color:hsla(0,0%,100%,.8);display:flex;height:1.25rem;justify-content:center;width:1.25rem}.buttons-module_button-container__-oPqd .buttons-module_camp-logo__slNl0{align-items:center;background-color:#fff;border-radius:50%;box-sizing:border-box;display:flex;height:1.5rem;justify-content:center;padding:.15rem;width:1.5rem}.buttons-module_link-button-default__EcKUT:disabled .buttons-module_button-container__-oPqd .buttons-module_camp-logo__slNl0 svg path{fill:#b8b8b8!important}.buttons-module_link-button-icon__llX8m{background-color:#ff6f00;border:none;box-shadow:inset 0 2px 0 hsla(0,0%,100%,.15),inset 0 -2px 4px rgba(0,0,0,.05),0 1px 1px rgba(46,54,80,.075);box-sizing:border-box;cursor:pointer;height:3rem;min-height:3rem;min-width:3rem;padding:0;position:relative;width:3rem}.buttons-module_link-button-icon__llX8m:disabled{background-color:#b8b8b8;cursor:not-allowed}.buttons-module_link-button-icon__llX8m:disabled:after{background-color:rgba(0,0,0,.35);border-radius:.35rem;box-sizing:border-box;color:#fff;content:\"Not connected\";display:grid;font-size:.75rem;height:-moz-fit-content;height:fit-content;left:-1rem;opacity:0;padding:.25rem;place-items:center;position:absolute;right:-1rem;top:-2.7rem;transform:translateY(-.5rem);transition:all .25s}.buttons-module_link-button-icon__llX8m:disabled:hover:after{opacity:1;transform:translateY(0)}.buttons-module_link-button-icon__llX8m:after{background-color:transparent;border-radius:.75rem;bottom:0;content:\"\";left:0;position:absolute;right:0;top:0;transition:background-color .15s}.buttons-module_link-button-icon__llX8m:not(:disabled):hover:after{background-color:rgba(0,0,0,.1)}.buttons-module_link-button-icon__llX8m:not(:disabled).buttons-module_twitter__9sRaz{background-color:#1da1f2}.buttons-module_link-button-icon__llX8m:not(:disabled).buttons-module_spotify__-fiKQ{background-color:#1db954}.buttons-module_link-button-icon__llX8m:not(:disabled).buttons-module_discord__I-YjZ{background-color:#7289da}.buttons-module_link-button-icon__llX8m:not(:disabled).buttons-module_tiktok__a80-0{background-color:#000}.buttons-module_link-button-icon__llX8m:not(:disabled).buttons-module_telegram__ExOTS{background-color:#08c}.buttons-module_link-button-icon__llX8m .buttons-module_icon-container__Q5bI1{align-items:center;display:flex;flex:1;height:100%;justify-content:center;position:relative;width:100%}.buttons-module_link-button-icon__llX8m .buttons-module_icon-container__Q5bI1>svg{fill:#fff!important;height:1.5rem;width:1.5rem}.buttons-module_link-button-icon__llX8m .buttons-module_icon-container__Q5bI1>svg path{fill:#fff!important}.buttons-module_link-button-icon__llX8m .buttons-module_camp-logo__slNl0{align-items:center;background-color:#fff;border-radius:50%;bottom:-.5rem;box-sizing:border-box;display:flex;height:1.5rem;justify-content:center;position:absolute;right:-.5rem;width:1.5rem}.buttons-module_link-button-icon__llX8m .buttons-module_camp-logo__slNl0 svg{height:1.1rem;width:1.1rem}.buttons-module_link-button-icon__llX8m:disabled .buttons-module_camp-logo__slNl0 svg path,.buttons-module_not-linked__ua4va svg path{fill:#b8b8b8!important}.buttons-module_file-upload-container__le7Cg{align-items:center;border:2px dashed #ccc;box-sizing:border-box;color:#777;cursor:pointer;display:flex;flex-direction:column;justify-content:center;max-width:100%;min-height:12rem;min-width:0;overflow-y:auto;padding:1rem;position:relative;text-align:center;transition:background-color .2s,border-color .2s;width:100%}.buttons-module_file-upload-container__le7Cg:hover{border-color:#e2e2e2}.buttons-module_file-upload-container__le7Cg.buttons-module_dragging__cfggZ{background-color:#f9f9f9;border-color:#ff6f00}.buttons-module_file-upload-container__le7Cg.buttons-module_dragging__cfggZ .buttons-module_file-preview__yuM5i{opacity:.2;transition:opacity .2s}.buttons-module_file-upload-container__le7Cg.buttons-module_file-selected__YY6ms{background-color:#f9f9f9;border:none;padding:0 .5rem 0 0}.buttons-module_file-input__gbD5T{display:none}.buttons-module_selected-file-container__E1AXM{align-items:center;display:flex;flex-direction:column;gap:.25rem;height:100%;justify-content:space-between;max-width:100%;position:relative;width:100%}.buttons-module_remove-file-button__Q1FMa{border:1px solid #ff6f00;color:#fff;color:#ff6f00;cursor:pointer;font-size:.875rem;margin-bottom:.75rem;margin-top:1rem;padding:.5rem;text-align:center;transition:background-color .2s}.buttons-module_remove-file-button__Q1FMa:hover{background-color:#cc4e02;border-color:#cc4e02;color:#fff;cursor:pointer}.buttons-module_remove-file-button__Q1FMa:disabled{background-color:#b8b8b8;border-color:#b8b8b8;color:#fff;cursor:not-allowed}.buttons-module_upload-file-button__vTwWd{background-color:#ff6f00;border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-size:.875rem;padding:.5rem;text-align:center;transition:background-color .2s;width:100%}.buttons-module_upload-file-button__vTwWd:hover{background-color:#cc4e02;cursor:pointer}.buttons-module_upload-file-button__vTwWd:disabled{background-color:#b8b8b8;cursor:not-allowed}.buttons-module_file-preview__yuM5i{max-height:8rem;max-width:100%}audio.buttons-module_file-preview__yuM5i{min-height:4rem}.buttons-module_file-preview-text__80Ju0{color:#333;font-size:.875rem;margin-bottom:.5rem}.buttons-module_file-name__3iskR{color:#333;font-size:.875rem;max-width:100%;min-height:-moz-fit-content;min-height:fit-content;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.buttons-module_upload-buttons__3SAw6{align-items:center;display:flex;gap:.25rem;justify-content:space-between;width:100%}.buttons-module_upload-buttons__3SAw6 .buttons-module_upload-file-button__vTwWd{flex-grow:1}.buttons-module_upload-buttons__3SAw6 .buttons-module_remove-file-button__Q1FMa{flex-grow:0}.buttons-module_accepted-types__Ys-D2{color:#777;font-size:.875rem;font-style:italic;margin-top:.5rem}.buttons-module_loading-bar-container__nrgPX{background-color:#e0e0e0;margin-top:8px;min-height:8px;overflow:hidden;width:100%}.buttons-module_loading-bar__IUAg1{background-color:#ff6f00;min-height:100%;transition:width .3s ease}.buttons-module_date-picker__V6gRM{display:flex;flex-direction:column;font-family:sans-serif;gap:6px;width:100%}.buttons-module_date-picker__V6gRM input{border:1px solid #ccc;border-radius:4px;font-size:14px;padding:6px 10px}.buttons-module_percentage-slider__M84tC{display:flex;flex-direction:row;font-family:sans-serif;gap:8px;justify-content:space-between;width:100%}.buttons-module_percentage-slider__M84tC input[type=range]{width:100%}.buttons-module_percentage-slider__M84tC label{min-width:50px}.buttons-module_fancy-input-container__s-zVw{align-items:center;border:1px solid #ccc;display:flex;font-family:sans-serif;gap:0;min-height:2.5rem;overflow:hidden;position:relative;width:100%}.buttons-module_fancy-input-container__s-zVw textarea.buttons-module_fancy-input__RpSOF{background:transparent;border:none;box-sizing:border-box;color:#222;font-family:inherit;font-size:1rem;line-height:1.4;max-height:12rem;outline:none;overflow-y:auto;padding:10px;resize:none;width:100%}.buttons-module_fancy-input__RpSOF{background:transparent;border:none;flex:1;font-family:sans-serif;outline:none;padding:6px 10px}.buttons-module_fancy-input-label__d-sG7{align-self:flex-start;color:#777;font-family:Geist Mono,monospace;font-size:.8rem;font-weight:500;margin-top:.25rem;padding:0 .25rem;pointer-events:none;text-transform:uppercase}.buttons-module_input-divider__RVasJ{background-color:#ccc;height:24px;margin:0;min-width:1px}.buttons-module_input-icon-container__MUYKL{align-items:center;background-color:#f8f9fa;display:flex;justify-content:center;min-width:40px;padding:6px 10px}.buttons-module_input-icon-container__MUYKL svg{height:16px;width:16px}.buttons-module_duration-input-container__Rh9Na{align-items:stretch;border:1px solid #ccc;box-sizing:border-box;display:flex;font-family:sans-serif;gap:0;min-height:2.5rem;overflow:hidden;width:100%}.buttons-module_duration-input__-gt3p{background:transparent;flex:1;min-width:0}.buttons-module_duration-input__-gt3p,.buttons-module_duration-unit-select__VKFf6{border:none;box-sizing:border-box;font-family:sans-serif;outline:none;padding:6px 10px}.buttons-module_duration-unit-select__VKFf6{background-color:#f8f9fa;border-left:1px solid #ccc;cursor:pointer;flex:0 0 auto;width:auto}.buttons-module_price-input-container__teIRS:focus-within{border-color:#ff6f00;box-shadow:0 0 0 1px #ff6f00}.buttons-module_duration-input-container__Rh9Na:focus-within{border-color:#ff6f00;box-shadow:0 0 0 1px #ff6f00}.buttons-module_duration-input-container__Rh9Na:hover,.buttons-module_price-input-container__teIRS:hover{border-color:#999}.buttons-module_duration-unit-select__VKFf6:focus,.buttons-module_duration-unit-select__VKFf6:hover{background-color:#e9ecef}\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["buttons.module.css"],"names":[],"mappings":"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","file":"buttons.module.css","sourcesContent":[".button {\n  position: relative;\n  background-color: #ff6f00;\n  color: white;\n  border: none;\n  border-radius: 0;\n  padding: 1rem;\n  padding-block: 0;\n  font-size: 1rem;\n  width: 100%;\n  margin-bottom: 0.75rem;\n  margin-top: 1rem;\n  height: 2.5rem;\n  box-shadow: hsla(0, 0%, 100%, 0.15) 0 2px 0 inset,\n    rgba(0, 0, 0, 0.05) 0 -2px 4px inset, rgba(46, 54, 80, 0.075) 0 1px 1px;\n\n  font-family: \"Geist Mono\", monospace;\n  font-weight: 600;\n  text-transform: uppercase;\n  font-size: 0.875rem;\n}\n\n.button:hover {\n  background-color: #cc4e02;\n  cursor: pointer;\n}\n\n.button:disabled {\n  background-color: #ccc;\n  cursor: not-allowed;\n}\n\n.connect-button {\n  position: relative;\n  background-color: #ff6f00;\n  color: white;\n  border: none;\n  /* border-radius: 0.75rem; */\n  padding-inline: 2.5rem;\n  padding-left: 5rem;\n  height: 2.75rem;\n  line-height: 1.333rem;\n  font-size: 1rem;\n  font-weight: 600;\n  width: 13rem;\n  font-family: \"Geist Mono\", monospace;\n  text-transform: uppercase;\n  box-shadow: hsla(0, 0%, 100%, 0.15) 0 2px 0 inset,\n    rgba(0, 0, 0, 0.05) 0 -2px 4px inset, rgba(46, 54, 80, 0.075) 0 1px 1px;\n  transition: background-color 0.15s;\n}\n\n.connect-button .button-icon {\n  position: absolute;\n  top: 50%;\n  left: 0;\n  transform: translateY(-50%);\n  width: 3rem;\n  height: 100%;\n  margin-right: 0.5rem;\n  background: rgba(255, 255, 255, 0.75);\n  box-shadow: hsla(0, 0%, 100%, 0.15) 0 2px 0 inset,\n    rgba(0, 0, 0, 0.05) 0 -2px 4px inset;\n  display: grid;\n  place-items: center;\n  transition: background-color 0.15s;\n  /* border-radius: 0.75rem 0 0 0.75rem; */\n}\n\n.connect-button .button-icon svg {\n  width: 1.25rem;\n  height: 1.25rem;\n}\n\n.connect-button:hover {\n  background-color: #cc4e02;\n  cursor: pointer;\n  border-color: #cc4e02;\n}\n\n.connect-button:hover .button-icon {\n  background: rgba(255, 255, 255, 0.675);\n}\n\n.connect-button:focus {\n  outline: none;\n}\n\n.connect-button:disabled {\n  background-color: #ccc;\n  cursor: not-allowed;\n}\n\n.provider-button {\n  position: relative;\n  display: flex;\n  padding: 0.5rem;\n  border: 1px solid #ddd;\n  /* border-radius: 0.5rem; */\n  /* background-color: #fefefe; */\n  align-items: center;\n  justify-content: flex-start;\n  gap: 0.5rem;\n  width: 100%;\n  transition: border-color 0.15s;\n}\n\n.provider-button:focus {\n  outline: 1px solid #ff6f00;\n  outline-offset: 2px;\n}\n\n.provider-button:hover {\n  border-color: #ff6f00;\n  /* background-color: #eee; */\n}\n\n.provider-button:hover:not(:disabled) {\n  /* background-color: #ddd; */\n  cursor: pointer;\n}\n\n.provider-button img {\n  width: 2rem;\n  height: 2rem;\n}\n\n.provider-button .provider-icon {\n  border-radius: 0.2rem;\n}\n\n.provider-button span {\n  margin-left: 0.5rem;\n  line-height: 1rem;\n}\n\n.provider-button span.provider-name {\n  color: #333;\n  font-size: 0.875rem;\n}\n\n.provider-button span.provider-label {\n  color: #777;\n  font-size: 0.7rem;\n  font-family: \"Geist Mono\", monospace;\n  text-transform: uppercase;\n}\n\n/* \"default\" variant */\n.link-button-default {\n  position: relative;\n  box-sizing: border-box;\n  border: none;\n  width: 7rem;\n  height: 2.6rem;\n  background-color: #ff6f00;\n  /* border-radius: 0.75rem; */\n  box-shadow: hsla(0, 0%, 100%, 0.15) 0 2px 0 inset,\n    rgba(0, 0, 0, 0.05) 0 -2px 4px inset, rgba(46, 54, 80, 0.075) 0 1px 1px;\n  cursor: pointer;\n}\n\n.link-button-default:disabled {\n  background-color: #b8b8b8;\n  cursor: not-allowed;\n}\n\n.link-button-default::after {\n  content: \"\";\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  border-radius: 0.75rem;\n  background-color: rgba(0, 0, 0, 0);\n  transition: background-color 0.15s;\n}\n\n.link-button-default:disabled::after {\n  content: \"Not connected\";\n  visibility: hidden;\n  position: absolute;\n  top: -2.7rem;\n  left: 0;\n  right: 0;\n  height: 2rem;\n  border-radius: 0.35rem;\n  background-color: rgba(0, 0, 0, 0.35);\n  color: white;\n  display: grid;\n  place-items: center;\n  font-size: 0.75rem;\n  padding: 0.25rem;\n  opacity: 0;\n  transition: all 0.25s;\n  transform: translateY(-0.5rem);\n  user-select: none;\n}\n\n.link-button-default:disabled:hover::after {\n  visibility: visible;\n  opacity: 1;\n  transform: translateY(0);\n}\n\n.link-button-default:not(:disabled):hover::after {\n  background-color: rgba(0, 0, 0, 0.1);\n}\n\n.link-button-default:not(:disabled).twitter {\n  background-color: #1da1f2;\n}\n\n.link-button-default:not(:disabled).spotify {\n  background-color: #1db954;\n}\n\n.link-button-default:not(:disabled).discord {\n  background-color: #7289da;\n}\n\n.link-button-default:not(:disabled).tiktok {\n  background-color: #000000;\n}\n\n.link-button-default:not(:disabled).telegram {\n  background-color: #0088cc;\n}\n\n.link-button-default .button-container {\n  display: flex;\n  flex-direction: row;\n  gap: 0.5rem;\n  justify-content: center;\n  align-items: center;\n  padding: 0.5rem;\n}\n\n.button-container .social-icon {\n  display: flex;\n  width: 1.5rem;\n  height: 1.5rem;\n  align-items: center;\n  justify-content: center;\n  color: white;\n}\n\n.button-container .social-icon svg {\n  width: 1.5rem;\n  height: 1.5rem;\n  fill: white !important;\n}\n\n.button-container .social-icon svg path {\n  fill: white !important;\n}\n\n.button-container .link-icon {\n  display: flex;\n  width: 1.25rem;\n  height: 1.25rem;\n  align-items: center;\n  justify-content: center;\n  color: rgba(255, 255, 255, 0.8);\n}\n\n.button-container .camp-logo {\n  box-sizing: border-box;\n  display: flex;\n  width: 1.5rem;\n  height: 1.5rem;\n  align-items: center;\n  justify-content: center;\n  background-color: white;\n  border-radius: 50%;\n  padding: 0.15rem;\n}\n\n.link-button-default:disabled .button-container .camp-logo svg path {\n  fill: #b8b8b8 !important;\n}\n\n/* \"icon\" variant */\n.link-button-icon {\n  position: relative;\n  box-sizing: border-box;\n  min-width: 3rem;\n  min-height: 3rem;\n  width: 3rem;\n  height: 3rem;\n  border: none;\n  padding: 0rem;\n  background-color: #ff6f00;\n  /* border-radius: 0.75rem; */\n  box-shadow: hsla(0, 0%, 100%, 0.15) 0 2px 0 inset,\n    rgba(0, 0, 0, 0.05) 0 -2px 4px inset, rgba(46, 54, 80, 0.075) 0 1px 1px;\n  cursor: pointer;\n}\n\n.link-button-icon:disabled {\n  background-color: #b8b8b8;\n  cursor: not-allowed;\n}\n\n.link-button-icon:disabled::after {\n  box-sizing: border-box;\n  content: \"Not connected\";\n  position: absolute;\n  top: -2.7rem;\n  left: -1rem;\n  right: -1rem;\n  height: fit-content;\n  border-radius: 0.35rem;\n  background-color: rgba(0, 0, 0, 0.35);\n  color: white;\n  display: grid;\n  place-items: center;\n  font-size: 0.75rem;\n  padding: 0.25rem;\n  opacity: 0;\n  transition: all 0.25s;\n  transform: translateY(-0.5rem);\n}\n\n.link-button-icon:disabled:hover::after {\n  opacity: 1;\n  transform: translateY(0);\n}\n\n.link-button-icon::after {\n  content: \"\";\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  border-radius: 0.75rem;\n  background-color: rgba(0, 0, 0, 0);\n  transition: background-color 0.15s;\n}\n\n.link-button-icon:not(:disabled):hover::after {\n  background-color: rgba(0, 0, 0, 0.1);\n}\n\n.link-button-icon:not(:disabled).twitter {\n  background-color: #1da1f2;\n}\n\n.link-button-icon:not(:disabled).spotify {\n  background-color: #1db954;\n}\n\n.link-button-icon:not(:disabled).discord {\n  background-color: #7289da;\n}\n\n.link-button-icon:not(:disabled).tiktok {\n  background-color: #000000;\n}\n\n.link-button-icon:not(:disabled).telegram {\n  background-color: #0088cc;\n}\n\n.link-button-icon .icon-container {\n  position: relative;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  flex: 1;\n  align-items: center;\n  justify-content: center;\n}\n\n.link-button-icon .icon-container > svg {\n  width: 1.5rem;\n  height: 1.5rem;\n  fill: white !important;\n}\n\n.link-button-icon .icon-container > svg path {\n  fill: white !important;\n}\n\n.link-button-icon .camp-logo {\n  position: absolute;\n  box-sizing: border-box;\n  display: flex;\n  width: 1.5rem;\n  height: 1.5rem;\n  right: -0.5rem;\n  bottom: -0.5rem;\n  align-items: center;\n  justify-content: center;\n  background-color: white;\n  border-radius: 50%;\n}\n\n.link-button-icon .camp-logo svg {\n  width: 1.1rem;\n  height: 1.1rem;\n}\n\n.link-button-icon:disabled .camp-logo svg path {\n  fill: #b8b8b8 !important;\n}\n\n.not-linked svg path {\n  fill: #b8b8b8 !important;\n}\n\n.file-upload-container {\n  box-sizing: border-box;\n  border: 2px dashed #ccc;\n  /* border-radius: 0.75rem; */\n  padding: 1rem;\n  text-align: center;\n  color: #777;\n  cursor: pointer;\n  transition: background-color 0.2s, border-color 0.2s;\n  width: 100%;\n  min-width: 0;\n  max-width: 100%;\n  min-height: 12rem;\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  align-items: center;\n  position: relative;\n  overflow-y: auto;\n  /* height: 300px; */\n}\n\n.file-upload-container:hover {\n  border-color: #e2e2e2;\n}\n\n.file-upload-container.dragging {\n  background-color: #f9f9f9;\n  border-color: #ff6f00;\n}\n\n.file-upload-container.dragging .file-preview {\n  opacity: 0.2;\n  transition: opacity 0.2s;\n}\n\n.file-upload-container.file-selected {\n  background-color: #f9f9f9;\n  border: none;\n  padding: 0;\n  padding-right: 0.5rem;\n  /* height: auto; */\n  /* min-height: auto; */\n}\n\n.file-input {\n  display: none;\n}\n\n.selected-file-container {\n  width: 100%;\n  height: 100%;\n  display: flex;\n  max-width: 100%;\n  flex-direction: column;\n  justify-content: space-between;\n  align-items: center;\n  position: relative;\n  gap: 0.25rem;\n}\n\n.remove-file-button {\n  color: white;\n  border: 1px solid #ff6f00;\n  /* border-radius: 0.5rem; */\n  padding: 0.5rem;\n  font-size: 0.875rem;\n  cursor: pointer;\n  transition: background-color 0.2s;\n  text-align: center;\n  margin-bottom: 0.75rem;\n  margin-top: 1rem;\n  color: #ff6f00;\n}\n\n.remove-file-button:hover {\n  background-color: #cc4e02;\n  border-color: #cc4e02;\n  color: white;\n  cursor: pointer;\n}\n\n.remove-file-button:disabled {\n  background-color: #b8b8b8;\n  cursor: not-allowed;\n  border-color: #b8b8b8;\n  color: white;\n}\n\n.upload-file-button {\n  color: white;\n  background-color: #ff6f00;\n  border: none;\n  border-radius: 0.5rem;\n  padding: 0.5rem;\n  font-size: 0.875rem;\n  cursor: pointer;\n  transition: background-color 0.2s;\n  width: 100%;\n  text-align: center;\n}\n.upload-file-button:hover {\n  background-color: #cc4e02;\n  cursor: pointer;\n}\n.upload-file-button:disabled {\n  background-color: #b8b8b8;\n  cursor: not-allowed;\n}\n\n.file-preview {\n  max-width: 100%;\n  max-height: 8rem;\n}\naudio.file-preview {\n  min-height: 4rem;\n}\n\n.file-preview-text {\n  font-size: 0.875rem;\n  color: #333;\n  margin-bottom: 0.5rem;\n}\n\n.file-name {\n  font-size: 0.875rem;\n  color: #333;\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  min-height: fit-content;\n  max-width: 100%;\n}\n\n.upload-buttons {\n  display: flex;\n  gap: 0.25rem;\n  width: 100%;\n  justify-content: space-between;\n  align-items: center;\n}\n\n.upload-buttons .upload-file-button {\n  flex-grow: 1;\n}\n\n.upload-buttons .remove-file-button {\n  flex-grow: 0;\n}\n\n.accepted-types {\n  font-size: 0.875rem;\n  color: #777;\n  margin-top: 0.5rem;\n  font-style: italic;\n}\n\n.loading-bar-container {\n  width: 100%;\n  min-height: 8px;\n  background-color: #e0e0e0;\n  overflow: hidden;\n  margin-top: 8px;\n}\n\n.loading-bar {\n  min-height: 100%;\n  background-color: #ff6f00;\n  transition: width 0.3s ease;\n}\n\n.date-picker {\n  width: 100%;\n  display: flex;\n  flex-direction: column;\n  gap: 6px;\n  font-family: sans-serif;\n}\n\n.date-picker input {\n  padding: 6px 10px;\n  font-size: 14px;\n  border: 1px solid #ccc;\n  border-radius: 4px;\n}\n\n.percentage-slider {\n  width: 100%;\n  display: flex;\n  flex-direction: row;\n  gap: 8px;\n  font-family: sans-serif;\n  justify-content: space-between;\n}\n\n.percentage-slider input[type=\"range\"] {\n  width: 100%;\n}\n\n.percentage-slider label {\n  min-width: 50px;\n}\n\n.fancy-input-container {\n  min-height: 2.5rem;\n  width: 100%;\n  display: flex;\n  align-items: center;\n  position: relative;\n  gap: 0;\n  font-family: sans-serif;\n  border: 1px solid #ccc;\n  overflow: hidden;\n}\n\n.fancy-input-container textarea.fancy-input {\n  resize: none;\n  max-height: 12rem;\n  width: 100%;\n  font-family: inherit;\n  padding: 10px;\n  border: none;\n  outline: none;\n  background: transparent;\n  font-size: 1rem;\n  color: #222;\n  box-sizing: border-box;\n  line-height: 1.4;\n  overflow-y: auto;\n}\n\n.fancy-input {\n  font-family: sans-serif;\n  padding: 6px 10px;\n  border: none;\n  outline: none;\n  flex: 1;\n  background: transparent;\n}\n\n.fancy-input-label {\n  font-size: 0.8rem;\n  color: #777;\n  align-self: flex-start;\n  padding: 0 0.25rem;\n  /* z-index: 2; */\n  pointer-events: none;\n  font-family: \"Geist Mono\", monospace;\n  font-weight: 500;\n  text-transform: uppercase;\n  margin-top: 0.25rem;\n}\n\n.input-divider {\n  min-width: 1px;\n  height: 24px;\n  background-color: #ccc;\n  margin: 0;\n}\n\n.input-icon-container {\n  padding: 6px 10px;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background-color: #f8f9fa;\n  min-width: 40px;\n}\n\n.input-icon-container svg {\n  width: 16px;\n  height: 16px;\n}\n\n.duration-input-container {\n  min-height: 2.5rem;\n  width: 100%;\n  display: flex;\n  align-items: stretch;\n  gap: 0;\n  font-family: sans-serif;\n  border: 1px solid #ccc;\n  /* border-radius: 4px; */\n  overflow: hidden;\n  box-sizing: border-box;\n}\n\n.duration-input {\n  font-family: sans-serif;\n  padding: 6px 10px;\n  border: none;\n  outline: none;\n  flex: 1;\n  background: transparent;\n  box-sizing: border-box;\n  min-width: 0;\n}\n\n.duration-unit-select {\n  font-family: sans-serif;\n  padding: 6px 10px;\n  border: none;\n  outline: none;\n  background-color: #f8f9fa;\n  border-left: 1px solid #ccc;\n  cursor: pointer;\n  flex: 0 0 auto;\n  width: auto;\n  box-sizing: border-box;\n}\n\n.price-input-container:focus-within {\n  border-color: #ff6f00;\n  box-shadow: 0 0 0 1px #ff6f00;\n}\n\n.duration-input-container:focus-within {\n  border-color: #ff6f00;\n  box-shadow: 0 0 0 1px #ff6f00;\n}\n\n.price-input-container:hover,\n.duration-input-container:hover {\n  border-color: #999;\n}\n\n.duration-unit-select:hover {\n  background-color: #e9ecef;\n}\n\n.duration-unit-select:focus {\n  background-color: #e9ecef;\n}\n"]} */";
5424
5718
  var buttonStyles = {"button":"buttons-module_button__4Ogad","connect-button":"buttons-module_connect-button__CJhUa","button-icon":"buttons-module_button-icon__JM4-2","provider-button":"buttons-module_provider-button__6JY7s","provider-icon":"buttons-module_provider-icon__MOhr8","provider-name":"buttons-module_provider-name__tHWO2","provider-label":"buttons-module_provider-label__CEGRr","link-button-default":"buttons-module_link-button-default__EcKUT","twitter":"buttons-module_twitter__9sRaz","spotify":"buttons-module_spotify__-fiKQ","discord":"buttons-module_discord__I-YjZ","tiktok":"buttons-module_tiktok__a80-0","telegram":"buttons-module_telegram__ExOTS","button-container":"buttons-module_button-container__-oPqd","social-icon":"buttons-module_social-icon__DPdPe","link-icon":"buttons-module_link-icon__8V8FP","camp-logo":"buttons-module_camp-logo__slNl0","link-button-icon":"buttons-module_link-button-icon__llX8m","icon-container":"buttons-module_icon-container__Q5bI1","not-linked":"buttons-module_not-linked__ua4va","file-upload-container":"buttons-module_file-upload-container__le7Cg","dragging":"buttons-module_dragging__cfggZ","file-preview":"buttons-module_file-preview__yuM5i","file-selected":"buttons-module_file-selected__YY6ms","file-input":"buttons-module_file-input__gbD5T","selected-file-container":"buttons-module_selected-file-container__E1AXM","remove-file-button":"buttons-module_remove-file-button__Q1FMa","upload-file-button":"buttons-module_upload-file-button__vTwWd","file-preview-text":"buttons-module_file-preview-text__80Ju0","file-name":"buttons-module_file-name__3iskR","upload-buttons":"buttons-module_upload-buttons__3SAw6","accepted-types":"buttons-module_accepted-types__Ys-D2","loading-bar-container":"buttons-module_loading-bar-container__nrgPX","loading-bar":"buttons-module_loading-bar__IUAg1","date-picker":"buttons-module_date-picker__V6gRM","percentage-slider":"buttons-module_percentage-slider__M84tC","fancy-input-container":"buttons-module_fancy-input-container__s-zVw","fancy-input":"buttons-module_fancy-input__RpSOF","fancy-input-label":"buttons-module_fancy-input-label__d-sG7","input-divider":"buttons-module_input-divider__RVasJ","input-icon-container":"buttons-module_input-icon-container__MUYKL","duration-input-container":"buttons-module_duration-input-container__Rh9Na","duration-input":"buttons-module_duration-input__-gt3p","duration-unit-select":"buttons-module_duration-unit-select__VKFf6","price-input-container":"buttons-module_price-input-container__teIRS"};
5425
5719
  styleInject(css_248z);