@teamias/pro-layout 0.0.1
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/LICENSE +21 -0
- package/README.md +0 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +1 -0
- package/dist/markdowns/example1/BasicRexProLayout/index.d.ts +3 -0
- package/dist/markdowns/example1/BasicRexProLayout/index.js +83 -0
- package/dist/markdowns/example1/BasicRexProLayout/pages/Home.d.ts +1 -0
- package/dist/markdowns/example1/BasicRexProLayout/pages/Home.js +21 -0
- package/dist/markdowns/example1/BasicRexProLayout/pages/Level1.d.ts +1 -0
- package/dist/markdowns/example1/BasicRexProLayout/pages/Level1.js +21 -0
- package/dist/markdowns/example1/BasicRexProLayout/pages/Level2.d.ts +1 -0
- package/dist/markdowns/example1/BasicRexProLayout/pages/Level2.js +21 -0
- package/dist/markdowns/example1/BasicRexProLayout/testData.d.ts +53 -0
- package/dist/markdowns/example1/BasicRexProLayout/testData.js +82 -0
- package/dist/pro-layout/assets/login-bg.png +0 -0
- package/dist/pro-layout/assets/logo.png +0 -0
- package/dist/pro-layout/components/AvatarItem.d.ts +3 -0
- package/dist/pro-layout/components/AvatarItem.js +93 -0
- package/dist/pro-layout/components/Collapsed.d.ts +5 -0
- package/dist/pro-layout/components/Collapsed.js +23 -0
- package/dist/pro-layout/components/DocumentTitle.d.ts +4 -0
- package/dist/pro-layout/components/DocumentTitle.js +24 -0
- package/dist/pro-layout/components/KeepAlive/KeepAliveClass.d.ts +44 -0
- package/dist/pro-layout/components/KeepAlive/KeepAliveClass.js +448 -0
- package/dist/pro-layout/components/KeepAlive/index.d.ts +13 -0
- package/dist/pro-layout/components/KeepAlive/index.js +17 -0
- package/dist/pro-layout/components/KeepAlive/modules/useCacheTabsLayout.d.ts +26 -0
- package/dist/pro-layout/components/KeepAlive/modules/useCacheTabsLayout.js +75 -0
- package/dist/pro-layout/components/KeepAlive/types.d.ts +25 -0
- package/dist/pro-layout/components/KeepAlive/types.js +9 -0
- package/dist/pro-layout/components/Login/Account.d.ts +1 -0
- package/dist/pro-layout/components/Login/Account.js +41 -0
- package/dist/pro-layout/components/Login/index.d.ts +3 -0
- package/dist/pro-layout/components/Login/index.js +127 -0
- package/dist/pro-layout/components/Login/style.d.ts +2 -0
- package/dist/pro-layout/components/Login/style.js +5 -0
- package/dist/pro-layout/components/Menu/index.d.ts +8 -0
- package/dist/pro-layout/components/Menu/index.js +142 -0
- package/dist/pro-layout/components/Menu/style.d.ts +7 -0
- package/dist/pro-layout/components/Menu/style.js +19 -0
- package/dist/pro-layout/components/NoFoundPage/index.d.ts +4 -0
- package/dist/pro-layout/components/NoFoundPage/index.js +45 -0
- package/dist/pro-layout/components/PageLoading.d.ts +2 -0
- package/dist/pro-layout/components/PageLoading.js +14 -0
- package/dist/pro-layout/components/SystemId.d.ts +3 -0
- package/dist/pro-layout/components/SystemId.js +17 -0
- package/dist/pro-layout/components/TabsLayout/index.d.ts +2 -0
- package/dist/pro-layout/components/TabsLayout/index.js +193 -0
- package/dist/pro-layout/constant/index.d.ts +20 -0
- package/dist/pro-layout/constant/index.js +19 -0
- package/dist/pro-layout/context/index.d.ts +6 -0
- package/dist/pro-layout/context/index.js +84 -0
- package/dist/pro-layout/core/index.d.ts +4 -0
- package/dist/pro-layout/core/index.js +222 -0
- package/dist/pro-layout/hooks/index.d.ts +14 -0
- package/dist/pro-layout/hooks/index.js +65 -0
- package/dist/pro-layout/index.d.ts +4 -0
- package/dist/pro-layout/index.js +4 -0
- package/dist/pro-layout/style/index.d.ts +27 -0
- package/dist/pro-layout/style/index.js +57 -0
- package/dist/pro-layout/types/index.d.ts +154 -0
- package/dist/pro-layout/types/index.js +1 -0
- package/dist/pro-layout/utils/index.d.ts +25 -0
- package/dist/pro-layout/utils/index.js +63 -0
- package/dist/pro-layout/utils/menu.d.ts +15 -0
- package/dist/pro-layout/utils/menu.js +122 -0
- package/dist/types/svg.d.ts +24 -0
- package/package.json +108 -0
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { ProFormText } from '@ant-design/pro-components';
|
|
2
|
+
import { Icons } from '@teamias/rex-design';
|
|
3
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
4
|
+
import { Fragment as _Fragment } from "react/jsx-runtime";
|
|
5
|
+
import { jsxs as _jsxs } from "react/jsx-runtime";
|
|
6
|
+
export var Account = function Account() {
|
|
7
|
+
// const { formatMessage } = useIntl();
|
|
8
|
+
|
|
9
|
+
return /*#__PURE__*/_jsxs(_Fragment, {
|
|
10
|
+
children: [/*#__PURE__*/_jsx(ProFormText, {
|
|
11
|
+
name: "username",
|
|
12
|
+
fieldProps: {
|
|
13
|
+
size: 'large',
|
|
14
|
+
prefix: /*#__PURE__*/_jsx(Icons, {
|
|
15
|
+
type: "iconify",
|
|
16
|
+
name: "ri:user-line"
|
|
17
|
+
})
|
|
18
|
+
},
|
|
19
|
+
placeholder: "\u7528\u6237\u540D",
|
|
20
|
+
rules: [{
|
|
21
|
+
required: true,
|
|
22
|
+
message: '用户名是必填项!'
|
|
23
|
+
}]
|
|
24
|
+
}), /*#__PURE__*/_jsx(ProFormText.Password, {
|
|
25
|
+
name: "password",
|
|
26
|
+
fieldProps: {
|
|
27
|
+
size: 'large',
|
|
28
|
+
prefix: /*#__PURE__*/_jsx(Icons, {
|
|
29
|
+
type: "iconify",
|
|
30
|
+
name: "ri:lock-line"
|
|
31
|
+
}),
|
|
32
|
+
visibilityToggle: false
|
|
33
|
+
},
|
|
34
|
+
placeholder: "\u5BC6\u7801",
|
|
35
|
+
rules: [{
|
|
36
|
+
required: true,
|
|
37
|
+
message: '密码是必填项!'
|
|
38
|
+
}]
|
|
39
|
+
})]
|
|
40
|
+
});
|
|
41
|
+
};
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
2
|
+
function _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return e; }; var t, e = {}, r = Object.prototype, n = r.hasOwnProperty, o = Object.defineProperty || function (t, e, r) { t[e] = r.value; }, i = "function" == typeof Symbol ? Symbol : {}, a = i.iterator || "@@iterator", c = i.asyncIterator || "@@asyncIterator", u = i.toStringTag || "@@toStringTag"; function define(t, e, r) { return Object.defineProperty(t, e, { value: r, enumerable: !0, configurable: !0, writable: !0 }), t[e]; } try { define({}, ""); } catch (t) { define = function define(t, e, r) { return t[e] = r; }; } function wrap(t, e, r, n) { var i = e && e.prototype instanceof Generator ? e : Generator, a = Object.create(i.prototype), c = new Context(n || []); return o(a, "_invoke", { value: makeInvokeMethod(t, r, c) }), a; } function tryCatch(t, e, r) { try { return { type: "normal", arg: t.call(e, r) }; } catch (t) { return { type: "throw", arg: t }; } } e.wrap = wrap; var h = "suspendedStart", l = "suspendedYield", f = "executing", s = "completed", y = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var p = {}; define(p, a, function () { return this; }); var d = Object.getPrototypeOf, v = d && d(d(values([]))); v && v !== r && n.call(v, a) && (p = v); var g = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(p); function defineIteratorMethods(t) { ["next", "throw", "return"].forEach(function (e) { define(t, e, function (t) { return this._invoke(e, t); }); }); } function AsyncIterator(t, e) { function invoke(r, o, i, a) { var c = tryCatch(t[r], t, o); if ("throw" !== c.type) { var u = c.arg, h = u.value; return h && "object" == _typeof(h) && n.call(h, "__await") ? e.resolve(h.__await).then(function (t) { invoke("next", t, i, a); }, function (t) { invoke("throw", t, i, a); }) : e.resolve(h).then(function (t) { u.value = t, i(u); }, function (t) { return invoke("throw", t, i, a); }); } a(c.arg); } var r; o(this, "_invoke", { value: function value(t, n) { function callInvokeWithMethodAndArg() { return new e(function (e, r) { invoke(t, n, e, r); }); } return r = r ? r.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); } }); } function makeInvokeMethod(e, r, n) { var o = h; return function (i, a) { if (o === f) throw new Error("Generator is already running"); if (o === s) { if ("throw" === i) throw a; return { value: t, done: !0 }; } for (n.method = i, n.arg = a;;) { var c = n.delegate; if (c) { var u = maybeInvokeDelegate(c, n); if (u) { if (u === y) continue; return u; } } if ("next" === n.method) n.sent = n._sent = n.arg;else if ("throw" === n.method) { if (o === h) throw o = s, n.arg; n.dispatchException(n.arg); } else "return" === n.method && n.abrupt("return", n.arg); o = f; var p = tryCatch(e, r, n); if ("normal" === p.type) { if (o = n.done ? s : l, p.arg === y) continue; return { value: p.arg, done: n.done }; } "throw" === p.type && (o = s, n.method = "throw", n.arg = p.arg); } }; } function maybeInvokeDelegate(e, r) { var n = r.method, o = e.iterator[n]; if (o === t) return r.delegate = null, "throw" === n && e.iterator.return && (r.method = "return", r.arg = t, maybeInvokeDelegate(e, r), "throw" === r.method) || "return" !== n && (r.method = "throw", r.arg = new TypeError("The iterator does not provide a '" + n + "' method")), y; var i = tryCatch(o, e.iterator, r.arg); if ("throw" === i.type) return r.method = "throw", r.arg = i.arg, r.delegate = null, y; var a = i.arg; return a ? a.done ? (r[e.resultName] = a.value, r.next = e.nextLoc, "return" !== r.method && (r.method = "next", r.arg = t), r.delegate = null, y) : a : (r.method = "throw", r.arg = new TypeError("iterator result is not an object"), r.delegate = null, y); } function pushTryEntry(t) { var e = { tryLoc: t[0] }; 1 in t && (e.catchLoc = t[1]), 2 in t && (e.finallyLoc = t[2], e.afterLoc = t[3]), this.tryEntries.push(e); } function resetTryEntry(t) { var e = t.completion || {}; e.type = "normal", delete e.arg, t.completion = e; } function Context(t) { this.tryEntries = [{ tryLoc: "root" }], t.forEach(pushTryEntry, this), this.reset(!0); } function values(e) { if (e || "" === e) { var r = e[a]; if (r) return r.call(e); if ("function" == typeof e.next) return e; if (!isNaN(e.length)) { var o = -1, i = function next() { for (; ++o < e.length;) if (n.call(e, o)) return next.value = e[o], next.done = !1, next; return next.value = t, next.done = !0, next; }; return i.next = i; } } throw new TypeError(_typeof(e) + " is not iterable"); } return GeneratorFunction.prototype = GeneratorFunctionPrototype, o(g, "constructor", { value: GeneratorFunctionPrototype, configurable: !0 }), o(GeneratorFunctionPrototype, "constructor", { value: GeneratorFunction, configurable: !0 }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, u, "GeneratorFunction"), e.isGeneratorFunction = function (t) { var e = "function" == typeof t && t.constructor; return !!e && (e === GeneratorFunction || "GeneratorFunction" === (e.displayName || e.name)); }, e.mark = function (t) { return Object.setPrototypeOf ? Object.setPrototypeOf(t, GeneratorFunctionPrototype) : (t.__proto__ = GeneratorFunctionPrototype, define(t, u, "GeneratorFunction")), t.prototype = Object.create(g), t; }, e.awrap = function (t) { return { __await: t }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, c, function () { return this; }), e.AsyncIterator = AsyncIterator, e.async = function (t, r, n, o, i) { void 0 === i && (i = Promise); var a = new AsyncIterator(wrap(t, r, n, o), i); return e.isGeneratorFunction(r) ? a : a.next().then(function (t) { return t.done ? t.value : a.next(); }); }, defineIteratorMethods(g), define(g, u, "Generator"), define(g, a, function () { return this; }), define(g, "toString", function () { return "[object Generator]"; }), e.keys = function (t) { var e = Object(t), r = []; for (var n in e) r.push(n); return r.reverse(), function next() { for (; r.length;) { var t = r.pop(); if (t in e) return next.value = t, next.done = !1, next; } return next.done = !0, next; }; }, e.values = values, Context.prototype = { constructor: Context, reset: function reset(e) { if (this.prev = 0, this.next = 0, this.sent = this._sent = t, this.done = !1, this.delegate = null, this.method = "next", this.arg = t, this.tryEntries.forEach(resetTryEntry), !e) for (var r in this) "t" === r.charAt(0) && n.call(this, r) && !isNaN(+r.slice(1)) && (this[r] = t); }, stop: function stop() { this.done = !0; var t = this.tryEntries[0].completion; if ("throw" === t.type) throw t.arg; return this.rval; }, dispatchException: function dispatchException(e) { if (this.done) throw e; var r = this; function handle(n, o) { return a.type = "throw", a.arg = e, r.next = n, o && (r.method = "next", r.arg = t), !!o; } for (var o = this.tryEntries.length - 1; o >= 0; --o) { var i = this.tryEntries[o], a = i.completion; if ("root" === i.tryLoc) return handle("end"); if (i.tryLoc <= this.prev) { var c = n.call(i, "catchLoc"), u = n.call(i, "finallyLoc"); if (c && u) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } else if (c) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); } else { if (!u) throw new Error("try statement without catch or finally"); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } } } }, abrupt: function abrupt(t, e) { for (var r = this.tryEntries.length - 1; r >= 0; --r) { var o = this.tryEntries[r]; if (o.tryLoc <= this.prev && n.call(o, "finallyLoc") && this.prev < o.finallyLoc) { var i = o; break; } } i && ("break" === t || "continue" === t) && i.tryLoc <= e && e <= i.finallyLoc && (i = null); var a = i ? i.completion : {}; return a.type = t, a.arg = e, i ? (this.method = "next", this.next = i.finallyLoc, y) : this.complete(a); }, complete: function complete(t, e) { if ("throw" === t.type) throw t.arg; return "break" === t.type || "continue" === t.type ? this.next = t.arg : "return" === t.type ? (this.rval = this.arg = t.arg, this.method = "return", this.next = "end") : "normal" === t.type && e && (this.next = e), y; }, finish: function finish(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.finallyLoc === t) return this.complete(r.completion, r.afterLoc), resetTryEntry(r), y; } }, catch: function _catch(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.tryLoc === t) { var n = r.completion; if ("throw" === n.type) { var o = n.arg; resetTryEntry(r); } return o; } } throw new Error("illegal catch attempt"); }, delegateYield: function delegateYield(e, r, n) { return this.delegate = { iterator: values(e), resultName: r, nextLoc: n }, "next" === this.method && (this.arg = t), y; } }, e; }
|
|
3
|
+
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }
|
|
4
|
+
function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
|
|
5
|
+
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
6
|
+
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
7
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
8
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
|
|
9
|
+
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
10
|
+
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
11
|
+
import { SmileOutlined } from '@ant-design/icons';
|
|
12
|
+
import { LoginForm } from '@ant-design/pro-components';
|
|
13
|
+
import { Col, Row, message, notification } from 'antd';
|
|
14
|
+
import dayjs from 'dayjs';
|
|
15
|
+
import relativeTime from 'dayjs/plugin/relativeTime';
|
|
16
|
+
import { useState } from 'react';
|
|
17
|
+
import { LOCAL_STORAGE } from "../../constant";
|
|
18
|
+
import { useLayoutContext } from "../../context";
|
|
19
|
+
import { setLocalStorageItem } from "../../utils";
|
|
20
|
+
import { Account } from "./Account"; // 账户密码登录
|
|
21
|
+
import { LoginDiv } from "./style";
|
|
22
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
23
|
+
import { jsxs as _jsxs } from "react/jsx-runtime";
|
|
24
|
+
export var Login = function Login(_ref) {
|
|
25
|
+
var onLogin = _ref.onLogin,
|
|
26
|
+
smallLogoImg = _ref.smallLogoImg,
|
|
27
|
+
renderSelectLang = _ref.renderSelectLang,
|
|
28
|
+
projectTitle = _ref.projectTitle,
|
|
29
|
+
loginBgImg = _ref.loginBgImg;
|
|
30
|
+
dayjs.extend(relativeTime);
|
|
31
|
+
var _useState = useState(false),
|
|
32
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
33
|
+
loginLoading = _useState2[0],
|
|
34
|
+
setLoginLoading = _useState2[1];
|
|
35
|
+
var layoutContext = useLayoutContext();
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
* @description: 获取当前时间
|
|
39
|
+
*/
|
|
40
|
+
var timeFix = function timeFix() {
|
|
41
|
+
var time = new Date();
|
|
42
|
+
var hour = time.getHours();
|
|
43
|
+
return hour < 9 ? '早上好' : hour <= 11 ? '上午好' : hour <= 13 ? '中午好' : hour < 20 ? '下午好' : '夜深了';
|
|
44
|
+
};
|
|
45
|
+
return /*#__PURE__*/_jsxs(LoginDiv, {
|
|
46
|
+
children: [renderSelectLang && /*#__PURE__*/_jsx("div", {
|
|
47
|
+
className: "lang",
|
|
48
|
+
"data-lang": true,
|
|
49
|
+
children: renderSelectLang()
|
|
50
|
+
}), /*#__PURE__*/_jsxs(Row, {
|
|
51
|
+
justify: "center",
|
|
52
|
+
className: "content",
|
|
53
|
+
children: [/*#__PURE__*/_jsx(Col, {
|
|
54
|
+
className: "login-left",
|
|
55
|
+
children: /*#__PURE__*/_jsx("div", {
|
|
56
|
+
className: "login-bg",
|
|
57
|
+
style: {
|
|
58
|
+
backgroundImage: "url(".concat(loginBgImg, ")")
|
|
59
|
+
}
|
|
60
|
+
})
|
|
61
|
+
}), /*#__PURE__*/_jsx(Col, {
|
|
62
|
+
className: "login-form",
|
|
63
|
+
children: /*#__PURE__*/_jsxs(LoginForm, {
|
|
64
|
+
logo: /*#__PURE__*/_jsx("img", {
|
|
65
|
+
alt: "logo",
|
|
66
|
+
src: smallLogoImg
|
|
67
|
+
}),
|
|
68
|
+
title: projectTitle,
|
|
69
|
+
submitter: {
|
|
70
|
+
submitButtonProps: {
|
|
71
|
+
loading: loginLoading
|
|
72
|
+
}
|
|
73
|
+
},
|
|
74
|
+
onFinish: ( /*#__PURE__*/function () {
|
|
75
|
+
var _ref2 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(values) {
|
|
76
|
+
var res, data, token, userInfo;
|
|
77
|
+
return _regeneratorRuntime().wrap(function _callee$(_context) {
|
|
78
|
+
while (1) switch (_context.prev = _context.next) {
|
|
79
|
+
case 0:
|
|
80
|
+
setLoginLoading(true);
|
|
81
|
+
_context.prev = 1;
|
|
82
|
+
_context.next = 4;
|
|
83
|
+
return onLogin(values);
|
|
84
|
+
case 4:
|
|
85
|
+
res = _context.sent;
|
|
86
|
+
data = res || {};
|
|
87
|
+
token = data.token, userInfo = data.userInfo;
|
|
88
|
+
setLocalStorageItem(LOCAL_STORAGE.ACCESS_TOKEN, token || '');
|
|
89
|
+
_context.next = 10;
|
|
90
|
+
return layoutContext.updateData({
|
|
91
|
+
token: token,
|
|
92
|
+
userInfo: userInfo
|
|
93
|
+
});
|
|
94
|
+
case 10:
|
|
95
|
+
notification.success({
|
|
96
|
+
message: "".concat(timeFix(), ", ").concat(userInfo === null || userInfo === void 0 ? void 0 : userInfo.username, " \uD83D\uDC95"),
|
|
97
|
+
icon: /*#__PURE__*/_jsx(SmileOutlined, {})
|
|
98
|
+
});
|
|
99
|
+
_context.next = 17;
|
|
100
|
+
break;
|
|
101
|
+
case 13:
|
|
102
|
+
_context.prev = 13;
|
|
103
|
+
_context.t0 = _context["catch"](1);
|
|
104
|
+
console.error(_context.t0);
|
|
105
|
+
message.error('登录失败,请重试!');
|
|
106
|
+
case 17:
|
|
107
|
+
setLoginLoading(false);
|
|
108
|
+
case 18:
|
|
109
|
+
case "end":
|
|
110
|
+
return _context.stop();
|
|
111
|
+
}
|
|
112
|
+
}, _callee, null, [[1, 13]]);
|
|
113
|
+
}));
|
|
114
|
+
return function (_x) {
|
|
115
|
+
return _ref2.apply(this, arguments);
|
|
116
|
+
};
|
|
117
|
+
}()),
|
|
118
|
+
children: [/*#__PURE__*/_jsx("div", {
|
|
119
|
+
style: {
|
|
120
|
+
height: 40
|
|
121
|
+
}
|
|
122
|
+
}), /*#__PURE__*/_jsx(Account, {})]
|
|
123
|
+
})
|
|
124
|
+
})]
|
|
125
|
+
})]
|
|
126
|
+
});
|
|
127
|
+
};
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
export declare const LoginDiv: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components").FastOmit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, never>> & string;
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import styled from 'styled-components';
|
|
2
|
+
export var LoginDiv = styled.div.withConfig({
|
|
3
|
+
displayName: "LoginDiv",
|
|
4
|
+
componentId: "pro-layout-aaf4__sc-1v8h1m3-0"
|
|
5
|
+
})(["display:flex;flex-direction:column;height:100vh;overflow:auto;justify-content:center;align-items:center;background:#f0f2f5;.lang{align-self:flex-end;:global(.ant-dropdown-trigger){margin-right:24px;}}.content{background-color:#fff;width:66.7%;box-shadow:0 1px 3px 0 rgb(0 0 0 / 10%),0 1px 2px 0 rgb(0 0 0 / 6%);align-items:center;}.login-left{height:100%;display:none;width:50%;background-color:#ebf4ff;}.login-bg{width:100%;height:100%;background:no-repeat center/cover;}.login-form{width:100%;}@media (min-width:640px){.content{border-radius:0.5rem;height:600px;}}@media (min-width:1024px){.login-left{display:block;}.login-form{width:50%;}}@media (max-width:640px){.content{height:calc(100vh - 124px);width:100%;}}"]);
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
2
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
3
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
4
|
+
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
5
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); }
|
|
6
|
+
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
7
|
+
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
8
|
+
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
9
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
10
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
|
|
11
|
+
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
12
|
+
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
13
|
+
import { useUpdateEffect } from 'ahooks';
|
|
14
|
+
import { Menu as AntdMenu, Tabs, theme } from 'antd';
|
|
15
|
+
import React, { useLayoutEffect, useRef, useState } from 'react';
|
|
16
|
+
import { useLocation } from 'react-router-dom';
|
|
17
|
+
import { useLayoutContext } from "../../context";
|
|
18
|
+
import { MenuContent } from "./style";
|
|
19
|
+
|
|
20
|
+
/** 菜单 */
|
|
21
|
+
import { Fragment as _Fragment } from "react/jsx-runtime";
|
|
22
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
23
|
+
import { jsxs as _jsxs } from "react/jsx-runtime";
|
|
24
|
+
export var Menu = function Menu(_ref) {
|
|
25
|
+
var _menuData$rootChildre;
|
|
26
|
+
var height = _ref.height,
|
|
27
|
+
asideWidth = _ref.asideWidth,
|
|
28
|
+
minAsideWidth = _ref.minAsideWidth,
|
|
29
|
+
collapsed = _ref.collapsed;
|
|
30
|
+
var layoutContext = useLayoutContext();
|
|
31
|
+
var _useLocation = useLocation(),
|
|
32
|
+
pathname = _useLocation.pathname;
|
|
33
|
+
var _theme$useToken = theme.useToken(),
|
|
34
|
+
token = _theme$useToken.token;
|
|
35
|
+
var menuData = layoutContext.routeMenu;
|
|
36
|
+
var _useRef = useRef({
|
|
37
|
+
actives: [],
|
|
38
|
+
cacheActives: []
|
|
39
|
+
}),
|
|
40
|
+
state = _useRef.current;
|
|
41
|
+
var _useState = useState({}),
|
|
42
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
43
|
+
update = _useState2[1];
|
|
44
|
+
var isRightMenu = state.actives.length && (menuData === null || menuData === void 0 || (_menuData$rootChildre = menuData.rootChildrenMap[state.cacheActives[0] || state.actives.at(-1) || '']) === null || _menuData$rootChildre === void 0 ? void 0 : _menuData$rootChildre.length);
|
|
45
|
+
|
|
46
|
+
/** 匹配 */
|
|
47
|
+
var matchPath = function matchPath() {
|
|
48
|
+
var paths = [];
|
|
49
|
+
var arr = pathname.split('/').filter(function (ii) {
|
|
50
|
+
return !!ii;
|
|
51
|
+
});
|
|
52
|
+
var len = arr.length;
|
|
53
|
+
|
|
54
|
+
// 完整路径, 逐渐减少层级
|
|
55
|
+
while (len > 0) {
|
|
56
|
+
paths.push("/".concat(arr.slice(0, len).join('/')));
|
|
57
|
+
len--;
|
|
58
|
+
}
|
|
59
|
+
state.actives = paths;
|
|
60
|
+
state.cacheActives = [];
|
|
61
|
+
|
|
62
|
+
// console.log(paths);
|
|
63
|
+
update({});
|
|
64
|
+
};
|
|
65
|
+
useLayoutEffect(function () {
|
|
66
|
+
matchPath();
|
|
67
|
+
}, []);
|
|
68
|
+
useUpdateEffect(function () {
|
|
69
|
+
matchPath();
|
|
70
|
+
}, [pathname]);
|
|
71
|
+
if (layoutContext.hideMenu) return /*#__PURE__*/_jsx(_Fragment, {});
|
|
72
|
+
return /*#__PURE__*/_jsx(MenuContent, {
|
|
73
|
+
"data-aside-width": collapsed ? minAsideWidth : isRightMenu ? asideWidth : minAsideWidth,
|
|
74
|
+
"data-min-aside-width": minAsideWidth,
|
|
75
|
+
style: {
|
|
76
|
+
height: height,
|
|
77
|
+
'--color-primary': token.colorPrimary,
|
|
78
|
+
'--color-primary-hover': token.colorPrimaryHover
|
|
79
|
+
},
|
|
80
|
+
children: function () {
|
|
81
|
+
if (collapsed) {
|
|
82
|
+
return /*#__PURE__*/_jsxs(_Fragment, {
|
|
83
|
+
children: [/*#__PURE__*/_jsx(AntdMenu, {
|
|
84
|
+
mode: "inline",
|
|
85
|
+
rootClassName: "collapsed-antd-menu"
|
|
86
|
+
// defaultSelectedKeys={['231']}
|
|
87
|
+
// defaultOpenKeys={state.actives}
|
|
88
|
+
,
|
|
89
|
+
selectedKeys: state.actives,
|
|
90
|
+
inlineCollapsed: true
|
|
91
|
+
// onOpenChange={onOpenChange}
|
|
92
|
+
,
|
|
93
|
+
items: menuData === null || menuData === void 0 ? void 0 : menuData.rootData
|
|
94
|
+
// onSelect={(e) => {
|
|
95
|
+
// console.log(e.keyPath);
|
|
96
|
+
// // state.actives = [state.cacheActives[0], ...e.keyPath];
|
|
97
|
+
// // state.cacheActives = [];
|
|
98
|
+
// // update({});
|
|
99
|
+
// }}
|
|
100
|
+
}), /*#__PURE__*/_jsx("div", {
|
|
101
|
+
className: "custom-menu-box"
|
|
102
|
+
})]
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
return /*#__PURE__*/_jsxs(_Fragment, {
|
|
106
|
+
children: [/*#__PURE__*/_jsx(Tabs, {
|
|
107
|
+
activeKey: state.actives.at(-1) || '',
|
|
108
|
+
tabPosition: "left",
|
|
109
|
+
animated: false,
|
|
110
|
+
items: menuData === null || menuData === void 0 ? void 0 : menuData.rootData.map(function (ii) {
|
|
111
|
+
return _objectSpread(_objectSpread({}, ii), {}, {
|
|
112
|
+
children: undefined
|
|
113
|
+
});
|
|
114
|
+
}),
|
|
115
|
+
onTabClick: function onTabClick(e) {
|
|
116
|
+
state.cacheActives = [e];
|
|
117
|
+
state.actives = [e];
|
|
118
|
+
update({});
|
|
119
|
+
}
|
|
120
|
+
}), /*#__PURE__*/_jsx("div", {
|
|
121
|
+
className: "custom-menu-box",
|
|
122
|
+
children: isRightMenu ? /*#__PURE__*/_jsx(AntdMenu, {
|
|
123
|
+
mode: "inline"
|
|
124
|
+
// defaultSelectedKeys={['231']}
|
|
125
|
+
,
|
|
126
|
+
defaultOpenKeys: state.actives,
|
|
127
|
+
selectedKeys: state.actives
|
|
128
|
+
// onOpenChange={onOpenChange}
|
|
129
|
+
,
|
|
130
|
+
items: menuData === null || menuData === void 0 ? void 0 : menuData.rootChildrenMap[state.cacheActives[0] || state.actives.at(-1) || '']
|
|
131
|
+
// onSelect={(e) => {
|
|
132
|
+
// console.log(e.keyPath);
|
|
133
|
+
// // state.actives = [state.cacheActives[0], ...e.keyPath];
|
|
134
|
+
// // state.cacheActives = [];
|
|
135
|
+
// // update({});
|
|
136
|
+
// }}
|
|
137
|
+
}) : /*#__PURE__*/_jsx(_Fragment, {})
|
|
138
|
+
})]
|
|
139
|
+
});
|
|
140
|
+
}()
|
|
141
|
+
});
|
|
142
|
+
};
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
export declare const MenuContent: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components").FastOmit<import("styled-components/dist/types").Substitute<import("styled-components/dist/types").Substitute<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, Omit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & {
|
|
3
|
+
ref?: ((instance: HTMLDivElement | null) => void) | import("react").RefObject<HTMLDivElement> | null | undefined;
|
|
4
|
+
}>, {
|
|
5
|
+
'data-aside-width': string;
|
|
6
|
+
'data-min-aside-width': string;
|
|
7
|
+
}>, never>> & string;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import styled from 'styled-components';
|
|
2
|
+
export var MenuContent = styled.div.attrs({
|
|
3
|
+
className: 'pro-menu-content'
|
|
4
|
+
}).withConfig({
|
|
5
|
+
displayName: "MenuContent",
|
|
6
|
+
componentId: "pro-layout-aaf4__sc-ugvqft-0"
|
|
7
|
+
})(["display:flex;max-width:", ";transition:0.1s;height:100%;background-color:#002140;position:relative;z-index:1;border-inline-end:1px solid #f2f2f2;.ant-tabs-nav{width:", ";}.ant-menu{border:none !important;}.ant-tabs-tab,.collapsed-antd-menu > li,.collapsed-antd-menu > li > .ant-menu-submenu-title{width:", ";height:", ";padding:6px 0 !important;box-sizing:content-box;margin:0 !important;align-items:center;justify-content:center;text-align:center;color:rgba(0,0,0,0.88);position:relative;display:flex;border-radius:0;&:not(.ant-tabs-tab-active){.ant-tabs-tab-btn{color:#fff;}}.ant-tabs-tab-btn,.ant-menu-title-content{white-space:normal;line-height:1.5;}&:hover{background-color:transparent !important;color:var(--color-primary-hover) !important;.ant-tabs-tab-btn,.ant-menu-title-content{color:var(--color-primary-hover);}}&.ant-tabs-tab-active,&.ant-menu-item-selected,&.ant-menu-submenu-selected > .ant-menu-submenu-title{background-color:var(--color-primary) !important;.ant-tabs-tab-btn,.ant-menu-title-content{color:#fff;}}}.ant-tabs-nav-operations{display:none !important;}.ant-tabs-ink-bar,.ant-tabs-content-holder{display:none;}.custom-menu-box{width:", ";overflow:hidden;transition:0.1s;height:inherit;.ant-menu{height:inherit;}}.collapsed-antd-menu{height:inherit;&.ant-menu-inline-collapsed{width:", ";background-color:#002140;}> li,> li > .ant-menu-submenu-title{color:#fff;}}a{position:absolute;left:0;top:0;width:100%;height:100%;z-index:2;}"], function (p) {
|
|
8
|
+
return p['data-aside-width'];
|
|
9
|
+
}, function (p) {
|
|
10
|
+
return p['data-min-aside-width'];
|
|
11
|
+
}, function (p) {
|
|
12
|
+
return p['data-min-aside-width'];
|
|
13
|
+
}, function (p) {
|
|
14
|
+
return p['data-min-aside-width'];
|
|
15
|
+
}, function (p) {
|
|
16
|
+
return "calc(".concat(p['data-aside-width'], " - ").concat(p['data-min-aside-width'], ")");
|
|
17
|
+
}, function (p) {
|
|
18
|
+
return p['data-min-aside-width'];
|
|
19
|
+
});
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
2
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
3
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
4
|
+
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
5
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); }
|
|
6
|
+
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
7
|
+
import { Button, Result } from 'antd';
|
|
8
|
+
import React from 'react';
|
|
9
|
+
import { useLocation, useNavigate } from 'react-router-dom';
|
|
10
|
+
import { useLayoutContext } from "../../context";
|
|
11
|
+
import { keepAliveControl } from "../KeepAlive";
|
|
12
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
13
|
+
export var NoFoundPage = function NoFoundPage(_ref) {
|
|
14
|
+
var _layoutContext$routeM;
|
|
15
|
+
var _ref$type = _ref.type,
|
|
16
|
+
type = _ref$type === void 0 ? 404 : _ref$type;
|
|
17
|
+
var layoutContext = useLayoutContext();
|
|
18
|
+
var location = useLocation();
|
|
19
|
+
var navigate = useNavigate();
|
|
20
|
+
var home = (_layoutContext$routeM = layoutContext.routeMenu) === null || _layoutContext$routeM === void 0 ? void 0 : _layoutContext$routeM.home;
|
|
21
|
+
var config = {
|
|
22
|
+
404: {
|
|
23
|
+
status: '404',
|
|
24
|
+
title: '404',
|
|
25
|
+
subTitle: '您貌似走丢了..'
|
|
26
|
+
},
|
|
27
|
+
403: {
|
|
28
|
+
status: '403',
|
|
29
|
+
title: '403',
|
|
30
|
+
subTitle: '您没有权限访问'
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
return /*#__PURE__*/_jsx(Result, _objectSpread(_objectSpread({}, config[type]), {}, {
|
|
34
|
+
extra: /*#__PURE__*/_jsx(Button, {
|
|
35
|
+
type: "primary",
|
|
36
|
+
onClick: function onClick() {
|
|
37
|
+
if (home) {
|
|
38
|
+
keepAliveControl.closePage(location.pathname);
|
|
39
|
+
navigate((home === null || home === void 0 ? void 0 : home.key) || '/');
|
|
40
|
+
}
|
|
41
|
+
},
|
|
42
|
+
children: "\u56DE\u5230\u4E3B\u9875"
|
|
43
|
+
})
|
|
44
|
+
}));
|
|
45
|
+
};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Spin } from 'antd';
|
|
2
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
export var PageLoading = function PageLoading() {
|
|
4
|
+
return /*#__PURE__*/_jsx(Spin, {
|
|
5
|
+
size: "large",
|
|
6
|
+
tip: "\u7CFB\u7EDF\u52A0\u8F7D\u4E2D",
|
|
7
|
+
children: /*#__PURE__*/_jsx("div", {
|
|
8
|
+
style: {
|
|
9
|
+
height: '50vh',
|
|
10
|
+
overflow: 'hidden'
|
|
11
|
+
}
|
|
12
|
+
})
|
|
13
|
+
});
|
|
14
|
+
};
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { Fragment as _Fragment } from "react/jsx-runtime";
|
|
3
|
+
import { jsxs as _jsxs } from "react/jsx-runtime";
|
|
4
|
+
export var SystemId = function SystemId(_ref) {
|
|
5
|
+
var smallLogoImg = _ref.smallLogoImg,
|
|
6
|
+
projectTitle = _ref.projectTitle;
|
|
7
|
+
return /*#__PURE__*/_jsxs(_Fragment, {
|
|
8
|
+
children: [/*#__PURE__*/_jsx("img", {
|
|
9
|
+
width: "auto",
|
|
10
|
+
height: "22",
|
|
11
|
+
src: smallLogoImg,
|
|
12
|
+
alt: "logo"
|
|
13
|
+
}), /*#__PURE__*/_jsx("h1", {
|
|
14
|
+
children: projectTitle
|
|
15
|
+
})]
|
|
16
|
+
});
|
|
17
|
+
};
|