@xyo-network/react-app-settings 2.64.0-rc.7 → 2.64.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (167) hide show
  1. package/dist/browser/WebAppNavigationType.cjs +19 -0
  2. package/dist/browser/WebAppNavigationType.cjs.map +1 -0
  3. package/dist/browser/WebAppNavigationType.d.cts +2 -0
  4. package/dist/browser/WebAppNavigationType.d.cts.map +1 -0
  5. package/dist/browser/components/DarkModeIconButton.cjs +62 -0
  6. package/dist/browser/components/DarkModeIconButton.cjs.map +1 -0
  7. package/dist/browser/components/DarkModeIconButton.d.cts +4 -0
  8. package/dist/browser/components/DarkModeIconButton.d.cts.map +1 -0
  9. package/dist/browser/components/Developer.cjs +56 -0
  10. package/dist/browser/components/Developer.cjs.map +1 -0
  11. package/dist/browser/components/Developer.d.cts +5 -0
  12. package/dist/browser/components/Developer.d.cts.map +1 -0
  13. package/dist/browser/components/index.cjs +71 -0
  14. package/dist/browser/components/index.cjs.map +1 -0
  15. package/dist/browser/components/index.d.cts +3 -0
  16. package/dist/browser/components/index.d.cts.map +1 -0
  17. package/dist/browser/contexts/AppSettings/Context.cjs +42 -0
  18. package/dist/browser/contexts/AppSettings/Context.cjs.map +1 -0
  19. package/dist/browser/contexts/AppSettings/Context.d.cts +18 -0
  20. package/dist/browser/contexts/AppSettings/Context.d.cts.map +1 -0
  21. package/dist/browser/contexts/AppSettings/Provider.cjs +226 -0
  22. package/dist/browser/contexts/AppSettings/Provider.cjs.map +1 -0
  23. package/dist/browser/contexts/AppSettings/Provider.d.cts +9 -0
  24. package/dist/browser/contexts/AppSettings/Provider.d.cts.map +1 -0
  25. package/dist/browser/contexts/AppSettings/Slug.cjs +35 -0
  26. package/dist/{node/contexts/AppSettings/Slug.mjs.map → browser/contexts/AppSettings/Slug.cjs.map} +1 -1
  27. package/dist/browser/contexts/AppSettings/Slug.d.cts +9 -0
  28. package/dist/browser/contexts/AppSettings/Slug.d.cts.map +1 -0
  29. package/dist/browser/contexts/AppSettings/Storage.cjs +157 -0
  30. package/dist/browser/contexts/AppSettings/Storage.cjs.map +1 -0
  31. package/dist/browser/contexts/AppSettings/Storage.d.cts +18 -0
  32. package/dist/browser/contexts/AppSettings/Storage.d.cts.map +1 -0
  33. package/dist/browser/contexts/AppSettings/StorageBase.cjs +100 -0
  34. package/dist/{node/contexts/AppSettings/StorageBase.mjs.map → browser/contexts/AppSettings/StorageBase.cjs.map} +1 -1
  35. package/dist/browser/contexts/AppSettings/StorageBase.d.cts +16 -0
  36. package/dist/browser/contexts/AppSettings/StorageBase.d.cts.map +1 -0
  37. package/dist/browser/contexts/AppSettings/appSettingDefault.cjs +36 -0
  38. package/dist/{node/contexts/AppSettings/appSettingDefault.mjs.map → browser/contexts/AppSettings/appSettingDefault.cjs.map} +1 -1
  39. package/dist/browser/contexts/AppSettings/appSettingDefault.d.cts +2 -0
  40. package/dist/browser/contexts/AppSettings/appSettingDefault.d.cts.map +1 -0
  41. package/dist/browser/contexts/AppSettings/index.cjs +250 -0
  42. package/dist/browser/contexts/AppSettings/index.cjs.map +1 -0
  43. package/dist/browser/contexts/AppSettings/index.d.cts +7 -0
  44. package/dist/browser/contexts/AppSettings/index.d.cts.map +1 -0
  45. package/dist/browser/contexts/AppSettings/useAppSettings.cjs +50 -0
  46. package/dist/browser/contexts/AppSettings/useAppSettings.cjs.map +1 -0
  47. package/dist/browser/contexts/AppSettings/useAppSettings.d.cts +2 -0
  48. package/dist/browser/contexts/AppSettings/useAppSettings.d.cts.map +1 -0
  49. package/dist/browser/contexts/index.cjs +250 -0
  50. package/dist/browser/contexts/index.cjs.map +1 -0
  51. package/dist/browser/contexts/index.d.cts +2 -0
  52. package/dist/browser/contexts/index.d.cts.map +1 -0
  53. package/dist/browser/index.cjs +272 -0
  54. package/dist/browser/index.cjs.map +1 -0
  55. package/dist/browser/index.d.cts +4 -0
  56. package/dist/browser/index.d.cts.map +1 -0
  57. package/dist/docs.json +4102 -0
  58. package/dist/node/WebAppNavigationType.cjs +19 -0
  59. package/dist/node/WebAppNavigationType.cjs.map +1 -0
  60. package/dist/node/WebAppNavigationType.d.cts +2 -0
  61. package/dist/node/WebAppNavigationType.d.cts.map +1 -0
  62. package/dist/node/WebAppNavigationType.js +0 -16
  63. package/dist/node/WebAppNavigationType.js.map +1 -1
  64. package/dist/node/components/DarkModeIconButton.cjs +66 -0
  65. package/dist/node/components/DarkModeIconButton.cjs.map +1 -0
  66. package/dist/node/components/DarkModeIconButton.d.cts +4 -0
  67. package/dist/node/components/DarkModeIconButton.d.cts.map +1 -0
  68. package/dist/node/components/DarkModeIconButton.js +34 -32
  69. package/dist/node/components/DarkModeIconButton.js.map +1 -1
  70. package/dist/node/components/Developer.cjs +60 -0
  71. package/dist/node/components/Developer.cjs.map +1 -0
  72. package/dist/node/components/Developer.d.cts +5 -0
  73. package/dist/node/components/Developer.d.cts.map +1 -0
  74. package/dist/node/components/Developer.js +27 -27
  75. package/dist/node/components/Developer.js.map +1 -1
  76. package/dist/node/components/index.cjs +76 -0
  77. package/dist/node/components/index.cjs.map +1 -0
  78. package/dist/node/components/index.d.cts +3 -0
  79. package/dist/node/components/index.d.cts.map +1 -0
  80. package/dist/node/components/index.js +46 -23
  81. package/dist/node/components/index.js.map +1 -1
  82. package/dist/node/contexts/AppSettings/Context.cjs +46 -0
  83. package/dist/node/contexts/AppSettings/Context.cjs.map +1 -0
  84. package/dist/node/contexts/AppSettings/Context.d.cts +18 -0
  85. package/dist/node/contexts/AppSettings/Context.d.cts.map +1 -0
  86. package/dist/node/contexts/AppSettings/Context.js +18 -28
  87. package/dist/node/contexts/AppSettings/Context.js.map +1 -1
  88. package/dist/node/contexts/AppSettings/Provider.cjs +231 -0
  89. package/dist/node/contexts/AppSettings/Provider.cjs.map +1 -0
  90. package/dist/node/contexts/AppSettings/Provider.d.cts +9 -0
  91. package/dist/node/contexts/AppSettings/Provider.d.cts.map +1 -0
  92. package/dist/node/contexts/AppSettings/Provider.js +152 -37
  93. package/dist/node/contexts/AppSettings/Provider.js.map +1 -1
  94. package/dist/node/contexts/AppSettings/Slug.cjs +39 -0
  95. package/dist/node/contexts/AppSettings/Slug.cjs.map +1 -0
  96. package/dist/node/contexts/AppSettings/Slug.d.cts +9 -0
  97. package/dist/node/contexts/AppSettings/Slug.d.cts.map +1 -0
  98. package/dist/node/contexts/AppSettings/Slug.js +3 -26
  99. package/dist/node/contexts/AppSettings/Slug.js.map +1 -1
  100. package/dist/node/contexts/AppSettings/Storage.cjs +162 -0
  101. package/dist/node/contexts/AppSettings/Storage.cjs.map +1 -0
  102. package/dist/node/contexts/AppSettings/Storage.d.cts +18 -0
  103. package/dist/node/contexts/AppSettings/Storage.d.cts.map +1 -0
  104. package/dist/node/contexts/AppSettings/Storage.js +104 -41
  105. package/dist/node/contexts/AppSettings/Storage.js.map +1 -1
  106. package/dist/node/contexts/AppSettings/StorageBase.cjs +105 -0
  107. package/dist/node/contexts/AppSettings/StorageBase.cjs.map +1 -0
  108. package/dist/node/contexts/AppSettings/StorageBase.d.cts +16 -0
  109. package/dist/node/contexts/AppSettings/StorageBase.d.cts.map +1 -0
  110. package/dist/node/contexts/AppSettings/StorageBase.js +19 -41
  111. package/dist/node/contexts/AppSettings/StorageBase.js.map +1 -1
  112. package/dist/node/contexts/AppSettings/appSettingDefault.cjs +40 -0
  113. package/dist/node/contexts/AppSettings/appSettingDefault.cjs.map +1 -0
  114. package/dist/node/contexts/AppSettings/appSettingDefault.d.cts +2 -0
  115. package/dist/node/contexts/AppSettings/appSettingDefault.d.cts.map +1 -0
  116. package/dist/node/contexts/AppSettings/appSettingDefault.js +10 -34
  117. package/dist/node/contexts/AppSettings/appSettingDefault.js.map +1 -1
  118. package/dist/node/contexts/AppSettings/index.cjs +260 -0
  119. package/dist/node/contexts/AppSettings/index.cjs.map +1 -0
  120. package/dist/node/contexts/AppSettings/index.d.cts +7 -0
  121. package/dist/node/contexts/AppSettings/index.d.cts.map +1 -0
  122. package/dist/node/contexts/AppSettings/index.js +226 -31
  123. package/dist/node/contexts/AppSettings/index.js.map +1 -1
  124. package/dist/node/contexts/AppSettings/useAppSettings.cjs +54 -0
  125. package/dist/node/contexts/AppSettings/useAppSettings.cjs.map +1 -0
  126. package/dist/node/contexts/AppSettings/useAppSettings.d.cts +2 -0
  127. package/dist/node/contexts/AppSettings/useAppSettings.d.cts.map +1 -0
  128. package/dist/node/contexts/AppSettings/useAppSettings.js +25 -29
  129. package/dist/node/contexts/AppSettings/useAppSettings.js.map +1 -1
  130. package/dist/node/contexts/index.cjs +260 -0
  131. package/dist/node/contexts/index.cjs.map +1 -0
  132. package/dist/node/contexts/index.d.cts +2 -0
  133. package/dist/node/contexts/index.d.cts.map +1 -0
  134. package/dist/node/contexts/index.js +226 -21
  135. package/dist/node/contexts/index.js.map +1 -1
  136. package/dist/node/index.cjs +284 -0
  137. package/dist/node/index.cjs.map +1 -0
  138. package/dist/node/index.d.cts +4 -0
  139. package/dist/node/index.d.cts.map +1 -0
  140. package/dist/node/index.js +249 -26
  141. package/dist/node/index.js.map +1 -1
  142. package/package.json +14 -14
  143. package/dist/node/WebAppNavigationType.mjs +0 -1
  144. package/dist/node/WebAppNavigationType.mjs.map +0 -1
  145. package/dist/node/components/DarkModeIconButton.mjs +0 -15
  146. package/dist/node/components/DarkModeIconButton.mjs.map +0 -1
  147. package/dist/node/components/Developer.mjs +0 -9
  148. package/dist/node/components/Developer.mjs.map +0 -1
  149. package/dist/node/components/index.mjs +0 -3
  150. package/dist/node/components/index.mjs.map +0 -1
  151. package/dist/node/contexts/AppSettings/Context.mjs +0 -7
  152. package/dist/node/contexts/AppSettings/Context.mjs.map +0 -1
  153. package/dist/node/contexts/AppSettings/Provider.mjs +0 -67
  154. package/dist/node/contexts/AppSettings/Provider.mjs.map +0 -1
  155. package/dist/node/contexts/AppSettings/Slug.mjs +0 -13
  156. package/dist/node/contexts/AppSettings/Storage.mjs +0 -48
  157. package/dist/node/contexts/AppSettings/Storage.mjs.map +0 -1
  158. package/dist/node/contexts/AppSettings/StorageBase.mjs +0 -78
  159. package/dist/node/contexts/AppSettings/appSettingDefault.mjs +0 -15
  160. package/dist/node/contexts/AppSettings/index.mjs +0 -7
  161. package/dist/node/contexts/AppSettings/index.mjs.map +0 -1
  162. package/dist/node/contexts/AppSettings/useAppSettings.mjs +0 -9
  163. package/dist/node/contexts/AppSettings/useAppSettings.mjs.map +0 -1
  164. package/dist/node/contexts/index.mjs +0 -2
  165. package/dist/node/contexts/index.mjs.map +0 -1
  166. package/dist/node/index.mjs +0 -4
  167. package/dist/node/index.mjs.map +0 -1
package/package.json CHANGED
@@ -10,9 +10,9 @@
10
10
  "url": "https://github.com/XYOracleNetwork/sdk-xyo-react-js/issues"
11
11
  },
12
12
  "dependencies": {
13
- "@xylabs/assert": "^2.11.11",
14
- "@xylabs/react-shared": "^3.1.0-rc.6",
15
- "@xyo-network/react-shared": "~2.64.0-rc.7"
13
+ "@xylabs/assert": "^2.12.13",
14
+ "@xylabs/react-shared": "^3.0.5",
15
+ "@xyo-network/react-shared": "~2.64.0"
16
16
  },
17
17
  "peerDependencies": {
18
18
  "@mui/icons-material": "^5",
@@ -24,7 +24,7 @@
24
24
  "react-router-dom": "^6.3.0"
25
25
  },
26
26
  "devDependencies": {
27
- "@xylabs/ts-scripts-yarn3": "^3.0.55",
27
+ "@xylabs/ts-scripts-yarn3": "^3.0.78",
28
28
  "typescript": "^5.2.2"
29
29
  },
30
30
  "description": "Common React library for all XYO projects that use React",
@@ -34,28 +34,28 @@
34
34
  "node": {
35
35
  "import": {
36
36
  "types": "./dist/node/index.d.mts",
37
- "default": "./dist/node/index.mjs"
37
+ "default": "./dist/node/index.js"
38
38
  },
39
39
  "require": {
40
- "types": "./dist/node/index.d.ts",
41
- "default": "./dist/node/index.js"
40
+ "types": "./dist/node/index.d.cts",
41
+ "default": "./dist/node/index.cjs"
42
42
  }
43
43
  },
44
44
  "browser": {
45
45
  "import": {
46
- "types": "./dist/browser/index.d.ts",
46
+ "types": "./dist/browser/index.d.mts",
47
47
  "default": "./dist/browser/index.js"
48
48
  },
49
49
  "require": {
50
- "types": "./dist/browser/index.d.ts",
51
- "default": "./dist/browser/index.js"
50
+ "types": "./dist/browser/index.d.cts",
51
+ "default": "./dist/browser/index.cjs"
52
52
  }
53
53
  },
54
- "default": "./dist/browser/index.mjs"
54
+ "default": "./dist/browser/index.js"
55
55
  },
56
56
  "./package.json": "./package.json"
57
57
  },
58
- "main": "dist/browser/index.js",
58
+ "main": "dist/browser/index.cjs",
59
59
  "module": "dist/browser/index.js",
60
60
  "homepage": "https://xyo.network",
61
61
  "keywords": [
@@ -78,6 +78,6 @@
78
78
  },
79
79
  "sideEffects": false,
80
80
  "types": "dist/browser/index.d.ts",
81
- "version": "2.64.0-rc.7",
82
- "stableVersion": "2.63.1"
81
+ "version": "2.64.0",
82
+ "type": "module"
83
83
  }
@@ -1 +0,0 @@
1
- //# sourceMappingURL=WebAppNavigationType.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -1,15 +0,0 @@
1
- import { jsx } from "react/jsx-runtime";
2
- import { DarkModeRounded as DarkModeRoundedIcon, LightModeRounded as LightModeRoundedIcon } from "@mui/icons-material";
3
- import { IconButton } from "@mui/material";
4
- import { useAppSettings } from "../contexts";
5
- const DarkModeIconButton = (props) => {
6
- const { darkMode, enableDarkMode } = useAppSettings();
7
- const handleDarkModeChange = () => {
8
- enableDarkMode?.(!darkMode);
9
- };
10
- return /* @__PURE__ */ jsx(IconButton, { onClick: handleDarkModeChange, ...props, children: darkMode ? /* @__PURE__ */ jsx(DarkModeRoundedIcon, {}) : /* @__PURE__ */ jsx(LightModeRoundedIcon, {}) });
11
- };
12
- export {
13
- DarkModeIconButton
14
- };
15
- //# sourceMappingURL=DarkModeIconButton.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../src/components/DarkModeIconButton.tsx"],"sourcesContent":["import { DarkModeRounded as DarkModeRoundedIcon, LightModeRounded as LightModeRoundedIcon } from '@mui/icons-material'\nimport { IconButton, IconButtonProps } from '@mui/material'\n\nimport { useAppSettings } from '../contexts'\n\nexport const DarkModeIconButton: React.FC<IconButtonProps> = (props) => {\n const { darkMode, enableDarkMode } = useAppSettings()\n\n const handleDarkModeChange = () => {\n enableDarkMode?.(!darkMode)\n }\n\n return (\n <IconButton onClick={handleDarkModeChange} {...props}>\n {darkMode ? <DarkModeRoundedIcon /> : <LightModeRoundedIcon />}\n </IconButton>\n )\n}\n"],"mappings":"AAckB;AAdlB,SAAS,mBAAmB,qBAAqB,oBAAoB,4BAA4B;AACjG,SAAS,kBAAmC;AAE5C,SAAS,sBAAsB;AAExB,MAAM,qBAAgD,CAAC,UAAU;AACtE,QAAM,EAAE,UAAU,eAAe,IAAI,eAAe;AAEpD,QAAM,uBAAuB,MAAM;AACjC,qBAAiB,CAAC,QAAQ;AAAA,EAC5B;AAEA,SACE,oBAAC,cAAW,SAAS,sBAAuB,GAAG,OAC5C,qBAAW,oBAAC,uBAAoB,IAAK,oBAAC,wBAAqB,GAC9D;AAEJ;","names":[]}
@@ -1,9 +0,0 @@
1
- import { useAppSettings } from "../contexts";
2
- const Developer = ({ children = null }) => {
3
- const { developerMode } = useAppSettings();
4
- return developerMode ? children : null;
5
- };
6
- export {
7
- Developer
8
- };
9
- //# sourceMappingURL=Developer.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../src/components/Developer.tsx"],"sourcesContent":["import { ReactElement } from 'react'\n\nimport { useAppSettings } from '../contexts'\n\nexport const Developer: React.FC<{ children: ReactElement }> = ({ children = null }) => {\n const { developerMode } = useAppSettings()\n\n return developerMode ? children : null\n}\n"],"mappings":"AAEA,SAAS,sBAAsB;AAExB,MAAM,YAAkD,CAAC,EAAE,WAAW,KAAK,MAAM;AACtF,QAAM,EAAE,cAAc,IAAI,eAAe;AAEzC,SAAO,gBAAgB,WAAW;AACpC;","names":[]}
@@ -1,3 +0,0 @@
1
- export * from "./DarkModeIconButton";
2
- export * from "./Developer";
3
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../src/components/index.ts"],"sourcesContent":["export * from './DarkModeIconButton'\nexport * from './Developer'\n"],"mappings":"AAAA,cAAc;AACd,cAAc;","names":[]}
@@ -1,7 +0,0 @@
1
- import { createContext } from "react";
2
- import { appSettingDefault } from "./appSettingDefault";
3
- const AppSettingsContext = createContext(appSettingDefault());
4
- export {
5
- AppSettingsContext
6
- };
7
- //# sourceMappingURL=Context.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../../src/contexts/AppSettings/Context.ts"],"sourcesContent":["import { createContext } from 'react'\n\nimport { WebAppNavigationType } from '../../WebAppNavigationType'\nimport { appSettingDefault } from './appSettingDefault'\n\nexport interface AppSettingsContextProps {\n changeMaxAccounts?: (value: number) => void\n changeNavigationCollapsed?: (value: boolean) => void\n changeNavigationType?: (value: WebAppNavigationType) => void\n changeSeedPhrase?: (value: string) => void\n darkMode?: boolean\n developerMode?: boolean\n enableDarkMode?: (value: boolean) => void\n enableDeveloperMode?: (value: boolean) => void\n maxAccounts?: number\n navigationCollapsed?: boolean\n navigationType?: WebAppNavigationType\n seedPhrase?: string\n}\n\nexport const AppSettingsContext = createContext<AppSettingsContextProps>(appSettingDefault())\n"],"mappings":"AAAA,SAAS,qBAAqB;AAG9B,SAAS,yBAAyB;AAiB3B,MAAM,qBAAqB,cAAuC,kBAAkB,CAAC;","names":[]}
@@ -1,67 +0,0 @@
1
- import { jsx } from "react/jsx-runtime";
2
- import { useState } from "react";
3
- import { AppSettingsContext } from "./Context";
4
- import { AppSettingsStorage } from "./Storage";
5
- const AppSettingsProvider = ({
6
- storage = new AppSettingsStorage(),
7
- value,
8
- children,
9
- ...props
10
- }) => {
11
- const [developerMode, setDeveloperMode] = useState(storage.developerMode);
12
- const [darkMode, setDarkMode] = useState(storage.darkMode);
13
- const [navigationType, setNavigationType] = useState(storage.navigationType);
14
- const [navigationCollapsed, setNavigationCollapsed] = useState(storage.navigationCollapsed);
15
- const [seedPhrase, setSeedPhrase] = useState(storage.seedPhrase);
16
- const [maxAccounts, setMaxAccounts] = useState(storage.maxAccounts);
17
- const enableDeveloperMode = (value2) => {
18
- storage.developerMode = value2;
19
- setDeveloperMode(storage.developerMode);
20
- };
21
- const enableDarkMode = (value2) => {
22
- storage.darkMode = value2;
23
- setDarkMode(storage.darkMode);
24
- };
25
- const changeNavigationType = (value2) => {
26
- storage.navigationType = value2;
27
- setNavigationType(value2);
28
- };
29
- const changeNavigationCollapsed = (value2) => {
30
- storage.navigationCollapsed = value2;
31
- setNavigationCollapsed(value2);
32
- };
33
- const changeSeedPhrase = (value2) => {
34
- storage.seedPhrase = value2;
35
- setSeedPhrase(value2);
36
- };
37
- const changeMaxAccounts = (value2) => {
38
- storage.maxAccounts = value2;
39
- setMaxAccounts(value2);
40
- };
41
- return /* @__PURE__ */ jsx(
42
- AppSettingsContext.Provider,
43
- {
44
- value: {
45
- changeMaxAccounts,
46
- changeNavigationCollapsed,
47
- changeNavigationType,
48
- changeSeedPhrase,
49
- darkMode,
50
- developerMode,
51
- enableDarkMode,
52
- enableDeveloperMode,
53
- maxAccounts,
54
- navigationCollapsed,
55
- navigationType,
56
- seedPhrase,
57
- ...value
58
- },
59
- ...props,
60
- children
61
- }
62
- );
63
- };
64
- export {
65
- AppSettingsProvider
66
- };
67
- //# sourceMappingURL=Provider.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../../src/contexts/AppSettings/Provider.tsx"],"sourcesContent":["import { WithChildren } from '@xylabs/react-shared'\nimport { ProviderProps, useState } from 'react'\n\nimport { WebAppNavigationType } from '../../WebAppNavigationType'\nimport { AppSettingsContext, AppSettingsContextProps } from './Context'\nimport { AppSettingsStorage } from './Storage'\n\nexport interface AppSettingsProviderProps<T extends AppSettingsContextProps = AppSettingsContextProps> extends ProviderProps<T> {\n storage?: AppSettingsStorage\n}\n\nexport const AppSettingsProvider: React.FC<WithChildren<AppSettingsProviderProps>> = ({\n storage = new AppSettingsStorage(),\n value,\n children,\n ...props\n}) => {\n const [developerMode, setDeveloperMode] = useState(storage.developerMode)\n const [darkMode, setDarkMode] = useState(storage.darkMode)\n const [navigationType, setNavigationType] = useState(storage.navigationType)\n const [navigationCollapsed, setNavigationCollapsed] = useState(storage.navigationCollapsed)\n const [seedPhrase, setSeedPhrase] = useState(storage.seedPhrase)\n const [maxAccounts, setMaxAccounts] = useState(storage.maxAccounts)\n\n const enableDeveloperMode = (value: boolean) => {\n storage.developerMode = value\n setDeveloperMode(storage.developerMode)\n }\n\n const enableDarkMode = (value: boolean) => {\n storage.darkMode = value\n setDarkMode(storage.darkMode)\n }\n\n const changeNavigationType = (value: WebAppNavigationType) => {\n storage.navigationType = value\n setNavigationType(value)\n }\n\n const changeNavigationCollapsed = (value: boolean) => {\n storage.navigationCollapsed = value\n setNavigationCollapsed(value)\n }\n\n const changeSeedPhrase = (value: string) => {\n storage.seedPhrase = value\n setSeedPhrase(value)\n }\n\n const changeMaxAccounts = (value: number) => {\n storage.maxAccounts = value\n setMaxAccounts(value)\n }\n\n return (\n <AppSettingsContext.Provider\n value={{\n changeMaxAccounts,\n changeNavigationCollapsed,\n changeNavigationType,\n changeSeedPhrase,\n darkMode,\n developerMode,\n enableDarkMode,\n enableDeveloperMode,\n maxAccounts,\n navigationCollapsed,\n navigationType,\n seedPhrase,\n\n ...value,\n }}\n {...props}\n >\n {children}\n </AppSettingsContext.Provider>\n )\n}\n"],"mappings":"AAuDI;AAtDJ,SAAwB,gBAAgB;AAGxC,SAAS,0BAAmD;AAC5D,SAAS,0BAA0B;AAM5B,MAAM,sBAAwE,CAAC;AAAA,EACpF,UAAU,IAAI,mBAAmB;AAAA,EACjC;AAAA,EACA;AAAA,EACA,GAAG;AACL,MAAM;AACJ,QAAM,CAAC,eAAe,gBAAgB,IAAI,SAAS,QAAQ,aAAa;AACxE,QAAM,CAAC,UAAU,WAAW,IAAI,SAAS,QAAQ,QAAQ;AACzD,QAAM,CAAC,gBAAgB,iBAAiB,IAAI,SAAS,QAAQ,cAAc;AAC3E,QAAM,CAAC,qBAAqB,sBAAsB,IAAI,SAAS,QAAQ,mBAAmB;AAC1F,QAAM,CAAC,YAAY,aAAa,IAAI,SAAS,QAAQ,UAAU;AAC/D,QAAM,CAAC,aAAa,cAAc,IAAI,SAAS,QAAQ,WAAW;AAElE,QAAM,sBAAsB,CAACA,WAAmB;AAC9C,YAAQ,gBAAgBA;AACxB,qBAAiB,QAAQ,aAAa;AAAA,EACxC;AAEA,QAAM,iBAAiB,CAACA,WAAmB;AACzC,YAAQ,WAAWA;AACnB,gBAAY,QAAQ,QAAQ;AAAA,EAC9B;AAEA,QAAM,uBAAuB,CAACA,WAAgC;AAC5D,YAAQ,iBAAiBA;AACzB,sBAAkBA,MAAK;AAAA,EACzB;AAEA,QAAM,4BAA4B,CAACA,WAAmB;AACpD,YAAQ,sBAAsBA;AAC9B,2BAAuBA,MAAK;AAAA,EAC9B;AAEA,QAAM,mBAAmB,CAACA,WAAkB;AAC1C,YAAQ,aAAaA;AACrB,kBAAcA,MAAK;AAAA,EACrB;AAEA,QAAM,oBAAoB,CAACA,WAAkB;AAC3C,YAAQ,cAAcA;AACtB,mBAAeA,MAAK;AAAA,EACtB;AAEA,SACE;AAAA,IAAC,mBAAmB;AAAA,IAAnB;AAAA,MACC,OAAO;AAAA,QACL;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QAEA,GAAG;AAAA,MACL;AAAA,MACC,GAAG;AAAA,MAEH;AAAA;AAAA,EACH;AAEJ;","names":["value"]}
@@ -1,13 +0,0 @@
1
- var AppSettingSlug = /* @__PURE__ */ ((AppSettingSlug2) => {
2
- AppSettingSlug2["DarkMode"] = "darkmode";
3
- AppSettingSlug2["Developer"] = "developer";
4
- AppSettingSlug2["NavigationType"] = "navigationType";
5
- AppSettingSlug2["NavigationCollapsed"] = "navigationCollapsed";
6
- AppSettingSlug2["SeedPhrase"] = "seedPhrase";
7
- AppSettingSlug2["MaxAccounts"] = "maxAccounts";
8
- return AppSettingSlug2;
9
- })(AppSettingSlug || {});
10
- export {
11
- AppSettingSlug
12
- };
13
- //# sourceMappingURL=Slug.mjs.map
@@ -1,48 +0,0 @@
1
- import { appSettingDefault } from "./appSettingDefault";
2
- import { AppSettingSlug } from "./Slug";
3
- import { AppSettingsStorageBase } from "./StorageBase";
4
- class AppSettingsStorage extends AppSettingsStorageBase {
5
- constructor(prefix = "AppSettings", defaults) {
6
- super(prefix, { ...appSettingDefault(), ...defaults });
7
- }
8
- get darkMode() {
9
- return this.getBoolean(AppSettingSlug.DarkMode);
10
- }
11
- set darkMode(value) {
12
- this.setBoolean(AppSettingSlug.DarkMode, value);
13
- }
14
- get developerMode() {
15
- return this.getBoolean(AppSettingSlug.Developer);
16
- }
17
- set developerMode(value) {
18
- this.setBoolean(AppSettingSlug.Developer, value);
19
- }
20
- get maxAccounts() {
21
- return this.getNumber(AppSettingSlug.MaxAccounts);
22
- }
23
- set maxAccounts(value) {
24
- this.setNumber(AppSettingSlug.MaxAccounts, value);
25
- }
26
- get navigationCollapsed() {
27
- return this.getBoolean(AppSettingSlug.NavigationCollapsed);
28
- }
29
- set navigationCollapsed(value) {
30
- this.setBoolean(AppSettingSlug.NavigationCollapsed, value);
31
- }
32
- get navigationType() {
33
- return this.getString(AppSettingSlug.NavigationType);
34
- }
35
- set navigationType(value) {
36
- this.setString(AppSettingSlug.NavigationType, value);
37
- }
38
- get seedPhrase() {
39
- return this.getString(AppSettingSlug.SeedPhrase);
40
- }
41
- set seedPhrase(value) {
42
- this.setString(AppSettingSlug.SeedPhrase, value);
43
- }
44
- }
45
- export {
46
- AppSettingsStorage
47
- };
48
- //# sourceMappingURL=Storage.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../../src/contexts/AppSettings/Storage.ts"],"sourcesContent":["import { WebAppNavigationType } from '../../WebAppNavigationType'\nimport { appSettingDefault } from './appSettingDefault'\nimport { AppSettingSlug } from './Slug'\nimport { AppSettingsStorageBase } from './StorageBase'\n\nexport class AppSettingsStorage extends AppSettingsStorageBase {\n constructor(prefix = 'AppSettings', defaults?: Record<string, unknown>) {\n super(prefix, { ...appSettingDefault(), ...defaults })\n }\n\n get darkMode() {\n return this.getBoolean(AppSettingSlug.DarkMode)\n }\n\n set darkMode(value: boolean) {\n this.setBoolean(AppSettingSlug.DarkMode, value)\n }\n\n get developerMode() {\n return this.getBoolean(AppSettingSlug.Developer)\n }\n\n set developerMode(value: boolean) {\n this.setBoolean(AppSettingSlug.Developer, value)\n }\n\n get maxAccounts() {\n return this.getNumber(AppSettingSlug.MaxAccounts)\n }\n\n set maxAccounts(value: number) {\n this.setNumber(AppSettingSlug.MaxAccounts, value)\n }\n\n get navigationCollapsed() {\n return this.getBoolean(AppSettingSlug.NavigationCollapsed)\n }\n\n set navigationCollapsed(value: boolean) {\n this.setBoolean(AppSettingSlug.NavigationCollapsed, value)\n }\n\n get navigationType() {\n return this.getString(AppSettingSlug.NavigationType) as WebAppNavigationType\n }\n\n set navigationType(value: WebAppNavigationType) {\n this.setString(AppSettingSlug.NavigationType, value)\n }\n\n get seedPhrase() {\n return this.getString(AppSettingSlug.SeedPhrase)\n }\n\n set seedPhrase(value: string) {\n this.setString(AppSettingSlug.SeedPhrase, value)\n }\n}\n"],"mappings":"AACA,SAAS,yBAAyB;AAClC,SAAS,sBAAsB;AAC/B,SAAS,8BAA8B;AAEhC,MAAM,2BAA2B,uBAAuB;AAAA,EAC7D,YAAY,SAAS,eAAe,UAAoC;AACtE,UAAM,QAAQ,EAAE,GAAG,kBAAkB,GAAG,GAAG,SAAS,CAAC;AAAA,EACvD;AAAA,EAEA,IAAI,WAAW;AACb,WAAO,KAAK,WAAW,eAAe,QAAQ;AAAA,EAChD;AAAA,EAEA,IAAI,SAAS,OAAgB;AAC3B,SAAK,WAAW,eAAe,UAAU,KAAK;AAAA,EAChD;AAAA,EAEA,IAAI,gBAAgB;AAClB,WAAO,KAAK,WAAW,eAAe,SAAS;AAAA,EACjD;AAAA,EAEA,IAAI,cAAc,OAAgB;AAChC,SAAK,WAAW,eAAe,WAAW,KAAK;AAAA,EACjD;AAAA,EAEA,IAAI,cAAc;AAChB,WAAO,KAAK,UAAU,eAAe,WAAW;AAAA,EAClD;AAAA,EAEA,IAAI,YAAY,OAAe;AAC7B,SAAK,UAAU,eAAe,aAAa,KAAK;AAAA,EAClD;AAAA,EAEA,IAAI,sBAAsB;AACxB,WAAO,KAAK,WAAW,eAAe,mBAAmB;AAAA,EAC3D;AAAA,EAEA,IAAI,oBAAoB,OAAgB;AACtC,SAAK,WAAW,eAAe,qBAAqB,KAAK;AAAA,EAC3D;AAAA,EAEA,IAAI,iBAAiB;AACnB,WAAO,KAAK,UAAU,eAAe,cAAc;AAAA,EACrD;AAAA,EAEA,IAAI,eAAe,OAA6B;AAC9C,SAAK,UAAU,eAAe,gBAAgB,KAAK;AAAA,EACrD;AAAA,EAEA,IAAI,aAAa;AACf,WAAO,KAAK,UAAU,eAAe,UAAU;AAAA,EACjD;AAAA,EAEA,IAAI,WAAW,OAAe;AAC5B,SAAK,UAAU,eAAe,YAAY,KAAK;AAAA,EACjD;AACF;","names":[]}
@@ -1,78 +0,0 @@
1
- import { assertEx } from "@xylabs/assert";
2
- import { assertDefinedEx } from "@xyo-network/react-shared";
3
- class AppSettingsStorageBase {
4
- defaults;
5
- prefix;
6
- constructor(prefix = "AppSettings", defaults) {
7
- this.prefix = prefix;
8
- this.defaults = defaults ?? {};
9
- }
10
- getBoolean(name) {
11
- const storedValue = localStorage.getItem(`${this.prefix}|${name}`);
12
- if (!storedValue) {
13
- assertEx(typeof this.defaults[name] === "boolean", "Default value is not boolean");
14
- const defaultValue = this.defaults[name];
15
- assertEx(defaultValue !== void 0, `Missing Default for ${name}`);
16
- return defaultValue;
17
- }
18
- return storedValue !== "false";
19
- }
20
- getNumber(name) {
21
- const storedValue = localStorage.getItem(`${this.prefix}|${name}`);
22
- if (!storedValue) {
23
- assertEx(typeof this.defaults[name] === "number", "Default value is not a number");
24
- const defaultValue = this.defaults[name];
25
- assertEx(defaultValue !== void 0, `Missing Default for ${name}`);
26
- return defaultValue;
27
- }
28
- return parseFloat(storedValue);
29
- }
30
- getObject(name) {
31
- const storedValue = localStorage.getItem(`${this.prefix}|${name}`);
32
- const parsedStoredValue = storedValue ? JSON.parse(storedValue) : null;
33
- if (!parsedStoredValue) {
34
- assertEx(typeof this.defaults[name] === "object", "Default value is not object");
35
- return assertEx(this.defaults[name], `Missing Default for ${name}`);
36
- }
37
- return parsedStoredValue;
38
- }
39
- getString(name) {
40
- const storedValue = localStorage.getItem(`${this.prefix}|${name}`);
41
- if (!storedValue) {
42
- assertDefinedEx(typeof this.defaults[name] === "string", "Default value is not string");
43
- const defaultValue = this.defaults[name];
44
- assertEx(defaultValue !== void 0, `Missing Default for ${name}`);
45
- return defaultValue;
46
- }
47
- return storedValue;
48
- }
49
- getStringArray(name) {
50
- const storedValue = localStorage.getItem(`${this.prefix}|${name}`)?.split(",");
51
- if (!storedValue) {
52
- assertDefinedEx(Array.isArray(this.defaults[name]), "Default value is not array");
53
- const defaultValue = this.defaults[name];
54
- assertEx(defaultValue !== void 0, `Missing Default for ${name}`);
55
- return defaultValue;
56
- }
57
- return storedValue;
58
- }
59
- setBoolean(name, value) {
60
- localStorage.setItem(`${this.prefix}|${name}`, JSON.stringify(value));
61
- }
62
- setNumber(name, value) {
63
- localStorage.setItem(`${this.prefix}|${name}`, JSON.stringify(value));
64
- }
65
- setObject(name, value) {
66
- localStorage.setItem(`${this.prefix}|${name}`, JSON.stringify(value));
67
- }
68
- setString(name, value) {
69
- localStorage.setItem(`${this.prefix}|${name}`, value);
70
- }
71
- setStringArray(name, value) {
72
- localStorage.setItem(`${this.prefix}|${name}`, value.join(","));
73
- }
74
- }
75
- export {
76
- AppSettingsStorageBase
77
- };
78
- //# sourceMappingURL=StorageBase.mjs.map
@@ -1,15 +0,0 @@
1
- import { AppSettingSlug } from "./Slug";
2
- const appSettingDefault = () => {
3
- return {
4
- [AppSettingSlug.DarkMode]: false,
5
- [AppSettingSlug.Developer]: false,
6
- [AppSettingSlug.NavigationType]: "menu",
7
- [AppSettingSlug.NavigationCollapsed]: false,
8
- [AppSettingSlug.SeedPhrase]: "",
9
- [AppSettingSlug.MaxAccounts]: 1
10
- };
11
- };
12
- export {
13
- appSettingDefault
14
- };
15
- //# sourceMappingURL=appSettingDefault.mjs.map
@@ -1,7 +0,0 @@
1
- export * from "./Context";
2
- export * from "./Provider";
3
- export * from "./Slug";
4
- export * from "./Storage";
5
- export * from "./StorageBase";
6
- export * from "./useAppSettings";
7
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../../src/contexts/AppSettings/index.ts"],"sourcesContent":["export * from './Context'\nexport * from './Provider'\nexport * from './Slug'\nexport * from './Storage'\nexport * from './StorageBase'\nexport * from './useAppSettings'\n"],"mappings":"AAAA,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;AACd,cAAc;","names":[]}
@@ -1,9 +0,0 @@
1
- import { useContext } from "react";
2
- import { AppSettingsContext } from "./Context";
3
- const useAppSettings = () => {
4
- return useContext(AppSettingsContext);
5
- };
6
- export {
7
- useAppSettings
8
- };
9
- //# sourceMappingURL=useAppSettings.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../../src/contexts/AppSettings/useAppSettings.ts"],"sourcesContent":["import { useContext } from 'react'\n\nimport { AppSettingsContext } from './Context'\n\nexport const useAppSettings = () => {\n return useContext(AppSettingsContext)\n}\n"],"mappings":"AAAA,SAAS,kBAAkB;AAE3B,SAAS,0BAA0B;AAE5B,MAAM,iBAAiB,MAAM;AAClC,SAAO,WAAW,kBAAkB;AACtC;","names":[]}
@@ -1,2 +0,0 @@
1
- export * from "./AppSettings";
2
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../src/contexts/index.ts"],"sourcesContent":["export * from './AppSettings'\n"],"mappings":"AAAA,cAAc;","names":[]}
@@ -1,4 +0,0 @@
1
- export * from "./components";
2
- export * from "./contexts";
3
- export * from "./WebAppNavigationType";
4
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/index.ts"],"sourcesContent":["export * from './components'\nexport * from './contexts'\nexport * from './WebAppNavigationType'\n"],"mappings":"AAAA,cAAc;AACd,cAAc;AACd,cAAc;","names":[]}