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) • 7.02 kB
JavaScript
Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),t=require("primereact/api"),r=require("primereact/componentbase"),n=require("primereact/hooks"),a=require("primereact/icons/chevronright"),l=require("primereact/utils");function o(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(r){if("default"!==r){var n=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,n.get?n:{enumerable:!0,get:function(){return e[r]}})}})),t.default=e,Object.freeze(t)}var i=o(e);function u(e){return u="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},u(e)}function c(e,t){if("object"!==u(e)||null===e)return e;var r=e[Symbol.toPrimitive];if(void 0!==r){var n=r.call(e,t||"default");if("object"!==u(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}function s(e){var t=c(e,"string");return"symbol"===u(t)?t:String(t)}function m(e){if(Array.isArray(e))return e}function p(e,t){var r=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=r){var n,a,l,o,i=[],u=!0,c=!1;try{if(l=(r=r.call(e)).next,0===t){if(Object(r)!==r)return;u=!1}else for(;!(u=(n=l.call(r)).done)&&(i.push(n.value),i.length!==t);u=!0);}catch(e){c=!0,a=e}finally{try{if(!u&&null!=r.return&&(o=r.return(),Object(o)!==o))return}finally{if(c)throw a}}return i}}function f(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,n=new Array(t);r<t;r++)n[r]=e[r];return n}function b(e,t){if(e){if("string"==typeof e)return f(e,t);var r=Object.prototype.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)?f(e,t):void 0}}function d(){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 y=r.ComponentBase.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 l.classNames("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 l.classNames("p-menuitem",t.className,{"p-disabled":t.disabled})},menu:"p-breadcrumb-list",root:function(e){return l.classNames("p-breadcrumb p-component",e.props.className)}},styles:"\n@layer primereact {\n .p-breadcrumb {\n overflow-x: auto;\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 v(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 g(e){for(var t=1;t<arguments.length;t++){var r=null!=arguments[t]?arguments[t]:{};t%2?v(Object(r),!0).forEach((function(t){var n,a,l;n=e,l=r[t],(a=s(a=t))in n?Object.defineProperty(n,a,{value:l,enumerable:!0,configurable:!0,writable:!0}):n[a]=l})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(r)):v(Object(r)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(r,t))}))}return e}var h=i.memo(i.forwardRef((function(e,o){var u,c,s=n.useMergeProps(),f=i.useContext(t.PrimeReactContext),v=y.getProps(e,f),h=i.useState(v.id),O=(c=2,m(u=h)||p(u,c)||b(u,c)||d()),j=O[0],N=O[1],w=i.useRef(null),E=y.setMetaData({props:v,state:{id:j}}),P=E.ptm,S=E.cx;r.useHandleStyle(y.css.styles,E.isUnstyled,{name:"breadcrumb"});var x=function(e,t){t.disabled?e.preventDefault():(t.command&&t.command({originalEvent:e,item:t}),t.url||(e.preventDefault(),e.stopPropagation()))},k=function(e){return e===("undefined"!=typeof window?window.location.pathname:"")?"page":void 0},C=function(e){var t=j+"_sep_"+e,r=s({className:S("separatorIcon"),"aria-hidden":"true"},P("separatorIcon")),n=l.IconUtils.getJSXIcon(v.separatorIcon||i.createElement(a.ChevronRightIcon,r),g({},r),{props:v}),o=s({id:t,key:t,className:S("separator"),role:"separator"},P("separator"));return i.createElement("li",o,n)},I=function(e,t){if(!1===e.visible)return null;var r=s({className:S("label")},P("label")),n=e.label&&i.createElement("span",r,e.label),a=s({href:e.url||"#",className:S("action"),target:e.target,"aria-current":k(e.url),onClick:function(t){return x(t,e)},"aria-disabled":e.disabled},P("action")),o=i.createElement("a",a,n);e.template&&(o=l.ObjectUtils.getJSXElement(e.template,e,{onClick:function(t){return x(t,e)},className:"p-menuitem-link",labelClassName:"p-menuitem-text",element:o,props:v}));var u=e.id||j+"_"+t,c=s({id:u,key:u,className:S("menuitem",{item:e}),style:e.style},P("menuitem"));return i.createElement("li",c,o)};n.useMountEffect((function(){j||N(l.UniqueComponentId())})),i.useImperativeHandle(o,(function(){return{props:v,getElement:function(){return w.current}}}));var _=function(e){var t=v.home;if(t){if(!1===t.visible)return null;var r=t.icon,n=t.target,a=t.url,o=t.disabled,u=t.style,c=t.className,m=t.template,p=t.label,f=s({className:S("icon")},P("icon")),b=l.IconUtils.getJSXIcon(r,g({},f),{props:v}),d=s({href:a||"#",className:S("action"),"aria-disabled":o,"aria-current":k(a),target:n,onClick:function(e){return x(e,t)}},P("action")),y=s({className:S("label")},P("label")),h=i.createElement("a",d,b,p&&i.createElement("span",y,p));if(m)h=l.ObjectUtils.getJSXElement(m,t,{onClick:function(e){return x(e,t)},className:"p-menuitem-link",labelClassName:"p-menuitem-text",element:h,props:v});var O=j+"_home",N=s({id:O,key:O,className:S("home",{_className:c,disabled:o}),style:u},P("home"));return i.createElement("li",N,h)}return null}(),D=function(){if(v.model){var e=v.model.map((function(e,t){if(!1===e.visible)return null;var r=I(e,t),n=t===v.model.length-1?null:C(t);return i.createElement(i.Fragment,{key:j+"_"+t},r,n)}));return e}return null}(),q=C("home"),U=s({className:S("menu")},P("menu")),A=s({id:v.id,ref:w,className:S("root"),style:v.style},y.getOtherProps(v),P("root"));return i.createElement("nav",A,i.createElement("ol",U,_,q,D))})));h.displayName="BreadCrumb",exports.BreadCrumb=h;
;