@xyo-network/react-address-render 2.64.0-rc.7 → 2.64.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 (148) hide show
  1. package/dist/browser/components/RenderRowBox.cjs +239 -0
  2. package/dist/browser/components/RenderRowBox.cjs.map +1 -0
  3. package/dist/browser/components/RenderRowBox.d.cts +14 -0
  4. package/dist/browser/components/RenderRowBox.d.cts.map +1 -0
  5. package/dist/browser/components/favorite/FavoriteIconButton.cjs +191 -0
  6. package/dist/browser/components/favorite/FavoriteIconButton.cjs.map +1 -0
  7. package/dist/browser/components/favorite/FavoriteIconButton.d.cts +12 -0
  8. package/dist/browser/components/favorite/FavoriteIconButton.d.cts.map +1 -0
  9. package/dist/browser/components/favorite/FavoriteToggleSVG.cjs +29 -0
  10. package/dist/{node/components/favorite/FavoriteToggleSVG.mjs.map → browser/components/favorite/FavoriteToggleSVG.cjs.map} +1 -1
  11. package/dist/browser/components/favorite/FavoriteToggleSVG.d.cts +5 -0
  12. package/dist/browser/components/favorite/FavoriteToggleSVG.d.cts.map +1 -0
  13. package/dist/browser/components/favorite/Popper.cjs +112 -0
  14. package/dist/browser/components/favorite/Popper.cjs.map +1 -0
  15. package/dist/browser/components/favorite/Popper.d.cts +11 -0
  16. package/dist/browser/components/favorite/Popper.d.cts.map +1 -0
  17. package/dist/browser/components/favorite/PopperButtonGroup.cjs +57 -0
  18. package/dist/browser/components/favorite/PopperButtonGroup.cjs.map +1 -0
  19. package/dist/browser/components/favorite/PopperButtonGroup.d.cts +9 -0
  20. package/dist/browser/components/favorite/PopperButtonGroup.d.cts.map +1 -0
  21. package/dist/browser/components/favorite/index.cjs +193 -0
  22. package/dist/browser/components/favorite/index.cjs.map +1 -0
  23. package/dist/browser/components/favorite/index.d.cts +2 -0
  24. package/dist/browser/components/favorite/index.d.cts.map +1 -0
  25. package/dist/browser/components/favorite/lib/PopperId.cjs +27 -0
  26. package/dist/{node/components/favorite/lib/PopperId.mjs.map → browser/components/favorite/lib/PopperId.cjs.map} +1 -1
  27. package/dist/browser/components/favorite/lib/PopperId.d.cts +2 -0
  28. package/dist/browser/components/favorite/lib/PopperId.d.cts.map +1 -0
  29. package/dist/browser/components/favorite/lib/index.cjs +29 -0
  30. package/dist/browser/components/favorite/lib/index.cjs.map +1 -0
  31. package/dist/browser/components/favorite/lib/index.d.cts +2 -0
  32. package/dist/browser/components/favorite/lib/index.d.cts.map +1 -0
  33. package/dist/browser/components/index.cjs +241 -0
  34. package/dist/browser/components/index.cjs.map +1 -0
  35. package/dist/browser/components/index.d.cts +4 -0
  36. package/dist/browser/components/index.d.cts.map +1 -0
  37. package/dist/browser/components/lib/FavoriteItemEvent.cjs +32 -0
  38. package/dist/{node/components/lib/FavoriteItemEvent.mjs.map → browser/components/lib/FavoriteItemEvent.cjs.map} +1 -1
  39. package/dist/browser/components/lib/FavoriteItemEvent.d.cts +9 -0
  40. package/dist/browser/components/lib/FavoriteItemEvent.d.cts.map +1 -0
  41. package/dist/browser/components/lib/index.cjs +34 -0
  42. package/dist/browser/components/lib/index.cjs.map +1 -0
  43. package/dist/browser/components/lib/index.d.cts +2 -0
  44. package/dist/browser/components/lib/index.d.cts.map +1 -0
  45. package/dist/browser/index.cjs +241 -0
  46. package/dist/browser/index.cjs.map +1 -0
  47. package/dist/browser/index.d.cts +2 -0
  48. package/dist/browser/index.d.cts.map +1 -0
  49. package/dist/docs.json +24106 -0
  50. package/dist/node/components/RenderRowBox.cjs +243 -0
  51. package/dist/node/components/RenderRowBox.cjs.map +1 -0
  52. package/dist/node/components/RenderRowBox.d.cts +14 -0
  53. package/dist/node/components/RenderRowBox.d.cts.map +1 -0
  54. package/dist/node/components/RenderRowBox.js +187 -42
  55. package/dist/node/components/RenderRowBox.js.map +1 -1
  56. package/dist/node/components/favorite/FavoriteIconButton.cjs +195 -0
  57. package/dist/node/components/favorite/FavoriteIconButton.cjs.map +1 -0
  58. package/dist/node/components/favorite/FavoriteIconButton.d.cts +12 -0
  59. package/dist/node/components/favorite/FavoriteIconButton.d.cts.map +1 -0
  60. package/dist/node/components/favorite/FavoriteIconButton.js +123 -47
  61. package/dist/node/components/favorite/FavoriteIconButton.js.map +1 -1
  62. package/dist/node/components/favorite/FavoriteToggleSVG.cjs +33 -0
  63. package/dist/node/components/favorite/FavoriteToggleSVG.cjs.map +1 -0
  64. package/dist/node/components/favorite/FavoriteToggleSVG.d.cts +5 -0
  65. package/dist/node/components/favorite/FavoriteToggleSVG.d.cts.map +1 -0
  66. package/dist/node/components/favorite/FavoriteToggleSVG.js +6 -29
  67. package/dist/node/components/favorite/FavoriteToggleSVG.js.map +1 -1
  68. package/dist/node/components/favorite/Popper.cjs +116 -0
  69. package/dist/node/components/favorite/Popper.cjs.map +1 -0
  70. package/dist/node/components/favorite/Popper.d.cts +11 -0
  71. package/dist/node/components/favorite/Popper.d.cts.map +1 -0
  72. package/dist/node/components/favorite/Popper.js +54 -41
  73. package/dist/node/components/favorite/Popper.js.map +1 -1
  74. package/dist/node/components/favorite/PopperButtonGroup.cjs +61 -0
  75. package/dist/node/components/favorite/{PopperButtonGroup.mjs.map → PopperButtonGroup.cjs.map} +1 -1
  76. package/dist/node/components/favorite/PopperButtonGroup.d.cts +9 -0
  77. package/dist/node/components/favorite/PopperButtonGroup.d.cts.map +1 -0
  78. package/dist/node/components/favorite/PopperButtonGroup.js +16 -39
  79. package/dist/node/components/favorite/PopperButtonGroup.js.map +1 -1
  80. package/dist/node/components/favorite/index.cjs +197 -0
  81. package/dist/node/components/favorite/index.cjs.map +1 -0
  82. package/dist/node/components/favorite/index.d.cts +2 -0
  83. package/dist/node/components/favorite/index.d.cts.map +1 -0
  84. package/dist/node/components/favorite/index.js +167 -20
  85. package/dist/node/components/favorite/index.js.map +1 -1
  86. package/dist/node/components/favorite/lib/PopperId.cjs +31 -0
  87. package/dist/node/components/favorite/lib/PopperId.cjs.map +1 -0
  88. package/dist/node/components/favorite/lib/PopperId.d.cts +2 -0
  89. package/dist/node/components/favorite/lib/PopperId.d.cts.map +1 -0
  90. package/dist/node/components/favorite/lib/PopperId.js +4 -27
  91. package/dist/node/components/favorite/lib/PopperId.js.map +1 -1
  92. package/dist/node/components/favorite/lib/index.cjs +33 -0
  93. package/dist/node/components/favorite/lib/index.cjs.map +1 -0
  94. package/dist/node/components/favorite/lib/index.d.cts +2 -0
  95. package/dist/node/components/favorite/lib/index.d.cts.map +1 -0
  96. package/dist/node/components/favorite/lib/index.js +4 -21
  97. package/dist/node/components/favorite/lib/index.js.map +1 -1
  98. package/dist/node/components/index.cjs +247 -0
  99. package/dist/node/components/index.cjs.map +1 -0
  100. package/dist/node/components/index.d.cts +4 -0
  101. package/dist/node/components/index.d.cts.map +1 -0
  102. package/dist/node/components/index.js +215 -24
  103. package/dist/node/components/index.js.map +1 -1
  104. package/dist/node/components/lib/FavoriteItemEvent.cjs +36 -0
  105. package/dist/node/components/lib/FavoriteItemEvent.cjs.map +1 -0
  106. package/dist/node/components/lib/FavoriteItemEvent.d.cts +9 -0
  107. package/dist/node/components/lib/FavoriteItemEvent.d.cts.map +1 -0
  108. package/dist/node/components/lib/FavoriteItemEvent.js +4 -27
  109. package/dist/node/components/lib/FavoriteItemEvent.js.map +1 -1
  110. package/dist/node/components/lib/index.cjs +38 -0
  111. package/dist/node/components/lib/index.cjs.map +1 -0
  112. package/dist/node/components/lib/index.d.cts +2 -0
  113. package/dist/node/components/lib/index.d.cts.map +1 -0
  114. package/dist/node/components/lib/index.js +9 -21
  115. package/dist/node/components/lib/index.js.map +1 -1
  116. package/dist/node/index.cjs +247 -0
  117. package/dist/node/index.cjs.map +1 -0
  118. package/dist/node/index.d.cts +2 -0
  119. package/dist/node/index.d.cts.map +1 -0
  120. package/dist/node/index.js +215 -20
  121. package/dist/node/index.js.map +1 -1
  122. package/package.json +20 -20
  123. package/dist/browser/components/RenderRowBox.stories.js +0 -81
  124. package/dist/browser/components/RenderRowBox.stories.js.map +0 -1
  125. package/dist/node/components/RenderRowBox.mjs +0 -49
  126. package/dist/node/components/RenderRowBox.mjs.map +0 -1
  127. package/dist/node/components/RenderRowBox.stories.js +0 -111
  128. package/dist/node/components/RenderRowBox.stories.js.map +0 -1
  129. package/dist/node/components/RenderRowBox.stories.mjs +0 -81
  130. package/dist/node/components/RenderRowBox.stories.mjs.map +0 -1
  131. package/dist/node/components/favorite/FavoriteIconButton.mjs +0 -70
  132. package/dist/node/components/favorite/FavoriteIconButton.mjs.map +0 -1
  133. package/dist/node/components/favorite/FavoriteToggleSVG.mjs +0 -7
  134. package/dist/node/components/favorite/Popper.mjs +0 -54
  135. package/dist/node/components/favorite/Popper.mjs.map +0 -1
  136. package/dist/node/components/favorite/PopperButtonGroup.mjs +0 -35
  137. package/dist/node/components/favorite/index.mjs +0 -2
  138. package/dist/node/components/favorite/index.mjs.map +0 -1
  139. package/dist/node/components/favorite/lib/PopperId.mjs +0 -5
  140. package/dist/node/components/favorite/lib/index.mjs +0 -2
  141. package/dist/node/components/favorite/lib/index.mjs.map +0 -1
  142. package/dist/node/components/index.mjs +0 -4
  143. package/dist/node/components/index.mjs.map +0 -1
  144. package/dist/node/components/lib/FavoriteItemEvent.mjs +0 -10
  145. package/dist/node/components/lib/index.mjs +0 -2
  146. package/dist/node/components/lib/index.mjs.map +0 -1
  147. package/dist/node/index.mjs +0 -2
  148. package/dist/node/index.mjs.map +0 -1
@@ -1,34 +1,11 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __export = (target, all) => {
7
- for (var name in all)
8
- __defProp(target, name, { get: all[name], enumerable: true });
9
- };
10
- var __copyProps = (to, from, except, desc) => {
11
- if (from && typeof from === "object" || typeof from === "function") {
12
- for (let key of __getOwnPropNames(from))
13
- if (!__hasOwnProp.call(to, key) && key !== except)
14
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
- }
16
- return to;
17
- };
18
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
- var FavoriteItemEvent_exports = {};
20
- __export(FavoriteItemEvent_exports, {
21
- generateFavoriteEvent: () => generateFavoriteEvent
22
- });
23
- module.exports = __toCommonJS(FavoriteItemEvent_exports);
24
- const generateFavoriteEvent = (favorite, favoriteType, favoriteValue, name) => ({
1
+ // src/components/lib/FavoriteItemEvent.ts
2
+ var generateFavoriteEvent = (favorite, favoriteType, favoriteValue, name) => ({
25
3
  favorite: !!favorite,
26
4
  favoriteType,
27
5
  favoriteValue,
28
6
  name
29
7
  });
30
- // Annotate the CommonJS export names for ESM import in node:
31
- 0 && (module.exports = {
8
+ export {
32
9
  generateFavoriteEvent
33
- });
10
+ };
34
11
  //# sourceMappingURL=FavoriteItemEvent.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/lib/FavoriteItemEvent.ts"],"sourcesContent":["export interface FavoriteItemEvent {\n favorite?: boolean\n favoriteType?: FavoriteType\n favoriteValue?: string\n name?: string\n}\n\nexport type FavoriteType = 'address' | 'schema' | 'hash'\n\nexport const generateFavoriteEvent = (favorite?: boolean, favoriteType?: FavoriteType, favoriteValue?: string, name?: string): FavoriteItemEvent => ({\n favorite: !!favorite,\n favoriteType,\n favoriteValue,\n name,\n})\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AASO,MAAM,wBAAwB,CAAC,UAAoB,cAA6B,eAAwB,UAAsC;AAAA,EACnJ,UAAU,CAAC,CAAC;AAAA,EACZ;AAAA,EACA;AAAA,EACA;AACF;","names":[]}
1
+ {"version":3,"sources":["../../../../src/components/lib/FavoriteItemEvent.ts"],"sourcesContent":["export interface FavoriteItemEvent {\n favorite?: boolean\n favoriteType?: FavoriteType\n favoriteValue?: string\n name?: string\n}\n\nexport type FavoriteType = 'address' | 'schema' | 'hash'\n\nexport const generateFavoriteEvent = (favorite?: boolean, favoriteType?: FavoriteType, favoriteValue?: string, name?: string): FavoriteItemEvent => ({\n favorite: !!favorite,\n favoriteType,\n favoriteValue,\n name,\n})\n"],"mappings":";AASO,IAAM,wBAAwB,CAAC,UAAoB,cAA6B,eAAwB,UAAsC;AAAA,EACnJ,UAAU,CAAC,CAAC;AAAA,EACZ;AAAA,EACA;AAAA,EACA;AACF;","names":[]}
@@ -0,0 +1,38 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/components/lib/index.ts
21
+ var lib_exports = {};
22
+ __export(lib_exports, {
23
+ generateFavoriteEvent: () => generateFavoriteEvent
24
+ });
25
+ module.exports = __toCommonJS(lib_exports);
26
+
27
+ // src/components/lib/FavoriteItemEvent.ts
28
+ var generateFavoriteEvent = (favorite, favoriteType, favoriteValue, name) => ({
29
+ favorite: !!favorite,
30
+ favoriteType,
31
+ favoriteValue,
32
+ name
33
+ });
34
+ // Annotate the CommonJS export names for ESM import in node:
35
+ 0 && (module.exports = {
36
+ generateFavoriteEvent
37
+ });
38
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/components/lib/index.ts","../../../../src/components/lib/FavoriteItemEvent.ts"],"sourcesContent":["export * from './FavoriteItemEvent'\n","export interface FavoriteItemEvent {\n favorite?: boolean\n favoriteType?: FavoriteType\n favoriteValue?: string\n name?: string\n}\n\nexport type FavoriteType = 'address' | 'schema' | 'hash'\n\nexport const generateFavoriteEvent = (favorite?: boolean, favoriteType?: FavoriteType, favoriteValue?: string, name?: string): FavoriteItemEvent => ({\n favorite: !!favorite,\n favoriteType,\n favoriteValue,\n name,\n})\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACSO,IAAM,wBAAwB,CAAC,UAAoB,cAA6B,eAAwB,UAAsC;AAAA,EACnJ,UAAU,CAAC,CAAC;AAAA,EACZ;AAAA,EACA;AAAA,EACA;AACF;","names":[]}
@@ -0,0 +1,2 @@
1
+ export * from './FavoriteItemEvent';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/lib/index.ts"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAA"}
@@ -1,23 +1,11 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __copyProps = (to, from, except, desc) => {
7
- if (from && typeof from === "object" || typeof from === "function") {
8
- for (let key of __getOwnPropNames(from))
9
- if (!__hasOwnProp.call(to, key) && key !== except)
10
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
11
- }
12
- return to;
13
- };
14
- var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
15
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
16
- var lib_exports = {};
17
- module.exports = __toCommonJS(lib_exports);
18
- __reExport(lib_exports, require("./FavoriteItemEvent"), module.exports);
19
- // Annotate the CommonJS export names for ESM import in node:
20
- 0 && (module.exports = {
21
- ...require("./FavoriteItemEvent")
1
+ // src/components/lib/FavoriteItemEvent.ts
2
+ var generateFavoriteEvent = (favorite, favoriteType, favoriteValue, name) => ({
3
+ favorite: !!favorite,
4
+ favoriteType,
5
+ favoriteValue,
6
+ name
22
7
  });
8
+ export {
9
+ generateFavoriteEvent
10
+ };
23
11
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/lib/index.ts"],"sourcesContent":["export * from './FavoriteItemEvent'\n"],"mappings":";;;;;;;;;;;;;;;AAAA;AAAA;AAAA,wBAAc,gCAAd;","names":[]}
1
+ {"version":3,"sources":["../../../../src/components/lib/FavoriteItemEvent.ts"],"sourcesContent":["export interface FavoriteItemEvent {\n favorite?: boolean\n favoriteType?: FavoriteType\n favoriteValue?: string\n name?: string\n}\n\nexport type FavoriteType = 'address' | 'schema' | 'hash'\n\nexport const generateFavoriteEvent = (favorite?: boolean, favoriteType?: FavoriteType, favoriteValue?: string, name?: string): FavoriteItemEvent => ({\n favorite: !!favorite,\n favoriteType,\n favoriteValue,\n name,\n})\n"],"mappings":";AASO,IAAM,wBAAwB,CAAC,UAAoB,cAA6B,eAAwB,UAAsC;AAAA,EACnJ,UAAU,CAAC,CAAC;AAAA,EACZ;AAAA,EACA;AAAA,EACA;AACF;","names":[]}
@@ -0,0 +1,247 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/index.ts
21
+ var src_exports = {};
22
+ __export(src_exports, {
23
+ AddressRenderRowBox: () => AddressRenderRowBox,
24
+ FavoriteIconButton: () => FavoriteIconButton,
25
+ generateFavoriteEvent: () => generateFavoriteEvent
26
+ });
27
+ module.exports = __toCommonJS(src_exports);
28
+
29
+ // src/components/favorite/FavoriteIconButton.tsx
30
+ var import_material3 = require("@mui/material");
31
+ var import_react_event = require("@xyo-network/react-event");
32
+ var import_react_shared = require("@xyo-network/react-shared");
33
+ var import_react2 = require("react");
34
+
35
+ // src/components/lib/FavoriteItemEvent.ts
36
+ var generateFavoriteEvent = (favorite, favoriteType, favoriteValue, name) => ({
37
+ favorite: !!favorite,
38
+ favoriteType,
39
+ favoriteValue,
40
+ name
41
+ });
42
+
43
+ // src/components/favorite/FavoriteToggleSVG.tsx
44
+ var import_icons_material = require("@mui/icons-material");
45
+ var import_jsx_runtime = require("react/jsx-runtime");
46
+ var FavoriteToggleSVG = ({ favorite }) => /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_jsx_runtime.Fragment, { children: favorite ? /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_icons_material.Star, { className: "favorite-icon", component: "svg", color: "secondary", fontSize: "small" }) : /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_icons_material.StarBorder, { className: "favorite-icon", fontSize: "small" }) });
47
+
48
+ // src/components/favorite/lib/PopperId.ts
49
+ var popperId = "favorite-popper";
50
+
51
+ // src/components/favorite/Popper.tsx
52
+ var import_material2 = require("@mui/material");
53
+ var import_react = require("react");
54
+
55
+ // src/components/favorite/PopperButtonGroup.tsx
56
+ var import_icons_material2 = require("@mui/icons-material");
57
+ var import_material = require("@mui/material");
58
+ var import_jsx_runtime2 = require("react/jsx-runtime");
59
+ var PopperButtonGroup = ({ name, onConfirmFavorite, favorite, ...props }) => {
60
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(import_material.ButtonGroup, { ...props, children: [
61
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
62
+ import_material.Button,
63
+ {
64
+ title: "Save Favorite",
65
+ variant: "contained",
66
+ onClick: (e) => {
67
+ e.stopPropagation();
68
+ onConfirmFavorite == null ? void 0 : onConfirmFavorite(name, true);
69
+ },
70
+ children: /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(import_icons_material2.Star, {})
71
+ }
72
+ ),
73
+ favorite ? /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
74
+ import_material.Button,
75
+ {
76
+ title: "Remove Favorite",
77
+ variant: "contained",
78
+ onClick: (e) => {
79
+ e.stopPropagation();
80
+ onConfirmFavorite == null ? void 0 : onConfirmFavorite(name, false);
81
+ },
82
+ children: /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(import_icons_material2.Delete, {})
83
+ }
84
+ ) : null
85
+ ] });
86
+ };
87
+
88
+ // src/components/favorite/Popper.tsx
89
+ var import_jsx_runtime3 = require("react/jsx-runtime");
90
+ var FavoritePopper = (0, import_react.forwardRef)(
91
+ ({
92
+ name: nameProp,
93
+ favorite,
94
+ favoriteRef,
95
+ onClickAway = () => {
96
+ return;
97
+ },
98
+ onConfirmFavorite,
99
+ ...props
100
+ }, ref) => {
101
+ const [name, setName] = (0, import_react.useState)(nameProp);
102
+ (0, import_react.useEffect)(() => {
103
+ setName(nameProp);
104
+ }, [nameProp]);
105
+ return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(import_material2.ClickAwayListener, { onClickAway, children: /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(
106
+ PopperStyled,
107
+ {
108
+ id: popperId,
109
+ anchorEl: favoriteRef == null ? void 0 : favoriteRef.current,
110
+ onClick: (e) => e.stopPropagation(),
111
+ onTouchStart: (e) => e.stopPropagation(),
112
+ transition: true,
113
+ ref,
114
+ ...props,
115
+ children: ({ TransitionProps }) => /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(import_material2.Fade, { ...TransitionProps, timeout: 350, children: /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(import_material2.Card, { children: /* @__PURE__ */ (0, import_jsx_runtime3.jsxs)(import_material2.CardContent, { sx: { display: "flex", gap: 1 }, children: [
116
+ /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(
117
+ import_material2.TextField,
118
+ {
119
+ autoFocus: true,
120
+ label: "Favorite Name",
121
+ placeholder: "optional",
122
+ size: "small",
123
+ value: name ?? "",
124
+ onChange: (e) => setName(e.target.value)
125
+ }
126
+ ),
127
+ /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(PopperButtonGroup, { favorite, onConfirmFavorite, name })
128
+ ] }) }) })
129
+ }
130
+ ) });
131
+ }
132
+ );
133
+ FavoritePopper.displayName = "FavoritePopper";
134
+ var PopperStyled = (0, import_material2.styled)(import_material2.Popper, { name: "PopperStyled" })(() => ({ zIndex: 9999 }));
135
+
136
+ // src/components/favorite/FavoriteIconButton.tsx
137
+ var import_jsx_runtime4 = require("react/jsx-runtime");
138
+ var FavoriteIconButton = (0, import_react2.forwardRef)(
139
+ ({ children, favorite: favoriteProp, name, valueType, value, ...props }, ref) => {
140
+ const [openPopper, setOpenPopper] = (0, import_react2.useState)(false);
141
+ const [favorite, setFavorite] = (0, import_react2.useState)(favoriteProp);
142
+ (0, import_react2.useEffect)(() => {
143
+ setFavorite(favoriteProp);
144
+ }, [favoriteProp]);
145
+ const sharedRef = (0, import_react_shared.useShareForwardedRef)(ref);
146
+ const [buttonRef, dispatch] = (0, import_react_event.useEvent)(void 0, sharedRef);
147
+ const onConfirmFavorite = (name2, newFavoriteState) => {
148
+ const favoriteEvent = generateFavoriteEvent(!!newFavoriteState, valueType, value, name2);
149
+ dispatch("address", "favorite", JSON.stringify(favoriteEvent));
150
+ setFavorite(newFavoriteState);
151
+ setOpenPopper(false);
152
+ };
153
+ const starRef = (0, import_react2.useRef)(null);
154
+ return /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)(
155
+ IconButtonCondensed,
156
+ {
157
+ "aria-describedby": popperId,
158
+ ref: buttonRef,
159
+ onClick: (event) => {
160
+ event.stopPropagation();
161
+ setOpenPopper(!openPopper);
162
+ },
163
+ onTouchStart: (event) => {
164
+ event.stopPropagation();
165
+ setOpenPopper(!openPopper);
166
+ },
167
+ onMouseDown: (e) => e.stopPropagation(),
168
+ sx: { lineHeight: 0, p: 0.25 },
169
+ ...props,
170
+ children: [
171
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("span", { ref: starRef, children: /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(FavoriteToggleSVG, { favorite }) }),
172
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
173
+ FavoritePopper,
174
+ {
175
+ sx: { zIndex: 1301 },
176
+ name,
177
+ favorite,
178
+ favoriteRef: starRef,
179
+ open: openPopper,
180
+ onConfirmFavorite,
181
+ onClickAway: () => setOpenPopper(false)
182
+ }
183
+ ),
184
+ children
185
+ ]
186
+ }
187
+ );
188
+ }
189
+ );
190
+ FavoriteIconButton.displayName = "FavoriteIconButton";
191
+ var IconButtonCondensed = (0, import_material3.styled)(import_material3.IconButton, { name: "IconButtonCondensed" })(({ theme }) => ({
192
+ lineHeight: 0,
193
+ padding: theme.spacing(0.25)
194
+ }));
195
+
196
+ // src/components/RenderRowBox.tsx
197
+ var import_material4 = require("@mui/material");
198
+ var import_react_flexbox = require("@xylabs/react-flexbox");
199
+ var import_react_identicon = require("@xylabs/react-identicon");
200
+ var import_react_event2 = require("@xyo-network/react-event");
201
+ var import_react_shared2 = require("@xyo-network/react-shared");
202
+ var import_react3 = require("react");
203
+ var import_jsx_runtime5 = require("react/jsx-runtime");
204
+ var AddressRenderRowBox = (0, import_react3.forwardRef)(
205
+ ({ address, children, disableSharedRef, favorite: favoriteProp = false, iconOnly, iconSize = 24, icons, name, showFavorite = false, ...props }, ref) => {
206
+ const theme = (0, import_material4.useTheme)();
207
+ const sharedRef = (0, import_react_shared2.useShareForwardedRef)(ref);
208
+ const [elementRef, dispatch] = (0, import_react_event2.useEvent)(void 0, sharedRef);
209
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(
210
+ import_react_flexbox.FlexRow,
211
+ {
212
+ gap: 2,
213
+ justifyContent: "flex-start",
214
+ ref: elementRef,
215
+ onClick: () => {
216
+ if (address) {
217
+ dispatch("address", "click", address);
218
+ }
219
+ },
220
+ ...props,
221
+ children: [
222
+ icons && address ? /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_material4.ListItemIcon, { sx: { minWidth: 0 }, children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_react_identicon.Identicon, { size: iconSize, value: address }) }) : null,
223
+ iconOnly ? null : /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
224
+ import_react_shared2.EllipsizeBox,
225
+ {
226
+ disableSharedRef,
227
+ ellipsisPosition: "end",
228
+ width: "100%",
229
+ typographyProps: { fontSize: theme.typography.body1.fontSize },
230
+ children: name ?? address
231
+ }
232
+ ),
233
+ children,
234
+ showFavorite && address ? /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(FavoriteIconButton, { name, size: "small", value: address, valueType: "address", favorite: favoriteProp }) : null
235
+ ]
236
+ }
237
+ );
238
+ }
239
+ );
240
+ AddressRenderRowBox.displayName = "AddressRenderRowBox";
241
+ // Annotate the CommonJS export names for ESM import in node:
242
+ 0 && (module.exports = {
243
+ AddressRenderRowBox,
244
+ FavoriteIconButton,
245
+ generateFavoriteEvent
246
+ });
247
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/index.ts","../../src/components/favorite/FavoriteIconButton.tsx","../../src/components/lib/FavoriteItemEvent.ts","../../src/components/favorite/FavoriteToggleSVG.tsx","../../src/components/favorite/lib/PopperId.ts","../../src/components/favorite/Popper.tsx","../../src/components/favorite/PopperButtonGroup.tsx","../../src/components/RenderRowBox.tsx"],"sourcesContent":["export * from './components'\n","import { IconButton, IconButtonProps, styled } from '@mui/material'\nimport { WithChildren } from '@xylabs/react-shared'\nimport { useEvent } from '@xyo-network/react-event'\nimport { useShareForwardedRef } from '@xyo-network/react-shared'\nimport { forwardRef, useEffect, useRef, useState } from 'react'\n\nimport { FavoriteItemEvent, generateFavoriteEvent } from '../lib'\nimport { FavoriteToggleSVG } from './FavoriteToggleSVG'\nimport { popperId } from './lib'\nimport { FavoritePopper } from './Popper'\n\nexport interface FavoriteIconButtonProps extends WithChildren, IconButtonProps {\n favorite?: FavoriteItemEvent['favorite']\n name?: FavoriteItemEvent['name']\n value?: string\n valueType?: FavoriteItemEvent['favoriteType']\n}\n\nexport const FavoriteIconButton = forwardRef<HTMLButtonElement, FavoriteIconButtonProps>(\n ({ children, favorite: favoriteProp, name, valueType, value, ...props }, ref) => {\n const [openPopper, setOpenPopper] = useState(false)\n\n const [favorite, setFavorite] = useState(favoriteProp)\n useEffect(() => {\n setFavorite(favoriteProp)\n }, [favoriteProp])\n\n const sharedRef = useShareForwardedRef(ref)\n const [buttonRef, dispatch] = useEvent(undefined, sharedRef)\n\n const onConfirmFavorite = (name?: string, newFavoriteState?: boolean) => {\n const favoriteEvent = generateFavoriteEvent(!!newFavoriteState, valueType, value, name)\n dispatch('address', 'favorite', JSON.stringify(favoriteEvent))\n setFavorite(newFavoriteState)\n setOpenPopper(false)\n }\n\n const starRef = useRef<HTMLSpanElement>(null)\n\n return (\n <IconButtonCondensed\n aria-describedby={popperId}\n ref={buttonRef}\n onClick={(event) => {\n event.stopPropagation()\n setOpenPopper(!openPopper)\n }}\n onTouchStart={(event) => {\n event.stopPropagation()\n setOpenPopper(!openPopper)\n }}\n onMouseDown={(e) => e.stopPropagation()}\n sx={{ lineHeight: 0, p: 0.25 }}\n {...props}\n >\n <span ref={starRef}>\n <FavoriteToggleSVG favorite={favorite} />\n </span>\n <FavoritePopper\n sx={{ zIndex: 1301 }}\n name={name}\n favorite={favorite}\n favoriteRef={starRef}\n open={openPopper}\n onConfirmFavorite={onConfirmFavorite}\n onClickAway={() => setOpenPopper(false)}\n />\n {children}\n </IconButtonCondensed>\n )\n },\n)\n\nFavoriteIconButton.displayName = 'FavoriteIconButton'\n\nconst IconButtonCondensed = styled(IconButton, { name: 'IconButtonCondensed' })(({ theme }) => ({\n lineHeight: 0,\n padding: theme.spacing(0.25),\n}))\n","export interface FavoriteItemEvent {\n favorite?: boolean\n favoriteType?: FavoriteType\n favoriteValue?: string\n name?: string\n}\n\nexport type FavoriteType = 'address' | 'schema' | 'hash'\n\nexport const generateFavoriteEvent = (favorite?: boolean, favoriteType?: FavoriteType, favoriteValue?: string, name?: string): FavoriteItemEvent => ({\n favorite: !!favorite,\n favoriteType,\n favoriteValue,\n name,\n})\n","import { Star as StarIcon, StarBorder as StarBorderIcon } from '@mui/icons-material'\n\nexport const FavoriteToggleSVG: React.FC<{ favorite?: boolean }> = ({ favorite }) => (\n <>\n {favorite ? (\n <StarIcon className=\"favorite-icon\" component={'svg'} color=\"secondary\" fontSize=\"small\" />\n ) : (\n <StarBorderIcon className=\"favorite-icon\" fontSize=\"small\" />\n )}\n </>\n)\n","export const popperId = 'favorite-popper'\n","import { Card, CardContent, ClickAwayListener, Fade, Popper, PopperProps, styled, TextField } from '@mui/material'\nimport { forwardRef, RefObject, useEffect, useState } from 'react'\n\nimport { popperId } from './lib'\nimport { PopperButtonGroup } from './PopperButtonGroup'\n\nexport interface FavoritePopperProps extends PopperProps {\n favorite?: boolean\n favoriteRef?: RefObject<HTMLElement>\n name?: string\n onClickAway?: (event: MouseEvent | TouchEvent) => void\n onConfirmFavorite?: (name?: string, newFavoriteState?: boolean) => void\n}\nexport const FavoritePopper = forwardRef<HTMLDivElement, FavoritePopperProps>(\n (\n {\n name: nameProp,\n favorite,\n favoriteRef,\n onClickAway = () => {\n return\n },\n onConfirmFavorite,\n ...props\n },\n ref,\n ) => {\n const [name, setName] = useState(nameProp)\n useEffect(() => {\n setName(nameProp)\n }, [nameProp])\n\n return (\n <ClickAwayListener onClickAway={onClickAway}>\n <PopperStyled\n id={popperId}\n anchorEl={favoriteRef?.current}\n onClick={(e) => e.stopPropagation()}\n onTouchStart={(e) => e.stopPropagation()}\n transition\n ref={ref}\n {...props}\n >\n {({ TransitionProps }) => (\n <Fade {...TransitionProps} timeout={350}>\n <Card>\n <CardContent sx={{ display: 'flex', gap: 1 }}>\n <TextField\n autoFocus\n label=\"Favorite Name\"\n placeholder=\"optional\"\n size=\"small\"\n value={name ?? ''}\n onChange={(e) => setName(e.target.value)}\n />\n <PopperButtonGroup favorite={favorite} onConfirmFavorite={onConfirmFavorite} name={name} />\n </CardContent>\n </Card>\n </Fade>\n )}\n </PopperStyled>\n </ClickAwayListener>\n )\n },\n)\n\nFavoritePopper.displayName = 'FavoritePopper'\n\n// Ensure the popper is over all other mui portal elements\nconst PopperStyled = styled(Popper, { name: 'PopperStyled' })(() => ({ zIndex: 9999 }))\n","import { Delete as DeleteIcon, Star as StarIcon } from '@mui/icons-material'\nimport { Button, ButtonGroup, ButtonGroupProps } from '@mui/material'\n\nexport interface FavoritePopperProps extends ButtonGroupProps {\n favorite?: boolean\n name?: string\n onConfirmFavorite?: (name?: string, newFavoriteState?: boolean) => void\n}\n\nexport const PopperButtonGroup: React.FC<FavoritePopperProps> = ({ name, onConfirmFavorite, favorite, ...props }) => {\n return (\n <ButtonGroup {...props}>\n <Button\n title=\"Save Favorite\"\n variant=\"contained\"\n onClick={(e) => {\n e.stopPropagation()\n onConfirmFavorite?.(name, true)\n }}\n >\n <StarIcon />\n </Button>\n {favorite ? (\n <Button\n title=\"Remove Favorite\"\n variant=\"contained\"\n onClick={(e) => {\n e.stopPropagation()\n onConfirmFavorite?.(name, false)\n }}\n >\n <DeleteIcon />\n </Button>\n ) : null}\n </ButtonGroup>\n )\n}\n","import { ListItemIcon, useTheme } from '@mui/material'\nimport { FlexBoxProps, FlexRow } from '@xylabs/react-flexbox'\nimport { Identicon } from '@xylabs/react-identicon'\nimport { useEvent } from '@xyo-network/react-event'\nimport { EllipsizeBox, useShareForwardedRef } from '@xyo-network/react-shared'\nimport { forwardRef } from 'react'\n\nimport { FavoriteIconButton } from './favorite'\n\nexport interface AddressRenderRowBoxProps extends FlexBoxProps {\n address?: string | null\n disableSharedRef?: boolean\n favorite?: boolean\n iconOnly?: boolean\n iconSize?: number\n icons?: boolean\n name?: string\n showFavorite?: boolean\n}\n\nexport const AddressRenderRowBox = forwardRef<HTMLElement, AddressRenderRowBoxProps>(\n (\n { address, children, disableSharedRef, favorite: favoriteProp = false, iconOnly, iconSize = 24, icons, name, showFavorite = false, ...props },\n ref,\n ) => {\n const theme = useTheme()\n\n const sharedRef = useShareForwardedRef(ref)\n const [elementRef, dispatch] = useEvent(undefined, sharedRef)\n\n return (\n <FlexRow\n gap={2}\n justifyContent=\"flex-start\"\n ref={elementRef}\n onClick={() => {\n if (address) {\n dispatch('address', 'click', address)\n }\n }}\n {...props}\n >\n {icons && address ? (\n <ListItemIcon sx={{ minWidth: 0 }}>\n <Identicon size={iconSize} value={address} />\n </ListItemIcon>\n ) : null}\n {iconOnly ? null : (\n <EllipsizeBox\n disableSharedRef={disableSharedRef}\n ellipsisPosition={'end'}\n width=\"100%\"\n typographyProps={{ fontSize: theme.typography.body1.fontSize }}\n >\n {name ?? address}\n </EllipsizeBox>\n )}\n {children}\n {showFavorite && address ? (\n <FavoriteIconButton name={name} size={'small'} value={address} valueType={'address'} favorite={favoriteProp} />\n ) : null}\n </FlexRow>\n )\n },\n)\n\nAddressRenderRowBox.displayName = 'AddressRenderRowBox'\n"],"mappings":"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","names":["import_material","import_react","StarIcon","StarBorderIcon","import_material","import_icons_material","import_jsx_runtime","StarIcon","DeleteIcon","import_jsx_runtime","import_jsx_runtime","name","import_material","import_react_event","import_react_shared","import_react","import_jsx_runtime"]}
@@ -0,0 +1,2 @@
1
+ export * from './components';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAA"}
@@ -1,23 +1,218 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __copyProps = (to, from, except, desc) => {
7
- if (from && typeof from === "object" || typeof from === "function") {
8
- for (let key of __getOwnPropNames(from))
9
- if (!__hasOwnProp.call(to, key) && key !== except)
10
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
1
+ // src/components/favorite/FavoriteIconButton.tsx
2
+ import { IconButton, styled as styled2 } from "@mui/material";
3
+ import { useEvent } from "@xyo-network/react-event";
4
+ import { useShareForwardedRef } from "@xyo-network/react-shared";
5
+ import { forwardRef as forwardRef2, useEffect as useEffect2, useRef, useState as useState2 } from "react";
6
+
7
+ // src/components/lib/FavoriteItemEvent.ts
8
+ var generateFavoriteEvent = (favorite, favoriteType, favoriteValue, name) => ({
9
+ favorite: !!favorite,
10
+ favoriteType,
11
+ favoriteValue,
12
+ name
13
+ });
14
+
15
+ // src/components/favorite/FavoriteToggleSVG.tsx
16
+ import { Star as StarIcon, StarBorder as StarBorderIcon } from "@mui/icons-material";
17
+ import { Fragment, jsx } from "react/jsx-runtime";
18
+ var FavoriteToggleSVG = ({ favorite }) => /* @__PURE__ */ jsx(Fragment, { children: favorite ? /* @__PURE__ */ jsx(StarIcon, { className: "favorite-icon", component: "svg", color: "secondary", fontSize: "small" }) : /* @__PURE__ */ jsx(StarBorderIcon, { className: "favorite-icon", fontSize: "small" }) });
19
+
20
+ // src/components/favorite/lib/PopperId.ts
21
+ var popperId = "favorite-popper";
22
+
23
+ // src/components/favorite/Popper.tsx
24
+ import { Card, CardContent, ClickAwayListener, Fade, Popper, styled, TextField } from "@mui/material";
25
+ import { forwardRef, useEffect, useState } from "react";
26
+
27
+ // src/components/favorite/PopperButtonGroup.tsx
28
+ import { Delete as DeleteIcon, Star as StarIcon2 } from "@mui/icons-material";
29
+ import { Button, ButtonGroup } from "@mui/material";
30
+ import { jsx as jsx2, jsxs } from "react/jsx-runtime";
31
+ var PopperButtonGroup = ({ name, onConfirmFavorite, favorite, ...props }) => {
32
+ return /* @__PURE__ */ jsxs(ButtonGroup, { ...props, children: [
33
+ /* @__PURE__ */ jsx2(
34
+ Button,
35
+ {
36
+ title: "Save Favorite",
37
+ variant: "contained",
38
+ onClick: (e) => {
39
+ e.stopPropagation();
40
+ onConfirmFavorite == null ? void 0 : onConfirmFavorite(name, true);
41
+ },
42
+ children: /* @__PURE__ */ jsx2(StarIcon2, {})
43
+ }
44
+ ),
45
+ favorite ? /* @__PURE__ */ jsx2(
46
+ Button,
47
+ {
48
+ title: "Remove Favorite",
49
+ variant: "contained",
50
+ onClick: (e) => {
51
+ e.stopPropagation();
52
+ onConfirmFavorite == null ? void 0 : onConfirmFavorite(name, false);
53
+ },
54
+ children: /* @__PURE__ */ jsx2(DeleteIcon, {})
55
+ }
56
+ ) : null
57
+ ] });
58
+ };
59
+
60
+ // src/components/favorite/Popper.tsx
61
+ import { jsx as jsx3, jsxs as jsxs2 } from "react/jsx-runtime";
62
+ var FavoritePopper = forwardRef(
63
+ ({
64
+ name: nameProp,
65
+ favorite,
66
+ favoriteRef,
67
+ onClickAway = () => {
68
+ return;
69
+ },
70
+ onConfirmFavorite,
71
+ ...props
72
+ }, ref) => {
73
+ const [name, setName] = useState(nameProp);
74
+ useEffect(() => {
75
+ setName(nameProp);
76
+ }, [nameProp]);
77
+ return /* @__PURE__ */ jsx3(ClickAwayListener, { onClickAway, children: /* @__PURE__ */ jsx3(
78
+ PopperStyled,
79
+ {
80
+ id: popperId,
81
+ anchorEl: favoriteRef == null ? void 0 : favoriteRef.current,
82
+ onClick: (e) => e.stopPropagation(),
83
+ onTouchStart: (e) => e.stopPropagation(),
84
+ transition: true,
85
+ ref,
86
+ ...props,
87
+ children: ({ TransitionProps }) => /* @__PURE__ */ jsx3(Fade, { ...TransitionProps, timeout: 350, children: /* @__PURE__ */ jsx3(Card, { children: /* @__PURE__ */ jsxs2(CardContent, { sx: { display: "flex", gap: 1 }, children: [
88
+ /* @__PURE__ */ jsx3(
89
+ TextField,
90
+ {
91
+ autoFocus: true,
92
+ label: "Favorite Name",
93
+ placeholder: "optional",
94
+ size: "small",
95
+ value: name ?? "",
96
+ onChange: (e) => setName(e.target.value)
97
+ }
98
+ ),
99
+ /* @__PURE__ */ jsx3(PopperButtonGroup, { favorite, onConfirmFavorite, name })
100
+ ] }) }) })
101
+ }
102
+ ) });
103
+ }
104
+ );
105
+ FavoritePopper.displayName = "FavoritePopper";
106
+ var PopperStyled = styled(Popper, { name: "PopperStyled" })(() => ({ zIndex: 9999 }));
107
+
108
+ // src/components/favorite/FavoriteIconButton.tsx
109
+ import { jsx as jsx4, jsxs as jsxs3 } from "react/jsx-runtime";
110
+ var FavoriteIconButton = forwardRef2(
111
+ ({ children, favorite: favoriteProp, name, valueType, value, ...props }, ref) => {
112
+ const [openPopper, setOpenPopper] = useState2(false);
113
+ const [favorite, setFavorite] = useState2(favoriteProp);
114
+ useEffect2(() => {
115
+ setFavorite(favoriteProp);
116
+ }, [favoriteProp]);
117
+ const sharedRef = useShareForwardedRef(ref);
118
+ const [buttonRef, dispatch] = useEvent(void 0, sharedRef);
119
+ const onConfirmFavorite = (name2, newFavoriteState) => {
120
+ const favoriteEvent = generateFavoriteEvent(!!newFavoriteState, valueType, value, name2);
121
+ dispatch("address", "favorite", JSON.stringify(favoriteEvent));
122
+ setFavorite(newFavoriteState);
123
+ setOpenPopper(false);
124
+ };
125
+ const starRef = useRef(null);
126
+ return /* @__PURE__ */ jsxs3(
127
+ IconButtonCondensed,
128
+ {
129
+ "aria-describedby": popperId,
130
+ ref: buttonRef,
131
+ onClick: (event) => {
132
+ event.stopPropagation();
133
+ setOpenPopper(!openPopper);
134
+ },
135
+ onTouchStart: (event) => {
136
+ event.stopPropagation();
137
+ setOpenPopper(!openPopper);
138
+ },
139
+ onMouseDown: (e) => e.stopPropagation(),
140
+ sx: { lineHeight: 0, p: 0.25 },
141
+ ...props,
142
+ children: [
143
+ /* @__PURE__ */ jsx4("span", { ref: starRef, children: /* @__PURE__ */ jsx4(FavoriteToggleSVG, { favorite }) }),
144
+ /* @__PURE__ */ jsx4(
145
+ FavoritePopper,
146
+ {
147
+ sx: { zIndex: 1301 },
148
+ name,
149
+ favorite,
150
+ favoriteRef: starRef,
151
+ open: openPopper,
152
+ onConfirmFavorite,
153
+ onClickAway: () => setOpenPopper(false)
154
+ }
155
+ ),
156
+ children
157
+ ]
158
+ }
159
+ );
11
160
  }
12
- return to;
161
+ );
162
+ FavoriteIconButton.displayName = "FavoriteIconButton";
163
+ var IconButtonCondensed = styled2(IconButton, { name: "IconButtonCondensed" })(({ theme }) => ({
164
+ lineHeight: 0,
165
+ padding: theme.spacing(0.25)
166
+ }));
167
+
168
+ // src/components/RenderRowBox.tsx
169
+ import { ListItemIcon, useTheme } from "@mui/material";
170
+ import { FlexRow } from "@xylabs/react-flexbox";
171
+ import { Identicon } from "@xylabs/react-identicon";
172
+ import { useEvent as useEvent2 } from "@xyo-network/react-event";
173
+ import { EllipsizeBox, useShareForwardedRef as useShareForwardedRef2 } from "@xyo-network/react-shared";
174
+ import { forwardRef as forwardRef3 } from "react";
175
+ import { jsx as jsx5, jsxs as jsxs4 } from "react/jsx-runtime";
176
+ var AddressRenderRowBox = forwardRef3(
177
+ ({ address, children, disableSharedRef, favorite: favoriteProp = false, iconOnly, iconSize = 24, icons, name, showFavorite = false, ...props }, ref) => {
178
+ const theme = useTheme();
179
+ const sharedRef = useShareForwardedRef2(ref);
180
+ const [elementRef, dispatch] = useEvent2(void 0, sharedRef);
181
+ return /* @__PURE__ */ jsxs4(
182
+ FlexRow,
183
+ {
184
+ gap: 2,
185
+ justifyContent: "flex-start",
186
+ ref: elementRef,
187
+ onClick: () => {
188
+ if (address) {
189
+ dispatch("address", "click", address);
190
+ }
191
+ },
192
+ ...props,
193
+ children: [
194
+ icons && address ? /* @__PURE__ */ jsx5(ListItemIcon, { sx: { minWidth: 0 }, children: /* @__PURE__ */ jsx5(Identicon, { size: iconSize, value: address }) }) : null,
195
+ iconOnly ? null : /* @__PURE__ */ jsx5(
196
+ EllipsizeBox,
197
+ {
198
+ disableSharedRef,
199
+ ellipsisPosition: "end",
200
+ width: "100%",
201
+ typographyProps: { fontSize: theme.typography.body1.fontSize },
202
+ children: name ?? address
203
+ }
204
+ ),
205
+ children,
206
+ showFavorite && address ? /* @__PURE__ */ jsx5(FavoriteIconButton, { name, size: "small", value: address, valueType: "address", favorite: favoriteProp }) : null
207
+ ]
208
+ }
209
+ );
210
+ }
211
+ );
212
+ AddressRenderRowBox.displayName = "AddressRenderRowBox";
213
+ export {
214
+ AddressRenderRowBox,
215
+ FavoriteIconButton,
216
+ generateFavoriteEvent
13
217
  };
14
- var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
15
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
16
- var src_exports = {};
17
- module.exports = __toCommonJS(src_exports);
18
- __reExport(src_exports, require("./components"), module.exports);
19
- // Annotate the CommonJS export names for ESM import in node:
20
- 0 && (module.exports = {
21
- ...require("./components")
22
- });
23
218
  //# sourceMappingURL=index.js.map