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.
- package/README.md +25 -0
- package/dist/cjs/Admin.js +47 -0
- package/dist/cjs/App.js +49 -0
- package/dist/cjs/api.js +225 -0
- package/dist/cjs/components/Branding.js +41 -0
- package/dist/cjs/components/Hamburger.js +40 -0
- package/dist/cjs/components/Link.js +21 -0
- package/dist/cjs/components/Logo.js +25 -0
- package/dist/cjs/components/NavBar.js +101 -0
- package/dist/cjs/components/NavBarItem.js +42 -0
- package/dist/cjs/components/NavBarRoutes.js +47 -0
- package/dist/cjs/components/ProgressBar.js +14 -0
- package/dist/cjs/components/User.js +71 -0
- package/dist/cjs/containers/Content.js +16 -0
- package/dist/cjs/containers/ErrorScreen.js +35 -0
- package/dist/cjs/containers/LoadingScreen.js +84 -0
- package/dist/cjs/containers/PageErrorBoundary.js +43 -0
- package/dist/cjs/containers/PageLoader.js +123 -0
- package/dist/cjs/contexts/ApiContext.js +105 -0
- package/dist/cjs/contexts/I18nContext.js +109 -0
- package/dist/cjs/contexts/RouterContext.js +99 -0
- package/dist/cjs/contexts/UserContext.js +144 -0
- package/dist/cjs/extensions/bananas/components/PasswordChangeForm.js +85 -0
- package/dist/cjs/extensions/bananas/index.js +54 -0
- package/dist/cjs/extensions/bananas/pages/me/list.js +20 -0
- package/dist/cjs/extensions/pos/components/PurchaseRow.js +32 -0
- package/dist/cjs/extensions/pos/components/ReceiptCard.js +86 -0
- package/dist/cjs/extensions/pos/components/ReceiptLine.js +29 -0
- package/dist/cjs/extensions/pos/index.js +22 -0
- package/dist/cjs/extensions/pos/pages/purchase/detail.js +13 -0
- package/dist/cjs/extensions/pos/pages/purchase/list.js +34 -0
- package/dist/cjs/extensions/pos/types/purchase.js +2 -0
- package/dist/cjs/extensions/pos/types/receipt.js +2 -0
- package/dist/cjs/forms/LoginForm.js +63 -0
- package/dist/cjs/hooks/useAsyncError.js +15 -0
- package/dist/cjs/hooks/useLocalStorage.js +47 -0
- package/dist/cjs/index.js +40 -0
- package/dist/cjs/pages/DashboardPage.js +10 -0
- package/dist/cjs/pages/LoginPage.js +31 -0
- package/dist/cjs/router/Router.js +35 -0
- package/dist/cjs/router/routes.js +57 -0
- package/dist/cjs/types/index.js +2 -0
- package/dist/cjs/util/get_cookie.js +10 -0
- package/dist/cjs/util/index.js +62 -0
- package/dist/cjs/util/select_styles.js +38 -0
- package/dist/esm/Admin.js +42 -0
- package/dist/esm/App.js +44 -0
- package/dist/esm/api.js +219 -0
- package/dist/esm/components/Branding.js +36 -0
- package/dist/esm/components/Hamburger.js +35 -0
- package/dist/esm/components/Link.js +16 -0
- package/dist/esm/components/Logo.js +20 -0
- package/dist/esm/components/NavBar.js +73 -0
- package/dist/esm/components/NavBarItem.js +37 -0
- package/dist/esm/components/NavBarRoutes.js +42 -0
- package/dist/esm/components/ProgressBar.js +9 -0
- package/dist/esm/components/User.js +66 -0
- package/dist/esm/containers/Content.js +11 -0
- package/dist/esm/containers/ErrorScreen.js +30 -0
- package/dist/esm/containers/LoadingScreen.js +79 -0
- package/dist/esm/containers/PageErrorBoundary.js +38 -0
- package/dist/esm/containers/PageLoader.js +117 -0
- package/dist/esm/contexts/ApiContext.js +77 -0
- package/dist/esm/contexts/I18nContext.js +77 -0
- package/dist/esm/contexts/RouterContext.js +71 -0
- package/dist/esm/contexts/UserContext.js +113 -0
- package/dist/esm/extensions/bananas/components/PasswordChangeForm.js +80 -0
- package/dist/esm/extensions/bananas/index.js +48 -0
- package/dist/esm/extensions/bananas/pages/me/list.js +15 -0
- package/dist/esm/extensions/pos/components/PurchaseRow.js +25 -0
- package/dist/esm/extensions/pos/components/ReceiptCard.js +56 -0
- package/dist/esm/extensions/pos/components/ReceiptLine.js +22 -0
- package/dist/esm/extensions/pos/index.js +16 -0
- package/dist/esm/extensions/pos/pages/purchase/detail.js +8 -0
- package/dist/esm/extensions/pos/pages/purchase/list.js +29 -0
- package/dist/esm/extensions/pos/types/purchase.js +1 -0
- package/dist/esm/extensions/pos/types/receipt.js +1 -0
- package/dist/esm/forms/LoginForm.js +58 -0
- package/dist/esm/hooks/useAsyncError.js +9 -0
- package/dist/esm/hooks/useLocalStorage.js +41 -0
- package/dist/esm/index.js +14 -0
- package/dist/esm/pages/DashboardPage.js +5 -0
- package/dist/esm/pages/LoginPage.js +26 -0
- package/dist/esm/router/Router.js +28 -0
- package/dist/esm/router/routes.js +49 -0
- package/dist/esm/types/index.js +1 -0
- package/dist/esm/util/get_cookie.js +6 -0
- package/dist/esm/util/index.js +54 -0
- package/dist/esm/util/select_styles.js +34 -0
- package/dist/types/Admin.d.ts +13 -0
- package/dist/types/App.d.ts +13 -0
- package/dist/types/api.d.ts +20 -0
- package/dist/types/components/Branding.d.ts +14 -0
- package/dist/types/components/Hamburger.d.ts +8 -0
- package/dist/types/components/Link.d.ts +9 -0
- package/dist/types/components/Logo.d.ts +7 -0
- package/dist/types/components/NavBar.d.ts +11 -0
- package/dist/types/components/NavBarItem.d.ts +12 -0
- package/dist/types/components/NavBarRoutes.d.ts +7 -0
- package/dist/types/components/ProgressBar.d.ts +7 -0
- package/dist/types/components/User.d.ts +824 -0
- package/dist/types/containers/Content.d.ts +3 -0
- package/dist/types/containers/ErrorScreen.d.ts +7 -0
- package/dist/types/containers/LoadingScreen.d.ts +50 -0
- package/dist/types/containers/PageErrorBoundary.d.ts +16 -0
- package/dist/types/containers/PageLoader.d.ts +13 -0
- package/dist/types/contexts/ApiContext.d.ts +12 -0
- package/dist/types/contexts/I18nContext.d.ts +10 -0
- package/dist/types/contexts/RouterContext.d.ts +24 -0
- package/dist/types/contexts/UserContext.d.ts +20 -0
- package/dist/types/extensions/bananas/components/PasswordChangeForm.d.ts +3 -0
- package/dist/types/extensions/bananas/index.d.ts +2 -0
- package/dist/types/extensions/bananas/pages/me/list.d.ts +6 -0
- package/dist/types/extensions/pos/components/PurchaseRow.d.ts +7 -0
- package/dist/types/extensions/pos/components/ReceiptCard.d.ts +7 -0
- package/dist/types/extensions/pos/components/ReceiptLine.d.ts +7 -0
- package/dist/types/extensions/pos/index.d.ts +2 -0
- package/dist/types/extensions/pos/pages/purchase/detail.d.ts +7 -0
- package/dist/types/extensions/pos/pages/purchase/list.d.ts +9 -0
- package/dist/types/extensions/pos/types/purchase.d.ts +18 -0
- package/dist/types/extensions/pos/types/receipt.d.ts +34 -0
- package/dist/types/forms/LoginForm.d.ts +3 -0
- package/dist/types/hooks/useAsyncError.d.ts +1 -0
- package/dist/types/hooks/useLocalStorage.d.ts +2 -0
- package/dist/types/index.d.ts +14 -0
- package/dist/types/pages/DashboardPage.d.ts +5 -0
- package/dist/types/pages/LoginPage.d.ts +9 -0
- package/dist/types/router/Router.d.ts +13 -0
- package/dist/types/router/routes.d.ts +20 -0
- package/dist/types/types/index.d.ts +6 -0
- package/dist/types/util/get_cookie.d.ts +1 -0
- package/dist/types/util/index.d.ts +8 -0
- package/dist/types/util/select_styles.d.ts +3 -0
- package/example/Dockerfile +27 -0
- package/example/docker-compose.yml +7 -0
- package/example/index.html +13 -0
- package/example/index.tsx +21 -0
- package/example/package-lock.json +13167 -0
- package/example/package.json +52 -0
- package/example/pages/.gitkeep +0 -0
- package/example/webpack.config.js +67 -0
- package/package.json +52 -0
- package/src/Admin.tsx +94 -0
- package/src/App.tsx +43 -0
- package/src/api.ts +202 -0
- package/src/components/Branding.tsx +79 -0
- package/src/components/Hamburger.tsx +41 -0
- package/src/components/Link.tsx +23 -0
- package/src/components/Logo.tsx +57 -0
- package/src/components/NavBar.tsx +115 -0
- package/src/components/NavBarItem.tsx +73 -0
- package/src/components/NavBarRoutes.tsx +67 -0
- package/src/components/ProgressBar.tsx +30 -0
- package/src/components/User.tsx +97 -0
- package/src/containers/Content.tsx +18 -0
- package/src/containers/ErrorScreen.tsx +64 -0
- package/src/containers/LoadingScreen.tsx +135 -0
- package/src/containers/PageErrorBoundary.tsx +32 -0
- package/src/containers/PageLoader.tsx +64 -0
- package/src/contexts/ApiContext.tsx +55 -0
- package/src/contexts/I18nContext.tsx +55 -0
- package/src/contexts/RouterContext.tsx +127 -0
- package/src/contexts/UserContext.tsx +99 -0
- package/src/extensions/bananas/components/PasswordChangeForm.tsx +138 -0
- package/src/extensions/bananas/index.ts +14 -0
- package/src/extensions/bananas/pages/me/list.tsx +31 -0
- package/src/extensions/pos/components/PurchaseRow.tsx +42 -0
- package/src/extensions/pos/components/ReceiptCard.tsx +101 -0
- package/src/extensions/pos/components/ReceiptLine.tsx +51 -0
- package/src/extensions/pos/index.tsx +20 -0
- package/src/extensions/pos/pages/purchase/detail.tsx +22 -0
- package/src/extensions/pos/pages/purchase/list.tsx +56 -0
- package/src/extensions/pos/types/purchase.ts +20 -0
- package/src/extensions/pos/types/receipt.ts +36 -0
- package/src/forms/LoginForm.tsx +99 -0
- package/src/hooks/useAsyncError.ts +13 -0
- package/src/hooks/useLocalStorage.ts +42 -0
- package/src/index.ts +18 -0
- package/src/pages/DashboardPage.tsx +9 -0
- package/src/pages/LoginPage.tsx +50 -0
- package/src/router/Router.tsx +63 -0
- package/src/router/routes.ts +67 -0
- package/src/types/index.ts +4 -0
- package/src/types/swagger-client.d.ts +1 -0
- package/src/util/get_cookie.ts +6 -0
- package/src/util/index.ts +63 -0
- package/src/util/select_styles.ts +29 -0
- 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,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;
|
package/dist/esm/App.js
ADDED
|
@@ -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;
|