1 | "use strict";
|
2 |
|
3 | var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
4 |
|
5 | var _typeof = require("@babel/runtime/helpers/typeof");
|
6 |
|
7 | Object.defineProperty(exports, "__esModule", {
|
8 | value: true
|
9 | });
|
10 | exports["default"] = void 0;
|
11 |
|
12 | var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
13 |
|
14 | var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
15 |
|
16 | var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
17 |
|
18 | var React = _interopRequireWildcard(require("react"));
|
19 |
|
20 | var _classnames = _interopRequireDefault(require("classnames"));
|
21 |
|
22 | var _toArray = _interopRequireDefault(require("rc-util/lib/Children/toArray"));
|
23 |
|
24 | var _BreadcrumbItem = _interopRequireDefault(require("./BreadcrumbItem"));
|
25 |
|
26 | var _BreadcrumbSeparator = _interopRequireDefault(require("./BreadcrumbSeparator"));
|
27 |
|
28 | var _menu = _interopRequireDefault(require("../menu"));
|
29 |
|
30 | var _configProvider = require("../config-provider");
|
31 |
|
32 | var _devWarning = _interopRequireDefault(require("../_util/devWarning"));
|
33 |
|
34 | var _reactNode = require("../_util/reactNode");
|
35 |
|
36 | function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
37 |
|
38 | function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
39 |
|
40 | var __rest = void 0 && (void 0).__rest || function (s, e) {
|
41 | var t = {};
|
42 |
|
43 | for (var p in s) {
|
44 | if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
|
45 | }
|
46 |
|
47 | if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
48 | if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
|
49 | }
|
50 | return t;
|
51 | };
|
52 |
|
53 | function getBreadcrumbName(route, params) {
|
54 | if (!route.breadcrumbName) {
|
55 | return null;
|
56 | }
|
57 |
|
58 | var paramsKeys = Object.keys(params).join('|');
|
59 | var name = route.breadcrumbName.replace(new RegExp(":(".concat(paramsKeys, ")"), 'g'), function (replacement, key) {
|
60 | return params[key] || replacement;
|
61 | });
|
62 | return name;
|
63 | }
|
64 |
|
65 | function defaultItemRender(route, params, routes, paths) {
|
66 | var isLastItem = routes.indexOf(route) === routes.length - 1;
|
67 | var name = getBreadcrumbName(route, params);
|
68 | return isLastItem ? React.createElement("span", null, name) : React.createElement("a", {
|
69 | href: "#/".concat(paths.join('/'))
|
70 | }, name);
|
71 | }
|
72 |
|
73 | var getPath = function getPath(path, params) {
|
74 | path = (path || '').replace(/^\//, '');
|
75 | Object.keys(params).forEach(function (key) {
|
76 | path = path.replace(":".concat(key), params[key]);
|
77 | });
|
78 | return path;
|
79 | };
|
80 |
|
81 | var addChildPath = function addChildPath(paths) {
|
82 | var childPath = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';
|
83 | var params = arguments.length > 2 ? arguments[2] : undefined;
|
84 | var originalPaths = (0, _toConsumableArray2["default"])(paths);
|
85 | var path = getPath(childPath, params);
|
86 |
|
87 | if (path) {
|
88 | originalPaths.push(path);
|
89 | }
|
90 |
|
91 | return originalPaths;
|
92 | };
|
93 |
|
94 | var Breadcrumb = function Breadcrumb(_a) {
|
95 | var customizePrefixCls = _a.prefixCls,
|
96 | _a$separator = _a.separator,
|
97 | separator = _a$separator === void 0 ? '/' : _a$separator,
|
98 | style = _a.style,
|
99 | className = _a.className,
|
100 | routes = _a.routes,
|
101 | children = _a.children,
|
102 | _a$itemRender = _a.itemRender,
|
103 | itemRender = _a$itemRender === void 0 ? defaultItemRender : _a$itemRender,
|
104 | _a$params = _a.params,
|
105 | params = _a$params === void 0 ? {} : _a$params,
|
106 | restProps = __rest(_a, ["prefixCls", "separator", "style", "className", "routes", "children", "itemRender", "params"]);
|
107 |
|
108 | var _React$useContext = React.useContext(_configProvider.ConfigContext),
|
109 | getPrefixCls = _React$useContext.getPrefixCls,
|
110 | direction = _React$useContext.direction;
|
111 |
|
112 | var crumbs;
|
113 | var prefixCls = getPrefixCls('breadcrumb', customizePrefixCls);
|
114 |
|
115 | if (routes && routes.length > 0) {
|
116 |
|
117 | var paths = [];
|
118 | crumbs = routes.map(function (route) {
|
119 | var path = getPath(route.path, params);
|
120 |
|
121 | if (path) {
|
122 | paths.push(path);
|
123 | }
|
124 |
|
125 |
|
126 | var overlay;
|
127 |
|
128 | if (route.children && route.children.length) {
|
129 | overlay = React.createElement(_menu["default"], null, route.children.map(function (child) {
|
130 | return React.createElement(_menu["default"].Item, {
|
131 | key: child.path || child.breadcrumbName
|
132 | }, itemRender(child, params, routes, addChildPath(paths, child.path, params)));
|
133 | }));
|
134 | }
|
135 |
|
136 | return React.createElement(_BreadcrumbItem["default"], {
|
137 | overlay: overlay,
|
138 | separator: separator,
|
139 | key: path || route.breadcrumbName
|
140 | }, itemRender(route, params, routes, paths));
|
141 | });
|
142 | } else if (children) {
|
143 | crumbs = (0, _toArray["default"])(children).map(function (element, index) {
|
144 | if (!element) {
|
145 | return element;
|
146 | }
|
147 |
|
148 | (0, _devWarning["default"])(element.type && (element.type.__ANT_BREADCRUMB_ITEM === true || element.type.__ANT_BREADCRUMB_SEPARATOR === true), 'Breadcrumb', "Only accepts Breadcrumb.Item and Breadcrumb.Separator as it's children");
|
149 | return (0, _reactNode.cloneElement)(element, {
|
150 | separator: separator,
|
151 | key: index
|
152 | });
|
153 | });
|
154 | }
|
155 |
|
156 | var breadcrumbClassName = (0, _classnames["default"])(prefixCls, (0, _defineProperty2["default"])({}, "".concat(prefixCls, "-rtl"), direction === 'rtl'), className);
|
157 | return React.createElement("div", (0, _extends2["default"])({
|
158 | className: breadcrumbClassName,
|
159 | style: style
|
160 | }, restProps), crumbs);
|
161 | };
|
162 |
|
163 | Breadcrumb.Item = _BreadcrumbItem["default"];
|
164 | Breadcrumb.Separator = _BreadcrumbSeparator["default"];
|
165 | var _default = Breadcrumb;
|
166 | exports["default"] = _default; |
\ | No newline at end of file |