@xylabs/sdk-react 2.9.12 → 2.9.16

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 (116) hide show
  1. package/dist/cjs5/components/Pixel/PixelDebugger.d.ts +2 -0
  2. package/dist/cjs5/components/Pixel/PixelDebugger.stories.d.ts +6 -0
  3. package/dist/cjs5/components/Pixel/PixelDebuggerToggle.d.ts +3 -0
  4. package/dist/cjs5/components/Pixel/hooks/index.d.ts +1 -0
  5. package/dist/cjs5/components/Pixel/index.d.ts +2 -0
  6. package/dist/cjs5/components/Pixel/models/index.d.ts +4 -0
  7. package/dist/cjs5/components/Portal/Portal.d.ts +3 -0
  8. package/dist/cjs5/components/Portal/PortalProps.d.ts +7 -0
  9. package/dist/cjs5/components/Portal/index.d.ts +2 -0
  10. package/dist/cjs5/components/index.d.ts +2 -0
  11. package/dist/cjs5/index.js +70 -2
  12. package/dist/cjs5/index.js.map +1 -1
  13. package/dist/components/Pixel/PixelDebugger.d.ts +2 -0
  14. package/dist/components/Pixel/PixelDebugger.js +26 -0
  15. package/dist/components/Pixel/PixelDebugger.js.map +1 -0
  16. package/dist/components/Pixel/PixelDebugger.stories.d.ts +6 -0
  17. package/dist/components/Pixel/PixelDebugger.stories.js +27 -0
  18. package/dist/components/Pixel/PixelDebugger.stories.js.map +1 -0
  19. package/dist/components/Pixel/PixelDebuggerToggle.d.ts +3 -0
  20. package/dist/components/Pixel/PixelDebuggerToggle.js +13 -0
  21. package/dist/components/Pixel/PixelDebuggerToggle.js.map +1 -0
  22. package/dist/components/Pixel/hooks/index.d.ts +1 -0
  23. package/dist/components/Pixel/hooks/index.js +25 -0
  24. package/dist/components/Pixel/hooks/index.js.map +1 -0
  25. package/dist/components/Pixel/index.d.ts +2 -0
  26. package/dist/components/Pixel/index.js +3 -0
  27. package/dist/components/Pixel/index.js.map +1 -0
  28. package/dist/components/Pixel/models/index.d.ts +4 -0
  29. package/dist/components/Pixel/models/index.js +2 -0
  30. package/dist/components/Pixel/models/index.js.map +1 -0
  31. package/dist/components/Portal/Portal.d.ts +3 -0
  32. package/dist/components/Portal/Portal.js +20 -0
  33. package/dist/components/Portal/Portal.js.map +1 -0
  34. package/dist/components/Portal/PortalProps.d.ts +7 -0
  35. package/dist/components/Portal/PortalProps.js +2 -0
  36. package/dist/components/Portal/PortalProps.js.map +1 -0
  37. package/dist/components/Portal/index.d.ts +2 -0
  38. package/dist/components/Portal/index.js +3 -0
  39. package/dist/components/Portal/index.js.map +1 -0
  40. package/dist/components/index.d.ts +2 -0
  41. package/dist/components/index.js +2 -0
  42. package/dist/components/index.js.map +1 -1
  43. package/dist/esm2015/components/Pixel/PixelDebugger.d.ts +2 -0
  44. package/dist/esm2015/components/Pixel/PixelDebugger.stories.d.ts +6 -0
  45. package/dist/esm2015/components/Pixel/PixelDebuggerToggle.d.ts +3 -0
  46. package/dist/esm2015/components/Pixel/hooks/index.d.ts +1 -0
  47. package/dist/esm2015/components/Pixel/index.d.ts +2 -0
  48. package/dist/esm2015/components/Pixel/models/index.d.ts +4 -0
  49. package/dist/esm2015/components/Portal/Portal.d.ts +3 -0
  50. package/dist/esm2015/components/Portal/PortalProps.d.ts +7 -0
  51. package/dist/esm2015/components/Portal/index.d.ts +2 -0
  52. package/dist/esm2015/components/index.d.ts +2 -0
  53. package/dist/esm2015/index.js +69 -4
  54. package/dist/esm2015/index.js.map +1 -1
  55. package/dist/esm2017/components/Pixel/PixelDebugger.d.ts +2 -0
  56. package/dist/esm2017/components/Pixel/PixelDebugger.stories.d.ts +6 -0
  57. package/dist/esm2017/components/Pixel/PixelDebuggerToggle.d.ts +3 -0
  58. package/dist/esm2017/components/Pixel/hooks/index.d.ts +1 -0
  59. package/dist/esm2017/components/Pixel/index.d.ts +2 -0
  60. package/dist/esm2017/components/Pixel/models/index.d.ts +4 -0
  61. package/dist/esm2017/components/Portal/Portal.d.ts +3 -0
  62. package/dist/esm2017/components/Portal/PortalProps.d.ts +7 -0
  63. package/dist/esm2017/components/Portal/index.d.ts +2 -0
  64. package/dist/esm2017/components/index.d.ts +2 -0
  65. package/dist/esm2017/index.js +69 -4
  66. package/dist/esm2017/index.js.map +1 -1
  67. package/dist/esm5/components/Pixel/PixelDebugger.d.ts +2 -0
  68. package/dist/esm5/components/Pixel/PixelDebugger.stories.d.ts +6 -0
  69. package/dist/esm5/components/Pixel/PixelDebuggerToggle.d.ts +3 -0
  70. package/dist/esm5/components/Pixel/hooks/index.d.ts +1 -0
  71. package/dist/esm5/components/Pixel/index.d.ts +2 -0
  72. package/dist/esm5/components/Pixel/models/index.d.ts +4 -0
  73. package/dist/esm5/components/Portal/Portal.d.ts +3 -0
  74. package/dist/esm5/components/Portal/PortalProps.d.ts +7 -0
  75. package/dist/esm5/components/Portal/index.d.ts +2 -0
  76. package/dist/esm5/components/index.d.ts +2 -0
  77. package/dist/esm5/index.js +69 -4
  78. package/dist/esm5/index.js.map +1 -1
  79. package/dist/hooks/useLocalStorage.js +0 -2
  80. package/dist/hooks/useLocalStorage.js.map +1 -1
  81. package/dist/node/components/Pixel/PixelDebugger.d.ts +2 -0
  82. package/dist/node/components/Pixel/PixelDebugger.stories.d.ts +6 -0
  83. package/dist/node/components/Pixel/PixelDebuggerToggle.d.ts +3 -0
  84. package/dist/node/components/Pixel/hooks/index.d.ts +1 -0
  85. package/dist/node/components/Pixel/index.d.ts +2 -0
  86. package/dist/node/components/Pixel/models/index.d.ts +4 -0
  87. package/dist/node/components/Portal/Portal.d.ts +3 -0
  88. package/dist/node/components/Portal/PortalProps.d.ts +7 -0
  89. package/dist/node/components/Portal/index.d.ts +2 -0
  90. package/dist/node/components/index.d.ts +2 -0
  91. package/dist/node/index.js +70 -2
  92. package/dist/node/index.js.map +1 -1
  93. package/dist/node-esm/components/Pixel/PixelDebugger.d.ts +2 -0
  94. package/dist/node-esm/components/Pixel/PixelDebugger.stories.d.ts +6 -0
  95. package/dist/node-esm/components/Pixel/PixelDebuggerToggle.d.ts +3 -0
  96. package/dist/node-esm/components/Pixel/hooks/index.d.ts +1 -0
  97. package/dist/node-esm/components/Pixel/index.d.ts +2 -0
  98. package/dist/node-esm/components/Pixel/models/index.d.ts +4 -0
  99. package/dist/node-esm/components/Portal/Portal.d.ts +3 -0
  100. package/dist/node-esm/components/Portal/PortalProps.d.ts +7 -0
  101. package/dist/node-esm/components/Portal/index.d.ts +2 -0
  102. package/dist/node-esm/components/index.d.ts +2 -0
  103. package/dist/node-esm/index.js +69 -4
  104. package/dist/node-esm/index.js.map +1 -1
  105. package/package.json +2 -1
  106. package/src/components/Pixel/PixelDebugger.stories.tsx +37 -0
  107. package/src/components/Pixel/PixelDebugger.tsx +76 -0
  108. package/src/components/Pixel/PixelDebuggerToggle.tsx +24 -0
  109. package/src/components/Pixel/hooks/index.ts +23 -0
  110. package/src/components/Pixel/index.ts +2 -0
  111. package/src/components/Pixel/models/index.ts +4 -0
  112. package/src/components/Portal/Portal.tsx +23 -0
  113. package/src/components/Portal/PortalProps.ts +6 -0
  114. package/src/components/Portal/index.ts +2 -0
  115. package/src/components/index.ts +2 -0
  116. package/src/hooks/useLocalStorage.ts +0 -2
@@ -0,0 +1,37 @@
1
+ import { ComponentMeta, ComponentStory } from '@storybook/react'
2
+ import { PixelApi, XyPixel } from '@xylabs/pixel'
3
+ import { useEffect } from 'react'
4
+
5
+ import { PixelDebuggerToggle } from './index'
6
+
7
+ const StorybookEntry = {
8
+ argTypes: {},
9
+ component: PixelDebuggerToggle,
10
+ parameters: {
11
+ docs: {
12
+ page: null,
13
+ },
14
+ },
15
+ title: 'Components/PixelDebuggerToggle',
16
+ } as ComponentMeta<typeof PixelDebuggerToggle>
17
+
18
+ const Template: ComponentStory<typeof PixelDebuggerToggle> = (args) => {
19
+ useEffect(() => {
20
+ XyPixel.selectApi(new PixelApi('local'))
21
+ XyPixel.init('storybookPixel')
22
+ }, [])
23
+ return (
24
+ <div>
25
+ <PixelDebuggerToggle {...args} />
26
+ <div id="pixelPortal" />
27
+ </div>
28
+ )
29
+ }
30
+
31
+ const Default = Template.bind({})
32
+ Default.args = {}
33
+
34
+ export { Default }
35
+
36
+ // eslint-disable-next-line import/no-default-export
37
+ export default StorybookEntry
@@ -0,0 +1,76 @@
1
+ import { Badge, Card, Divider, Typography, useTheme } from '@mui/material'
2
+ import { useState } from 'react'
3
+
4
+ import { ButtonEx } from '../ButtonEx'
5
+ import { FlexCol } from '../FlexBox'
6
+ import { usePixelAltSendHandler } from './hooks'
7
+ import { PixelEvent } from './models'
8
+
9
+ export const PixelDebugger: React.FC = () => {
10
+ //TODO - when adding in the location hook to detect location change, was dropping the setEvents in usePixelAltSendHand
11
+ const theme = useTheme()
12
+ const [displayEvents, setDisplayEvents] = useState(false)
13
+ const [events, setEvents] = useState<PixelEvent[]>([])
14
+
15
+ usePixelAltSendHandler((event: string, fields?: Record<string, unknown>) => {
16
+ setEvents((events) => [{ event, fields }, ...events])
17
+ })
18
+
19
+ return (
20
+ <div style={{ bottom: 0, left: 0, position: 'fixed', width: 350 }}>
21
+ <Badge badgeContent={events.length} color="primary" sx={{ width: '100%' }}>
22
+ <Card
23
+ variant="outlined"
24
+ sx={{
25
+ backdropFilter: 'blur(16px) saturate(180%)',
26
+ backgroundColor: 'rgba(18, 18, 18, .70)',
27
+ overflowY: 'auto',
28
+ width: '100%',
29
+ }}
30
+ color={theme.palette.primary.main}
31
+ >
32
+ <FlexCol alignItems="stretch" sx={{ flexFlow: 'column', maxHeight: 400 }}>
33
+ <FlexCol alignItems="stretch" sx={{ flex: '0 1 auto' }}>
34
+ <ButtonEx variant="text" onClick={() => setDisplayEvents(!displayEvents)}>
35
+ XY Pixel Debugger
36
+ </ButtonEx>
37
+ </FlexCol>
38
+ {displayEvents && !!events.length && (
39
+ <FlexCol
40
+ alignItems="stretch"
41
+ alignContent="start"
42
+ padding={2}
43
+ sx={{ cursor: 'pointer', flex: '1 1 auto', overflowY: 'auto', userSelect: 'none' }}
44
+ >
45
+ {events.map((e, index) => (
46
+ <PixelEventDetails key={`${e.event}-${index}`} events={events} index={index} {...e} />
47
+ ))}
48
+ </FlexCol>
49
+ )}
50
+ {displayEvents && !events.length && <Typography variant="subtitle2">No Events</Typography>}
51
+ </FlexCol>
52
+ </Card>
53
+ </Badge>
54
+ </div>
55
+ )
56
+ }
57
+
58
+ const PixelEventDetails: React.FC<PixelEvent & { index: number; events: PixelEvent[] }> = ({
59
+ event,
60
+ fields,
61
+ index,
62
+ events,
63
+ }) => {
64
+ const [isOpen, setIsOpen] = useState(false)
65
+ return (
66
+ <FlexCol alignItems="stretch" marginBottom={0.5} onClick={() => setIsOpen(!isOpen)}>
67
+ <Typography variant="subtitle2">{event}</Typography>
68
+ {isOpen && (
69
+ <Typography marginBottom={0.5} variant="caption">
70
+ {JSON.stringify(fields, null, 2)}
71
+ </Typography>
72
+ )}
73
+ {events[index + 1] && <Divider />}
74
+ </FlexCol>
75
+ )
76
+ }
@@ -0,0 +1,24 @@
1
+ import { FormControl, FormLabel, Switch } from '@mui/material'
2
+
3
+ import { useLocalStorage } from '../../hooks'
4
+ import { BusyBoxProps, FlexRow } from '../FlexBox'
5
+ import { Portal } from '../Portal'
6
+ import { PixelDebugger } from './PixelDebugger'
7
+
8
+ export const PixelDebuggerToggle: React.FC<BusyBoxProps> = ({ ...props }) => {
9
+ const [showDebugger, setDebugger] = useLocalStorage<boolean>('isDebuggingPixel', false)
10
+
11
+ return (
12
+ <FlexRow {...props}>
13
+ <FormControl>
14
+ <FormLabel>Enable Debugger</FormLabel>
15
+ <Switch checked={showDebugger} onClick={() => setDebugger(!showDebugger)} />
16
+ </FormControl>
17
+ {showDebugger && (
18
+ <Portal target="#pixelPortal">
19
+ <PixelDebugger />
20
+ </Portal>
21
+ )}
22
+ </FlexRow>
23
+ )
24
+ }
@@ -0,0 +1,23 @@
1
+ import { XyPixel } from '@xylabs/pixel'
2
+ import { useEffect, useState } from 'react'
3
+
4
+ export const usePixelAltSendHandler = (altHandler: (event: string, fields?: Record<string, unknown>) => void) => {
5
+ const [pixelSend, setPixelSend] = useState<typeof XyPixel.instance.send>()
6
+ useEffect(() => {
7
+ if (!pixelSend && XyPixel.instance.send) {
8
+ const oldHandler = XyPixel.instance.send.bind(XyPixel.instance)
9
+ setPixelSend(oldHandler)
10
+ } else {
11
+ XyPixel.instance.send = async (event: string, fields?: Record<string, unknown>) => {
12
+ altHandler(event, fields)
13
+ return await pixelSend?.(event, fields)
14
+ }
15
+ }
16
+ return () => {
17
+ //restore send on unmount
18
+ if (pixelSend) {
19
+ XyPixel.instance.send = pixelSend
20
+ }
21
+ }
22
+ }, [pixelSend, altHandler])
23
+ }
@@ -0,0 +1,2 @@
1
+ export * from './PixelDebugger'
2
+ export * from './PixelDebuggerToggle'
@@ -0,0 +1,4 @@
1
+ export interface PixelEvent {
2
+ event: string
3
+ fields?: unknown
4
+ }
@@ -0,0 +1,23 @@
1
+ import { useEffect, useState } from 'react'
2
+ import { createPortal } from 'react-dom'
3
+
4
+ import { PortalProps } from './PortalProps'
5
+
6
+ export const Portal: React.FC<PortalProps> = ({ children, className, el = 'div', target = 'body' }: PortalProps) => {
7
+ const [container] = useState(document.createElement(el))
8
+ if (className) {
9
+ container.classList.add(className)
10
+ }
11
+ useEffect(() => {
12
+ const targetElement = document.querySelector(target)
13
+ if (!targetElement) {
14
+ console.warn(`Unable to find target element: ${target}`)
15
+ }
16
+ targetElement?.appendChild(container)
17
+ return () => {
18
+ targetElement?.removeChild(container)
19
+ }
20
+ }, [container, target])
21
+
22
+ return createPortal(children, container)
23
+ }
@@ -0,0 +1,6 @@
1
+ export interface PortalProps {
2
+ children: React.ReactNode
3
+ className?: string
4
+ el?: string
5
+ target?: string
6
+ }
@@ -0,0 +1,2 @@
1
+ export * from './Portal'
2
+ export * from './PortalProps'
@@ -17,6 +17,8 @@ export * from './FlexBox'
17
17
  export * from './InvertableThemeProvider'
18
18
  export * from './LinkEx'
19
19
  export * from './NumberStatus'
20
+ export * from './Pixel'
21
+ export * from './Portal'
20
22
  export * from './QuickTipButton'
21
23
  export * from './RichResult'
22
24
  export * from './ScrollToTop'
@@ -14,10 +14,8 @@ export const useLocalStorage = <T>(key: string, defaultValue: T): [T, (value: T)
14
14
  })
15
15
 
16
16
  const setValue = (value: T) => {
17
- console.log('setValue', value)
18
17
  setStoredValue(value)
19
18
  setLocalStorageObject(key, value)
20
- console.log('getValue from ls', getLocalStorageObject(key))
21
19
  }
22
20
 
23
21
  return [storedValue, setValue]