bananas-commerce-admin 0.1.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 (188) hide show
  1. package/README.md +25 -0
  2. package/dist/cjs/Admin.js +47 -0
  3. package/dist/cjs/App.js +49 -0
  4. package/dist/cjs/api.js +225 -0
  5. package/dist/cjs/components/Branding.js +41 -0
  6. package/dist/cjs/components/Hamburger.js +40 -0
  7. package/dist/cjs/components/Link.js +21 -0
  8. package/dist/cjs/components/Logo.js +25 -0
  9. package/dist/cjs/components/NavBar.js +101 -0
  10. package/dist/cjs/components/NavBarItem.js +42 -0
  11. package/dist/cjs/components/NavBarRoutes.js +47 -0
  12. package/dist/cjs/components/ProgressBar.js +14 -0
  13. package/dist/cjs/components/User.js +71 -0
  14. package/dist/cjs/containers/Content.js +16 -0
  15. package/dist/cjs/containers/ErrorScreen.js +35 -0
  16. package/dist/cjs/containers/LoadingScreen.js +84 -0
  17. package/dist/cjs/containers/PageErrorBoundary.js +43 -0
  18. package/dist/cjs/containers/PageLoader.js +123 -0
  19. package/dist/cjs/contexts/ApiContext.js +105 -0
  20. package/dist/cjs/contexts/I18nContext.js +109 -0
  21. package/dist/cjs/contexts/RouterContext.js +99 -0
  22. package/dist/cjs/contexts/UserContext.js +144 -0
  23. package/dist/cjs/extensions/bananas/components/PasswordChangeForm.js +85 -0
  24. package/dist/cjs/extensions/bananas/index.js +54 -0
  25. package/dist/cjs/extensions/bananas/pages/me/list.js +20 -0
  26. package/dist/cjs/extensions/pos/components/PurchaseRow.js +32 -0
  27. package/dist/cjs/extensions/pos/components/ReceiptCard.js +86 -0
  28. package/dist/cjs/extensions/pos/components/ReceiptLine.js +29 -0
  29. package/dist/cjs/extensions/pos/index.js +22 -0
  30. package/dist/cjs/extensions/pos/pages/purchase/detail.js +13 -0
  31. package/dist/cjs/extensions/pos/pages/purchase/list.js +34 -0
  32. package/dist/cjs/extensions/pos/types/purchase.js +2 -0
  33. package/dist/cjs/extensions/pos/types/receipt.js +2 -0
  34. package/dist/cjs/forms/LoginForm.js +63 -0
  35. package/dist/cjs/hooks/useAsyncError.js +15 -0
  36. package/dist/cjs/hooks/useLocalStorage.js +47 -0
  37. package/dist/cjs/index.js +40 -0
  38. package/dist/cjs/pages/DashboardPage.js +10 -0
  39. package/dist/cjs/pages/LoginPage.js +31 -0
  40. package/dist/cjs/router/Router.js +35 -0
  41. package/dist/cjs/router/routes.js +57 -0
  42. package/dist/cjs/types/index.js +2 -0
  43. package/dist/cjs/util/get_cookie.js +10 -0
  44. package/dist/cjs/util/index.js +62 -0
  45. package/dist/cjs/util/select_styles.js +38 -0
  46. package/dist/esm/Admin.js +42 -0
  47. package/dist/esm/App.js +44 -0
  48. package/dist/esm/api.js +219 -0
  49. package/dist/esm/components/Branding.js +36 -0
  50. package/dist/esm/components/Hamburger.js +35 -0
  51. package/dist/esm/components/Link.js +16 -0
  52. package/dist/esm/components/Logo.js +20 -0
  53. package/dist/esm/components/NavBar.js +73 -0
  54. package/dist/esm/components/NavBarItem.js +37 -0
  55. package/dist/esm/components/NavBarRoutes.js +42 -0
  56. package/dist/esm/components/ProgressBar.js +9 -0
  57. package/dist/esm/components/User.js +66 -0
  58. package/dist/esm/containers/Content.js +11 -0
  59. package/dist/esm/containers/ErrorScreen.js +30 -0
  60. package/dist/esm/containers/LoadingScreen.js +79 -0
  61. package/dist/esm/containers/PageErrorBoundary.js +38 -0
  62. package/dist/esm/containers/PageLoader.js +117 -0
  63. package/dist/esm/contexts/ApiContext.js +77 -0
  64. package/dist/esm/contexts/I18nContext.js +77 -0
  65. package/dist/esm/contexts/RouterContext.js +71 -0
  66. package/dist/esm/contexts/UserContext.js +113 -0
  67. package/dist/esm/extensions/bananas/components/PasswordChangeForm.js +80 -0
  68. package/dist/esm/extensions/bananas/index.js +48 -0
  69. package/dist/esm/extensions/bananas/pages/me/list.js +15 -0
  70. package/dist/esm/extensions/pos/components/PurchaseRow.js +25 -0
  71. package/dist/esm/extensions/pos/components/ReceiptCard.js +56 -0
  72. package/dist/esm/extensions/pos/components/ReceiptLine.js +22 -0
  73. package/dist/esm/extensions/pos/index.js +16 -0
  74. package/dist/esm/extensions/pos/pages/purchase/detail.js +8 -0
  75. package/dist/esm/extensions/pos/pages/purchase/list.js +29 -0
  76. package/dist/esm/extensions/pos/types/purchase.js +1 -0
  77. package/dist/esm/extensions/pos/types/receipt.js +1 -0
  78. package/dist/esm/forms/LoginForm.js +58 -0
  79. package/dist/esm/hooks/useAsyncError.js +9 -0
  80. package/dist/esm/hooks/useLocalStorage.js +41 -0
  81. package/dist/esm/index.js +14 -0
  82. package/dist/esm/pages/DashboardPage.js +5 -0
  83. package/dist/esm/pages/LoginPage.js +26 -0
  84. package/dist/esm/router/Router.js +28 -0
  85. package/dist/esm/router/routes.js +49 -0
  86. package/dist/esm/types/index.js +1 -0
  87. package/dist/esm/util/get_cookie.js +6 -0
  88. package/dist/esm/util/index.js +54 -0
  89. package/dist/esm/util/select_styles.js +34 -0
  90. package/dist/types/Admin.d.ts +13 -0
  91. package/dist/types/App.d.ts +13 -0
  92. package/dist/types/api.d.ts +20 -0
  93. package/dist/types/components/Branding.d.ts +14 -0
  94. package/dist/types/components/Hamburger.d.ts +8 -0
  95. package/dist/types/components/Link.d.ts +9 -0
  96. package/dist/types/components/Logo.d.ts +7 -0
  97. package/dist/types/components/NavBar.d.ts +11 -0
  98. package/dist/types/components/NavBarItem.d.ts +12 -0
  99. package/dist/types/components/NavBarRoutes.d.ts +7 -0
  100. package/dist/types/components/ProgressBar.d.ts +7 -0
  101. package/dist/types/components/User.d.ts +824 -0
  102. package/dist/types/containers/Content.d.ts +3 -0
  103. package/dist/types/containers/ErrorScreen.d.ts +7 -0
  104. package/dist/types/containers/LoadingScreen.d.ts +50 -0
  105. package/dist/types/containers/PageErrorBoundary.d.ts +16 -0
  106. package/dist/types/containers/PageLoader.d.ts +13 -0
  107. package/dist/types/contexts/ApiContext.d.ts +12 -0
  108. package/dist/types/contexts/I18nContext.d.ts +10 -0
  109. package/dist/types/contexts/RouterContext.d.ts +24 -0
  110. package/dist/types/contexts/UserContext.d.ts +20 -0
  111. package/dist/types/extensions/bananas/components/PasswordChangeForm.d.ts +3 -0
  112. package/dist/types/extensions/bananas/index.d.ts +2 -0
  113. package/dist/types/extensions/bananas/pages/me/list.d.ts +6 -0
  114. package/dist/types/extensions/pos/components/PurchaseRow.d.ts +7 -0
  115. package/dist/types/extensions/pos/components/ReceiptCard.d.ts +7 -0
  116. package/dist/types/extensions/pos/components/ReceiptLine.d.ts +7 -0
  117. package/dist/types/extensions/pos/index.d.ts +2 -0
  118. package/dist/types/extensions/pos/pages/purchase/detail.d.ts +7 -0
  119. package/dist/types/extensions/pos/pages/purchase/list.d.ts +9 -0
  120. package/dist/types/extensions/pos/types/purchase.d.ts +18 -0
  121. package/dist/types/extensions/pos/types/receipt.d.ts +34 -0
  122. package/dist/types/forms/LoginForm.d.ts +3 -0
  123. package/dist/types/hooks/useAsyncError.d.ts +1 -0
  124. package/dist/types/hooks/useLocalStorage.d.ts +2 -0
  125. package/dist/types/index.d.ts +14 -0
  126. package/dist/types/pages/DashboardPage.d.ts +5 -0
  127. package/dist/types/pages/LoginPage.d.ts +9 -0
  128. package/dist/types/router/Router.d.ts +13 -0
  129. package/dist/types/router/routes.d.ts +20 -0
  130. package/dist/types/types/index.d.ts +6 -0
  131. package/dist/types/util/get_cookie.d.ts +1 -0
  132. package/dist/types/util/index.d.ts +8 -0
  133. package/dist/types/util/select_styles.d.ts +3 -0
  134. package/example/Dockerfile +27 -0
  135. package/example/docker-compose.yml +7 -0
  136. package/example/index.html +13 -0
  137. package/example/index.tsx +21 -0
  138. package/example/package-lock.json +13167 -0
  139. package/example/package.json +52 -0
  140. package/example/pages/.gitkeep +0 -0
  141. package/example/webpack.config.js +67 -0
  142. package/package.json +52 -0
  143. package/src/Admin.tsx +94 -0
  144. package/src/App.tsx +43 -0
  145. package/src/api.ts +202 -0
  146. package/src/components/Branding.tsx +79 -0
  147. package/src/components/Hamburger.tsx +41 -0
  148. package/src/components/Link.tsx +23 -0
  149. package/src/components/Logo.tsx +57 -0
  150. package/src/components/NavBar.tsx +115 -0
  151. package/src/components/NavBarItem.tsx +73 -0
  152. package/src/components/NavBarRoutes.tsx +67 -0
  153. package/src/components/ProgressBar.tsx +30 -0
  154. package/src/components/User.tsx +97 -0
  155. package/src/containers/Content.tsx +18 -0
  156. package/src/containers/ErrorScreen.tsx +64 -0
  157. package/src/containers/LoadingScreen.tsx +135 -0
  158. package/src/containers/PageErrorBoundary.tsx +32 -0
  159. package/src/containers/PageLoader.tsx +64 -0
  160. package/src/contexts/ApiContext.tsx +55 -0
  161. package/src/contexts/I18nContext.tsx +55 -0
  162. package/src/contexts/RouterContext.tsx +127 -0
  163. package/src/contexts/UserContext.tsx +99 -0
  164. package/src/extensions/bananas/components/PasswordChangeForm.tsx +138 -0
  165. package/src/extensions/bananas/index.ts +14 -0
  166. package/src/extensions/bananas/pages/me/list.tsx +31 -0
  167. package/src/extensions/pos/components/PurchaseRow.tsx +42 -0
  168. package/src/extensions/pos/components/ReceiptCard.tsx +101 -0
  169. package/src/extensions/pos/components/ReceiptLine.tsx +51 -0
  170. package/src/extensions/pos/index.tsx +20 -0
  171. package/src/extensions/pos/pages/purchase/detail.tsx +22 -0
  172. package/src/extensions/pos/pages/purchase/list.tsx +56 -0
  173. package/src/extensions/pos/types/purchase.ts +20 -0
  174. package/src/extensions/pos/types/receipt.ts +36 -0
  175. package/src/forms/LoginForm.tsx +99 -0
  176. package/src/hooks/useAsyncError.ts +13 -0
  177. package/src/hooks/useLocalStorage.ts +42 -0
  178. package/src/index.ts +18 -0
  179. package/src/pages/DashboardPage.tsx +9 -0
  180. package/src/pages/LoginPage.tsx +50 -0
  181. package/src/router/Router.tsx +63 -0
  182. package/src/router/routes.ts +67 -0
  183. package/src/types/index.ts +4 -0
  184. package/src/types/swagger-client.d.ts +1 -0
  185. package/src/util/get_cookie.ts +6 -0
  186. package/src/util/index.ts +63 -0
  187. package/src/util/select_styles.ts +29 -0
  188. package/tsconfig.json +38 -0
@@ -0,0 +1,63 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ var notistack_1 = require("notistack");
7
+ var react_1 = __importDefault(require("react"));
8
+ var Box_1 = __importDefault(require("@mui/material/Box"));
9
+ var DialogActions_1 = __importDefault(require("@mui/material/DialogActions"));
10
+ var DialogContent_1 = __importDefault(require("@mui/material/DialogContent"));
11
+ var Stack_1 = __importDefault(require("@mui/material/Stack"));
12
+ var styles_1 = require("@mui/material/styles");
13
+ var TextField_1 = __importDefault(require("@mui/material/TextField"));
14
+ var ApiContext_1 = require("../contexts/ApiContext");
15
+ var I18nContext_1 = require("../contexts/I18nContext");
16
+ var UserContext_1 = require("../contexts/UserContext");
17
+ var LoadingButton_1 = __importDefault(require("@mui/lab/LoadingButton"));
18
+ var LoginForm = function () {
19
+ var theme = (0, styles_1.useTheme)();
20
+ var enqueueSnackbar = (0, notistack_1.useSnackbar)().enqueueSnackbar;
21
+ var t = (0, I18nContext_1.useI18n)().t;
22
+ var login = (0, UserContext_1.useUser)().login;
23
+ var api = (0, ApiContext_1.useApi)();
24
+ var _a = react_1.default.useState(""), username = _a[0], setUsername = _a[1];
25
+ var _b = react_1.default.useState(""), password = _b[0], setPassword = _b[1];
26
+ var _c = react_1.default.useState(false), loading = _c[0], setLoading = _c[1];
27
+ var operation = api.operations["bananas.login:create"];
28
+ var properties = operation.request.body.schema.properties;
29
+ var handleSubmit = function (event) {
30
+ event.preventDefault();
31
+ setLoading(true);
32
+ login(username, password).then(function (user) {
33
+ if (user !== null) {
34
+ enqueueSnackbar("".concat(t("Welcome,"), " ").concat(user.full_name), {
35
+ variant: "success",
36
+ });
37
+ }
38
+ else {
39
+ enqueueSnackbar(t("Unable to log in with provided credentials."), {
40
+ variant: "error",
41
+ });
42
+ }
43
+ }).finally(function () { return setLoading(false); });
44
+ };
45
+ return (react_1.default.createElement(Box_1.default, { component: "form", onSubmit: handleSubmit },
46
+ react_1.default.createElement(DialogContent_1.default, null,
47
+ react_1.default.createElement(Stack_1.default, { spacing: 1 },
48
+ react_1.default.createElement(TextField_1.default, { autoFocus: true, fullWidth: true, label: properties.username.title, name: "username", type: "text", onChange: function (e) {
49
+ setUsername(e.target.value);
50
+ }, color: "secondary", inputProps: { "aria-label": "Username" } }),
51
+ react_1.default.createElement(TextField_1.default, { fullWidth: true, label: properties.password.title, name: "password", type: "password", onChange: function (e) {
52
+ setPassword(e.target.value);
53
+ }, color: "secondary", inputProps: { "aria-label": "Password" } }))),
54
+ react_1.default.createElement(DialogActions_1.default, { sx: {
55
+ borderTop: "1px solid ".concat(theme.palette.divider),
56
+ margin: 0,
57
+ padding: theme.spacing(1),
58
+ } },
59
+ react_1.default.createElement(LoadingButton_1.default, { sx: {
60
+ margin: "auto",
61
+ }, variant: "contained", type: "submit", color: "secondary", "aria-label": "login", loading: loading }, t("Log in")))));
62
+ };
63
+ exports.default = LoginForm;
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ var react_1 = __importDefault(require("react"));
7
+ function useAsyncError() {
8
+ var _a = react_1.default.useState(), _ = _a[0], setError = _a[1];
9
+ return react_1.default.useCallback(function (e) {
10
+ setError(function () {
11
+ throw e;
12
+ });
13
+ }, [setError]);
14
+ }
15
+ exports.default = useAsyncError;
@@ -0,0 +1,47 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ var react_1 = __importDefault(require("react"));
7
+ function useLocalStorage(key, defaultValue) {
8
+ var _a;
9
+ var _b = react_1.default.useState((_a = getState(key)) !== null && _a !== void 0 ? _a : defaultValue), state = _b[0], setState = _b[1];
10
+ var _c = react_1.default.useState(false), mounted = _c[0], setMounted = _c[1];
11
+ react_1.default.useEffect(function () {
12
+ if (mounted)
13
+ return;
14
+ // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
15
+ if (localStorage) {
16
+ var value = getState(key);
17
+ if (value)
18
+ setState(value);
19
+ setMounted(true);
20
+ }
21
+ }, [key, mounted]);
22
+ react_1.default.useEffect(function () {
23
+ if (mounted)
24
+ setLocalState(key, state);
25
+ }, [state, key, mounted]);
26
+ return [state, setState];
27
+ }
28
+ exports.default = useLocalStorage;
29
+ function getState(key) {
30
+ return tryJSONParse(localStorage.getItem(buildStorageKey(key)));
31
+ }
32
+ function setLocalState(key, state) {
33
+ localStorage.setItem(buildStorageKey(key), JSON.stringify(state));
34
+ }
35
+ function buildStorageKey(key) {
36
+ return "__useLocalStorage_".concat(key);
37
+ }
38
+ function tryJSONParse(json) {
39
+ if (!json)
40
+ return null;
41
+ try {
42
+ return JSON.parse(json);
43
+ }
44
+ catch (e) {
45
+ return null;
46
+ }
47
+ }
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ var __importDefault = (this && this.__importDefault) || function (mod) {
17
+ return (mod && mod.__esModule) ? mod : { "default": mod };
18
+ };
19
+ Object.defineProperty(exports, "__esModule", { value: true });
20
+ exports.App = exports.Admin = exports.Link = exports.Logo = exports.Content = exports.ProgressBar = void 0;
21
+ var ProgressBar_1 = require("./components/ProgressBar");
22
+ Object.defineProperty(exports, "ProgressBar", { enumerable: true, get: function () { return __importDefault(ProgressBar_1).default; } });
23
+ var Content_1 = require("./containers/Content");
24
+ Object.defineProperty(exports, "Content", { enumerable: true, get: function () { return __importDefault(Content_1).default; } });
25
+ var Logo_1 = require("./components/Logo");
26
+ Object.defineProperty(exports, "Logo", { enumerable: true, get: function () { return __importDefault(Logo_1).default; } });
27
+ var Link_1 = require("./components/Link");
28
+ Object.defineProperty(exports, "Link", { enumerable: true, get: function () { return __importDefault(Link_1).default; } });
29
+ __exportStar(require("./contexts/ApiContext"), exports);
30
+ __exportStar(require("./contexts/I18nContext"), exports);
31
+ __exportStar(require("./contexts/RouterContext"), exports);
32
+ __exportStar(require("./contexts/UserContext"), exports);
33
+ __exportStar(require("./containers/LoadingScreen"), exports);
34
+ var Admin_1 = require("./Admin");
35
+ Object.defineProperty(exports, "Admin", { enumerable: true, get: function () { return __importDefault(Admin_1).default; } });
36
+ var App_1 = require("./App");
37
+ Object.defineProperty(exports, "App", { enumerable: true, get: function () { return __importDefault(App_1).default; } });
38
+ __exportStar(require("./api"), exports);
39
+ __exportStar(require("./extensions/bananas"), exports);
40
+ __exportStar(require("./extensions/pos"), exports);
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ var react_1 = __importDefault(require("react"));
7
+ var DashboardPage = function (_a) {
8
+ return react_1.default.createElement("h1", null, "Dashboard!");
9
+ };
10
+ exports.default = DashboardPage;
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ var react_1 = __importDefault(require("react"));
7
+ var material_1 = require("@mui/material");
8
+ var styles_1 = require("@mui/material/styles");
9
+ var LoginForm_1 = __importDefault(require("../forms/LoginForm"));
10
+ var Logo_1 = __importDefault(require("../components/Logo"));
11
+ var LoginPage = function (_a) {
12
+ var title = _a.title, logo = _a.logo, Form = _a.form;
13
+ var theme = (0, styles_1.useTheme)();
14
+ Form !== null && Form !== void 0 ? Form : (Form = LoginForm_1.default);
15
+ return (react_1.default.createElement(material_1.Dialog, { open: true, sx: { "> * > *": { width: "100%" } } },
16
+ react_1.default.createElement(material_1.DialogTitle, { sx: {
17
+ borderBottom: "1px solid ".concat(theme.palette.divider),
18
+ margin: 0,
19
+ backgroundColor: theme.palette.primary.main,
20
+ padding: theme.spacing(2),
21
+ textAlign: "center",
22
+ alignItems: "middle",
23
+ justifyContent: "center",
24
+ display: "flex",
25
+ } }, logo ? react_1.default.createElement(Logo_1.default, { src: logo }) : (react_1.default.createElement(material_1.Typography, { sx: {
26
+ color: theme.palette.primary.contrastText,
27
+ fontWeight: "bold",
28
+ } }, title))),
29
+ react_1.default.createElement(Form, null)));
30
+ };
31
+ exports.default = LoginPage;
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.Router = void 0;
7
+ var Box_1 = __importDefault(require("@mui/material/Box"));
8
+ var react_1 = __importDefault(require("react"));
9
+ var react_router_dom_1 = require("react-router-dom");
10
+ var RouterContext_1 = require("../contexts/RouterContext");
11
+ var DashboardPage_1 = __importDefault(require("../pages/DashboardPage"));
12
+ var PageLoader_1 = __importDefault(require("../containers/PageLoader"));
13
+ var PageErrorBoundary_1 = __importDefault(require("../containers/PageErrorBoundary"));
14
+ var ErrorScreen_1 = __importDefault(require("../containers/ErrorScreen"));
15
+ var Router = function (_a) {
16
+ var dashboard = _a.dashboard, extensions = _a.extensions, pages = _a.pages;
17
+ extensions !== null && extensions !== void 0 ? extensions : (extensions = Array.isArray(extensions) ? extensions : []);
18
+ var routes = (0, RouterContext_1.useRouter)().routes;
19
+ var Dashboard = dashboard !== null && dashboard !== void 0 ? dashboard : DashboardPage_1.default;
20
+ var extensionsMap = new Map(extensions.map(function (_a) {
21
+ var app = _a.app, pages = _a.pages;
22
+ return [app, pages];
23
+ }));
24
+ var pageRoutes = routes.map(function (route) {
25
+ var pageLoader = extensionsMap.get(route.app);
26
+ var Element = function () { return (react_1.default.createElement(PageErrorBoundary_1.default, { errorPage: ErrorScreen_1.default },
27
+ react_1.default.createElement(PageLoader_1.default, { route: route, page: pageLoader(route) }))); };
28
+ return (react_1.default.createElement(react_router_dom_1.Route, { key: route.path, path: route.path, element: react_1.default.createElement(Element, null) }));
29
+ });
30
+ return (react_1.default.createElement(Box_1.default, { component: "main", sx: { flexGrow: 1, p: 3 } },
31
+ react_1.default.createElement(react_router_dom_1.Routes, null,
32
+ react_1.default.createElement(react_router_dom_1.Route, { index: true, element: react_1.default.createElement(Dashboard, null) }),
33
+ pageRoutes)));
34
+ };
35
+ exports.Router = Router;
@@ -0,0 +1,57 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getTitle = exports.getPage = exports.getPath = exports.isNavigation = exports.parseOperationId = void 0;
4
+ var util_1 = require("../util");
5
+ /**
6
+ * Parses an `operationId` returning app, view and action
7
+ *
8
+ * ## Examples
9
+ *
10
+ * `bananas.me:list` -> `{ app: "bananas", view: "me", action: "list" }`
11
+ *
12
+ * `bananas.login:create` -> `{ app: "bananas", view: "login", action: "create" }`
13
+ *
14
+ * `bananas.i18n:list` -> `{ app: "bananas", view: "i18n", action: "list" }`
15
+ */
16
+ function parseOperationId(operationId) {
17
+ var match = operationId.match(/^(\w+)\.(\w+):(\w+)$/);
18
+ if (match !== null) {
19
+ return {
20
+ app: match[1],
21
+ view: match[2],
22
+ action: match[3],
23
+ };
24
+ }
25
+ return undefined;
26
+ }
27
+ exports.parseOperationId = parseOperationId;
28
+ function isNavigation(tags) {
29
+ return tags.includes("navigation");
30
+ }
31
+ exports.isNavigation = isNavigation;
32
+ function getPath(endpoint, method, action) {
33
+ return (method.toLowerCase() === "get"
34
+ ? endpoint
35
+ : "".concat(endpoint).concat(action !== null && action !== void 0 ? action : "", "/")).replace(/{([^}]*)}/, ":$1");
36
+ }
37
+ exports.getPath = getPath;
38
+ function getBasePath(path) {
39
+ return path.substring(0, ((0, util_1.nthIndexOf)(path, "/", 2, 1) + 1) || undefined);
40
+ }
41
+ function getPage(path, action) {
42
+ var basePath = getBasePath(path);
43
+ var relativeBasePath = basePath.slice(1);
44
+ return "".concat(relativeBasePath).concat(action);
45
+ }
46
+ exports.getPage = getPage;
47
+ function getAppLabel(tags) {
48
+ var _a;
49
+ return (_a = tags.filter(function (tag) { return tag.startsWith("app:"); })[0]) === null || _a === void 0 ? void 0 : _a.split(":")[1];
50
+ }
51
+ function getView(id) {
52
+ return id.substring(id.indexOf(".") + 1, id.indexOf(":"));
53
+ }
54
+ function getTitle(view, summary) {
55
+ return (summary !== null && summary !== void 0 ? summary : (view && (0, util_1.capitalize)(view.replace("_", " "))));
56
+ }
57
+ exports.getTitle = getTitle;
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getCookie = void 0;
4
+ function getCookie(name) {
5
+ var prefix = "".concat(name, "=");
6
+ var cookies = document.cookie.split(/\s*;\s*/);
7
+ var match = cookies.find(function (cookie) { return cookie.startsWith(prefix); });
8
+ return match == null ? undefined : match.slice(prefix.length);
9
+ }
10
+ exports.getCookie = getCookie;
@@ -0,0 +1,62 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.capitalize = exports.nthIndexOf = exports.absolutePath = exports.ensureLeadingHash = exports.ensureTrailingSlash = void 0;
4
+ function ensureTrailingSlash(path) {
5
+ if (path != null && !path.endsWith("/")) {
6
+ return "".concat(path, "/");
7
+ }
8
+ return path;
9
+ }
10
+ exports.ensureTrailingSlash = ensureTrailingSlash;
11
+ function ensureLeadingHash(hash) {
12
+ if (hash != null && !hash.startsWith("#")) {
13
+ return "#".concat(hash);
14
+ }
15
+ return hash;
16
+ }
17
+ exports.ensureLeadingHash = ensureLeadingHash;
18
+ function absolutePath(path, basename) {
19
+ if (basename === void 0) { basename = "/"; }
20
+ if (!path) {
21
+ return path;
22
+ }
23
+ var pathname = path;
24
+ // Make relative path absolute to basename
25
+ if (!pathname.startsWith("/")) {
26
+ pathname = ensureTrailingSlash(basename) + pathname;
27
+ }
28
+ // Expand path
29
+ if (pathname.indexOf(".") >= 0) {
30
+ var stack = [];
31
+ for (var _i = 0, _a = pathname.split("/"); _i < _a.length; _i++) {
32
+ var part = _a[_i];
33
+ if (part === ".") {
34
+ continue;
35
+ }
36
+ else if (part === ".." && stack.length > 0) {
37
+ stack.pop();
38
+ }
39
+ else {
40
+ stack.push(part);
41
+ }
42
+ }
43
+ pathname = stack.join("/");
44
+ }
45
+ return ensureTrailingSlash(pathname);
46
+ }
47
+ exports.absolutePath = absolutePath;
48
+ function nthIndexOf(str, pattern, n, start) {
49
+ var index = str.indexOf(pattern, start !== null && start !== void 0 ? start : 0);
50
+ if (index >= 0 && n > 1) {
51
+ return nthIndexOf(str, pattern, n - 1, index + 1);
52
+ }
53
+ return index;
54
+ }
55
+ exports.nthIndexOf = nthIndexOf;
56
+ /**
57
+ * Like Python’s `.capitalize()`.
58
+ */
59
+ function capitalize(string) {
60
+ return string.slice(0, 1).toUpperCase() + string.slice(1).toLowerCase();
61
+ }
62
+ exports.capitalize = capitalize;
@@ -0,0 +1,38 @@
1
+ "use strict";
2
+ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
3
+ if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
4
+ if (ar || !(i in from)) {
5
+ if (!ar) ar = Array.prototype.slice.call(from, 0, i);
6
+ ar[i] = from[i];
7
+ }
8
+ }
9
+ return to.concat(ar || Array.prototype.slice.call(from));
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.ss = exports.selectStyles = void 0;
13
+ function selectStyles() {
14
+ var sxs = [];
15
+ for (var _i = 0; _i < arguments.length; _i++) {
16
+ sxs[_i] = arguments[_i];
17
+ }
18
+ var final = [];
19
+ for (var _a = 0, sxs_1 = sxs; _a < sxs_1.length; _a++) {
20
+ var sx = sxs_1[_a];
21
+ if (Array.isArray(sx)) {
22
+ if (sx.filter(function (v) { return typeof v === "boolean"; })
23
+ .every(function (v) { return v; })) {
24
+ // If every entry is true
25
+ final.concat(sx.filter(function (v) {
26
+ return typeof v !== "boolean";
27
+ }));
28
+ }
29
+ }
30
+ else if (sx !== undefined) {
31
+ final.push(sx);
32
+ }
33
+ }
34
+ return Object.assign.apply(Object, __spreadArray([{}], final.reverse(), false));
35
+ }
36
+ exports.selectStyles = selectStyles;
37
+ // Shorthand for select styles helper
38
+ exports.ss = selectStyles;
@@ -0,0 +1,42 @@
1
+ import React from "react";
2
+ import { BrowserRouter } from "react-router-dom";
3
+ import Box from "@mui/material/Box";
4
+ import NavBar from "./components/NavBar";
5
+ import LoadingScreen from "./containers/LoadingScreen";
6
+ import { useApi } from "./contexts/ApiContext";
7
+ import { useI18n } from "./contexts/I18nContext";
8
+ import { RouterContextProvider } from "./contexts/RouterContext";
9
+ import { useUser } from "./contexts/UserContext";
10
+ import LoginPage from "./pages/LoginPage";
11
+ import { Router } from "./router/Router";
12
+ var Admin = function (_a) {
13
+ var logo = _a.logo, title = _a.title, subtitle = _a.subtitle, version = _a.version, nav = _a.nav, pages = _a.pages, extensions = _a.extensions, dashboard = _a.dashboard, basename = _a.basename;
14
+ var _b = React.useState(false), loaded = _b[0], setLoaded = _b[1];
15
+ var api = useApi();
16
+ var i18n = useI18n();
17
+ var user = useUser().user;
18
+ React.useEffect(function () {
19
+ if (!loaded && api !== undefined && i18n !== undefined && user !== undefined) {
20
+ setLoaded(true);
21
+ }
22
+ }, [loaded, api, i18n, user]);
23
+ return (React.createElement(React.Fragment, null,
24
+ React.createElement(Box, { sx: {
25
+ display: "flex",
26
+ position: "fixed",
27
+ top: 0,
28
+ left: 0,
29
+ width: "100%",
30
+ height: "100%",
31
+ flexDirection: "column",
32
+ } }, loaded
33
+ ? user !== null
34
+ ? (React.createElement(BrowserRouter, { basename: basename },
35
+ React.createElement(RouterContextProvider, null,
36
+ React.createElement(Box, { sx: { display: "flex" } },
37
+ React.createElement(NavBar, { nav: nav, logo: logo, title: title, subtitle: subtitle, version: version }),
38
+ React.createElement(Router, { pages: pages, extensions: extensions, dashboard: dashboard })))))
39
+ : React.createElement(LoginPage, { logo: logo, title: title })
40
+ : React.createElement(LoadingScreen, { logo: logo, loading: !loaded }))));
41
+ };
42
+ export default Admin;
@@ -0,0 +1,44 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ var __rest = (this && this.__rest) || function (s, e) {
13
+ var t = {};
14
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
15
+ t[p] = s[p];
16
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
17
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
18
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
19
+ t[p[i]] = s[p[i]];
20
+ }
21
+ return t;
22
+ };
23
+ import React from "react";
24
+ import CssBaseline from "@mui/material/CssBaseline";
25
+ import { createTheme, ThemeProvider } from "@mui/material/styles";
26
+ import Admin from "./Admin";
27
+ import { ApiContextProvider } from "./contexts/ApiContext";
28
+ import { UserContextProvider } from "./contexts/UserContext";
29
+ import { I18nContextProvider } from "./contexts/I18nContext";
30
+ import { SnackbarProvider } from "notistack";
31
+ var App = function (_a) {
32
+ var theme = _a.theme, api = _a.api, rest = __rest(_a, ["theme", "api"]);
33
+ return (React.createElement(ThemeProvider, { theme: theme !== null && theme !== void 0 ? theme : createTheme() },
34
+ React.createElement(CssBaseline, null),
35
+ React.createElement(SnackbarProvider, { maxSnack: 4, anchorOrigin: {
36
+ vertical: "bottom",
37
+ horizontal: "right",
38
+ } },
39
+ React.createElement(ApiContextProvider, { api: api },
40
+ React.createElement(I18nContextProvider, null,
41
+ React.createElement(UserContextProvider, null,
42
+ React.createElement(Admin, __assign({}, rest))))))));
43
+ };
44
+ export default App;