UNPKG

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) 8.17 kB
this.primereact=this.primereact||{},this.primereact.speeddial=function(e,t,n,r,i,o){"use strict";function l(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(n){if("default"!==n){var r=Object.getOwnPropertyDescriptor(e,n);Object.defineProperty(t,n,r.get?r:{enumerable:!0,get:function(){return e[n]}})}})),t.default=e,Object.freeze(t)}var a=l(t);function c(){return c=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)Object.prototype.hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e},c.apply(this,arguments)}function s(e){return s="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},s(e)}function u(e,t){if("object"!==s(e)||null===e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var r=n.call(e,t||"default");if("object"!==s(r))return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}function f(e){var t=u(e,"string");return"symbol"===s(t)?t:String(t)}function p(e,t,n){return(t=f(t))in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function d(e){if(Array.isArray(e))return e}function m(e,t){var n=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=n){var r,i,o,l,a=[],c=!0,s=!1;try{if(o=(n=n.call(e)).next,0===t){if(Object(n)!==n)return;c=!1}else for(;!(c=(r=o.call(n)).done)&&(a.push(r.value),a.length!==t);c=!0);}catch(e){s=!0,i=e}finally{try{if(!c&&null!=n.return&&(l=n.return(),Object(l)!==l))return}finally{if(s)throw i}}return a}}function b(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,r=new Array(t);n<t;n++)r[n]=e[n];return r}function y(e,t){if(e){if("string"==typeof e)return b(e,t);var n=Object.prototype.toString.call(e).slice(8,-1);return"Object"===n&&e.constructor&&(n=e.constructor.name),"Map"===n||"Set"===n?Array.from(e):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?b(e,t):void 0}}function h(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function v(e,t){return d(e)||m(e,t)||y(e,t)||h()}var g={defaultProps:{__TYPE:"SpeedDial",id:null,model:null,visible:!1,style:null,className:null,direction:"up",transitionDelay:30,type:"linear",radius:0,mask:!1,disabled:!1,hideOnClickOutside:!0,buttonStyle:null,buttonClassName:null,buttonTemplate:null,"aria-label":null,maskStyle:null,maskClassName:null,showIcon:"pi pi-plus",hideIcon:null,rotateAnimation:!0,onVisibleChange:null,onClick:null,onShow:null,onHide:null,children:void 0},getProps:function(e){return o.ObjectUtils.getMergedProps(e,g.defaultProps)},getOtherProps:function(e){return o.ObjectUtils.getDiffProps(e,g.defaultProps)}};function O(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}function S(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?O(Object(n),!0).forEach((function(t){p(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):O(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}var j=a.memo(a.forwardRef((function(e,t){var l,s=g.getProps(e),u=v(a.useState(!1),2),f=u[0],d=u[1],m=a.useRef(!1),b=a.useRef(null),y=a.useRef(null),h=s.onVisibleChange?s.visible:f,O=v(r.useEventListener({type:"click",listener:function(e){!m.current&&C(e)&&N(),m.current=!1},when:f}),2),j=O[0],P=O[1],w=function(){s.onVisibleChange?s.onVisibleChange(!0):d(!0),s.onShow&&s.onShow()},N=function(){s.onVisibleChange?s.onVisibleChange(!1):d(!1),s.onHide&&s.onHide()},I=function(e){h?N():w(),s.onClick&&s.onClick(e),m.current=!0},k=function(e,t){t.command&&t.command({originalEvent:e,item:t}),N(),m.current=!0,e.preventDefault()},C=function(e){return b.current&&!(b.current.isSameNode(e.target)||b.current.contains(e.target))},E=function(e){return(h?e:s.model.length-e-1)*s.transitionDelay},x=function(e){var t=s.type;if("linear"!==t){var n=s.model.length,r=s.radius||20*n;if("circle"===t){var i=2*Math.PI/n;return{left:"calc(".concat(r*Math.cos(i*e),"px + var(--item-diff-x, 0px))"),top:"calc(".concat(r*Math.sin(i*e),"px + var(--item-diff-y, 0px))")}}if("semi-circle"===t){var o=s.direction,l=Math.PI/(n-1),a="calc(".concat(r*Math.cos(l*e),"px + var(--item-diff-x, 0px))"),c="calc(".concat(r*Math.sin(l*e),"px + var(--item-diff-y, 0px))");if("up"===o)return{left:a,bottom:c};if("down"===o)return{left:a,top:c};if("left"===o)return{right:c,top:a};if("right"===o)return{left:c,top:a}}else if("quarter-circle"===t){var u=s.direction,f=Math.PI/(2*(n-1)),p="calc(".concat(r*Math.cos(f*e),"px + var(--item-diff-x, 0px))"),d="calc(".concat(r*Math.sin(f*e),"px + var(--item-diff-y, 0px))");if("up-left"===u)return{right:p,bottom:d};if("up-right"===u)return{left:p,bottom:d};if("down-left"===u)return{right:d,top:p};if("down-right"===u)return{left:d,top:p}}}return{}},M=function(e){var t=E(e),n=x(e);return S({transitionDelay:"".concat(t,"ms")},n)};r.useMountEffect((function(){if("linear"!==s.type){var e=o.DomHandler.findSingle(b.current,".p-speeddial-button"),t=o.DomHandler.findSingle(y.current,".p-speeddial-item");if(e&&t){var n=Math.abs(e.offsetWidth-t.offsetWidth),r=Math.abs(e.offsetHeight-t.offsetHeight);y.current.style.setProperty("--item-diff-x","".concat(n/2,"px")),y.current.style.setProperty("--item-diff-y","".concat(r/2,"px"))}}})),r.useUpdateEffect((function(){return f&&s.hideOnClickOutside&&j(),function(){s.hideOnClickOutside&&P()}}),[f]),a.useImperativeHandle(t,(function(){return{props:s,show:w,hide:N,getElement:function(){return b.current}}}));var D,A=function(e,t){if(!1===e.visible)return null;var n=M(t),r=e.icon,l=e.label,c=e.template,u=e.url,f=e.target,p=o.classNames("p-speeddial-action",{"p-disabled":e.disabled}),d=o.classNames("p-speeddial-action-icon",r),m=o.IconUtils.getJSXIcon(r,{className:"p-speeddial-action-icon"},{props:s}),b=a.createElement("a",{href:u||"#",role:"menuitem",className:p,target:f,"data-pr-tooltip":l,onClick:function(t){return k(t,e)}},m,a.createElement(i.Ripple,null));c&&(b=o.ObjectUtils.getJSXElement(c,e,{onClick:function(t){return k(t,e)},className:p,iconClassName:d,element:b,props:s,visible:h}));return a.createElement("li",{key:t,className:"p-speeddial-item",style:n,role:"none"},b)},H=g.getOtherProps(s),U=o.classNames("p-speeddial p-component p-speeddial-".concat(s.type),(p(l={},"p-speeddial-direction-".concat(s.direction),"circle"!==s.type),p(l,"p-speeddial-opened",h),p(l,"p-disabled",s.disabled),l),s.className),R=function(){var e,t=!h&&!!s.showIcon||!s.hideIcon,r=h&&!!s.hideIcon,i=o.classNames("p-speeddial-button p-button-rounded",{"p-speeddial-rotate":s.rotateAnimation&&!s.hideIcon},s.buttonClassName),l=o.classNames((p(e={},"".concat(s.showIcon),!h&&!!s.showIcon||!s.hideIcon),p(e,"".concat(s.hideIcon),h&&!!s.hideIcon),e)),c=o.IconUtils.getJSXIcon(t?s.showIcon:r?s.hideIcon:null,void 0,{props:s}),u=a.createElement(n.Button,{type:"button",style:s.buttonStyle,className:i,icon:c,onClick:I,disabled:s.disabled,"aria-label":s["aria-label"]});return s.buttonTemplate?o.ObjectUtils.getJSXElement(s.buttonTemplate,{onClick:I,className:i,iconClassName:l,element:u,props:s,visible:h}):u}(),T=(D=s.model?s.model.map(A):null,a.createElement("ul",{ref:y,className:"p-speeddial-list",role:"menu"},D)),V=function(){if(s.mask){var e=o.classNames("p-speeddial-mask",{"p-speeddial-mask-visible":h},s.maskClassName);return a.createElement("div",{className:e,style:s.maskStyle})}return null}();return a.createElement(a.Fragment,null,a.createElement("div",c({ref:b,id:s.id,className:U,style:s.style},H),R,T),V)})));return j.displayName="SpeedDial",e.SpeedDial=j,Object.defineProperty(e,"__esModule",{value:!0}),e}({},React,primereact.button,primereact.hooks,primereact.ripple,primereact.utils);