@blaze-cms/plugin-admin-core-ui 0.146.0-translations.8 → 0.147.0-rc-eagle.4
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/lib/components/Header/Header.js +18 -20
- package/lib/components/Header/Header.js.map +1 -1
- package/lib/components/Header/components/Language/Language.js +10 -12
- package/lib/components/Header/components/Language/Language.js.map +1 -1
- package/lib/components/Header/components/Language/index.js +2 -3
- package/lib/components/Header/components/Language/index.js.map +1 -1
- package/lib/components/Header/components/Logo/Logo.js +14 -13
- package/lib/components/Header/components/Logo/Logo.js.map +1 -1
- package/lib/components/Header/components/Logo/index.js +2 -3
- package/lib/components/Header/components/Logo/index.js.map +1 -1
- package/lib/components/Header/components/Menu/Menu.js +15 -15
- package/lib/components/Header/components/Menu/Menu.js.map +1 -1
- package/lib/components/Header/components/Menu/index.js +2 -3
- package/lib/components/Header/components/Menu/index.js.map +1 -1
- package/lib/components/Header/components/index.js +6 -7
- package/lib/components/Header/components/index.js.map +1 -1
- package/lib/components/Header/index.js +2 -3
- package/lib/components/Header/index.js.map +1 -1
- package/lib/components/Layout/Background.js +10 -12
- package/lib/components/Layout/Background.js.map +1 -1
- package/lib/components/Layout/Layout.js +26 -39
- package/lib/components/Layout/Layout.js.map +1 -1
- package/lib/components/Layout/components/Grid/Grid.js +20 -22
- package/lib/components/Layout/components/Grid/Grid.js.map +1 -1
- package/lib/components/Layout/components/Grid/index.js +2 -3
- package/lib/components/Layout/components/Grid/index.js.map +1 -1
- package/lib/components/Layout/components/index.js +2 -3
- package/lib/components/Layout/components/index.js.map +1 -1
- package/lib/components/Menu/Icons/ChevronDown.js +18 -22
- package/lib/components/Menu/Icons/ChevronDown.js.map +1 -1
- package/lib/components/Menu/Icons/ChevronUp.js +18 -22
- package/lib/components/Menu/Icons/ChevronUp.js.map +1 -1
- package/lib/components/Menu/Items/MenuActionItem.js +21 -19
- package/lib/components/Menu/Items/MenuActionItem.js.map +1 -1
- package/lib/components/Menu/Items/MenuItem.js +29 -33
- package/lib/components/Menu/Items/MenuItem.js.map +1 -1
- package/lib/components/Menu/Items/MenuLinkItem.js +20 -20
- package/lib/components/Menu/Items/MenuLinkItem.js.map +1 -1
- package/lib/components/Menu/Menu.js +22 -59
- package/lib/components/Menu/Menu.js.map +1 -1
- package/lib/components/Menu/Section/MenuSection.js +10 -12
- package/lib/components/Menu/Section/MenuSection.js.map +1 -1
- package/lib/components/Menu/Section/MenuSectionCollapsible.js +32 -47
- package/lib/components/Menu/Section/MenuSectionCollapsible.js.map +1 -1
- package/lib/components/Menu/Section/MenuSectionItem.js +13 -15
- package/lib/components/Menu/Section/MenuSectionItem.js.map +1 -1
- package/lib/components/Menu/Section/MenuSectionItems.js +14 -19
- package/lib/components/Menu/Section/MenuSectionItems.js.map +1 -1
- package/lib/components/Menu/index.js +2 -3
- package/lib/components/Menu/index.js.map +1 -1
- package/lib/components/SideBar/SideBar.js +35 -46
- package/lib/components/SideBar/SideBar.js.map +1 -1
- package/lib/components/SideBar/components/SideBlock.js +27 -43
- package/lib/components/SideBar/components/SideBlock.js.map +1 -1
- package/lib/components/SideBar/components/SideBlockItem.js +14 -17
- package/lib/components/SideBar/components/SideBlockItem.js.map +1 -1
- package/lib/components/SideBar/components/index.js +2 -3
- package/lib/components/SideBar/components/index.js.map +1 -1
- package/lib/components/SideBar/index.js +2 -3
- package/lib/components/SideBar/index.js.map +1 -1
- package/lib/components/index.js +2 -3
- package/lib/components/index.js.map +1 -1
- package/lib/constants.js +5 -6
- package/lib/constants.js.map +1 -1
- package/lib/containers/Home/Home.js +3 -6
- package/lib/containers/Home/Home.js.map +1 -1
- package/lib/containers/index.js +2 -3
- package/lib/containers/index.js.map +1 -1
- package/lib/index.js +26 -61
- package/lib/index.js.map +1 -1
- package/lib/utils/get-menu-items-resolver.js +12 -24
- package/lib/utils/get-menu-items-resolver.js.map +1 -1
- package/lib/utils/menu-handler-singleton.js +56 -99
- package/lib/utils/menu-handler-singleton.js.map +1 -1
- package/lib/utils/menu-handler.js +24 -39
- package/lib/utils/menu-handler.js.map +1 -1
- package/lib-es/components/Header/Header.js +2 -2
- package/lib-es/components/Header/Header.js.map +1 -1
- package/lib-es/components/Layout/Layout.js.map +1 -1
- package/lib-es/components/Menu/Items/MenuActionItem.js.map +1 -1
- package/lib-es/components/Menu/Items/MenuItem.js.map +1 -1
- package/lib-es/components/Menu/Items/MenuLinkItem.js.map +1 -1
- package/lib-es/components/SideBar/SideBar.js.map +1 -1
- package/lib-es/components/SideBar/components/SideBlock.js.map +1 -1
- package/lib-es/index.js +1 -1
- package/lib-es/index.js.map +1 -1
- package/lib-es/utils/menu-handler-singleton.js +4 -0
- package/lib-es/utils/menu-handler-singleton.js.map +1 -1
- package/lib-es/utils/menu-handler.js.map +1 -1
- package/package.json +26 -18
- package/src/components/Header/Header.js +10 -13
- package/src/utils/menu-handler-singleton.js +2 -0
- package/CHANGELOG.md +0 -1276
- package/babel.config.js +0 -3
- package/jest.config.js +0 -5
package/lib/index.js
CHANGED
|
@@ -4,72 +4,37 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
|
|
|
4
4
|
Object.defineProperty(exports, "__esModule", {
|
|
5
5
|
value: true
|
|
6
6
|
});
|
|
7
|
-
exports
|
|
8
|
-
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
9
|
-
var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
|
|
10
|
-
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
11
|
-
require("core-js/modules/es.array.iterator.js");
|
|
12
|
-
require("core-js/modules/es.object.define-property.js");
|
|
13
|
-
require("core-js/modules/es.object.get-own-property-descriptor.js");
|
|
14
|
-
require("core-js/modules/es.object.to-string.js");
|
|
15
|
-
require("core-js/modules/es.promise.js");
|
|
16
|
-
require("core-js/modules/es.string.iterator.js");
|
|
17
|
-
require("core-js/modules/es.weak-map.js");
|
|
18
|
-
require("core-js/modules/web.dom-collections.iterator.js");
|
|
7
|
+
exports.default = void 0;
|
|
19
8
|
var _react = _interopRequireDefault(require("react"));
|
|
20
9
|
var _components = require("./components");
|
|
21
10
|
var _package = _interopRequireDefault(require("../package.json"));
|
|
22
11
|
var _constants = require("./constants");
|
|
23
12
|
var _menuHandlerSingleton = _interopRequireDefault(require("./utils/menu-handler-singleton"));
|
|
24
|
-
function
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
path: '/',
|
|
49
|
-
exact: true,
|
|
50
|
-
key: 'home',
|
|
51
|
-
redirect: homeRoute,
|
|
52
|
-
component: Home
|
|
53
|
-
};
|
|
54
|
-
app.addRoute(home);
|
|
55
|
-
_menuHandlerSingleton["default"].setApp(app);
|
|
56
|
-
app.setLayout(_components.Layout);
|
|
57
|
-
app.events.once('admin:menu:config:load:after', function (_ref) {
|
|
58
|
-
var addConfig = _ref.addConfig;
|
|
59
|
-
return addConfig(menuConfig);
|
|
60
|
-
});
|
|
61
|
-
return _context.abrupt("return", {
|
|
62
|
-
name: _constants.PLUGIN_NAME,
|
|
63
|
-
version: _package["default"].version
|
|
64
|
-
});
|
|
65
|
-
case 8:
|
|
66
|
-
case "end":
|
|
67
|
-
return _context.stop();
|
|
68
|
-
}
|
|
69
|
-
}, _callee);
|
|
70
|
-
}));
|
|
71
|
-
return _load.apply(this, arguments);
|
|
13
|
+
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); }
|
|
14
|
+
const Home = /*#__PURE__*/_react.default.lazy(() => Promise.resolve().then(() => _interopRequireWildcard(require('./containers'))));
|
|
15
|
+
async function load(app, options = {}) {
|
|
16
|
+
const {
|
|
17
|
+
menuConfig = {},
|
|
18
|
+
homeRoute
|
|
19
|
+
} = options;
|
|
20
|
+
const home = {
|
|
21
|
+
path: '/',
|
|
22
|
+
exact: true,
|
|
23
|
+
key: 'home',
|
|
24
|
+
redirect: homeRoute,
|
|
25
|
+
component: Home
|
|
26
|
+
};
|
|
27
|
+
app.addRoute(home);
|
|
28
|
+
_menuHandlerSingleton.default.setApp(app);
|
|
29
|
+
app.setLayout(_components.Layout);
|
|
30
|
+
app.events.once('admin:menu:config:load:after', ({
|
|
31
|
+
addConfig
|
|
32
|
+
}) => addConfig(menuConfig));
|
|
33
|
+
return {
|
|
34
|
+
name: _constants.PLUGIN_NAME,
|
|
35
|
+
version: _package.default.version
|
|
36
|
+
};
|
|
72
37
|
}
|
|
73
38
|
load.pluginName = _constants.PLUGIN_NAME;
|
|
74
|
-
var _default = exports
|
|
39
|
+
var _default = exports.default = load;
|
|
75
40
|
//# sourceMappingURL=index.js.map
|
package/lib/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["_react","_interopRequireDefault","require","_components","_package","_constants","_menuHandlerSingleton","
|
|
1
|
+
{"version":3,"file":"index.js","names":["_react","_interopRequireDefault","require","_components","_package","_constants","_menuHandlerSingleton","_interopRequireWildcard","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","Home","React","lazy","Promise","resolve","then","load","app","options","menuConfig","homeRoute","home","path","exact","key","redirect","component","addRoute","menuHandler","setApp","setLayout","Layout","events","once","addConfig","name","PLUGIN_NAME","version","pkg","pluginName","_default","exports"],"sources":["../src/index.js"],"sourcesContent":["import React from 'react';\nimport { Layout } from './components';\nimport pkg from '../package.json';\nimport { PLUGIN_NAME } from './constants';\nimport menuHandler from './utils/menu-handler-singleton';\n\nconst Home = React.lazy(() => import(/* webpackChunkName: 'Home' */ './containers'));\n\nasync function load(app, options = {}) {\n const { menuConfig = {}, homeRoute } = options;\n\n const home = {\n path: '/',\n exact: true,\n key: 'home',\n redirect: homeRoute,\n component: Home\n };\n\n app.addRoute(home);\n\n menuHandler.setApp(app);\n\n app.setLayout(Layout);\n\n app.events.once('admin:menu:config:load:after', ({ addConfig }) => addConfig(menuConfig));\n\n return {\n name: PLUGIN_NAME,\n version: pkg.version\n };\n}\n\nload.pluginName = PLUGIN_NAME;\n\nexport default load;\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,WAAA,GAAAD,OAAA;AACA,IAAAE,QAAA,GAAAH,sBAAA,CAAAC,OAAA;AACA,IAAAG,UAAA,GAAAH,OAAA;AACA,IAAAI,qBAAA,GAAAL,sBAAA,CAAAC,OAAA;AAAyD,SAAAK,wBAAAC,CAAA,EAAAC,CAAA,6BAAAC,OAAA,MAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAH,uBAAA,YAAAA,CAAAC,CAAA,EAAAC,CAAA,SAAAA,CAAA,IAAAD,CAAA,IAAAA,CAAA,CAAAK,UAAA,SAAAL,CAAA,MAAAM,CAAA,EAAAC,CAAA,EAAAC,CAAA,KAAAC,SAAA,QAAAC,OAAA,EAAAV,CAAA,iBAAAA,CAAA,uBAAAA,CAAA,yBAAAA,CAAA,SAAAQ,CAAA,MAAAF,CAAA,GAAAL,CAAA,GAAAG,CAAA,GAAAD,CAAA,QAAAG,CAAA,CAAAK,GAAA,CAAAX,CAAA,UAAAM,CAAA,CAAAM,GAAA,CAAAZ,CAAA,GAAAM,CAAA,CAAAO,GAAA,CAAAb,CAAA,EAAAQ,CAAA,gBAAAP,CAAA,IAAAD,CAAA,gBAAAC,CAAA,OAAAa,cAAA,CAAAC,IAAA,CAAAf,CAAA,EAAAC,CAAA,OAAAM,CAAA,IAAAD,CAAA,GAAAU,MAAA,CAAAC,cAAA,KAAAD,MAAA,CAAAE,wBAAA,CAAAlB,CAAA,EAAAC,CAAA,OAAAM,CAAA,CAAAK,GAAA,IAAAL,CAAA,CAAAM,GAAA,IAAAP,CAAA,CAAAE,CAAA,EAAAP,CAAA,EAAAM,CAAA,IAAAC,CAAA,CAAAP,CAAA,IAAAD,CAAA,CAAAC,CAAA,WAAAO,CAAA,KAAAR,CAAA,EAAAC,CAAA;AAEzD,MAAMkB,IAAI,gBAAGC,cAAK,CAACC,IAAI,CAAC,MAAAC,OAAA,CAAAC,OAAA,GAAAC,IAAA,OAAAzB,uBAAA,CAAAL,OAAA,CAA4C,cAAc,GAAC,CAAC;AAEpF,eAAe+B,IAAIA,CAACC,GAAG,EAAEC,OAAO,GAAG,CAAC,CAAC,EAAE;EACrC,MAAM;IAAEC,UAAU,GAAG,CAAC,CAAC;IAAEC;EAAU,CAAC,GAAGF,OAAO;EAE9C,MAAMG,IAAI,GAAG;IACXC,IAAI,EAAE,GAAG;IACTC,KAAK,EAAE,IAAI;IACXC,GAAG,EAAE,MAAM;IACXC,QAAQ,EAAEL,SAAS;IACnBM,SAAS,EAAEhB;EACb,CAAC;EAEDO,GAAG,CAACU,QAAQ,CAACN,IAAI,CAAC;EAElBO,6BAAW,CAACC,MAAM,CAACZ,GAAG,CAAC;EAEvBA,GAAG,CAACa,SAAS,CAACC,kBAAM,CAAC;EAErBd,GAAG,CAACe,MAAM,CAACC,IAAI,CAAC,8BAA8B,EAAE,CAAC;IAAEC;EAAU,CAAC,KAAKA,SAAS,CAACf,UAAU,CAAC,CAAC;EAEzF,OAAO;IACLgB,IAAI,EAAEC,sBAAW;IACjBC,OAAO,EAAEC,gBAAG,CAACD;EACf,CAAC;AACH;AAEArB,IAAI,CAACuB,UAAU,GAAGH,sBAAW;AAAC,IAAAI,QAAA,GAAAC,OAAA,CAAAxC,OAAA,GAEfe,IAAI","ignoreList":[]}
|
|
@@ -1,33 +1,21 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
require("core-js/modules/es.object.define-property.js");
|
|
4
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
|
-
exports
|
|
9
|
-
var
|
|
10
|
-
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
11
|
-
var _menuHandler2 = _interopRequireDefault(require("./menu-handler"));
|
|
7
|
+
exports.default = getMenuItemsResolver;
|
|
8
|
+
var _menuHandler = _interopRequireDefault(require("./menu-handler"));
|
|
12
9
|
function getMenuItemsResolver(app) {
|
|
13
|
-
return
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
return app.events.emitAsync('load:menu-items', addItem);
|
|
24
|
-
case 5:
|
|
25
|
-
return _context.abrupt("return", getAll());
|
|
26
|
-
case 6:
|
|
27
|
-
case "end":
|
|
28
|
-
return _context.stop();
|
|
29
|
-
}
|
|
30
|
-
}, _callee);
|
|
31
|
-
}));
|
|
10
|
+
return async () => {
|
|
11
|
+
const {
|
|
12
|
+
addItem,
|
|
13
|
+
addSection,
|
|
14
|
+
getAll
|
|
15
|
+
} = (0, _menuHandler.default)();
|
|
16
|
+
await app.events.emitAsync('load:menu-section', addSection);
|
|
17
|
+
await app.events.emitAsync('load:menu-items', addItem);
|
|
18
|
+
return getAll();
|
|
19
|
+
};
|
|
32
20
|
}
|
|
33
21
|
//# sourceMappingURL=get-menu-items-resolver.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-menu-items-resolver.js","names":["
|
|
1
|
+
{"version":3,"file":"get-menu-items-resolver.js","names":["_menuHandler","_interopRequireDefault","require","getMenuItemsResolver","app","addItem","addSection","getAll","menuHandler","events","emitAsync"],"sources":["../../src/utils/get-menu-items-resolver.js"],"sourcesContent":["import menuHandler from './menu-handler';\n\nexport default function getMenuItemsResolver(app) {\n return async () => {\n const { addItem, addSection, getAll } = menuHandler();\n await app.events.emitAsync('load:menu-section', addSection);\n await app.events.emitAsync('load:menu-items', addItem);\n return getAll();\n };\n}\n"],"mappings":";;;;;;;AAAA,IAAAA,YAAA,GAAAC,sBAAA,CAAAC,OAAA;AAEe,SAASC,oBAAoBA,CAACC,GAAG,EAAE;EAChD,OAAO,YAAY;IACjB,MAAM;MAAEC,OAAO;MAAEC,UAAU;MAAEC;IAAO,CAAC,GAAG,IAAAC,oBAAW,EAAC,CAAC;IACrD,MAAMJ,GAAG,CAACK,MAAM,CAACC,SAAS,CAAC,mBAAmB,EAAEJ,UAAU,CAAC;IAC3D,MAAMF,GAAG,CAACK,MAAM,CAACC,SAAS,CAAC,iBAAiB,EAAEL,OAAO,CAAC;IACtD,OAAOE,MAAM,CAAC,CAAC;EACjB,CAAC;AACH","ignoreList":[]}
|
|
@@ -1,31 +1,18 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
require("core-js/modules/es.object.define-property.js");
|
|
4
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
5
4
|
Object.defineProperty(exports, "__esModule", {
|
|
6
5
|
value: true
|
|
7
6
|
});
|
|
8
|
-
exports
|
|
9
|
-
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
10
|
-
require("core-js/modules/es.array.iterator.js");
|
|
11
|
-
require("core-js/modules/es.array.sort.js");
|
|
12
|
-
require("core-js/modules/es.map.js");
|
|
13
|
-
require("core-js/modules/es.object.entries.js");
|
|
14
|
-
require("core-js/modules/es.object.to-string.js");
|
|
15
|
-
require("core-js/modules/es.string.iterator.js");
|
|
16
|
-
require("core-js/modules/web.dom-collections.iterator.js");
|
|
17
|
-
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
18
|
-
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
19
|
-
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
7
|
+
exports.default = exports.MenuHandler = void 0;
|
|
20
8
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
21
9
|
var _lodash = _interopRequireDefault(require("lodash.merge"));
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
(0,
|
|
26
|
-
(0, _defineProperty2
|
|
27
|
-
(0, _defineProperty2
|
|
28
|
-
(0, _defineProperty2["default"])(this, "app", void 0);
|
|
10
|
+
let instance;
|
|
11
|
+
class MenuHandler {
|
|
12
|
+
constructor(app) {
|
|
13
|
+
(0, _defineProperty2.default)(this, "menuSections", new Map());
|
|
14
|
+
(0, _defineProperty2.default)(this, "menuConfig", void 0);
|
|
15
|
+
(0, _defineProperty2.default)(this, "app", void 0);
|
|
29
16
|
if (instance) {
|
|
30
17
|
throw new Error('You can only create one instance!');
|
|
31
18
|
}
|
|
@@ -33,85 +20,55 @@ var MenuHandler = exports.MenuHandler = /*#__PURE__*/function () {
|
|
|
33
20
|
this.menuConfig = {};
|
|
34
21
|
this.app = null;
|
|
35
22
|
}
|
|
36
|
-
(
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
this.
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
_this.addConfig(newConfig);
|
|
67
|
-
};
|
|
68
|
-
menuConfig = this.menuConfig;
|
|
69
|
-
if (!(this.app && this.app.events)) {
|
|
70
|
-
_context.next = 7;
|
|
71
|
-
break;
|
|
72
|
-
}
|
|
73
|
-
_context.next = 5;
|
|
74
|
-
return this.app.events.emitAsync('admin:menu:config:load', {
|
|
75
|
-
addConfig: addConfig
|
|
76
|
-
});
|
|
77
|
-
case 5:
|
|
78
|
-
_context.next = 7;
|
|
79
|
-
return this.app.events.emitAsync('admin:menu:config:load:after', {
|
|
80
|
-
addConfig: addConfig,
|
|
81
|
-
menuConfig: menuConfig
|
|
82
|
-
});
|
|
83
|
-
case 7:
|
|
84
|
-
case "end":
|
|
85
|
-
return _context.stop();
|
|
86
|
-
}
|
|
87
|
-
}, _callee, this);
|
|
88
|
-
}));
|
|
89
|
-
function loadConfig() {
|
|
90
|
-
return _loadConfig.apply(this, arguments);
|
|
91
|
-
}
|
|
92
|
-
return loadConfig;
|
|
93
|
-
}()
|
|
94
|
-
}, {
|
|
95
|
-
key: "getInstance",
|
|
96
|
-
value: function getInstance() {
|
|
97
|
-
return this;
|
|
98
|
-
}
|
|
99
|
-
}, {
|
|
100
|
-
key: "getAll",
|
|
101
|
-
value: function getAll() {
|
|
102
|
-
return Object.entries(this.menuConfig).sort(function (a, b) {
|
|
103
|
-
if (a[1].order === undefined) {
|
|
104
|
-
return 1;
|
|
105
|
-
}
|
|
106
|
-
if (b[1].order === undefined) {
|
|
107
|
-
return -1;
|
|
108
|
-
}
|
|
109
|
-
return a[1].order > b[1].order ? 1 : -1;
|
|
23
|
+
setApp(app) {
|
|
24
|
+
this.app = app;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
// eslint-disable-next-line no-dupe-class-members
|
|
28
|
+
get app() {
|
|
29
|
+
return this.app;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
// eslint-disable-next-line no-dupe-class-members
|
|
33
|
+
get menuConfig() {
|
|
34
|
+
return this.menuConfig;
|
|
35
|
+
}
|
|
36
|
+
addConfig(newConfig) {
|
|
37
|
+
this.menuConfig = (0, _lodash.default)(this.menuConfig, newConfig);
|
|
38
|
+
}
|
|
39
|
+
async loadConfig() {
|
|
40
|
+
const addConfig = newConfig => {
|
|
41
|
+
this.addConfig(newConfig);
|
|
42
|
+
};
|
|
43
|
+
const {
|
|
44
|
+
menuConfig
|
|
45
|
+
} = this;
|
|
46
|
+
if (this.app && this.app.events) {
|
|
47
|
+
await this.app.events.emitAsync('admin:menu:config:load', {
|
|
48
|
+
addConfig
|
|
49
|
+
});
|
|
50
|
+
await this.app.events.emitAsync('admin:menu:config:load:after', {
|
|
51
|
+
addConfig,
|
|
52
|
+
menuConfig
|
|
110
53
|
});
|
|
111
54
|
}
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
55
|
+
}
|
|
56
|
+
getInstance() {
|
|
57
|
+
return this;
|
|
58
|
+
}
|
|
59
|
+
getAll() {
|
|
60
|
+
return Object.entries(this.menuConfig).sort((a, b) => {
|
|
61
|
+
if (a[1].order === undefined) {
|
|
62
|
+
return 1;
|
|
63
|
+
}
|
|
64
|
+
if (b[1].order === undefined) {
|
|
65
|
+
return -1;
|
|
66
|
+
}
|
|
67
|
+
return a[1].order > b[1].order ? 1 : -1;
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
exports.MenuHandler = MenuHandler;
|
|
72
|
+
const menuHandler = new MenuHandler();
|
|
73
|
+
var _default = exports.default = menuHandler;
|
|
117
74
|
//# sourceMappingURL=menu-handler-singleton.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"menu-handler-singleton.js","names":["_lodash","_interopRequireDefault","require","instance","MenuHandler","
|
|
1
|
+
{"version":3,"file":"menu-handler-singleton.js","names":["_lodash","_interopRequireDefault","require","instance","MenuHandler","constructor","app","_defineProperty2","default","Map","Error","menuConfig","setApp","addConfig","newConfig","merge","loadConfig","events","emitAsync","getInstance","getAll","Object","entries","sort","a","b","order","undefined","exports","menuHandler","_default"],"sources":["../../src/utils/menu-handler-singleton.js"],"sourcesContent":["import merge from 'lodash.merge';\n\nlet instance;\n\nexport class MenuHandler {\n menuSections = new Map();\n\n menuConfig;\n\n app;\n\n constructor(app) {\n if (instance) {\n throw new Error('You can only create one instance!');\n }\n instance = this;\n this.menuConfig = {};\n this.app = null;\n }\n\n setApp(app) {\n this.app = app;\n }\n\n // eslint-disable-next-line no-dupe-class-members\n get app() {\n return this.app;\n }\n\n // eslint-disable-next-line no-dupe-class-members\n get menuConfig() {\n return this.menuConfig;\n }\n\n addConfig(newConfig) {\n this.menuConfig = merge(this.menuConfig, newConfig);\n }\n\n async loadConfig() {\n const addConfig = newConfig => {\n this.addConfig(newConfig);\n };\n\n const { menuConfig } = this;\n\n if (this.app && this.app.events) {\n await this.app.events.emitAsync('admin:menu:config:load', { addConfig });\n await this.app.events.emitAsync('admin:menu:config:load:after', { addConfig, menuConfig });\n }\n }\n\n getInstance() {\n return this;\n }\n\n getAll() {\n return Object.entries(this.menuConfig).sort((a, b) => {\n if (a[1].order === undefined) {\n return 1;\n }\n if (b[1].order === undefined) {\n return -1;\n }\n return a[1].order > b[1].order ? 1 : -1;\n });\n }\n}\n\nconst menuHandler = new MenuHandler();\nexport default menuHandler;\n"],"mappings":";;;;;;;;AAAA,IAAAA,OAAA,GAAAC,sBAAA,CAAAC,OAAA;AAEA,IAAIC,QAAQ;AAEL,MAAMC,WAAW,CAAC;EAOvBC,WAAWA,CAACC,GAAG,EAAE;IAAA,IAAAC,gBAAA,CAAAC,OAAA,wBANF,IAAIC,GAAG,CAAC,CAAC;IAAA,IAAAF,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA;IAOtB,IAAIL,QAAQ,EAAE;MACZ,MAAM,IAAIO,KAAK,CAAC,mCAAmC,CAAC;IACtD;IACAP,QAAQ,GAAG,IAAI;IACf,IAAI,CAACQ,UAAU,GAAG,CAAC,CAAC;IACpB,IAAI,CAACL,GAAG,GAAG,IAAI;EACjB;EAEAM,MAAMA,CAACN,GAAG,EAAE;IACV,IAAI,CAACA,GAAG,GAAGA,GAAG;EAChB;;EAEA;EACA,IAAIA,GAAGA,CAAA,EAAG;IACR,OAAO,IAAI,CAACA,GAAG;EACjB;;EAEA;EACA,IAAIK,UAAUA,CAAA,EAAG;IACf,OAAO,IAAI,CAACA,UAAU;EACxB;EAEAE,SAASA,CAACC,SAAS,EAAE;IACnB,IAAI,CAACH,UAAU,GAAG,IAAAI,eAAK,EAAC,IAAI,CAACJ,UAAU,EAAEG,SAAS,CAAC;EACrD;EAEA,MAAME,UAAUA,CAAA,EAAG;IACjB,MAAMH,SAAS,GAAGC,SAAS,IAAI;MAC7B,IAAI,CAACD,SAAS,CAACC,SAAS,CAAC;IAC3B,CAAC;IAED,MAAM;MAAEH;IAAW,CAAC,GAAG,IAAI;IAE3B,IAAI,IAAI,CAACL,GAAG,IAAI,IAAI,CAACA,GAAG,CAACW,MAAM,EAAE;MAC/B,MAAM,IAAI,CAACX,GAAG,CAACW,MAAM,CAACC,SAAS,CAAC,wBAAwB,EAAE;QAAEL;MAAU,CAAC,CAAC;MACxE,MAAM,IAAI,CAACP,GAAG,CAACW,MAAM,CAACC,SAAS,CAAC,8BAA8B,EAAE;QAAEL,SAAS;QAAEF;MAAW,CAAC,CAAC;IAC5F;EACF;EAEAQ,WAAWA,CAAA,EAAG;IACZ,OAAO,IAAI;EACb;EAEAC,MAAMA,CAAA,EAAG;IACP,OAAOC,MAAM,CAACC,OAAO,CAAC,IAAI,CAACX,UAAU,CAAC,CAACY,IAAI,CAAC,CAACC,CAAC,EAAEC,CAAC,KAAK;MACpD,IAAID,CAAC,CAAC,CAAC,CAAC,CAACE,KAAK,KAAKC,SAAS,EAAE;QAC5B,OAAO,CAAC;MACV;MACA,IAAIF,CAAC,CAAC,CAAC,CAAC,CAACC,KAAK,KAAKC,SAAS,EAAE;QAC5B,OAAO,CAAC,CAAC;MACX;MACA,OAAOH,CAAC,CAAC,CAAC,CAAC,CAACE,KAAK,GAAGD,CAAC,CAAC,CAAC,CAAC,CAACC,KAAK,GAAG,CAAC,GAAG,CAAC,CAAC;IACzC,CAAC,CAAC;EACJ;AACF;AAACE,OAAA,CAAAxB,WAAA,GAAAA,WAAA;AAED,MAAMyB,WAAW,GAAG,IAAIzB,WAAW,CAAC,CAAC;AAAC,IAAA0B,QAAA,GAAAF,OAAA,CAAApB,OAAA,GACvBqB,WAAW","ignoreList":[]}
|
|
@@ -1,70 +1,55 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
require("core-js/modules/es.object.define-property.js");
|
|
4
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
5
3
|
Object.defineProperty(exports, "__esModule", {
|
|
6
4
|
value: true
|
|
7
5
|
});
|
|
8
|
-
exports
|
|
9
|
-
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
10
|
-
require("core-js/modules/es.array.from.js");
|
|
11
|
-
require("core-js/modules/es.array.iterator.js");
|
|
12
|
-
require("core-js/modules/es.array.some.js");
|
|
13
|
-
require("core-js/modules/es.array.sort.js");
|
|
14
|
-
require("core-js/modules/es.map.js");
|
|
15
|
-
require("core-js/modules/es.object.to-string.js");
|
|
16
|
-
require("core-js/modules/es.string.iterator.js");
|
|
17
|
-
require("core-js/modules/web.dom-collections.iterator.js");
|
|
6
|
+
exports.default = menuHandler;
|
|
18
7
|
function menuHandler() {
|
|
19
|
-
|
|
8
|
+
const menuSections = new Map();
|
|
20
9
|
function getSection(key) {
|
|
21
10
|
return menuSections.get(key);
|
|
22
11
|
}
|
|
23
12
|
function getAll() {
|
|
24
|
-
return Array.from(menuSections.entries()).sort(
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
return order1 > order2 ? 1 : -1;
|
|
30
|
-
});
|
|
13
|
+
return Array.from(menuSections.entries()).sort(([, {
|
|
14
|
+
order: order1
|
|
15
|
+
}], [, {
|
|
16
|
+
order: order2
|
|
17
|
+
}]) => order1 > order2 ? 1 : -1);
|
|
31
18
|
}
|
|
32
|
-
function addSection(key,
|
|
33
|
-
|
|
34
|
-
|
|
19
|
+
function addSection(key, {
|
|
20
|
+
header,
|
|
21
|
+
order
|
|
22
|
+
}) {
|
|
35
23
|
validateSection(key, order);
|
|
36
|
-
|
|
37
|
-
header
|
|
38
|
-
order
|
|
24
|
+
const section = {
|
|
25
|
+
header,
|
|
26
|
+
order,
|
|
39
27
|
items: []
|
|
40
28
|
};
|
|
41
29
|
menuSections.set(key, section);
|
|
42
30
|
}
|
|
43
31
|
function addItem(item, sectionKey) {
|
|
44
32
|
validateItem(sectionKey);
|
|
45
|
-
|
|
33
|
+
const section = menuSections.get(sectionKey);
|
|
46
34
|
section.items.push(item);
|
|
47
35
|
}
|
|
48
36
|
function validateItem(key) {
|
|
49
|
-
if (!menuSections.has(key)) throw new Error(
|
|
37
|
+
if (!menuSections.has(key)) throw new Error(`Section ${key} doesn\'t exist`);
|
|
50
38
|
}
|
|
51
39
|
function validateSection(key, order) {
|
|
52
40
|
if (!key) throw new Error('Section requires a key');
|
|
53
|
-
if (menuSections.has(key)) throw new Error(
|
|
54
|
-
if (Array.from(menuSections.entries()).some(
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
_order = _ref7[1].order;
|
|
58
|
-
return _order === order;
|
|
59
|
-
})) {
|
|
41
|
+
if (menuSections.has(key)) throw new Error(`Section with ${key} has been already added`);
|
|
42
|
+
if (Array.from(menuSections.entries()).some(([_, {
|
|
43
|
+
order: _order
|
|
44
|
+
}]) => _order === order)) {
|
|
60
45
|
throw new Error('Section with this order has already been added');
|
|
61
46
|
}
|
|
62
47
|
}
|
|
63
48
|
return {
|
|
64
|
-
addSection
|
|
65
|
-
addItem
|
|
66
|
-
getSection
|
|
67
|
-
getAll
|
|
49
|
+
addSection,
|
|
50
|
+
addItem,
|
|
51
|
+
getSection,
|
|
52
|
+
getAll
|
|
68
53
|
};
|
|
69
54
|
}
|
|
70
55
|
//# sourceMappingURL=menu-handler.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"menu-handler.js","names":["menuHandler","menuSections","Map","getSection","key","get","getAll","Array","from","entries","sort","
|
|
1
|
+
{"version":3,"file":"menu-handler.js","names":["menuHandler","menuSections","Map","getSection","key","get","getAll","Array","from","entries","sort","order","order1","order2","addSection","header","validateSection","section","items","set","addItem","item","sectionKey","validateItem","push","has","Error","some","_","_order"],"sources":["../../src/utils/menu-handler.js"],"sourcesContent":["export default function menuHandler() {\n const menuSections = new Map();\n\n function getSection(key) {\n return menuSections.get(key);\n }\n\n function getAll() {\n return Array.from(menuSections.entries()).sort(\n ([, { order: order1 }], [, { order: order2 }]) => (order1 > order2 ? 1 : -1)\n );\n }\n\n function addSection(key, { header, order }) {\n validateSection(key, order);\n const section = {\n header,\n order,\n items: []\n };\n menuSections.set(key, section);\n }\n\n function addItem(item, sectionKey) {\n validateItem(sectionKey);\n const section = menuSections.get(sectionKey);\n section.items.push(item);\n }\n\n function validateItem(key) {\n if (!menuSections.has(key)) throw new Error(`Section ${key} doesn\\'t exist`);\n }\n\n function validateSection(key, order) {\n if (!key) throw new Error('Section requires a key');\n if (menuSections.has(key)) throw new Error(`Section with ${key} has been already added`);\n if (Array.from(menuSections.entries()).some(([_, { order: _order }]) => _order === order)) {\n throw new Error('Section with this order has already been added');\n }\n }\n\n return {\n addSection,\n addItem,\n getSection,\n getAll\n };\n}\n"],"mappings":";;;;;;AAAe,SAASA,WAAWA,CAAA,EAAG;EACpC,MAAMC,YAAY,GAAG,IAAIC,GAAG,CAAC,CAAC;EAE9B,SAASC,UAAUA,CAACC,GAAG,EAAE;IACvB,OAAOH,YAAY,CAACI,GAAG,CAACD,GAAG,CAAC;EAC9B;EAEA,SAASE,MAAMA,CAAA,EAAG;IAChB,OAAOC,KAAK,CAACC,IAAI,CAACP,YAAY,CAACQ,OAAO,CAAC,CAAC,CAAC,CAACC,IAAI,CAC5C,CAAC,GAAG;MAAEC,KAAK,EAAEC;IAAO,CAAC,CAAC,EAAE,GAAG;MAAED,KAAK,EAAEE;IAAO,CAAC,CAAC,KAAMD,MAAM,GAAGC,MAAM,GAAG,CAAC,GAAG,CAAC,CAC5E,CAAC;EACH;EAEA,SAASC,UAAUA,CAACV,GAAG,EAAE;IAAEW,MAAM;IAAEJ;EAAM,CAAC,EAAE;IAC1CK,eAAe,CAACZ,GAAG,EAAEO,KAAK,CAAC;IAC3B,MAAMM,OAAO,GAAG;MACdF,MAAM;MACNJ,KAAK;MACLO,KAAK,EAAE;IACT,CAAC;IACDjB,YAAY,CAACkB,GAAG,CAACf,GAAG,EAAEa,OAAO,CAAC;EAChC;EAEA,SAASG,OAAOA,CAACC,IAAI,EAAEC,UAAU,EAAE;IACjCC,YAAY,CAACD,UAAU,CAAC;IACxB,MAAML,OAAO,GAAGhB,YAAY,CAACI,GAAG,CAACiB,UAAU,CAAC;IAC5CL,OAAO,CAACC,KAAK,CAACM,IAAI,CAACH,IAAI,CAAC;EAC1B;EAEA,SAASE,YAAYA,CAACnB,GAAG,EAAE;IACzB,IAAI,CAACH,YAAY,CAACwB,GAAG,CAACrB,GAAG,CAAC,EAAE,MAAM,IAAIsB,KAAK,CAAC,WAAWtB,GAAG,iBAAiB,CAAC;EAC9E;EAEA,SAASY,eAAeA,CAACZ,GAAG,EAAEO,KAAK,EAAE;IACnC,IAAI,CAACP,GAAG,EAAE,MAAM,IAAIsB,KAAK,CAAC,wBAAwB,CAAC;IACnD,IAAIzB,YAAY,CAACwB,GAAG,CAACrB,GAAG,CAAC,EAAE,MAAM,IAAIsB,KAAK,CAAC,gBAAgBtB,GAAG,yBAAyB,CAAC;IACxF,IAAIG,KAAK,CAACC,IAAI,CAACP,YAAY,CAACQ,OAAO,CAAC,CAAC,CAAC,CAACkB,IAAI,CAAC,CAAC,CAACC,CAAC,EAAE;MAAEjB,KAAK,EAAEkB;IAAO,CAAC,CAAC,KAAKA,MAAM,KAAKlB,KAAK,CAAC,EAAE;MACzF,MAAM,IAAIe,KAAK,CAAC,gDAAgD,CAAC;IACnE;EACF;EAEA,OAAO;IACLZ,UAAU;IACVM,OAAO;IACPjB,UAAU;IACVG;EACF,CAAC;AACH","ignoreList":[]}
|
|
@@ -7,7 +7,7 @@ const Header = ({
|
|
|
7
7
|
isLoggedIn,
|
|
8
8
|
isOpenMenu,
|
|
9
9
|
onMenuClick
|
|
10
|
-
}) =>
|
|
10
|
+
}) => isLoggedIn ? /*#__PURE__*/React.createElement("header", {
|
|
11
11
|
className: "header"
|
|
12
12
|
}, /*#__PURE__*/React.createElement("div", {
|
|
13
13
|
className: "header__menu"
|
|
@@ -15,7 +15,7 @@ const Header = ({
|
|
|
15
15
|
isOpenMenu: isOpenMenu,
|
|
16
16
|
onMenuClick: onMenuClick,
|
|
17
17
|
id: "menu-button"
|
|
18
|
-
})), /*#__PURE__*/React.createElement(Logo, LOGO_PROPS), /*#__PURE__*/React.createElement(SearchAdmin, null))
|
|
18
|
+
})), /*#__PURE__*/React.createElement(Logo, LOGO_PROPS), /*#__PURE__*/React.createElement(SearchAdmin, null)) : null;
|
|
19
19
|
Header.propTypes = {
|
|
20
20
|
isLoggedIn: PropTypes.bool,
|
|
21
21
|
isOpenMenu: PropTypes.bool.isRequired,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Header.js","names":["React","PropTypes","SearchAdmin","Menu","Logo","LOGO_PROPS","Header","isLoggedIn","isOpenMenu","onMenuClick","createElement","
|
|
1
|
+
{"version":3,"file":"Header.js","names":["React","PropTypes","SearchAdmin","Menu","Logo","LOGO_PROPS","Header","isLoggedIn","isOpenMenu","onMenuClick","createElement","className","id","propTypes","bool","isRequired","func","defaultProps"],"sources":["../../../src/components/Header/Header.js"],"sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { SearchAdmin } from '@blaze-cms/plugin-search-ui';\nimport { Menu, Logo } from './components';\nimport { LOGO_PROPS } from '../../constants';\n\nconst Header = ({ isLoggedIn, isOpenMenu, onMenuClick }) =>\n isLoggedIn ? (\n <header className=\"header\">\n <div className=\"header__menu\">\n <Menu isOpenMenu={isOpenMenu} onMenuClick={onMenuClick} id=\"menu-button\" />\n </div>\n <Logo {...LOGO_PROPS} />\n <SearchAdmin />\n </header>\n ) : null;\n\nHeader.propTypes = {\n isLoggedIn: PropTypes.bool,\n isOpenMenu: PropTypes.bool.isRequired,\n onMenuClick: PropTypes.func.isRequired\n};\n\nHeader.defaultProps = {\n isLoggedIn: false\n};\n\nexport default Header;\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,OAAOC,SAAS,MAAM,YAAY;AAClC,SAASC,WAAW,QAAQ,6BAA6B;AACzD,SAASC,IAAI,EAAEC,IAAI,QAAQ,cAAc;AACzC,SAASC,UAAU,QAAQ,iBAAiB;AAE5C,MAAMC,MAAM,GAAGA,CAAC;EAAEC,UAAU;EAAEC,UAAU;EAAEC;AAAY,CAAC,KACrDF,UAAU,gBACRP,KAAA,CAAAU,aAAA;EAAQC,SAAS,EAAC;AAAQ,gBACxBX,KAAA,CAAAU,aAAA;EAAKC,SAAS,EAAC;AAAc,gBAC3BX,KAAA,CAAAU,aAAA,CAACP,IAAI;EAACK,UAAU,EAAEA,UAAW;EAACC,WAAW,EAAEA,WAAY;EAACG,EAAE,EAAC;AAAa,CAAE,CACvE,CAAC,eACNZ,KAAA,CAAAU,aAAA,CAACN,IAAI,EAAKC,UAAa,CAAC,eACxBL,KAAA,CAAAU,aAAA,CAACR,WAAW,MAAE,CACR,CAAC,GACP,IAAI;AAEVI,MAAM,CAACO,SAAS,GAAG;EACjBN,UAAU,EAAEN,SAAS,CAACa,IAAI;EAC1BN,UAAU,EAAEP,SAAS,CAACa,IAAI,CAACC,UAAU;EACrCN,WAAW,EAAER,SAAS,CAACe,IAAI,CAACD;AAC9B,CAAC;AAEDT,MAAM,CAACW,YAAY,GAAG;EACpBV,UAAU,EAAE;AACd,CAAC;AAED,eAAeD,MAAM","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Layout.js","names":["React","useState","PropTypes","Query","getQuery","Login","LoginModal","BlazeAuthContextWrapper","Grid","Background","Header","Layout","children","isOpenMenu","setOpenMenu","onMenuClick","simpleLayout","window","location","parent","wrapperClass","createElement","className","query","errorPolicy","data","session","isLoggedIn","userData","Fragment","propTypes","oneOfType","arrayOf","node","isRequired"],"sources":["../../../src/components/Layout/Layout.js"],"sourcesContent":["import React, { useState } from 'react';\nimport PropTypes from 'prop-types';\nimport { Query } from '@apollo/client/react/components';\nimport { getQuery } from '@blaze-cms/admin-ui-utils';\nimport { Login, LoginModal } from '@blaze-cms/plugin-auth-ui';\nimport { BlazeAuthContextWrapper } from '@blaze-cms/core-auth-ui';\nimport '@blaze-cms/admin-ui-styles/main.scss';\nimport { Grid } from './components';\nimport Background from './Background';\n\nimport Header from '../Header';\n\nconst Layout = ({ children }) => {\n const [isOpenMenu, setOpenMenu] = useState(true);\n\n const onMenuClick = () => setOpenMenu(!isOpenMenu);\n\n const simpleLayout = window.location !== window.parent.location;\n const wrapperClass = simpleLayout ? ' grid--site-container--simle-layout' : '';\n\n return (\n <div className={`site-container grid--site-container${wrapperClass}`}>\n <Query query={getQuery('GET_USER_AUTH_DATA')} errorPolicy=\"all\">\n {({ data = {} }) => {\n const { session: { isLoggedIn, userData = {} } = {} } = data;\n\n return (\n <>\n {!simpleLayout && (\n <Header isLoggedIn={isLoggedIn} onMenuClick={onMenuClick} isOpenMenu={isOpenMenu} />\n )}\n {isLoggedIn ? (\n <BlazeAuthContextWrapper>\n {!simpleLayout && <LoginModal />}\n <Grid\n isOpenMenu={isOpenMenu}\n onMenuClick={onMenuClick}\n userData={userData}\n simpleLayout={simpleLayout}>\n {children}\n </Grid>\n </BlazeAuthContextWrapper>\n ) : (\n <Background>\n <Login />\n </Background>\n )}\n </>\n );\n }}\n </Query>\n </div>\n );\n};\n\nLayout.propTypes = {\n children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]).isRequired\n};\n\nexport default Layout;\n"],"mappings":"AAAA,OAAOA,KAAK,IAAIC,QAAQ,QAAQ,OAAO;AACvC,OAAOC,SAAS,MAAM,YAAY;AAClC,SAASC,KAAK,QAAQ,iCAAiC;AACvD,SAASC,QAAQ,QAAQ,2BAA2B;AACpD,SAASC,KAAK,EAAEC,UAAU,QAAQ,2BAA2B;AAC7D,SAASC,uBAAuB,QAAQ,yBAAyB;AACjE,OAAO,sCAAsC;AAC7C,SAASC,IAAI,QAAQ,cAAc;AACnC,OAAOC,UAAU,MAAM,cAAc;AAErC,OAAOC,MAAM,MAAM,WAAW;AAE9B,MAAMC,MAAM,GAAGA,CAAC;EAAEC;AAAS,CAAC,KAAK;EAC/B,MAAM,CAACC,UAAU,EAAEC,WAAW,CAAC,GAAGb,QAAQ,CAAC,IAAI,CAAC;EAEhD,MAAMc,WAAW,GAAGA,CAAA,KAAMD,WAAW,CAAC,CAACD,UAAU,CAAC;EAElD,MAAMG,YAAY,GAAGC,MAAM,CAACC,QAAQ,KAAKD,MAAM,CAACE,MAAM,CAACD,QAAQ;EAC/D,MAAME,YAAY,GAAGJ,YAAY,GAAG,qCAAqC,GAAG,EAAE;EAE9E,oBACEhB,KAAA,CAAAqB,aAAA;IAAKC,SAAS,
|
|
1
|
+
{"version":3,"file":"Layout.js","names":["React","useState","PropTypes","Query","getQuery","Login","LoginModal","BlazeAuthContextWrapper","Grid","Background","Header","Layout","children","isOpenMenu","setOpenMenu","onMenuClick","simpleLayout","window","location","parent","wrapperClass","createElement","className","query","errorPolicy","data","session","isLoggedIn","userData","Fragment","propTypes","oneOfType","arrayOf","node","isRequired"],"sources":["../../../src/components/Layout/Layout.js"],"sourcesContent":["import React, { useState } from 'react';\nimport PropTypes from 'prop-types';\nimport { Query } from '@apollo/client/react/components';\nimport { getQuery } from '@blaze-cms/admin-ui-utils';\nimport { Login, LoginModal } from '@blaze-cms/plugin-auth-ui';\nimport { BlazeAuthContextWrapper } from '@blaze-cms/core-auth-ui';\nimport '@blaze-cms/admin-ui-styles/main.scss';\nimport { Grid } from './components';\nimport Background from './Background';\n\nimport Header from '../Header';\n\nconst Layout = ({ children }) => {\n const [isOpenMenu, setOpenMenu] = useState(true);\n\n const onMenuClick = () => setOpenMenu(!isOpenMenu);\n\n const simpleLayout = window.location !== window.parent.location;\n const wrapperClass = simpleLayout ? ' grid--site-container--simle-layout' : '';\n\n return (\n <div className={`site-container grid--site-container${wrapperClass}`}>\n <Query query={getQuery('GET_USER_AUTH_DATA')} errorPolicy=\"all\">\n {({ data = {} }) => {\n const { session: { isLoggedIn, userData = {} } = {} } = data;\n\n return (\n <>\n {!simpleLayout && (\n <Header isLoggedIn={isLoggedIn} onMenuClick={onMenuClick} isOpenMenu={isOpenMenu} />\n )}\n {isLoggedIn ? (\n <BlazeAuthContextWrapper>\n {!simpleLayout && <LoginModal />}\n <Grid\n isOpenMenu={isOpenMenu}\n onMenuClick={onMenuClick}\n userData={userData}\n simpleLayout={simpleLayout}>\n {children}\n </Grid>\n </BlazeAuthContextWrapper>\n ) : (\n <Background>\n <Login />\n </Background>\n )}\n </>\n );\n }}\n </Query>\n </div>\n );\n};\n\nLayout.propTypes = {\n children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]).isRequired\n};\n\nexport default Layout;\n"],"mappings":"AAAA,OAAOA,KAAK,IAAIC,QAAQ,QAAQ,OAAO;AACvC,OAAOC,SAAS,MAAM,YAAY;AAClC,SAASC,KAAK,QAAQ,iCAAiC;AACvD,SAASC,QAAQ,QAAQ,2BAA2B;AACpD,SAASC,KAAK,EAAEC,UAAU,QAAQ,2BAA2B;AAC7D,SAASC,uBAAuB,QAAQ,yBAAyB;AACjE,OAAO,sCAAsC;AAC7C,SAASC,IAAI,QAAQ,cAAc;AACnC,OAAOC,UAAU,MAAM,cAAc;AAErC,OAAOC,MAAM,MAAM,WAAW;AAE9B,MAAMC,MAAM,GAAGA,CAAC;EAAEC;AAAS,CAAC,KAAK;EAC/B,MAAM,CAACC,UAAU,EAAEC,WAAW,CAAC,GAAGb,QAAQ,CAAC,IAAI,CAAC;EAEhD,MAAMc,WAAW,GAAGA,CAAA,KAAMD,WAAW,CAAC,CAACD,UAAU,CAAC;EAElD,MAAMG,YAAY,GAAGC,MAAM,CAACC,QAAQ,KAAKD,MAAM,CAACE,MAAM,CAACD,QAAQ;EAC/D,MAAME,YAAY,GAAGJ,YAAY,GAAG,qCAAqC,GAAG,EAAE;EAE9E,oBACEhB,KAAA,CAAAqB,aAAA;IAAKC,SAAS,EAAE,sCAAsCF,YAAY;EAAG,gBACnEpB,KAAA,CAAAqB,aAAA,CAAClB,KAAK;IAACoB,KAAK,EAAEnB,QAAQ,CAAC,oBAAoB,CAAE;IAACoB,WAAW,EAAC;EAAK,GAC5D,CAAC;IAAEC,IAAI,GAAG,CAAC;EAAE,CAAC,KAAK;IAClB,MAAM;MAAEC,OAAO,EAAE;QAAEC,UAAU;QAAEC,QAAQ,GAAG,CAAC;MAAE,CAAC,GAAG,CAAC;IAAE,CAAC,GAAGH,IAAI;IAE5D,oBACEzB,KAAA,CAAAqB,aAAA,CAAArB,KAAA,CAAA6B,QAAA,QACG,CAACb,YAAY,iBACZhB,KAAA,CAAAqB,aAAA,CAACX,MAAM;MAACiB,UAAU,EAAEA,UAAW;MAACZ,WAAW,EAAEA,WAAY;MAACF,UAAU,EAAEA;IAAW,CAAE,CACpF,EACAc,UAAU,gBACT3B,KAAA,CAAAqB,aAAA,CAACd,uBAAuB,QACrB,CAACS,YAAY,iBAAIhB,KAAA,CAAAqB,aAAA,CAACf,UAAU,MAAE,CAAC,eAChCN,KAAA,CAAAqB,aAAA,CAACb,IAAI;MACHK,UAAU,EAAEA,UAAW;MACvBE,WAAW,EAAEA,WAAY;MACzBa,QAAQ,EAAEA,QAAS;MACnBZ,YAAY,EAAEA;IAAa,GAC1BJ,QACG,CACiB,CAAC,gBAE1BZ,KAAA,CAAAqB,aAAA,CAACZ,UAAU,qBACTT,KAAA,CAAAqB,aAAA,CAAChB,KAAK,MAAE,CACE,CAEd,CAAC;EAEP,CACK,CACJ,CAAC;AAEV,CAAC;AAEDM,MAAM,CAACmB,SAAS,GAAG;EACjBlB,QAAQ,EAAEV,SAAS,CAAC6B,SAAS,CAAC,CAAC7B,SAAS,CAAC8B,OAAO,CAAC9B,SAAS,CAAC+B,IAAI,CAAC,EAAE/B,SAAS,CAAC+B,IAAI,CAAC,CAAC,CAACC;AACrF,CAAC;AAED,eAAevB,MAAM","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MenuActionItem.js","names":["React","Link","MenuActionItem","item","label","icon","MenuSectionIcon","onClick","uri","modifier","createElement","className","key","to","width","height"],"sources":["../../../../src/components/Menu/Items/MenuActionItem.js"],"sourcesContent":["import React from 'react';\nimport { Link } from 'react-router-dom';\n\nconst MenuActionItem = ({ item }) => {\n const { label, icon: MenuSectionIcon, onClick, uri } = item;\n\n const modifier = MenuSectionIcon ? '' : 'side-nav__list-link--noIcon';\n\n return (\n <li className=\"side-nav__list--item\" key={item.label}>\n <Link\n to={uri}\n className={`side-nav__list-link ${modifier}`}\n onClick={() => {\n if (onClick) {\n onClick();\n }\n }}>\n {MenuSectionIcon && (\n <div className=\"side-nav__list-link--icon\">\n <MenuSectionIcon width=\"20px\" height=\"20px\" />\n </div>\n )}\n <div className=\"side-nav__list-label\">{label}</div>\n </Link>\n </li>\n );\n};\n\nexport default MenuActionItem;\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,IAAI,QAAQ,kBAAkB;AAEvC,MAAMC,cAAc,GAAGA,CAAC;EAAEC;AAAK,CAAC,KAAK;EACnC,MAAM;IAAEC,KAAK;IAAEC,IAAI,EAAEC,eAAe;IAAEC,OAAO;IAAEC;EAAI,CAAC,GAAGL,IAAI;EAE3D,MAAMM,QAAQ,GAAGH,eAAe,GAAG,EAAE,GAAG,6BAA6B;EAErE,oBACEN,KAAA,CAAAU,aAAA;IAAIC,SAAS,EAAC,sBAAsB;IAACC,GAAG,EAAET,IAAI,CAACC;EAAM,gBACnDJ,KAAA,CAAAU,aAAA,CAACT,IAAI;IACHY,EAAE,EAAEL,GAAI;IACRG,SAAS,
|
|
1
|
+
{"version":3,"file":"MenuActionItem.js","names":["React","Link","MenuActionItem","item","label","icon","MenuSectionIcon","onClick","uri","modifier","createElement","className","key","to","width","height"],"sources":["../../../../src/components/Menu/Items/MenuActionItem.js"],"sourcesContent":["import React from 'react';\nimport { Link } from 'react-router-dom';\n\nconst MenuActionItem = ({ item }) => {\n const { label, icon: MenuSectionIcon, onClick, uri } = item;\n\n const modifier = MenuSectionIcon ? '' : 'side-nav__list-link--noIcon';\n\n return (\n <li className=\"side-nav__list--item\" key={item.label}>\n <Link\n to={uri}\n className={`side-nav__list-link ${modifier}`}\n onClick={() => {\n if (onClick) {\n onClick();\n }\n }}>\n {MenuSectionIcon && (\n <div className=\"side-nav__list-link--icon\">\n <MenuSectionIcon width=\"20px\" height=\"20px\" />\n </div>\n )}\n <div className=\"side-nav__list-label\">{label}</div>\n </Link>\n </li>\n );\n};\n\nexport default MenuActionItem;\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,IAAI,QAAQ,kBAAkB;AAEvC,MAAMC,cAAc,GAAGA,CAAC;EAAEC;AAAK,CAAC,KAAK;EACnC,MAAM;IAAEC,KAAK;IAAEC,IAAI,EAAEC,eAAe;IAAEC,OAAO;IAAEC;EAAI,CAAC,GAAGL,IAAI;EAE3D,MAAMM,QAAQ,GAAGH,eAAe,GAAG,EAAE,GAAG,6BAA6B;EAErE,oBACEN,KAAA,CAAAU,aAAA;IAAIC,SAAS,EAAC,sBAAsB;IAACC,GAAG,EAAET,IAAI,CAACC;EAAM,gBACnDJ,KAAA,CAAAU,aAAA,CAACT,IAAI;IACHY,EAAE,EAAEL,GAAI;IACRG,SAAS,EAAE,uBAAuBF,QAAQ,EAAG;IAC7CF,OAAO,EAAEA,CAAA,KAAM;MACb,IAAIA,OAAO,EAAE;QACXA,OAAO,CAAC,CAAC;MACX;IACF;EAAE,GACDD,eAAe,iBACdN,KAAA,CAAAU,aAAA;IAAKC,SAAS,EAAC;EAA2B,gBACxCX,KAAA,CAAAU,aAAA,CAACJ,eAAe;IAACQ,KAAK,EAAC,MAAM;IAACC,MAAM,EAAC;EAAM,CAAE,CAC1C,CACN,eACDf,KAAA,CAAAU,aAAA;IAAKC,SAAS,EAAC;EAAsB,GAAEP,KAAW,CAC9C,CACJ,CAAC;AAET,CAAC;AAED,eAAeF,cAAc","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MenuItem.js","names":["React","useLocation","MenuLinkItem","MenuItem","item","RenderItems","location","label","items","uri","isActive","currentUri","pathname","startsWith","createElement","root","Object","values","length","childrenMenu","keys","map","key","childrenComponents","child","childLabel","childUri"],"sources":["../../../../src/components/Menu/Items/MenuItem.js"],"sourcesContent":["import React from 'react';\nimport { useLocation } from 'react-router-dom';\nimport MenuLinkItem from './MenuLinkItem';\n\nconst MenuItem = ({ item, RenderItems }) => {\n const location = useLocation();\n const { label, items, uri } = item;\n\n const isActive = currentUri =>\n location.pathname === currentUri || location.pathname.startsWith(`${currentUri}/`);\n\n if (label && uri) {\n return <MenuLinkItem item={item} isActive={isActive(uri)} root />;\n }\n\n if (label && items && Object.values(items).length > 0) {\n const childrenMenu = Object.keys(items).map(key => items[key]);\n\n const childrenComponents = childrenMenu.map(child => {\n const { label: childLabel, uri: childUri } = child;\n\n if (childLabel && childUri) {\n return <MenuLinkItem item={child} isActive={isActive(childUri)} root={false} key={label} />;\n }\n\n return null;\n });\n\n return <RenderItems item={item}>{childrenComponents}</RenderItems>;\n }\n\n if (!label && items) {\n const childrenMenu = Object.keys(items).map(key => items[key]);\n\n return childrenMenu.map(child => {\n const { label: childLabel, uri: childUri } = child;\n\n if (childLabel && childUri) {\n return <MenuLinkItem item={child} isActive={isActive(childUri)} key={childUri} root />;\n }\n\n return null;\n });\n }\n\n return null;\n};\n\nexport default MenuItem;\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,WAAW,QAAQ,kBAAkB;AAC9C,OAAOC,YAAY,MAAM,gBAAgB;AAEzC,MAAMC,QAAQ,GAAGA,CAAC;EAAEC,IAAI;EAAEC;AAAY,CAAC,KAAK;EAC1C,MAAMC,QAAQ,GAAGL,WAAW,CAAC,CAAC;EAC9B,MAAM;IAAEM,KAAK;IAAEC,KAAK;IAAEC;EAAI,CAAC,GAAGL,IAAI;EAElC,MAAMM,QAAQ,GAAGC,UAAU,IACzBL,QAAQ,CAACM,QAAQ,KAAKD,UAAU,IAAIL,QAAQ,CAACM,QAAQ,CAACC,UAAU,
|
|
1
|
+
{"version":3,"file":"MenuItem.js","names":["React","useLocation","MenuLinkItem","MenuItem","item","RenderItems","location","label","items","uri","isActive","currentUri","pathname","startsWith","createElement","root","Object","values","length","childrenMenu","keys","map","key","childrenComponents","child","childLabel","childUri"],"sources":["../../../../src/components/Menu/Items/MenuItem.js"],"sourcesContent":["import React from 'react';\nimport { useLocation } from 'react-router-dom';\nimport MenuLinkItem from './MenuLinkItem';\n\nconst MenuItem = ({ item, RenderItems }) => {\n const location = useLocation();\n const { label, items, uri } = item;\n\n const isActive = currentUri =>\n location.pathname === currentUri || location.pathname.startsWith(`${currentUri}/`);\n\n if (label && uri) {\n return <MenuLinkItem item={item} isActive={isActive(uri)} root />;\n }\n\n if (label && items && Object.values(items).length > 0) {\n const childrenMenu = Object.keys(items).map(key => items[key]);\n\n const childrenComponents = childrenMenu.map(child => {\n const { label: childLabel, uri: childUri } = child;\n\n if (childLabel && childUri) {\n return <MenuLinkItem item={child} isActive={isActive(childUri)} root={false} key={label} />;\n }\n\n return null;\n });\n\n return <RenderItems item={item}>{childrenComponents}</RenderItems>;\n }\n\n if (!label && items) {\n const childrenMenu = Object.keys(items).map(key => items[key]);\n\n return childrenMenu.map(child => {\n const { label: childLabel, uri: childUri } = child;\n\n if (childLabel && childUri) {\n return <MenuLinkItem item={child} isActive={isActive(childUri)} key={childUri} root />;\n }\n\n return null;\n });\n }\n\n return null;\n};\n\nexport default MenuItem;\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,WAAW,QAAQ,kBAAkB;AAC9C,OAAOC,YAAY,MAAM,gBAAgB;AAEzC,MAAMC,QAAQ,GAAGA,CAAC;EAAEC,IAAI;EAAEC;AAAY,CAAC,KAAK;EAC1C,MAAMC,QAAQ,GAAGL,WAAW,CAAC,CAAC;EAC9B,MAAM;IAAEM,KAAK;IAAEC,KAAK;IAAEC;EAAI,CAAC,GAAGL,IAAI;EAElC,MAAMM,QAAQ,GAAGC,UAAU,IACzBL,QAAQ,CAACM,QAAQ,KAAKD,UAAU,IAAIL,QAAQ,CAACM,QAAQ,CAACC,UAAU,CAAC,GAAGF,UAAU,GAAG,CAAC;EAEpF,IAAIJ,KAAK,IAAIE,GAAG,EAAE;IAChB,oBAAOT,KAAA,CAAAc,aAAA,CAACZ,YAAY;MAACE,IAAI,EAAEA,IAAK;MAACM,QAAQ,EAAEA,QAAQ,CAACD,GAAG,CAAE;MAACM,IAAI;IAAA,CAAE,CAAC;EACnE;EAEA,IAAIR,KAAK,IAAIC,KAAK,IAAIQ,MAAM,CAACC,MAAM,CAACT,KAAK,CAAC,CAACU,MAAM,GAAG,CAAC,EAAE;IACrD,MAAMC,YAAY,GAAGH,MAAM,CAACI,IAAI,CAACZ,KAAK,CAAC,CAACa,GAAG,CAACC,GAAG,IAAId,KAAK,CAACc,GAAG,CAAC,CAAC;IAE9D,MAAMC,kBAAkB,GAAGJ,YAAY,CAACE,GAAG,CAACG,KAAK,IAAI;MACnD,MAAM;QAAEjB,KAAK,EAAEkB,UAAU;QAAEhB,GAAG,EAAEiB;MAAS,CAAC,GAAGF,KAAK;MAElD,IAAIC,UAAU,IAAIC,QAAQ,EAAE;QAC1B,oBAAO1B,KAAA,CAAAc,aAAA,CAACZ,YAAY;UAACE,IAAI,EAAEoB,KAAM;UAACd,QAAQ,EAAEA,QAAQ,CAACgB,QAAQ,CAAE;UAACX,IAAI,EAAE,KAAM;UAACO,GAAG,EAAEf;QAAM,CAAE,CAAC;MAC7F;MAEA,OAAO,IAAI;IACb,CAAC,CAAC;IAEF,oBAAOP,KAAA,CAAAc,aAAA,CAACT,WAAW;MAACD,IAAI,EAAEA;IAAK,GAAEmB,kBAAgC,CAAC;EACpE;EAEA,IAAI,CAAChB,KAAK,IAAIC,KAAK,EAAE;IACnB,MAAMW,YAAY,GAAGH,MAAM,CAACI,IAAI,CAACZ,KAAK,CAAC,CAACa,GAAG,CAACC,GAAG,IAAId,KAAK,CAACc,GAAG,CAAC,CAAC;IAE9D,OAAOH,YAAY,CAACE,GAAG,CAACG,KAAK,IAAI;MAC/B,MAAM;QAAEjB,KAAK,EAAEkB,UAAU;QAAEhB,GAAG,EAAEiB;MAAS,CAAC,GAAGF,KAAK;MAElD,IAAIC,UAAU,IAAIC,QAAQ,EAAE;QAC1B,oBAAO1B,KAAA,CAAAc,aAAA,CAACZ,YAAY;UAACE,IAAI,EAAEoB,KAAM;UAACd,QAAQ,EAAEA,QAAQ,CAACgB,QAAQ,CAAE;UAACJ,GAAG,EAAEI,QAAS;UAACX,IAAI;QAAA,CAAE,CAAC;MACxF;MAEA,OAAO,IAAI;IACb,CAAC,CAAC;EACJ;EAEA,OAAO,IAAI;AACb,CAAC;AAED,eAAeZ,QAAQ","ignoreList":[]}
|