@teamias/pro-layout 0.0.12 → 0.0.13

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.
@@ -1,4 +1,5 @@
1
1
  import { useEffect } from 'react';
2
+ import { useIntl } from 'react-intl';
2
3
  import { useAccessRouter } from "../hooks";
3
4
  import { Fragment as _Fragment } from "react/jsx-runtime";
4
5
  import { jsx as _jsx } from "react/jsx-runtime";
@@ -8,7 +9,10 @@ export var DocumentTitle = function DocumentTitle(_ref) {
8
9
  _useAccessRouter$loca = _useAccessRouter.location,
9
10
  pageStatus = _useAccessRouter$loca.pageStatus,
10
11
  pathname = _useAccessRouter$loca.pathname,
11
- pageTitle = _useAccessRouter$loca.pageTitle;
12
+ pageTitle = _useAccessRouter$loca.pageTitle,
13
+ intlMenuConfig = _useAccessRouter$loca.intlMenuConfig;
14
+ var _useIntl = useIntl(),
15
+ formatMessage = _useIntl.formatMessage;
12
16
  useEffect(function () {
13
17
  if (title) {
14
18
  document.title = title;
@@ -18,7 +22,7 @@ export var DocumentTitle = function DocumentTitle(_ref) {
18
22
  // document.title = pageStatus + '';
19
23
  // return;
20
24
  // }
21
- document.title = pageTitle;
22
- }, [pathname, pageStatus, pageTitle, title]);
25
+ document.title = pageTitle || formatMessage(intlMenuConfig || {});
26
+ }, [pathname, pageStatus, pageTitle, intlMenuConfig, title]);
23
27
  return /*#__PURE__*/_jsx(_Fragment, {});
24
28
  };
@@ -19,6 +19,11 @@ export declare class KeepAliveClass {
19
19
  getPages(): (import("react-router-dom").Location & {
20
20
  pageStatus: 200 | 404 | 403;
21
21
  pageTitle: string;
22
+ intlMenuConfig?: {
23
+ id: string;
24
+ defaultMessage: string;
25
+ localConfigPath: string;
26
+ } | undefined;
22
27
  })[];
23
28
  /** 关闭页面 */
24
29
  closePage(assignKey: string): number;
@@ -34,6 +39,11 @@ export declare class KeepAliveClass {
34
39
  useKeepAlivePages: () => (import("react-router-dom").Location & {
35
40
  pageStatus: 200 | 404 | 403;
36
41
  pageTitle: string;
42
+ intlMenuConfig?: {
43
+ id: string;
44
+ defaultMessage: string;
45
+ localConfigPath: string;
46
+ } | undefined;
37
47
  })[];
38
48
  /** 更新当前路由页面 */
39
49
  updateCurrentPage(index?: number): void;
@@ -8,6 +8,11 @@ export declare const useLifeCycle: (callback: import("./types").IPageLifeCycleCa
8
8
  export declare const useKeepAlivePages: () => (import("react-router-dom").Location & {
9
9
  pageStatus: 200 | 404 | 403;
10
10
  pageTitle: string;
11
+ intlMenuConfig?: {
12
+ id: string;
13
+ defaultMessage: string;
14
+ localConfigPath: string;
15
+ } | undefined;
11
16
  })[];
12
17
  /** 根 */
13
18
  export declare const KeepAliveRoot: () => import("react/jsx-runtime").JSX.Element;
@@ -1,8 +1,8 @@
1
- import { FC } from 'react';
1
+ import { FC, ReactNode } from 'react';
2
2
  import { TABS_LAYOUT } from '../../constant';
3
3
  export declare const TabItem: FC<{
4
4
  isCurrent: boolean;
5
- pageTitle: string;
5
+ pageTitle: ReactNode;
6
6
  pathname: string;
7
7
  onClickMenu: (key: TABS_LAYOUT, pathname: string) => void;
8
8
  }>;
@@ -1,4 +1,9 @@
1
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); }
2
7
  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
8
  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
9
  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); }); }; }
@@ -6,6 +11,7 @@ import { useStateData } from '@teamias/rex-design';
6
11
  import { Tabs, message } from 'antd';
7
12
  import { eq } from 'lodash-es';
8
13
  import { useEffect } from 'react';
14
+ import { FormattedMessage } from 'react-intl';
9
15
  import { useNavigate } from 'react-router-dom';
10
16
  import { TABS_LAYOUT } from "../../constant";
11
17
  import { useAccessRouter } from "../../hooks";
@@ -132,7 +138,7 @@ export var TabsLayout = function TabsLayout() {
132
138
  return {
133
139
  key: item.pathname,
134
140
  label: /*#__PURE__*/_jsx(TabItem, {
135
- pageTitle: item.pageTitle,
141
+ pageTitle: item.pageTitle || /*#__PURE__*/_jsx(FormattedMessage, _objectSpread({}, item.intlMenuConfig)),
136
142
  pathname: item.pathname,
137
143
  isCurrent: isCurrent,
138
144
  onClickMenu: handleClickMenu
@@ -11,6 +11,13 @@ export declare const useAccessRouter: () => {
11
11
  };
12
12
  location: import("react-router-dom").Location & {
13
13
  pageStatus: 200 | 404 | 403;
14
+ /** 接口上的页面标题 */
14
15
  pageTitle: string;
16
+ /** 国际化菜单配置 */
17
+ intlMenuConfig?: {
18
+ id: string;
19
+ defaultMessage: string;
20
+ localConfigPath: string;
21
+ } | undefined;
15
22
  };
16
23
  };
@@ -12,9 +12,10 @@ var getMenuFormattedTitle = function getMenuFormattedTitle(pageComponentMap, men
12
12
  var localConfigPath = Object.keys(pageComponentMap || {}).find(function (p) {
13
13
  return matchPath(p, menuKey);
14
14
  }) || menuKey;
15
+ var id = "menu".concat(localConfigPath.replaceAll('/', '.'));
15
16
  return {
16
- id: "menu".concat(localConfigPath.replaceAll('/', '.')),
17
- defaultMessage: defaultName || '',
17
+ id: id,
18
+ defaultMessage: "".concat(defaultName, "-id:").concat(id),
18
19
  localConfigPath: localConfigPath
19
20
  };
20
21
  };
@@ -47,7 +48,8 @@ export var useAccessRouter = function useAccessRouter() {
47
48
 
48
49
  // 补充数据
49
50
  location.pageStatus = 200;
50
- location.pageTitle = ((_fullPathDataMap = fullPathDataMap[((_currentPage = currentPage) === null || _currentPage === void 0 ? void 0 : _currentPage.path) || location.pathname]) === null || _fullPathDataMap === void 0 || (_fullPathDataMap = _fullPathDataMap.raw) === null || _fullPathDataMap === void 0 ? void 0 : _fullPathDataMap.title) || formatMessage(getMenuFormattedTitle(pageComponentMap, location.pathname, '未知页面'));
51
+ location.intlMenuConfig = getMenuFormattedTitle(pageComponentMap, location.pathname, '未匹配到菜单名称');
52
+ location.pageTitle = (_fullPathDataMap = fullPathDataMap[((_currentPage = currentPage) === null || _currentPage === void 0 ? void 0 : _currentPage.path) || location.pathname]) === null || _fullPathDataMap === void 0 || (_fullPathDataMap = _fullPathDataMap.raw) === null || _fullPathDataMap === void 0 ? void 0 : _fullPathDataMap.title;
51
53
 
52
54
  // 路由不存在, 但有菜单, 使用默认页面
53
55
  if (!currentPage && fullPathDataMap[location.pathname]) {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@teamias/pro-layout",
3
- "version": "0.0.12",
3
+ "version": "0.0.13",
4
4
  "description": "A react library developed with dumi",
5
5
  "license": "MIT",
6
6
  "module": "dist/index.js",