@thenamespace/ens-components 0.5.0 → 0.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.css +1792 -1
- package/dist/index.css.map +1 -1
- package/dist/index.d.ts +7168 -290
- package/dist/index.js +1732 -48
- package/dist/index.js.map +1 -1
- package/dist/styles.js +1 -1
- package/dist/types/components/atoms/icon/custom/SearchIcon.d.ts +6 -0
- package/dist/types/components/ens-names-register-component/ENSNamesRegisterComponent.d.ts +17 -0
- package/dist/types/components/ens-names-register-component/sub-components/CostSummary.d.ts +10 -0
- package/dist/types/components/ens-names-register-component/sub-components/Header.d.ts +7 -0
- package/dist/types/components/ens-names-register-component/sub-components/NameSearch.d.ts +9 -0
- package/dist/types/components/ens-names-register-component/sub-components/ProgressBar.d.ts +5 -0
- package/dist/types/components/ens-names-register-component/sub-components/RegistrationForm.d.ts +15 -0
- package/dist/types/components/ens-names-register-component/sub-components/RegistrationProcess.d.ts +17 -0
- package/dist/types/components/ens-names-register-component/sub-components/StepItem.d.ts +11 -0
- package/dist/types/components/ens-names-register-component/sub-components/SuccessScreen.d.ts +13 -0
- package/dist/types/components/ens-names-register-component/sub-components/Timer.d.ts +6 -0
- package/dist/types/components/ens-offchain-register-modal/EnsOffChainRegisterModal.d.ts +18 -0
- package/dist/types/components/ens-offchain-register-modal/sub-components/InitialStep.d.ts +9 -0
- package/dist/types/components/ens-offchain-register-modal/sub-components/OffchainRegistrationProcess.d.ts +18 -0
- package/dist/types/components/ens-offchain-register-modal/sub-components/OffchainSuccessScreen.d.ts +8 -0
- package/dist/types/components/ens-onchain-register-modal/EnsOnChainRegisterModal.d.ts +30 -0
- package/dist/types/components/ens-onchain-register-modal/sub-components/ConfirmationStep.d.ts +18 -0
- package/dist/types/components/ens-onchain-register-modal/sub-components/InitialStep.d.ts +10 -0
- package/dist/types/components/ens-onchain-register-modal/sub-components/OnchainSuccessScreen.d.ts +6 -0
- package/dist/types/components/ens-onchain-register-modal/sub-components/RegistrationStep.d.ts +22 -0
- package/dist/types/components/index.d.ts +3 -0
- package/dist/types/hooks/useWeb3Clients.d.ts +4 -4
- package/package.json +2 -1
package/dist/index.js
CHANGED
|
@@ -264,7 +264,7 @@ const createLucideIcon = (iconName, iconNode) => {
|
|
|
264
264
|
*/
|
|
265
265
|
|
|
266
266
|
|
|
267
|
-
const __iconNode$
|
|
267
|
+
const __iconNode$r = [
|
|
268
268
|
[
|
|
269
269
|
"path",
|
|
270
270
|
{
|
|
@@ -273,7 +273,7 @@ const __iconNode$l = [
|
|
|
273
273
|
}
|
|
274
274
|
]
|
|
275
275
|
];
|
|
276
|
-
const Book = createLucideIcon("book", __iconNode$
|
|
276
|
+
const Book = createLucideIcon("book", __iconNode$r);
|
|
277
277
|
|
|
278
278
|
/**
|
|
279
279
|
* @license lucide-react v0.542.0 - ISC
|
|
@@ -283,7 +283,7 @@ const Book = createLucideIcon("book", __iconNode$l);
|
|
|
283
283
|
*/
|
|
284
284
|
|
|
285
285
|
|
|
286
|
-
const __iconNode$
|
|
286
|
+
const __iconNode$q = [
|
|
287
287
|
[
|
|
288
288
|
"path",
|
|
289
289
|
{
|
|
@@ -294,7 +294,7 @@ const __iconNode$k = [
|
|
|
294
294
|
["path", { d: "m3.3 7 8.7 5 8.7-5", key: "g66t2b" }],
|
|
295
295
|
["path", { d: "M12 22V12", key: "d0xqtd" }]
|
|
296
296
|
];
|
|
297
|
-
const Box = createLucideIcon("box", __iconNode$
|
|
297
|
+
const Box = createLucideIcon("box", __iconNode$q);
|
|
298
298
|
|
|
299
299
|
/**
|
|
300
300
|
* @license lucide-react v0.542.0 - ISC
|
|
@@ -304,12 +304,67 @@ const Box = createLucideIcon("box", __iconNode$k);
|
|
|
304
304
|
*/
|
|
305
305
|
|
|
306
306
|
|
|
307
|
-
const __iconNode$
|
|
307
|
+
const __iconNode$p = [["path", { d: "M20 6 9 17l-5-5", key: "1gmf2c" }]];
|
|
308
|
+
const Check = createLucideIcon("check", __iconNode$p);
|
|
309
|
+
|
|
310
|
+
/**
|
|
311
|
+
* @license lucide-react v0.542.0 - ISC
|
|
312
|
+
*
|
|
313
|
+
* This source code is licensed under the ISC license.
|
|
314
|
+
* See the LICENSE file in the root directory of this source tree.
|
|
315
|
+
*/
|
|
316
|
+
|
|
317
|
+
|
|
318
|
+
const __iconNode$o = [["path", { d: "m6 9 6 6 6-6", key: "qrunsl" }]];
|
|
319
|
+
const ChevronDown = createLucideIcon("chevron-down", __iconNode$o);
|
|
320
|
+
|
|
321
|
+
/**
|
|
322
|
+
* @license lucide-react v0.542.0 - ISC
|
|
323
|
+
*
|
|
324
|
+
* This source code is licensed under the ISC license.
|
|
325
|
+
* See the LICENSE file in the root directory of this source tree.
|
|
326
|
+
*/
|
|
327
|
+
|
|
328
|
+
|
|
329
|
+
const __iconNode$n = [["path", { d: "m15 18-6-6 6-6", key: "1wnfg3" }]];
|
|
330
|
+
const ChevronLeft = createLucideIcon("chevron-left", __iconNode$n);
|
|
331
|
+
|
|
332
|
+
/**
|
|
333
|
+
* @license lucide-react v0.542.0 - ISC
|
|
334
|
+
*
|
|
335
|
+
* This source code is licensed under the ISC license.
|
|
336
|
+
* See the LICENSE file in the root directory of this source tree.
|
|
337
|
+
*/
|
|
338
|
+
|
|
339
|
+
|
|
340
|
+
const __iconNode$m = [["path", { d: "m9 18 6-6-6-6", key: "mthhwq" }]];
|
|
341
|
+
const ChevronRight = createLucideIcon("chevron-right", __iconNode$m);
|
|
342
|
+
|
|
343
|
+
/**
|
|
344
|
+
* @license lucide-react v0.542.0 - ISC
|
|
345
|
+
*
|
|
346
|
+
* This source code is licensed under the ISC license.
|
|
347
|
+
* See the LICENSE file in the root directory of this source tree.
|
|
348
|
+
*/
|
|
349
|
+
|
|
350
|
+
|
|
351
|
+
const __iconNode$l = [["path", { d: "m18 15-6-6-6 6", key: "153udz" }]];
|
|
352
|
+
const ChevronUp = createLucideIcon("chevron-up", __iconNode$l);
|
|
353
|
+
|
|
354
|
+
/**
|
|
355
|
+
* @license lucide-react v0.542.0 - ISC
|
|
356
|
+
*
|
|
357
|
+
* This source code is licensed under the ISC license.
|
|
358
|
+
* See the LICENSE file in the root directory of this source tree.
|
|
359
|
+
*/
|
|
360
|
+
|
|
361
|
+
|
|
362
|
+
const __iconNode$k = [
|
|
308
363
|
["circle", { cx: "12", cy: "12", r: "10", key: "1mglay" }],
|
|
309
364
|
["line", { x1: "12", x2: "12", y1: "8", y2: "12", key: "1pkeuh" }],
|
|
310
365
|
["line", { x1: "12", x2: "12.01", y1: "16", y2: "16", key: "4dfq90" }]
|
|
311
366
|
];
|
|
312
|
-
const CircleAlert = createLucideIcon("circle-alert", __iconNode$
|
|
367
|
+
const CircleAlert = createLucideIcon("circle-alert", __iconNode$k);
|
|
313
368
|
|
|
314
369
|
/**
|
|
315
370
|
* @license lucide-react v0.542.0 - ISC
|
|
@@ -319,11 +374,11 @@ const CircleAlert = createLucideIcon("circle-alert", __iconNode$j);
|
|
|
319
374
|
*/
|
|
320
375
|
|
|
321
376
|
|
|
322
|
-
const __iconNode$
|
|
377
|
+
const __iconNode$j = [
|
|
323
378
|
["path", { d: "M21.801 10A10 10 0 1 1 17 3.335", key: "yps3ct" }],
|
|
324
379
|
["path", { d: "m9 11 3 3L22 4", key: "1pflzl" }]
|
|
325
380
|
];
|
|
326
|
-
const CircleCheckBig = createLucideIcon("circle-check-big", __iconNode$
|
|
381
|
+
const CircleCheckBig = createLucideIcon("circle-check-big", __iconNode$j);
|
|
327
382
|
|
|
328
383
|
/**
|
|
329
384
|
* @license lucide-react v0.542.0 - ISC
|
|
@@ -333,7 +388,7 @@ const CircleCheckBig = createLucideIcon("circle-check-big", __iconNode$i);
|
|
|
333
388
|
*/
|
|
334
389
|
|
|
335
390
|
|
|
336
|
-
const __iconNode$
|
|
391
|
+
const __iconNode$i = [
|
|
337
392
|
["path", { d: "M12 2a10 10 0 0 1 7.38 16.75", key: "175t95" }],
|
|
338
393
|
["path", { d: "M12 8v8", key: "napkw2" }],
|
|
339
394
|
["path", { d: "M16 12H8", key: "1fr5h0" }],
|
|
@@ -342,7 +397,7 @@ const __iconNode$h = [
|
|
|
342
397
|
["path", { d: "M4.636 5.235a10 10 0 0 1 .891-.857", key: "1szpfk" }],
|
|
343
398
|
["path", { d: "M8.644 21.42a10 10 0 0 0 7.631-.38", key: "9yhvd4" }]
|
|
344
399
|
];
|
|
345
|
-
const CircleFadingPlus = createLucideIcon("circle-fading-plus", __iconNode$
|
|
400
|
+
const CircleFadingPlus = createLucideIcon("circle-fading-plus", __iconNode$i);
|
|
346
401
|
|
|
347
402
|
/**
|
|
348
403
|
* @license lucide-react v0.542.0 - ISC
|
|
@@ -352,12 +407,12 @@ const CircleFadingPlus = createLucideIcon("circle-fading-plus", __iconNode$h);
|
|
|
352
407
|
*/
|
|
353
408
|
|
|
354
409
|
|
|
355
|
-
const __iconNode$
|
|
410
|
+
const __iconNode$h = [
|
|
356
411
|
["circle", { cx: "12", cy: "12", r: "10", key: "1mglay" }],
|
|
357
412
|
["circle", { cx: "12", cy: "10", r: "3", key: "ilqhr7" }],
|
|
358
413
|
["path", { d: "M7 20.662V19a2 2 0 0 1 2-2h6a2 2 0 0 1 2 2v1.662", key: "154egf" }]
|
|
359
414
|
];
|
|
360
|
-
const CircleUser = createLucideIcon("circle-user", __iconNode$
|
|
415
|
+
const CircleUser = createLucideIcon("circle-user", __iconNode$h);
|
|
361
416
|
|
|
362
417
|
/**
|
|
363
418
|
* @license lucide-react v0.542.0 - ISC
|
|
@@ -367,12 +422,12 @@ const CircleUser = createLucideIcon("circle-user", __iconNode$g);
|
|
|
367
422
|
*/
|
|
368
423
|
|
|
369
424
|
|
|
370
|
-
const __iconNode$
|
|
425
|
+
const __iconNode$g = [
|
|
371
426
|
["circle", { cx: "12", cy: "12", r: "10", key: "1mglay" }],
|
|
372
427
|
["path", { d: "m15 9-6 6", key: "1uzhvr" }],
|
|
373
428
|
["path", { d: "m9 9 6 6", key: "z0biqf" }]
|
|
374
429
|
];
|
|
375
|
-
const CircleX = createLucideIcon("circle-x", __iconNode$
|
|
430
|
+
const CircleX = createLucideIcon("circle-x", __iconNode$g);
|
|
376
431
|
|
|
377
432
|
/**
|
|
378
433
|
* @license lucide-react v0.542.0 - ISC
|
|
@@ -382,11 +437,11 @@ const CircleX = createLucideIcon("circle-x", __iconNode$f);
|
|
|
382
437
|
*/
|
|
383
438
|
|
|
384
439
|
|
|
385
|
-
const __iconNode$
|
|
440
|
+
const __iconNode$f = [
|
|
386
441
|
["path", { d: "M12 6v6l4 2", key: "mmk7yg" }],
|
|
387
442
|
["circle", { cx: "12", cy: "12", r: "10", key: "1mglay" }]
|
|
388
443
|
];
|
|
389
|
-
const Clock = createLucideIcon("clock", __iconNode$
|
|
444
|
+
const Clock = createLucideIcon("clock", __iconNode$f);
|
|
390
445
|
|
|
391
446
|
/**
|
|
392
447
|
* @license lucide-react v0.542.0 - ISC
|
|
@@ -396,11 +451,11 @@ const Clock = createLucideIcon("clock", __iconNode$e);
|
|
|
396
451
|
*/
|
|
397
452
|
|
|
398
453
|
|
|
399
|
-
const __iconNode$
|
|
454
|
+
const __iconNode$e = [
|
|
400
455
|
["rect", { width: "14", height: "14", x: "8", y: "8", rx: "2", ry: "2", key: "17jyea" }],
|
|
401
456
|
["path", { d: "M4 16c-1.1 0-2-.9-2-2V4c0-1.1.9-2 2-2h10c1.1 0 2 .9 2 2", key: "zix9uf" }]
|
|
402
457
|
];
|
|
403
|
-
const Copy = createLucideIcon("copy", __iconNode$
|
|
458
|
+
const Copy = createLucideIcon("copy", __iconNode$e);
|
|
404
459
|
|
|
405
460
|
/**
|
|
406
461
|
* @license lucide-react v0.542.0 - ISC
|
|
@@ -410,12 +465,12 @@ const Copy = createLucideIcon("copy", __iconNode$d);
|
|
|
410
465
|
*/
|
|
411
466
|
|
|
412
467
|
|
|
413
|
-
const __iconNode$
|
|
468
|
+
const __iconNode$d = [
|
|
414
469
|
["circle", { cx: "12", cy: "12", r: "10", key: "1mglay" }],
|
|
415
470
|
["path", { d: "M12 2a14.5 14.5 0 0 0 0 20 14.5 14.5 0 0 0 0-20", key: "13o1zl" }],
|
|
416
471
|
["path", { d: "M2 12h20", key: "9i4pu4" }]
|
|
417
472
|
];
|
|
418
|
-
const Globe = createLucideIcon("globe", __iconNode$
|
|
473
|
+
const Globe = createLucideIcon("globe", __iconNode$d);
|
|
419
474
|
|
|
420
475
|
/**
|
|
421
476
|
* @license lucide-react v0.542.0 - ISC
|
|
@@ -425,12 +480,12 @@ const Globe = createLucideIcon("globe", __iconNode$c);
|
|
|
425
480
|
*/
|
|
426
481
|
|
|
427
482
|
|
|
428
|
-
const __iconNode$
|
|
483
|
+
const __iconNode$c = [
|
|
429
484
|
["rect", { width: "18", height: "18", x: "3", y: "3", rx: "2", ry: "2", key: "1m3agn" }],
|
|
430
485
|
["circle", { cx: "9", cy: "9", r: "2", key: "af1f0g" }],
|
|
431
486
|
["path", { d: "m21 15-3.086-3.086a2 2 0 0 0-2.828 0L6 21", key: "1xmnt7" }]
|
|
432
487
|
];
|
|
433
|
-
const Image = createLucideIcon("image", __iconNode$
|
|
488
|
+
const Image = createLucideIcon("image", __iconNode$c);
|
|
434
489
|
|
|
435
490
|
/**
|
|
436
491
|
* @license lucide-react v0.542.0 - ISC
|
|
@@ -440,12 +495,12 @@ const Image = createLucideIcon("image", __iconNode$b);
|
|
|
440
495
|
*/
|
|
441
496
|
|
|
442
497
|
|
|
443
|
-
const __iconNode$
|
|
498
|
+
const __iconNode$b = [
|
|
444
499
|
["circle", { cx: "12", cy: "12", r: "10", key: "1mglay" }],
|
|
445
500
|
["path", { d: "M12 16v-4", key: "1dtifu" }],
|
|
446
501
|
["path", { d: "M12 8h.01", key: "e9boi3" }]
|
|
447
502
|
];
|
|
448
|
-
const Info = createLucideIcon("info", __iconNode$
|
|
503
|
+
const Info = createLucideIcon("info", __iconNode$b);
|
|
449
504
|
|
|
450
505
|
/**
|
|
451
506
|
* @license lucide-react v0.542.0 - ISC
|
|
@@ -455,12 +510,12 @@ const Info = createLucideIcon("info", __iconNode$a);
|
|
|
455
510
|
*/
|
|
456
511
|
|
|
457
512
|
|
|
458
|
-
const __iconNode$
|
|
513
|
+
const __iconNode$a = [
|
|
459
514
|
["path", { d: "m16 17 5-5-5-5", key: "1bji2h" }],
|
|
460
515
|
["path", { d: "M21 12H9", key: "dn1m92" }],
|
|
461
516
|
["path", { d: "M9 21H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h4", key: "1uf3rs" }]
|
|
462
517
|
];
|
|
463
|
-
const LogOut = createLucideIcon("log-out", __iconNode$
|
|
518
|
+
const LogOut = createLucideIcon("log-out", __iconNode$a);
|
|
464
519
|
|
|
465
520
|
/**
|
|
466
521
|
* @license lucide-react v0.542.0 - ISC
|
|
@@ -470,11 +525,11 @@ const LogOut = createLucideIcon("log-out", __iconNode$9);
|
|
|
470
525
|
*/
|
|
471
526
|
|
|
472
527
|
|
|
473
|
-
const __iconNode$
|
|
528
|
+
const __iconNode$9 = [
|
|
474
529
|
["path", { d: "m22 7-8.991 5.727a2 2 0 0 1-2.009 0L2 7", key: "132q7q" }],
|
|
475
530
|
["rect", { x: "2", y: "4", width: "20", height: "16", rx: "2", key: "izxlao" }]
|
|
476
531
|
];
|
|
477
|
-
const Mail = createLucideIcon("mail", __iconNode$
|
|
532
|
+
const Mail = createLucideIcon("mail", __iconNode$9);
|
|
478
533
|
|
|
479
534
|
/**
|
|
480
535
|
* @license lucide-react v0.542.0 - ISC
|
|
@@ -484,7 +539,7 @@ const Mail = createLucideIcon("mail", __iconNode$8);
|
|
|
484
539
|
*/
|
|
485
540
|
|
|
486
541
|
|
|
487
|
-
const __iconNode$
|
|
542
|
+
const __iconNode$8 = [
|
|
488
543
|
[
|
|
489
544
|
"path",
|
|
490
545
|
{
|
|
@@ -494,7 +549,7 @@ const __iconNode$7 = [
|
|
|
494
549
|
],
|
|
495
550
|
["circle", { cx: "12", cy: "10", r: "3", key: "ilqhr7" }]
|
|
496
551
|
];
|
|
497
|
-
const MapPin = createLucideIcon("map-pin", __iconNode$
|
|
552
|
+
const MapPin = createLucideIcon("map-pin", __iconNode$8);
|
|
498
553
|
|
|
499
554
|
/**
|
|
500
555
|
* @license lucide-react v0.542.0 - ISC
|
|
@@ -504,7 +559,7 @@ const MapPin = createLucideIcon("map-pin", __iconNode$7);
|
|
|
504
559
|
*/
|
|
505
560
|
|
|
506
561
|
|
|
507
|
-
const __iconNode$
|
|
562
|
+
const __iconNode$7 = [
|
|
508
563
|
["path", { d: "M12 17v5", key: "bb1du9" }],
|
|
509
564
|
[
|
|
510
565
|
"path",
|
|
@@ -514,7 +569,7 @@ const __iconNode$6 = [
|
|
|
514
569
|
}
|
|
515
570
|
]
|
|
516
571
|
];
|
|
517
|
-
const Pin = createLucideIcon("pin", __iconNode$
|
|
572
|
+
const Pin = createLucideIcon("pin", __iconNode$7);
|
|
518
573
|
|
|
519
574
|
/**
|
|
520
575
|
* @license lucide-react v0.542.0 - ISC
|
|
@@ -524,11 +579,33 @@ const Pin = createLucideIcon("pin", __iconNode$6);
|
|
|
524
579
|
*/
|
|
525
580
|
|
|
526
581
|
|
|
527
|
-
const __iconNode$
|
|
582
|
+
const __iconNode$6 = [
|
|
528
583
|
["path", { d: "m21 21-4.34-4.34", key: "14j7rj" }],
|
|
529
584
|
["circle", { cx: "11", cy: "11", r: "8", key: "4ej97u" }]
|
|
530
585
|
];
|
|
531
|
-
const Search = createLucideIcon("search", __iconNode$
|
|
586
|
+
const Search = createLucideIcon("search", __iconNode$6);
|
|
587
|
+
|
|
588
|
+
/**
|
|
589
|
+
* @license lucide-react v0.542.0 - ISC
|
|
590
|
+
*
|
|
591
|
+
* This source code is licensed under the ISC license.
|
|
592
|
+
* See the LICENSE file in the root directory of this source tree.
|
|
593
|
+
*/
|
|
594
|
+
|
|
595
|
+
|
|
596
|
+
const __iconNode$5 = [
|
|
597
|
+
[
|
|
598
|
+
"path",
|
|
599
|
+
{
|
|
600
|
+
d: "M11.017 2.814a1 1 0 0 1 1.966 0l1.051 5.558a2 2 0 0 0 1.594 1.594l5.558 1.051a1 1 0 0 1 0 1.966l-5.558 1.051a2 2 0 0 0-1.594 1.594l-1.051 5.558a1 1 0 0 1-1.966 0l-1.051-5.558a2 2 0 0 0-1.594-1.594l-5.558-1.051a1 1 0 0 1 0-1.966l5.558-1.051a2 2 0 0 0 1.594-1.594z",
|
|
601
|
+
key: "1s2grr"
|
|
602
|
+
}
|
|
603
|
+
],
|
|
604
|
+
["path", { d: "M20 2v4", key: "1rf3ol" }],
|
|
605
|
+
["path", { d: "M22 4h-4", key: "gwowj6" }],
|
|
606
|
+
["circle", { cx: "4", cy: "20", r: "2", key: "6kqj1y" }]
|
|
607
|
+
];
|
|
608
|
+
const Sparkles = createLucideIcon("sparkles", __iconNode$5);
|
|
532
609
|
|
|
533
610
|
/**
|
|
534
611
|
* @license lucide-react v0.542.0 - ISC
|
|
@@ -1175,7 +1252,9 @@ const Tooltip = ({
|
|
|
1175
1252
|
const [tooltipPosition, setTooltipPosition] = useState({ top: 0, left: 0 });
|
|
1176
1253
|
const triggerRef = useRef(null);
|
|
1177
1254
|
const tooltipRef = useRef(null);
|
|
1178
|
-
const timeoutRef = useRef(
|
|
1255
|
+
const timeoutRef = useRef(
|
|
1256
|
+
void 0
|
|
1257
|
+
);
|
|
1179
1258
|
const showTooltip = () => {
|
|
1180
1259
|
if (disabled) return;
|
|
1181
1260
|
if (timeoutRef.current) {
|
|
@@ -12194,7 +12273,10 @@ const ContenthashRecord = ({
|
|
|
12194
12273
|
if (e.key === "Backspace" && cursorPosition > 0) {
|
|
12195
12274
|
e.preventDefault();
|
|
12196
12275
|
setTimeout(() => {
|
|
12197
|
-
input.setSelectionRange(
|
|
12276
|
+
input.setSelectionRange(
|
|
12277
|
+
protocolPrefix.length,
|
|
12278
|
+
protocolPrefix.length
|
|
12279
|
+
);
|
|
12198
12280
|
}, 0);
|
|
12199
12281
|
} else if (e.key === "Delete" && cursorPosition < protocolPrefix.length) {
|
|
12200
12282
|
e.preventDefault();
|
|
@@ -12203,7 +12285,10 @@ const ContenthashRecord = ({
|
|
|
12203
12285
|
},
|
|
12204
12286
|
error: contenthash.value.length > 0 && !isContenthashValid(contenthash.protocol, contenthash.value),
|
|
12205
12287
|
prefix: /* @__PURE__ */ jsx(ContenthashIcon, { protocol: contenthash.protocol, size: 18 }),
|
|
12206
|
-
value: prefixWithProtocol(
|
|
12288
|
+
value: prefixWithProtocol(
|
|
12289
|
+
contenthash.value,
|
|
12290
|
+
contenthash.protocol
|
|
12291
|
+
),
|
|
12207
12292
|
placeholder: `${contenthash.protocol}://`
|
|
12208
12293
|
}
|
|
12209
12294
|
),
|
|
@@ -12251,18 +12336,34 @@ const ImageRecords = ({
|
|
|
12251
12336
|
return /* @__PURE__ */ jsx("div", { className: "ns-image-records", children: /* @__PURE__ */ jsxs("div", { style: headerStyles, className: "ns-cover-record-cont", children: [
|
|
12252
12337
|
/* @__PURE__ */ jsx("div", { className: "ns-top-grad" }),
|
|
12253
12338
|
/* @__PURE__ */ jsx("div", { className: "ns-bot-grad" }),
|
|
12254
|
-
!headerRecordSet && /* @__PURE__ */ jsx(
|
|
12255
|
-
|
|
12256
|
-
|
|
12257
|
-
|
|
12339
|
+
!headerRecordSet && /* @__PURE__ */ jsx(
|
|
12340
|
+
"div",
|
|
12341
|
+
{
|
|
12342
|
+
style: { zIndex: 10 },
|
|
12343
|
+
onClick: (e) => {
|
|
12344
|
+
e.stopPropagation();
|
|
12345
|
+
if (!headerRecordSet) {
|
|
12346
|
+
onHeaderAdded("");
|
|
12347
|
+
}
|
|
12348
|
+
},
|
|
12349
|
+
className: "ns-header-handle",
|
|
12350
|
+
children: /* @__PURE__ */ jsx(Icon, { color: "white", name: "rotate-circle" })
|
|
12258
12351
|
}
|
|
12259
|
-
|
|
12260
|
-
/* @__PURE__ */ jsx("div", { style: avatarStyles, className: "ns-avatar-record-cont", children: !avatarRecordSet && /* @__PURE__ */ jsx(
|
|
12261
|
-
|
|
12262
|
-
|
|
12263
|
-
|
|
12352
|
+
),
|
|
12353
|
+
/* @__PURE__ */ jsx("div", { style: avatarStyles, className: "ns-avatar-record-cont", children: !avatarRecordSet && /* @__PURE__ */ jsx(
|
|
12354
|
+
"div",
|
|
12355
|
+
{
|
|
12356
|
+
style: { zIndex: 10 },
|
|
12357
|
+
onClick: (e) => {
|
|
12358
|
+
e.stopPropagation();
|
|
12359
|
+
if (!avatarRecordSet) {
|
|
12360
|
+
onAvatarAdded("");
|
|
12361
|
+
}
|
|
12362
|
+
},
|
|
12363
|
+
className: "ns-image-handle",
|
|
12364
|
+
children: /* @__PURE__ */ jsx(Icon, { color: "grey", name: "rotate-circle" })
|
|
12264
12365
|
}
|
|
12265
|
-
|
|
12366
|
+
) })
|
|
12266
12367
|
] }) });
|
|
12267
12368
|
};
|
|
12268
12369
|
|
|
@@ -12723,6 +12824,1589 @@ const NavbarProfileCard = ({
|
|
|
12723
12824
|
] });
|
|
12724
12825
|
};
|
|
12725
12826
|
|
|
12827
|
+
var img$2 = "";
|
|
12828
|
+
|
|
12829
|
+
function InitialStep$1({
|
|
12830
|
+
name,
|
|
12831
|
+
onNameChange,
|
|
12832
|
+
onCancel,
|
|
12833
|
+
onRegister,
|
|
12834
|
+
onClose,
|
|
12835
|
+
isNameAvailable,
|
|
12836
|
+
domainSuffix = "eth"
|
|
12837
|
+
}) {
|
|
12838
|
+
const [nameAvailable, setNameAvailable] = useState(
|
|
12839
|
+
isNameAvailable
|
|
12840
|
+
);
|
|
12841
|
+
const getSubnamePart = (inputName) => {
|
|
12842
|
+
if (!inputName) return "";
|
|
12843
|
+
const suffixPattern = new RegExp(
|
|
12844
|
+
`\\.${domainSuffix.replace(".", "\\.")}$`,
|
|
12845
|
+
"i"
|
|
12846
|
+
);
|
|
12847
|
+
return inputName.replace(suffixPattern, "").trim();
|
|
12848
|
+
};
|
|
12849
|
+
useEffect(() => {
|
|
12850
|
+
const subnamePart2 = getSubnamePart(name);
|
|
12851
|
+
if (subnamePart2 && subnamePart2.length > 0) {
|
|
12852
|
+
const isValid = /^[a-z0-9-]+$/i.test(subnamePart2) && subnamePart2.length > 3;
|
|
12853
|
+
const timer = setTimeout(() => {
|
|
12854
|
+
setNameAvailable(isValid);
|
|
12855
|
+
}, 300);
|
|
12856
|
+
return () => clearTimeout(timer);
|
|
12857
|
+
} else {
|
|
12858
|
+
setNameAvailable(void 0);
|
|
12859
|
+
}
|
|
12860
|
+
}, [name]);
|
|
12861
|
+
const available = isNameAvailable !== void 0 ? isNameAvailable : nameAvailable;
|
|
12862
|
+
const showStatus = name && name.length > 0 && available !== void 0;
|
|
12863
|
+
const isUnavailable = showStatus && available === false;
|
|
12864
|
+
const subnamePart = getSubnamePart(name);
|
|
12865
|
+
const handleClear = () => {
|
|
12866
|
+
onNameChange("");
|
|
12867
|
+
};
|
|
12868
|
+
const handleNameInputChange = (e) => {
|
|
12869
|
+
let value = e.target.value;
|
|
12870
|
+
const suffixPattern = new RegExp(
|
|
12871
|
+
`\\.${domainSuffix.replace(".", "\\.")}$`,
|
|
12872
|
+
"i"
|
|
12873
|
+
);
|
|
12874
|
+
value = value.replace(suffixPattern, "");
|
|
12875
|
+
value = value.replace(/[^a-z0-9-]/gi, "");
|
|
12876
|
+
onNameChange(value);
|
|
12877
|
+
};
|
|
12878
|
+
return /* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-card", children: [
|
|
12879
|
+
onClose && /* @__PURE__ */ jsx("button", { className: "ns-onchain-register-close-btn", onClick: onClose, children: /* @__PURE__ */ jsx(Icon, { name: "x", size: 20 }) }),
|
|
12880
|
+
/* @__PURE__ */ jsx("div", { className: "ns-onchain-register-banner", children: /* @__PURE__ */ jsx("img", { src: img$2, alt: "ENS Banner" }) }),
|
|
12881
|
+
/* @__PURE__ */ jsx("div", { className: "ns-onchain-register-header", children: /* @__PURE__ */ jsx(Text, { size: "lg", weight: "bold", children: "Get your Web3 Username" }) }),
|
|
12882
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-input-row", children: [
|
|
12883
|
+
/* @__PURE__ */ jsx(
|
|
12884
|
+
Icon,
|
|
12885
|
+
{
|
|
12886
|
+
name: "search",
|
|
12887
|
+
size: 16,
|
|
12888
|
+
className: "ns-onchain-register-search-icon"
|
|
12889
|
+
}
|
|
12890
|
+
),
|
|
12891
|
+
/* @__PURE__ */ jsx(
|
|
12892
|
+
Input,
|
|
12893
|
+
{
|
|
12894
|
+
type: "text",
|
|
12895
|
+
className: "ns-onchain-register-input",
|
|
12896
|
+
placeholder: "Find name",
|
|
12897
|
+
value: subnamePart,
|
|
12898
|
+
onChange: handleNameInputChange
|
|
12899
|
+
}
|
|
12900
|
+
),
|
|
12901
|
+
subnamePart && available && /* @__PURE__ */ jsx("div", { className: "ns-onchain-register-checkmark available", children: /* @__PURE__ */ jsx(Icon, { name: "check-circle", size: 14, color: "black" }) }),
|
|
12902
|
+
subnamePart && isUnavailable && /* @__PURE__ */ jsx(
|
|
12903
|
+
"button",
|
|
12904
|
+
{
|
|
12905
|
+
className: "ns-onchain-register-clear-btn",
|
|
12906
|
+
onClick: handleClear,
|
|
12907
|
+
type: "button",
|
|
12908
|
+
children: /* @__PURE__ */ jsx(Icon, { name: "x", size: 14, color: "#ffffff" })
|
|
12909
|
+
}
|
|
12910
|
+
),
|
|
12911
|
+
/* @__PURE__ */ jsxs(Text, { className: "ns-onchain-register-domain-suffix", children: [
|
|
12912
|
+
".",
|
|
12913
|
+
domainSuffix
|
|
12914
|
+
] })
|
|
12915
|
+
] }),
|
|
12916
|
+
isUnavailable && /* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-unavailable-message", children: [
|
|
12917
|
+
/* @__PURE__ */ jsx(Icon, { name: "alert-triangle", size: 14 }),
|
|
12918
|
+
/* @__PURE__ */ jsx(Text, { size: "sm", className: "ns-onchain-register-error-text", children: "This name is unavailable. Please choose a different one." })
|
|
12919
|
+
] }),
|
|
12920
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-actions", children: [
|
|
12921
|
+
/* @__PURE__ */ jsx(Button, { className: "cancel", onClick: onCancel, children: "Cancel" }),
|
|
12922
|
+
/* @__PURE__ */ jsx(
|
|
12923
|
+
Button,
|
|
12924
|
+
{
|
|
12925
|
+
className: "primary",
|
|
12926
|
+
onClick: () => {
|
|
12927
|
+
const fullName = subnamePart ? `${subnamePart}.${domainSuffix}` : "";
|
|
12928
|
+
if (fullName) {
|
|
12929
|
+
onNameChange(fullName);
|
|
12930
|
+
}
|
|
12931
|
+
onRegister();
|
|
12932
|
+
},
|
|
12933
|
+
disabled: !subnamePart || !!isUnavailable,
|
|
12934
|
+
children: available ? "Next" : "Register"
|
|
12935
|
+
}
|
|
12936
|
+
)
|
|
12937
|
+
] }),
|
|
12938
|
+
/* @__PURE__ */ jsx("div", { className: "ns-onchain-register-footer", children: /* @__PURE__ */ jsx(Text, { size: "sm", color: "grey", children: "Powered by Namespace" }) })
|
|
12939
|
+
] });
|
|
12940
|
+
}
|
|
12941
|
+
|
|
12942
|
+
var img$1 = "";
|
|
12943
|
+
|
|
12944
|
+
function RegistrationStep({
|
|
12945
|
+
name,
|
|
12946
|
+
domainSuffix = "eth",
|
|
12947
|
+
owner = "0x035eB...24117D3",
|
|
12948
|
+
duration: initialDuration = 1,
|
|
12949
|
+
registrationFee = "0.004",
|
|
12950
|
+
networkFee = "0.0010",
|
|
12951
|
+
totalCost = "0.0014",
|
|
12952
|
+
useAsPrimary: initialUseAsPrimary = false,
|
|
12953
|
+
profileComplete = false,
|
|
12954
|
+
profileImageUrl,
|
|
12955
|
+
onBack,
|
|
12956
|
+
onCancel,
|
|
12957
|
+
onRegister,
|
|
12958
|
+
onNext,
|
|
12959
|
+
onClose,
|
|
12960
|
+
onOwnerChange,
|
|
12961
|
+
onDurationChange,
|
|
12962
|
+
onUseAsPrimaryChange,
|
|
12963
|
+
onCompleteProfile
|
|
12964
|
+
}) {
|
|
12965
|
+
const [duration, setDuration] = useState(initialDuration);
|
|
12966
|
+
const [useAsPrimary, setUseAsPrimary] = useState(initialUseAsPrimary);
|
|
12967
|
+
const [ownerAddress, setOwnerAddress] = useState(owner);
|
|
12968
|
+
const [isOwnerExpanded, setIsOwnerExpanded] = useState(true);
|
|
12969
|
+
useEffect(() => {
|
|
12970
|
+
setOwnerAddress(owner);
|
|
12971
|
+
}, [owner]);
|
|
12972
|
+
const handleDurationDecrease = () => {
|
|
12973
|
+
if (duration > 1) {
|
|
12974
|
+
const newDuration = duration - 1;
|
|
12975
|
+
setDuration(newDuration);
|
|
12976
|
+
onDurationChange?.(newDuration);
|
|
12977
|
+
}
|
|
12978
|
+
};
|
|
12979
|
+
const handleDurationIncrease = () => {
|
|
12980
|
+
const newDuration = duration + 1;
|
|
12981
|
+
setDuration(newDuration);
|
|
12982
|
+
onDurationChange?.(newDuration);
|
|
12983
|
+
};
|
|
12984
|
+
const handleTogglePrimary = () => {
|
|
12985
|
+
const newValue = !useAsPrimary;
|
|
12986
|
+
setUseAsPrimary(newValue);
|
|
12987
|
+
onUseAsPrimaryChange?.(newValue);
|
|
12988
|
+
};
|
|
12989
|
+
const handleOwnerChange = (value) => {
|
|
12990
|
+
setOwnerAddress(value);
|
|
12991
|
+
onOwnerChange?.(value);
|
|
12992
|
+
};
|
|
12993
|
+
const fullName = name.includes(".") ? name : `${name}.${domainSuffix}`;
|
|
12994
|
+
const isSubname = domainSuffix.includes(".");
|
|
12995
|
+
return /* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-card", children: [
|
|
12996
|
+
onClose && /* @__PURE__ */ jsx("button", { className: "ns-onchain-register-close-btn", onClick: onClose, children: /* @__PURE__ */ jsx(Icon, { name: "x", size: 20 }) }),
|
|
12997
|
+
/* @__PURE__ */ jsx("div", { className: "ns-onchain-register-mint-title", children: /* @__PURE__ */ jsx(Text, { size: "sm", color: "grey", children: "You are about to mint" }) }),
|
|
12998
|
+
/* @__PURE__ */ jsx("div", { className: "ns-onchain-register-name-display", children: /* @__PURE__ */ jsx(Text, { size: "xl", weight: "bold", children: fullName }) }),
|
|
12999
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-owner-section", children: [
|
|
13000
|
+
/* @__PURE__ */ jsxs(
|
|
13001
|
+
"div",
|
|
13002
|
+
{
|
|
13003
|
+
className: "ns-onchain-register-owner-header",
|
|
13004
|
+
onClick: () => setIsOwnerExpanded(!isOwnerExpanded),
|
|
13005
|
+
children: [
|
|
13006
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-owner-left", children: [
|
|
13007
|
+
/* @__PURE__ */ jsx(Icon, { name: "person", size: 16 }),
|
|
13008
|
+
/* @__PURE__ */ jsx(Text, { size: "sm", weight: "medium", children: "Owner" })
|
|
13009
|
+
] }),
|
|
13010
|
+
/* @__PURE__ */ jsx("div", { className: "ns-onchain-register-owner-chevron", children: isOwnerExpanded ? /* @__PURE__ */ jsx(ChevronUp, { size: 16 }) : /* @__PURE__ */ jsx(ChevronDown, { size: 16 }) })
|
|
13011
|
+
]
|
|
13012
|
+
}
|
|
13013
|
+
),
|
|
13014
|
+
isOwnerExpanded && /* @__PURE__ */ jsx("div", { className: "ns-onchain-register-owner-content", children: /* @__PURE__ */ jsx(
|
|
13015
|
+
Input,
|
|
13016
|
+
{
|
|
13017
|
+
type: "text",
|
|
13018
|
+
placeholder: "Enter owner address (0x...)",
|
|
13019
|
+
value: ownerAddress,
|
|
13020
|
+
onChange: (e) => handleOwnerChange(e.target.value),
|
|
13021
|
+
size: "md",
|
|
13022
|
+
className: "ns-onchain-register-owner-input"
|
|
13023
|
+
}
|
|
13024
|
+
) })
|
|
13025
|
+
] }),
|
|
13026
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-duration-section", children: [
|
|
13027
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-duration-controls", children: [
|
|
13028
|
+
/* @__PURE__ */ jsx(
|
|
13029
|
+
"button",
|
|
13030
|
+
{
|
|
13031
|
+
className: "ns-onchain-register-duration-btn",
|
|
13032
|
+
onClick: handleDurationDecrease,
|
|
13033
|
+
disabled: duration <= 1,
|
|
13034
|
+
children: /* @__PURE__ */ jsx("span", { style: { fontSize: "20px", lineHeight: "1" }, children: "\u2212" })
|
|
13035
|
+
}
|
|
13036
|
+
),
|
|
13037
|
+
/* @__PURE__ */ jsxs(Text, { size: "md", weight: "medium", children: [
|
|
13038
|
+
duration,
|
|
13039
|
+
" year",
|
|
13040
|
+
duration !== 1 ? "s" : ""
|
|
13041
|
+
] }),
|
|
13042
|
+
/* @__PURE__ */ jsx(
|
|
13043
|
+
"button",
|
|
13044
|
+
{
|
|
13045
|
+
className: "ns-onchain-register-duration-btn",
|
|
13046
|
+
onClick: handleDurationIncrease,
|
|
13047
|
+
children: /* @__PURE__ */ jsx("span", { style: { fontSize: "20px", lineHeight: "1" }, children: "+" })
|
|
13048
|
+
}
|
|
13049
|
+
)
|
|
13050
|
+
] }),
|
|
13051
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-cost-breakdown", children: [
|
|
13052
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-cost-row", children: [
|
|
13053
|
+
/* @__PURE__ */ jsxs(Text, { size: "sm", color: "grey", children: [
|
|
13054
|
+
duration,
|
|
13055
|
+
" year registration"
|
|
13056
|
+
] }),
|
|
13057
|
+
/* @__PURE__ */ jsxs(Text, { size: "sm", weight: "medium", children: [
|
|
13058
|
+
registrationFee,
|
|
13059
|
+
" ETH"
|
|
13060
|
+
] })
|
|
13061
|
+
] }),
|
|
13062
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-cost-row", children: [
|
|
13063
|
+
/* @__PURE__ */ jsx(Text, { size: "sm", color: "grey", children: "Est. network fee" }),
|
|
13064
|
+
/* @__PURE__ */ jsxs(Text, { size: "sm", weight: "medium", children: [
|
|
13065
|
+
networkFee,
|
|
13066
|
+
" ETH"
|
|
13067
|
+
] })
|
|
13068
|
+
] }),
|
|
13069
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-cost-row total", children: [
|
|
13070
|
+
/* @__PURE__ */ jsx(Text, { size: "md", weight: "bold", children: "Total" }),
|
|
13071
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-total-cost", children: [
|
|
13072
|
+
/* @__PURE__ */ jsx(Text, { size: "md", weight: "bold", children: totalCost }),
|
|
13073
|
+
/* @__PURE__ */ jsx("span", { style: { fontSize: "14px", color: "#3b82f6" }, children: "\u039E" }),
|
|
13074
|
+
/* @__PURE__ */ jsx(Text, { size: "sm", weight: "medium", children: "ETH" })
|
|
13075
|
+
] })
|
|
13076
|
+
] })
|
|
13077
|
+
] })
|
|
13078
|
+
] }),
|
|
13079
|
+
profileComplete ? /* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-profile-completed", children: [
|
|
13080
|
+
/* @__PURE__ */ jsx("div", { className: "ns-onchain-register-profile-completed-avatar", children: profileImageUrl ? /* @__PURE__ */ jsx("img", { src: profileImageUrl, alt: "Profile" }) : /* @__PURE__ */ jsx(Icon, { name: "person", size: 24 }) }),
|
|
13081
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-profile-completed-text", children: [
|
|
13082
|
+
/* @__PURE__ */ jsx(Text, { size: "md", weight: "bold", children: "Profile completed" }),
|
|
13083
|
+
/* @__PURE__ */ jsx(Text, { size: "sm", color: "grey", children: "You're all set! Finish your registration." })
|
|
13084
|
+
] }),
|
|
13085
|
+
/* @__PURE__ */ jsx("div", { className: "ns-onchain-register-profile-completed-checkmark", children: /* @__PURE__ */ jsx(Icon, { name: "check-circle", size: 24, color: "#ffffff" }) })
|
|
13086
|
+
] }) : onCompleteProfile && /* @__PURE__ */ jsxs(
|
|
13087
|
+
"div",
|
|
13088
|
+
{
|
|
13089
|
+
className: "ns-onchain-register-profile-card",
|
|
13090
|
+
onClick: onCompleteProfile,
|
|
13091
|
+
children: [
|
|
13092
|
+
/* @__PURE__ */ jsx("div", { className: "ns-onchain-register-profile-icon", children: /* @__PURE__ */ jsx("img", { src: img$1, alt: "Profile Icon" }) }),
|
|
13093
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-profile-text", children: [
|
|
13094
|
+
/* @__PURE__ */ jsx(Text, { size: "md", weight: "bold", children: "Complete your profile" }),
|
|
13095
|
+
/* @__PURE__ */ jsx(Text, { size: "sm", color: "grey", children: "Make your ENS more discoverable" })
|
|
13096
|
+
] }),
|
|
13097
|
+
/* @__PURE__ */ jsx("button", { className: "ns-onchain-register-profile-arrow", children: /* @__PURE__ */ jsx(ChevronRight, { size: 20 }) })
|
|
13098
|
+
]
|
|
13099
|
+
}
|
|
13100
|
+
),
|
|
13101
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-toggle", children: [
|
|
13102
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-toggle-text", children: [
|
|
13103
|
+
/* @__PURE__ */ jsx(Text, { size: "md", weight: "bold", children: "Use as primary name" }),
|
|
13104
|
+
/* @__PURE__ */ jsxs("div", { style: { marginTop: "8px" }, children: [
|
|
13105
|
+
/* @__PURE__ */ jsxs(Text, { size: "sm", color: "grey", children: [
|
|
13106
|
+
"This links your address to this name, allowing dApps to display it as your profile when connected to them. You can only have",
|
|
13107
|
+
" "
|
|
13108
|
+
] }),
|
|
13109
|
+
/* @__PURE__ */ jsx(Text, { size: "sm", color: "grey", weight: "bold", children: "one primary name per address" }),
|
|
13110
|
+
/* @__PURE__ */ jsx(Text, { size: "sm", color: "grey", children: "." })
|
|
13111
|
+
] })
|
|
13112
|
+
] }),
|
|
13113
|
+
/* @__PURE__ */ jsxs("div", { className: "toggle-switch", children: [
|
|
13114
|
+
/* @__PURE__ */ jsx(
|
|
13115
|
+
"input",
|
|
13116
|
+
{
|
|
13117
|
+
type: "checkbox",
|
|
13118
|
+
id: "use-as-primary",
|
|
13119
|
+
checked: useAsPrimary,
|
|
13120
|
+
onChange: handleTogglePrimary
|
|
13121
|
+
}
|
|
13122
|
+
),
|
|
13123
|
+
/* @__PURE__ */ jsx("label", { htmlFor: "use-as-primary" })
|
|
13124
|
+
] })
|
|
13125
|
+
] }),
|
|
13126
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-actions", children: [
|
|
13127
|
+
/* @__PURE__ */ jsx(Button, { className: "cancel", onClick: onCancel || onBack, children: "Cancel" }),
|
|
13128
|
+
/* @__PURE__ */ jsx(
|
|
13129
|
+
Button,
|
|
13130
|
+
{
|
|
13131
|
+
className: "primary",
|
|
13132
|
+
onClick: isSubname && onNext ? onNext : onRegister,
|
|
13133
|
+
children: isSubname ? "Next" : "Register"
|
|
13134
|
+
}
|
|
13135
|
+
)
|
|
13136
|
+
] })
|
|
13137
|
+
] });
|
|
13138
|
+
}
|
|
13139
|
+
|
|
13140
|
+
function ConfirmationStep({
|
|
13141
|
+
name,
|
|
13142
|
+
domainSuffix = "eth",
|
|
13143
|
+
owner = "0x035eB...24117D3",
|
|
13144
|
+
duration = 1,
|
|
13145
|
+
registrationFee = "0.004",
|
|
13146
|
+
networkFee = "0.0010",
|
|
13147
|
+
totalCost = "0.0014",
|
|
13148
|
+
useAsPrimary = false,
|
|
13149
|
+
profileComplete = true,
|
|
13150
|
+
profileImageUrl = "https://gratisography.com/wp-content/uploads/2024/11/gratisography-augmented-reality-800x525.jpg",
|
|
13151
|
+
onBack,
|
|
13152
|
+
onCancel,
|
|
13153
|
+
onRegister,
|
|
13154
|
+
onClose,
|
|
13155
|
+
onOwnerChange
|
|
13156
|
+
}) {
|
|
13157
|
+
const [isOwnerExpanded, setIsOwnerExpanded] = useState(true);
|
|
13158
|
+
const fullName = name.includes(".") ? name : `${name}.${domainSuffix}`;
|
|
13159
|
+
return /* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-card", children: [
|
|
13160
|
+
onClose && /* @__PURE__ */ jsx("button", { className: "ns-onchain-register-close-btn", onClick: onClose, children: /* @__PURE__ */ jsx(Icon, { name: "x", size: 20 }) }),
|
|
13161
|
+
/* @__PURE__ */ jsx("div", { className: "ns-onchain-register-mint-title", children: /* @__PURE__ */ jsx(Text, { size: "sm", color: "grey", children: "You are about to mint" }) }),
|
|
13162
|
+
/* @__PURE__ */ jsx("div", { className: "ns-onchain-register-name-display", children: /* @__PURE__ */ jsx(Text, { size: "xl", weight: "bold", children: fullName }) }),
|
|
13163
|
+
profileComplete && /* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-profile-completed", children: [
|
|
13164
|
+
/* @__PURE__ */ jsx("div", { className: "ns-onchain-register-profile-completed-avatar", children: profileImageUrl ? /* @__PURE__ */ jsx("img", { src: profileImageUrl, alt: "Profile" }) : /* @__PURE__ */ jsx(Icon, { name: "person", size: 24 }) }),
|
|
13165
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-profile-completed-text", children: [
|
|
13166
|
+
/* @__PURE__ */ jsx(Text, { size: "md", weight: "bold", children: "Profile completed" }),
|
|
13167
|
+
/* @__PURE__ */ jsx(Text, { size: "sm", color: "grey", children: "You're all set! Finish your registration." })
|
|
13168
|
+
] }),
|
|
13169
|
+
/* @__PURE__ */ jsx("div", { className: "ns-onchain-register-profile-completed-checkmark", children: /* @__PURE__ */ jsx(Icon, { name: "check-circle", size: 24, color: "#ffffff" }) })
|
|
13170
|
+
] }),
|
|
13171
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-owner-section", children: [
|
|
13172
|
+
/* @__PURE__ */ jsxs(
|
|
13173
|
+
"div",
|
|
13174
|
+
{
|
|
13175
|
+
className: "ns-onchain-register-owner-header",
|
|
13176
|
+
onClick: () => setIsOwnerExpanded(!isOwnerExpanded),
|
|
13177
|
+
children: [
|
|
13178
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-owner-left", children: [
|
|
13179
|
+
/* @__PURE__ */ jsx(Icon, { name: "person", size: 16 }),
|
|
13180
|
+
/* @__PURE__ */ jsx(Text, { size: "sm", weight: "medium", children: "Owner" })
|
|
13181
|
+
] }),
|
|
13182
|
+
/* @__PURE__ */ jsx("div", { className: "ns-onchain-register-owner-chevron", children: isOwnerExpanded ? /* @__PURE__ */ jsx(ChevronUp, { size: 16 }) : /* @__PURE__ */ jsx(ChevronDown, { size: 16 }) })
|
|
13183
|
+
]
|
|
13184
|
+
}
|
|
13185
|
+
),
|
|
13186
|
+
isOwnerExpanded && /* @__PURE__ */ jsx("div", { className: "ns-onchain-register-owner-content", children: /* @__PURE__ */ jsx(
|
|
13187
|
+
Input,
|
|
13188
|
+
{
|
|
13189
|
+
type: "text",
|
|
13190
|
+
placeholder: "Enter owner address (0x...)",
|
|
13191
|
+
value: owner,
|
|
13192
|
+
onChange: (e) => onOwnerChange?.(e.target.value),
|
|
13193
|
+
size: "md",
|
|
13194
|
+
className: "ns-onchain-register-owner-input"
|
|
13195
|
+
}
|
|
13196
|
+
) })
|
|
13197
|
+
] }),
|
|
13198
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-duration-section", children: [
|
|
13199
|
+
/* @__PURE__ */ jsx("div", { className: "ns-onchain-register-duration-controls", children: /* @__PURE__ */ jsxs(Text, { size: "md", weight: "medium", children: [
|
|
13200
|
+
duration,
|
|
13201
|
+
" year",
|
|
13202
|
+
duration !== 1 ? "s" : ""
|
|
13203
|
+
] }) }),
|
|
13204
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-cost-breakdown", children: [
|
|
13205
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-cost-row", children: [
|
|
13206
|
+
/* @__PURE__ */ jsxs(Text, { size: "sm", color: "grey", children: [
|
|
13207
|
+
duration,
|
|
13208
|
+
" year registration"
|
|
13209
|
+
] }),
|
|
13210
|
+
/* @__PURE__ */ jsxs(Text, { size: "sm", weight: "medium", children: [
|
|
13211
|
+
registrationFee,
|
|
13212
|
+
" ETH"
|
|
13213
|
+
] })
|
|
13214
|
+
] }),
|
|
13215
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-cost-row", children: [
|
|
13216
|
+
/* @__PURE__ */ jsx(Text, { size: "sm", color: "grey", children: "Est. network fee" }),
|
|
13217
|
+
/* @__PURE__ */ jsxs(Text, { size: "sm", weight: "medium", children: [
|
|
13218
|
+
networkFee,
|
|
13219
|
+
" ETH"
|
|
13220
|
+
] })
|
|
13221
|
+
] }),
|
|
13222
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-cost-row total", children: [
|
|
13223
|
+
/* @__PURE__ */ jsx(Text, { size: "md", weight: "bold", children: "Total" }),
|
|
13224
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-total-cost", children: [
|
|
13225
|
+
/* @__PURE__ */ jsx(Text, { size: "md", weight: "bold", children: totalCost }),
|
|
13226
|
+
/* @__PURE__ */ jsx("span", { style: { fontSize: "14px", color: "#3b82f6" }, children: "\u039E" }),
|
|
13227
|
+
/* @__PURE__ */ jsx(Text, { size: "sm", weight: "medium", children: "ETH" })
|
|
13228
|
+
] })
|
|
13229
|
+
] })
|
|
13230
|
+
] })
|
|
13231
|
+
] }),
|
|
13232
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-actions", children: [
|
|
13233
|
+
/* @__PURE__ */ jsx(Button, { className: "cancel", onClick: onCancel || onBack, children: "Cancel" }),
|
|
13234
|
+
/* @__PURE__ */ jsx(Button, { className: "primary", onClick: onRegister, children: "Register" })
|
|
13235
|
+
] })
|
|
13236
|
+
] });
|
|
13237
|
+
}
|
|
13238
|
+
|
|
13239
|
+
var img = "";
|
|
13240
|
+
|
|
13241
|
+
function OnchainSuccessScreen({
|
|
13242
|
+
name,
|
|
13243
|
+
onClose,
|
|
13244
|
+
onFinish
|
|
13245
|
+
}) {
|
|
13246
|
+
return /* @__PURE__ */ jsx("div", { className: "ns-onchain-register-container", children: /* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-card ns-onchain-register-success", children: [
|
|
13247
|
+
onClose && /* @__PURE__ */ jsx("button", { className: "ns-onchain-register-close-btn", onClick: onClose, children: /* @__PURE__ */ jsx(Icon, { name: "x", size: 20 }) }),
|
|
13248
|
+
/* @__PURE__ */ jsx("div", { className: "ns-onchain-register-finish-banner", children: /* @__PURE__ */ jsx("img", { src: img, alt: "Success" }) }),
|
|
13249
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-onchain-register-success-title-section", children: [
|
|
13250
|
+
/* @__PURE__ */ jsx(
|
|
13251
|
+
Text,
|
|
13252
|
+
{
|
|
13253
|
+
size: "xl",
|
|
13254
|
+
weight: "bold",
|
|
13255
|
+
className: "ns-onchain-register-success-message",
|
|
13256
|
+
children: "ENS name registered successfully"
|
|
13257
|
+
}
|
|
13258
|
+
),
|
|
13259
|
+
/* @__PURE__ */ jsx(
|
|
13260
|
+
Text,
|
|
13261
|
+
{
|
|
13262
|
+
size: "md",
|
|
13263
|
+
color: "grey",
|
|
13264
|
+
className: "ns-onchain-register-success-subtitle",
|
|
13265
|
+
children: "Your ENS name is now active and ready to use"
|
|
13266
|
+
}
|
|
13267
|
+
)
|
|
13268
|
+
] }),
|
|
13269
|
+
/* @__PURE__ */ jsx("div", { className: "ns-onchain-register-actions", children: /* @__PURE__ */ jsx(Button, { className: "primary finish-btn", onClick: onFinish || onClose, children: "Finish" }) })
|
|
13270
|
+
] }) });
|
|
13271
|
+
}
|
|
13272
|
+
|
|
13273
|
+
function EnsOnChainRegisterModal({
|
|
13274
|
+
step: initialStep = 0,
|
|
13275
|
+
name: initialName = "",
|
|
13276
|
+
profileComplete = false,
|
|
13277
|
+
domainSuffix = "eth",
|
|
13278
|
+
owner: initialOwner = "0x035eB...24117D3",
|
|
13279
|
+
duration: initialDuration = 1,
|
|
13280
|
+
registrationFee = "0.004",
|
|
13281
|
+
networkFee = "0.0010",
|
|
13282
|
+
totalCost = "0.0014",
|
|
13283
|
+
useAsPrimary: initialUseAsPrimary = false,
|
|
13284
|
+
profileImageUrl,
|
|
13285
|
+
onStepChange,
|
|
13286
|
+
onNameChange,
|
|
13287
|
+
onProfileCompleteChange,
|
|
13288
|
+
onOwnerChange,
|
|
13289
|
+
onDurationChange,
|
|
13290
|
+
onUseAsPrimaryChange,
|
|
13291
|
+
onRegister,
|
|
13292
|
+
onCancel,
|
|
13293
|
+
onClose,
|
|
13294
|
+
onCompleteProfile,
|
|
13295
|
+
onOpenWallet,
|
|
13296
|
+
onCompleteRegistration,
|
|
13297
|
+
onRegisterAnother,
|
|
13298
|
+
onViewName,
|
|
13299
|
+
onFinish
|
|
13300
|
+
}) {
|
|
13301
|
+
const [currentStep, setCurrentStep] = useState(initialStep);
|
|
13302
|
+
const [ensName, setEnsName] = useState(initialName);
|
|
13303
|
+
const [owner, setOwner] = useState(initialOwner);
|
|
13304
|
+
const [duration, setDuration] = useState(initialDuration);
|
|
13305
|
+
const [useAsPrimary, setUseAsPrimary] = useState(initialUseAsPrimary);
|
|
13306
|
+
const handleNameChange = (value) => {
|
|
13307
|
+
setEnsName(value);
|
|
13308
|
+
onNameChange?.(value);
|
|
13309
|
+
};
|
|
13310
|
+
const handleOwnerChange = (value) => {
|
|
13311
|
+
setOwner(value);
|
|
13312
|
+
onOwnerChange?.(value);
|
|
13313
|
+
};
|
|
13314
|
+
const handleDurationChange = (value) => {
|
|
13315
|
+
setDuration(value);
|
|
13316
|
+
onDurationChange?.(value);
|
|
13317
|
+
};
|
|
13318
|
+
const handleUseAsPrimaryChange = (value) => {
|
|
13319
|
+
setUseAsPrimary(value);
|
|
13320
|
+
onUseAsPrimaryChange?.(value);
|
|
13321
|
+
};
|
|
13322
|
+
const handleRegister = () => {
|
|
13323
|
+
setCurrentStep(1);
|
|
13324
|
+
onStepChange?.(1);
|
|
13325
|
+
onRegister?.();
|
|
13326
|
+
};
|
|
13327
|
+
const handleFinalRegister = () => {
|
|
13328
|
+
setCurrentStep(3);
|
|
13329
|
+
onStepChange?.(3);
|
|
13330
|
+
onCompleteRegistration?.();
|
|
13331
|
+
};
|
|
13332
|
+
const handleFinish = () => {
|
|
13333
|
+
onFinish?.();
|
|
13334
|
+
onClose?.();
|
|
13335
|
+
};
|
|
13336
|
+
const handleNext = () => {
|
|
13337
|
+
setCurrentStep(2);
|
|
13338
|
+
onStepChange?.(2);
|
|
13339
|
+
};
|
|
13340
|
+
const handleBack = () => {
|
|
13341
|
+
if (currentStep === 2) {
|
|
13342
|
+
setCurrentStep(1);
|
|
13343
|
+
onStepChange?.(1);
|
|
13344
|
+
} else {
|
|
13345
|
+
setCurrentStep(0);
|
|
13346
|
+
onStepChange?.(0);
|
|
13347
|
+
}
|
|
13348
|
+
};
|
|
13349
|
+
const handleCancel = () => {
|
|
13350
|
+
onCancel?.();
|
|
13351
|
+
};
|
|
13352
|
+
if (currentStep === 0) {
|
|
13353
|
+
return /* @__PURE__ */ jsx("div", { className: "ns-onchain-register-container", children: /* @__PURE__ */ jsx(
|
|
13354
|
+
InitialStep$1,
|
|
13355
|
+
{
|
|
13356
|
+
name: ensName,
|
|
13357
|
+
onNameChange: handleNameChange,
|
|
13358
|
+
onCancel: handleCancel,
|
|
13359
|
+
onRegister: handleRegister,
|
|
13360
|
+
onClose,
|
|
13361
|
+
domainSuffix
|
|
13362
|
+
}
|
|
13363
|
+
) });
|
|
13364
|
+
}
|
|
13365
|
+
if (currentStep === 1) {
|
|
13366
|
+
return /* @__PURE__ */ jsx("div", { className: "ns-onchain-register-container", children: /* @__PURE__ */ jsx(
|
|
13367
|
+
RegistrationStep,
|
|
13368
|
+
{
|
|
13369
|
+
name: ensName,
|
|
13370
|
+
domainSuffix,
|
|
13371
|
+
owner,
|
|
13372
|
+
duration,
|
|
13373
|
+
registrationFee,
|
|
13374
|
+
networkFee,
|
|
13375
|
+
totalCost,
|
|
13376
|
+
useAsPrimary,
|
|
13377
|
+
profileComplete,
|
|
13378
|
+
profileImageUrl,
|
|
13379
|
+
onBack: handleBack,
|
|
13380
|
+
onCancel: handleCancel,
|
|
13381
|
+
onRegister,
|
|
13382
|
+
onNext: handleNext,
|
|
13383
|
+
onClose,
|
|
13384
|
+
onOwnerChange: handleOwnerChange,
|
|
13385
|
+
onDurationChange: handleDurationChange,
|
|
13386
|
+
onUseAsPrimaryChange: handleUseAsPrimaryChange,
|
|
13387
|
+
onCompleteProfile
|
|
13388
|
+
}
|
|
13389
|
+
) });
|
|
13390
|
+
}
|
|
13391
|
+
if (currentStep === 2) {
|
|
13392
|
+
return /* @__PURE__ */ jsx("div", { className: "ns-onchain-register-container", children: /* @__PURE__ */ jsx(
|
|
13393
|
+
ConfirmationStep,
|
|
13394
|
+
{
|
|
13395
|
+
name: ensName,
|
|
13396
|
+
domainSuffix,
|
|
13397
|
+
owner,
|
|
13398
|
+
duration,
|
|
13399
|
+
registrationFee,
|
|
13400
|
+
networkFee,
|
|
13401
|
+
totalCost,
|
|
13402
|
+
useAsPrimary,
|
|
13403
|
+
profileComplete,
|
|
13404
|
+
profileImageUrl,
|
|
13405
|
+
onBack: handleBack,
|
|
13406
|
+
onCancel: handleCancel,
|
|
13407
|
+
onRegister: handleFinalRegister,
|
|
13408
|
+
onClose,
|
|
13409
|
+
onOwnerChange: handleOwnerChange
|
|
13410
|
+
}
|
|
13411
|
+
) });
|
|
13412
|
+
}
|
|
13413
|
+
if (currentStep === 3) {
|
|
13414
|
+
return /* @__PURE__ */ jsx("div", { className: "ns-onchain-register-container", children: /* @__PURE__ */ jsx(
|
|
13415
|
+
OnchainSuccessScreen,
|
|
13416
|
+
{
|
|
13417
|
+
name: ensName,
|
|
13418
|
+
onClose,
|
|
13419
|
+
onFinish: handleFinish
|
|
13420
|
+
}
|
|
13421
|
+
) });
|
|
13422
|
+
}
|
|
13423
|
+
return /* @__PURE__ */ jsx("div", { className: "ns-onchain-register-container", children: /* @__PURE__ */ jsx(
|
|
13424
|
+
InitialStep$1,
|
|
13425
|
+
{
|
|
13426
|
+
name: ensName,
|
|
13427
|
+
onNameChange: handleNameChange,
|
|
13428
|
+
onCancel: handleCancel,
|
|
13429
|
+
onRegister: handleRegister,
|
|
13430
|
+
onClose,
|
|
13431
|
+
domainSuffix
|
|
13432
|
+
}
|
|
13433
|
+
) });
|
|
13434
|
+
}
|
|
13435
|
+
|
|
13436
|
+
function InitialStep({
|
|
13437
|
+
name,
|
|
13438
|
+
onNameChange,
|
|
13439
|
+
onCancel,
|
|
13440
|
+
onRegister,
|
|
13441
|
+
onClose,
|
|
13442
|
+
isNameAvailable
|
|
13443
|
+
}) {
|
|
13444
|
+
const [nameAvailable, setNameAvailable] = useState(
|
|
13445
|
+
isNameAvailable
|
|
13446
|
+
);
|
|
13447
|
+
const domainSuffix = "particle.eth";
|
|
13448
|
+
const getSubnamePart = (inputName) => {
|
|
13449
|
+
if (!inputName) return "";
|
|
13450
|
+
const suffixPattern = new RegExp(
|
|
13451
|
+
`\\.${domainSuffix.replace(".", "\\.")}$`,
|
|
13452
|
+
"i"
|
|
13453
|
+
);
|
|
13454
|
+
return inputName.replace(suffixPattern, "").trim();
|
|
13455
|
+
};
|
|
13456
|
+
useEffect(() => {
|
|
13457
|
+
const subnamePart2 = getSubnamePart(name);
|
|
13458
|
+
if (subnamePart2 && subnamePart2.length > 0) {
|
|
13459
|
+
const isValid = /^[a-z0-9-]+$/i.test(subnamePart2) && subnamePart2.length > 3;
|
|
13460
|
+
const timer = setTimeout(() => {
|
|
13461
|
+
setNameAvailable(isValid);
|
|
13462
|
+
}, 300);
|
|
13463
|
+
return () => clearTimeout(timer);
|
|
13464
|
+
} else {
|
|
13465
|
+
setNameAvailable(void 0);
|
|
13466
|
+
}
|
|
13467
|
+
}, [name]);
|
|
13468
|
+
const available = isNameAvailable !== void 0 ? isNameAvailable : nameAvailable;
|
|
13469
|
+
const showStatus = name && name.length > 0 && available !== void 0;
|
|
13470
|
+
const isUnavailable = showStatus && available === false;
|
|
13471
|
+
const subnamePart = getSubnamePart(name);
|
|
13472
|
+
const handleClear = () => {
|
|
13473
|
+
onNameChange("");
|
|
13474
|
+
};
|
|
13475
|
+
const handleNameInputChange = (e) => {
|
|
13476
|
+
let value = e.target.value;
|
|
13477
|
+
const suffixPattern = new RegExp(
|
|
13478
|
+
`\\.${domainSuffix.replace(".", "\\.")}$`,
|
|
13479
|
+
"i"
|
|
13480
|
+
);
|
|
13481
|
+
value = value.replace(suffixPattern, "");
|
|
13482
|
+
value = value.replace(/[^a-z0-9-]/gi, "");
|
|
13483
|
+
onNameChange(value);
|
|
13484
|
+
};
|
|
13485
|
+
return /* @__PURE__ */ jsxs("div", { className: "ns-offchain-register-card", children: [
|
|
13486
|
+
onClose && /* @__PURE__ */ jsx("button", { className: "ns-offchain-register-close-btn", onClick: onClose, children: /* @__PURE__ */ jsx(Icon, { name: "x", size: 20 }) }),
|
|
13487
|
+
/* @__PURE__ */ jsx("div", { className: "ns-offchain-register-banner", children: /* @__PURE__ */ jsx("img", { src: img$2, alt: "ENS Banner" }) }),
|
|
13488
|
+
/* @__PURE__ */ jsx("div", { className: "ns-offchain-register-header", children: /* @__PURE__ */ jsx(Text, { size: "lg", weight: "bold", children: "Get your Web3 Username" }) }),
|
|
13489
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-offchain-register-input-row", children: [
|
|
13490
|
+
/* @__PURE__ */ jsx(
|
|
13491
|
+
Icon,
|
|
13492
|
+
{
|
|
13493
|
+
name: "search",
|
|
13494
|
+
size: 16,
|
|
13495
|
+
className: "ns-offchain-register-search-icon"
|
|
13496
|
+
}
|
|
13497
|
+
),
|
|
13498
|
+
/* @__PURE__ */ jsx(
|
|
13499
|
+
Input,
|
|
13500
|
+
{
|
|
13501
|
+
type: "text",
|
|
13502
|
+
className: "ns-offchain-register-input",
|
|
13503
|
+
placeholder: "Find name",
|
|
13504
|
+
value: subnamePart,
|
|
13505
|
+
onChange: handleNameInputChange
|
|
13506
|
+
}
|
|
13507
|
+
),
|
|
13508
|
+
subnamePart && available && /* @__PURE__ */ jsx("div", { className: "ns-offchain-register-checkmark available", children: /* @__PURE__ */ jsx(Icon, { name: "check-circle", size: 14, color: "black" }) }),
|
|
13509
|
+
subnamePart && isUnavailable && /* @__PURE__ */ jsx(
|
|
13510
|
+
"button",
|
|
13511
|
+
{
|
|
13512
|
+
className: "ns-offchain-register-clear-btn",
|
|
13513
|
+
onClick: handleClear,
|
|
13514
|
+
type: "button",
|
|
13515
|
+
children: /* @__PURE__ */ jsx(Icon, { name: "x", size: 14, color: "#ffffff" })
|
|
13516
|
+
}
|
|
13517
|
+
),
|
|
13518
|
+
/* @__PURE__ */ jsxs(Text, { className: "ns-offchain-register-domain-suffix", children: [
|
|
13519
|
+
".",
|
|
13520
|
+
domainSuffix
|
|
13521
|
+
] })
|
|
13522
|
+
] }),
|
|
13523
|
+
isUnavailable && /* @__PURE__ */ jsxs("div", { className: "ns-offchain-register-unavailable-message", children: [
|
|
13524
|
+
/* @__PURE__ */ jsx(Icon, { name: "alert-triangle", size: 14 }),
|
|
13525
|
+
/* @__PURE__ */ jsx(Text, { size: "sm", className: "ns-offchain-register-error-text", children: "This name is unavailable. Please choose a different one." })
|
|
13526
|
+
] }),
|
|
13527
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-offchain-register-actions", children: [
|
|
13528
|
+
/* @__PURE__ */ jsx(Button, { className: "cancel", onClick: onCancel, children: "Cancel" }),
|
|
13529
|
+
/* @__PURE__ */ jsx(
|
|
13530
|
+
Button,
|
|
13531
|
+
{
|
|
13532
|
+
className: "primary",
|
|
13533
|
+
onClick: () => {
|
|
13534
|
+
const fullName = subnamePart ? `${subnamePart}.${domainSuffix}` : "";
|
|
13535
|
+
if (fullName) {
|
|
13536
|
+
onNameChange(fullName);
|
|
13537
|
+
}
|
|
13538
|
+
onRegister();
|
|
13539
|
+
},
|
|
13540
|
+
disabled: !subnamePart || !!isUnavailable,
|
|
13541
|
+
children: subnamePart && available ? "Next" : "Register"
|
|
13542
|
+
}
|
|
13543
|
+
)
|
|
13544
|
+
] }),
|
|
13545
|
+
/* @__PURE__ */ jsx("div", { className: "ns-offchain-register-footer", children: /* @__PURE__ */ jsx(Text, { size: "sm", color: "grey", children: "Powered by Namespace" }) })
|
|
13546
|
+
] });
|
|
13547
|
+
}
|
|
13548
|
+
|
|
13549
|
+
function OffchainSuccessScreen({
|
|
13550
|
+
name,
|
|
13551
|
+
onClose,
|
|
13552
|
+
onSetProfile,
|
|
13553
|
+
onFinish
|
|
13554
|
+
}) {
|
|
13555
|
+
return /* @__PURE__ */ jsx("div", { className: "ns-offchain-register-container", children: /* @__PURE__ */ jsxs("div", { className: "ns-offchain-register-card ns-offchain-register-success", children: [
|
|
13556
|
+
onClose && /* @__PURE__ */ jsx("button", { className: "ns-offchain-register-close-btn", onClick: onClose, children: /* @__PURE__ */ jsx(Icon, { name: "x", size: 20 }) }),
|
|
13557
|
+
/* @__PURE__ */ jsx("div", { className: "ns-offchain-register-finish-banner", children: /* @__PURE__ */ jsx("img", { src: img, alt: "Success" }) }),
|
|
13558
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-offchain-register-success-title-section", children: [
|
|
13559
|
+
/* @__PURE__ */ jsx(
|
|
13560
|
+
Text,
|
|
13561
|
+
{
|
|
13562
|
+
size: "xl",
|
|
13563
|
+
weight: "bold",
|
|
13564
|
+
className: "ns-offchain-register-success-message",
|
|
13565
|
+
children: "ENS name registered successfully"
|
|
13566
|
+
}
|
|
13567
|
+
),
|
|
13568
|
+
/* @__PURE__ */ jsx(
|
|
13569
|
+
Text,
|
|
13570
|
+
{
|
|
13571
|
+
size: "md",
|
|
13572
|
+
color: "grey",
|
|
13573
|
+
className: "ns-offchain-register-success-subtitle",
|
|
13574
|
+
children: "Complete your profile now"
|
|
13575
|
+
}
|
|
13576
|
+
)
|
|
13577
|
+
] }),
|
|
13578
|
+
onSetProfile && /* @__PURE__ */ jsxs(
|
|
13579
|
+
"div",
|
|
13580
|
+
{
|
|
13581
|
+
className: "ns-offchain-register-profile-card",
|
|
13582
|
+
onClick: onSetProfile,
|
|
13583
|
+
children: [
|
|
13584
|
+
/* @__PURE__ */ jsx("div", { className: "ns-offchain-register-profile-icon", children: /* @__PURE__ */ jsx("img", { src: img$1, alt: "Profile Icon" }) }),
|
|
13585
|
+
/* @__PURE__ */ jsxs("div", { className: "ns-offchain-register-profile-text", children: [
|
|
13586
|
+
/* @__PURE__ */ jsx(Text, { size: "md", weight: "bold", children: "Complete your profile" }),
|
|
13587
|
+
/* @__PURE__ */ jsx(Text, { size: "sm", color: "grey", children: "Make your ENS more discoverable" })
|
|
13588
|
+
] }),
|
|
13589
|
+
/* @__PURE__ */ jsx("button", { className: "ns-offchain-register-profile-arrow", children: /* @__PURE__ */ jsx(ChevronRight, { size: 20 }) })
|
|
13590
|
+
]
|
|
13591
|
+
}
|
|
13592
|
+
),
|
|
13593
|
+
/* @__PURE__ */ jsx("div", { className: "ns-offchain-register-actions", children: /* @__PURE__ */ jsx(Button, { className: "primary finish-btn", onClick: onFinish || onClose, children: "Finish" }) })
|
|
13594
|
+
] }) });
|
|
13595
|
+
}
|
|
13596
|
+
|
|
13597
|
+
function EnsOffChainRegisterModal({
|
|
13598
|
+
step: initialStep = 0,
|
|
13599
|
+
name: initialName = "",
|
|
13600
|
+
profileComplete = false,
|
|
13601
|
+
onStepChange,
|
|
13602
|
+
onNameChange,
|
|
13603
|
+
onProfileCompleteChange,
|
|
13604
|
+
onRegister,
|
|
13605
|
+
onCancel,
|
|
13606
|
+
onClose,
|
|
13607
|
+
onCompleteProfile,
|
|
13608
|
+
onOpenWallet,
|
|
13609
|
+
onCompleteRegistration,
|
|
13610
|
+
onRegisterAnother,
|
|
13611
|
+
onViewName
|
|
13612
|
+
}) {
|
|
13613
|
+
const [currentStep, setCurrentStep] = useState(initialStep);
|
|
13614
|
+
const [ensName, setEnsName] = useState(initialName);
|
|
13615
|
+
const handleNameChange = (value) => {
|
|
13616
|
+
setEnsName(value);
|
|
13617
|
+
onNameChange?.(value);
|
|
13618
|
+
};
|
|
13619
|
+
const handleRegister = () => {
|
|
13620
|
+
setCurrentStep(2);
|
|
13621
|
+
onStepChange?.(2);
|
|
13622
|
+
onRegister?.();
|
|
13623
|
+
};
|
|
13624
|
+
const handleCancel = () => {
|
|
13625
|
+
onCancel?.();
|
|
13626
|
+
};
|
|
13627
|
+
if (currentStep === 0) {
|
|
13628
|
+
return /* @__PURE__ */ jsx("div", { className: "ns-offchain-register-container", children: /* @__PURE__ */ jsx(
|
|
13629
|
+
InitialStep,
|
|
13630
|
+
{
|
|
13631
|
+
name: ensName,
|
|
13632
|
+
onNameChange: handleNameChange,
|
|
13633
|
+
onCancel: handleCancel,
|
|
13634
|
+
onRegister: handleRegister,
|
|
13635
|
+
onClose
|
|
13636
|
+
}
|
|
13637
|
+
) });
|
|
13638
|
+
}
|
|
13639
|
+
if (currentStep === 2) {
|
|
13640
|
+
return /* @__PURE__ */ jsx(
|
|
13641
|
+
OffchainSuccessScreen,
|
|
13642
|
+
{
|
|
13643
|
+
name: ensName,
|
|
13644
|
+
onClose,
|
|
13645
|
+
onSetProfile: onCompleteProfile,
|
|
13646
|
+
onFinish: onClose
|
|
13647
|
+
}
|
|
13648
|
+
);
|
|
13649
|
+
}
|
|
13650
|
+
return /* @__PURE__ */ jsx("div", { className: "ns-offchain-register-container", children: /* @__PURE__ */ jsx(
|
|
13651
|
+
InitialStep,
|
|
13652
|
+
{
|
|
13653
|
+
name: ensName,
|
|
13654
|
+
onNameChange: handleNameChange,
|
|
13655
|
+
onCancel: handleCancel,
|
|
13656
|
+
onRegister: handleRegister,
|
|
13657
|
+
onClose
|
|
13658
|
+
}
|
|
13659
|
+
) });
|
|
13660
|
+
}
|
|
13661
|
+
|
|
13662
|
+
function Header({ showBack = true, onBack, onClose }) {
|
|
13663
|
+
return /* @__PURE__ */ jsxs("div", { className: "ens-names-register-header", children: [
|
|
13664
|
+
showBack && /* @__PURE__ */ jsx("button", { className: "ens-names-register-back-btn", onClick: onBack, children: /* @__PURE__ */ jsx(ChevronLeft, { size: 20 }) }),
|
|
13665
|
+
/* @__PURE__ */ jsx("button", { className: "ens-names-register-close-btn", onClick: onClose, children: /* @__PURE__ */ jsx(Icon, { name: "x", size: 20 }) })
|
|
13666
|
+
] });
|
|
13667
|
+
}
|
|
13668
|
+
|
|
13669
|
+
function NameSearch({
|
|
13670
|
+
ensName,
|
|
13671
|
+
onNameChange,
|
|
13672
|
+
onBack,
|
|
13673
|
+
onClose,
|
|
13674
|
+
onNext
|
|
13675
|
+
}) {
|
|
13676
|
+
return /* @__PURE__ */ jsx("div", { className: "ens-names-register-container", children: /* @__PURE__ */ jsxs("div", { className: "ens-names-register-card", children: [
|
|
13677
|
+
/* @__PURE__ */ jsx(Header, { showBack: true, onBack, onClose }),
|
|
13678
|
+
/* @__PURE__ */ jsx("div", { className: "ens-names-register-banner", children: /* @__PURE__ */ jsx("img", { src: img$2, alt: "ENS Banner" }) }),
|
|
13679
|
+
/* @__PURE__ */ jsxs("div", { className: "ens-names-register-title-section", children: [
|
|
13680
|
+
/* @__PURE__ */ jsx(Text, { size: "xl", weight: "bold", className: "ens-names-register-title", children: "ENS Registration Registration" }),
|
|
13681
|
+
/* @__PURE__ */ jsx(Text, { size: "md", color: "grey", className: "ens-names-register-subtitle", children: "Register multiple ENS name is a single transaction" })
|
|
13682
|
+
] }),
|
|
13683
|
+
/* @__PURE__ */ jsxs("div", { className: "ens-names-register-input-row", children: [
|
|
13684
|
+
/* @__PURE__ */ jsx(
|
|
13685
|
+
Icon,
|
|
13686
|
+
{
|
|
13687
|
+
name: "search",
|
|
13688
|
+
size: 16,
|
|
13689
|
+
className: "ens-names-register-search-icon"
|
|
13690
|
+
}
|
|
13691
|
+
),
|
|
13692
|
+
/* @__PURE__ */ jsx(
|
|
13693
|
+
Input,
|
|
13694
|
+
{
|
|
13695
|
+
type: "text",
|
|
13696
|
+
className: "ens-names-register-input",
|
|
13697
|
+
value: ensName,
|
|
13698
|
+
onChange: (e) => onNameChange(e.target.value)
|
|
13699
|
+
}
|
|
13700
|
+
),
|
|
13701
|
+
/* @__PURE__ */ jsx(Text, { className: "ens-names-register-domain-suffix", children: ".eth" })
|
|
13702
|
+
] }),
|
|
13703
|
+
/* @__PURE__ */ jsx(
|
|
13704
|
+
Button,
|
|
13705
|
+
{
|
|
13706
|
+
className: "ens-names-register-next-btn",
|
|
13707
|
+
variant: "solid",
|
|
13708
|
+
size: "lg",
|
|
13709
|
+
onClick: onNext,
|
|
13710
|
+
children: "Next"
|
|
13711
|
+
}
|
|
13712
|
+
)
|
|
13713
|
+
] }) });
|
|
13714
|
+
}
|
|
13715
|
+
|
|
13716
|
+
function CostSummary({
|
|
13717
|
+
duration,
|
|
13718
|
+
registrationCost,
|
|
13719
|
+
networkFee,
|
|
13720
|
+
total,
|
|
13721
|
+
showExpiry = false,
|
|
13722
|
+
expiryDate
|
|
13723
|
+
}) {
|
|
13724
|
+
return /* @__PURE__ */ jsxs(
|
|
13725
|
+
"div",
|
|
13726
|
+
{
|
|
13727
|
+
className: `ens-names-register-${showExpiry ? "success-" : ""}summary`,
|
|
13728
|
+
children: [
|
|
13729
|
+
/* @__PURE__ */ jsxs(
|
|
13730
|
+
"div",
|
|
13731
|
+
{
|
|
13732
|
+
className: `ens-names-register-${showExpiry ? "success-" : ""}summary-row`,
|
|
13733
|
+
children: [
|
|
13734
|
+
/* @__PURE__ */ jsxs(Text, { size: "sm", children: [
|
|
13735
|
+
duration,
|
|
13736
|
+
" year registration"
|
|
13737
|
+
] }),
|
|
13738
|
+
/* @__PURE__ */ jsxs(Text, { size: "sm", weight: "bold", children: [
|
|
13739
|
+
registrationCost.toFixed(3),
|
|
13740
|
+
" ETH"
|
|
13741
|
+
] })
|
|
13742
|
+
]
|
|
13743
|
+
}
|
|
13744
|
+
),
|
|
13745
|
+
/* @__PURE__ */ jsxs(
|
|
13746
|
+
"div",
|
|
13747
|
+
{
|
|
13748
|
+
className: `ens-names-register-${showExpiry ? "success-" : ""}summary-row`,
|
|
13749
|
+
children: [
|
|
13750
|
+
/* @__PURE__ */ jsx(Text, { size: "sm", children: "Est. network fee" }),
|
|
13751
|
+
/* @__PURE__ */ jsxs(Text, { size: "sm", weight: "bold", children: [
|
|
13752
|
+
networkFee.toFixed(4),
|
|
13753
|
+
" ETH"
|
|
13754
|
+
] })
|
|
13755
|
+
]
|
|
13756
|
+
}
|
|
13757
|
+
),
|
|
13758
|
+
/* @__PURE__ */ jsxs(
|
|
13759
|
+
"div",
|
|
13760
|
+
{
|
|
13761
|
+
className: `ens-names-register-${showExpiry ? "success-" : ""}summary-row ens-names-register-${showExpiry ? "success-" : ""}total`,
|
|
13762
|
+
children: [
|
|
13763
|
+
/* @__PURE__ */ jsx(Text, { size: showExpiry ? "md" : "lg", weight: "bold", children: "Total" }),
|
|
13764
|
+
/* @__PURE__ */ jsxs(
|
|
13765
|
+
"div",
|
|
13766
|
+
{
|
|
13767
|
+
className: `ens-names-register-${showExpiry ? "success-" : ""}total-amount`,
|
|
13768
|
+
children: [
|
|
13769
|
+
/* @__PURE__ */ jsx(Text, { size: showExpiry ? "md" : "lg", weight: "bold", children: total.toFixed(4) }),
|
|
13770
|
+
/* @__PURE__ */ jsx("span", { className: "ens-names-register-eth-logo", children: "\u27E0" }),
|
|
13771
|
+
/* @__PURE__ */ jsx(Text, { size: showExpiry ? "md" : "lg", weight: "bold", children: "ETH" })
|
|
13772
|
+
]
|
|
13773
|
+
}
|
|
13774
|
+
)
|
|
13775
|
+
]
|
|
13776
|
+
}
|
|
13777
|
+
),
|
|
13778
|
+
showExpiry && expiryDate && /* @__PURE__ */ jsxs("div", { className: "ens-names-register-success-summary-row ens-names-register-success-expiry", children: [
|
|
13779
|
+
/* @__PURE__ */ jsx(Text, { size: "sm", children: "Name Expires" }),
|
|
13780
|
+
/* @__PURE__ */ jsx(Text, { size: "sm", weight: "bold", children: expiryDate })
|
|
13781
|
+
] })
|
|
13782
|
+
]
|
|
13783
|
+
}
|
|
13784
|
+
);
|
|
13785
|
+
}
|
|
13786
|
+
|
|
13787
|
+
function RegistrationForm({
|
|
13788
|
+
ensName,
|
|
13789
|
+
duration,
|
|
13790
|
+
registrationCost,
|
|
13791
|
+
networkFee,
|
|
13792
|
+
total,
|
|
13793
|
+
onNameChange,
|
|
13794
|
+
onDurationChange,
|
|
13795
|
+
onBack,
|
|
13796
|
+
onClose,
|
|
13797
|
+
onNext,
|
|
13798
|
+
onCompleteProfile
|
|
13799
|
+
}) {
|
|
13800
|
+
return /* @__PURE__ */ jsx("div", { className: "ens-names-register-container", children: /* @__PURE__ */ jsxs("div", { className: "ens-names-register-card", children: [
|
|
13801
|
+
/* @__PURE__ */ jsx(Header, { showBack: true, onBack, onClose }),
|
|
13802
|
+
/* @__PURE__ */ jsxs("div", { className: "ens-names-register-title-section", children: [
|
|
13803
|
+
/* @__PURE__ */ jsx(Text, { size: "xl", weight: "bold", className: "ens-names-register-title", children: "ENS Registration Registration" }),
|
|
13804
|
+
/* @__PURE__ */ jsx(Text, { size: "md", color: "grey", className: "ens-names-register-subtitle", children: "Register multiple ENS name is a single transaction" })
|
|
13805
|
+
] }),
|
|
13806
|
+
/* @__PURE__ */ jsxs("div", { className: "ens-names-register-input-row", children: [
|
|
13807
|
+
/* @__PURE__ */ jsx(
|
|
13808
|
+
Icon,
|
|
13809
|
+
{
|
|
13810
|
+
name: "search",
|
|
13811
|
+
size: 16,
|
|
13812
|
+
className: "ens-names-register-search-icon"
|
|
13813
|
+
}
|
|
13814
|
+
),
|
|
13815
|
+
/* @__PURE__ */ jsx(
|
|
13816
|
+
Input,
|
|
13817
|
+
{
|
|
13818
|
+
type: "text",
|
|
13819
|
+
className: "ens-names-register-input",
|
|
13820
|
+
value: ensName,
|
|
13821
|
+
onChange: (e) => onNameChange(e.target.value)
|
|
13822
|
+
}
|
|
13823
|
+
),
|
|
13824
|
+
/* @__PURE__ */ jsx(Text, { className: "ens-names-register-domain-suffix", children: ".eth" })
|
|
13825
|
+
] }),
|
|
13826
|
+
/* @__PURE__ */ jsxs("div", { className: "ens-names-register-cost-section", children: [
|
|
13827
|
+
/* @__PURE__ */ jsxs("div", { className: "ens-names-register-duration", children: [
|
|
13828
|
+
/* @__PURE__ */ jsx(
|
|
13829
|
+
"button",
|
|
13830
|
+
{
|
|
13831
|
+
className: "ens-names-register-duration-btn",
|
|
13832
|
+
onClick: () => onDurationChange(-1),
|
|
13833
|
+
children: /* @__PURE__ */ jsx(Text, { size: "md", weight: "bold", children: "-" })
|
|
13834
|
+
}
|
|
13835
|
+
),
|
|
13836
|
+
/* @__PURE__ */ jsxs(
|
|
13837
|
+
Text,
|
|
13838
|
+
{
|
|
13839
|
+
size: "lg",
|
|
13840
|
+
weight: "bold",
|
|
13841
|
+
className: "ens-names-register-duration-text",
|
|
13842
|
+
children: [
|
|
13843
|
+
duration,
|
|
13844
|
+
" year",
|
|
13845
|
+
duration > 1 ? "s" : ""
|
|
13846
|
+
]
|
|
13847
|
+
}
|
|
13848
|
+
),
|
|
13849
|
+
/* @__PURE__ */ jsx(
|
|
13850
|
+
"button",
|
|
13851
|
+
{
|
|
13852
|
+
className: "ens-names-register-duration-btn",
|
|
13853
|
+
onClick: () => onDurationChange(1),
|
|
13854
|
+
children: /* @__PURE__ */ jsx(Text, { size: "md", weight: "bold", children: "+" })
|
|
13855
|
+
}
|
|
13856
|
+
)
|
|
13857
|
+
] }),
|
|
13858
|
+
/* @__PURE__ */ jsx(
|
|
13859
|
+
CostSummary,
|
|
13860
|
+
{
|
|
13861
|
+
duration,
|
|
13862
|
+
registrationCost,
|
|
13863
|
+
networkFee,
|
|
13864
|
+
total
|
|
13865
|
+
}
|
|
13866
|
+
)
|
|
13867
|
+
] }),
|
|
13868
|
+
/* @__PURE__ */ jsxs(
|
|
13869
|
+
"div",
|
|
13870
|
+
{
|
|
13871
|
+
className: "ens-names-register-profile-card",
|
|
13872
|
+
onClick: onCompleteProfile,
|
|
13873
|
+
children: [
|
|
13874
|
+
/* @__PURE__ */ jsx("div", { className: "ens-names-register-profile-icon", children: /* @__PURE__ */ jsx("img", { src: img$1, alt: "Profile Icon" }) }),
|
|
13875
|
+
/* @__PURE__ */ jsxs("div", { className: "ens-names-register-profile-text", children: [
|
|
13876
|
+
/* @__PURE__ */ jsx(Text, { size: "md", weight: "bold", children: "Complete your profile" }),
|
|
13877
|
+
/* @__PURE__ */ jsx(Text, { size: "sm", color: "grey", children: "Make your ENS more discoverable" })
|
|
13878
|
+
] }),
|
|
13879
|
+
/* @__PURE__ */ jsx("button", { className: "ens-names-register-profile-arrow", children: /* @__PURE__ */ jsx(ChevronRight, { size: 20 }) })
|
|
13880
|
+
]
|
|
13881
|
+
}
|
|
13882
|
+
),
|
|
13883
|
+
/* @__PURE__ */ jsx(
|
|
13884
|
+
Button,
|
|
13885
|
+
{
|
|
13886
|
+
className: "ens-names-register-next-btn",
|
|
13887
|
+
variant: "solid",
|
|
13888
|
+
size: "lg",
|
|
13889
|
+
onClick: onNext,
|
|
13890
|
+
children: "Next"
|
|
13891
|
+
}
|
|
13892
|
+
)
|
|
13893
|
+
] }) });
|
|
13894
|
+
}
|
|
13895
|
+
|
|
13896
|
+
function StepItem({
|
|
13897
|
+
stepNumber,
|
|
13898
|
+
title,
|
|
13899
|
+
isExpanded,
|
|
13900
|
+
isCompleted,
|
|
13901
|
+
onToggle,
|
|
13902
|
+
children
|
|
13903
|
+
}) {
|
|
13904
|
+
return /* @__PURE__ */ jsxs("div", { className: `ens-names-register-step ${isExpanded ? "expanded" : ""}`, children: [
|
|
13905
|
+
/* @__PURE__ */ jsxs("div", { className: "ens-names-register-step-header", onClick: onToggle, children: [
|
|
13906
|
+
/* @__PURE__ */ jsx(
|
|
13907
|
+
"div",
|
|
13908
|
+
{
|
|
13909
|
+
className: `ens-names-register-step-number ${isCompleted ? "completed" : ""}`,
|
|
13910
|
+
children: isCompleted ? /* @__PURE__ */ jsx(Check, { size: 18, className: "ens-names-register-step-check" }) : /* @__PURE__ */ jsx("span", { className: isExpanded ? "active" : "", children: stepNumber })
|
|
13911
|
+
}
|
|
13912
|
+
),
|
|
13913
|
+
/* @__PURE__ */ jsx(Text, { size: "md", weight: "bold", className: "ens-names-register-step-title", children: title }),
|
|
13914
|
+
/* @__PURE__ */ jsx("div", { className: "ens-names-register-step-chevron", children: isExpanded ? /* @__PURE__ */ jsx(ChevronUp, { size: 20 }) : /* @__PURE__ */ jsx(ChevronDown, { size: 20 }) })
|
|
13915
|
+
] }),
|
|
13916
|
+
isExpanded && children && /* @__PURE__ */ jsx("div", { className: "ens-names-register-step-content", children })
|
|
13917
|
+
] });
|
|
13918
|
+
}
|
|
13919
|
+
|
|
13920
|
+
function ProgressBar({ progress }) {
|
|
13921
|
+
return /* @__PURE__ */ jsx("div", { className: "ens-names-register-progress-container", children: /* @__PURE__ */ jsx("div", { className: "ens-names-register-progress-bar", children: /* @__PURE__ */ jsx(
|
|
13922
|
+
"div",
|
|
13923
|
+
{
|
|
13924
|
+
className: "ens-names-register-progress-fill",
|
|
13925
|
+
style: { width: `${Math.min(progress, 100)}%` },
|
|
13926
|
+
children: /* @__PURE__ */ jsx(Sparkles, { size: 25, className: "ens-names-register-progress-sparkle" })
|
|
13927
|
+
}
|
|
13928
|
+
) }) });
|
|
13929
|
+
}
|
|
13930
|
+
|
|
13931
|
+
function Timer({ seconds, progress }) {
|
|
13932
|
+
const formatTime = (secs) => {
|
|
13933
|
+
const mins = Math.floor(secs / 60);
|
|
13934
|
+
const sec = secs % 60;
|
|
13935
|
+
return `${mins}:${sec.toString().padStart(2, "0")}`;
|
|
13936
|
+
};
|
|
13937
|
+
return /* @__PURE__ */ jsx("div", { className: "ens-names-register-timer-container", children: /* @__PURE__ */ jsxs("div", { className: "ens-names-register-timer-circle", children: [
|
|
13938
|
+
/* @__PURE__ */ jsxs("svg", { className: "ens-names-register-timer-svg", viewBox: "0 0 120 120", children: [
|
|
13939
|
+
/* @__PURE__ */ jsx(
|
|
13940
|
+
"circle",
|
|
13941
|
+
{
|
|
13942
|
+
cx: "60",
|
|
13943
|
+
cy: "60",
|
|
13944
|
+
r: "54",
|
|
13945
|
+
fill: "none",
|
|
13946
|
+
stroke: "#e5e7eb",
|
|
13947
|
+
strokeWidth: "8"
|
|
13948
|
+
}
|
|
13949
|
+
),
|
|
13950
|
+
/* @__PURE__ */ jsx(
|
|
13951
|
+
"circle",
|
|
13952
|
+
{
|
|
13953
|
+
cx: "60",
|
|
13954
|
+
cy: "60",
|
|
13955
|
+
r: "54",
|
|
13956
|
+
fill: "none",
|
|
13957
|
+
stroke: "#d1d5db",
|
|
13958
|
+
strokeWidth: "8",
|
|
13959
|
+
strokeDasharray: `${2 * Math.PI * 54}`,
|
|
13960
|
+
strokeDashoffset: `${2 * Math.PI * 54 * (1 - progress / 100)}`,
|
|
13961
|
+
strokeLinecap: "round",
|
|
13962
|
+
transform: "rotate(-90 60 60)",
|
|
13963
|
+
className: "ens-names-register-timer-progress"
|
|
13964
|
+
}
|
|
13965
|
+
)
|
|
13966
|
+
] }),
|
|
13967
|
+
/* @__PURE__ */ jsx("div", { className: "ens-names-register-timer-text", children: /* @__PURE__ */ jsx(Text, { size: "xl", weight: "bold", children: formatTime(seconds) }) })
|
|
13968
|
+
] }) });
|
|
13969
|
+
}
|
|
13970
|
+
|
|
13971
|
+
function RegistrationProcess({
|
|
13972
|
+
expandedStep,
|
|
13973
|
+
completedSteps,
|
|
13974
|
+
isTransactionInProgress,
|
|
13975
|
+
progress,
|
|
13976
|
+
timerSeconds,
|
|
13977
|
+
timerProgress,
|
|
13978
|
+
remainingHours,
|
|
13979
|
+
onBack,
|
|
13980
|
+
onClose,
|
|
13981
|
+
onToggleStep,
|
|
13982
|
+
onOpenWallet,
|
|
13983
|
+
onCompleteRegistration,
|
|
13984
|
+
onCompleteProfile
|
|
13985
|
+
}) {
|
|
13986
|
+
return /* @__PURE__ */ jsx("div", { className: "ens-names-register-container", children: /* @__PURE__ */ jsxs("div", { className: "ens-names-register-card", children: [
|
|
13987
|
+
/* @__PURE__ */ jsx(Header, { showBack: true, onBack, onClose }),
|
|
13988
|
+
/* @__PURE__ */ jsxs("div", { className: "ens-names-register-title-section", children: [
|
|
13989
|
+
/* @__PURE__ */ jsx(Text, { size: "xl", weight: "bold", className: "ens-names-register-title", children: "ENS Registration Process" }),
|
|
13990
|
+
/* @__PURE__ */ jsx(Text, { size: "md", color: "grey", className: "ens-names-register-subtitle", children: "Registration Consists of 3 Steps" })
|
|
13991
|
+
] }),
|
|
13992
|
+
/* @__PURE__ */ jsx(
|
|
13993
|
+
StepItem,
|
|
13994
|
+
{
|
|
13995
|
+
stepNumber: 1,
|
|
13996
|
+
title: "Commitment",
|
|
13997
|
+
isExpanded: expandedStep === 1,
|
|
13998
|
+
isCompleted: completedSteps.includes(1),
|
|
13999
|
+
onToggle: () => onToggleStep(1),
|
|
14000
|
+
children: !isTransactionInProgress ? /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
14001
|
+
/* @__PURE__ */ jsx(
|
|
14002
|
+
Text,
|
|
14003
|
+
{
|
|
14004
|
+
size: "lg",
|
|
14005
|
+
weight: "bold",
|
|
14006
|
+
className: "ens-names-register-step-content-title",
|
|
14007
|
+
children: "Start Your Journey"
|
|
14008
|
+
}
|
|
14009
|
+
),
|
|
14010
|
+
/* @__PURE__ */ jsx(
|
|
14011
|
+
Text,
|
|
14012
|
+
{
|
|
14013
|
+
size: "sm",
|
|
14014
|
+
color: "grey",
|
|
14015
|
+
className: "ens-names-register-step-content-description",
|
|
14016
|
+
children: "Kickstart your registration by completing a transaction. This action sets your timer and officially begins the process. Simply create the transaction in your wallet to move forward."
|
|
14017
|
+
}
|
|
14018
|
+
),
|
|
14019
|
+
/* @__PURE__ */ jsx(
|
|
14020
|
+
Button,
|
|
14021
|
+
{
|
|
14022
|
+
className: "ens-names-register-open-wallet-btn",
|
|
14023
|
+
variant: "solid",
|
|
14024
|
+
size: "lg",
|
|
14025
|
+
onClick: onOpenWallet,
|
|
14026
|
+
children: "Open Wallet"
|
|
14027
|
+
}
|
|
14028
|
+
)
|
|
14029
|
+
] }) : /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
14030
|
+
/* @__PURE__ */ jsx(
|
|
14031
|
+
Text,
|
|
14032
|
+
{
|
|
14033
|
+
size: "lg",
|
|
14034
|
+
weight: "bold",
|
|
14035
|
+
className: "ens-names-register-step-content-title",
|
|
14036
|
+
children: "Transaction in Progress"
|
|
14037
|
+
}
|
|
14038
|
+
),
|
|
14039
|
+
/* @__PURE__ */ jsx(
|
|
14040
|
+
Text,
|
|
14041
|
+
{
|
|
14042
|
+
size: "sm",
|
|
14043
|
+
color: "grey",
|
|
14044
|
+
className: "ens-names-register-step-content-description",
|
|
14045
|
+
children: "Your transaction has been sent! The timer is now running. Once the progress bar completes, your registration will be confirmed."
|
|
14046
|
+
}
|
|
14047
|
+
),
|
|
14048
|
+
/* @__PURE__ */ jsx(ProgressBar, { progress })
|
|
14049
|
+
] })
|
|
14050
|
+
}
|
|
14051
|
+
),
|
|
14052
|
+
/* @__PURE__ */ jsxs(
|
|
14053
|
+
StepItem,
|
|
14054
|
+
{
|
|
14055
|
+
stepNumber: 2,
|
|
14056
|
+
title: "Time Started",
|
|
14057
|
+
isExpanded: expandedStep === 2,
|
|
14058
|
+
isCompleted: completedSteps.includes(2),
|
|
14059
|
+
onToggle: () => onToggleStep(2),
|
|
14060
|
+
children: [
|
|
14061
|
+
/* @__PURE__ */ jsx(
|
|
14062
|
+
Text,
|
|
14063
|
+
{
|
|
14064
|
+
size: "lg",
|
|
14065
|
+
weight: "bold",
|
|
14066
|
+
className: "ens-names-register-step-content-title",
|
|
14067
|
+
children: "Waiting..."
|
|
14068
|
+
}
|
|
14069
|
+
),
|
|
14070
|
+
/* @__PURE__ */ jsx(
|
|
14071
|
+
Text,
|
|
14072
|
+
{
|
|
14073
|
+
size: "sm",
|
|
14074
|
+
color: "grey",
|
|
14075
|
+
className: "ens-names-register-step-content-description",
|
|
14076
|
+
children: "This wait prevents others from front running your transaction. You will be prompted to complete a second transaction when the timer is complete."
|
|
14077
|
+
}
|
|
14078
|
+
),
|
|
14079
|
+
/* @__PURE__ */ jsx(Timer, { seconds: timerSeconds, progress: timerProgress })
|
|
14080
|
+
]
|
|
14081
|
+
}
|
|
14082
|
+
),
|
|
14083
|
+
/* @__PURE__ */ jsxs(
|
|
14084
|
+
StepItem,
|
|
14085
|
+
{
|
|
14086
|
+
stepNumber: 3,
|
|
14087
|
+
title: "Complete Registration",
|
|
14088
|
+
isExpanded: expandedStep === 3,
|
|
14089
|
+
isCompleted: false,
|
|
14090
|
+
onToggle: () => onToggleStep(3),
|
|
14091
|
+
children: [
|
|
14092
|
+
/* @__PURE__ */ jsx(
|
|
14093
|
+
Text,
|
|
14094
|
+
{
|
|
14095
|
+
size: "lg",
|
|
14096
|
+
weight: "bold",
|
|
14097
|
+
className: "ens-names-register-step-content-title",
|
|
14098
|
+
children: "Register name"
|
|
14099
|
+
}
|
|
14100
|
+
),
|
|
14101
|
+
/* @__PURE__ */ jsxs(
|
|
14102
|
+
Text,
|
|
14103
|
+
{
|
|
14104
|
+
size: "sm",
|
|
14105
|
+
color: "grey",
|
|
14106
|
+
className: "ens-names-register-step-content-description",
|
|
14107
|
+
children: [
|
|
14108
|
+
"Your name is not registered until you've completed the second transaction. You have ",
|
|
14109
|
+
remainingHours,
|
|
14110
|
+
" hours remaining to complete it."
|
|
14111
|
+
]
|
|
14112
|
+
}
|
|
14113
|
+
),
|
|
14114
|
+
/* @__PURE__ */ jsx(
|
|
14115
|
+
Button,
|
|
14116
|
+
{
|
|
14117
|
+
className: "ens-names-register-complete-btn",
|
|
14118
|
+
variant: "solid",
|
|
14119
|
+
size: "lg",
|
|
14120
|
+
onClick: onCompleteRegistration,
|
|
14121
|
+
children: "Complete Registration"
|
|
14122
|
+
}
|
|
14123
|
+
)
|
|
14124
|
+
]
|
|
14125
|
+
}
|
|
14126
|
+
),
|
|
14127
|
+
/* @__PURE__ */ jsx(
|
|
14128
|
+
"div",
|
|
14129
|
+
{
|
|
14130
|
+
className: "ens-names-register-footer-link",
|
|
14131
|
+
onClick: onCompleteProfile,
|
|
14132
|
+
children: /* @__PURE__ */ jsx(Text, { size: "sm", color: "grey", children: "I'd like to set up my profile first" })
|
|
14133
|
+
}
|
|
14134
|
+
)
|
|
14135
|
+
] }) });
|
|
14136
|
+
}
|
|
14137
|
+
|
|
14138
|
+
function SuccessScreen({
|
|
14139
|
+
ensName,
|
|
14140
|
+
duration,
|
|
14141
|
+
registrationCost,
|
|
14142
|
+
networkFee,
|
|
14143
|
+
total,
|
|
14144
|
+
expiryDate,
|
|
14145
|
+
onClose,
|
|
14146
|
+
onRegisterAnother,
|
|
14147
|
+
onViewName
|
|
14148
|
+
}) {
|
|
14149
|
+
return /* @__PURE__ */ jsx("div", { className: "ens-names-register-container", children: /* @__PURE__ */ jsxs("div", { className: "ens-names-register-card ens-names-register-success-card", children: [
|
|
14150
|
+
/* @__PURE__ */ jsx(Header, { showBack: false, onClose }),
|
|
14151
|
+
/* @__PURE__ */ jsx("div", { className: "ens-names-register-success-illustration", children: /* @__PURE__ */ jsx("img", { src: img, alt: "Success Illustration" }) }),
|
|
14152
|
+
/* @__PURE__ */ jsxs("div", { className: "ens-names-register-success-title-section", children: [
|
|
14153
|
+
/* @__PURE__ */ jsx(
|
|
14154
|
+
Text,
|
|
14155
|
+
{
|
|
14156
|
+
size: "lg",
|
|
14157
|
+
weight: "bold",
|
|
14158
|
+
className: "ens-names-register-success-message",
|
|
14159
|
+
children: "Hooray! You've registered"
|
|
14160
|
+
}
|
|
14161
|
+
),
|
|
14162
|
+
/* @__PURE__ */ jsxs(
|
|
14163
|
+
Text,
|
|
14164
|
+
{
|
|
14165
|
+
size: "xl",
|
|
14166
|
+
weight: "bold",
|
|
14167
|
+
className: "ens-names-register-success-name",
|
|
14168
|
+
children: [
|
|
14169
|
+
ensName,
|
|
14170
|
+
".eth"
|
|
14171
|
+
]
|
|
14172
|
+
}
|
|
14173
|
+
)
|
|
14174
|
+
] }),
|
|
14175
|
+
/* @__PURE__ */ jsx("div", { className: "ens-names-register-success-summary", children: /* @__PURE__ */ jsx(
|
|
14176
|
+
CostSummary,
|
|
14177
|
+
{
|
|
14178
|
+
duration,
|
|
14179
|
+
registrationCost,
|
|
14180
|
+
networkFee,
|
|
14181
|
+
total,
|
|
14182
|
+
showExpiry: true,
|
|
14183
|
+
expiryDate
|
|
14184
|
+
}
|
|
14185
|
+
) }),
|
|
14186
|
+
/* @__PURE__ */ jsxs("div", { className: "ens-names-register-success-actions", children: [
|
|
14187
|
+
/* @__PURE__ */ jsx(
|
|
14188
|
+
Button,
|
|
14189
|
+
{
|
|
14190
|
+
className: "ens-names-register-register-another-btn",
|
|
14191
|
+
variant: "outline",
|
|
14192
|
+
size: "lg",
|
|
14193
|
+
onClick: onRegisterAnother,
|
|
14194
|
+
children: "Register another"
|
|
14195
|
+
}
|
|
14196
|
+
),
|
|
14197
|
+
/* @__PURE__ */ jsx(
|
|
14198
|
+
Button,
|
|
14199
|
+
{
|
|
14200
|
+
className: "ens-names-register-view-name-btn",
|
|
14201
|
+
variant: "solid",
|
|
14202
|
+
size: "lg",
|
|
14203
|
+
onClick: onViewName,
|
|
14204
|
+
children: "View Name"
|
|
14205
|
+
}
|
|
14206
|
+
)
|
|
14207
|
+
] })
|
|
14208
|
+
] }) });
|
|
14209
|
+
}
|
|
14210
|
+
|
|
14211
|
+
function ENSNamesRegisterComponent({
|
|
14212
|
+
name = "brightwave",
|
|
14213
|
+
duration: initialDuration = 1,
|
|
14214
|
+
onNameChange,
|
|
14215
|
+
onDurationChange,
|
|
14216
|
+
onBack,
|
|
14217
|
+
onClose,
|
|
14218
|
+
onNext,
|
|
14219
|
+
onCompleteProfile,
|
|
14220
|
+
onOpenWallet,
|
|
14221
|
+
onCompleteRegistration,
|
|
14222
|
+
onRegisterAnother,
|
|
14223
|
+
onViewName
|
|
14224
|
+
}) {
|
|
14225
|
+
const [duration, setDuration] = useState(initialDuration);
|
|
14226
|
+
const [ensName, setEnsName] = useState(name);
|
|
14227
|
+
const [currentStep, setCurrentStep] = useState(0);
|
|
14228
|
+
const [expandedStep, setExpandedStep] = useState(1);
|
|
14229
|
+
const [isTransactionInProgress, setIsTransactionInProgress] = useState(false);
|
|
14230
|
+
const [progress, setProgress] = useState(0);
|
|
14231
|
+
const [timerSeconds, setTimerSeconds] = useState(60);
|
|
14232
|
+
const [isTimerActive, setIsTimerActive] = useState(false);
|
|
14233
|
+
const [completedSteps, setCompletedSteps] = useState([]);
|
|
14234
|
+
const [remainingHours, setRemainingHours] = useState(23);
|
|
14235
|
+
const getExpiryDate = () => {
|
|
14236
|
+
const now = /* @__PURE__ */ new Date();
|
|
14237
|
+
const expiryDate = new Date(now);
|
|
14238
|
+
expiryDate.setFullYear(now.getFullYear() + duration);
|
|
14239
|
+
const months = [
|
|
14240
|
+
"January",
|
|
14241
|
+
"February",
|
|
14242
|
+
"March",
|
|
14243
|
+
"April",
|
|
14244
|
+
"May",
|
|
14245
|
+
"June",
|
|
14246
|
+
"July",
|
|
14247
|
+
"August",
|
|
14248
|
+
"September",
|
|
14249
|
+
"October",
|
|
14250
|
+
"November",
|
|
14251
|
+
"December"
|
|
14252
|
+
];
|
|
14253
|
+
const month = months[expiryDate.getMonth()];
|
|
14254
|
+
const day = expiryDate.getDate();
|
|
14255
|
+
const year = expiryDate.getFullYear();
|
|
14256
|
+
return `${month} ${day}, ${year}`;
|
|
14257
|
+
};
|
|
14258
|
+
useEffect(() => {
|
|
14259
|
+
if (isTransactionInProgress) {
|
|
14260
|
+
const interval = setInterval(() => {
|
|
14261
|
+
setProgress((prev) => {
|
|
14262
|
+
if (prev >= 100) {
|
|
14263
|
+
clearInterval(interval);
|
|
14264
|
+
setIsTimerActive(true);
|
|
14265
|
+
setCompletedSteps([1]);
|
|
14266
|
+
return 100;
|
|
14267
|
+
}
|
|
14268
|
+
return prev + 0.5;
|
|
14269
|
+
});
|
|
14270
|
+
}, 50);
|
|
14271
|
+
return () => clearInterval(interval);
|
|
14272
|
+
}
|
|
14273
|
+
}, [isTransactionInProgress]);
|
|
14274
|
+
useEffect(() => {
|
|
14275
|
+
if (isTimerActive && timerSeconds > 0) {
|
|
14276
|
+
const interval = setInterval(() => {
|
|
14277
|
+
setTimerSeconds((prev) => {
|
|
14278
|
+
if (prev <= 1) {
|
|
14279
|
+
clearInterval(interval);
|
|
14280
|
+
setIsTimerActive(false);
|
|
14281
|
+
setCompletedSteps([1, 2]);
|
|
14282
|
+
setExpandedStep(3);
|
|
14283
|
+
return 0;
|
|
14284
|
+
}
|
|
14285
|
+
return prev - 1;
|
|
14286
|
+
});
|
|
14287
|
+
}, 1e3);
|
|
14288
|
+
return () => clearInterval(interval);
|
|
14289
|
+
}
|
|
14290
|
+
}, [isTimerActive, timerSeconds]);
|
|
14291
|
+
const handleDurationChange = (delta) => {
|
|
14292
|
+
const newDuration = Math.max(1, duration + delta);
|
|
14293
|
+
setDuration(newDuration);
|
|
14294
|
+
onDurationChange?.(newDuration);
|
|
14295
|
+
};
|
|
14296
|
+
const handleNameChange = (value) => {
|
|
14297
|
+
setEnsName(value);
|
|
14298
|
+
onNameChange?.(value);
|
|
14299
|
+
};
|
|
14300
|
+
const handleNameSearchNext = () => {
|
|
14301
|
+
setCurrentStep(1);
|
|
14302
|
+
onNext?.();
|
|
14303
|
+
};
|
|
14304
|
+
const handleNext = () => {
|
|
14305
|
+
setCurrentStep(2);
|
|
14306
|
+
onNext?.();
|
|
14307
|
+
};
|
|
14308
|
+
const handleBackToForm = () => {
|
|
14309
|
+
setCurrentStep(1);
|
|
14310
|
+
setIsTransactionInProgress(false);
|
|
14311
|
+
setProgress(0);
|
|
14312
|
+
setIsTimerActive(false);
|
|
14313
|
+
setTimerSeconds(60);
|
|
14314
|
+
setCompletedSteps([]);
|
|
14315
|
+
onBack?.();
|
|
14316
|
+
};
|
|
14317
|
+
const toggleStep = (stepNumber) => {
|
|
14318
|
+
setExpandedStep(expandedStep === stepNumber ? 0 : stepNumber);
|
|
14319
|
+
};
|
|
14320
|
+
const handleOpenWallet = () => {
|
|
14321
|
+
setIsTransactionInProgress(true);
|
|
14322
|
+
setProgress(0);
|
|
14323
|
+
onOpenWallet?.();
|
|
14324
|
+
};
|
|
14325
|
+
const handleCompleteRegistration = () => {
|
|
14326
|
+
setCurrentStep(3);
|
|
14327
|
+
onCompleteRegistration?.();
|
|
14328
|
+
};
|
|
14329
|
+
const handleRegisterAnother = () => {
|
|
14330
|
+
setCurrentStep(0);
|
|
14331
|
+
setIsTransactionInProgress(false);
|
|
14332
|
+
setProgress(0);
|
|
14333
|
+
setIsTimerActive(false);
|
|
14334
|
+
setTimerSeconds(60);
|
|
14335
|
+
setCompletedSteps([]);
|
|
14336
|
+
setExpandedStep(1);
|
|
14337
|
+
onRegisterAnother?.();
|
|
14338
|
+
};
|
|
14339
|
+
const timerProgress = (60 - timerSeconds) / 60 * 100;
|
|
14340
|
+
const registrationCost = 4e-3 * duration;
|
|
14341
|
+
const networkFee = 1e-3;
|
|
14342
|
+
const total = registrationCost + networkFee;
|
|
14343
|
+
if (currentStep === 0) {
|
|
14344
|
+
return /* @__PURE__ */ jsx(
|
|
14345
|
+
NameSearch,
|
|
14346
|
+
{
|
|
14347
|
+
ensName,
|
|
14348
|
+
onNameChange: handleNameChange,
|
|
14349
|
+
onBack,
|
|
14350
|
+
onClose,
|
|
14351
|
+
onNext: handleNameSearchNext
|
|
14352
|
+
}
|
|
14353
|
+
);
|
|
14354
|
+
}
|
|
14355
|
+
if (currentStep === 1) {
|
|
14356
|
+
return /* @__PURE__ */ jsx(
|
|
14357
|
+
RegistrationForm,
|
|
14358
|
+
{
|
|
14359
|
+
ensName,
|
|
14360
|
+
duration,
|
|
14361
|
+
registrationCost,
|
|
14362
|
+
networkFee,
|
|
14363
|
+
total,
|
|
14364
|
+
onNameChange: handleNameChange,
|
|
14365
|
+
onDurationChange: handleDurationChange,
|
|
14366
|
+
onBack: () => setCurrentStep(0),
|
|
14367
|
+
onClose,
|
|
14368
|
+
onNext: handleNext,
|
|
14369
|
+
onCompleteProfile
|
|
14370
|
+
}
|
|
14371
|
+
);
|
|
14372
|
+
}
|
|
14373
|
+
if (currentStep === 3) {
|
|
14374
|
+
return /* @__PURE__ */ jsx(
|
|
14375
|
+
SuccessScreen,
|
|
14376
|
+
{
|
|
14377
|
+
ensName,
|
|
14378
|
+
duration,
|
|
14379
|
+
registrationCost,
|
|
14380
|
+
networkFee,
|
|
14381
|
+
total,
|
|
14382
|
+
expiryDate: getExpiryDate(),
|
|
14383
|
+
onClose,
|
|
14384
|
+
onRegisterAnother: handleRegisterAnother,
|
|
14385
|
+
onViewName: onViewName || (() => {
|
|
14386
|
+
})
|
|
14387
|
+
}
|
|
14388
|
+
);
|
|
14389
|
+
}
|
|
14390
|
+
return /* @__PURE__ */ jsx(
|
|
14391
|
+
RegistrationProcess,
|
|
14392
|
+
{
|
|
14393
|
+
expandedStep,
|
|
14394
|
+
completedSteps,
|
|
14395
|
+
isTransactionInProgress,
|
|
14396
|
+
progress,
|
|
14397
|
+
timerSeconds,
|
|
14398
|
+
timerProgress,
|
|
14399
|
+
remainingHours,
|
|
14400
|
+
onBack: handleBackToForm,
|
|
14401
|
+
onClose,
|
|
14402
|
+
onToggleStep: toggleStep,
|
|
14403
|
+
onOpenWallet: handleOpenWallet,
|
|
14404
|
+
onCompleteRegistration: handleCompleteRegistration,
|
|
14405
|
+
onCompleteProfile
|
|
14406
|
+
}
|
|
14407
|
+
);
|
|
14408
|
+
}
|
|
14409
|
+
|
|
12726
14410
|
const useWaitForTransaction = ({
|
|
12727
14411
|
chainId: number
|
|
12728
14412
|
}) => {
|
|
@@ -12783,5 +14467,5 @@ const useTheme = () => {
|
|
|
12783
14467
|
return ctx;
|
|
12784
14468
|
};
|
|
12785
14469
|
|
|
12786
|
-
export { Alert, Button, Card, ChainIcon, ContenthashIcon, ContenthashProtocol, Dropdown, ENSNameCard, ENS_RESOLVER_ABI, Icon, Input, MULTICALL, Modal, NavbarProfileCard, PendingTransaction, ProfileCard, ProfileHeader, SET_ADDRESS_FUNC, SET_CONTENTHASH_FUNC, SET_TEXT_FUNC, SelectRecordsForm, Text, TextRecordCategory, Textarea, ThemeProvider, Tooltip, TransactionState, capitalize, convertEVMChainIdToCoinType, deepCopy, equalsIgnoreCase, getEnsRecordsDiff, getSupportedAddressByCoin, getSupportedAddressByName, getSupportedAddressMap, getSupportedChashByProtocol, getSupportedText, isContenthashValid, supportedAddresses, supportedContenthashRecords, supportedTexts, useTheme, useWaitForTransaction, useWeb3Client };
|
|
14470
|
+
export { Alert, Button, Card, ChainIcon, ContenthashIcon, ContenthashProtocol, Dropdown, ENSNameCard, ENSNamesRegisterComponent, ENS_RESOLVER_ABI, EnsOffChainRegisterModal, EnsOnChainRegisterModal, Icon, Input, MULTICALL, Modal, NavbarProfileCard, PendingTransaction, ProfileCard, ProfileHeader, SET_ADDRESS_FUNC, SET_CONTENTHASH_FUNC, SET_TEXT_FUNC, SelectRecordsForm, Text, TextRecordCategory, Textarea, ThemeProvider, Tooltip, TransactionState, capitalize, convertEVMChainIdToCoinType, deepCopy, equalsIgnoreCase, getEnsRecordsDiff, getSupportedAddressByCoin, getSupportedAddressByName, getSupportedAddressMap, getSupportedChashByProtocol, getSupportedText, isContenthashValid, supportedAddresses, supportedContenthashRecords, supportedTexts, useTheme, useWaitForTransaction, useWeb3Client };
|
|
12787
14471
|
//# sourceMappingURL=index.js.map
|