@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.
- package/README.md +231 -4
- package/dist/core.cjs +164 -86
- package/dist/core.d.ts +170 -6
- package/dist/core.esm.d.ts +170 -6
- package/dist/core.esm.js +173 -86
- package/dist/react/index.esm.d.ts +39 -4
- package/dist/react/index.esm.js +366 -72
- package/package.json +16 -1
package/dist/react/index.esm.js
CHANGED
|
@@ -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
|
-
|
|
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
|
-
|
|
4210
|
-
|
|
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
|
-
|
|
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
|
|
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
|
-
|
|
4394
|
-
|
|
4395
|
-
|
|
4396
|
-
|
|
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
|
-
|
|
4425
|
-
|
|
4426
|
-
|
|
4427
|
-
|
|
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
|
-
|
|
4792
|
-
|
|
4793
|
-
|
|
4794
|
-
const
|
|
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:
|
|
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:
|
|
5223
|
+
uri: uri ||
|
|
5224
|
+
(__classPrivateFieldGet(this, _Auth_isNodeEnvironment, "f") ? "http://localhost" : window.location.origin),
|
|
4891
5225
|
version: "1",
|
|
4892
|
-
chainId: this.
|
|
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);
|