@vuu-ui/vuu-shell 0.13.8 → 0.13.10

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 (225) hide show
  1. package/cjs/ShellContextProvider.js +25 -0
  2. package/cjs/ShellContextProvider.js.map +1 -0
  3. package/cjs/app-header/AppHeader.css.js +6 -0
  4. package/cjs/app-header/AppHeader.css.js.map +1 -0
  5. package/cjs/app-header/AppHeader.js +85 -0
  6. package/cjs/app-header/AppHeader.js.map +1 -0
  7. package/cjs/app-status-bar/AppStatusBar.css.js +6 -0
  8. package/cjs/app-status-bar/AppStatusBar.css.js.map +1 -0
  9. package/cjs/app-status-bar/AppStatusBar.js +47 -0
  10. package/cjs/app-status-bar/AppStatusBar.js.map +1 -0
  11. package/cjs/application-provider/ApplicationContext.js +18 -0
  12. package/cjs/application-provider/ApplicationContext.js.map +1 -0
  13. package/cjs/application-provider/ApplicationProvider.js +104 -0
  14. package/cjs/application-provider/ApplicationProvider.js.map +1 -0
  15. package/cjs/connection-status/ConnectionRetryCountdown.js +36 -0
  16. package/cjs/connection-status/ConnectionRetryCountdown.js.map +1 -0
  17. package/cjs/connection-status/ConnectionStateDisplay.css.js +6 -0
  18. package/cjs/connection-status/ConnectionStateDisplay.css.js.map +1 -0
  19. package/cjs/connection-status/ConnectionStateDisplay.js +65 -0
  20. package/cjs/connection-status/ConnectionStateDisplay.js.map +1 -0
  21. package/cjs/connection-status/ConnectionStatusIndicator.css.js +6 -0
  22. package/cjs/connection-status/ConnectionStatusIndicator.css.js.map +1 -0
  23. package/cjs/connection-status/ConnectionStatusIndicator.js +81 -0
  24. package/cjs/connection-status/ConnectionStatusIndicator.js.map +1 -0
  25. package/cjs/feature/Feature.js +55 -0
  26. package/cjs/feature/Feature.js.map +1 -0
  27. package/cjs/feature/FeatureErrorBoundary.js +30 -0
  28. package/cjs/feature/FeatureErrorBoundary.js.map +1 -0
  29. package/cjs/feature/Loader.js +8 -0
  30. package/cjs/feature/Loader.js.map +1 -0
  31. package/cjs/feature-and-layout-provider/FeatureAndLayoutProvider.js +60 -0
  32. package/cjs/feature-and-layout-provider/FeatureAndLayoutProvider.js.map +1 -0
  33. package/cjs/feature-list/FeatureList.css.js +6 -0
  34. package/cjs/feature-list/FeatureList.css.js.map +1 -0
  35. package/cjs/feature-list/FeatureList.js +97 -0
  36. package/cjs/feature-list/FeatureList.js.map +1 -0
  37. package/cjs/index.js +77 -2826
  38. package/cjs/index.js.map +1 -1
  39. package/cjs/left-nav/LeftNav.css.js +6 -0
  40. package/cjs/left-nav/LeftNav.css.js.map +1 -0
  41. package/cjs/left-nav/LeftNav.js +199 -0
  42. package/cjs/left-nav/LeftNav.js.map +1 -0
  43. package/cjs/login/LoginPanel.css.js +6 -0
  44. package/cjs/login/LoginPanel.css.js.map +1 -0
  45. package/cjs/login/LoginPanel.js +108 -0
  46. package/cjs/login/LoginPanel.js.map +1 -0
  47. package/cjs/login/VuuLogo.js +134 -0
  48. package/cjs/login/VuuLogo.js.map +1 -0
  49. package/cjs/login/login-utils.js +31 -0
  50. package/cjs/login/login-utils.js.map +1 -0
  51. package/cjs/persistence-manager/LocalPersistenceManager.js +197 -0
  52. package/cjs/persistence-manager/LocalPersistenceManager.js.map +1 -0
  53. package/cjs/persistence-manager/PersistenceProvider.js +21 -0
  54. package/cjs/persistence-manager/PersistenceProvider.js.map +1 -0
  55. package/cjs/persistence-manager/RemotePersistenceManager.js +175 -0
  56. package/cjs/persistence-manager/RemotePersistenceManager.js.map +1 -0
  57. package/cjs/persistence-manager/StaticPersistenceManager.js +71 -0
  58. package/cjs/persistence-manager/StaticPersistenceManager.js.map +1 -0
  59. package/cjs/shell-layout-templates/context-panel/ContextPanel.css.js +6 -0
  60. package/cjs/shell-layout-templates/context-panel/ContextPanel.css.js.map +1 -0
  61. package/cjs/shell-layout-templates/context-panel/ContextPanel.js +94 -0
  62. package/cjs/shell-layout-templates/context-panel/ContextPanel.js.map +1 -0
  63. package/cjs/shell-layout-templates/full-height-left-panel/useFullHeightLeftPanel.js +53 -0
  64. package/cjs/shell-layout-templates/full-height-left-panel/useFullHeightLeftPanel.js.map +1 -0
  65. package/cjs/shell-layout-templates/inlay-left-panel/useInlayLeftPanel.js +83 -0
  66. package/cjs/shell-layout-templates/inlay-left-panel/useInlayLeftPanel.js.map +1 -0
  67. package/cjs/shell-layout-templates/left-main-tabs/useLeftMainTabs.js +46 -0
  68. package/cjs/shell-layout-templates/left-main-tabs/useLeftMainTabs.js.map +1 -0
  69. package/cjs/shell-layout-templates/side-panel/SidePanel.css.js +6 -0
  70. package/cjs/shell-layout-templates/side-panel/SidePanel.css.js.map +1 -0
  71. package/cjs/shell-layout-templates/side-panel/SidePanel.js +36 -0
  72. package/cjs/shell-layout-templates/side-panel/SidePanel.js.map +1 -0
  73. package/cjs/shell-layout-templates/simple-content-pane/useSimpleContentPane.js +48 -0
  74. package/cjs/shell-layout-templates/simple-content-pane/useSimpleContentPane.js.map +1 -0
  75. package/cjs/shell-layout-templates/useShellLayout.js +23 -0
  76. package/cjs/shell-layout-templates/useShellLayout.js.map +1 -0
  77. package/cjs/shell.css.js +6 -0
  78. package/cjs/shell.css.js.map +1 -0
  79. package/cjs/shell.js +161 -0
  80. package/cjs/shell.js.map +1 -0
  81. package/cjs/theme-switch/ThemeSwitch.css.js +6 -0
  82. package/cjs/theme-switch/ThemeSwitch.css.js.map +1 -0
  83. package/cjs/theme-switch/ThemeSwitch.js +56 -0
  84. package/cjs/theme-switch/ThemeSwitch.js.map +1 -0
  85. package/cjs/user-settings/SettingsForm.css.js +6 -0
  86. package/cjs/user-settings/SettingsForm.css.js.map +1 -0
  87. package/cjs/user-settings/SettingsForm.js +168 -0
  88. package/cjs/user-settings/SettingsForm.js.map +1 -0
  89. package/cjs/user-settings/UserSettingsPanel.css.js +6 -0
  90. package/cjs/user-settings/UserSettingsPanel.css.js.map +1 -0
  91. package/cjs/user-settings/UserSettingsPanel.js +42 -0
  92. package/cjs/user-settings/UserSettingsPanel.js.map +1 -0
  93. package/cjs/workspace-management/LayoutList.css.js +6 -0
  94. package/cjs/workspace-management/LayoutList.css.js.map +1 -0
  95. package/cjs/workspace-management/LayoutList.js +116 -0
  96. package/cjs/workspace-management/LayoutList.js.map +1 -0
  97. package/cjs/workspace-management/LayoutTile.css.js +6 -0
  98. package/cjs/workspace-management/LayoutTile.css.js.map +1 -0
  99. package/cjs/workspace-management/LayoutTile.js +41 -0
  100. package/cjs/workspace-management/LayoutTile.js.map +1 -0
  101. package/cjs/workspace-management/SaveLayoutPanel.css.js +6 -0
  102. package/cjs/workspace-management/SaveLayoutPanel.css.js.map +1 -0
  103. package/cjs/workspace-management/SaveLayoutPanel.js +129 -0
  104. package/cjs/workspace-management/SaveLayoutPanel.js.map +1 -0
  105. package/cjs/workspace-management/WorkspaceProvider.js +264 -0
  106. package/cjs/workspace-management/WorkspaceProvider.js.map +1 -0
  107. package/cjs/workspace-management/defaultWorkspaceJSON.js +101 -0
  108. package/cjs/workspace-management/defaultWorkspaceJSON.js.map +1 -0
  109. package/cjs/workspace-management/screenshot-utils.js +25 -0
  110. package/cjs/workspace-management/screenshot-utils.js.map +1 -0
  111. package/cjs/workspace-management/useWorkspaceContextMenuItems.js +72 -0
  112. package/cjs/workspace-management/useWorkspaceContextMenuItems.js.map +1 -0
  113. package/esm/ShellContextProvider.js +23 -0
  114. package/esm/ShellContextProvider.js.map +1 -0
  115. package/esm/app-header/AppHeader.css.js +4 -0
  116. package/esm/app-header/AppHeader.css.js.map +1 -0
  117. package/esm/app-header/AppHeader.js +83 -0
  118. package/esm/app-header/AppHeader.js.map +1 -0
  119. package/esm/app-status-bar/AppStatusBar.css.js +4 -0
  120. package/esm/app-status-bar/AppStatusBar.css.js.map +1 -0
  121. package/esm/app-status-bar/AppStatusBar.js +45 -0
  122. package/esm/app-status-bar/AppStatusBar.js.map +1 -0
  123. package/esm/application-provider/ApplicationContext.js +16 -0
  124. package/esm/application-provider/ApplicationContext.js.map +1 -0
  125. package/esm/application-provider/ApplicationProvider.js +98 -0
  126. package/esm/application-provider/ApplicationProvider.js.map +1 -0
  127. package/esm/connection-status/ConnectionRetryCountdown.js +34 -0
  128. package/esm/connection-status/ConnectionRetryCountdown.js.map +1 -0
  129. package/esm/connection-status/ConnectionStateDisplay.css.js +4 -0
  130. package/esm/connection-status/ConnectionStateDisplay.css.js.map +1 -0
  131. package/esm/connection-status/ConnectionStateDisplay.js +63 -0
  132. package/esm/connection-status/ConnectionStateDisplay.js.map +1 -0
  133. package/esm/connection-status/ConnectionStatusIndicator.css.js +4 -0
  134. package/esm/connection-status/ConnectionStatusIndicator.css.js.map +1 -0
  135. package/esm/connection-status/ConnectionStatusIndicator.js +79 -0
  136. package/esm/connection-status/ConnectionStatusIndicator.js.map +1 -0
  137. package/esm/feature/Feature.js +53 -0
  138. package/esm/feature/Feature.js.map +1 -0
  139. package/esm/feature/FeatureErrorBoundary.js +28 -0
  140. package/esm/feature/FeatureErrorBoundary.js.map +1 -0
  141. package/esm/feature/Loader.js +6 -0
  142. package/esm/feature/Loader.js.map +1 -0
  143. package/esm/feature-and-layout-provider/FeatureAndLayoutProvider.js +56 -0
  144. package/esm/feature-and-layout-provider/FeatureAndLayoutProvider.js.map +1 -0
  145. package/esm/feature-list/FeatureList.css.js +4 -0
  146. package/esm/feature-list/FeatureList.css.js.map +1 -0
  147. package/esm/feature-list/FeatureList.js +95 -0
  148. package/esm/feature-list/FeatureList.js.map +1 -0
  149. package/esm/index.js +27 -2780
  150. package/esm/index.js.map +1 -1
  151. package/esm/left-nav/LeftNav.css.js +4 -0
  152. package/esm/left-nav/LeftNav.css.js.map +1 -0
  153. package/esm/left-nav/LeftNav.js +197 -0
  154. package/esm/left-nav/LeftNav.js.map +1 -0
  155. package/esm/login/LoginPanel.css.js +4 -0
  156. package/esm/login/LoginPanel.css.js.map +1 -0
  157. package/esm/login/LoginPanel.js +106 -0
  158. package/esm/login/LoginPanel.js.map +1 -0
  159. package/esm/login/VuuLogo.js +132 -0
  160. package/esm/login/VuuLogo.js.map +1 -0
  161. package/esm/login/login-utils.js +26 -0
  162. package/esm/login/login-utils.js.map +1 -0
  163. package/esm/persistence-manager/LocalPersistenceManager.js +195 -0
  164. package/esm/persistence-manager/LocalPersistenceManager.js.map +1 -0
  165. package/esm/persistence-manager/PersistenceProvider.js +17 -0
  166. package/esm/persistence-manager/PersistenceProvider.js.map +1 -0
  167. package/esm/persistence-manager/RemotePersistenceManager.js +173 -0
  168. package/esm/persistence-manager/RemotePersistenceManager.js.map +1 -0
  169. package/esm/persistence-manager/StaticPersistenceManager.js +69 -0
  170. package/esm/persistence-manager/StaticPersistenceManager.js.map +1 -0
  171. package/esm/shell-layout-templates/context-panel/ContextPanel.css.js +4 -0
  172. package/esm/shell-layout-templates/context-panel/ContextPanel.css.js.map +1 -0
  173. package/esm/shell-layout-templates/context-panel/ContextPanel.js +92 -0
  174. package/esm/shell-layout-templates/context-panel/ContextPanel.js.map +1 -0
  175. package/esm/shell-layout-templates/full-height-left-panel/useFullHeightLeftPanel.js +51 -0
  176. package/esm/shell-layout-templates/full-height-left-panel/useFullHeightLeftPanel.js.map +1 -0
  177. package/esm/shell-layout-templates/inlay-left-panel/useInlayLeftPanel.js +81 -0
  178. package/esm/shell-layout-templates/inlay-left-panel/useInlayLeftPanel.js.map +1 -0
  179. package/esm/shell-layout-templates/left-main-tabs/useLeftMainTabs.js +44 -0
  180. package/esm/shell-layout-templates/left-main-tabs/useLeftMainTabs.js.map +1 -0
  181. package/esm/shell-layout-templates/side-panel/SidePanel.css.js +4 -0
  182. package/esm/shell-layout-templates/side-panel/SidePanel.css.js.map +1 -0
  183. package/esm/shell-layout-templates/side-panel/SidePanel.js +34 -0
  184. package/esm/shell-layout-templates/side-panel/SidePanel.js.map +1 -0
  185. package/esm/shell-layout-templates/simple-content-pane/useSimpleContentPane.js +46 -0
  186. package/esm/shell-layout-templates/simple-content-pane/useSimpleContentPane.js.map +1 -0
  187. package/esm/shell-layout-templates/useShellLayout.js +21 -0
  188. package/esm/shell-layout-templates/useShellLayout.js.map +1 -0
  189. package/esm/shell.css.js +4 -0
  190. package/esm/shell.css.js.map +1 -0
  191. package/esm/shell.js +159 -0
  192. package/esm/shell.js.map +1 -0
  193. package/esm/theme-switch/ThemeSwitch.css.js +4 -0
  194. package/esm/theme-switch/ThemeSwitch.css.js.map +1 -0
  195. package/esm/theme-switch/ThemeSwitch.js +54 -0
  196. package/esm/theme-switch/ThemeSwitch.js.map +1 -0
  197. package/esm/user-settings/SettingsForm.css.js +4 -0
  198. package/esm/user-settings/SettingsForm.css.js.map +1 -0
  199. package/esm/user-settings/SettingsForm.js +162 -0
  200. package/esm/user-settings/SettingsForm.js.map +1 -0
  201. package/esm/user-settings/UserSettingsPanel.css.js +4 -0
  202. package/esm/user-settings/UserSettingsPanel.css.js.map +1 -0
  203. package/esm/user-settings/UserSettingsPanel.js +40 -0
  204. package/esm/user-settings/UserSettingsPanel.js.map +1 -0
  205. package/esm/workspace-management/LayoutList.css.js +4 -0
  206. package/esm/workspace-management/LayoutList.css.js.map +1 -0
  207. package/esm/workspace-management/LayoutList.js +114 -0
  208. package/esm/workspace-management/LayoutList.js.map +1 -0
  209. package/esm/workspace-management/LayoutTile.css.js +4 -0
  210. package/esm/workspace-management/LayoutTile.css.js.map +1 -0
  211. package/esm/workspace-management/LayoutTile.js +39 -0
  212. package/esm/workspace-management/LayoutTile.js.map +1 -0
  213. package/esm/workspace-management/SaveLayoutPanel.css.js +4 -0
  214. package/esm/workspace-management/SaveLayoutPanel.css.js.map +1 -0
  215. package/esm/workspace-management/SaveLayoutPanel.js +127 -0
  216. package/esm/workspace-management/SaveLayoutPanel.js.map +1 -0
  217. package/esm/workspace-management/WorkspaceProvider.js +261 -0
  218. package/esm/workspace-management/WorkspaceProvider.js.map +1 -0
  219. package/esm/workspace-management/defaultWorkspaceJSON.js +95 -0
  220. package/esm/workspace-management/defaultWorkspaceJSON.js.map +1 -0
  221. package/esm/workspace-management/screenshot-utils.js +23 -0
  222. package/esm/workspace-management/screenshot-utils.js.map +1 -0
  223. package/esm/workspace-management/useWorkspaceContextMenuItems.js +70 -0
  224. package/esm/workspace-management/useWorkspaceContextMenuItems.js.map +1 -0
  225. package/package.json +13 -13
@@ -0,0 +1,4 @@
1
+ var appStatusBarCss = ".vuuAppStatusBar {\n align-items: center;\n background-color: var(--salt-container-secondary-background);\n display: flex;\n height: 36px;\n justify-content: flex-end;\n}\n.vuuAppStatusBar-hidden {\n display: none;\n}\n";
2
+
3
+ export { appStatusBarCss as default };
4
+ //# sourceMappingURL=AppStatusBar.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AppStatusBar.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
@@ -0,0 +1,45 @@
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { useComponentCssInjection } from '@salt-ds/styles';
3
+ import { useWindow } from '@salt-ds/window';
4
+ import cx from 'clsx';
5
+ import { ConnectionManager } from '@vuu-ui/vuu-data-remote';
6
+ import appStatusBarCss from './AppStatusBar.css.js';
7
+ import { useUserSetting } from '../application-provider/ApplicationProvider.js';
8
+ import { ConnectionStateDisplay } from '../connection-status/ConnectionStateDisplay.js';
9
+ import '../connection-status/ConnectionStatusIndicator.js';
10
+ import { useState, useEffect } from 'react';
11
+
12
+ const classBase = "vuuAppStatusBar";
13
+ const shouldShowStatusBar = (connected, settings) => {
14
+ if (settings && "showAppStatusBar" in settings) {
15
+ return settings.showAppStatusBar === true || connected === false;
16
+ } else {
17
+ return connected === false;
18
+ }
19
+ };
20
+ const ApplicationStatusBar = () => {
21
+ const targetWindow = useWindow();
22
+ useComponentCssInjection({
23
+ testId: "vuu-settings-form",
24
+ css: appStatusBarCss,
25
+ window: targetWindow
26
+ });
27
+ const [connected, setConnected] = useState(true);
28
+ const settings = useUserSetting();
29
+ useEffect(() => {
30
+ ConnectionManager.on("connection-status", ({ connectionStatus }) => {
31
+ if (connectionStatus === "disconnected") {
32
+ setConnected(false);
33
+ } else if (connectionStatus.endsWith("connected")) {
34
+ setConnected(true);
35
+ }
36
+ });
37
+ }, []);
38
+ if (!shouldShowStatusBar(connected, settings)) {
39
+ return /* @__PURE__ */ jsx("div", { className: cx(classBase, `${classBase}-hidden`) });
40
+ }
41
+ return /* @__PURE__ */ jsx("div", { className: classBase, children: /* @__PURE__ */ jsx(ConnectionStateDisplay, {}) });
42
+ };
43
+
44
+ export { ApplicationStatusBar };
45
+ //# sourceMappingURL=AppStatusBar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AppStatusBar.js","sources":["../../src/app-status-bar/AppStatusBar.tsx"],"sourcesContent":["import { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport cx from \"clsx\";\nimport { ConnectionManager } from \"@vuu-ui/vuu-data-remote\";\n\nimport appStatusBarCss from \"./AppStatusBar.css\";\nimport { useUserSetting } from \"../application-provider\";\nimport { Settings } from \"@vuu-ui/vuu-utils\";\nimport { ConnectionStateDisplay } from \"../connection-status\";\nimport { useEffect, useState } from \"react\";\n\nconst classBase = \"vuuAppStatusBar\";\n\nconst shouldShowStatusBar = (connected: boolean, settings?: Settings) => {\n if (settings && \"showAppStatusBar\" in settings) {\n return settings.showAppStatusBar === true || connected === false;\n } else {\n return connected === false;\n }\n};\n\nexport const ApplicationStatusBar = () => {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"vuu-settings-form\",\n css: appStatusBarCss,\n window: targetWindow,\n });\n\n const [connected, setConnected] = useState(true);\n const settings = useUserSetting();\n\n useEffect(() => {\n ConnectionManager.on(\"connection-status\", ({ connectionStatus }) => {\n if (connectionStatus === \"disconnected\") {\n setConnected(false);\n } else if (connectionStatus.endsWith(\"connected\")) {\n setConnected(true);\n }\n });\n }, []);\n\n if (!shouldShowStatusBar(connected, settings)) {\n return <div className={cx(classBase, `${classBase}-hidden`)} />;\n }\n\n // const connect = () => {\n // ConnectionManager.connect({\n // token: \"blah\",\n // url: \"ws://localhost:8090/websocket\",\n // username: \"steve\",\n // });\n // };\n // const disconnect = () => {\n // ConnectionManager.disconnect();\n // };\n\n return (\n <div className={classBase}>\n {/* <Button onClick={disconnect}>Disconnect</Button>\n <Button onClick={connect}>Connect</Button> */}\n <ConnectionStateDisplay />\n </div>\n );\n};\n"],"names":[],"mappings":";;;;;;;;;;;AAWA,MAAM,SAAY,GAAA,iBAAA;AAElB,MAAM,mBAAA,GAAsB,CAAC,SAAA,EAAoB,QAAwB,KAAA;AACvE,EAAI,IAAA,QAAA,IAAY,sBAAsB,QAAU,EAAA;AAC9C,IAAO,OAAA,QAAA,CAAS,gBAAqB,KAAA,IAAA,IAAQ,SAAc,KAAA,KAAA;AAAA,GACtD,MAAA;AACL,IAAA,OAAO,SAAc,KAAA,KAAA;AAAA;AAEzB,CAAA;AAEO,MAAM,uBAAuB,MAAM;AACxC,EAAA,MAAM,eAAe,SAAU,EAAA;AAC/B,EAAyB,wBAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,mBAAA;AAAA,IACR,GAAK,EAAA,eAAA;AAAA,IACL,MAAQ,EAAA;AAAA,GACT,CAAA;AAED,EAAA,MAAM,CAAC,SAAA,EAAW,YAAY,CAAA,GAAI,SAAS,IAAI,CAAA;AAC/C,EAAA,MAAM,WAAW,cAAe,EAAA;AAEhC,EAAA,SAAA,CAAU,MAAM;AACd,IAAA,iBAAA,CAAkB,EAAG,CAAA,mBAAA,EAAqB,CAAC,EAAE,kBAAuB,KAAA;AAClE,MAAA,IAAI,qBAAqB,cAAgB,EAAA;AACvC,QAAA,YAAA,CAAa,KAAK,CAAA;AAAA,OACT,MAAA,IAAA,gBAAA,CAAiB,QAAS,CAAA,WAAW,CAAG,EAAA;AACjD,QAAA,YAAA,CAAa,IAAI,CAAA;AAAA;AACnB,KACD,CAAA;AAAA,GACH,EAAG,EAAE,CAAA;AAEL,EAAA,IAAI,CAAC,mBAAA,CAAoB,SAAW,EAAA,QAAQ,CAAG,EAAA;AAC7C,IAAO,uBAAA,GAAA,CAAC,SAAI,SAAW,EAAA,EAAA,CAAG,WAAW,CAAG,EAAA,SAAS,SAAS,CAAG,EAAA,CAAA;AAAA;AAc/D,EAAA,2BACG,KAAI,EAAA,EAAA,SAAA,EAAW,SAGd,EAAA,QAAA,kBAAA,GAAA,CAAC,0BAAuB,CAC1B,EAAA,CAAA;AAEJ;;;;"}
@@ -0,0 +1,16 @@
1
+ import { createContext } from 'react';
2
+
3
+ const Guest = {
4
+ username: "unknown",
5
+ token: ""
6
+ };
7
+ const ApplicationContext = createContext({
8
+ onUserSettingChanged: (propertyName) => console.warn(
9
+ `Cannot change setting '${propertyName}'.
10
+ Did you forget to declare an ApplicationProvider ?`
11
+ ),
12
+ user: Guest
13
+ });
14
+
15
+ export { ApplicationContext };
16
+ //# sourceMappingURL=ApplicationContext.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ApplicationContext.js","sources":["../../src/application-provider/ApplicationContext.tsx"],"sourcesContent":["import type { Settings, VuuUser } from \"@vuu-ui/vuu-utils\";\nimport { VuuRowDataItemType } from \"@vuu-ui/vuu-protocol-types\";\nimport { createContext } from \"react\";\nimport { SettingsSchema } from \"../user-settings\";\n\nconst Guest: VuuUser = {\n username: \"unknown\",\n token: \"\",\n};\n\nexport interface ApplicationContextProps {\n onUserSettingChanged: (\n propertyName: string,\n value: VuuRowDataItemType,\n ) => void;\n loginUrl?: string;\n userSettings?: Settings;\n userSettingsSchema?: SettingsSchema;\n user: VuuUser;\n}\n\nexport const ApplicationContext = createContext<ApplicationContextProps>({\n onUserSettingChanged: (propertyName: string) =>\n console.warn(\n `Cannot change setting '${propertyName}'.\\nDid you forget to declare an ApplicationProvider ?`,\n ),\n user: Guest,\n});\n"],"names":[],"mappings":";;AAKA,MAAM,KAAiB,GAAA;AAAA,EACrB,QAAU,EAAA,SAAA;AAAA,EACV,KAAO,EAAA;AACT,CAAA;AAaO,MAAM,qBAAqB,aAAuC,CAAA;AAAA,EACvE,oBAAA,EAAsB,CAAC,YAAA,KACrB,OAAQ,CAAA,IAAA;AAAA,IACN,0BAA0B,YAAY,CAAA;AAAA,kDAAA;AAAA,GACxC;AAAA,EACF,IAAM,EAAA;AACR,CAAC;;;;"}
@@ -0,0 +1,98 @@
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { useTheme, useDensity, SaltProvider } from '@salt-ds/core';
3
+ import { useContext, useState, useMemo, useCallback } from 'react';
4
+ import { ApplicationContext } from './ApplicationContext.js';
5
+ import { usePersistenceManager } from '../persistence-manager/PersistenceProvider.js';
6
+ import '../persistence-manager/LocalPersistenceManager.js';
7
+ import '@vuu-ui/vuu-ui-controls';
8
+ import '@salt-ds/styles';
9
+ import '@salt-ds/window';
10
+ import 'clsx';
11
+ import '@vuu-ui/vuu-utils';
12
+ import '../persistence-manager/StaticPersistenceManager.js';
13
+
14
+ const getThemeMode = (mode = "light", userSettings) => {
15
+ const themeMode = userSettings?.themeMode;
16
+ if (themeMode === "light" || themeMode === "dark") {
17
+ return themeMode;
18
+ }
19
+ return mode;
20
+ };
21
+ const ApplicationProvider = ({
22
+ children,
23
+ density: densityProp,
24
+ loginUrl,
25
+ mode,
26
+ theme,
27
+ userSettingsSchema,
28
+ user
29
+ }) => {
30
+ const { mode: inheritedMode, theme: inheritedTheme } = useTheme();
31
+ const density = useDensity(densityProp);
32
+ const persistenceManager = usePersistenceManager();
33
+ const context = useContext(ApplicationContext);
34
+ const [userSettings, setSettings] = useState();
35
+ useMemo(async () => {
36
+ if (persistenceManager) {
37
+ const userSettings2 = await persistenceManager.getUserSettings();
38
+ setSettings(userSettings2);
39
+ } else {
40
+ setSettings({});
41
+ }
42
+ }, [persistenceManager]);
43
+ const onUserSettingChanged = useCallback(
44
+ (propertyName, value) => {
45
+ setSettings((currentSettings) => {
46
+ const newSettings = { ...currentSettings, [propertyName]: value };
47
+ persistenceManager?.saveUserSettings(newSettings);
48
+ return newSettings;
49
+ });
50
+ },
51
+ [persistenceManager]
52
+ );
53
+ return userSettings ? /* @__PURE__ */ jsx(
54
+ ApplicationContext.Provider,
55
+ {
56
+ value: {
57
+ ...context,
58
+ loginUrl,
59
+ onUserSettingChanged,
60
+ userSettings,
61
+ userSettingsSchema,
62
+ user: user ?? context.user
63
+ },
64
+ children: /* @__PURE__ */ jsx(
65
+ SaltProvider,
66
+ {
67
+ theme: theme ?? inheritedTheme ?? "vuu-theme",
68
+ density,
69
+ mode: getThemeMode(mode ?? inheritedMode, userSettings),
70
+ children
71
+ }
72
+ )
73
+ }
74
+ ) : null;
75
+ };
76
+ const useApplicationUser = () => {
77
+ const { user } = useContext(ApplicationContext);
78
+ return user;
79
+ };
80
+ const useLoginUrl = () => {
81
+ const { loginUrl } = useContext(ApplicationContext);
82
+ return loginUrl;
83
+ };
84
+ const useApplicationSettings = () => {
85
+ const { onUserSettingChanged, userSettings, userSettingsSchema } = useContext(ApplicationContext);
86
+ return {
87
+ onUserSettingChanged,
88
+ userSettings,
89
+ userSettingsSchema
90
+ };
91
+ };
92
+ const useUserSetting = () => {
93
+ const { userSettings } = useContext(ApplicationContext);
94
+ return userSettings;
95
+ };
96
+
97
+ export { ApplicationProvider, useApplicationSettings, useApplicationUser, useLoginUrl, useUserSetting };
98
+ //# sourceMappingURL=ApplicationProvider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ApplicationProvider.js","sources":["../../src/application-provider/ApplicationProvider.tsx"],"sourcesContent":["import { VuuRowDataItemType } from \"@vuu-ui/vuu-protocol-types\";\nimport {\n Density,\n Mode,\n SaltProvider,\n ThemeContextProps,\n useDensity,\n useTheme,\n} from \"@salt-ds/core\";\nimport {\n ReactElement,\n ReactNode,\n useCallback,\n useContext,\n useMemo,\n useState,\n} from \"react\";\nimport {\n ApplicationContext,\n ApplicationContextProps,\n} from \"./ApplicationContext\";\nimport { usePersistenceManager } from \"../persistence-manager\";\n\nexport interface ApplicationProviderProps\n extends Partial<Pick<ThemeContextProps, \"theme\" | \"mode\">>,\n Partial<Omit<ApplicationContextProps, \"userSettings\">> {\n children: ReactNode;\n density?: Density;\n}\n\nconst getThemeMode = (\n mode: Mode = \"light\",\n userSettings?: Record<string, string | number | boolean>,\n) => {\n const themeMode = userSettings?.themeMode;\n if (themeMode === \"light\" || themeMode === \"dark\") {\n return themeMode;\n }\n return mode;\n};\n\nexport const ApplicationProvider = ({\n children,\n density: densityProp,\n loginUrl,\n mode,\n theme,\n userSettingsSchema: userSettingsSchema,\n user,\n}: ApplicationProviderProps): ReactElement | null => {\n const { mode: inheritedMode, theme: inheritedTheme } = useTheme();\n const density = useDensity(densityProp);\n const persistenceManager = usePersistenceManager();\n const context = useContext(ApplicationContext);\n const [userSettings, setSettings] =\n useState<Record<string, string | number | boolean>>();\n\n useMemo(async () => {\n if (persistenceManager) {\n const userSettings = await persistenceManager.getUserSettings();\n setSettings(userSettings);\n } else {\n setSettings({});\n }\n }, [persistenceManager]);\n\n const onUserSettingChanged = useCallback(\n (propertyName: string, value: VuuRowDataItemType) => {\n setSettings((currentSettings) => {\n const newSettings = { ...currentSettings, [propertyName]: value };\n persistenceManager?.saveUserSettings(newSettings);\n return newSettings;\n });\n },\n [persistenceManager],\n );\n\n return userSettings ? (\n <ApplicationContext.Provider\n value={{\n ...context,\n loginUrl,\n onUserSettingChanged,\n userSettings,\n userSettingsSchema,\n user: user ?? context.user,\n }}\n >\n <SaltProvider\n theme={theme ?? inheritedTheme ?? \"vuu-theme\"}\n density={density}\n mode={getThemeMode(mode ?? inheritedMode, userSettings)}\n >\n {children}\n </SaltProvider>\n </ApplicationContext.Provider>\n ) : null;\n};\n\nexport const useApplicationUser = () => {\n const { user } = useContext(ApplicationContext);\n return user;\n};\n\nexport const useLoginUrl = () => {\n const { loginUrl } = useContext(ApplicationContext);\n return loginUrl;\n};\n\n//Setter method (only used within the shell)\nexport const useApplicationSettings = () => {\n const { onUserSettingChanged, userSettings, userSettingsSchema } =\n useContext(ApplicationContext);\n return {\n onUserSettingChanged,\n userSettings,\n userSettingsSchema,\n };\n};\n\n//Getter method (read only access to applicationSetting)\nexport const useUserSetting = () => {\n const { userSettings } = useContext(ApplicationContext);\n return userSettings;\n};\n"],"names":["userSettings"],"mappings":"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"}
@@ -0,0 +1,34 @@
1
+ import { jsx, jsxs } from 'react/jsx-runtime';
2
+ import { useRef, useState, useCallback, useEffect, useMemo } from 'react';
3
+
4
+ const classBase = "vuuConnectionRetryCountdown";
5
+ const ConnectionRetryCountdown = ({
6
+ seconds: secondsProp
7
+ }) => {
8
+ const secondsRemainingRef = useRef(secondsProp);
9
+ const [seconds, setSeconds] = useState(secondsRemainingRef.current);
10
+ const countDown = useCallback(() => {
11
+ secondsRemainingRef.current -= 1;
12
+ setSeconds(secondsRemainingRef.current);
13
+ if (secondsRemainingRef.current > 0) {
14
+ setTimeout(countDown, 1e3);
15
+ }
16
+ }, []);
17
+ useEffect(() => {
18
+ if (secondsProp !== secondsRemainingRef.current) {
19
+ secondsRemainingRef.current = secondsProp;
20
+ countDown();
21
+ }
22
+ }, [countDown, secondsProp]);
23
+ useMemo(() => {
24
+ setTimeout(countDown, 1e3);
25
+ }, [countDown]);
26
+ return seconds === 0 ? /* @__PURE__ */ jsx("div", { className: classBase, children: /* @__PURE__ */ jsx("span", { children: "connecting" }) }) : /* @__PURE__ */ jsx("div", { className: classBase, children: /* @__PURE__ */ jsxs("span", { children: [
27
+ "retry in ",
28
+ seconds,
29
+ " seconds"
30
+ ] }) });
31
+ };
32
+
33
+ export { ConnectionRetryCountdown };
34
+ //# sourceMappingURL=ConnectionRetryCountdown.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ConnectionRetryCountdown.js","sources":["../../src/connection-status/ConnectionRetryCountdown.tsx"],"sourcesContent":["import { useCallback, useEffect, useMemo, useRef, useState } from \"react\";\n\nconst classBase = \"vuuConnectionRetryCountdown\";\n\nexport const ConnectionRetryCountdown = ({\n seconds: secondsProp,\n}: {\n seconds: number;\n}) => {\n const secondsRemainingRef = useRef(secondsProp);\n const [seconds, setSeconds] = useState<number>(secondsRemainingRef.current);\n\n const countDown = useCallback(() => {\n secondsRemainingRef.current -= 1;\n setSeconds(secondsRemainingRef.current);\n if (secondsRemainingRef.current > 0) {\n setTimeout(countDown, 1000);\n }\n }, []);\n\n useEffect(() => {\n if (secondsProp !== secondsRemainingRef.current) {\n secondsRemainingRef.current = secondsProp;\n countDown();\n }\n }, [countDown, secondsProp]);\n\n useMemo(() => {\n setTimeout(countDown, 1000);\n }, [countDown]);\n\n return seconds === 0 ? (\n <div className={classBase}>\n <span>connecting</span>\n </div>\n ) : (\n <div className={classBase}>\n <span>retry in {seconds} seconds</span>\n </div>\n );\n};\n"],"names":[],"mappings":";;;AAEA,MAAM,SAAY,GAAA,6BAAA;AAEX,MAAM,2BAA2B,CAAC;AAAA,EACvC,OAAS,EAAA;AACX,CAEM,KAAA;AACJ,EAAM,MAAA,mBAAA,GAAsB,OAAO,WAAW,CAAA;AAC9C,EAAA,MAAM,CAAC,OAAS,EAAA,UAAU,CAAI,GAAA,QAAA,CAAiB,oBAAoB,OAAO,CAAA;AAE1E,EAAM,MAAA,SAAA,GAAY,YAAY,MAAM;AAClC,IAAA,mBAAA,CAAoB,OAAW,IAAA,CAAA;AAC/B,IAAA,UAAA,CAAW,oBAAoB,OAAO,CAAA;AACtC,IAAI,IAAA,mBAAA,CAAoB,UAAU,CAAG,EAAA;AACnC,MAAA,UAAA,CAAW,WAAW,GAAI,CAAA;AAAA;AAC5B,GACF,EAAG,EAAE,CAAA;AAEL,EAAA,SAAA,CAAU,MAAM;AACd,IAAI,IAAA,WAAA,KAAgB,oBAAoB,OAAS,EAAA;AAC/C,MAAA,mBAAA,CAAoB,OAAU,GAAA,WAAA;AAC9B,MAAU,SAAA,EAAA;AAAA;AACZ,GACC,EAAA,CAAC,SAAW,EAAA,WAAW,CAAC,CAAA;AAE3B,EAAA,OAAA,CAAQ,MAAM;AACZ,IAAA,UAAA,CAAW,WAAW,GAAI,CAAA;AAAA,GAC5B,EAAG,CAAC,SAAS,CAAC,CAAA;AAEd,EAAA,OAAO,YAAY,CACjB,mBAAA,GAAA,CAAC,KAAI,EAAA,EAAA,SAAA,EAAW,WACd,QAAC,kBAAA,GAAA,CAAA,MAAA,EAAA,EAAK,QAAU,EAAA,YAAA,EAAA,CAAA,EAClB,oBAEC,GAAA,CAAA,KAAA,EAAA,EAAI,SAAW,EAAA,SAAA,EACd,+BAAC,MAAK,EAAA,EAAA,QAAA,EAAA;AAAA,IAAA,WAAA;AAAA,IAAU,OAAA;AAAA,IAAQ;AAAA,GAAA,EAAQ,CAClC,EAAA,CAAA;AAEJ;;;;"}
@@ -0,0 +1,4 @@
1
+ var connectionStateDisplayCss = ".vuuConnectionStateDisplay {\n --ballbox-height: 24px;\n --message-height: 14px;\n --row-gap: 3px;\n --top-row: calc(var(--ballbox-height) + var(--message-height));\n --bottom-row: 0px;\n\n align-items: center;\n background: var(--salt-container-secondary-background);\n column-gap: var(--salt-spacing-200);\n display: grid;\n grid-template-columns: auto 1fr;\n grid-template-rows: var(--top-row) var(--bottom-row);\n justify-items: end;\n height: calc(var(--ballbox-height) + var(--message-height) + var(--row-gap));\n padding: 0 var(--salt-spacing-200);\n transition: grid-template-rows 0.4s linear;\n row-gap: var(--row-gap);\n width: max-content;\n\n .vuuTrafficLightControl {\n grid-area: 1/2/2/3;\n padding-left: 20px;\n }\n\n &.vuuConnectionStateDisplay-disconnected {\n --top-row: var(--ballbox-height);\n --bottom-row: var(--message-height);\n }\n\n .vuuConnectionRetryCountdown {\n color: var(--salt-content-secondary-foreground);\n grid-area: 2/2/3/3;\n font-size: 11px;\n text-align: end;\n width: 100%;\n }\n}\n\n.vuuConnectionStateDisplay-text {\n grid-area: 1/1/2/2;\n text-transform: capitalize;\n}\n";
2
+
3
+ export { connectionStateDisplayCss as default };
4
+ //# sourceMappingURL=ConnectionStateDisplay.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ConnectionStateDisplay.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
@@ -0,0 +1,63 @@
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import { ConnectionManager } from '@vuu-ui/vuu-data-remote';
3
+ import { useComponentCssInjection } from '@salt-ds/styles';
4
+ import { useWindow } from '@salt-ds/window';
5
+ import { useState, useMemo } from 'react';
6
+ import { ConnectionRetryCountdown } from './ConnectionRetryCountdown.js';
7
+ import { ConnectionStatusIndicator } from './ConnectionStatusIndicator.js';
8
+ import cx from 'clsx';
9
+ import connectionStateDisplayCss from './ConnectionStateDisplay.css.js';
10
+
11
+ const classBase = "vuuConnectionStateDisplay";
12
+ const DefaultConnectionState = {
13
+ connectionPhase: "connecting",
14
+ connectionStatus: "closed",
15
+ secondsToNextRetry: -1,
16
+ retryAttemptsRemaining: 0,
17
+ retryAttemptsTotal: 1
18
+ };
19
+ const getDisplayText = (connectionState) => {
20
+ switch (connectionState.connectionStatus) {
21
+ case "closed":
22
+ return "Unable to connect to data service";
23
+ case "failed":
24
+ return connectionState.connectionPhase === "connecting" ? "Failed to connect" : "Failed to re-connect";
25
+ case "disconnected":
26
+ return connectionState.connectionPhase === "connecting" ? "Attempting to connect to data service" : "Attempting to reconnect to data service";
27
+ }
28
+ };
29
+ const ConnectionStateDisplay = ({
30
+ connectionState: connectionStateProp,
31
+ showText = true,
32
+ ...htmlAttributes
33
+ }) => {
34
+ const targetWindow = useWindow();
35
+ useComponentCssInjection({
36
+ testId: "vuu-connection-status-indicator",
37
+ css: connectionStateDisplayCss,
38
+ window: targetWindow
39
+ });
40
+ const [connectionState, setConnectionState] = useState(DefaultConnectionState);
41
+ useMemo(() => {
42
+ ConnectionManager.on("connection-status", setConnectionState);
43
+ if (connectionStateProp) {
44
+ setConnectionState(connectionStateProp);
45
+ }
46
+ }, [connectionStateProp]);
47
+ const { connectionStatus, secondsToNextRetry } = connectionState;
48
+ return /* @__PURE__ */ jsxs(
49
+ "div",
50
+ {
51
+ ...htmlAttributes,
52
+ className: cx(classBase, `${classBase}-${connectionStatus}`),
53
+ children: [
54
+ showText ? /* @__PURE__ */ jsx("div", { className: `${classBase}-text`, children: getDisplayText(connectionState) }) : null,
55
+ connectionStatus === "disconnected" && secondsToNextRetry > 0 ? /* @__PURE__ */ jsx(ConnectionRetryCountdown, { seconds: secondsToNextRetry }) : null,
56
+ /* @__PURE__ */ jsx(ConnectionStatusIndicator, { connectionState })
57
+ ]
58
+ }
59
+ );
60
+ };
61
+
62
+ export { ConnectionStateDisplay };
63
+ //# sourceMappingURL=ConnectionStateDisplay.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ConnectionStateDisplay.js","sources":["../../src/connection-status/ConnectionStateDisplay.tsx"],"sourcesContent":["import { ConnectionManager } from \"@vuu-ui/vuu-data-remote\";\nimport type { WebSocketConnectionState } from \"@vuu-ui/vuu-data-remote/src/WebSocketConnection\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { HTMLAttributes, useMemo, useState } from \"react\";\nimport { ConnectionRetryCountdown } from \"./ConnectionRetryCountdown\";\nimport { ConnectionStatusIndicator } from \"./ConnectionStatusIndicator\";\nimport cx from \"clsx\";\n\nimport connectionStateDisplayCss from \"./ConnectionStateDisplay.css\";\n\nconst classBase = \"vuuConnectionStateDisplay\";\n\nconst DefaultConnectionState: WebSocketConnectionState = {\n connectionPhase: \"connecting\",\n connectionStatus: \"closed\",\n secondsToNextRetry: -1,\n retryAttemptsRemaining: 0,\n retryAttemptsTotal: 1,\n};\n\ninterface ConnectionStateDisplayProps extends HTMLAttributes<HTMLDivElement> {\n className?: string;\n connectionState?: WebSocketConnectionState;\n showText?: boolean;\n}\n\nconst getDisplayText = (connectionState: WebSocketConnectionState) => {\n switch (connectionState.connectionStatus) {\n case \"closed\":\n return \"Unable to connect to data service\";\n case \"failed\":\n return connectionState.connectionPhase === \"connecting\"\n ? \"Failed to connect\"\n : \"Failed to re-connect\";\n\n case \"disconnected\":\n return connectionState.connectionPhase === \"connecting\"\n ? \"Attempting to connect to data service\"\n : \"Attempting to reconnect to data service\";\n }\n};\n\nexport const ConnectionStateDisplay = ({\n connectionState: connectionStateProp,\n showText = true,\n ...htmlAttributes\n}: ConnectionStateDisplayProps) => {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"vuu-connection-status-indicator\",\n css: connectionStateDisplayCss,\n window: targetWindow,\n });\n const [connectionState, setConnectionState] =\n useState<WebSocketConnectionState>(DefaultConnectionState);\n\n useMemo(() => {\n ConnectionManager.on(\"connection-status\", setConnectionState);\n if (connectionStateProp) {\n setConnectionState(connectionStateProp);\n }\n }, [connectionStateProp]);\n\n const { connectionStatus, secondsToNextRetry } = connectionState;\n\n return (\n <div\n {...htmlAttributes}\n className={cx(classBase, `${classBase}-${connectionStatus}`)}\n >\n {showText ? (\n <div className={`${classBase}-text`}>\n {getDisplayText(connectionState)}\n </div>\n ) : null}\n {connectionStatus === \"disconnected\" && secondsToNextRetry > 0 ? (\n <ConnectionRetryCountdown seconds={secondsToNextRetry} />\n ) : null}\n <ConnectionStatusIndicator connectionState={connectionState} />\n </div>\n );\n};\n"],"names":[],"mappings":";;;;;;;;;;AAWA,MAAM,SAAY,GAAA,2BAAA;AAElB,MAAM,sBAAmD,GAAA;AAAA,EACvD,eAAiB,EAAA,YAAA;AAAA,EACjB,gBAAkB,EAAA,QAAA;AAAA,EAClB,kBAAoB,EAAA,CAAA,CAAA;AAAA,EACpB,sBAAwB,EAAA,CAAA;AAAA,EACxB,kBAAoB,EAAA;AACtB,CAAA;AAQA,MAAM,cAAA,GAAiB,CAAC,eAA8C,KAAA;AACpE,EAAA,QAAQ,gBAAgB,gBAAkB;AAAA,IACxC,KAAK,QAAA;AACH,MAAO,OAAA,mCAAA;AAAA,IACT,KAAK,QAAA;AACH,MAAO,OAAA,eAAA,CAAgB,eAAoB,KAAA,YAAA,GACvC,mBACA,GAAA,sBAAA;AAAA,IAEN,KAAK,cAAA;AACH,MAAO,OAAA,eAAA,CAAgB,eAAoB,KAAA,YAAA,GACvC,uCACA,GAAA,yCAAA;AAAA;AAEV,CAAA;AAEO,MAAM,yBAAyB,CAAC;AAAA,EACrC,eAAiB,EAAA,mBAAA;AAAA,EACjB,QAAW,GAAA,IAAA;AAAA,EACX,GAAG;AACL,CAAmC,KAAA;AACjC,EAAA,MAAM,eAAe,SAAU,EAAA;AAC/B,EAAyB,wBAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,iCAAA;AAAA,IACR,GAAK,EAAA,yBAAA;AAAA,IACL,MAAQ,EAAA;AAAA,GACT,CAAA;AACD,EAAA,MAAM,CAAC,eAAA,EAAiB,kBAAkB,CAAA,GACxC,SAAmC,sBAAsB,CAAA;AAE3D,EAAA,OAAA,CAAQ,MAAM;AACZ,IAAkB,iBAAA,CAAA,EAAA,CAAG,qBAAqB,kBAAkB,CAAA;AAC5D,IAAA,IAAI,mBAAqB,EAAA;AACvB,MAAA,kBAAA,CAAmB,mBAAmB,CAAA;AAAA;AACxC,GACF,EAAG,CAAC,mBAAmB,CAAC,CAAA;AAExB,EAAM,MAAA,EAAE,gBAAkB,EAAA,kBAAA,EAAuB,GAAA,eAAA;AAEjD,EACE,uBAAA,IAAA;AAAA,IAAC,KAAA;AAAA,IAAA;AAAA,MACE,GAAG,cAAA;AAAA,MACJ,WAAW,EAAG,CAAA,SAAA,EAAW,GAAG,SAAS,CAAA,CAAA,EAAI,gBAAgB,CAAE,CAAA,CAAA;AAAA,MAE1D,QAAA,EAAA;AAAA,QACC,QAAA,mBAAA,GAAA,CAAC,SAAI,SAAW,EAAA,CAAA,EAAG,SAAS,CACzB,KAAA,CAAA,EAAA,QAAA,EAAA,cAAA,CAAe,eAAe,CAAA,EACjC,CACE,GAAA,IAAA;AAAA,QACH,gBAAA,KAAqB,kBAAkB,kBAAqB,GAAA,CAAA,uBAC1D,wBAAyB,EAAA,EAAA,OAAA,EAAS,oBAAoB,CACrD,GAAA,IAAA;AAAA,wBACJ,GAAA,CAAC,6BAA0B,eAAkC,EAAA;AAAA;AAAA;AAAA,GAC/D;AAEJ;;;;"}
@@ -0,0 +1,4 @@
1
+ var connectionStatusIndicatorCss = "@keyframes squeeze {\n 0% {\n transform: scale(1);\n }\n\n 50% {\n transform: scale(0.85);\n }\n\n 100% {\n transform: scale(1);\n }\n}\n\n.ConnectionStatusIndicator {\n --ball-size-large: 20px;\n --ball-size-small: 14px;\n --ballbox-padding: 4px;\n --retry-count: 0;\n --height: var(\n --ballbox-height,\n calc(var(--ball-size-large) + var(--salt-spacing-100))\n );\n height: var(--height);\n padding: 0 4px;\n position: relative;\n width: calc(\n var(--ball-size-large) + var(--salt-spacing-400) +\n (var(--ball-size-small) + var(--salt-spacing-100)) * var(--retry-count)\n );\n\n &.expanded {\n transition-delay: 1s;\n .Ball.large {\n animation-duration: 0.8s;\n animation-name: squeeze;\n transform-origin: center;\n }\n .Ball.small {\n transform: translateX(calc(var(--ball-size-large) * var(--i)));\n }\n }\n}\n\n.ConnectionStatusIndicator-inactive {\n --ball-color: lightgray;\n}\n\n.ConnectionStatusIndicator-closed {\n --ball-color: red;\n opacity: 0.8;\n .Ball.large {\n transition: background-color 1s linear;\n }\n}\n\n.ConnectionStatusIndicator-connected {\n --ball-color: green;\n}\n\n.ConnectionStatusIndicator-disconnected {\n --ball-color: red;\n}\n\n.Ball.large {\n background-color: var(--ball-color);\n border-radius: calc(var(--ball-size-large) / 2);\n height: var(--ball-size-large);\n right: var(--ballbox-padding);\n top: calc(var(--height) / 2 - (var(--ball-size-large) / 2));\n position: absolute;\n transition: transform 0.8s linear;\n\n width: var(--ball-size-large);\n z-index: 1;\n}\n\n.Ball.small {\n background-color: var(--ball-color);\n border-radius: calc(var(--ball-size-small) / 2);\n height: var(--ball-size-small);\n position: absolute;\n right: calc(\n var(--ballbox-padding) + (var(--ball-size-large) - var(--ball-size-small)) /\n 2\n );\n top: calc(var(--height) / 2 - (var(--ball-size-small) / 2));\n width: var(--ball-size-small);\n\n transition: transform 0.4s ease-out;\n transition-delay: 0.1s;\n}\n";
2
+
3
+ export { connectionStatusIndicatorCss as default };
4
+ //# sourceMappingURL=ConnectionStatusIndicator.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ConnectionStatusIndicator.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
@@ -0,0 +1,79 @@
1
+ import { jsx, jsxs } from 'react/jsx-runtime';
2
+ import { memo, useRef, useMemo } from 'react';
3
+ import { useComponentCssInjection } from '@salt-ds/styles';
4
+ import { useWindow } from '@salt-ds/window';
5
+ import cx from 'clsx';
6
+ import connectionStatusIndicatorCss from './ConnectionStatusIndicator.css.js';
7
+
8
+ const classBase = "ConnectionStatusIndicator";
9
+ const Ball = memo(({ background, i = 0, large = false }) => {
10
+ if (large) {
11
+ return /* @__PURE__ */ jsx("div", { className: "Ball large", style: { background } }, i);
12
+ } else {
13
+ return /* @__PURE__ */ jsx(
14
+ "div",
15
+ {
16
+ className: "Ball small",
17
+ style: { "--i": -(i + 1), background }
18
+ },
19
+ i
20
+ );
21
+ }
22
+ });
23
+ Ball.displayName = "Ball";
24
+ const ConnectionStatusIndicator = ({
25
+ connectionState
26
+ }) => {
27
+ const targetWindow = useWindow();
28
+ useComponentCssInjection({
29
+ testId: "vuu-connection-status-indicator",
30
+ css: connectionStatusIndicatorCss,
31
+ window: targetWindow
32
+ });
33
+ const ballbox = useRef(null);
34
+ const expandedRef = useRef(false);
35
+ const { connectionStatus, retryAttemptsRemaining, retryAttemptsTotal } = connectionState;
36
+ if (connectionStatus === "disconnected") {
37
+ expandedRef.current = true;
38
+ }
39
+ const finalState = connectionStatus === "connected" || connectionStatus === "closed";
40
+ useMemo(() => {
41
+ if (finalState) {
42
+ expandedRef.current = false;
43
+ }
44
+ }, [finalState]);
45
+ const getSmallBalls = () => {
46
+ const colors = Array(retryAttemptsTotal).fill("lightgray");
47
+ const index = retryAttemptsTotal - retryAttemptsRemaining;
48
+ if (retryAttemptsRemaining) {
49
+ colors[index] = "orange";
50
+ for (let i = 0; i < index; i++) {
51
+ colors[i] = "red";
52
+ }
53
+ } else {
54
+ colors.fill("red");
55
+ }
56
+ colors.reverse();
57
+ return colors.map((background, i) => /* @__PURE__ */ jsx(Ball, { i, background }, i));
58
+ };
59
+ const balls = getSmallBalls();
60
+ const displayState = connectionStatus;
61
+ const retryCount = connectionStatus === "disconnected" ? retryAttemptsTotal : 0;
62
+ return /* @__PURE__ */ jsxs(
63
+ "div",
64
+ {
65
+ className: cx(classBase, `${classBase}-${displayState}`, {
66
+ expanded: expandedRef.current
67
+ }),
68
+ ref: ballbox,
69
+ style: { "--retry-count": retryCount },
70
+ children: [
71
+ /* @__PURE__ */ jsx(Ball, { large: true }),
72
+ balls
73
+ ]
74
+ }
75
+ );
76
+ };
77
+
78
+ export { ConnectionStatusIndicator };
79
+ //# sourceMappingURL=ConnectionStatusIndicator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ConnectionStatusIndicator.js","sources":["../../src/connection-status/ConnectionStatusIndicator.tsx"],"sourcesContent":["import { CSSProperties, memo, useMemo, useRef } from \"react\";\nimport type { WebSocketConnectionState } from \"@vuu-ui/vuu-data-remote\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\n\nimport cx from \"clsx\";\n\nimport connectionStatusIndicatorCss from \"./ConnectionStatusIndicator.css\";\n\nconst classBase = \"ConnectionStatusIndicator\";\n\ninterface BallProps {\n background?: string;\n i?: number;\n large?: boolean;\n}\nconst Ball = memo(({ background, i = 0, large = false }: BallProps) => {\n if (large) {\n return <div className=\"Ball large\" key={i} style={{ background }} />;\n } else {\n return (\n <div\n className=\"Ball small\"\n key={i}\n style={{ \"--i\": -(i + 1), background } as CSSProperties}\n />\n );\n }\n});\nBall.displayName = \"Ball\";\n\ninterface ConnectionStatusIndicatorProps {\n connectionState: WebSocketConnectionState;\n}\n\nexport const ConnectionStatusIndicator = ({\n connectionState,\n}: ConnectionStatusIndicatorProps) => {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"vuu-connection-status-indicator\",\n css: connectionStatusIndicatorCss,\n window: targetWindow,\n });\n\n const ballbox = useRef<HTMLDivElement>(null);\n const expandedRef = useRef(false);\n const { connectionStatus, retryAttemptsRemaining, retryAttemptsTotal } =\n connectionState;\n\n if (connectionStatus === \"disconnected\") {\n // one way switch\n expandedRef.current = true;\n }\n const finalState =\n connectionStatus === \"connected\" || connectionStatus === \"closed\";\n\n useMemo(() => {\n if (finalState) {\n expandedRef.current = false;\n }\n }, [finalState]);\n\n const getSmallBalls = () => {\n const colors = Array(retryAttemptsTotal).fill(\"lightgray\");\n const index = retryAttemptsTotal - retryAttemptsRemaining;\n if (retryAttemptsRemaining) {\n colors[index] = \"orange\";\n for (let i = 0; i < index; i++) {\n colors[i] = \"red\";\n }\n } else {\n colors.fill(\"red\");\n }\n colors.reverse();\n return colors.map((background, i) => (\n <Ball key={i} i={i} background={background} />\n ));\n };\n\n const balls = getSmallBalls();\n\n // const displayState = balls.length > 0 ? \"disconnected\" : connectionStatus;\n const displayState = connectionStatus;\n const retryCount =\n connectionStatus === \"disconnected\" ? retryAttemptsTotal : 0;\n\n return (\n <div\n className={cx(classBase, `${classBase}-${displayState}`, {\n expanded: expandedRef.current,\n })}\n ref={ballbox}\n style={{ \"--retry-count\": retryCount } as CSSProperties}\n >\n <Ball large />\n {balls}\n </div>\n );\n};\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,53 @@
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { registerComponent, importCSS } from '@vuu-ui/vuu-utils';
3
+ import React, { Suspense, useEffect } from 'react';
4
+ import { FeatureErrorBoundary } from './FeatureErrorBoundary.js';
5
+ import { Loader } from './Loader.js';
6
+
7
+ const componentsMap = /* @__PURE__ */ new Map();
8
+ const useCachedFeature = (url) => {
9
+ useEffect(
10
+ () => () => {
11
+ componentsMap.delete(url);
12
+ },
13
+ [url]
14
+ );
15
+ if (!componentsMap.has(url)) {
16
+ componentsMap.set(
17
+ url,
18
+ React.lazy(() => import(
19
+ /* @vite-ignore */
20
+ url
21
+ ))
22
+ );
23
+ }
24
+ const lazyFeature = componentsMap.get(url);
25
+ if (!lazyFeature) {
26
+ throw Error(`Unable to load Lazy Feature at url ${url}`);
27
+ } else {
28
+ return lazyFeature;
29
+ }
30
+ };
31
+ function RawFeature({
32
+ url,
33
+ css,
34
+ ComponentProps: params,
35
+ ...props
36
+ }) {
37
+ if (css) {
38
+ importCSS(css).then((styleSheet) => {
39
+ document.adoptedStyleSheets = [
40
+ ...document.adoptedStyleSheets,
41
+ styleSheet
42
+ ];
43
+ });
44
+ }
45
+ const LazyFeature = useCachedFeature(url);
46
+ return /* @__PURE__ */ jsx(FeatureErrorBoundary, { url, children: /* @__PURE__ */ jsx(Suspense, { fallback: /* @__PURE__ */ jsx(Loader, {}), children: /* @__PURE__ */ jsx(LazyFeature, { ...props, ...params }) }) });
47
+ }
48
+ const Feature = React.memo(RawFeature);
49
+ Feature.displayName = "Feature";
50
+ registerComponent("Feature", Feature, "view");
51
+
52
+ export { Feature };
53
+ //# sourceMappingURL=Feature.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Feature.js","sources":["../../src/feature/Feature.tsx"],"sourcesContent":["import {\n DynamicFeatureProps,\n importCSS,\n registerComponent,\n} from \"@vuu-ui/vuu-utils\";\nimport React, { Suspense, useEffect } from \"react\";\nimport { FeatureErrorBoundary } from \"./FeatureErrorBoundary\";\nimport { Loader } from \"./Loader\";\n\n/**\n * Ensure we never lazy load the same component more than once\n */\nconst componentsMap = new Map<string, ReturnType<typeof React.lazy>>();\nconst useCachedFeature = (url: string) => {\n useEffect(\n () => () => {\n componentsMap.delete(url);\n },\n [url],\n );\n\n if (!componentsMap.has(url)) {\n componentsMap.set(\n url,\n React.lazy(() => import(/* @vite-ignore */ url)),\n );\n }\n\n const lazyFeature = componentsMap.get(url);\n\n if (!lazyFeature) {\n throw Error(`Unable to load Lazy Feature at url ${url}`);\n } else {\n return lazyFeature;\n }\n};\n\nfunction RawFeature<Params extends object | undefined>({\n url,\n css,\n ComponentProps: params,\n ...props\n}: DynamicFeatureProps<Params>) {\n if (css) {\n // import(/* @vite-ignore */ css, { assert: { type: \"css\" } }).then(\n // (cssModule) => {\n // console.log(\"%cInject Styles\", \"color: blue;font-weight: bold\");\n // document.adoptedStyleSheets = [\n // ...document.adoptedStyleSheets,\n // cssModule.default,\n // ];\n // }\n // );\n // Polyfill until cypress build supports import assertions\n // Note: already fully supported in esbuild and vite\n importCSS(css).then((styleSheet) => {\n document.adoptedStyleSheets = [\n ...document.adoptedStyleSheets,\n styleSheet,\n ];\n });\n }\n\n const LazyFeature = useCachedFeature(url);\n return (\n <FeatureErrorBoundary url={url}>\n <Suspense fallback={<Loader />}>\n <LazyFeature {...props} {...params} />\n </Suspense>\n </FeatureErrorBoundary>\n );\n}\n\n/**\n Feature is a wrapper around React Lazy Loading. It will load a component\n from the given url. That url must resolve to a javascript bundle with a\n single default export. That export must be a React component.\n */\nexport const Feature = React.memo(RawFeature);\nFeature.displayName = \"Feature\";\nregisterComponent(\"Feature\", Feature, \"view\");\n"],"names":[],"mappings":";;;;;;AAYA,MAAM,aAAA,uBAAoB,GAA2C,EAAA;AACrE,MAAM,gBAAA,GAAmB,CAAC,GAAgB,KAAA;AACxC,EAAA,SAAA;AAAA,IACE,MAAM,MAAM;AACV,MAAA,aAAA,CAAc,OAAO,GAAG,CAAA;AAAA,KAC1B;AAAA,IACA,CAAC,GAAG;AAAA,GACN;AAEA,EAAA,IAAI,CAAC,aAAA,CAAc,GAAI,CAAA,GAAG,CAAG,EAAA;AAC3B,IAAc,aAAA,CAAA,GAAA;AAAA,MACZ,GAAA;AAAA,MACA,KAAA,CAAM,KAAK,MAAM;AAAA;AAAA,QAA0B;AAAA,OAAI;AAAA,KACjD;AAAA;AAGF,EAAM,MAAA,WAAA,GAAc,aAAc,CAAA,GAAA,CAAI,GAAG,CAAA;AAEzC,EAAA,IAAI,CAAC,WAAa,EAAA;AAChB,IAAM,MAAA,KAAA,CAAM,CAAsC,mCAAA,EAAA,GAAG,CAAE,CAAA,CAAA;AAAA,GAClD,MAAA;AACL,IAAO,OAAA,WAAA;AAAA;AAEX,CAAA;AAEA,SAAS,UAA8C,CAAA;AAAA,EACrD,GAAA;AAAA,EACA,GAAA;AAAA,EACA,cAAgB,EAAA,MAAA;AAAA,EAChB,GAAG;AACL,CAAgC,EAAA;AAC9B,EAAA,IAAI,GAAK,EAAA;AAYP,IAAA,SAAA,CAAU,GAAG,CAAA,CAAE,IAAK,CAAA,CAAC,UAAe,KAAA;AAClC,MAAA,QAAA,CAAS,kBAAqB,GAAA;AAAA,QAC5B,GAAG,QAAS,CAAA,kBAAA;AAAA,QACZ;AAAA,OACF;AAAA,KACD,CAAA;AAAA;AAGH,EAAM,MAAA,WAAA,GAAc,iBAAiB,GAAG,CAAA;AACxC,EAAA,2BACG,oBAAqB,EAAA,EAAA,GAAA,EACpB,QAAC,kBAAA,GAAA,CAAA,QAAA,EAAA,EAAS,0BAAW,GAAA,CAAA,MAAA,EAAA,EAAO,CAC1B,EAAA,QAAA,kBAAA,GAAA,CAAC,eAAa,GAAG,KAAA,EAAQ,GAAG,MAAA,EAAQ,GACtC,CACF,EAAA,CAAA;AAEJ;AAOa,MAAA,OAAA,GAAU,KAAM,CAAA,IAAA,CAAK,UAAU;AAC5C,OAAA,CAAQ,WAAc,GAAA,SAAA;AACtB,iBAAkB,CAAA,SAAA,EAAW,SAAS,MAAM,CAAA;;;;"}
@@ -0,0 +1,28 @@
1
+ import { jsxs, Fragment, jsx } from 'react/jsx-runtime';
2
+ import React from 'react';
3
+
4
+ class FeatureErrorBoundary extends React.Component {
5
+ constructor(props) {
6
+ super(props);
7
+ this.state = { errorMessage: null };
8
+ }
9
+ static getDerivedStateFromError(error) {
10
+ return { errorMessage: error.message };
11
+ }
12
+ componentDidCatch(error, errorInfo) {
13
+ console.log(`error creating component at ${this.props.url}`);
14
+ console.log(error, errorInfo);
15
+ }
16
+ render() {
17
+ if (this.state.errorMessage) {
18
+ return /* @__PURE__ */ jsxs(Fragment, { children: [
19
+ /* @__PURE__ */ jsx("h1", { children: "An error occured while creating component." }),
20
+ /* @__PURE__ */ jsx("p", { children: this.state.errorMessage })
21
+ ] });
22
+ }
23
+ return this.props.children;
24
+ }
25
+ }
26
+
27
+ export { FeatureErrorBoundary };
28
+ //# sourceMappingURL=FeatureErrorBoundary.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FeatureErrorBoundary.js","sources":["../../src/feature/FeatureErrorBoundary.tsx"],"sourcesContent":["import { DynamicFeatureProps } from \"@vuu-ui/vuu-utils\";\nimport React, { ErrorInfo, ReactNode } from \"react\";\n\nexport interface FeatureErrorBoundaryProps extends DynamicFeatureProps {\n children: ReactNode;\n}\n\nexport class FeatureErrorBoundary extends React.Component<\n FeatureErrorBoundaryProps,\n any\n> {\n constructor(props: FeatureErrorBoundaryProps) {\n super(props);\n this.state = { errorMessage: null };\n }\n\n static getDerivedStateFromError(error: Error) {\n // Update state so the next render will show the fallback UI.\n return { errorMessage: error.message };\n }\n\n componentDidCatch(error: Error, errorInfo: ErrorInfo) {\n // You can also log the error to an error reporting service\n console.log(`error creating component at ${this.props.url}`);\n console.log(error, errorInfo);\n }\n\n render() {\n if (this.state.errorMessage) {\n return (\n <>\n <h1>An error occured while creating component.</h1>\n <p>{this.state.errorMessage}</p>\n </>\n );\n }\n\n return this.props.children;\n }\n}\n"],"names":[],"mappings":";;;AAOa,MAAA,oBAAA,SAA6B,MAAM,SAG9C,CAAA;AAAA,EACA,YAAY,KAAkC,EAAA;AAC5C,IAAA,KAAA,CAAM,KAAK,CAAA;AACX,IAAK,IAAA,CAAA,KAAA,GAAQ,EAAE,YAAA,EAAc,IAAK,EAAA;AAAA;AACpC,EAEA,OAAO,yBAAyB,KAAc,EAAA;AAE5C,IAAO,OAAA,EAAE,YAAc,EAAA,KAAA,CAAM,OAAQ,EAAA;AAAA;AACvC,EAEA,iBAAA,CAAkB,OAAc,SAAsB,EAAA;AAEpD,IAAA,OAAA,CAAQ,GAAI,CAAA,CAAA,4BAAA,EAA+B,IAAK,CAAA,KAAA,CAAM,GAAG,CAAE,CAAA,CAAA;AAC3D,IAAQ,OAAA,CAAA,GAAA,CAAI,OAAO,SAAS,CAAA;AAAA;AAC9B,EAEA,MAAS,GAAA;AACP,IAAI,IAAA,IAAA,CAAK,MAAM,YAAc,EAAA;AAC3B,MAAA,uBAEI,IAAA,CAAA,QAAA,EAAA,EAAA,QAAA,EAAA;AAAA,wBAAA,GAAA,CAAC,QAAG,QAA0C,EAAA,4CAAA,EAAA,CAAA;AAAA,wBAC7C,GAAA,CAAA,GAAA,EAAA,EAAG,QAAK,EAAA,IAAA,CAAA,KAAA,CAAM,YAAa,EAAA;AAAA,OAC9B,EAAA,CAAA;AAAA;AAIJ,IAAA,OAAO,KAAK,KAAM,CAAA,QAAA;AAAA;AAEtB;;;;"}
@@ -0,0 +1,6 @@
1
+ import { jsx } from 'react/jsx-runtime';
2
+
3
+ const Loader = () => /* @__PURE__ */ jsx("div", { className: "hwLoader" });
4
+
5
+ export { Loader };
6
+ //# sourceMappingURL=Loader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Loader.js","sources":["../../src/feature/Loader.tsx"],"sourcesContent":["// TODO\nexport const Loader = () => <div className=\"hwLoader\"></div>;\n"],"names":[],"mappings":";;AACO,MAAM,MAAS,GAAA,sBAAO,GAAA,CAAA,KAAA,EAAA,EAAI,WAAU,UAAW,EAAA;;;;"}
@@ -0,0 +1,56 @@
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { getCustomAndTableFeatures } from '@vuu-ui/vuu-utils';
3
+ import { createContext, useMemo, useContext } from 'react';
4
+ import { useVuuTables } from '@vuu-ui/vuu-data-react';
5
+
6
+ const NO_FEATURES = [];
7
+ const NO_STATICFEATURES = [];
8
+ const NO_SYSTEMLAYOUTS = [];
9
+ const NO_FEATURES_VUU = {
10
+ dynamicFeatures: NO_FEATURES,
11
+ tableFeatures: NO_FEATURES
12
+ };
13
+ const FeatureContext = createContext({
14
+ dynamicFeatures: NO_FEATURES,
15
+ tableFeatures: NO_FEATURES,
16
+ staticFeatures: NO_STATICFEATURES
17
+ });
18
+ const LayoutContext = createContext({
19
+ systemLayouts: NO_SYSTEMLAYOUTS
20
+ });
21
+ const FeatureAndLayoutProvider = ({
22
+ children,
23
+ dynamicFeatures: dynamicFeaturesProp = [],
24
+ staticFeatures,
25
+ systemLayouts
26
+ }) => {
27
+ const tableSchemas = useVuuTables();
28
+ const { dynamicFeatures, tableFeatures } = useMemo(
29
+ () => tableSchemas ? getCustomAndTableFeatures(dynamicFeaturesProp, tableSchemas) : NO_FEATURES_VUU,
30
+ [dynamicFeaturesProp, tableSchemas]
31
+ );
32
+ return /* @__PURE__ */ jsx(
33
+ FeatureContext.Provider,
34
+ {
35
+ value: {
36
+ dynamicFeatures,
37
+ tableFeatures,
38
+ staticFeatures
39
+ },
40
+ children: /* @__PURE__ */ jsx(
41
+ LayoutContext.Provider,
42
+ {
43
+ value: {
44
+ systemLayouts
45
+ },
46
+ children
47
+ }
48
+ )
49
+ }
50
+ );
51
+ };
52
+ const useFeatures = () => useContext(FeatureContext);
53
+ const useLayouts = () => useContext(LayoutContext);
54
+
55
+ export { FeatureAndLayoutProvider, useFeatures, useLayouts };
56
+ //# sourceMappingURL=FeatureAndLayoutProvider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FeatureAndLayoutProvider.js","sources":["../../src/feature-and-layout-provider/FeatureAndLayoutProvider.tsx"],"sourcesContent":["import {\n DynamicFeatureDescriptor,\n DynamicFeatureProps,\n FilterTableFeatureProps,\n StaticFeatureDescriptor,\n SystemLayoutMetadata,\n getCustomAndTableFeatures,\n} from \"@vuu-ui/vuu-utils\";\nimport {\n ReactElement,\n ReactNode,\n createContext,\n useContext,\n useMemo,\n} from \"react\";\nimport { useVuuTables } from \"@vuu-ui/vuu-data-react\";\n\nexport interface FeatureContextProps {\n dynamicFeatures?: DynamicFeatureProps[];\n tableFeatures?: DynamicFeatureProps<FilterTableFeatureProps>[];\n staticFeatures?: StaticFeatureDescriptor[];\n}\n\nexport interface LayoutContextProps {\n systemLayouts?: SystemLayoutMetadata[];\n}\n\nconst NO_FEATURES: DynamicFeatureDescriptor[] = [];\nconst NO_STATICFEATURES: StaticFeatureDescriptor[] = [];\nconst NO_SYSTEMLAYOUTS: SystemLayoutMetadata[] = [];\n\nconst NO_FEATURES_VUU = {\n dynamicFeatures: NO_FEATURES,\n tableFeatures: NO_FEATURES,\n};\n\nconst FeatureContext = createContext<FeatureContextProps>({\n dynamicFeatures: NO_FEATURES,\n tableFeatures: NO_FEATURES,\n staticFeatures: NO_STATICFEATURES,\n});\n\nconst LayoutContext = createContext<LayoutContextProps>({\n systemLayouts: NO_SYSTEMLAYOUTS,\n});\n\nexport interface FeatureAndLayoutProviderProps\n extends Partial<FeatureContextProps> {\n children: ReactNode;\n dynamicFeatures?: DynamicFeatureDescriptor[];\n staticFeatures?: StaticFeatureDescriptor[];\n systemLayouts?: SystemLayoutMetadata[];\n}\n\nexport const FeatureAndLayoutProvider = ({\n children,\n dynamicFeatures: dynamicFeaturesProp = [],\n staticFeatures,\n systemLayouts,\n}: FeatureAndLayoutProviderProps): ReactElement => {\n const tableSchemas = useVuuTables();\n\n const { dynamicFeatures, tableFeatures } = useMemo<{\n dynamicFeatures: DynamicFeatureProps[];\n tableFeatures: DynamicFeatureProps<FilterTableFeatureProps>[];\n }>(\n () =>\n tableSchemas\n ? getCustomAndTableFeatures(dynamicFeaturesProp, tableSchemas)\n : NO_FEATURES_VUU,\n [dynamicFeaturesProp, tableSchemas],\n );\n\n return (\n <FeatureContext.Provider\n value={{\n dynamicFeatures,\n tableFeatures,\n staticFeatures,\n }}\n >\n <LayoutContext.Provider\n value={{\n systemLayouts,\n }}\n >\n {children}\n </LayoutContext.Provider>\n </FeatureContext.Provider>\n );\n};\n\nexport const useFeatures = () => useContext(FeatureContext);\nexport const useLayouts = () => useContext(LayoutContext);\n"],"names":[],"mappings":";;;;;AA2BA,MAAM,cAA0C,EAAC;AACjD,MAAM,oBAA+C,EAAC;AACtD,MAAM,mBAA2C,EAAC;AAElD,MAAM,eAAkB,GAAA;AAAA,EACtB,eAAiB,EAAA,WAAA;AAAA,EACjB,aAAe,EAAA;AACjB,CAAA;AAEA,MAAM,iBAAiB,aAAmC,CAAA;AAAA,EACxD,eAAiB,EAAA,WAAA;AAAA,EACjB,aAAe,EAAA,WAAA;AAAA,EACf,cAAgB,EAAA;AAClB,CAAC,CAAA;AAED,MAAM,gBAAgB,aAAkC,CAAA;AAAA,EACtD,aAAe,EAAA;AACjB,CAAC,CAAA;AAUM,MAAM,2BAA2B,CAAC;AAAA,EACvC,QAAA;AAAA,EACA,eAAA,EAAiB,sBAAsB,EAAC;AAAA,EACxC,cAAA;AAAA,EACA;AACF,CAAmD,KAAA;AACjD,EAAA,MAAM,eAAe,YAAa,EAAA;AAElC,EAAM,MAAA,EAAE,eAAiB,EAAA,aAAA,EAAkB,GAAA,OAAA;AAAA,IAIzC,MACE,YAAA,GACI,yBAA0B,CAAA,mBAAA,EAAqB,YAAY,CAC3D,GAAA,eAAA;AAAA,IACN,CAAC,qBAAqB,YAAY;AAAA,GACpC;AAEA,EACE,uBAAA,GAAA;AAAA,IAAC,cAAe,CAAA,QAAA;AAAA,IAAf;AAAA,MACC,KAAO,EAAA;AAAA,QACL,eAAA;AAAA,QACA,aAAA;AAAA,QACA;AAAA,OACF;AAAA,MAEA,QAAA,kBAAA,GAAA;AAAA,QAAC,aAAc,CAAA,QAAA;AAAA,QAAd;AAAA,UACC,KAAO,EAAA;AAAA,YACL;AAAA,WACF;AAAA,UAEC;AAAA;AAAA;AACH;AAAA,GACF;AAEJ;AAEa,MAAA,WAAA,GAAc,MAAM,UAAA,CAAW,cAAc;AAC7C,MAAA,UAAA,GAAa,MAAM,UAAA,CAAW,aAAa;;;;"}
@@ -0,0 +1,4 @@
1
+ var featureListCss = ".vuuFeatureList {\n --vuuListItem-padding: var(--salt-spacing-200);\n background: var(\n --vuuFeatureList-background,\n var(--salt-container-primary-background)\n );\n display: flex;\n flex-direction: column;\n height: 100%;\n padding: 0 var(--vuuFeatureList-padding, 0);\n}\n\n.vuuFeatureList-header {\n align-items: center;\n display: flex;\n flex: 0 0 48px;\n font-weight: 700;\n line-height: 2;\n}\n\n.vuuFeatureList-content {\n display: flex;\n flex: 1 1 auto;\n flex-direction: column;\n font-size: 12px;\n font-weight: 700;\n overflow: auto;\n}\n\n.vuuFeatureList-standalone {\n margin-top: 24px;\n}\n\n.vuuFeatureList-group {\n --vuuMeasuredContainer-flex: 0 0 auto;\n\n display: flex;\n flex-direction: column;\n\n .vuuFeatureList-groupHeader {\n flex: 0 0 32px;\n padding: 8px 0;\n }\n\n .vuuPalette {\n flex: 1 1 auto;\n height: auto;\n }\n}\n\n.vuuFeatureList-group:first-child {\n margin-top: 12px;\n}\n\n.vuuFeatureList-group + .vuuFeatureList-group {\n margin-top: 24px;\n}\n\n.vuuFeatureList-itemName {\n font-weight: 700;\n}\n";
2
+
3
+ export { featureListCss as default };
4
+ //# sourceMappingURL=FeatureList.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FeatureList.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}