@pinnacle0/web-ui 0.4.9-beta.1 → 0.4.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/admin/AdminApp/Menu.d.ts +8 -46
- package/admin/AdminApp/Menu.js +120 -144
- package/admin/AdminApp/Menu.js.map +1 -1
- package/admin/AdminApp/Navigator.d.ts +5 -28
- package/admin/AdminApp/Navigator.js +89 -142
- package/admin/AdminApp/Navigator.js.map +1 -1
- package/admin/AdminApp/RouteSwitch.js +2 -1
- package/admin/AdminApp/RouteSwitch.js.map +1 -1
- package/core/FlatList/VirtualFlatList/Item.d.ts +11 -0
- package/core/FlatList/VirtualFlatList/Item.js +20 -0
- package/core/FlatList/VirtualFlatList/Item.js.map +1 -0
- package/core/FlatList/VirtualFlatList/index.d.ts +8 -0
- package/core/FlatList/VirtualFlatList/index.js +111 -0
- package/core/FlatList/VirtualFlatList/index.js.map +1 -0
- package/core/FlatList/VirtualFlatList/index.less +22 -0
- package/core/FlatList/VirtualFlatList/type.d.ts +20 -0
- package/core/FlatList/VirtualFlatList/type.js +2 -0
- package/core/FlatList/VirtualFlatList/type.js.map +1 -0
- package/core/FlatList/index.d.ts +1 -3
- package/core/FlatList/index.js +27 -76
- package/core/FlatList/index.js.map +1 -1
- package/core/FlatList/shared/Footer/index.d.ts +8 -0
- package/core/FlatList/shared/Footer/index.js +13 -0
- package/core/FlatList/shared/Footer/index.js.map +1 -0
- package/core/FlatList/{Content → shared}/Footer/index.less +3 -2
- package/core/FlatList/shared/GetRowKey.d.ts +2 -0
- package/core/FlatList/shared/GetRowKey.js +12 -0
- package/core/FlatList/shared/GetRowKey.js.map +1 -0
- package/core/FlatList/{Refresh → shared/Spinner}/index.d.ts +1 -1
- package/core/FlatList/shared/Spinner/index.js +10 -0
- package/core/FlatList/shared/Spinner/index.js.map +1 -0
- package/core/FlatList/shared/Spinner/index.less +13 -0
- package/core/FlatList/shared/Wrapper/Loading.d.ts +8 -0
- package/core/FlatList/shared/Wrapper/Loading.js +7 -0
- package/core/FlatList/shared/Wrapper/Loading.js.map +1 -0
- package/core/FlatList/shared/Wrapper/index.d.ts +14 -0
- package/core/FlatList/shared/Wrapper/index.js +109 -0
- package/core/FlatList/shared/Wrapper/index.js.map +1 -0
- package/core/FlatList/shared/Wrapper/index.less +33 -0
- package/core/FlatList/shared/hooks/useBounceSwipe.d.ts +22 -0
- package/core/FlatList/shared/hooks/useBounceSwipe.js +111 -0
- package/core/FlatList/shared/hooks/useBounceSwipe.js.map +1 -0
- package/core/FlatList/shared/hooks/useElementScrollState.d.ts +8 -0
- package/core/FlatList/shared/hooks/useElementScrollState.js +38 -0
- package/core/FlatList/shared/hooks/useElementScrollState.js.map +1 -0
- package/core/FlatList/shared/hooks/useLoadingWithDelay.d.ts +9 -0
- package/core/FlatList/shared/hooks/useLoadingWithDelay.js +52 -0
- package/core/FlatList/shared/hooks/useLoadingWithDelay.js.map +1 -0
- package/core/FlatList/type.d.ts +37 -69
- package/core/FlatList/type.js +1 -1
- package/core/FlatList/type.js.map +1 -1
- package/hooks/useSwipe/controller.js +0 -1
- package/hooks/useSwipe/controller.js.map +1 -1
- package/hooks/useSwipe/type.d.ts +0 -1
- package/hooks/useSwipe/type.js.map +1 -1
- package/package.json +2 -4
- package/util/AdminNavigationUtil.d.ts +3 -3
- package/util/AdminNavigationUtil.js +4 -27
- package/util/AdminNavigationUtil.js.map +1 -1
- package/core/FlatList/Content/Footer/index.d.ts +0 -10
- package/core/FlatList/Content/Footer/index.js +0 -11
- package/core/FlatList/Content/Footer/index.js.map +0 -1
- package/core/FlatList/Content/index.d.ts +0 -9
- package/core/FlatList/Content/index.js +0 -71
- package/core/FlatList/Content/index.js.map +0 -1
- package/core/FlatList/Loader/index.d.ts +0 -3
- package/core/FlatList/Loader/index.js +0 -9
- package/core/FlatList/Loader/index.js.map +0 -1
- package/core/FlatList/Loader/index.less +0 -39
- package/core/FlatList/Refresh/index.js +0 -8
- package/core/FlatList/Refresh/index.js.map +0 -1
- package/core/FlatList/Refresh/index.less +0 -22
- package/core/FlatList/index.less +0 -36
- package/core/FlatList/useGap.d.ts +0 -2
- package/core/FlatList/useGap.js +0 -12
- package/core/FlatList/useGap.js.map +0 -1
- package/core/FlatList/util.d.ts +0 -8
- package/core/FlatList/util.js +0 -35
- package/core/FlatList/util.js.map +0 -1
- package/internal/polyfill/IntersectionObserver.d.ts +0 -1
- package/internal/polyfill/IntersectionObserver.js +0 -5
- package/internal/polyfill/IntersectionObserver.js.map +0 -1
package/admin/AdminApp/Menu.d.ts
CHANGED
|
@@ -1,54 +1,16 @@
|
|
|
1
|
-
|
|
2
|
-
import { AdminAppContext } from "./context";
|
|
3
|
-
import type { RouteComponentProps } from "react-router-dom";
|
|
4
|
-
import "antd/es/menu/style";
|
|
1
|
+
/// <reference types="react" />
|
|
5
2
|
import type { NavigationGroupItem } from "../../util/AdminNavigationUtil";
|
|
6
|
-
|
|
3
|
+
import "antd/es/menu/style";
|
|
4
|
+
interface Badges {
|
|
5
|
+
[key: string]: number;
|
|
6
|
+
}
|
|
7
|
+
interface Props<Feature, Field> {
|
|
7
8
|
siteName: string;
|
|
8
9
|
permissions: Feature[];
|
|
9
10
|
superAdminPermission: Feature;
|
|
10
11
|
navigationGroups: Array<NavigationGroupItem<Feature, Field>>;
|
|
11
12
|
menuExpanded: boolean;
|
|
12
|
-
badges?:
|
|
13
|
-
[key: string]: number;
|
|
14
|
-
};
|
|
15
|
-
}
|
|
16
|
-
interface State {
|
|
17
|
-
currentOpenedMenuKey: string | null;
|
|
18
|
-
currentSelectedMenuKey: string | null;
|
|
19
|
-
}
|
|
20
|
-
declare class RouterAwareMenu<Feature, Field> extends React.PureComponent<Props<Feature, Field>, State> {
|
|
21
|
-
static displayName: string;
|
|
22
|
-
static contextType: React.Context<import("./context").AdminAppContextType>;
|
|
23
|
-
context: React.ContextType<typeof AdminAppContext>;
|
|
24
|
-
private readonly soundEnabledKey;
|
|
25
|
-
constructor(props: Props<Feature, Field>);
|
|
26
|
-
componentDidUpdate(prevProps: Props<Feature, Field>): void;
|
|
27
|
-
/**
|
|
28
|
-
* Return true if any field of currentBadges > prevBadges.
|
|
29
|
-
*/
|
|
30
|
-
shouldAlertNewBadge: (prevBadges: {
|
|
31
|
-
[key: string]: number;
|
|
32
|
-
}, currentBadges: {
|
|
33
|
-
[key: string]: number;
|
|
34
|
-
}) => boolean;
|
|
35
|
-
calculateTotalBadge: (badges: {
|
|
36
|
-
[key: string]: number;
|
|
37
|
-
}) => number;
|
|
38
|
-
calculateMenuKeyByURL: (prevBadges?: {
|
|
39
|
-
[key: string]: number;
|
|
40
|
-
} | undefined) => State;
|
|
41
|
-
onMenuOpenChange: (openKeys: string[]) => void;
|
|
42
|
-
renderMenuGroup: (groupItem: NavigationGroupItem<any, any>) => {
|
|
43
|
-
children: {
|
|
44
|
-
label: JSX.Element;
|
|
45
|
-
key: string;
|
|
46
|
-
onClick(): void;
|
|
47
|
-
}[];
|
|
48
|
-
label: JSX.Element;
|
|
49
|
-
key: string;
|
|
50
|
-
};
|
|
51
|
-
render(): JSX.Element;
|
|
13
|
+
badges?: Badges;
|
|
52
14
|
}
|
|
53
|
-
export declare
|
|
15
|
+
export declare function Menu<Feature, Field>({ siteName, permissions, superAdminPermission, navigationGroups, menuExpanded, badges }: Props<Feature, Field>): JSX.Element;
|
|
54
16
|
export {};
|
package/admin/AdminApp/Menu.js
CHANGED
|
@@ -1,29 +1,3 @@
|
|
|
1
|
-
var __extends = (this && this.__extends) || (function () {
|
|
2
|
-
var extendStatics = function (d, b) {
|
|
3
|
-
extendStatics = Object.setPrototypeOf ||
|
|
4
|
-
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
|
|
5
|
-
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
|
|
6
|
-
return extendStatics(d, b);
|
|
7
|
-
};
|
|
8
|
-
return function (d, b) {
|
|
9
|
-
if (typeof b !== "function" && b !== null)
|
|
10
|
-
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
|
|
11
|
-
extendStatics(d, b);
|
|
12
|
-
function __() { this.constructor = d; }
|
|
13
|
-
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
|
14
|
-
};
|
|
15
|
-
})();
|
|
16
|
-
var __values = (this && this.__values) || function(o) {
|
|
17
|
-
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
|
|
18
|
-
if (m) return m.call(o);
|
|
19
|
-
if (o && typeof o.length === "number") return {
|
|
20
|
-
next: function () {
|
|
21
|
-
if (o && i >= o.length) o = void 0;
|
|
22
|
-
return { value: o && o[i++], done: !o };
|
|
23
|
-
}
|
|
24
|
-
};
|
|
25
|
-
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
|
|
26
|
-
};
|
|
27
1
|
var __read = (this && this.__read) || function (o, n) {
|
|
28
2
|
var m = typeof Symbol === "function" && o[Symbol.iterator];
|
|
29
3
|
if (!m) return o;
|
|
@@ -40,137 +14,139 @@ var __read = (this && this.__read) || function (o, n) {
|
|
|
40
14
|
}
|
|
41
15
|
return ar;
|
|
42
16
|
};
|
|
17
|
+
var __values = (this && this.__values) || function(o) {
|
|
18
|
+
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
|
|
19
|
+
if (m) return m.call(o);
|
|
20
|
+
if (o && typeof o.length === "number") return {
|
|
21
|
+
next: function () {
|
|
22
|
+
if (o && i >= o.length) o = void 0;
|
|
23
|
+
return { value: o && o[i++], done: !o };
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
|
|
27
|
+
};
|
|
43
28
|
import React from "react";
|
|
44
|
-
import {
|
|
29
|
+
import { useHistory, useLocation } from "react-router-dom";
|
|
45
30
|
import AntMenu from "antd/es/menu";
|
|
46
31
|
import { LocalStorageUtil } from "../../util/LocalStorageUtil";
|
|
47
32
|
import { MediaUtil } from "../../util/MediaUtil";
|
|
48
33
|
import { Badge } from "../../core/Badge";
|
|
49
|
-
import { AdminAppContext } from "./context";
|
|
50
|
-
import "antd/es/menu/style";
|
|
51
34
|
import { AdminNavigationUtil } from "../../util/AdminNavigationUtil";
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
|
74
|
-
}
|
|
75
|
-
finally { if (e_1) throw e_1.error; }
|
|
76
|
-
}
|
|
77
|
-
return false;
|
|
78
|
-
};
|
|
79
|
-
_this.calculateTotalBadge = function (badges) {
|
|
80
|
-
var _a = _this.props, navigationGroups = _a.navigationGroups, permissions = _a.permissions, superAdminPermission = _a.superAdminPermission;
|
|
81
|
-
var totalCount = 0;
|
|
82
|
-
AdminNavigationUtil.groups(navigationGroups, permissions, superAdminPermission, false).forEach(function (_a) {
|
|
83
|
-
var modules = _a.modules;
|
|
84
|
-
modules.forEach(function (_) { return (totalCount += badges[_.url] || 0); });
|
|
85
|
-
});
|
|
86
|
-
return totalCount;
|
|
87
|
-
};
|
|
88
|
-
_this.calculateMenuKeyByURL = function (prevBadges) {
|
|
89
|
-
var _a;
|
|
90
|
-
var _b = _this.props, location = _b.location, menuExpanded = _b.menuExpanded, siteName = _b.siteName, badges = _b.badges, navigationGroups = _b.navigationGroups, permissions = _b.permissions, superAdminPermission = _b.superAdminPermission;
|
|
91
|
-
var allNavigationGroups = AdminNavigationUtil.groups(navigationGroups, permissions, superAdminPermission, true);
|
|
92
|
-
var currentOpenedMenuKey = ((_a = allNavigationGroups === null || allNavigationGroups === void 0 ? void 0 : allNavigationGroups[0]) === null || _a === void 0 ? void 0 : _a.title) || null; // Fallback opened key
|
|
93
|
-
var currentSelectedMenuKey = null;
|
|
94
|
-
var currentModule = AdminNavigationUtil.moduleByURL(location.pathname, navigationGroups, permissions, superAdminPermission);
|
|
95
|
-
var totalBadgeCount = badges ? _this.calculateTotalBadge(badges) : 0;
|
|
96
|
-
var titlePrefix = (totalBadgeCount > 0 ? "(".concat(totalBadgeCount, ") ") : "") + siteName;
|
|
97
|
-
var soundEnabled = LocalStorageUtil.getBool(_this.soundEnabledKey, true);
|
|
98
|
-
if (soundEnabled && prevBadges && badges && _this.shouldAlertNewBadge(prevBadges, badges)) {
|
|
99
|
-
MediaUtil.playAudio(require("./asset/alert.mp3"));
|
|
100
|
-
}
|
|
101
|
-
if (currentModule) {
|
|
102
|
-
var matchedGroup = allNavigationGroups.find(function (_) { return _.modules.includes(currentModule); });
|
|
103
|
-
if (matchedGroup) {
|
|
104
|
-
currentOpenedMenuKey = matchedGroup.title;
|
|
105
|
-
currentSelectedMenuKey = currentModule.url;
|
|
35
|
+
import "antd/es/menu/style";
|
|
36
|
+
var SOUND_ENABLED_KEY = "admin-sound-enabled";
|
|
37
|
+
export function Menu(_a) {
|
|
38
|
+
var siteName = _a.siteName, permissions = _a.permissions, superAdminPermission = _a.superAdminPermission, navigationGroups = _a.navigationGroups, menuExpanded = _a.menuExpanded, badges = _a.badges;
|
|
39
|
+
var _b = __read(React.useState(null), 2), currentOpenedMenuKey = _b[0], setCurrentOpenedMenuKey = _b[1];
|
|
40
|
+
var _c = __read(React.useState(null), 2), currentSelectedMenuKey = _c[0], setCurrentSelectedMenuKey = _c[1];
|
|
41
|
+
var _d = __read(React.useState(undefined), 2), prevBadges = _d[0], setPrevBadges = _d[1];
|
|
42
|
+
var history = useHistory();
|
|
43
|
+
var location = useLocation();
|
|
44
|
+
var shownNavigationGroups = React.useMemo(function () { return AdminNavigationUtil.groups(navigationGroups, permissions, superAdminPermission, false); }, [navigationGroups, permissions, superAdminPermission]);
|
|
45
|
+
var modules = React.useMemo(function () { return AdminNavigationUtil.modules(shownNavigationGroups); }, [shownNavigationGroups]);
|
|
46
|
+
/**
|
|
47
|
+
* Return true if any field of currentBadges > prevBadges.
|
|
48
|
+
*/
|
|
49
|
+
var shouldAlertNewBadge = React.useCallback(function (badges) {
|
|
50
|
+
var e_1, _a;
|
|
51
|
+
try {
|
|
52
|
+
for (var _b = __values(Object.entries(badges)), _c = _b.next(); !_c.done; _c = _b.next()) {
|
|
53
|
+
var _d = __read(_c.value, 2), key = _d[0], badge = _d[1];
|
|
54
|
+
if (prevBadges && (prevBadges[key] === undefined || badge > prevBadges[key])) {
|
|
55
|
+
return true;
|
|
106
56
|
}
|
|
107
|
-
document.title = titlePrefix + " - " + currentModule.title;
|
|
108
|
-
}
|
|
109
|
-
else {
|
|
110
|
-
document.title = titlePrefix;
|
|
111
57
|
}
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
_this.onMenuOpenChange = function (openKeys) {
|
|
118
|
-
var length = openKeys.length;
|
|
119
|
-
if (length === 0) {
|
|
120
|
-
_this.setState({ currentOpenedMenuKey: null });
|
|
58
|
+
}
|
|
59
|
+
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
|
60
|
+
finally {
|
|
61
|
+
try {
|
|
62
|
+
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
|
121
63
|
}
|
|
122
|
-
|
|
123
|
-
|
|
64
|
+
finally { if (e_1) throw e_1.error; }
|
|
65
|
+
}
|
|
66
|
+
return false;
|
|
67
|
+
}, [prevBadges]);
|
|
68
|
+
var calculateTotalBadge = React.useCallback(function (badges) {
|
|
69
|
+
var totalCount = 0;
|
|
70
|
+
shownNavigationGroups.forEach(function (_a) {
|
|
71
|
+
var modules = _a.modules;
|
|
72
|
+
modules.forEach(function (_) { return (totalCount += badges[_.url] || 0); });
|
|
73
|
+
});
|
|
74
|
+
return totalCount;
|
|
75
|
+
}, [shownNavigationGroups]);
|
|
76
|
+
var calculateMenuKeyByURL = React.useCallback(function () {
|
|
77
|
+
var _a;
|
|
78
|
+
var currentOpenedMenuKey = ((_a = shownNavigationGroups === null || shownNavigationGroups === void 0 ? void 0 : shownNavigationGroups[0]) === null || _a === void 0 ? void 0 : _a.title) || null; // Fallback opened key
|
|
79
|
+
var currentSelectedMenuKey = null;
|
|
80
|
+
var currentModule = AdminNavigationUtil.moduleByURL(location.pathname, modules);
|
|
81
|
+
var totalBadgeCount = badges ? calculateTotalBadge(badges) : 0;
|
|
82
|
+
var titlePrefix = (totalBadgeCount > 0 ? "(".concat(totalBadgeCount, ") ") : "") + siteName;
|
|
83
|
+
var soundEnabled = LocalStorageUtil.getBool(SOUND_ENABLED_KEY, true);
|
|
84
|
+
if (soundEnabled && prevBadges && badges && shouldAlertNewBadge(badges)) {
|
|
85
|
+
MediaUtil.playAudio(require("./asset/alert.mp3"));
|
|
86
|
+
}
|
|
87
|
+
if (currentModule) {
|
|
88
|
+
var matchedGroup = shownNavigationGroups.find(function (_) { return _.modules.includes(currentModule); });
|
|
89
|
+
if (matchedGroup) {
|
|
90
|
+
currentOpenedMenuKey = matchedGroup.title;
|
|
91
|
+
currentSelectedMenuKey = currentModule.url;
|
|
124
92
|
}
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
93
|
+
document.title = titlePrefix + " - " + currentModule.title;
|
|
94
|
+
}
|
|
95
|
+
else {
|
|
96
|
+
document.title = titlePrefix;
|
|
97
|
+
}
|
|
98
|
+
if (!menuExpanded) {
|
|
99
|
+
currentOpenedMenuKey = null; // Otherwise, AntD will pop this menu
|
|
100
|
+
}
|
|
101
|
+
return { currentOpenedMenuKey: currentOpenedMenuKey, currentSelectedMenuKey: currentSelectedMenuKey };
|
|
102
|
+
}, [shownNavigationGroups, location, modules, badges, calculateTotalBadge, menuExpanded, prevBadges, shouldAlertNewBadge, siteName]);
|
|
103
|
+
var onMenuOpenChange = function (openKeys) {
|
|
104
|
+
var length = openKeys.length;
|
|
105
|
+
if (length === 0) {
|
|
106
|
+
setCurrentOpenedMenuKey(null);
|
|
107
|
+
}
|
|
108
|
+
else if (length === 1) {
|
|
109
|
+
setCurrentOpenedMenuKey(openKeys[0]);
|
|
110
|
+
}
|
|
111
|
+
else {
|
|
112
|
+
var index = openKeys.indexOf(currentOpenedMenuKey); // By logic, index should be 0/1 (length should be 2)
|
|
113
|
+
if (index >= 0) {
|
|
114
|
+
setCurrentOpenedMenuKey(openKeys[length - 1 - index]);
|
|
130
115
|
}
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
return {
|
|
140
|
-
label: React.createElement(Badge, { count: count }, title),
|
|
141
|
-
key: url,
|
|
142
|
-
onClick: function () {
|
|
143
|
-
history.push(url);
|
|
144
|
-
},
|
|
145
|
-
};
|
|
146
|
-
});
|
|
147
|
-
var label = (React.createElement(Badge, { count: totalCount },
|
|
148
|
-
groupItem.icon,
|
|
149
|
-
" ",
|
|
150
|
-
menuExpanded ? groupItem.title : ""));
|
|
116
|
+
}
|
|
117
|
+
};
|
|
118
|
+
var renderMenuGroup = function (groupItem) {
|
|
119
|
+
var totalCount = 0;
|
|
120
|
+
var children = groupItem.modules.map(function (_a) {
|
|
121
|
+
var title = _a.title, url = _a.url;
|
|
122
|
+
var count = (badges === null || badges === void 0 ? void 0 : badges[url]) || 0;
|
|
123
|
+
totalCount += count;
|
|
151
124
|
return {
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
125
|
+
label: React.createElement(Badge, { count: count }, title),
|
|
126
|
+
key: url,
|
|
127
|
+
onClick: function () {
|
|
128
|
+
history.push(url);
|
|
129
|
+
},
|
|
155
130
|
};
|
|
131
|
+
});
|
|
132
|
+
var label = (React.createElement(Badge, { count: totalCount },
|
|
133
|
+
groupItem.icon,
|
|
134
|
+
" ",
|
|
135
|
+
menuExpanded ? groupItem.title : ""));
|
|
136
|
+
return {
|
|
137
|
+
children: children,
|
|
138
|
+
label: label,
|
|
139
|
+
key: groupItem.title,
|
|
156
140
|
};
|
|
157
|
-
_this.state = _this.calculateMenuKeyByURL();
|
|
158
|
-
return _this;
|
|
159
|
-
}
|
|
160
|
-
RouterAwareMenu.prototype.componentDidUpdate = function (prevProps) {
|
|
161
|
-
var _a = this.props, location = _a.location, menuExpanded = _a.menuExpanded, badges = _a.badges;
|
|
162
|
-
if (prevProps.location.pathname !== location.pathname || prevProps.menuExpanded !== menuExpanded || prevProps.badges !== badges) {
|
|
163
|
-
this.setState(this.calculateMenuKeyByURL(prevProps.badges));
|
|
164
|
-
}
|
|
165
|
-
};
|
|
166
|
-
RouterAwareMenu.prototype.render = function () {
|
|
167
|
-
var _a = this.props, navigationGroups = _a.navigationGroups, permissions = _a.permissions, superAdminPermission = _a.superAdminPermission;
|
|
168
|
-
var _b = this.state, currentOpenedMenuKey = _b.currentOpenedMenuKey, currentSelectedMenuKey = _b.currentSelectedMenuKey;
|
|
169
|
-
return (React.createElement(AntMenu, { theme: "dark", mode: "inline", openKeys: currentOpenedMenuKey ? [currentOpenedMenuKey] : [], selectedKeys: currentSelectedMenuKey ? [currentSelectedMenuKey] : [], onOpenChange: this.onMenuOpenChange, items: AdminNavigationUtil.groups(navigationGroups, permissions, superAdminPermission, false).map(this.renderMenuGroup) }));
|
|
170
141
|
};
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
142
|
+
React.useEffect(function () {
|
|
143
|
+
var _a = calculateMenuKeyByURL(), currentOpenedMenuKey = _a.currentOpenedMenuKey, currentSelectedMenuKey = _a.currentSelectedMenuKey;
|
|
144
|
+
setCurrentOpenedMenuKey(currentOpenedMenuKey);
|
|
145
|
+
setCurrentSelectedMenuKey(currentSelectedMenuKey);
|
|
146
|
+
}, [location.pathname, menuExpanded, badges, calculateMenuKeyByURL]);
|
|
147
|
+
React.useEffect(function () {
|
|
148
|
+
setPrevBadges(badges);
|
|
149
|
+
}, [badges]);
|
|
150
|
+
return (React.createElement(AntMenu, { theme: "dark", mode: "inline", openKeys: currentOpenedMenuKey ? [currentOpenedMenuKey] : [], selectedKeys: currentSelectedMenuKey ? [currentSelectedMenuKey] : [], onOpenChange: onMenuOpenChange, items: shownNavigationGroups.map(renderMenuGroup) }));
|
|
151
|
+
}
|
|
176
152
|
//# sourceMappingURL=Menu.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Menu.js","sourceRoot":"","sources":["../../../src/admin/AdminApp/Menu.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"Menu.js","sourceRoot":"","sources":["../../../src/admin/AdminApp/Menu.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,32 +1,9 @@
|
|
|
1
|
-
|
|
2
|
-
import type {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
interface NavigatorTabItem {
|
|
6
|
-
url: string;
|
|
7
|
-
module: NavigationModuleItem<any, any>;
|
|
8
|
-
historyState?: any;
|
|
9
|
-
customTitle?: string | null;
|
|
10
|
-
}
|
|
11
|
-
interface Props<Feature, Field> extends RouteComponentProps {
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import type { NavigationGroupItem } from "../../util/AdminNavigationUtil";
|
|
3
|
+
interface Props<Feature, Field> {
|
|
4
|
+
navigationGroups: Array<NavigationGroupItem<Feature, Field>>;
|
|
12
5
|
permissions: Feature[];
|
|
13
6
|
superAdminPermission: Feature;
|
|
14
|
-
navigationGroups: Array<NavigationGroupItem<Feature, Field>>;
|
|
15
|
-
}
|
|
16
|
-
interface State {
|
|
17
|
-
tabs: NavigatorTabItem[];
|
|
18
|
-
}
|
|
19
|
-
declare class RouterAwareNavigator<Feature, Field> extends React.PureComponent<Props<Feature, Field>, State> {
|
|
20
|
-
static displayName: string;
|
|
21
|
-
static contextType: React.Context<import("./context").AdminAppContextType>;
|
|
22
|
-
context: React.ContextType<typeof AdminAppContext>;
|
|
23
|
-
constructor(props: Props<Feature, Field>);
|
|
24
|
-
componentDidMount(): void;
|
|
25
|
-
componentDidUpdate(prevProps: Props<Feature, Field>): void;
|
|
26
|
-
computeIndexByURL: (url: string) => number;
|
|
27
|
-
onTabClose: (key: string | React.MouseEvent | React.KeyboardEvent) => void;
|
|
28
|
-
onTabChange: (url: string) => void;
|
|
29
|
-
render(): JSX.Element;
|
|
30
7
|
}
|
|
31
|
-
export declare
|
|
8
|
+
export declare function Navigator<Feature, Field>({ permissions, superAdminPermission, navigationGroups }: Props<Feature, Field>): JSX.Element;
|
|
32
9
|
export {};
|