UNPKG

@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
"use strict"; 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