@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.
Files changed (29) hide show
  1. package/dist/index.css +1792 -1
  2. package/dist/index.css.map +1 -1
  3. package/dist/index.d.ts +7168 -290
  4. package/dist/index.js +1732 -48
  5. package/dist/index.js.map +1 -1
  6. package/dist/styles.js +1 -1
  7. package/dist/types/components/atoms/icon/custom/SearchIcon.d.ts +6 -0
  8. package/dist/types/components/ens-names-register-component/ENSNamesRegisterComponent.d.ts +17 -0
  9. package/dist/types/components/ens-names-register-component/sub-components/CostSummary.d.ts +10 -0
  10. package/dist/types/components/ens-names-register-component/sub-components/Header.d.ts +7 -0
  11. package/dist/types/components/ens-names-register-component/sub-components/NameSearch.d.ts +9 -0
  12. package/dist/types/components/ens-names-register-component/sub-components/ProgressBar.d.ts +5 -0
  13. package/dist/types/components/ens-names-register-component/sub-components/RegistrationForm.d.ts +15 -0
  14. package/dist/types/components/ens-names-register-component/sub-components/RegistrationProcess.d.ts +17 -0
  15. package/dist/types/components/ens-names-register-component/sub-components/StepItem.d.ts +11 -0
  16. package/dist/types/components/ens-names-register-component/sub-components/SuccessScreen.d.ts +13 -0
  17. package/dist/types/components/ens-names-register-component/sub-components/Timer.d.ts +6 -0
  18. package/dist/types/components/ens-offchain-register-modal/EnsOffChainRegisterModal.d.ts +18 -0
  19. package/dist/types/components/ens-offchain-register-modal/sub-components/InitialStep.d.ts +9 -0
  20. package/dist/types/components/ens-offchain-register-modal/sub-components/OffchainRegistrationProcess.d.ts +18 -0
  21. package/dist/types/components/ens-offchain-register-modal/sub-components/OffchainSuccessScreen.d.ts +8 -0
  22. package/dist/types/components/ens-onchain-register-modal/EnsOnChainRegisterModal.d.ts +30 -0
  23. package/dist/types/components/ens-onchain-register-modal/sub-components/ConfirmationStep.d.ts +18 -0
  24. package/dist/types/components/ens-onchain-register-modal/sub-components/InitialStep.d.ts +10 -0
  25. package/dist/types/components/ens-onchain-register-modal/sub-components/OnchainSuccessScreen.d.ts +6 -0
  26. package/dist/types/components/ens-onchain-register-modal/sub-components/RegistrationStep.d.ts +22 -0
  27. package/dist/types/components/index.d.ts +3 -0
  28. package/dist/types/hooks/useWeb3Clients.d.ts +4 -4
  29. 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$l = [
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$l);
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$k = [
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$k);
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$j = [
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$j);
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$i = [
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$i);
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$h = [
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$h);
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$g = [
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$g);
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$f = [
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$f);
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$e = [
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$e);
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$d = [
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$d);
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$c = [
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$c);
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$b = [
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$b);
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$a = [
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$a);
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$9 = [
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$9);
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$8 = [
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$8);
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$7 = [
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$7);
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$6 = [
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$6);
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$5 = [
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$5);
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(void 0);
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(protocolPrefix.length, protocolPrefix.length);
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(contenthash.value, contenthash.protocol),
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("div", { style: { zIndex: 10 }, onClick: (e) => {
12255
- e.stopPropagation();
12256
- if (!headerRecordSet) {
12257
- onHeaderAdded("");
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
- }, className: "ns-header-handle", children: /* @__PURE__ */ jsx(Icon, { color: "white", name: "rotate-circle" }) }),
12260
- /* @__PURE__ */ jsx("div", { style: avatarStyles, className: "ns-avatar-record-cont", children: !avatarRecordSet && /* @__PURE__ */ jsx("div", { style: { zIndex: 10 }, onClick: (e) => {
12261
- e.stopPropagation();
12262
- if (!avatarRecordSet) {
12263
- onAvatarAdded("");
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
- }, className: "ns-image-handle", children: /* @__PURE__ */ jsx(Icon, { color: "grey", name: "rotate-circle" }) }) })
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