primereact
Version:
PrimeReact is an open source UI library for React featuring a rich set of 90+ components, a theme designer, various theme alternatives such as Material, Bootstrap, Tailwind, premium templates and professional support. In addition, it integrates with Prime
2 lines (1 loc) • 6.94 kB
JavaScript
import*as e from"react";import{PrimeReactContext as t}from"primereact/api";import{ComponentBase as r,useHandleStyle as n}from"primereact/componentbase";import{useMergeProps as a,useMountEffect as l}from"primereact/hooks";import{ChevronRightIcon as o}from"primereact/icons/chevronright";import{classNames as i,UniqueComponentId as c,IconUtils as u,ObjectUtils as m}from"primereact/utils";function s(){return s=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)({}).hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},s.apply(null,arguments)}function p(e){return p="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},p(e)}function f(e,t){if("object"!=p(e)||!e)return e;var r=e[Symbol.toPrimitive];if(void 0!==r){var n=r.call(e,t||"default");if("object"!=p(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}function b(e){var t=f(e,"string");return"symbol"==p(t)?t:t+""}function d(e,t,r){return(t=b(t))in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function y(e){if(Array.isArray(e))return e}function v(e,t){var r=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=r){var n,a,l,o,i=[],c=!0,u=!1;try{if(l=(r=r.call(e)).next,0===t){if(Object(r)!==r)return;c=!1}else for(;!(c=(n=l.call(r)).done)&&(i.push(n.value),i.length!==t);c=!0);}catch(e){u=!0,a=e}finally{try{if(!c&&null!=r.return&&(o=r.return(),Object(o)!==o))return}finally{if(u)throw a}}return i}}function g(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,n=Array(t);r<t;r++)n[r]=e[r];return n}function h(e,t){if(e){if("string"==typeof e)return g(e,t);var r={}.toString.call(e).slice(8,-1);return"Object"===r&&e.constructor&&(r=e.constructor.name),"Map"===r||"Set"===r?Array.from(e):"Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r)?g(e,t):void 0}}function O(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var N=r.extend({defaultProps:{__TYPE:"BreadCrumb",id:null,model:null,home:null,separatorIcon:null,style:null,className:null,children:void 0},css:{classes:{icon:"p-menuitem-icon",action:"p-menuitem-link",label:"p-menuitem-text",home:function(e){return i("p-breadcrumb-home p-menuitem",{"p-disabled":e.disabled},e._className)},separatorIcon:"p-breadcrumb-chevron",separator:"p-menuitem-separator",menuitem:function(e){var t=e.item;return i("p-menuitem",t.className,{"p-disabled":t.disabled})},menu:"p-breadcrumb-list",root:"p-breadcrumb p-component"},styles:"\n@layer primereact {\n .p-breadcrumb {\n overflow-x: auto;\n display: flex;\n }\n\n .p-breadcrumb ol {\n margin: 0;\n padding: 0;\n list-style-type: none;\n display: flex;\n align-items: center;\n flex-wrap: nowrap;\n }\n\n .p-breadcrumb .p-menuitem-text {\n line-height: 1;\n }\n\n .p-breadcrumb .p-menuitem-link {\n text-decoration: none;\n display: flex;\n align-items: center;\n }\n\n .p-breadcrumb .p-menuitem-separator {\n display: flex;\n align-items: center;\n }\n\n .p-breadcrumb::-webkit-scrollbar {\n display: none;\n }\n}\n"}});function w(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,n)}return r}function j(e){for(var t=1;t<arguments.length;t++){var r=null!=arguments[t]?arguments[t]:{};t%2?w(Object(r),!0).forEach((function(t){d(e,t,r[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(r)):w(Object(r)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(r,t))}))}return e}var E=e.memo(e.forwardRef((function(r,p){var f,b,d=a(),g=e.useContext(t),w=N.getProps(r,g),E=e.useState(w.id),S=(b=2,y(f=E)||v(f,b)||h(f,b)||O()),x=S[0],P=S[1],k=e.useRef(null),I=N.setMetaData({props:w,state:{id:x}}),C=I.ptm,_=I.cx;n(N.css.styles,I.isUnstyled,{name:"breadcrumb"});var D=function(e,t){t.disabled?e.preventDefault():(t.command&&t.command({originalEvent:e,item:t}),t.url||(e.preventDefault(),e.stopPropagation()))},A=function(e){return e===("undefined"!=typeof window?window.location.pathname:"")?"page":void 0},J=function(t){var r=x+"_sep_"+t,n=d({className:_("separatorIcon"),"aria-hidden":"true"},C("separatorIcon")),a=u.getJSXIcon(w.separatorIcon||e.createElement(o,n),j({},n),{props:w}),l=d({id:r,className:_("separator"),role:"separator"},C("separator"));return e.createElement("li",s({},l,{key:r}),a)},X=function(t,r){if(!1===t.visible)return null;var n=d({className:_("label")},C("label")),a=t.label&&e.createElement("span",n,t.label),l=d({href:t.url||"#",className:_("action"),target:t.target,"aria-current":A(t.url),onClick:function(e){return D(e,t)},"aria-disabled":t.disabled,tabIndex:t.disabled?-1:void 0},C("action")),o=e.createElement("a",l,a);t.template&&(o=m.getJSXElement(t.template,t,{onClick:function(e){return D(e,t)},className:"p-menuitem-link",labelClassName:"p-menuitem-text",element:o,props:w}));var i=t.id||x+"_"+r,c=d({id:i,className:_("menuitem",{item:t}),style:t.style},C("menuitem"));return e.createElement("li",s({},c,{key:i}),o)};l((function(){x||P(c())})),e.useImperativeHandle(p,(function(){return{props:w,getElement:function(){return k.current}}}));var T=function(){var t=w.home;if(t){if(!1===t.visible)return null;var r=t.icon,n=t.target,a=t.url,l=t.disabled,o=t.style,i=t.className,c=t.template,p=t.label,f=d({className:_("icon")},C("icon")),b=u.getJSXIcon(r,j({},f),{props:w}),y=d({href:a||"#",className:_("action"),"aria-disabled":l,"aria-current":A(a),target:n,onClick:function(e){return D(e,t)}},C("action")),v=d({className:_("label")},C("label")),g=e.createElement("a",y,b,p&&e.createElement("span",v,p));if(c)g=m.getJSXElement(c,t,{onClick:function(e){return D(e,t)},className:"p-menuitem-link",labelClassName:"p-menuitem-text",element:g,props:w});var h=x+"_home",O=d({id:h,className:_("home",{_className:i,disabled:l}),style:o},C("home"));return e.createElement("li",s({},O,{key:h}),g)}return null}(),B=function(){if(w.model){var t=w.model.map((function(t,r){if(!1===t.visible)return null;var n=X(t,r),a=r===w.model.length-1?null:J(r);return e.createElement(e.Fragment,{key:x+"_"+r},n,a)}));return t}return null}(),M=J("home"),R=d({className:_("menu")},C("menu")),U=d({id:w.id,ref:k,className:i(w.className,_("root")),style:w.style},N.getOtherProps(w),C("root"));return e.createElement("nav",U,e.createElement("ol",R,T,T&&!(null==B||!B.length)&&M,B))})));E.displayName="BreadCrumb";export{E as BreadCrumb};