tntd
Version:
tntd是基于 TNT Design 设计体系的 React UI 组件库,主要用于研发企业级中后台产品。
48 lines (47 loc) • 1.63 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _react = _interopRequireDefault(require("react"));
function _interopRequireDefault(e) {
return e && e.__esModule ? e : {
"default": e
};
}
var __rest = void 0 && (void 0).__rest || function (s, e) {
var t = {};
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
}
return t;
};
var _default = exports["default"] = function _default(props) {
var children = props.children,
href = props.href,
unmountHandle = props.unmountHandle,
rest = __rest(props, ["children", "href", "unmountHandle"]);
if (window.__isMultiTab__) {
return _react["default"].createElement("a", {
onClick: function onClick(evt) {
evt.preventDefault();
if (unmountHandle && typeof unmountHandle === 'function') {
unmountHandle();
}
var pathName = href;
if (href && href.includes('?')) {
pathName = href === null || href === void 0 ? void 0 : href.split('?')[0];
}
if (pathName === window.location.pathname) {
window.location.href = href;
} else {
window.push(href);
}
}
}, children);
}
return _react["default"].createElement("a", Object.assign({
href: href
}, rest), children);
};