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) 7.72 kB
import*as e from"react";import{Button as t}from"primereact/button";import{useEventListener as n,useMountEffect as r,useUpdateEffect as i}from"primereact/hooks";import{Ripple as o}from"primereact/ripple";import{ObjectUtils as l,DomHandler as a,classNames as c,IconUtils as u}from"primereact/utils";function s(){return s=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},s.apply(this,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)||null===e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var r=n.call(e,t||"default");if("object"!==p(r))return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}function d(e){var t=f(e,"string");return"symbol"===p(t)?t:String(t)}function m(e,t,n){return(t=d(t))in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function b(e){if(Array.isArray(e))return e}function y(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,u=!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){u=!0,i=e}finally{try{if(!c&&null!=n.return&&(l=n.return(),Object(l)!==l))return}finally{if(u)throw i}}return a}}function h(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 v(e,t){if(e){if("string"==typeof e)return h(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)?h(e,t):void 0}}function g(){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 O(e,t){return b(e)||y(e,t)||v(e,t)||g()}var S={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 l.getMergedProps(e,S.defaultProps)},getOtherProps:function(e){return l.getDiffProps(e,S.defaultProps)}};function w(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 P(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?w(Object(n),!0).forEach((function(t){m(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):w(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}var C=e.memo(e.forwardRef((function(p,f){var d,b=S.getProps(p),y=O(e.useState(!1),2),h=y[0],v=y[1],g=e.useRef(!1),w=e.useRef(null),C=e.useRef(null),j=b.onVisibleChange?b.visible:h,k=O(n({type:"click",listener:function(e){!g.current&&A(e)&&E(),g.current=!1},when:h}),2),I=k[0],x=k[1],N=function(){b.onVisibleChange?b.onVisibleChange(!0):v(!0),b.onShow&&b.onShow()},E=function(){b.onVisibleChange?b.onVisibleChange(!1):v(!1),b.onHide&&b.onHide()},M=function(e){j?E():N(),b.onClick&&b.onClick(e),g.current=!0},D=function(e,t){t.command&&t.command({originalEvent:e,item:t}),E(),g.current=!0,e.preventDefault()},A=function(e){return w.current&&!(w.current.isSameNode(e.target)||w.current.contains(e.target))},H=function(e){return(j?e:b.model.length-e-1)*b.transitionDelay},T=function(e){var t=b.type;if("linear"!==t){var n=b.model.length,r=b.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=b.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=b.direction,s=Math.PI/(2*(n-1)),p="calc(".concat(r*Math.cos(s*e),"px + var(--item-diff-x, 0px))"),f="calc(".concat(r*Math.sin(s*e),"px + var(--item-diff-y, 0px))");if("up-left"===u)return{right:p,bottom:f};if("up-right"===u)return{left:p,bottom:f};if("down-left"===u)return{right:f,top:p};if("down-right"===u)return{left:f,top:p}}}return{}},V=function(e){var t=H(e),n=T(e);return P({transitionDelay:"".concat(t,"ms")},n)};r((function(){if("linear"!==b.type){var e=a.findSingle(w.current,".p-speeddial-button"),t=a.findSingle(C.current,".p-speeddial-item");if(e&&t){var n=Math.abs(e.offsetWidth-t.offsetWidth),r=Math.abs(e.offsetHeight-t.offsetHeight);C.current.style.setProperty("--item-diff-x","".concat(n/2,"px")),C.current.style.setProperty("--item-diff-y","".concat(r/2,"px"))}}})),i((function(){return h&&b.hideOnClickOutside&&I(),function(){b.hideOnClickOutside&&x()}}),[h]),e.useImperativeHandle(f,(function(){return{props:b,show:N,hide:E,getElement:function(){return w.current}}}));var J,R=function(t,n){if(!1===t.visible)return null;var r=V(n),i=t.icon,a=t.label,s=t.template,p=t.url,f=t.target,d=c("p-speeddial-action",{"p-disabled":t.disabled}),m=c("p-speeddial-action-icon",i),y=u.getJSXIcon(i,{className:"p-speeddial-action-icon"},{props:b}),h=e.createElement("a",{href:p||"#",role:"menuitem",className:d,target:f,"data-pr-tooltip":a,onClick:function(e){return D(e,t)}},y,e.createElement(o,null));s&&(h=l.getJSXElement(s,t,{onClick:function(e){return D(e,t)},className:d,iconClassName:m,element:h,props:b,visible:j}));return e.createElement("li",{key:n,className:"p-speeddial-item",style:r,role:"none"},h)},X=S.getOtherProps(b),W=c("p-speeddial p-component p-speeddial-".concat(b.type),(m(d={},"p-speeddial-direction-".concat(b.direction),"circle"!==b.type),m(d,"p-speeddial-opened",j),m(d,"p-disabled",b.disabled),d),b.className),_=function(){var n,r=!j&&!!b.showIcon||!b.hideIcon,i=j&&!!b.hideIcon,o=c("p-speeddial-button p-button-rounded",{"p-speeddial-rotate":b.rotateAnimation&&!b.hideIcon},b.buttonClassName),a=c((m(n={},"".concat(b.showIcon),!j&&!!b.showIcon||!b.hideIcon),m(n,"".concat(b.hideIcon),j&&!!b.hideIcon),n)),s=u.getJSXIcon(r?b.showIcon:i?b.hideIcon:null,void 0,{props:b}),p=e.createElement(t,{type:"button",style:b.buttonStyle,className:o,icon:s,onClick:M,disabled:b.disabled,"aria-label":b["aria-label"]});return b.buttonTemplate?l.getJSXElement(b.buttonTemplate,{onClick:M,className:o,iconClassName:a,element:p,props:b,visible:j}):p}(),q=(J=b.model?b.model.map(R):null,e.createElement("ul",{ref:C,className:"p-speeddial-list",role:"menu"},J)),F=function(){if(b.mask){var t=c("p-speeddial-mask",{"p-speeddial-mask-visible":j},b.maskClassName);return e.createElement("div",{className:t,style:b.maskStyle})}return null}();return e.createElement(e.Fragment,null,e.createElement("div",s({ref:w,id:b.id,className:W,style:b.style},X),_,q),F)})));C.displayName="SpeedDial";export{C as SpeedDial};