bananas-commerce-admin 0.10.7 → 0.10.9
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/dist/cjs/Admin.js +3 -3
- package/dist/cjs/Admin.js.map +1 -1
- package/dist/cjs/components/Brand.js +2 -1
- package/dist/cjs/components/Brand.js.map +1 -1
- package/dist/cjs/components/Card/index.js +30 -36
- package/dist/cjs/components/Card/index.js.map +1 -1
- package/dist/cjs/components/Card/shared.js.map +1 -1
- package/dist/cjs/components/NavRail/Branding.js +1 -0
- package/dist/cjs/components/NavRail/Branding.js.map +1 -1
- package/dist/cjs/contexts/CardContext.js +9 -6
- package/dist/cjs/contexts/CardContext.js.map +1 -1
- package/dist/cjs/index.js +15 -1
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/pages/LoginPage.js +2 -2
- package/dist/cjs/pages/LoginPage.js.map +1 -1
- package/dist/esm/Admin.js +3 -3
- package/dist/esm/Admin.js.map +1 -1
- package/dist/esm/components/Brand.js +2 -1
- package/dist/esm/components/Brand.js.map +1 -1
- package/dist/esm/components/Card/index.js +27 -36
- package/dist/esm/components/Card/index.js.map +1 -1
- package/dist/esm/components/Card/shared.js.map +1 -1
- package/dist/esm/components/NavRail/Branding.js +1 -0
- package/dist/esm/components/NavRail/Branding.js.map +1 -1
- package/dist/esm/contexts/CardContext.js +9 -3
- package/dist/esm/contexts/CardContext.js.map +1 -1
- package/dist/esm/index.js +15 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/pages/LoginPage.js +2 -2
- package/dist/esm/pages/LoginPage.js.map +1 -1
- package/dist/types/Admin.d.ts +2 -0
- package/dist/types/components/Card/index.d.ts +2 -1
- package/dist/types/components/Card/shared.d.ts +7 -14
- package/dist/types/index.d.ts +15 -1
- package/dist/types/pages/LoginPage.d.ts +1 -0
- package/package.json +1 -1
- package/src/Admin.tsx +6 -2
- package/src/components/Brand.tsx +2 -1
- package/src/components/Card/index.tsx +61 -73
- package/src/components/Card/shared.ts +7 -15
- package/src/components/NavRail/Branding.tsx +1 -0
- package/src/contexts/CardContext.tsx +13 -3
- package/src/index.ts +16 -1
- package/src/pages/LoginPage.tsx +6 -2
package/dist/cjs/Admin.js
CHANGED
|
@@ -39,7 +39,7 @@ const RouterContext_1 = require("./contexts/RouterContext");
|
|
|
39
39
|
const UserContext_1 = require("./contexts/UserContext");
|
|
40
40
|
const LoginPage_1 = __importDefault(require("./pages/LoginPage"));
|
|
41
41
|
const Router_1 = require("./router/Router");
|
|
42
|
-
const Admin = ({ logo, title, subtitle, version, navigation, extensions, dashboard, basename, basepath, }) => {
|
|
42
|
+
const Admin = ({ logo, logoSymbol, loginLogoHeight, title, subtitle, version, navigation, extensions, dashboard, basename, basepath, }) => {
|
|
43
43
|
const api = (0, ApiContext_1.useApi)();
|
|
44
44
|
const i18n = (0, I18nContext_1.useI18n)();
|
|
45
45
|
const { hasTriedToFetchUser, user } = (0, UserContext_1.useUser)();
|
|
@@ -54,12 +54,12 @@ const Admin = ({ logo, title, subtitle, version, navigation, extensions, dashboa
|
|
|
54
54
|
height: "100%",
|
|
55
55
|
flexDirection: "column",
|
|
56
56
|
backgroundColor: "background.default",
|
|
57
|
-
} }, !hasLoaded || !hasTriedToFetchUser ? (react_1.default.createElement(LoadingScreen_1.default, null)) : !hasUser ? (react_1.default.createElement(LoginPage_1.default, { logo: logo, title: title })) : (react_1.default.createElement(react_router_dom_1.BrowserRouter, { basename: basename },
|
|
57
|
+
} }, !hasLoaded || !hasTriedToFetchUser ? (react_1.default.createElement(LoadingScreen_1.default, null)) : !hasUser ? (react_1.default.createElement(LoginPage_1.default, { logo: logo, title: title, logoHeight: loginLogoHeight })) : (react_1.default.createElement(react_router_dom_1.BrowserRouter, { basename: basename },
|
|
58
58
|
react_1.default.createElement(RouterContext_1.RouterContextProvider, { basename: basename, stripPathPrefix: basepath },
|
|
59
59
|
react_1.default.createElement(DialogContext_1.default, null,
|
|
60
60
|
react_1.default.createElement(DialogContext_1.BcomDialog, null),
|
|
61
61
|
react_1.default.createElement(Box_1.default, { sx: { display: "flex" } },
|
|
62
|
-
react_1.default.createElement(NavRail_1.default, { navigation: navigation, logo:
|
|
62
|
+
react_1.default.createElement(NavRail_1.default, { navigation: navigation, logo: logoSymbol, title: title, subtitle: subtitle, version: version }),
|
|
63
63
|
react_1.default.createElement(Router_1.Router, { extensions: extensions, dashboard: dashboard }))))))));
|
|
64
64
|
};
|
|
65
65
|
exports.Admin = Admin;
|
package/dist/cjs/Admin.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Admin.js","sourceRoot":"","sources":["../../src/Admin.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,kDAA0B;AAC1B,uDAAiD;AACjD,4DAAoC;AACpC,mEAA2C;AAC3C,+EAAuD;AACvD,sDAA+C;AAC/C,0EAA6E;AAC7E,wDAAiD;AACjD,4DAAiE;AACjE,wDAAiD;AACjD,kEAA0C;AAC1C,4CAAsD;
|
|
1
|
+
{"version":3,"file":"Admin.js","sourceRoot":"","sources":["../../src/Admin.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,kDAA0B;AAC1B,uDAAiD;AACjD,4DAAoC;AACpC,mEAA2C;AAC3C,+EAAuD;AACvD,sDAA+C;AAC/C,0EAA6E;AAC7E,wDAAiD;AACjD,4DAAiE;AACjE,wDAAiD;AACjD,kEAA0C;AAC1C,4CAAsD;AAoB/C,MAAM,KAAK,GAAyB,CAAC,EAC1C,IAAI,EACJ,UAAU,EACV,eAAe,EACf,KAAK,EACL,QAAQ,EACR,OAAO,EACP,UAAU,EACV,UAAU,EACV,SAAS,EACT,QAAQ,EACR,QAAQ,GACT,EAAE,EAAE;IACH,MAAM,GAAG,GAAG,IAAA,mBAAM,GAAE,CAAC;IACrB,MAAM,IAAI,GAAG,IAAA,qBAAO,GAAE,CAAC;IACvB,MAAM,EAAE,mBAAmB,EAAE,IAAI,EAAE,GAAG,IAAA,qBAAO,GAAE,CAAC;IAEhD,MAAM,SAAS,GAAG,OAAO,CAAC,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,CAAC,CAAC;IACvD,MAAM,OAAO,GAAG,IAAI,IAAI,IAAI,CAAC;IAE7B,OAAO,CACL,8BAAC,aAAG,IACF,EAAE,EAAE;YACF,OAAO,EAAE,MAAM;YACf,QAAQ,EAAE,OAAO;YACjB,GAAG,EAAE,CAAC;YACN,IAAI,EAAE,CAAC;YACP,KAAK,EAAE,MAAM;YACb,MAAM,EAAE,MAAM;YACd,aAAa,EAAE,QAAQ;YACvB,eAAe,EAAE,oBAAoB;SACtC,IAEA,CAAC,SAAS,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,CACpC,8BAAC,uBAAa,OAAG,CAClB,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CACb,8BAAC,mBAAS,IAAC,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,eAAe,GAAI,CACrE,CAAC,CAAC,CAAC,CACF,8BAAC,gCAAa,IAAC,QAAQ,EAAE,QAAQ;QAC/B,8BAAC,qCAAqB,IAAC,QAAQ,EAAE,QAAQ,EAAE,eAAe,EAAE,QAAQ;YAClE,8BAAC,uBAAqB;gBACpB,8BAAC,0BAAU,OAAG;gBACd,8BAAC,aAAG,IAAC,EAAE,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE;oBAC1B,8BAAC,iBAAO,IACN,UAAU,EAAE,UAAU,EACtB,IAAI,EAAE,UAAU,EAChB,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,QAAQ,EAClB,OAAO,EAAE,OAAO,GAChB;oBAEF,8BAAC,eAAM,IAAC,UAAU,EAAE,UAAU,EAAE,SAAS,EAAE,SAAS,GAAI,CACpD,CACgB,CACF,CACV,CACjB,CACG,CACP,CAAC;AACJ,CAAC,CAAC;AA3DW,QAAA,KAAK,SA2DhB;AAEF,kBAAe,aAAK,CAAC"}
|
|
@@ -9,9 +9,10 @@ const Logo_1 = __importDefault(require("./Logo"));
|
|
|
9
9
|
const select_styles_1 = require("../util/select_styles");
|
|
10
10
|
const Brand = ({ BoxProps, src, sx, LogoProps }) => {
|
|
11
11
|
return (react_1.default.createElement(Box_1.default, { sx: (0, select_styles_1.ss)({
|
|
12
|
+
textAlign: "center",
|
|
12
13
|
width: "100%",
|
|
13
14
|
lineHeight: 0,
|
|
14
|
-
"& > svg": {
|
|
15
|
+
"& > svg, & > img": {
|
|
15
16
|
width: "100% !important",
|
|
16
17
|
height: "100% !important",
|
|
17
18
|
fill: "currentColor",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Brand.js","sourceRoot":"","sources":["../../../src/components/Brand.tsx"],"names":[],"mappings":";;;;;AAAA,kDAA0B;AAE1B,4DAAkD;AAGlD,kDAA0B;AAG1B,yDAA2C;AAS3C,MAAM,KAAK,GAAyB,CAAC,EAAE,QAAQ,EAAE,GAAG,EAAE,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE;IACvE,OAAO,CACL,8BAAC,aAAG,IACF,EAAE,EAAE,IAAA,kBAAE,EACJ;YACE,KAAK,EAAE,MAAM;YACb,UAAU,EAAE,CAAC;YACb,
|
|
1
|
+
{"version":3,"file":"Brand.js","sourceRoot":"","sources":["../../../src/components/Brand.tsx"],"names":[],"mappings":";;;;;AAAA,kDAA0B;AAE1B,4DAAkD;AAGlD,kDAA0B;AAG1B,yDAA2C;AAS3C,MAAM,KAAK,GAAyB,CAAC,EAAE,QAAQ,EAAE,GAAG,EAAE,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE;IACvE,OAAO,CACL,8BAAC,aAAG,IACF,EAAE,EAAE,IAAA,kBAAE,EACJ;YACE,SAAS,EAAE,QAAQ;YACnB,KAAK,EAAE,MAAM;YACb,UAAU,EAAE,CAAC;YACb,kBAAkB,EAAE;gBAClB,KAAK,EAAE,iBAAiB;gBACxB,MAAM,EAAE,iBAAiB;gBACzB,IAAI,EAAE,cAAc;gBACpB,UAAU,EAAE;oBACV,IAAI,EAAE,OAAO;iBACd;gBACD,GAAG,SAAS,EAAE,KAAK;aACpB;SACF,EACD,EAAE,CACH,KACG,QAAQ;QAEZ,8BAAC,cAAI,IAAC,GAAG,EAAE,GAAG,KAAM,SAAS,GAAI,CAC7B,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,kBAAe,KAAK,CAAC"}
|
|
@@ -22,26 +22,29 @@ var __importStar = (this && this.__importStar) || function (mod) {
|
|
|
22
22
|
__setModuleDefault(result, mod);
|
|
23
23
|
return result;
|
|
24
24
|
};
|
|
25
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
26
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
27
|
+
};
|
|
25
28
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
29
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
30
|
};
|
|
28
31
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
32
|
+
const react_1 = __importStar(require("react"));
|
|
29
33
|
const Card_1 = __importDefault(require("@mui/material/Card"));
|
|
30
34
|
const styles_1 = require("@mui/material/styles");
|
|
31
35
|
const notistack_1 = require("notistack");
|
|
32
|
-
const react_1 = __importStar(require("react"));
|
|
33
36
|
const CardContext_1 = require("../../contexts/CardContext");
|
|
34
37
|
const I18nContext_1 = require("../../contexts/I18nContext");
|
|
35
|
-
|
|
38
|
+
__exportStar(require("./shared"), exports);
|
|
39
|
+
const Card = ({ columns = 1, onSubmit, isEditable = false, children, isDisabled: isDisabledDefault = false, ...props }) => {
|
|
36
40
|
const [isEditing, setIsEditing] = (0, react_1.useState)(false);
|
|
37
41
|
const [hasChanges, setHasChanges] = (0, react_1.useState)(false);
|
|
38
42
|
const [isDisabled, setIsDisabled] = (0, react_1.useState)(isDisabledDefault);
|
|
39
43
|
const theme = (0, styles_1.useTheme)();
|
|
40
44
|
const { enqueueSnackbar } = (0, notistack_1.useSnackbar)();
|
|
41
45
|
const { t } = (0, I18nContext_1.useI18n)();
|
|
42
|
-
const handleSubmit = async (event) => {
|
|
43
|
-
|
|
44
|
-
if (!onSubmit)
|
|
46
|
+
const handleSubmit = (0, react_1.useCallback)(async (event) => {
|
|
47
|
+
if (onSubmit == null)
|
|
45
48
|
throw new Error("No onSubmit function provided.");
|
|
46
49
|
event.preventDefault();
|
|
47
50
|
const form = event.currentTarget;
|
|
@@ -50,9 +53,7 @@ const Card = ({ columns, onSubmit, isEditable = false, children, isDisabled: isD
|
|
|
50
53
|
setIsDisabled(true);
|
|
51
54
|
try {
|
|
52
55
|
const success = await onSubmit(values);
|
|
53
|
-
enqueueSnackbar(success, {
|
|
54
|
-
variant: "success",
|
|
55
|
-
});
|
|
56
|
+
enqueueSnackbar(success, { variant: "success" });
|
|
56
57
|
setIsEditing(false);
|
|
57
58
|
setIsDisabled(false);
|
|
58
59
|
}
|
|
@@ -65,34 +66,27 @@ const Card = ({ columns, onSubmit, isEditable = false, children, isDisabled: isD
|
|
|
65
66
|
// Don't exit edit mode (and clear fields) on error. Give the user the chance to save/fix.
|
|
66
67
|
setIsDisabled(false);
|
|
67
68
|
}
|
|
68
|
-
};
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
borderRadius: 3,
|
|
90
|
-
borderWidth: "1px",
|
|
91
|
-
borderStyle: "solid",
|
|
92
|
-
borderColor: theme.palette.divider,
|
|
93
|
-
backgroundColor: theme.palette.background.paper,
|
|
94
|
-
overflow: "visible",
|
|
95
|
-
} }, children))));
|
|
69
|
+
}, [onSubmit, enqueueSnackbar, t]);
|
|
70
|
+
const contextValues = (0, react_1.useMemo)(() => ({
|
|
71
|
+
isDisabled,
|
|
72
|
+
isEditable,
|
|
73
|
+
isEditing,
|
|
74
|
+
setIsEditing,
|
|
75
|
+
columns,
|
|
76
|
+
hasChanges,
|
|
77
|
+
setHasChanges,
|
|
78
|
+
}), [isDisabled, isEditable, isEditing, columns, hasChanges]);
|
|
79
|
+
return (react_1.default.createElement(CardContext_1.CardContext.Provider, { value: contextValues },
|
|
80
|
+
react_1.default.createElement(Card_1.default, { sx: {
|
|
81
|
+
width: "100%",
|
|
82
|
+
boxShadow: 0,
|
|
83
|
+
borderRadius: 3,
|
|
84
|
+
borderWidth: "1px",
|
|
85
|
+
borderStyle: "solid",
|
|
86
|
+
borderColor: theme.palette.divider,
|
|
87
|
+
backgroundColor: theme.palette.background.paper,
|
|
88
|
+
overflow: "visible",
|
|
89
|
+
}, component: isEditable ? "form" : "div", onSubmit: isEditable ? handleSubmit : undefined, ...props }, children)));
|
|
96
90
|
};
|
|
97
91
|
exports.default = Card;
|
|
98
92
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/Card/index.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/Card/index.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"shared.js","sourceRoot":"","sources":["../../../../src/components/Card/shared.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"shared.js","sourceRoot":"","sources":["../../../../src/components/Card/shared.ts"],"names":[],"mappings":";;;AAQO,MAAM,YAAY,GAAG,CAAC,SAAkB,EAAW,EAAE,CAAC,CAAC;IAC5D,OAAO,EAAE,MAAM;IACf,GAAG,EAAE,GAAG;IACR,aAAa,EAAE,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ;IAC3C,cAAc,EAAE,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,YAAY;CAC3D,CAAC,CAAC;AALU,QAAA,YAAY,gBAKtB;AAEU,QAAA,MAAM,GAAG;IACpB,KAAK,EAAE,MAAM;IACb,MAAM,EAAE,MAAM;IACd,SAAS,EAAE,OAAO;IAClB,QAAQ,EAAE,OAAO;IACjB,SAAS,EAAE,OAAO;CACnB,CAAC"}
|
|
@@ -45,6 +45,7 @@ const StyledBrandIconBox = (0, styles_1.styled)(Box_1.default, {
|
|
|
45
45
|
name: "BananasNavRail",
|
|
46
46
|
slot: "BrandIconBox",
|
|
47
47
|
})(({ theme }) => theme.unstable_sx({
|
|
48
|
+
width: "100%",
|
|
48
49
|
transition: theme.transitions.create(["transform"], {
|
|
49
50
|
duration: theme.transitions.duration.shortest,
|
|
50
51
|
}),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Branding.js","sourceRoot":"","sources":["../../../../src/components/NavRail/Branding.tsx"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"Branding.js","sourceRoot":"","sources":["../../../../src/components/NavRail/Branding.tsx"],"names":[],"mappings":";;;;;AAAA,kDAA0B;AAG1B,4DAAoC;AACpC,0EAAkD;AAClD,0EAAkD;AAClD,iDAA8C;AAE9C,8DAAsC;AAEtC,qDAA6B;AAc7B,MAAM,YAAY,GAAG,IAAA,eAAM,EAAC,aAAG,EAAE;IAC/B,IAAI,EAAE,gBAAgB;IACtB,IAAI,EAAE,UAAU;CACjB,CAAC,CAAqC,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,EAAE,EAAE,CAC/D,KAAK,CAAC,WAAW,CAAC;IAChB,OAAO,EAAE,MAAM;IACf,aAAa,EAAE,KAAK;IACpB,UAAU,EAAE,QAAQ;IACpB,QAAQ,EAAE,CAAC;IACX,KAAK,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG;CAC3C,CAAC,CACH,CAAC;AAEF,MAAM,cAAc,GAAG,IAAA,eAAM,EAAC,aAAG,EAAE;IACjC,IAAI,EAAE,gBAAgB;IACtB,IAAI,EAAE,UAAU;CACjB,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CACf,KAAK,CAAC,WAAW,CAAC;IAChB,QAAQ,EAAE,MAAM;IAChB,WAAW,EAAE,OAAO;IACpB,OAAO,EAAE,oBAAoB;IAC7B,OAAO,EAAE,MAAM;IACf,UAAU,EAAE,QAAQ;IACpB,CAAC,EAAE,GAAG;IACN,YAAY,EAAE,CAAC;IACf,SAAS,EAAE;QACT,OAAO,EAAE,qBAAqB;KAC/B;IACD,iCAAiC,EAAE;QACjC,SAAS,EAAE,YAAY;KACxB;IACD,UAAU,EAAE,KAAK,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,kBAAkB,CAAC,EAAE;QACzD,QAAQ,EAAE,KAAK,CAAC,WAAW,CAAC,QAAQ,CAAC,QAAQ;KAC9C,CAAC;CACH,CAAC,CACH,CAAC;AAEF,MAAM,kBAAkB,GAAG,IAAA,eAAM,EAAC,aAAG,EAAE;IACrC,IAAI,EAAE,gBAAgB;IACtB,IAAI,EAAE,cAAc;CACrB,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CACf,KAAK,CAAC,WAAW,CAAC;IAChB,KAAK,EAAE,MAAM;IACb,UAAU,EAAE,KAAK,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,WAAW,CAAC,EAAE;QAClD,QAAQ,EAAE,KAAK,CAAC,WAAW,CAAC,QAAQ,CAAC,QAAQ;KAC9C,CAAC;CACH,CAAC,CACH,CAAC;AAEF,MAAM,QAAQ,GAA4B,CAAC,EACzC,IAAI,EACJ,KAAK,EACL,QAAQ,EACR,OAAO,EACP,OAAO,EACP,SAAS,EACT,EAAE,GACH,EAAE,EAAE;IACH,MAAM,UAAU,GAAG,EAAE,SAAS,EAAE,CAAC;IAEjC,OAAO,CACL,8BAAC,eAAK,IACJ,EAAE,EAAE;YACF,KAAK,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG;YAC1C,EAAE,EAAE,CAAC;YACL,EAAE,EAAE,GAAG;YACP,SAAS,EAAE,EAAE;SACd;QAED,8BAAC,YAAY,IAAC,UAAU,EAAE,UAAU,EAAE,EAAE,EAAE,EAAE;YAC1C,8BAAC,oBAAU,IACT,aAAa,QACb,EAAE,EAAE;oBACF,cAAc,EAAE,YAAY;oBAC5B,KAAK,EAAE,MAAM;oBACb,MAAM,EAAE,MAAM;oBACd,KAAK,EAAE,SAAS;iBACjB,EACD,OAAO,EAAE,OAAO;gBAEf,IAAI,CAAC,CAAC,CAAC,CACN,8BAAC,cAAc;oBACb,8BAAC,kBAAkB;wBACjB,8BAAC,eAAK,IACJ,GAAG,EAAE,IAAI,EACT,SAAS,EAAE;gCACT,KAAK,EAAE;oCACL,SAAS,EAAE,EAAE;iCACd;6BACF,GACD,CACiB,CACN,CAClB,CAAC,CAAC,CAAC,CACF,8BAAC,oBAAU,IACT,EAAE,EAAE;wBACF,UAAU,EAAE,MAAM;qBACnB,EACD,KAAK,EAAC,SAAS,EACf,OAAO,EAAC,IAAI,IAEX,KAAK,CACK,CACd;gBACD,8BAAC,aAAG,IACF,EAAE,EAAE;wBACF,UAAU,EAAE,EAAE;wBACd,OAAO,EAAE;4BACP,SAAS,EAAE,MAAM;4BACjB,QAAQ,EAAE,SAAS;4BACnB,OAAO,EAAE,OAAO;4BAChB,UAAU,EAAE,KAAK;yBAClB;qBACF;oBAED,8BAAC,oBAAU,IAAC,KAAK,EAAC,SAAS,IAAE,QAAQ,CAAc;oBACnD,8BAAC,oBAAU,IAAC,KAAK,EAAC,SAAS,IAAE,OAAO,CAAc,CAC9C,CACK,CACA,CACT,CACT,CAAC;AACJ,CAAC,CAAC;AAEF,kBAAe,QAAQ,CAAC"}
|
|
@@ -1,11 +1,14 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
3
|
exports.useCardContext = exports.CardContext = void 0;
|
|
7
|
-
const react_1 =
|
|
8
|
-
exports.CardContext = react_1.
|
|
9
|
-
const useCardContext = () =>
|
|
4
|
+
const react_1 = require("react");
|
|
5
|
+
exports.CardContext = (0, react_1.createContext)(undefined);
|
|
6
|
+
const useCardContext = () => {
|
|
7
|
+
const context = (0, react_1.useContext)(exports.CardContext);
|
|
8
|
+
if (context == null) {
|
|
9
|
+
throw new Error("useCardContext must be used within a CardProvider. You are most likely not using the correct <Card> parent component.");
|
|
10
|
+
}
|
|
11
|
+
return context;
|
|
12
|
+
};
|
|
10
13
|
exports.useCardContext = useCardContext;
|
|
11
14
|
//# sourceMappingURL=CardContext.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CardContext.js","sourceRoot":"","sources":["../../../src/contexts/CardContext.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"CardContext.js","sourceRoot":"","sources":["../../../src/contexts/CardContext.tsx"],"names":[],"mappings":";;;AAAA,iCAAyD;AAY5C,QAAA,WAAW,GAAG,IAAA,qBAAa,EAAc,SAAmC,CAAC,CAAC;AAEpF,MAAM,cAAc,GAAG,GAAG,EAAE;IACjC,MAAM,OAAO,GAAG,IAAA,kBAAU,EAAC,mBAAW,CAAC,CAAC;IACxC,IAAI,OAAO,IAAI,IAAI,EAAE,CAAC;QACpB,MAAM,IAAI,KAAK,CACb,uHAAuH,CACxH,CAAC;IACJ,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC,CAAC;AATW,QAAA,cAAc,kBASzB"}
|
package/dist/cjs/index.js
CHANGED
|
@@ -31,7 +31,6 @@ __exportStar(require("./components/TitleBar"), exports);
|
|
|
31
31
|
__exportStar(require("./components/Header"), exports);
|
|
32
32
|
__exportStar(require("./components/ActionBar"), exports);
|
|
33
33
|
__exportStar(require("./components/Link"), exports);
|
|
34
|
-
__exportStar(require("./components/Card"), exports);
|
|
35
34
|
__exportStar(require("./components/ChipsInput"), exports);
|
|
36
35
|
__exportStar(require("./components/Chip"), exports);
|
|
37
36
|
__exportStar(require("./components/FilterChip"), exports);
|
|
@@ -40,6 +39,21 @@ __exportStar(require("./components/TabPanels"), exports);
|
|
|
40
39
|
__exportStar(require("./components/TabPanel"), exports);
|
|
41
40
|
__exportStar(require("./components/Tab"), exports);
|
|
42
41
|
__exportStar(require("./components/Page"), exports);
|
|
42
|
+
__exportStar(require("./components/Card"), exports);
|
|
43
|
+
__exportStar(require("./components/Card/CardHeader"), exports);
|
|
44
|
+
__exportStar(require("./components/Card/CardActions"), exports);
|
|
45
|
+
__exportStar(require("./components/Card/CardContent"), exports);
|
|
46
|
+
__exportStar(require("./components/Card/CardCancelButton"), exports);
|
|
47
|
+
__exportStar(require("./components/Card/CardSaveButton"), exports);
|
|
48
|
+
__exportStar(require("./components/Card/CardRow"), exports);
|
|
49
|
+
__exportStar(require("./components/Card/CardPill"), exports);
|
|
50
|
+
__exportStar(require("./components/Card/CardFieldAutoComplete"), exports);
|
|
51
|
+
__exportStar(require("./components/Card/CardFieldCheckbox"), exports);
|
|
52
|
+
__exportStar(require("./components/Card/CardFieldImage"), exports);
|
|
53
|
+
__exportStar(require("./components/Card/CardFieldNumber"), exports);
|
|
54
|
+
__exportStar(require("./components/Card/CardFieldSelect"), exports);
|
|
55
|
+
__exportStar(require("./components/Card/CardFieldSwitch"), exports);
|
|
56
|
+
__exportStar(require("./components/Card/CardFieldText"), exports);
|
|
43
57
|
__exportStar(require("./contexts/ApiContext"), exports);
|
|
44
58
|
__exportStar(require("./contexts/I18nContext"), exports);
|
|
45
59
|
__exportStar(require("./contexts/RouterContext"), exports);
|
package/dist/cjs/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,wDAAsC;AACtC,sDAAoC;AACpC,yDAAuC;AACvC,oDAAkC;AAClC,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,wDAAsC;AACtC,sDAAoC;AACpC,yDAAuC;AACvC,oDAAkC;AAClC,0DAAwC;AACxC,oDAAkC;AAClC,0DAAwC;AACxC,oDAAkC;AAClC,yDAAuC;AACvC,wDAAsC;AACtC,mDAAiC;AACjC,oDAAkC;AAElC,oDAAkC;AAClC,+DAA6C;AAC7C,gEAA8C;AAC9C,gEAA8C;AAC9C,qEAAmD;AACnD,mEAAiD;AACjD,4DAA0C;AAC1C,6DAA2C;AAC3C,0EAAwD;AACxD,sEAAoD;AACpD,mEAAiD;AACjD,oEAAkD;AAClD,oEAAkD;AAClD,oEAAkD;AAClD,kEAAgD;AAEhD,wDAAsC;AACtC,yDAAuC;AACvC,2DAAyC;AACzC,yDAAuC;AACvC,2DAAyC;AAEzC,uDAAqC;AACrC,+DAA6C;AAC7C,6DAA2C;AAE3C,0CAAwB;AACxB,wCAAsB;AACtB,wCAAsB;AAEtB,gEAAgD;AAChD,wDAAwC;AACxC,wEAAwD;AACxD,8DAA8C;AAC9C,gEAAgD;AAChD,gEAAgD"}
|
|
@@ -35,11 +35,11 @@ const StyledBackdrop = (0, styles_1.styled)(Backdrop_1.default, {
|
|
|
35
35
|
justifyContent: "center",
|
|
36
36
|
display: "flex",
|
|
37
37
|
}));
|
|
38
|
-
const LoginPage = ({ title, logo, form: Form }) => {
|
|
38
|
+
const LoginPage = ({ title, logo, form: Form, logoHeight }) => {
|
|
39
39
|
Form ??= LoginForm_1.default;
|
|
40
40
|
return (react_1.default.createElement(Content_1.default, null,
|
|
41
41
|
react_1.default.createElement(StyledDialog, { open: true, sx: { "> * > *": { width: "100%" } }, PaperProps: { elevation: 1 }, BackdropComponent: StyledBackdrop },
|
|
42
|
-
react_1.default.createElement(StyledDialogTitle, null, logo ? (react_1.default.createElement(Brand_1.default, { src: logo, LogoProps: { style: { height: "24px !important" } } })) : (react_1.default.createElement(Typography_1.default, { sx: { fontWeight: "bold", color: "inherit" } }, title))),
|
|
42
|
+
react_1.default.createElement(StyledDialogTitle, null, logo ? (react_1.default.createElement(Brand_1.default, { src: logo, LogoProps: { style: { width: "auto", height: logoHeight ?? "24px !important" } } })) : (react_1.default.createElement(Typography_1.default, { sx: { fontWeight: "bold", color: "inherit" } }, title))),
|
|
43
43
|
react_1.default.createElement(Form, null))));
|
|
44
44
|
};
|
|
45
45
|
exports.default = LoginPage;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"LoginPage.js","sourceRoot":"","sources":["../../../src/pages/LoginPage.tsx"],"names":[],"mappings":";;;;;AAAA,kDAA0B;AAE1B,kEAA0C;AAC1C,4EAAoD;AACpD,sEAA8C;AAC9C,0EAAkD;AAClD,iDAA8C;AAE9C,gEAAwC;AACxC,oEAA4C;AAC5C,mEAA2C;
|
|
1
|
+
{"version":3,"file":"LoginPage.js","sourceRoot":"","sources":["../../../src/pages/LoginPage.tsx"],"names":[],"mappings":";;;;;AAAA,kDAA0B;AAE1B,kEAA0C;AAC1C,4EAAoD;AACpD,sEAA8C;AAC9C,0EAAkD;AAClD,iDAA8C;AAE9C,gEAAwC;AACxC,oEAA4C;AAC5C,mEAA2C;AAU3C,MAAM,YAAY,GAAG,IAAA,eAAM,EAAC,gBAAM,EAAE;IAClC,IAAI,EAAE,oBAAoB;IAC1B,IAAI,EAAE,MAAM;CACb,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;AAEf,MAAM,iBAAiB,GAAG,IAAA,eAAM,EAAC,qBAAW,EAAE;IAC5C,IAAI,EAAE,oBAAoB;IAC1B,IAAI,EAAE,OAAO;CACd,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CACf,KAAK,CAAC,WAAW,CAAC;IAChB,OAAO,EAAE,cAAc;IACvB,KAAK,EAAE,sBAAsB;CAC9B,CAAC,CACH,CAAC;AAEF,MAAM,cAAc,GAAG,IAAA,eAAM,EAAC,kBAAQ,EAAE;IACtC,IAAI,EAAE,oBAAoB;IAC1B,IAAI,EAAE,UAAU;CACjB,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CACf,KAAK,CAAC,WAAW,CAAC;IAChB,OAAO,EAAE,cAAc;IACvB,CAAC,EAAE,CAAC;IACJ,CAAC,EAAE,CAAC;IACJ,SAAS,EAAE,QAAQ;IACnB,UAAU,EAAE,QAAQ;IACpB,cAAc,EAAE,QAAQ;IACxB,OAAO,EAAE,MAAM;CAChB,CAAC,CACH,CAAC;AAEF,MAAM,SAAS,GAA6B,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,UAAU,EAAE,EAAE,EAAE;IACtF,IAAI,KAAK,mBAAS,CAAC;IAEnB,OAAO,CACL,8BAAC,iBAAO;QACN,8BAAC,YAAY,IACX,IAAI,QACJ,EAAE,EAAE,EAAE,SAAS,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,EACpC,UAAU,EAAE,EAAE,SAAS,EAAE,CAAC,EAAE,EAC5B,iBAAiB,EAAE,cAAc;YAEjC,8BAAC,iBAAiB,QACf,IAAI,CAAC,CAAC,CAAC,CACN,8BAAC,eAAK,IACJ,GAAG,EAAE,IAAI,EACT,SAAS,EAAE,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,UAAU,IAAI,iBAAiB,EAAE,EAAE,GAChF,CACH,CAAC,CAAC,CAAC,CACF,8BAAC,oBAAU,IAAC,EAAE,EAAE,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,IAAG,KAAK,CAAc,CAC/E,CACiB;YAEpB,8BAAC,IAAI,OAAG,CACK,CACP,CACX,CAAC;AACJ,CAAC,CAAC;AAEF,kBAAe,SAAS,CAAC"}
|
package/dist/esm/Admin.js
CHANGED
|
@@ -10,7 +10,7 @@ import { RouterContextProvider } from "./contexts/RouterContext";
|
|
|
10
10
|
import { useUser } from "./contexts/UserContext";
|
|
11
11
|
import LoginPage from "./pages/LoginPage";
|
|
12
12
|
import { Router } from "./router/Router";
|
|
13
|
-
export const Admin = ({ logo, title, subtitle, version, navigation, extensions, dashboard, basename, basepath, }) => {
|
|
13
|
+
export const Admin = ({ logo, logoSymbol, loginLogoHeight, title, subtitle, version, navigation, extensions, dashboard, basename, basepath, }) => {
|
|
14
14
|
const api = useApi();
|
|
15
15
|
const i18n = useI18n();
|
|
16
16
|
const { hasTriedToFetchUser, user } = useUser();
|
|
@@ -25,12 +25,12 @@ export const Admin = ({ logo, title, subtitle, version, navigation, extensions,
|
|
|
25
25
|
height: "100%",
|
|
26
26
|
flexDirection: "column",
|
|
27
27
|
backgroundColor: "background.default",
|
|
28
|
-
} }, !hasLoaded || !hasTriedToFetchUser ? (React.createElement(LoadingScreen, null)) : !hasUser ? (React.createElement(LoginPage, { logo: logo, title: title })) : (React.createElement(BrowserRouter, { basename: basename },
|
|
28
|
+
} }, !hasLoaded || !hasTriedToFetchUser ? (React.createElement(LoadingScreen, null)) : !hasUser ? (React.createElement(LoginPage, { logo: logo, title: title, logoHeight: loginLogoHeight })) : (React.createElement(BrowserRouter, { basename: basename },
|
|
29
29
|
React.createElement(RouterContextProvider, { basename: basename, stripPathPrefix: basepath },
|
|
30
30
|
React.createElement(DialogContextProvider, null,
|
|
31
31
|
React.createElement(BcomDialog, null),
|
|
32
32
|
React.createElement(Box, { sx: { display: "flex" } },
|
|
33
|
-
React.createElement(NavRail, { navigation: navigation, logo:
|
|
33
|
+
React.createElement(NavRail, { navigation: navigation, logo: logoSymbol, title: title, subtitle: subtitle, version: version }),
|
|
34
34
|
React.createElement(Router, { extensions: extensions, dashboard: dashboard }))))))));
|
|
35
35
|
};
|
|
36
36
|
export default Admin;
|
package/dist/esm/Admin.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Admin.js","sourceRoot":"","sources":["../../src/Admin.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AACjD,OAAO,GAAG,MAAM,mBAAmB,CAAC;AACpC,OAAO,OAAO,MAAM,sBAAsB,CAAC;AAC3C,OAAO,aAAa,MAAM,4BAA4B,CAAC;AACvD,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAC/C,OAAO,qBAAqB,EAAE,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AAC7E,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AACjD,OAAO,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACjE,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AACjD,OAAO,SAAS,MAAM,mBAAmB,CAAC;AAC1C,OAAO,EAAE,MAAM,EAAe,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"Admin.js","sourceRoot":"","sources":["../../src/Admin.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AACjD,OAAO,GAAG,MAAM,mBAAmB,CAAC;AACpC,OAAO,OAAO,MAAM,sBAAsB,CAAC;AAC3C,OAAO,aAAa,MAAM,4BAA4B,CAAC;AACvD,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAC/C,OAAO,qBAAqB,EAAE,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AAC7E,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AACjD,OAAO,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACjE,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AACjD,OAAO,SAAS,MAAM,mBAAmB,CAAC;AAC1C,OAAO,EAAE,MAAM,EAAe,MAAM,iBAAiB,CAAC;AAoBtD,MAAM,CAAC,MAAM,KAAK,GAAyB,CAAC,EAC1C,IAAI,EACJ,UAAU,EACV,eAAe,EACf,KAAK,EACL,QAAQ,EACR,OAAO,EACP,UAAU,EACV,UAAU,EACV,SAAS,EACT,QAAQ,EACR,QAAQ,GACT,EAAE,EAAE;IACH,MAAM,GAAG,GAAG,MAAM,EAAE,CAAC;IACrB,MAAM,IAAI,GAAG,OAAO,EAAE,CAAC;IACvB,MAAM,EAAE,mBAAmB,EAAE,IAAI,EAAE,GAAG,OAAO,EAAE,CAAC;IAEhD,MAAM,SAAS,GAAG,OAAO,CAAC,GAAG,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,CAAC,CAAC;IACvD,MAAM,OAAO,GAAG,IAAI,IAAI,IAAI,CAAC;IAE7B,OAAO,CACL,oBAAC,GAAG,IACF,EAAE,EAAE;YACF,OAAO,EAAE,MAAM;YACf,QAAQ,EAAE,OAAO;YACjB,GAAG,EAAE,CAAC;YACN,IAAI,EAAE,CAAC;YACP,KAAK,EAAE,MAAM;YACb,MAAM,EAAE,MAAM;YACd,aAAa,EAAE,QAAQ;YACvB,eAAe,EAAE,oBAAoB;SACtC,IAEA,CAAC,SAAS,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,CACpC,oBAAC,aAAa,OAAG,CAClB,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CACb,oBAAC,SAAS,IAAC,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,eAAe,GAAI,CACrE,CAAC,CAAC,CAAC,CACF,oBAAC,aAAa,IAAC,QAAQ,EAAE,QAAQ;QAC/B,oBAAC,qBAAqB,IAAC,QAAQ,EAAE,QAAQ,EAAE,eAAe,EAAE,QAAQ;YAClE,oBAAC,qBAAqB;gBACpB,oBAAC,UAAU,OAAG;gBACd,oBAAC,GAAG,IAAC,EAAE,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE;oBAC1B,oBAAC,OAAO,IACN,UAAU,EAAE,UAAU,EACtB,IAAI,EAAE,UAAU,EAChB,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,QAAQ,EAClB,OAAO,EAAE,OAAO,GAChB;oBAEF,oBAAC,MAAM,IAAC,UAAU,EAAE,UAAU,EAAE,SAAS,EAAE,SAAS,GAAI,CACpD,CACgB,CACF,CACV,CACjB,CACG,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,KAAK,CAAC"}
|
|
@@ -4,9 +4,10 @@ import Logo from "./Logo";
|
|
|
4
4
|
import { ss } from "../util/select_styles";
|
|
5
5
|
const Brand = ({ BoxProps, src, sx, LogoProps }) => {
|
|
6
6
|
return (React.createElement(Box, { sx: ss({
|
|
7
|
+
textAlign: "center",
|
|
7
8
|
width: "100%",
|
|
8
9
|
lineHeight: 0,
|
|
9
|
-
"& > svg": {
|
|
10
|
+
"& > svg, & > img": {
|
|
10
11
|
width: "100% !important",
|
|
11
12
|
height: "100% !important",
|
|
12
13
|
fill: "currentColor",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Brand.js","sourceRoot":"","sources":["../../../src/components/Brand.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,GAAiB,MAAM,mBAAmB,CAAC;AAGlD,OAAO,IAAI,MAAM,QAAQ,CAAC;AAG1B,OAAO,EAAE,EAAE,EAAE,MAAM,uBAAuB,CAAC;AAS3C,MAAM,KAAK,GAAyB,CAAC,EAAE,QAAQ,EAAE,GAAG,EAAE,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE;IACvE,OAAO,CACL,oBAAC,GAAG,IACF,EAAE,EAAE,EAAE,CACJ;YACE,KAAK,EAAE,MAAM;YACb,UAAU,EAAE,CAAC;YACb,
|
|
1
|
+
{"version":3,"file":"Brand.js","sourceRoot":"","sources":["../../../src/components/Brand.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,GAAiB,MAAM,mBAAmB,CAAC;AAGlD,OAAO,IAAI,MAAM,QAAQ,CAAC;AAG1B,OAAO,EAAE,EAAE,EAAE,MAAM,uBAAuB,CAAC;AAS3C,MAAM,KAAK,GAAyB,CAAC,EAAE,QAAQ,EAAE,GAAG,EAAE,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE;IACvE,OAAO,CACL,oBAAC,GAAG,IACF,EAAE,EAAE,EAAE,CACJ;YACE,SAAS,EAAE,QAAQ;YACnB,KAAK,EAAE,MAAM;YACb,UAAU,EAAE,CAAC;YACb,kBAAkB,EAAE;gBAClB,KAAK,EAAE,iBAAiB;gBACxB,MAAM,EAAE,iBAAiB;gBACzB,IAAI,EAAE,cAAc;gBACpB,UAAU,EAAE;oBACV,IAAI,EAAE,OAAO;iBACd;gBACD,GAAG,SAAS,EAAE,KAAK;aACpB;SACF,EACD,EAAE,CACH,KACG,QAAQ;QAEZ,oBAAC,IAAI,IAAC,GAAG,EAAE,GAAG,KAAM,SAAS,GAAI,CAC7B,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,KAAK,CAAC"}
|
|
@@ -1,19 +1,19 @@
|
|
|
1
|
+
import React, { useCallback, useMemo, useState } from "react";
|
|
1
2
|
import MuiCard from "@mui/material/Card";
|
|
2
3
|
import { useTheme } from "@mui/material/styles";
|
|
3
4
|
import { useSnackbar } from "notistack";
|
|
4
|
-
import React, { useState } from "react";
|
|
5
5
|
import { CardContext } from "../../contexts/CardContext";
|
|
6
6
|
import { useI18n } from "../../contexts/I18nContext";
|
|
7
|
-
|
|
7
|
+
export * from "./shared";
|
|
8
|
+
const Card = ({ columns = 1, onSubmit, isEditable = false, children, isDisabled: isDisabledDefault = false, ...props }) => {
|
|
8
9
|
const [isEditing, setIsEditing] = useState(false);
|
|
9
10
|
const [hasChanges, setHasChanges] = useState(false);
|
|
10
11
|
const [isDisabled, setIsDisabled] = useState(isDisabledDefault);
|
|
11
12
|
const theme = useTheme();
|
|
12
13
|
const { enqueueSnackbar } = useSnackbar();
|
|
13
14
|
const { t } = useI18n();
|
|
14
|
-
const handleSubmit = async (event) => {
|
|
15
|
-
|
|
16
|
-
if (!onSubmit)
|
|
15
|
+
const handleSubmit = useCallback(async (event) => {
|
|
16
|
+
if (onSubmit == null)
|
|
17
17
|
throw new Error("No onSubmit function provided.");
|
|
18
18
|
event.preventDefault();
|
|
19
19
|
const form = event.currentTarget;
|
|
@@ -22,9 +22,7 @@ const Card = ({ columns, onSubmit, isEditable = false, children, isDisabled: isD
|
|
|
22
22
|
setIsDisabled(true);
|
|
23
23
|
try {
|
|
24
24
|
const success = await onSubmit(values);
|
|
25
|
-
enqueueSnackbar(success, {
|
|
26
|
-
variant: "success",
|
|
27
|
-
});
|
|
25
|
+
enqueueSnackbar(success, { variant: "success" });
|
|
28
26
|
setIsEditing(false);
|
|
29
27
|
setIsDisabled(false);
|
|
30
28
|
}
|
|
@@ -37,34 +35,27 @@ const Card = ({ columns, onSubmit, isEditable = false, children, isDisabled: isD
|
|
|
37
35
|
// Don't exit edit mode (and clear fields) on error. Give the user the chance to save/fix.
|
|
38
36
|
setIsDisabled(false);
|
|
39
37
|
}
|
|
40
|
-
};
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
borderRadius: 3,
|
|
62
|
-
borderWidth: "1px",
|
|
63
|
-
borderStyle: "solid",
|
|
64
|
-
borderColor: theme.palette.divider,
|
|
65
|
-
backgroundColor: theme.palette.background.paper,
|
|
66
|
-
overflow: "visible",
|
|
67
|
-
} }, children))));
|
|
38
|
+
}, [onSubmit, enqueueSnackbar, t]);
|
|
39
|
+
const contextValues = useMemo(() => ({
|
|
40
|
+
isDisabled,
|
|
41
|
+
isEditable,
|
|
42
|
+
isEditing,
|
|
43
|
+
setIsEditing,
|
|
44
|
+
columns,
|
|
45
|
+
hasChanges,
|
|
46
|
+
setHasChanges,
|
|
47
|
+
}), [isDisabled, isEditable, isEditing, columns, hasChanges]);
|
|
48
|
+
return (React.createElement(CardContext.Provider, { value: contextValues },
|
|
49
|
+
React.createElement(MuiCard, { sx: {
|
|
50
|
+
width: "100%",
|
|
51
|
+
boxShadow: 0,
|
|
52
|
+
borderRadius: 3,
|
|
53
|
+
borderWidth: "1px",
|
|
54
|
+
borderStyle: "solid",
|
|
55
|
+
borderColor: theme.palette.divider,
|
|
56
|
+
backgroundColor: theme.palette.background.paper,
|
|
57
|
+
overflow: "visible",
|
|
58
|
+
}, component: isEditable ? "form" : "div", onSubmit: isEditable ? handleSubmit : undefined, ...props }, children)));
|
|
68
59
|
};
|
|
69
60
|
export default Card;
|
|
70
61
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/Card/index.tsx"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/Card/index.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"shared.js","sourceRoot":"","sources":["../../../../src/components/Card/shared.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"shared.js","sourceRoot":"","sources":["../../../../src/components/Card/shared.ts"],"names":[],"mappings":"AAQA,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,SAAkB,EAAW,EAAE,CAAC,CAAC;IAC5D,OAAO,EAAE,MAAM;IACf,GAAG,EAAE,GAAG;IACR,aAAa,EAAE,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ;IAC3C,cAAc,EAAE,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,YAAY;CAC3D,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,MAAM,GAAG;IACpB,KAAK,EAAE,MAAM;IACb,MAAM,EAAE,MAAM;IACd,SAAS,EAAE,OAAO;IAClB,QAAQ,EAAE,OAAO;IACjB,SAAS,EAAE,OAAO;CACnB,CAAC"}
|
|
@@ -40,6 +40,7 @@ const StyledBrandIconBox = styled(Box, {
|
|
|
40
40
|
name: "BananasNavRail",
|
|
41
41
|
slot: "BrandIconBox",
|
|
42
42
|
})(({ theme }) => theme.unstable_sx({
|
|
43
|
+
width: "100%",
|
|
43
44
|
transition: theme.transitions.create(["transform"], {
|
|
44
45
|
duration: theme.transitions.duration.shortest,
|
|
45
46
|
}),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Branding.js","sourceRoot":"","sources":["../../../../src/components/NavRail/Branding.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,OAAO,GAAG,MAAM,mBAAmB,CAAC;AACpC,OAAO,UAAU,MAAM,0BAA0B,CAAC;AAClD,OAAO,UAAU,MAAM,0BAA0B,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAE9C,OAAO,KAAK,MAAM,mBAAmB,CAAC;AAEtC,OAAO,KAAK,MAAM,UAAU,CAAC;AAc7B,MAAM,YAAY,GAAG,MAAM,CAAC,GAAG,EAAE;IAC/B,IAAI,EAAE,gBAAgB;IACtB,IAAI,EAAE,UAAU;CACjB,CAAC,CAAqC,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,EAAE,EAAE,CAC/D,KAAK,CAAC,WAAW,CAAC;IAChB,OAAO,EAAE,MAAM;IACf,aAAa,EAAE,KAAK;IACpB,UAAU,EAAE,QAAQ;IACpB,QAAQ,EAAE,CAAC;IACX,KAAK,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG;CAC3C,CAAC,CACH,CAAC;AAEF,MAAM,cAAc,GAAG,MAAM,CAAC,GAAG,EAAE;IACjC,IAAI,EAAE,gBAAgB;IACtB,IAAI,EAAE,UAAU;CACjB,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CACf,KAAK,CAAC,WAAW,CAAC;IAChB,QAAQ,EAAE,MAAM;IAChB,WAAW,EAAE,OAAO;IACpB,OAAO,EAAE,oBAAoB;IAC7B,OAAO,EAAE,MAAM;IACf,UAAU,EAAE,QAAQ;IACpB,CAAC,EAAE,GAAG;IACN,YAAY,EAAE,CAAC;IACf,SAAS,EAAE;QACT,OAAO,EAAE,qBAAqB;KAC/B;IACD,iCAAiC,EAAE;QACjC,SAAS,EAAE,YAAY;KACxB;IACD,UAAU,EAAE,KAAK,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,kBAAkB,CAAC,EAAE;QACzD,QAAQ,EAAE,KAAK,CAAC,WAAW,CAAC,QAAQ,CAAC,QAAQ;KAC9C,CAAC;CACH,CAAC,CACH,CAAC;AAEF,MAAM,kBAAkB,GAAG,MAAM,CAAC,GAAG,EAAE;IACrC,IAAI,EAAE,gBAAgB;IACtB,IAAI,EAAE,cAAc;CACrB,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CACf,KAAK,CAAC,WAAW,CAAC;IAChB,UAAU,EAAE,KAAK,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,WAAW,CAAC,EAAE;QAClD,QAAQ,EAAE,KAAK,CAAC,WAAW,CAAC,QAAQ,CAAC,QAAQ;KAC9C,CAAC;CACH,CAAC,CACH,CAAC;AAEF,MAAM,QAAQ,GAA4B,CAAC,EACzC,IAAI,EACJ,KAAK,EACL,QAAQ,EACR,OAAO,EACP,OAAO,EACP,SAAS,EACT,EAAE,GACH,EAAE,EAAE;IACH,MAAM,UAAU,GAAG,EAAE,SAAS,EAAE,CAAC;IAEjC,OAAO,CACL,oBAAC,KAAK,IACJ,EAAE,EAAE;YACF,KAAK,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG;YAC1C,EAAE,EAAE,CAAC;YACL,EAAE,EAAE,GAAG;YACP,SAAS,EAAE,EAAE;SACd;QAED,oBAAC,YAAY,IAAC,UAAU,EAAE,UAAU,EAAE,EAAE,EAAE,EAAE;YAC1C,oBAAC,UAAU,IACT,aAAa,QACb,EAAE,EAAE;oBACF,cAAc,EAAE,YAAY;oBAC5B,KAAK,EAAE,MAAM;oBACb,MAAM,EAAE,MAAM;oBACd,KAAK,EAAE,SAAS;iBACjB,EACD,OAAO,EAAE,OAAO;gBAEf,IAAI,CAAC,CAAC,CAAC,CACN,oBAAC,cAAc;oBACb,oBAAC,kBAAkB;wBACjB,oBAAC,KAAK,IACJ,GAAG,EAAE,IAAI,EACT,SAAS,EAAE;gCACT,KAAK,EAAE;oCACL,SAAS,EAAE,EAAE;iCACd;6BACF,GACD,CACiB,CACN,CAClB,CAAC,CAAC,CAAC,CACF,oBAAC,UAAU,IACT,EAAE,EAAE;wBACF,UAAU,EAAE,MAAM;qBACnB,EACD,KAAK,EAAC,SAAS,EACf,OAAO,EAAC,IAAI,IAEX,KAAK,CACK,CACd;gBACD,oBAAC,GAAG,IACF,EAAE,EAAE;wBACF,UAAU,EAAE,EAAE;wBACd,OAAO,EAAE;4BACP,SAAS,EAAE,MAAM;4BACjB,QAAQ,EAAE,SAAS;4BACnB,OAAO,EAAE,OAAO;4BAChB,UAAU,EAAE,KAAK;yBAClB;qBACF;oBAED,oBAAC,UAAU,IAAC,KAAK,EAAC,SAAS,IAAE,QAAQ,CAAc;oBACnD,oBAAC,UAAU,IAAC,KAAK,EAAC,SAAS,IAAE,OAAO,CAAc,CAC9C,CACK,CACA,CACT,CACT,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,QAAQ,CAAC"}
|
|
1
|
+
{"version":3,"file":"Branding.js","sourceRoot":"","sources":["../../../../src/components/NavRail/Branding.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,10 @@
|
|
|
1
|
-
import
|
|
2
|
-
export const CardContext =
|
|
3
|
-
export const useCardContext = () =>
|
|
1
|
+
import { createContext, useContext } from "react";
|
|
2
|
+
export const CardContext = createContext(undefined);
|
|
3
|
+
export const useCardContext = () => {
|
|
4
|
+
const context = useContext(CardContext);
|
|
5
|
+
if (context == null) {
|
|
6
|
+
throw new Error("useCardContext must be used within a CardProvider. You are most likely not using the correct <Card> parent component.");
|
|
7
|
+
}
|
|
8
|
+
return context;
|
|
9
|
+
};
|
|
4
10
|
//# sourceMappingURL=CardContext.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CardContext.js","sourceRoot":"","sources":["../../../src/contexts/CardContext.tsx"],"names":[],"mappings":"AAAA,
|
|
1
|
+
{"version":3,"file":"CardContext.js","sourceRoot":"","sources":["../../../src/contexts/CardContext.tsx"],"names":[],"mappings":"AAAA,OAAc,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAYzD,MAAM,CAAC,MAAM,WAAW,GAAG,aAAa,CAAc,SAAmC,CAAC,CAAC;AAE3F,MAAM,CAAC,MAAM,cAAc,GAAG,GAAG,EAAE;IACjC,MAAM,OAAO,GAAG,UAAU,CAAC,WAAW,CAAC,CAAC;IACxC,IAAI,OAAO,IAAI,IAAI,EAAE,CAAC;QACpB,MAAM,IAAI,KAAK,CACb,uHAAuH,CACxH,CAAC;IACJ,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC,CAAC"}
|
package/dist/esm/index.js
CHANGED
|
@@ -2,7 +2,6 @@ export * from "./components/TitleBar";
|
|
|
2
2
|
export * from "./components/Header";
|
|
3
3
|
export * from "./components/ActionBar";
|
|
4
4
|
export * from "./components/Link";
|
|
5
|
-
export * from "./components/Card";
|
|
6
5
|
export * from "./components/ChipsInput";
|
|
7
6
|
export * from "./components/Chip";
|
|
8
7
|
export * from "./components/FilterChip";
|
|
@@ -11,6 +10,21 @@ export * from "./components/TabPanels";
|
|
|
11
10
|
export * from "./components/TabPanel";
|
|
12
11
|
export * from "./components/Tab";
|
|
13
12
|
export * from "./components/Page";
|
|
13
|
+
export * from "./components/Card";
|
|
14
|
+
export * from "./components/Card/CardHeader";
|
|
15
|
+
export * from "./components/Card/CardActions";
|
|
16
|
+
export * from "./components/Card/CardContent";
|
|
17
|
+
export * from "./components/Card/CardCancelButton";
|
|
18
|
+
export * from "./components/Card/CardSaveButton";
|
|
19
|
+
export * from "./components/Card/CardRow";
|
|
20
|
+
export * from "./components/Card/CardPill";
|
|
21
|
+
export * from "./components/Card/CardFieldAutoComplete";
|
|
22
|
+
export * from "./components/Card/CardFieldCheckbox";
|
|
23
|
+
export * from "./components/Card/CardFieldImage";
|
|
24
|
+
export * from "./components/Card/CardFieldNumber";
|
|
25
|
+
export * from "./components/Card/CardFieldSelect";
|
|
26
|
+
export * from "./components/Card/CardFieldSwitch";
|
|
27
|
+
export * from "./components/Card/CardFieldText";
|
|
14
28
|
export * from "./contexts/ApiContext";
|
|
15
29
|
export * from "./contexts/I18nContext";
|
|
16
30
|
export * from "./contexts/RouterContext";
|
package/dist/esm/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAC;AACtC,cAAc,qBAAqB,CAAC;AACpC,cAAc,wBAAwB,CAAC;AACvC,cAAc,mBAAmB,CAAC;AAClC,cAAc,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAC;AACtC,cAAc,qBAAqB,CAAC;AACpC,cAAc,wBAAwB,CAAC;AACvC,cAAc,mBAAmB,CAAC;AAClC,cAAc,yBAAyB,CAAC;AACxC,cAAc,mBAAmB,CAAC;AAClC,cAAc,yBAAyB,CAAC;AACxC,cAAc,mBAAmB,CAAC;AAClC,cAAc,wBAAwB,CAAC;AACvC,cAAc,uBAAuB,CAAC;AACtC,cAAc,kBAAkB,CAAC;AACjC,cAAc,mBAAmB,CAAC;AAElC,cAAc,mBAAmB,CAAC;AAClC,cAAc,8BAA8B,CAAC;AAC7C,cAAc,+BAA+B,CAAC;AAC9C,cAAc,+BAA+B,CAAC;AAC9C,cAAc,oCAAoC,CAAC;AACnD,cAAc,kCAAkC,CAAC;AACjD,cAAc,2BAA2B,CAAC;AAC1C,cAAc,4BAA4B,CAAC;AAC3C,cAAc,yCAAyC,CAAC;AACxD,cAAc,qCAAqC,CAAC;AACpD,cAAc,kCAAkC,CAAC;AACjD,cAAc,mCAAmC,CAAC;AAClD,cAAc,mCAAmC,CAAC;AAClD,cAAc,mCAAmC,CAAC;AAClD,cAAc,iCAAiC,CAAC;AAEhD,cAAc,uBAAuB,CAAC;AACtC,cAAc,wBAAwB,CAAC;AACvC,cAAc,0BAA0B,CAAC;AACzC,cAAc,wBAAwB,CAAC;AACvC,cAAc,0BAA0B,CAAC;AAEzC,cAAc,sBAAsB,CAAC;AACrC,cAAc,8BAA8B,CAAC;AAC7C,cAAc,4BAA4B,CAAC;AAE3C,cAAc,SAAS,CAAC;AACxB,cAAc,OAAO,CAAC;AACtB,cAAc,OAAO,CAAC;AAEtB,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAChD,OAAO,KAAK,GAAG,MAAM,kBAAkB,CAAC;AACxC,OAAO,KAAK,WAAW,MAAM,0BAA0B,CAAC;AACxD,OAAO,KAAK,MAAM,MAAM,qBAAqB,CAAC;AAC9C,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAChD,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC"}
|
|
@@ -30,11 +30,11 @@ const StyledBackdrop = styled(Backdrop, {
|
|
|
30
30
|
justifyContent: "center",
|
|
31
31
|
display: "flex",
|
|
32
32
|
}));
|
|
33
|
-
const LoginPage = ({ title, logo, form: Form }) => {
|
|
33
|
+
const LoginPage = ({ title, logo, form: Form, logoHeight }) => {
|
|
34
34
|
Form ??= LoginForm;
|
|
35
35
|
return (React.createElement(Content, null,
|
|
36
36
|
React.createElement(StyledDialog, { open: true, sx: { "> * > *": { width: "100%" } }, PaperProps: { elevation: 1 }, BackdropComponent: StyledBackdrop },
|
|
37
|
-
React.createElement(StyledDialogTitle, null, logo ? (React.createElement(Brand, { src: logo, LogoProps: { style: { height: "24px !important" } } })) : (React.createElement(Typography, { sx: { fontWeight: "bold", color: "inherit" } }, title))),
|
|
37
|
+
React.createElement(StyledDialogTitle, null, logo ? (React.createElement(Brand, { src: logo, LogoProps: { style: { width: "auto", height: logoHeight ?? "24px !important" } } })) : (React.createElement(Typography, { sx: { fontWeight: "bold", color: "inherit" } }, title))),
|
|
38
38
|
React.createElement(Form, null))));
|
|
39
39
|
};
|
|
40
40
|
export default LoginPage;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"LoginPage.js","sourceRoot":"","sources":["../../../src/pages/LoginPage.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,MAAM,MAAM,sBAAsB,CAAC;AAC1C,OAAO,WAAW,MAAM,2BAA2B,CAAC;AACpD,OAAO,QAAQ,MAAM,wBAAwB,CAAC;AAC9C,OAAO,UAAU,MAAM,0BAA0B,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAE9C,OAAO,KAAK,MAAM,qBAAqB,CAAC;AACxC,OAAO,OAAO,MAAM,uBAAuB,CAAC;AAC5C,OAAO,SAAS,MAAM,oBAAoB,CAAC;
|
|
1
|
+
{"version":3,"file":"LoginPage.js","sourceRoot":"","sources":["../../../src/pages/LoginPage.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,MAAM,MAAM,sBAAsB,CAAC;AAC1C,OAAO,WAAW,MAAM,2BAA2B,CAAC;AACpD,OAAO,QAAQ,MAAM,wBAAwB,CAAC;AAC9C,OAAO,UAAU,MAAM,0BAA0B,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAE9C,OAAO,KAAK,MAAM,qBAAqB,CAAC;AACxC,OAAO,OAAO,MAAM,uBAAuB,CAAC;AAC5C,OAAO,SAAS,MAAM,oBAAoB,CAAC;AAU3C,MAAM,YAAY,GAAG,MAAM,CAAC,MAAM,EAAE;IAClC,IAAI,EAAE,oBAAoB;IAC1B,IAAI,EAAE,MAAM;CACb,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;AAEf,MAAM,iBAAiB,GAAG,MAAM,CAAC,WAAW,EAAE;IAC5C,IAAI,EAAE,oBAAoB;IAC1B,IAAI,EAAE,OAAO;CACd,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CACf,KAAK,CAAC,WAAW,CAAC;IAChB,OAAO,EAAE,cAAc;IACvB,KAAK,EAAE,sBAAsB;CAC9B,CAAC,CACH,CAAC;AAEF,MAAM,cAAc,GAAG,MAAM,CAAC,QAAQ,EAAE;IACtC,IAAI,EAAE,oBAAoB;IAC1B,IAAI,EAAE,UAAU;CACjB,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CACf,KAAK,CAAC,WAAW,CAAC;IAChB,OAAO,EAAE,cAAc;IACvB,CAAC,EAAE,CAAC;IACJ,CAAC,EAAE,CAAC;IACJ,SAAS,EAAE,QAAQ;IACnB,UAAU,EAAE,QAAQ;IACpB,cAAc,EAAE,QAAQ;IACxB,OAAO,EAAE,MAAM;CAChB,CAAC,CACH,CAAC;AAEF,MAAM,SAAS,GAA6B,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,UAAU,EAAE,EAAE,EAAE;IACtF,IAAI,KAAK,SAAS,CAAC;IAEnB,OAAO,CACL,oBAAC,OAAO;QACN,oBAAC,YAAY,IACX,IAAI,QACJ,EAAE,EAAE,EAAE,SAAS,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,EACpC,UAAU,EAAE,EAAE,SAAS,EAAE,CAAC,EAAE,EAC5B,iBAAiB,EAAE,cAAc;YAEjC,oBAAC,iBAAiB,QACf,IAAI,CAAC,CAAC,CAAC,CACN,oBAAC,KAAK,IACJ,GAAG,EAAE,IAAI,EACT,SAAS,EAAE,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,UAAU,IAAI,iBAAiB,EAAE,EAAE,GAChF,CACH,CAAC,CAAC,CAAC,CACF,oBAAC,UAAU,IAAC,EAAE,EAAE,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,IAAG,KAAK,CAAc,CAC/E,CACiB;YAEpB,oBAAC,IAAI,OAAG,CACK,CACP,CACX,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,SAAS,CAAC"}
|
package/dist/types/Admin.d.ts
CHANGED
|
@@ -3,6 +3,8 @@ import { RouterProps } from "./router/Router";
|
|
|
3
3
|
import { LogoType, NavigationOverrides } from "./types";
|
|
4
4
|
export interface AdminProps extends RouterProps {
|
|
5
5
|
logo?: LogoType;
|
|
6
|
+
logoSymbol?: LogoType;
|
|
7
|
+
loginLogoHeight?: number | string;
|
|
6
8
|
title?: string;
|
|
7
9
|
subtitle?: string;
|
|
8
10
|
version?: string;
|
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
import { CardProps as MuiCardProps } from "@mui/material/Card";
|
|
2
1
|
import React from "react";
|
|
2
|
+
import { CardProps as MuiCardProps } from "@mui/material/Card";
|
|
3
|
+
export * from "./shared";
|
|
3
4
|
export interface CardProps<T = unknown> extends Omit<MuiCardProps, "onSubmit"> {
|
|
4
5
|
columns?: number;
|
|
5
6
|
isEditable?: boolean;
|
|
@@ -4,16 +4,6 @@ export interface AutocompleteState {
|
|
|
4
4
|
label: string;
|
|
5
5
|
id: string | number;
|
|
6
6
|
}
|
|
7
|
-
export type Field = {
|
|
8
|
-
label: string;
|
|
9
|
-
formName?: string;
|
|
10
|
-
required?: boolean;
|
|
11
|
-
disabled?: boolean;
|
|
12
|
-
options?: AutocompleteState[];
|
|
13
|
-
helperText?: string;
|
|
14
|
-
isReadable?: boolean;
|
|
15
|
-
writable?: boolean;
|
|
16
|
-
};
|
|
17
7
|
export declare const readFieldCSS: (isCompact: boolean) => SxProps;
|
|
18
8
|
export declare const imgCSS: {
|
|
19
9
|
width: string;
|
|
@@ -27,10 +17,13 @@ export interface Pill {
|
|
|
27
17
|
color?: "success" | "error" | "warning" | "info" | "default";
|
|
28
18
|
icon?: React.ReactElement;
|
|
29
19
|
}
|
|
30
|
-
export interface CardFieldBaseProps extends React.PropsWithChildren
|
|
31
|
-
label: string;
|
|
32
|
-
size?: GridSize;
|
|
20
|
+
export interface CardFieldBaseProps extends React.PropsWithChildren {
|
|
33
21
|
formName: string;
|
|
34
|
-
|
|
22
|
+
label: string;
|
|
23
|
+
helperText?: string;
|
|
35
24
|
isDisabled?: boolean;
|
|
25
|
+
isReadable?: boolean;
|
|
26
|
+
options?: AutocompleteState[];
|
|
27
|
+
required?: boolean;
|
|
28
|
+
size?: GridSize;
|
|
36
29
|
}
|
package/dist/types/index.d.ts
CHANGED
|
@@ -2,7 +2,6 @@ export * from "./components/TitleBar";
|
|
|
2
2
|
export * from "./components/Header";
|
|
3
3
|
export * from "./components/ActionBar";
|
|
4
4
|
export * from "./components/Link";
|
|
5
|
-
export * from "./components/Card";
|
|
6
5
|
export * from "./components/ChipsInput";
|
|
7
6
|
export * from "./components/Chip";
|
|
8
7
|
export * from "./components/FilterChip";
|
|
@@ -11,6 +10,21 @@ export * from "./components/TabPanels";
|
|
|
11
10
|
export * from "./components/TabPanel";
|
|
12
11
|
export * from "./components/Tab";
|
|
13
12
|
export * from "./components/Page";
|
|
13
|
+
export * from "./components/Card";
|
|
14
|
+
export * from "./components/Card/CardHeader";
|
|
15
|
+
export * from "./components/Card/CardActions";
|
|
16
|
+
export * from "./components/Card/CardContent";
|
|
17
|
+
export * from "./components/Card/CardCancelButton";
|
|
18
|
+
export * from "./components/Card/CardSaveButton";
|
|
19
|
+
export * from "./components/Card/CardRow";
|
|
20
|
+
export * from "./components/Card/CardPill";
|
|
21
|
+
export * from "./components/Card/CardFieldAutoComplete";
|
|
22
|
+
export * from "./components/Card/CardFieldCheckbox";
|
|
23
|
+
export * from "./components/Card/CardFieldImage";
|
|
24
|
+
export * from "./components/Card/CardFieldNumber";
|
|
25
|
+
export * from "./components/Card/CardFieldSelect";
|
|
26
|
+
export * from "./components/Card/CardFieldSwitch";
|
|
27
|
+
export * from "./components/Card/CardFieldText";
|
|
14
28
|
export * from "./contexts/ApiContext";
|
|
15
29
|
export * from "./contexts/I18nContext";
|
|
16
30
|
export * from "./contexts/RouterContext";
|
package/package.json
CHANGED
package/src/Admin.tsx
CHANGED
|
@@ -14,6 +14,8 @@ import { LogoType, NavigationOverrides } from "./types";
|
|
|
14
14
|
|
|
15
15
|
export interface AdminProps extends RouterProps {
|
|
16
16
|
logo?: LogoType;
|
|
17
|
+
logoSymbol?: LogoType;
|
|
18
|
+
loginLogoHeight?: number | string;
|
|
17
19
|
title?: string;
|
|
18
20
|
subtitle?: string;
|
|
19
21
|
version?: string;
|
|
@@ -29,6 +31,8 @@ export interface AdminProps extends RouterProps {
|
|
|
29
31
|
|
|
30
32
|
export const Admin: React.FC<AdminProps> = ({
|
|
31
33
|
logo,
|
|
34
|
+
logoSymbol,
|
|
35
|
+
loginLogoHeight,
|
|
32
36
|
title,
|
|
33
37
|
subtitle,
|
|
34
38
|
version,
|
|
@@ -61,7 +65,7 @@ export const Admin: React.FC<AdminProps> = ({
|
|
|
61
65
|
{!hasLoaded || !hasTriedToFetchUser ? (
|
|
62
66
|
<LoadingScreen />
|
|
63
67
|
) : !hasUser ? (
|
|
64
|
-
<LoginPage logo={logo} title={title} />
|
|
68
|
+
<LoginPage logo={logo} title={title} logoHeight={loginLogoHeight} />
|
|
65
69
|
) : (
|
|
66
70
|
<BrowserRouter basename={basename}>
|
|
67
71
|
<RouterContextProvider basename={basename} stripPathPrefix={basepath}>
|
|
@@ -70,7 +74,7 @@ export const Admin: React.FC<AdminProps> = ({
|
|
|
70
74
|
<Box sx={{ display: "flex" }}>
|
|
71
75
|
<NavRail
|
|
72
76
|
navigation={navigation}
|
|
73
|
-
logo={
|
|
77
|
+
logo={logoSymbol}
|
|
74
78
|
title={title}
|
|
75
79
|
subtitle={subtitle}
|
|
76
80
|
version={version}
|
package/src/components/Brand.tsx
CHANGED
|
@@ -20,9 +20,10 @@ const Brand: React.FC<BrandProps> = ({ BoxProps, src, sx, LogoProps }) => {
|
|
|
20
20
|
<Box
|
|
21
21
|
sx={ss(
|
|
22
22
|
{
|
|
23
|
+
textAlign: "center",
|
|
23
24
|
width: "100%",
|
|
24
25
|
lineHeight: 0,
|
|
25
|
-
"& > svg": {
|
|
26
|
+
"& > svg, & > img": {
|
|
26
27
|
width: "100% !important",
|
|
27
28
|
height: "100% !important",
|
|
28
29
|
fill: "currentColor",
|
|
@@ -1,12 +1,14 @@
|
|
|
1
|
+
import React, { useCallback, useMemo, useState } from "react";
|
|
1
2
|
import MuiCard, { CardProps as MuiCardProps } from "@mui/material/Card";
|
|
2
3
|
import { useTheme } from "@mui/material/styles";
|
|
3
4
|
import { useSnackbar } from "notistack";
|
|
4
|
-
|
|
5
|
+
|
|
5
6
|
import { CardContext } from "../../contexts/CardContext";
|
|
6
7
|
import { useI18n } from "../../contexts/I18nContext";
|
|
7
8
|
|
|
8
|
-
|
|
9
|
+
export * from "./shared";
|
|
9
10
|
|
|
11
|
+
// TODO Type the `FormData` object.
|
|
10
12
|
export interface CardProps<T = unknown> extends Omit<MuiCardProps, "onSubmit"> {
|
|
11
13
|
columns?: number;
|
|
12
14
|
isEditable?: boolean;
|
|
@@ -15,7 +17,7 @@ export interface CardProps<T = unknown> extends Omit<MuiCardProps, "onSubmit"> {
|
|
|
15
17
|
}
|
|
16
18
|
|
|
17
19
|
const Card: React.FC<CardProps> = ({
|
|
18
|
-
columns,
|
|
20
|
+
columns = 1,
|
|
19
21
|
onSubmit,
|
|
20
22
|
isEditable = false,
|
|
21
23
|
children,
|
|
@@ -31,82 +33,68 @@ const Card: React.FC<CardProps> = ({
|
|
|
31
33
|
const { enqueueSnackbar } = useSnackbar();
|
|
32
34
|
const { t } = useI18n();
|
|
33
35
|
|
|
34
|
-
const handleSubmit =
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
36
|
+
const handleSubmit = useCallback(
|
|
37
|
+
async (event: React.FormEvent<HTMLFormElement>) => {
|
|
38
|
+
if (onSubmit == null) throw new Error("No onSubmit function provided.");
|
|
39
|
+
event.preventDefault();
|
|
40
|
+
|
|
41
|
+
const form = event.currentTarget;
|
|
42
|
+
const formData = new FormData(form);
|
|
43
|
+
const values = Object.fromEntries(formData);
|
|
38
44
|
|
|
39
|
-
|
|
40
|
-
const formData = new FormData(form);
|
|
41
|
-
const values = Object.fromEntries(formData);
|
|
45
|
+
setIsDisabled(true);
|
|
42
46
|
|
|
43
|
-
|
|
47
|
+
try {
|
|
48
|
+
const success = await onSubmit(values);
|
|
49
|
+
enqueueSnackbar(success, { variant: "success" });
|
|
44
50
|
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
51
|
+
setIsEditing(false);
|
|
52
|
+
setIsDisabled(false);
|
|
53
|
+
} catch (error) {
|
|
54
|
+
// TODO Report error to sentry
|
|
55
|
+
console.error("Error when submitting data", error);
|
|
56
|
+
enqueueSnackbar(t("Failed to submit data. Contact support or try again later."), {
|
|
57
|
+
variant: "error",
|
|
58
|
+
});
|
|
59
|
+
// Don't exit edit mode (and clear fields) on error. Give the user the chance to save/fix.
|
|
60
|
+
setIsDisabled(false);
|
|
61
|
+
}
|
|
62
|
+
},
|
|
63
|
+
[onSubmit, enqueueSnackbar, t],
|
|
64
|
+
);
|
|
50
65
|
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
66
|
+
const contextValues = useMemo(
|
|
67
|
+
() => ({
|
|
68
|
+
isDisabled,
|
|
69
|
+
isEditable,
|
|
70
|
+
isEditing,
|
|
71
|
+
setIsEditing,
|
|
72
|
+
columns,
|
|
73
|
+
hasChanges,
|
|
74
|
+
setHasChanges,
|
|
75
|
+
}),
|
|
76
|
+
[isDisabled, isEditable, isEditing, columns, hasChanges],
|
|
77
|
+
);
|
|
63
78
|
|
|
64
79
|
return (
|
|
65
|
-
<CardContext.Provider
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
borderStyle: "solid",
|
|
84
|
-
borderColor: theme.palette.divider,
|
|
85
|
-
backgroundColor: theme.palette.background.paper,
|
|
86
|
-
overflow: "visible",
|
|
87
|
-
}}
|
|
88
|
-
component={isEditable ? "form" : "div"}
|
|
89
|
-
onSubmit={handleSubmit}
|
|
90
|
-
{...props}
|
|
91
|
-
>
|
|
92
|
-
{children}
|
|
93
|
-
</MuiCard>
|
|
94
|
-
) : (
|
|
95
|
-
<MuiCard
|
|
96
|
-
sx={{
|
|
97
|
-
width: "100%",
|
|
98
|
-
boxShadow: 0,
|
|
99
|
-
borderRadius: 3,
|
|
100
|
-
borderWidth: "1px",
|
|
101
|
-
borderStyle: "solid",
|
|
102
|
-
borderColor: theme.palette.divider,
|
|
103
|
-
backgroundColor: theme.palette.background.paper,
|
|
104
|
-
overflow: "visible",
|
|
105
|
-
}}
|
|
106
|
-
>
|
|
107
|
-
{children}
|
|
108
|
-
</MuiCard>
|
|
109
|
-
)}
|
|
80
|
+
<CardContext.Provider value={contextValues}>
|
|
81
|
+
<MuiCard
|
|
82
|
+
sx={{
|
|
83
|
+
width: "100%",
|
|
84
|
+
boxShadow: 0,
|
|
85
|
+
borderRadius: 3,
|
|
86
|
+
borderWidth: "1px",
|
|
87
|
+
borderStyle: "solid",
|
|
88
|
+
borderColor: theme.palette.divider,
|
|
89
|
+
backgroundColor: theme.palette.background.paper,
|
|
90
|
+
overflow: "visible",
|
|
91
|
+
}}
|
|
92
|
+
component={isEditable ? "form" : "div"}
|
|
93
|
+
onSubmit={isEditable ? handleSubmit : undefined}
|
|
94
|
+
{...props}
|
|
95
|
+
>
|
|
96
|
+
{children}
|
|
97
|
+
</MuiCard>
|
|
110
98
|
</CardContext.Provider>
|
|
111
99
|
);
|
|
112
100
|
};
|
|
@@ -6,17 +6,6 @@ export interface AutocompleteState {
|
|
|
6
6
|
id: string | number;
|
|
7
7
|
}
|
|
8
8
|
|
|
9
|
-
export type Field = {
|
|
10
|
-
label: string;
|
|
11
|
-
formName?: string;
|
|
12
|
-
required?: boolean;
|
|
13
|
-
disabled?: boolean;
|
|
14
|
-
options?: AutocompleteState[];
|
|
15
|
-
helperText?: string;
|
|
16
|
-
isReadable?: boolean;
|
|
17
|
-
writable?: boolean;
|
|
18
|
-
};
|
|
19
|
-
|
|
20
9
|
export const readFieldCSS = (isCompact: boolean): SxProps => ({
|
|
21
10
|
display: "flex",
|
|
22
11
|
gap: 0.5,
|
|
@@ -38,10 +27,13 @@ export interface Pill {
|
|
|
38
27
|
icon?: React.ReactElement;
|
|
39
28
|
}
|
|
40
29
|
|
|
41
|
-
export interface CardFieldBaseProps extends React.PropsWithChildren
|
|
42
|
-
label: string;
|
|
43
|
-
size?: GridSize;
|
|
30
|
+
export interface CardFieldBaseProps extends React.PropsWithChildren {
|
|
44
31
|
formName: string;
|
|
45
|
-
|
|
32
|
+
label: string;
|
|
33
|
+
helperText?: string;
|
|
46
34
|
isDisabled?: boolean;
|
|
35
|
+
isReadable?: boolean;
|
|
36
|
+
options?: AutocompleteState[];
|
|
37
|
+
required?: boolean;
|
|
38
|
+
size?: GridSize;
|
|
47
39
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import React from "react";
|
|
1
|
+
import React, { createContext, useContext } from "react";
|
|
2
2
|
|
|
3
3
|
export interface CardContext {
|
|
4
4
|
isEditable: boolean;
|
|
@@ -10,5 +10,15 @@ export interface CardContext {
|
|
|
10
10
|
isDisabled: boolean;
|
|
11
11
|
}
|
|
12
12
|
|
|
13
|
-
export const CardContext =
|
|
14
|
-
|
|
13
|
+
export const CardContext = createContext<CardContext>(undefined as unknown as CardContext);
|
|
14
|
+
|
|
15
|
+
export const useCardContext = () => {
|
|
16
|
+
const context = useContext(CardContext);
|
|
17
|
+
if (context == null) {
|
|
18
|
+
throw new Error(
|
|
19
|
+
"useCardContext must be used within a CardProvider. You are most likely not using the correct <Card> parent component.",
|
|
20
|
+
);
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
return context;
|
|
24
|
+
};
|
package/src/index.ts
CHANGED
|
@@ -2,7 +2,6 @@ export * from "./components/TitleBar";
|
|
|
2
2
|
export * from "./components/Header";
|
|
3
3
|
export * from "./components/ActionBar";
|
|
4
4
|
export * from "./components/Link";
|
|
5
|
-
export * from "./components/Card";
|
|
6
5
|
export * from "./components/ChipsInput";
|
|
7
6
|
export * from "./components/Chip";
|
|
8
7
|
export * from "./components/FilterChip";
|
|
@@ -12,6 +11,22 @@ export * from "./components/TabPanel";
|
|
|
12
11
|
export * from "./components/Tab";
|
|
13
12
|
export * from "./components/Page";
|
|
14
13
|
|
|
14
|
+
export * from "./components/Card";
|
|
15
|
+
export * from "./components/Card/CardHeader";
|
|
16
|
+
export * from "./components/Card/CardActions";
|
|
17
|
+
export * from "./components/Card/CardContent";
|
|
18
|
+
export * from "./components/Card/CardCancelButton";
|
|
19
|
+
export * from "./components/Card/CardSaveButton";
|
|
20
|
+
export * from "./components/Card/CardRow";
|
|
21
|
+
export * from "./components/Card/CardPill";
|
|
22
|
+
export * from "./components/Card/CardFieldAutoComplete";
|
|
23
|
+
export * from "./components/Card/CardFieldCheckbox";
|
|
24
|
+
export * from "./components/Card/CardFieldImage";
|
|
25
|
+
export * from "./components/Card/CardFieldNumber";
|
|
26
|
+
export * from "./components/Card/CardFieldSelect";
|
|
27
|
+
export * from "./components/Card/CardFieldSwitch";
|
|
28
|
+
export * from "./components/Card/CardFieldText";
|
|
29
|
+
|
|
15
30
|
export * from "./contexts/ApiContext";
|
|
16
31
|
export * from "./contexts/I18nContext";
|
|
17
32
|
export * from "./contexts/RouterContext";
|
package/src/pages/LoginPage.tsx
CHANGED
|
@@ -14,6 +14,7 @@ import { LogoType } from "../types";
|
|
|
14
14
|
interface LoginPageProps {
|
|
15
15
|
title?: string;
|
|
16
16
|
logo?: LogoType;
|
|
17
|
+
logoHeight?: number | string;
|
|
17
18
|
form?: React.ElementType;
|
|
18
19
|
}
|
|
19
20
|
|
|
@@ -47,7 +48,7 @@ const StyledBackdrop = styled(Backdrop, {
|
|
|
47
48
|
}),
|
|
48
49
|
);
|
|
49
50
|
|
|
50
|
-
const LoginPage: React.FC<LoginPageProps> = ({ title, logo, form: Form }) => {
|
|
51
|
+
const LoginPage: React.FC<LoginPageProps> = ({ title, logo, form: Form, logoHeight }) => {
|
|
51
52
|
Form ??= LoginForm;
|
|
52
53
|
|
|
53
54
|
return (
|
|
@@ -60,7 +61,10 @@ const LoginPage: React.FC<LoginPageProps> = ({ title, logo, form: Form }) => {
|
|
|
60
61
|
>
|
|
61
62
|
<StyledDialogTitle>
|
|
62
63
|
{logo ? (
|
|
63
|
-
<Brand
|
|
64
|
+
<Brand
|
|
65
|
+
src={logo}
|
|
66
|
+
LogoProps={{ style: { width: "auto", height: logoHeight ?? "24px !important" } }}
|
|
67
|
+
/>
|
|
64
68
|
) : (
|
|
65
69
|
<Typography sx={{ fontWeight: "bold", color: "inherit" }}>{title}</Typography>
|
|
66
70
|
)}
|