@xylabs/sdk-react 2.9.14 → 2.9.19

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 (145) hide show
  1. package/dist/cjs5/components/InvertableThemeProvider/InvertableThemeProvider.stories.d.ts +2 -1
  2. package/dist/cjs5/components/InvertableThemeProvider/InvertableThemeProviderProps.d.ts +1 -0
  3. package/dist/cjs5/components/Pixel/PixelDebugger.d.ts +2 -0
  4. package/dist/cjs5/components/Pixel/PixelDebugger.stories.d.ts +6 -0
  5. package/dist/cjs5/components/Pixel/PixelDebuggerProvider.d.ts +2 -0
  6. package/dist/cjs5/components/Pixel/PixelDebuggerToggle.d.ts +3 -0
  7. package/dist/cjs5/components/Pixel/hooks/index.d.ts +1 -0
  8. package/dist/cjs5/components/Pixel/index.d.ts +3 -0
  9. package/dist/cjs5/components/Pixel/models/index.d.ts +4 -0
  10. package/dist/cjs5/components/TokenAmount/TokenAmountProps.d.ts +1 -0
  11. package/dist/cjs5/components/index.d.ts +1 -0
  12. package/dist/cjs5/contexts/UserEvents/Context.d.ts +6 -1
  13. package/dist/cjs5/contexts/UserEvents/index.d.ts +1 -2
  14. package/dist/cjs5/index.js +71 -3
  15. package/dist/cjs5/index.js.map +1 -1
  16. package/dist/components/InvertableThemeProvider/InvertableThemeProvider.js +4 -1
  17. package/dist/components/InvertableThemeProvider/InvertableThemeProvider.js.map +1 -1
  18. package/dist/components/InvertableThemeProvider/InvertableThemeProvider.stories.d.ts +2 -1
  19. package/dist/components/InvertableThemeProvider/InvertableThemeProvider.stories.js +33 -3
  20. package/dist/components/InvertableThemeProvider/InvertableThemeProvider.stories.js.map +1 -1
  21. package/dist/components/InvertableThemeProvider/InvertableThemeProviderProps.d.ts +1 -0
  22. package/dist/components/Pixel/PixelDebugger.d.ts +2 -0
  23. package/dist/components/Pixel/PixelDebugger.js +32 -0
  24. package/dist/components/Pixel/PixelDebugger.js.map +1 -0
  25. package/dist/components/Pixel/PixelDebugger.stories.d.ts +6 -0
  26. package/dist/components/Pixel/PixelDebugger.stories.js +28 -0
  27. package/dist/components/Pixel/PixelDebugger.stories.js.map +1 -0
  28. package/dist/components/Pixel/PixelDebuggerProvider.d.ts +2 -0
  29. package/dist/components/Pixel/PixelDebuggerProvider.js +8 -0
  30. package/dist/components/Pixel/PixelDebuggerProvider.js.map +1 -0
  31. package/dist/components/Pixel/PixelDebuggerToggle.d.ts +3 -0
  32. package/dist/components/Pixel/PixelDebuggerToggle.js +12 -0
  33. package/dist/components/Pixel/PixelDebuggerToggle.js.map +1 -0
  34. package/dist/components/Pixel/hooks/index.d.ts +1 -0
  35. package/dist/components/Pixel/hooks/index.js +25 -0
  36. package/dist/components/Pixel/hooks/index.js.map +1 -0
  37. package/dist/components/Pixel/index.d.ts +3 -0
  38. package/dist/components/Pixel/index.js +4 -0
  39. package/dist/components/Pixel/index.js.map +1 -0
  40. package/dist/components/Pixel/models/index.d.ts +4 -0
  41. package/dist/components/Pixel/models/index.js +2 -0
  42. package/dist/components/Pixel/models/index.js.map +1 -0
  43. package/dist/components/TokenAmount/TokenAmountProps.d.ts +1 -0
  44. package/dist/components/index.d.ts +1 -0
  45. package/dist/components/index.js +1 -0
  46. package/dist/components/index.js.map +1 -1
  47. package/dist/contexts/UserEvents/Context.d.ts +6 -1
  48. package/dist/contexts/UserEvents/Context.js +7 -1
  49. package/dist/contexts/UserEvents/Context.js.map +1 -1
  50. package/dist/contexts/UserEvents/index.d.ts +1 -2
  51. package/dist/contexts/UserEvents/index.js +1 -2
  52. package/dist/contexts/UserEvents/index.js.map +1 -1
  53. package/dist/esm2015/components/InvertableThemeProvider/InvertableThemeProvider.stories.d.ts +2 -1
  54. package/dist/esm2015/components/InvertableThemeProvider/InvertableThemeProviderProps.d.ts +1 -0
  55. package/dist/esm2015/components/Pixel/PixelDebugger.d.ts +2 -0
  56. package/dist/esm2015/components/Pixel/PixelDebugger.stories.d.ts +6 -0
  57. package/dist/esm2015/components/Pixel/PixelDebuggerProvider.d.ts +2 -0
  58. package/dist/esm2015/components/Pixel/PixelDebuggerToggle.d.ts +3 -0
  59. package/dist/esm2015/components/Pixel/hooks/index.d.ts +1 -0
  60. package/dist/esm2015/components/Pixel/index.d.ts +3 -0
  61. package/dist/esm2015/components/Pixel/models/index.d.ts +4 -0
  62. package/dist/esm2015/components/TokenAmount/TokenAmountProps.d.ts +1 -0
  63. package/dist/esm2015/components/index.d.ts +1 -0
  64. package/dist/esm2015/contexts/UserEvents/Context.d.ts +6 -1
  65. package/dist/esm2015/contexts/UserEvents/index.d.ts +1 -2
  66. package/dist/esm2015/index.js +69 -5
  67. package/dist/esm2015/index.js.map +1 -1
  68. package/dist/esm2017/components/InvertableThemeProvider/InvertableThemeProvider.stories.d.ts +2 -1
  69. package/dist/esm2017/components/InvertableThemeProvider/InvertableThemeProviderProps.d.ts +1 -0
  70. package/dist/esm2017/components/Pixel/PixelDebugger.d.ts +2 -0
  71. package/dist/esm2017/components/Pixel/PixelDebugger.stories.d.ts +6 -0
  72. package/dist/esm2017/components/Pixel/PixelDebuggerProvider.d.ts +2 -0
  73. package/dist/esm2017/components/Pixel/PixelDebuggerToggle.d.ts +3 -0
  74. package/dist/esm2017/components/Pixel/hooks/index.d.ts +1 -0
  75. package/dist/esm2017/components/Pixel/index.d.ts +3 -0
  76. package/dist/esm2017/components/Pixel/models/index.d.ts +4 -0
  77. package/dist/esm2017/components/TokenAmount/TokenAmountProps.d.ts +1 -0
  78. package/dist/esm2017/components/index.d.ts +1 -0
  79. package/dist/esm2017/contexts/UserEvents/Context.d.ts +6 -1
  80. package/dist/esm2017/contexts/UserEvents/index.d.ts +1 -2
  81. package/dist/esm2017/index.js +69 -5
  82. package/dist/esm2017/index.js.map +1 -1
  83. package/dist/esm5/components/InvertableThemeProvider/InvertableThemeProvider.stories.d.ts +2 -1
  84. package/dist/esm5/components/InvertableThemeProvider/InvertableThemeProviderProps.d.ts +1 -0
  85. package/dist/esm5/components/Pixel/PixelDebugger.d.ts +2 -0
  86. package/dist/esm5/components/Pixel/PixelDebugger.stories.d.ts +6 -0
  87. package/dist/esm5/components/Pixel/PixelDebuggerProvider.d.ts +2 -0
  88. package/dist/esm5/components/Pixel/PixelDebuggerToggle.d.ts +3 -0
  89. package/dist/esm5/components/Pixel/hooks/index.d.ts +1 -0
  90. package/dist/esm5/components/Pixel/index.d.ts +3 -0
  91. package/dist/esm5/components/Pixel/models/index.d.ts +4 -0
  92. package/dist/esm5/components/TokenAmount/TokenAmountProps.d.ts +1 -0
  93. package/dist/esm5/components/index.d.ts +1 -0
  94. package/dist/esm5/contexts/UserEvents/Context.d.ts +6 -1
  95. package/dist/esm5/contexts/UserEvents/index.d.ts +1 -2
  96. package/dist/esm5/index.js +69 -5
  97. package/dist/esm5/index.js.map +1 -1
  98. package/dist/hooks/useLocalStorage.js +0 -2
  99. package/dist/hooks/useLocalStorage.js.map +1 -1
  100. package/dist/node/components/InvertableThemeProvider/InvertableThemeProvider.stories.d.ts +2 -1
  101. package/dist/node/components/InvertableThemeProvider/InvertableThemeProviderProps.d.ts +1 -0
  102. package/dist/node/components/Pixel/PixelDebugger.d.ts +2 -0
  103. package/dist/node/components/Pixel/PixelDebugger.stories.d.ts +6 -0
  104. package/dist/node/components/Pixel/PixelDebuggerProvider.d.ts +2 -0
  105. package/dist/node/components/Pixel/PixelDebuggerToggle.d.ts +3 -0
  106. package/dist/node/components/Pixel/hooks/index.d.ts +1 -0
  107. package/dist/node/components/Pixel/index.d.ts +3 -0
  108. package/dist/node/components/Pixel/models/index.d.ts +4 -0
  109. package/dist/node/components/TokenAmount/TokenAmountProps.d.ts +1 -0
  110. package/dist/node/components/index.d.ts +1 -0
  111. package/dist/node/contexts/UserEvents/Context.d.ts +6 -1
  112. package/dist/node/contexts/UserEvents/index.d.ts +1 -2
  113. package/dist/node/index.js +71 -3
  114. package/dist/node/index.js.map +1 -1
  115. package/dist/node-esm/components/InvertableThemeProvider/InvertableThemeProvider.stories.d.ts +2 -1
  116. package/dist/node-esm/components/InvertableThemeProvider/InvertableThemeProviderProps.d.ts +1 -0
  117. package/dist/node-esm/components/Pixel/PixelDebugger.d.ts +2 -0
  118. package/dist/node-esm/components/Pixel/PixelDebugger.stories.d.ts +6 -0
  119. package/dist/node-esm/components/Pixel/PixelDebuggerProvider.d.ts +2 -0
  120. package/dist/node-esm/components/Pixel/PixelDebuggerToggle.d.ts +3 -0
  121. package/dist/node-esm/components/Pixel/hooks/index.d.ts +1 -0
  122. package/dist/node-esm/components/Pixel/index.d.ts +3 -0
  123. package/dist/node-esm/components/Pixel/models/index.d.ts +4 -0
  124. package/dist/node-esm/components/TokenAmount/TokenAmountProps.d.ts +1 -0
  125. package/dist/node-esm/components/index.d.ts +1 -0
  126. package/dist/node-esm/contexts/UserEvents/Context.d.ts +6 -1
  127. package/dist/node-esm/contexts/UserEvents/index.d.ts +1 -2
  128. package/dist/node-esm/index.js +69 -5
  129. package/dist/node-esm/index.js.map +1 -1
  130. package/package.json +1 -1
  131. package/src/components/InvertableThemeProvider/InvertableThemeProvider.stories.tsx +47 -2
  132. package/src/components/InvertableThemeProvider/InvertableThemeProvider.tsx +5 -0
  133. package/src/components/InvertableThemeProvider/InvertableThemeProviderProps.ts +1 -0
  134. package/src/components/Pixel/PixelDebugger.stories.tsx +38 -0
  135. package/src/components/Pixel/PixelDebugger.tsx +85 -0
  136. package/src/components/Pixel/PixelDebuggerProvider.tsx +11 -0
  137. package/src/components/Pixel/PixelDebuggerToggle.tsx +18 -0
  138. package/src/components/Pixel/hooks/index.ts +23 -0
  139. package/src/components/Pixel/index.ts +3 -0
  140. package/src/components/Pixel/models/index.ts +4 -0
  141. package/src/components/index.ts +1 -0
  142. package/src/contexts/UserEvents/Context.ts +14 -2
  143. package/src/contexts/UserEvents/index.ts +1 -2
  144. package/src/hooks/useLocalStorage.ts +0 -2
  145. package/xylabs-sdk-react-v2.8.2.tgz +0 -0
@@ -0,0 +1,85 @@
1
+ import { Badge, Card, Divider, Typography, useTheme } from '@mui/material'
2
+ import { useContext, useState } from 'react'
3
+
4
+ import { DebugUserEventsContext } from '../../contexts'
5
+ import { ButtonEx } from '../ButtonEx'
6
+ import { FlexCol } from '../FlexBox'
7
+ import { Portal } from '../Portal'
8
+ import { usePixelAltSendHandler } from './hooks'
9
+ import { PixelEvent } from './models'
10
+
11
+ export const PixelDebugger: React.FC = () => {
12
+ const { isDebugging } = useContext(DebugUserEventsContext)
13
+ //TODO - when adding in the location hook to detect location change, was dropping the setEvents in usePixelAltSendHand
14
+ const theme = useTheme()
15
+ const [displayEvents, setDisplayEvents] = useState(false)
16
+ const [events, setEvents] = useState<PixelEvent[]>([])
17
+
18
+ usePixelAltSendHandler((event: string, fields?: Record<string, unknown>) => {
19
+ setEvents((events) => [{ event, fields }, ...events])
20
+ })
21
+
22
+ if (!isDebugging) {
23
+ return null
24
+ }
25
+
26
+ return (
27
+ <Portal>
28
+ <div style={{ bottom: 0, left: 0, position: 'fixed', width: 350 }}>
29
+ <Badge badgeContent={events.length} color="primary" sx={{ width: '100%' }}>
30
+ <Card
31
+ variant="outlined"
32
+ sx={{
33
+ backdropFilter: 'blur(16px) saturate(180%)',
34
+ backgroundColor: 'rgba(18, 18, 18, .70)',
35
+ overflowY: 'auto',
36
+ width: '100%',
37
+ }}
38
+ color={theme.palette.primary.main}
39
+ >
40
+ <FlexCol alignItems="stretch" sx={{ flexFlow: 'column', maxHeight: 400 }}>
41
+ <FlexCol alignItems="stretch" sx={{ flex: '0 1 auto' }}>
42
+ <ButtonEx variant="text" onClick={() => setDisplayEvents(!displayEvents)}>
43
+ XY Pixel Debugger
44
+ </ButtonEx>
45
+ </FlexCol>
46
+ {displayEvents && !!events.length && (
47
+ <FlexCol
48
+ alignItems="stretch"
49
+ alignContent="start"
50
+ padding={2}
51
+ sx={{ cursor: 'pointer', flex: '1 1 auto', overflowY: 'auto', userSelect: 'none' }}
52
+ >
53
+ {events.map((e, index) => (
54
+ <PixelEventDetails key={`${e.event}-${index}`} events={events} index={index} {...e} />
55
+ ))}
56
+ </FlexCol>
57
+ )}
58
+ {displayEvents && !events.length && <Typography variant="subtitle2">No Events</Typography>}
59
+ </FlexCol>
60
+ </Card>
61
+ </Badge>
62
+ </div>
63
+ </Portal>
64
+ )
65
+ }
66
+
67
+ const PixelEventDetails: React.FC<PixelEvent & { index: number; events: PixelEvent[] }> = ({
68
+ event,
69
+ fields,
70
+ index,
71
+ events,
72
+ }) => {
73
+ const [isOpen, setIsOpen] = useState(false)
74
+ return (
75
+ <FlexCol alignItems="stretch" marginBottom={0.5} onClick={() => setIsOpen(!isOpen)}>
76
+ <Typography variant="subtitle2">{event}</Typography>
77
+ {isOpen && (
78
+ <Typography marginBottom={0.5} variant="caption">
79
+ {JSON.stringify(fields, null, 2)}
80
+ </Typography>
81
+ )}
82
+ {events[index + 1] && <Divider />}
83
+ </FlexCol>
84
+ )
85
+ }
@@ -0,0 +1,11 @@
1
+ import { DebugUserEventsContext } from '../../contexts'
2
+ import { useLocalStorage } from '../../hooks'
3
+
4
+ export const PixelDebuggerProvider: React.FC = ({ children }) => {
5
+ const [isDebugging, setIsDebugging] = useLocalStorage<boolean>('isDebuggingPixel', false)
6
+ return (
7
+ <DebugUserEventsContext.Provider value={{ isDebugging, setIsDebugging }}>
8
+ {children}
9
+ </DebugUserEventsContext.Provider>
10
+ )
11
+ }
@@ -0,0 +1,18 @@
1
+ import { FormControl, FormLabel, Switch } from '@mui/material'
2
+ import { useContext } from 'react'
3
+
4
+ import { DebugUserEventsContext } from '../../contexts'
5
+ import { BusyBoxProps, FlexRow } from '../FlexBox'
6
+
7
+ export const PixelDebuggerToggle: React.FC<BusyBoxProps> = ({ ...props }) => {
8
+ const { setIsDebugging, isDebugging } = useContext(DebugUserEventsContext)
9
+
10
+ return (
11
+ <FlexRow {...props}>
12
+ <FormControl>
13
+ <FormLabel>Enable Debugger</FormLabel>
14
+ <Switch checked={isDebugging} onClick={() => setIsDebugging(!isDebugging)} />
15
+ </FormControl>
16
+ </FlexRow>
17
+ )
18
+ }
@@ -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,3 @@
1
+ export * from './PixelDebugger'
2
+ export * from './PixelDebuggerProvider'
3
+ export * from './PixelDebuggerToggle'
@@ -0,0 +1,4 @@
1
+ export interface PixelEvent {
2
+ event: string
3
+ fields?: unknown
4
+ }
@@ -17,6 +17,7 @@ export * from './FlexBox'
17
17
  export * from './InvertableThemeProvider'
18
18
  export * from './LinkEx'
19
19
  export * from './NumberStatus'
20
+ export * from './Pixel'
20
21
  export * from './Portal'
21
22
  export * from './QuickTipButton'
22
23
  export * from './RichResult'
@@ -4,6 +4,18 @@ import { createContext } from 'react'
4
4
  interface Props {
5
5
  userEvents?: UserEventHandler<unknown>
6
6
  }
7
-
8
7
  const UserEventsContext = createContext<Props>({})
9
- export { UserEventsContext }
8
+
9
+ interface DebuggingProps {
10
+ isDebugging: boolean
11
+ setIsDebugging: (value: boolean) => void
12
+ }
13
+
14
+ const DebugUserEventsContext = createContext<DebuggingProps>({
15
+ isDebugging: false,
16
+ setIsDebugging: (value) => {
17
+ console.warn('set is debugging is not set', value)
18
+ },
19
+ })
20
+
21
+ export { DebugUserEventsContext, UserEventsContext }
@@ -1,3 +1,2 @@
1
- import { UserEventsContext } from './Context'
1
+ export * from './Context'
2
2
  export * from './Loader'
3
- export { UserEventsContext }
@@ -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]
Binary file