@tmnrp/react-breadcrumbs
Version:
Breadcrumbs is a component that can be used to display location of current route. Configurable icon, text and seperator as per need
85 lines • 4.5 kB
JavaScript
;
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
var __rest = (this && this.__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;
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.useBreadcrumbs = exports.Breadcrumbs = void 0;
/* eslint-disable react/display-name */
const react_1 = __importStar(require("react"));
const react_2 = require("react");
const react_3 = require("react");
exports.Breadcrumbs = (0, react_1.forwardRef)((_a, ref) => {
var { className = "", style, seperator = "/", crumbsProps = {}, seperatorProps, iconProps, labelProps } = _a, props = __rest(_a, ["className", "style", "seperator", "crumbsProps", "seperatorProps", "iconProps", "labelProps"]);
const [crumbs, setCrumbs] = (0, react_2.useState)(props.crumbs);
(0, react_3.useImperativeHandle)(ref, () => ({
setCrumbs: setCrumbs,
}));
const { className: crumbsPropsClassName } = crumbsProps, crumbsPropsRest = __rest(crumbsProps, ["className"]);
//
return (react_1.default.createElement("div", Object.assign({ className: `tm-breadcrumbs ${className}`, style: Object.assign({ display: "flex" }, style) }, props), crumbs === null || crumbs === void 0 ? void 0 : crumbs.map((_a, i) => {
var { className = "", icon, label, style = {} } = _a, props = __rest(_a, ["className", "icon", "label", "style"]);
return (react_1.default.createElement("div", Object.assign({ key: i, className: `crumb ${crumbsPropsClassName} ${className}`, style: Object.assign({ display: "flex" }, style) }, crumbsPropsRest, props),
react_1.default.createElement(Seperator, Object.assign({}, seperatorProps), seperator),
icon && react_1.default.createElement(Icon, Object.assign({}, iconProps), icon),
label && react_1.default.createElement(Label, Object.assign({}, labelProps), label)));
})));
});
const Seperator = (_a) => {
var { children, style = {} } = _a, props = __rest(_a, ["children", "style"]);
return (react_1.default.createElement("div", Object.assign({ style: {
display: "flex",
alignItems: "center",
} }, props), children));
};
const Icon = (_a) => {
var { children, style = {} } = _a, props = __rest(_a, ["children", "style"]);
return (react_1.default.createElement("div", Object.assign({ style: {
display: "flex",
alignItems: "center",
} }, props), children));
};
const Label = (_a) => {
var { children, style = {} } = _a, props = __rest(_a, ["children", "style"]);
return (react_1.default.createElement("div", Object.assign({ style: {
display: "flex",
alignItems: "center",
} }, props), children));
};
//
const useBreadcrumbs = ({ ref, crumbs, }) => {
(0, react_1.useEffect)(() => {
const currRef = ref === null || ref === void 0 ? void 0 : ref.current;
currRef === null || currRef === void 0 ? void 0 : currRef.setCrumbs(crumbs);
// cleanup : clear the breadcrumb
return () => currRef === null || currRef === void 0 ? void 0 : currRef.setCrumbs([]);
}, [ref, crumbs]);
};
exports.useBreadcrumbs = useBreadcrumbs;
//# sourceMappingURL=index.js.map