@xylabs/react-pixel-debugger 3.4.0 → 3.4.2

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 (108) hide show
  1. package/dist/browser/components/PixelDebugger.d.cts +1 -0
  2. package/dist/browser/components/PixelDebugger.d.cts.map +1 -1
  3. package/dist/browser/components/PixelDebugger.d.mts +1 -0
  4. package/dist/browser/components/PixelDebugger.d.mts.map +1 -1
  5. package/dist/browser/components/PixelDebugger.d.ts +1 -0
  6. package/dist/browser/components/PixelDebugger.d.ts.map +1 -1
  7. package/dist/browser/components/PixelDebuggerProvider.d.cts +1 -0
  8. package/dist/browser/components/PixelDebuggerProvider.d.cts.map +1 -1
  9. package/dist/browser/components/PixelDebuggerProvider.d.mts +1 -0
  10. package/dist/browser/components/PixelDebuggerProvider.d.mts.map +1 -1
  11. package/dist/browser/components/PixelDebuggerProvider.d.ts +1 -0
  12. package/dist/browser/components/PixelDebuggerProvider.d.ts.map +1 -1
  13. package/dist/browser/components/PixelDebuggerToggle.d.cts +1 -0
  14. package/dist/browser/components/PixelDebuggerToggle.d.cts.map +1 -1
  15. package/dist/browser/components/PixelDebuggerToggle.d.mts +1 -0
  16. package/dist/browser/components/PixelDebuggerToggle.d.mts.map +1 -1
  17. package/dist/browser/components/PixelDebuggerToggle.d.ts +1 -0
  18. package/dist/browser/components/PixelDebuggerToggle.d.ts.map +1 -1
  19. package/dist/browser/components/index.d.cts +3 -3
  20. package/dist/browser/components/index.d.mts +3 -3
  21. package/dist/browser/components/index.d.ts +3 -3
  22. package/dist/browser/hooks/index.d.cts +1 -1
  23. package/dist/browser/hooks/index.d.mts +1 -1
  24. package/dist/browser/hooks/index.d.ts +1 -1
  25. package/dist/browser/index.cjs +113 -54
  26. package/dist/browser/index.cjs.map +1 -1
  27. package/dist/browser/index.d.cts +3 -3
  28. package/dist/browser/index.d.mts +3 -3
  29. package/dist/browser/index.d.ts +3 -3
  30. package/dist/browser/index.mjs +161 -0
  31. package/dist/browser/index.mjs.map +1 -0
  32. package/dist/neutral/components/PixelDebugger.d.cts +1 -0
  33. package/dist/neutral/components/PixelDebugger.d.cts.map +1 -1
  34. package/dist/neutral/components/PixelDebugger.d.mts +1 -0
  35. package/dist/neutral/components/PixelDebugger.d.mts.map +1 -1
  36. package/dist/neutral/components/PixelDebugger.d.ts +1 -0
  37. package/dist/neutral/components/PixelDebugger.d.ts.map +1 -1
  38. package/dist/neutral/components/PixelDebuggerProvider.d.cts +1 -0
  39. package/dist/neutral/components/PixelDebuggerProvider.d.cts.map +1 -1
  40. package/dist/neutral/components/PixelDebuggerProvider.d.mts +1 -0
  41. package/dist/neutral/components/PixelDebuggerProvider.d.mts.map +1 -1
  42. package/dist/neutral/components/PixelDebuggerProvider.d.ts +1 -0
  43. package/dist/neutral/components/PixelDebuggerProvider.d.ts.map +1 -1
  44. package/dist/neutral/components/PixelDebuggerToggle.d.cts +1 -0
  45. package/dist/neutral/components/PixelDebuggerToggle.d.cts.map +1 -1
  46. package/dist/neutral/components/PixelDebuggerToggle.d.mts +1 -0
  47. package/dist/neutral/components/PixelDebuggerToggle.d.mts.map +1 -1
  48. package/dist/neutral/components/PixelDebuggerToggle.d.ts +1 -0
  49. package/dist/neutral/components/PixelDebuggerToggle.d.ts.map +1 -1
  50. package/dist/neutral/components/index.d.cts +3 -3
  51. package/dist/neutral/components/index.d.mts +3 -3
  52. package/dist/neutral/components/index.d.ts +3 -3
  53. package/dist/neutral/hooks/index.d.cts +1 -1
  54. package/dist/neutral/hooks/index.d.mts +1 -1
  55. package/dist/neutral/hooks/index.d.ts +1 -1
  56. package/dist/neutral/index.cjs +113 -54
  57. package/dist/neutral/index.cjs.map +1 -1
  58. package/dist/neutral/index.d.cts +3 -3
  59. package/dist/neutral/index.d.mts +3 -3
  60. package/dist/neutral/index.d.ts +3 -3
  61. package/dist/neutral/index.mjs +161 -0
  62. package/dist/neutral/index.mjs.map +1 -0
  63. package/dist/node/components/PixelDebugger.d.cts +1 -0
  64. package/dist/node/components/PixelDebugger.d.cts.map +1 -1
  65. package/dist/node/components/PixelDebugger.d.mts +1 -0
  66. package/dist/node/components/PixelDebugger.d.mts.map +1 -1
  67. package/dist/node/components/PixelDebugger.d.ts +1 -0
  68. package/dist/node/components/PixelDebugger.d.ts.map +1 -1
  69. package/dist/node/components/PixelDebuggerProvider.d.cts +1 -0
  70. package/dist/node/components/PixelDebuggerProvider.d.cts.map +1 -1
  71. package/dist/node/components/PixelDebuggerProvider.d.mts +1 -0
  72. package/dist/node/components/PixelDebuggerProvider.d.mts.map +1 -1
  73. package/dist/node/components/PixelDebuggerProvider.d.ts +1 -0
  74. package/dist/node/components/PixelDebuggerProvider.d.ts.map +1 -1
  75. package/dist/node/components/PixelDebuggerToggle.d.cts +1 -0
  76. package/dist/node/components/PixelDebuggerToggle.d.cts.map +1 -1
  77. package/dist/node/components/PixelDebuggerToggle.d.mts +1 -0
  78. package/dist/node/components/PixelDebuggerToggle.d.mts.map +1 -1
  79. package/dist/node/components/PixelDebuggerToggle.d.ts +1 -0
  80. package/dist/node/components/PixelDebuggerToggle.d.ts.map +1 -1
  81. package/dist/node/components/index.d.cts +3 -3
  82. package/dist/node/components/index.d.mts +3 -3
  83. package/dist/node/components/index.d.ts +3 -3
  84. package/dist/node/hooks/index.d.cts +1 -1
  85. package/dist/node/hooks/index.d.mts +1 -1
  86. package/dist/node/hooks/index.d.ts +1 -1
  87. package/dist/node/index.cjs +113 -54
  88. package/dist/node/index.cjs.map +1 -1
  89. package/dist/node/index.d.cts +3 -3
  90. package/dist/node/index.d.mts +3 -3
  91. package/dist/node/index.d.ts +3 -3
  92. package/dist/node/index.mjs +161 -0
  93. package/dist/node/index.mjs.map +1 -0
  94. package/package.json +15 -16
  95. package/src/components/PixelDebugger.stories.tsx +12 -8
  96. package/src/components/PixelDebugger.tsx +5 -5
  97. package/src/components/PixelDebuggerProvider.tsx +3 -1
  98. package/src/components/PixelDebuggerToggle.tsx +1 -1
  99. package/src/components/index.ts +3 -3
  100. package/src/hooks/index.ts +1 -1
  101. package/src/hooks/usePixelAltSendHandler.ts +1 -1
  102. package/src/index.ts +3 -3
  103. package/dist/browser/index.js +0 -110
  104. package/dist/browser/index.js.map +0 -1
  105. package/dist/neutral/index.js +0 -110
  106. package/dist/neutral/index.js.map +0 -1
  107. package/dist/node/index.js +0 -110
  108. package/dist/node/index.js.map +0 -1
@@ -1,2 +1,3 @@
1
+ import React from 'react';
1
2
  export declare const PixelDebugger: React.FC;
2
3
  //# sourceMappingURL=PixelDebugger.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"PixelDebugger.d.ts","sourceRoot":"","sources":["../../../src/components/PixelDebugger.tsx"],"names":[],"mappings":"AAUA,eAAO,MAAM,aAAa,EAAE,KAAK,CAAC,EAsDjC,CAAA"}
1
+ {"version":3,"file":"PixelDebugger.d.ts","sourceRoot":"","sources":["../../../src/components/PixelDebugger.tsx"],"names":[],"mappings":"AAKA,OAAO,KAA+B,MAAM,OAAO,CAAA;AAKnD,eAAO,MAAM,aAAa,EAAE,KAAK,CAAC,EAsDjC,CAAA"}
@@ -1,2 +1,3 @@
1
+ import React from 'react';
1
2
  export declare const PixelDebugger: React.FC;
2
3
  //# sourceMappingURL=PixelDebugger.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"PixelDebugger.d.ts","sourceRoot":"","sources":["../../../src/components/PixelDebugger.tsx"],"names":[],"mappings":"AAUA,eAAO,MAAM,aAAa,EAAE,KAAK,CAAC,EAsDjC,CAAA"}
1
+ {"version":3,"file":"PixelDebugger.d.ts","sourceRoot":"","sources":["../../../src/components/PixelDebugger.tsx"],"names":[],"mappings":"AAKA,OAAO,KAA+B,MAAM,OAAO,CAAA;AAKnD,eAAO,MAAM,aAAa,EAAE,KAAK,CAAC,EAsDjC,CAAA"}
@@ -1,2 +1,3 @@
1
+ import React from 'react';
1
2
  export declare const PixelDebugger: React.FC;
2
3
  //# sourceMappingURL=PixelDebugger.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"PixelDebugger.d.ts","sourceRoot":"","sources":["../../../src/components/PixelDebugger.tsx"],"names":[],"mappings":"AAUA,eAAO,MAAM,aAAa,EAAE,KAAK,CAAC,EAsDjC,CAAA"}
1
+ {"version":3,"file":"PixelDebugger.d.ts","sourceRoot":"","sources":["../../../src/components/PixelDebugger.tsx"],"names":[],"mappings":"AAKA,OAAO,KAA+B,MAAM,OAAO,CAAA;AAKnD,eAAO,MAAM,aAAa,EAAE,KAAK,CAAC,EAsDjC,CAAA"}
@@ -1,3 +1,4 @@
1
1
  import { WithChildren } from '@xylabs/react-shared';
2
+ import React from 'react';
2
3
  export declare const PixelDebuggerProvider: React.FC<WithChildren>;
3
4
  //# sourceMappingURL=PixelDebuggerProvider.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"PixelDebuggerProvider.d.ts","sourceRoot":"","sources":["../../../src/components/PixelDebuggerProvider.tsx"],"names":[],"mappings":"AACA,OAAO,EAAmB,YAAY,EAAE,MAAM,sBAAsB,CAAA;AAEpE,eAAO,MAAM,qBAAqB,EAAE,KAAK,CAAC,EAAE,CAAC,YAAY,CAGxD,CAAA"}
1
+ {"version":3,"file":"PixelDebuggerProvider.d.ts","sourceRoot":"","sources":["../../../src/components/PixelDebuggerProvider.tsx"],"names":[],"mappings":"AACA,OAAO,EAAmB,YAAY,EAAE,MAAM,sBAAsB,CAAA;AACpE,OAAO,KAAkB,MAAM,OAAO,CAAA;AAEtC,eAAO,MAAM,qBAAqB,EAAE,KAAK,CAAC,EAAE,CAAC,YAAY,CAIxD,CAAA"}
@@ -1,3 +1,4 @@
1
1
  import { WithChildren } from '@xylabs/react-shared';
2
+ import React from 'react';
2
3
  export declare const PixelDebuggerProvider: React.FC<WithChildren>;
3
4
  //# sourceMappingURL=PixelDebuggerProvider.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"PixelDebuggerProvider.d.ts","sourceRoot":"","sources":["../../../src/components/PixelDebuggerProvider.tsx"],"names":[],"mappings":"AACA,OAAO,EAAmB,YAAY,EAAE,MAAM,sBAAsB,CAAA;AAEpE,eAAO,MAAM,qBAAqB,EAAE,KAAK,CAAC,EAAE,CAAC,YAAY,CAGxD,CAAA"}
1
+ {"version":3,"file":"PixelDebuggerProvider.d.ts","sourceRoot":"","sources":["../../../src/components/PixelDebuggerProvider.tsx"],"names":[],"mappings":"AACA,OAAO,EAAmB,YAAY,EAAE,MAAM,sBAAsB,CAAA;AACpE,OAAO,KAAkB,MAAM,OAAO,CAAA;AAEtC,eAAO,MAAM,qBAAqB,EAAE,KAAK,CAAC,EAAE,CAAC,YAAY,CAIxD,CAAA"}
@@ -1,3 +1,4 @@
1
1
  import { WithChildren } from '@xylabs/react-shared';
2
+ import React from 'react';
2
3
  export declare const PixelDebuggerProvider: React.FC<WithChildren>;
3
4
  //# sourceMappingURL=PixelDebuggerProvider.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"PixelDebuggerProvider.d.ts","sourceRoot":"","sources":["../../../src/components/PixelDebuggerProvider.tsx"],"names":[],"mappings":"AACA,OAAO,EAAmB,YAAY,EAAE,MAAM,sBAAsB,CAAA;AAEpE,eAAO,MAAM,qBAAqB,EAAE,KAAK,CAAC,EAAE,CAAC,YAAY,CAGxD,CAAA"}
1
+ {"version":3,"file":"PixelDebuggerProvider.d.ts","sourceRoot":"","sources":["../../../src/components/PixelDebuggerProvider.tsx"],"names":[],"mappings":"AACA,OAAO,EAAmB,YAAY,EAAE,MAAM,sBAAsB,CAAA;AACpE,OAAO,KAAkB,MAAM,OAAO,CAAA;AAEtC,eAAO,MAAM,qBAAqB,EAAE,KAAK,CAAC,EAAE,CAAC,YAAY,CAIxD,CAAA"}
@@ -1,3 +1,4 @@
1
1
  import { BusyBoxProps } from '@xylabs/react-flexbox';
2
+ import React from 'react';
2
3
  export declare const PixelDebuggerToggle: React.FC<BusyBoxProps>;
3
4
  //# sourceMappingURL=PixelDebuggerToggle.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"PixelDebuggerToggle.d.ts","sourceRoot":"","sources":["../../../src/components/PixelDebuggerToggle.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAW,MAAM,uBAAuB,CAAA;AAI7D,eAAO,MAAM,mBAAmB,EAAE,KAAK,CAAC,EAAE,CAAC,YAAY,CAWtD,CAAA"}
1
+ {"version":3,"file":"PixelDebuggerToggle.d.ts","sourceRoot":"","sources":["../../../src/components/PixelDebuggerToggle.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAW,MAAM,uBAAuB,CAAA;AAE7D,OAAO,KAAqB,MAAM,OAAO,CAAA;AAEzC,eAAO,MAAM,mBAAmB,EAAE,KAAK,CAAC,EAAE,CAAC,YAAY,CAWtD,CAAA"}
@@ -1,3 +1,4 @@
1
1
  import { BusyBoxProps } from '@xylabs/react-flexbox';
2
+ import React from 'react';
2
3
  export declare const PixelDebuggerToggle: React.FC<BusyBoxProps>;
3
4
  //# sourceMappingURL=PixelDebuggerToggle.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"PixelDebuggerToggle.d.ts","sourceRoot":"","sources":["../../../src/components/PixelDebuggerToggle.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAW,MAAM,uBAAuB,CAAA;AAI7D,eAAO,MAAM,mBAAmB,EAAE,KAAK,CAAC,EAAE,CAAC,YAAY,CAWtD,CAAA"}
1
+ {"version":3,"file":"PixelDebuggerToggle.d.ts","sourceRoot":"","sources":["../../../src/components/PixelDebuggerToggle.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAW,MAAM,uBAAuB,CAAA;AAE7D,OAAO,KAAqB,MAAM,OAAO,CAAA;AAEzC,eAAO,MAAM,mBAAmB,EAAE,KAAK,CAAC,EAAE,CAAC,YAAY,CAWtD,CAAA"}
@@ -1,3 +1,4 @@
1
1
  import { BusyBoxProps } from '@xylabs/react-flexbox';
2
+ import React from 'react';
2
3
  export declare const PixelDebuggerToggle: React.FC<BusyBoxProps>;
3
4
  //# sourceMappingURL=PixelDebuggerToggle.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"PixelDebuggerToggle.d.ts","sourceRoot":"","sources":["../../../src/components/PixelDebuggerToggle.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAW,MAAM,uBAAuB,CAAA;AAI7D,eAAO,MAAM,mBAAmB,EAAE,KAAK,CAAC,EAAE,CAAC,YAAY,CAWtD,CAAA"}
1
+ {"version":3,"file":"PixelDebuggerToggle.d.ts","sourceRoot":"","sources":["../../../src/components/PixelDebuggerToggle.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAW,MAAM,uBAAuB,CAAA;AAE7D,OAAO,KAAqB,MAAM,OAAO,CAAA;AAEzC,eAAO,MAAM,mBAAmB,EAAE,KAAK,CAAC,EAAE,CAAC,YAAY,CAWtD,CAAA"}
@@ -1,4 +1,4 @@
1
- export * from './PixelDebugger.jsx';
2
- export * from './PixelDebuggerProvider.jsx';
3
- export * from './PixelDebuggerToggle.jsx';
1
+ export * from './PixelDebugger.tsx';
2
+ export * from './PixelDebuggerProvider.tsx';
3
+ export * from './PixelDebuggerToggle.tsx';
4
4
  //# sourceMappingURL=index.d.ts.map
@@ -1,4 +1,4 @@
1
- export * from './PixelDebugger.jsx';
2
- export * from './PixelDebuggerProvider.jsx';
3
- export * from './PixelDebuggerToggle.jsx';
1
+ export * from './PixelDebugger.tsx';
2
+ export * from './PixelDebuggerProvider.tsx';
3
+ export * from './PixelDebuggerToggle.tsx';
4
4
  //# sourceMappingURL=index.d.ts.map
@@ -1,4 +1,4 @@
1
- export * from './PixelDebugger.jsx';
2
- export * from './PixelDebuggerProvider.jsx';
3
- export * from './PixelDebuggerToggle.jsx';
1
+ export * from './PixelDebugger.tsx';
2
+ export * from './PixelDebuggerProvider.tsx';
3
+ export * from './PixelDebuggerToggle.tsx';
4
4
  //# sourceMappingURL=index.d.ts.map
@@ -1,2 +1,2 @@
1
- export * from './usePixelAltSendHandler.js';
1
+ export * from './usePixelAltSendHandler.ts';
2
2
  //# sourceMappingURL=index.d.ts.map
@@ -1,2 +1,2 @@
1
- export * from './usePixelAltSendHandler.js';
1
+ export * from './usePixelAltSendHandler.ts';
2
2
  //# sourceMappingURL=index.d.ts.map
@@ -1,2 +1,2 @@
1
- export * from './usePixelAltSendHandler.js';
1
+ export * from './usePixelAltSendHandler.ts';
2
2
  //# sourceMappingURL=index.d.ts.map
@@ -1,8 +1,11 @@
1
1
  "use strict";
2
+ var __create = Object.create;
2
3
  var __defProp = Object.defineProperty;
3
4
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
5
  var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
5
7
  var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
6
9
  var __export = (target, all) => {
7
10
  for (var name in all)
8
11
  __defProp(target, name, { get: all[name], enumerable: true });
@@ -15,6 +18,14 @@ var __copyProps = (to, from, except, desc) => {
15
18
  }
16
19
  return to;
17
20
  };
21
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
22
+ // If the importer is in node compatibility mode or this is not an ESM
23
+ // file that has been converted to a CommonJS file using a Babel-
24
+ // compatible transform (i.e. "__esModule" has not been set), then set
25
+ // "default" to the CommonJS "module.exports" for node compatibility.
26
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
27
+ mod
28
+ ));
18
29
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
30
 
20
31
  // src/index.ts
@@ -33,12 +44,12 @@ var import_react_button = require("@xylabs/react-button");
33
44
  var import_react_flexbox = require("@xylabs/react-flexbox");
34
45
  var import_react_pixel = require("@xylabs/react-pixel");
35
46
  var import_react_portal = require("@xylabs/react-portal");
36
- var import_react2 = require("react");
47
+ var import_react2 = __toESM(require("react"), 1);
37
48
 
38
49
  // src/hooks/usePixelAltSendHandler.ts
39
50
  var import_pixel = require("@xylabs/pixel");
40
51
  var import_react = require("react");
41
- var usePixelAltSendHandler = (altHandler) => {
52
+ var usePixelAltSendHandler = /* @__PURE__ */ __name((altHandler) => {
42
53
  const [pixelSend, setPixelSend] = (0, import_react.useState)();
43
54
  (0, import_react.useEffect)(() => {
44
55
  if (!pixelSend && import_pixel.XyPixel.instance.send) {
@@ -55,79 +66,127 @@ var usePixelAltSendHandler = (altHandler) => {
55
66
  import_pixel.XyPixel.instance.send = pixelSend;
56
67
  }
57
68
  };
58
- }, [pixelSend, altHandler]);
59
- };
69
+ }, [
70
+ pixelSend,
71
+ altHandler
72
+ ]);
73
+ }, "usePixelAltSendHandler");
60
74
 
61
75
  // src/components/PixelDebugger.tsx
62
- var import_jsx_runtime = require("react/jsx-runtime");
63
- var PixelDebugger = () => {
76
+ var PixelDebugger = /* @__PURE__ */ __name(() => {
64
77
  const { isDebugging } = (0, import_react2.useContext)(import_react_pixel.DebugUserEventsContext);
65
78
  const theme = (0, import_material.useTheme)();
66
79
  const [displayEvents, setDisplayEvents] = (0, import_react2.useState)(false);
67
80
  const [events, setEvents] = (0, import_react2.useState)([]);
68
81
  usePixelAltSendHandler((event, fields) => {
69
- setEvents((events2) => [{ event, fields }, ...events2]);
82
+ setEvents((events2) => [
83
+ {
84
+ event,
85
+ fields
86
+ },
87
+ ...events2
88
+ ]);
70
89
  });
71
90
  if (!isDebugging) {
72
91
  return null;
73
92
  }
74
- return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_react_portal.Portal, { children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { style: { bottom: 0, left: 0, position: "fixed", width: 350 }, children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_material.Badge, { badgeContent: events.length, color: "primary", sx: { width: "100%" }, children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
75
- import_material.Card,
76
- {
77
- variant: "outlined",
78
- sx: {
79
- backdropFilter: "blur(16px) saturate(180%)",
80
- backgroundColor: "rgba(18, 18, 18, .70)",
81
- overflowY: "auto",
82
- width: "100%"
83
- },
84
- color: theme.palette.primary.main,
85
- children: /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(import_react_flexbox.FlexCol, { alignItems: "stretch", sx: { flexFlow: "column", maxHeight: 400 }, children: [
86
- /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_react_flexbox.FlexCol, { alignItems: "stretch", sx: { flex: "0 1 auto" }, children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_react_button.ButtonEx, { variant: "text", onClick: () => setDisplayEvents(!displayEvents), children: "XY Pixel Debugger" }) }),
87
- displayEvents && events.length > 0 && /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
88
- import_react_flexbox.FlexCol,
89
- {
90
- alignItems: "stretch",
91
- alignContent: "start",
92
- padding: 2,
93
- sx: { cursor: "pointer", flex: "1 1 auto", overflowY: "auto", userSelect: "none" },
94
- children: events.map((e, index) => /* @__PURE__ */ (0, import_jsx_runtime.jsx)(PixelEventDetails, { events, index, ...e }, `${e.event}-${index}`))
95
- }
96
- ),
97
- displayEvents && events.length === 0 && /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_material.Typography, { variant: "subtitle2", children: "No Events" })
98
- ] })
93
+ return /* @__PURE__ */ import_react2.default.createElement(import_react_portal.Portal, null, /* @__PURE__ */ import_react2.default.createElement("div", {
94
+ style: {
95
+ bottom: 0,
96
+ left: 0,
97
+ position: "fixed",
98
+ width: 350
99
99
  }
100
- ) }) }) });
101
- };
102
- var PixelEventDetails = ({ event, fields, index, events }) => {
100
+ }, /* @__PURE__ */ import_react2.default.createElement(import_material.Badge, {
101
+ badgeContent: events.length,
102
+ color: "primary",
103
+ sx: {
104
+ width: "100%"
105
+ }
106
+ }, /* @__PURE__ */ import_react2.default.createElement(import_material.Card, {
107
+ variant: "outlined",
108
+ sx: {
109
+ backdropFilter: "blur(16px) saturate(180%)",
110
+ backgroundColor: "rgba(18, 18, 18, .70)",
111
+ overflowY: "auto",
112
+ width: "100%"
113
+ },
114
+ color: theme.palette.primary.main
115
+ }, /* @__PURE__ */ import_react2.default.createElement(import_react_flexbox.FlexCol, {
116
+ alignItems: "stretch",
117
+ sx: {
118
+ flexFlow: "column",
119
+ maxHeight: 400
120
+ }
121
+ }, /* @__PURE__ */ import_react2.default.createElement(import_react_flexbox.FlexCol, {
122
+ alignItems: "stretch",
123
+ sx: {
124
+ flex: "0 1 auto"
125
+ }
126
+ }, /* @__PURE__ */ import_react2.default.createElement(import_react_button.ButtonEx, {
127
+ variant: "text",
128
+ onClick: /* @__PURE__ */ __name(() => setDisplayEvents(!displayEvents), "onClick")
129
+ }, "XY Pixel Debugger")), displayEvents && events.length > 0 && /* @__PURE__ */ import_react2.default.createElement(import_react_flexbox.FlexCol, {
130
+ alignItems: "stretch",
131
+ alignContent: "start",
132
+ padding: 2,
133
+ sx: {
134
+ cursor: "pointer",
135
+ flex: "1 1 auto",
136
+ overflowY: "auto",
137
+ userSelect: "none"
138
+ }
139
+ }, events.map((e, index) => /* @__PURE__ */ import_react2.default.createElement(PixelEventDetails, {
140
+ key: `${e.event}-${index}`,
141
+ events,
142
+ index,
143
+ ...e
144
+ }))), displayEvents && events.length === 0 && /* @__PURE__ */ import_react2.default.createElement(import_material.Typography, {
145
+ variant: "subtitle2"
146
+ }, "No Events"))))));
147
+ }, "PixelDebugger");
148
+ var PixelEventDetails = /* @__PURE__ */ __name(({ event, fields, index, events }) => {
103
149
  const [isOpen, setIsOpen] = (0, import_react2.useState)(false);
104
- return /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(import_react_flexbox.FlexCol, { alignItems: "stretch", marginBottom: 0.5, onClick: () => setIsOpen(!isOpen), children: [
105
- /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_material.Typography, { variant: "subtitle2", children: event }),
106
- isOpen && /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_material.Typography, { marginBottom: 0.5, variant: "caption", children: JSON.stringify(fields, null, 2) }),
107
- events[index + 1] && /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_material.Divider, {})
108
- ] });
109
- };
150
+ return /* @__PURE__ */ import_react2.default.createElement(import_react_flexbox.FlexCol, {
151
+ alignItems: "stretch",
152
+ marginBottom: 0.5,
153
+ onClick: /* @__PURE__ */ __name(() => setIsOpen(!isOpen), "onClick")
154
+ }, /* @__PURE__ */ import_react2.default.createElement(import_material.Typography, {
155
+ variant: "subtitle2"
156
+ }, event), isOpen && /* @__PURE__ */ import_react2.default.createElement(import_material.Typography, {
157
+ marginBottom: 0.5,
158
+ variant: "caption"
159
+ }, JSON.stringify(fields, null, 2)), events[index + 1] && /* @__PURE__ */ import_react2.default.createElement(import_material.Divider, null));
160
+ }, "PixelEventDetails");
110
161
 
111
162
  // src/components/PixelDebuggerProvider.tsx
112
163
  var import_react_pixel2 = require("@xylabs/react-pixel");
113
164
  var import_react_shared = require("@xylabs/react-shared");
114
- var import_jsx_runtime2 = require("react/jsx-runtime");
115
- var PixelDebuggerProvider = ({ children }) => {
165
+ var import_react3 = __toESM(require("react"), 1);
166
+ var PixelDebuggerProvider = /* @__PURE__ */ __name(({ children }) => {
116
167
  const [isDebugging, setIsDebugging] = (0, import_react_shared.useLocalStorage)("isDebuggingPixel", false);
117
- return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(import_react_pixel2.DebugUserEventsContext.Provider, { value: { isDebugging, setIsDebugging }, children });
118
- };
168
+ const value = (0, import_react3.useMemo)(() => ({
169
+ isDebugging,
170
+ setIsDebugging
171
+ }), [
172
+ isDebugging,
173
+ setIsDebugging
174
+ ]);
175
+ return /* @__PURE__ */ import_react3.default.createElement(import_react_pixel2.DebugUserEventsContext.Provider, {
176
+ value
177
+ }, children);
178
+ }, "PixelDebuggerProvider");
119
179
 
120
180
  // src/components/PixelDebuggerToggle.tsx
121
181
  var import_material2 = require("@mui/material");
122
182
  var import_react_flexbox2 = require("@xylabs/react-flexbox");
123
183
  var import_react_pixel3 = require("@xylabs/react-pixel");
124
- var import_react3 = require("react");
125
- var import_jsx_runtime3 = require("react/jsx-runtime");
126
- var PixelDebuggerToggle = ({ ...props }) => {
127
- const { setIsDebugging, isDebugging } = (0, import_react3.useContext)(import_react_pixel3.DebugUserEventsContext);
128
- return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(import_react_flexbox2.FlexRow, { ...props, children: /* @__PURE__ */ (0, import_jsx_runtime3.jsxs)(import_material2.FormControl, { children: [
129
- /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(import_material2.FormLabel, { children: "Enable Debugger" }),
130
- /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(import_material2.Switch, { checked: isDebugging, onClick: () => setIsDebugging(!isDebugging) })
131
- ] }) });
132
- };
184
+ var import_react4 = __toESM(require("react"), 1);
185
+ var PixelDebuggerToggle = /* @__PURE__ */ __name(({ ...props }) => {
186
+ const { setIsDebugging, isDebugging } = (0, import_react4.useContext)(import_react_pixel3.DebugUserEventsContext);
187
+ return /* @__PURE__ */ import_react4.default.createElement(import_react_flexbox2.FlexRow, props, /* @__PURE__ */ import_react4.default.createElement(import_material2.FormControl, null, /* @__PURE__ */ import_react4.default.createElement(import_material2.FormLabel, null, "Enable Debugger"), /* @__PURE__ */ import_react4.default.createElement(import_material2.Switch, {
188
+ checked: isDebugging,
189
+ onClick: /* @__PURE__ */ __name(() => setIsDebugging(!isDebugging), "onClick")
190
+ })));
191
+ }, "PixelDebuggerToggle");
133
192
  //# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/components/PixelDebugger.tsx","../../src/hooks/usePixelAltSendHandler.ts","../../src/components/PixelDebuggerProvider.tsx","../../src/components/PixelDebuggerToggle.tsx"],"sourcesContent":["export * from './components/index.js'\nexport * from './hooks/index.js'\nexport * from './PixelEvent.js'\n","import { Badge, Card, Divider, Typography, useTheme } from '@mui/material'\nimport { ButtonEx } from '@xylabs/react-button'\nimport { FlexCol } from '@xylabs/react-flexbox'\nimport { DebugUserEventsContext } from '@xylabs/react-pixel'\nimport { Portal } from '@xylabs/react-portal'\nimport { useContext, useState } from 'react'\n\nimport { usePixelAltSendHandler } from '../hooks/index.js'\nimport { PixelEvent } from '../PixelEvent.js'\n\nexport const PixelDebugger: React.FC = () => {\n const { isDebugging } = useContext(DebugUserEventsContext)\n //TODO - when adding in the location hook to detect location change, was dropping the setEvents in usePixelAltSendHand\n const theme = useTheme()\n const [displayEvents, setDisplayEvents] = useState(false)\n const [events, setEvents] = useState<PixelEvent[]>([])\n\n usePixelAltSendHandler((event: string, fields?: Record<string, unknown>) => {\n setEvents((events) => [{ event, fields }, ...events])\n })\n\n if (!isDebugging) {\n return null\n }\n\n return (\n <Portal>\n <div style={{ bottom: 0, left: 0, position: 'fixed', width: 350 }}>\n <Badge badgeContent={events.length} color=\"primary\" sx={{ width: '100%' }}>\n <Card\n variant=\"outlined\"\n sx={{\n backdropFilter: 'blur(16px) saturate(180%)',\n backgroundColor: 'rgba(18, 18, 18, .70)',\n overflowY: 'auto',\n width: '100%',\n }}\n color={theme.palette.primary.main}\n >\n <FlexCol alignItems=\"stretch\" sx={{ flexFlow: 'column', maxHeight: 400 }}>\n <FlexCol alignItems=\"stretch\" sx={{ flex: '0 1 auto' }}>\n <ButtonEx variant=\"text\" onClick={() => setDisplayEvents(!displayEvents)}>\n XY Pixel Debugger\n </ButtonEx>\n </FlexCol>\n {displayEvents && events.length > 0 && (\n <FlexCol\n alignItems=\"stretch\"\n alignContent=\"start\"\n padding={2}\n sx={{ cursor: 'pointer', flex: '1 1 auto', overflowY: 'auto', userSelect: 'none' }}\n >\n {events.map((e, index) => (\n <PixelEventDetails key={`${e.event}-${index}`} events={events} index={index} {...e} />\n ))}\n </FlexCol>\n )}\n {displayEvents && events.length === 0 && <Typography variant=\"subtitle2\">No Events</Typography>}\n </FlexCol>\n </Card>\n </Badge>\n </div>\n </Portal>\n )\n}\n\nconst PixelEventDetails: React.FC<PixelEvent & { events: PixelEvent[]; index: number }> = ({ event, fields, index, events }) => {\n const [isOpen, setIsOpen] = useState(false)\n return (\n <FlexCol alignItems=\"stretch\" marginBottom={0.5} onClick={() => setIsOpen(!isOpen)}>\n <Typography variant=\"subtitle2\">{event}</Typography>\n {isOpen && (\n <Typography marginBottom={0.5} variant=\"caption\">\n {JSON.stringify(fields, null, 2)}\n </Typography>\n )}\n {events[index + 1] && <Divider />}\n </FlexCol>\n )\n}\n","import { XyPixel } from '@xylabs/pixel'\nimport { useEffect, useState } from 'react'\n\nexport const usePixelAltSendHandler = (altHandler: (event: string, fields?: Record<string, unknown>) => void) => {\n const [pixelSend, setPixelSend] = useState<typeof XyPixel.instance.send>()\n useEffect(() => {\n if (!pixelSend && XyPixel.instance.send) {\n const oldHandler = XyPixel.instance.send.bind(XyPixel.instance)\n setPixelSend(oldHandler)\n } else {\n XyPixel.instance.send = async (event: string, fields?: Record<string, unknown>, eventId?: string) => {\n altHandler(event, fields)\n return await pixelSend?.(event, fields, eventId)\n }\n }\n return () => {\n //restore send on unmount\n if (pixelSend) {\n XyPixel.instance.send = pixelSend\n }\n }\n }, [pixelSend, altHandler])\n}\n","import { DebugUserEventsContext } from '@xylabs/react-pixel'\nimport { useLocalStorage, WithChildren } from '@xylabs/react-shared'\n\nexport const PixelDebuggerProvider: React.FC<WithChildren> = ({ children }) => {\n const [isDebugging, setIsDebugging] = useLocalStorage<boolean>('isDebuggingPixel', false)\n return <DebugUserEventsContext.Provider value={{ isDebugging, setIsDebugging }}>{children}</DebugUserEventsContext.Provider>\n}\n","import { FormControl, FormLabel, Switch } from '@mui/material'\nimport { BusyBoxProps, FlexRow } from '@xylabs/react-flexbox'\nimport { DebugUserEventsContext } from '@xylabs/react-pixel'\nimport { useContext } from 'react'\n\nexport const PixelDebuggerToggle: React.FC<BusyBoxProps> = ({ ...props }) => {\n const { setIsDebugging, isDebugging } = useContext(DebugUserEventsContext)\n\n return (\n <FlexRow {...props}>\n <FormControl>\n <FormLabel>Enable Debugger</FormLabel>\n <Switch checked={isDebugging} onClick={() => setIsDebugging(!isDebugging)} />\n </FormControl>\n </FlexRow>\n )\n}\n"],"mappings":"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","names":["import_react","events","import_react_pixel","import_jsx_runtime","import_material","import_react_flexbox","import_react_pixel","import_react","import_jsx_runtime"]}
1
+ {"version":3,"sources":["../../src/index.ts","../../src/components/PixelDebugger.tsx","../../src/hooks/usePixelAltSendHandler.ts","../../src/components/PixelDebuggerProvider.tsx","../../src/components/PixelDebuggerToggle.tsx"],"sourcesContent":["export * from './components/index.ts'\nexport * from './hooks/index.ts'\nexport * from './PixelEvent.ts'\n","import { Badge, Card, Divider, Typography, useTheme } from '@mui/material'\nimport { ButtonEx } from '@xylabs/react-button'\nimport { FlexCol } from '@xylabs/react-flexbox'\nimport { DebugUserEventsContext } from '@xylabs/react-pixel'\nimport { Portal } from '@xylabs/react-portal'\nimport React, { useContext, useState } from 'react'\n\nimport { usePixelAltSendHandler } from '../hooks/index.ts'\nimport { PixelEvent } from '../PixelEvent.ts'\n\nexport const PixelDebugger: React.FC = () => {\n const { isDebugging } = useContext(DebugUserEventsContext)\n // TODO - when adding in the location hook to detect location change, was dropping the setEvents in usePixelAltSendHand\n const theme = useTheme()\n const [displayEvents, setDisplayEvents] = useState(false)\n const [events, setEvents] = useState<PixelEvent[]>([])\n\n usePixelAltSendHandler((event: string, fields?: Record<string, unknown>) => {\n setEvents(events => [{ event, fields }, ...events])\n })\n\n if (!isDebugging) {\n return null\n }\n\n return (\n <Portal>\n <div style={{ bottom: 0, left: 0, position: 'fixed', width: 350 }}>\n <Badge badgeContent={events.length} color=\"primary\" sx={{ width: '100%' }}>\n <Card\n variant=\"outlined\"\n sx={{\n backdropFilter: 'blur(16px) saturate(180%)',\n backgroundColor: 'rgba(18, 18, 18, .70)',\n overflowY: 'auto',\n width: '100%',\n }}\n color={theme.palette.primary.main}\n >\n <FlexCol alignItems=\"stretch\" sx={{ flexFlow: 'column', maxHeight: 400 }}>\n <FlexCol alignItems=\"stretch\" sx={{ flex: '0 1 auto' }}>\n <ButtonEx variant=\"text\" onClick={() => setDisplayEvents(!displayEvents)}>\n XY Pixel Debugger\n </ButtonEx>\n </FlexCol>\n {displayEvents && events.length > 0 && (\n <FlexCol\n alignItems=\"stretch\"\n alignContent=\"start\"\n padding={2}\n sx={{ cursor: 'pointer', flex: '1 1 auto', overflowY: 'auto', userSelect: 'none' }}\n >\n {events.map((e, index) => (\n <PixelEventDetails key={`${e.event}-${index}`} events={events} index={index} {...e} />\n ))}\n </FlexCol>\n )}\n {displayEvents && events.length === 0 && <Typography variant=\"subtitle2\">No Events</Typography>}\n </FlexCol>\n </Card>\n </Badge>\n </div>\n </Portal>\n )\n}\n\nconst PixelEventDetails: React.FC<PixelEvent & { events: PixelEvent[]; index: number }> = ({ event, fields, index, events }) => {\n const [isOpen, setIsOpen] = useState(false)\n return (\n <FlexCol alignItems=\"stretch\" marginBottom={0.5} onClick={() => setIsOpen(!isOpen)}>\n <Typography variant=\"subtitle2\">{event}</Typography>\n {isOpen && (\n <Typography marginBottom={0.5} variant=\"caption\">\n {JSON.stringify(fields, null, 2)}\n </Typography>\n )}\n {events[index + 1] && <Divider />}\n </FlexCol>\n )\n}\n","import { XyPixel } from '@xylabs/pixel'\nimport { useEffect, useState } from 'react'\n\nexport const usePixelAltSendHandler = (altHandler: (event: string, fields?: Record<string, unknown>) => void) => {\n const [pixelSend, setPixelSend] = useState<typeof XyPixel.instance.send>()\n useEffect(() => {\n if (!pixelSend && XyPixel.instance.send) {\n const oldHandler = XyPixel.instance.send.bind(XyPixel.instance)\n setPixelSend(oldHandler)\n } else {\n XyPixel.instance.send = async (event: string, fields?: Record<string, unknown>, eventId?: string) => {\n altHandler(event, fields)\n return await pixelSend?.(event, fields, eventId)\n }\n }\n return () => {\n // restore send on unmount\n if (pixelSend) {\n XyPixel.instance.send = pixelSend\n }\n }\n }, [pixelSend, altHandler])\n}\n","import { DebugUserEventsContext } from '@xylabs/react-pixel'\nimport { useLocalStorage, WithChildren } from '@xylabs/react-shared'\nimport React, { useMemo } from 'react'\n\nexport const PixelDebuggerProvider: React.FC<WithChildren> = ({ children }) => {\n const [isDebugging, setIsDebugging] = useLocalStorage<boolean>('isDebuggingPixel', false)\n const value = useMemo(() => ({ isDebugging, setIsDebugging }), [isDebugging, setIsDebugging])\n return <DebugUserEventsContext.Provider value={value}>{children}</DebugUserEventsContext.Provider>\n}\n","import { FormControl, FormLabel, Switch } from '@mui/material'\nimport { BusyBoxProps, FlexRow } from '@xylabs/react-flexbox'\nimport { DebugUserEventsContext } from '@xylabs/react-pixel'\nimport React, { useContext } from 'react'\n\nexport const PixelDebuggerToggle: React.FC<BusyBoxProps> = ({ ...props }) => {\n const { setIsDebugging, isDebugging } = useContext(DebugUserEventsContext)\n\n return (\n <FlexRow {...props}>\n <FormControl>\n <FormLabel>Enable Debugger</FormLabel>\n <Switch checked={isDebugging} onClick={() => setIsDebugging(!isDebugging)} />\n </FormControl>\n </FlexRow>\n )\n}\n"],"mappings":"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","names":["import_react","usePixelAltSendHandler","altHandler","pixelSend","setPixelSend","useState","useEffect","XyPixel","instance","send","oldHandler","bind","event","fields","eventId","PixelDebugger","isDebugging","useContext","DebugUserEventsContext","theme","useTheme","displayEvents","setDisplayEvents","useState","events","setEvents","usePixelAltSendHandler","event","fields","React","Portal","div","style","bottom","left","position","width","Badge","badgeContent","length","color","sx","Card","variant","backdropFilter","backgroundColor","overflowY","palette","primary","main","FlexCol","alignItems","flexFlow","maxHeight","flex","ButtonEx","onClick","alignContent","padding","cursor","userSelect","map","e","index","PixelEventDetails","key","Typography","isOpen","setIsOpen","marginBottom","JSON","stringify","Divider","import_react_pixel","import_react","PixelDebuggerProvider","children","isDebugging","setIsDebugging","useLocalStorage","value","useMemo","React","DebugUserEventsContext","Provider","import_material","import_react_flexbox","import_react_pixel","import_react","PixelDebuggerToggle","props","setIsDebugging","isDebugging","useContext","DebugUserEventsContext","React","FlexRow","FormControl","FormLabel","Switch","checked","onClick"]}
@@ -1,4 +1,4 @@
1
- export * from './components/index.js';
2
- export * from './hooks/index.js';
3
- export * from './PixelEvent.js';
1
+ export * from './components/index.ts';
2
+ export * from './hooks/index.ts';
3
+ export * from './PixelEvent.ts';
4
4
  //# sourceMappingURL=index.d.ts.map
@@ -1,4 +1,4 @@
1
- export * from './components/index.js';
2
- export * from './hooks/index.js';
3
- export * from './PixelEvent.js';
1
+ export * from './components/index.ts';
2
+ export * from './hooks/index.ts';
3
+ export * from './PixelEvent.ts';
4
4
  //# sourceMappingURL=index.d.ts.map
@@ -1,4 +1,4 @@
1
- export * from './components/index.js';
2
- export * from './hooks/index.js';
3
- export * from './PixelEvent.js';
1
+ export * from './components/index.ts';
2
+ export * from './hooks/index.ts';
3
+ export * from './PixelEvent.ts';
4
4
  //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1,161 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
+
4
+ // src/components/PixelDebugger.tsx
5
+ import { Badge, Card, Divider, Typography, useTheme } from "@mui/material";
6
+ import { ButtonEx } from "@xylabs/react-button";
7
+ import { FlexCol } from "@xylabs/react-flexbox";
8
+ import { DebugUserEventsContext } from "@xylabs/react-pixel";
9
+ import { Portal } from "@xylabs/react-portal";
10
+ import React, { useContext, useState as useState2 } from "react";
11
+
12
+ // src/hooks/usePixelAltSendHandler.ts
13
+ import { XyPixel } from "@xylabs/pixel";
14
+ import { useEffect, useState } from "react";
15
+ var usePixelAltSendHandler = /* @__PURE__ */ __name((altHandler) => {
16
+ const [pixelSend, setPixelSend] = useState();
17
+ useEffect(() => {
18
+ if (!pixelSend && XyPixel.instance.send) {
19
+ const oldHandler = XyPixel.instance.send.bind(XyPixel.instance);
20
+ setPixelSend(oldHandler);
21
+ } else {
22
+ XyPixel.instance.send = async (event, fields, eventId) => {
23
+ altHandler(event, fields);
24
+ return await pixelSend?.(event, fields, eventId);
25
+ };
26
+ }
27
+ return () => {
28
+ if (pixelSend) {
29
+ XyPixel.instance.send = pixelSend;
30
+ }
31
+ };
32
+ }, [
33
+ pixelSend,
34
+ altHandler
35
+ ]);
36
+ }, "usePixelAltSendHandler");
37
+
38
+ // src/components/PixelDebugger.tsx
39
+ var PixelDebugger = /* @__PURE__ */ __name(() => {
40
+ const { isDebugging } = useContext(DebugUserEventsContext);
41
+ const theme = useTheme();
42
+ const [displayEvents, setDisplayEvents] = useState2(false);
43
+ const [events, setEvents] = useState2([]);
44
+ usePixelAltSendHandler((event, fields) => {
45
+ setEvents((events2) => [
46
+ {
47
+ event,
48
+ fields
49
+ },
50
+ ...events2
51
+ ]);
52
+ });
53
+ if (!isDebugging) {
54
+ return null;
55
+ }
56
+ return /* @__PURE__ */ React.createElement(Portal, null, /* @__PURE__ */ React.createElement("div", {
57
+ style: {
58
+ bottom: 0,
59
+ left: 0,
60
+ position: "fixed",
61
+ width: 350
62
+ }
63
+ }, /* @__PURE__ */ React.createElement(Badge, {
64
+ badgeContent: events.length,
65
+ color: "primary",
66
+ sx: {
67
+ width: "100%"
68
+ }
69
+ }, /* @__PURE__ */ React.createElement(Card, {
70
+ variant: "outlined",
71
+ sx: {
72
+ backdropFilter: "blur(16px) saturate(180%)",
73
+ backgroundColor: "rgba(18, 18, 18, .70)",
74
+ overflowY: "auto",
75
+ width: "100%"
76
+ },
77
+ color: theme.palette.primary.main
78
+ }, /* @__PURE__ */ React.createElement(FlexCol, {
79
+ alignItems: "stretch",
80
+ sx: {
81
+ flexFlow: "column",
82
+ maxHeight: 400
83
+ }
84
+ }, /* @__PURE__ */ React.createElement(FlexCol, {
85
+ alignItems: "stretch",
86
+ sx: {
87
+ flex: "0 1 auto"
88
+ }
89
+ }, /* @__PURE__ */ React.createElement(ButtonEx, {
90
+ variant: "text",
91
+ onClick: /* @__PURE__ */ __name(() => setDisplayEvents(!displayEvents), "onClick")
92
+ }, "XY Pixel Debugger")), displayEvents && events.length > 0 && /* @__PURE__ */ React.createElement(FlexCol, {
93
+ alignItems: "stretch",
94
+ alignContent: "start",
95
+ padding: 2,
96
+ sx: {
97
+ cursor: "pointer",
98
+ flex: "1 1 auto",
99
+ overflowY: "auto",
100
+ userSelect: "none"
101
+ }
102
+ }, events.map((e, index) => /* @__PURE__ */ React.createElement(PixelEventDetails, {
103
+ key: `${e.event}-${index}`,
104
+ events,
105
+ index,
106
+ ...e
107
+ }))), displayEvents && events.length === 0 && /* @__PURE__ */ React.createElement(Typography, {
108
+ variant: "subtitle2"
109
+ }, "No Events"))))));
110
+ }, "PixelDebugger");
111
+ var PixelEventDetails = /* @__PURE__ */ __name(({ event, fields, index, events }) => {
112
+ const [isOpen, setIsOpen] = useState2(false);
113
+ return /* @__PURE__ */ React.createElement(FlexCol, {
114
+ alignItems: "stretch",
115
+ marginBottom: 0.5,
116
+ onClick: /* @__PURE__ */ __name(() => setIsOpen(!isOpen), "onClick")
117
+ }, /* @__PURE__ */ React.createElement(Typography, {
118
+ variant: "subtitle2"
119
+ }, event), isOpen && /* @__PURE__ */ React.createElement(Typography, {
120
+ marginBottom: 0.5,
121
+ variant: "caption"
122
+ }, JSON.stringify(fields, null, 2)), events[index + 1] && /* @__PURE__ */ React.createElement(Divider, null));
123
+ }, "PixelEventDetails");
124
+
125
+ // src/components/PixelDebuggerProvider.tsx
126
+ import { DebugUserEventsContext as DebugUserEventsContext2 } from "@xylabs/react-pixel";
127
+ import { useLocalStorage } from "@xylabs/react-shared";
128
+ import React2, { useMemo } from "react";
129
+ var PixelDebuggerProvider = /* @__PURE__ */ __name(({ children }) => {
130
+ const [isDebugging, setIsDebugging] = useLocalStorage("isDebuggingPixel", false);
131
+ const value = useMemo(() => ({
132
+ isDebugging,
133
+ setIsDebugging
134
+ }), [
135
+ isDebugging,
136
+ setIsDebugging
137
+ ]);
138
+ return /* @__PURE__ */ React2.createElement(DebugUserEventsContext2.Provider, {
139
+ value
140
+ }, children);
141
+ }, "PixelDebuggerProvider");
142
+
143
+ // src/components/PixelDebuggerToggle.tsx
144
+ import { FormControl, FormLabel, Switch } from "@mui/material";
145
+ import { FlexRow } from "@xylabs/react-flexbox";
146
+ import { DebugUserEventsContext as DebugUserEventsContext3 } from "@xylabs/react-pixel";
147
+ import React3, { useContext as useContext2 } from "react";
148
+ var PixelDebuggerToggle = /* @__PURE__ */ __name(({ ...props }) => {
149
+ const { setIsDebugging, isDebugging } = useContext2(DebugUserEventsContext3);
150
+ return /* @__PURE__ */ React3.createElement(FlexRow, props, /* @__PURE__ */ React3.createElement(FormControl, null, /* @__PURE__ */ React3.createElement(FormLabel, null, "Enable Debugger"), /* @__PURE__ */ React3.createElement(Switch, {
151
+ checked: isDebugging,
152
+ onClick: /* @__PURE__ */ __name(() => setIsDebugging(!isDebugging), "onClick")
153
+ })));
154
+ }, "PixelDebuggerToggle");
155
+ export {
156
+ PixelDebugger,
157
+ PixelDebuggerProvider,
158
+ PixelDebuggerToggle,
159
+ usePixelAltSendHandler
160
+ };
161
+ //# sourceMappingURL=index.mjs.map