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) 6.32 kB
this.primereact=this.primereact||{},this.primereact.scrolltop=function(e,t,n,r,o,i,l,c,a){"use strict";function s(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}function u(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 p=u(t),f=s(n);function y(){return y=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)({}).hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e},y.apply(null,arguments)}function m(e){return m="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},m(e)}function d(e,t){if("object"!=m(e)||!e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var r=n.call(e,t||"default");if("object"!=m(r))return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}function b(e){var t=d(e,"string");return"symbol"==m(t)?t:t+""}function v(e,t,n){return(t=b(t))in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}function g(e){if(Array.isArray(e))return e}function h(e,t){var n=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=n){var r,o,i,l,c=[],a=!0,s=!1;try{if(i=(n=n.call(e)).next,0===t){if(Object(n)!==n)return;a=!1}else for(;!(a=(r=i.call(n)).done)&&(c.push(r.value),c.length!==t);a=!0);}catch(e){s=!0,o=e}finally{try{if(!a&&null!=n.return&&(l=n.return(),Object(l)!==l))return}finally{if(s)throw o}}return c}}function O(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,r=Array(t);n<t;n++)r[n]=e[n];return r}function w(e,t){if(e){if("string"==typeof e)return O(e,t);var n={}.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)?O(e,t):void 0}}function j(){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 S(e,t){return g(e)||h(e,t)||w(e,t)||j()}var E=r.ComponentBase.extend({defaultProps:{__TYPE:"ScrollTop",target:"window",threshold:400,icon:null,behavior:"smooth",className:null,style:null,transitionOptions:null,onShow:null,onHide:null,children:void 0},css:{classes:{root:function(e){return a.classNames("p-scrolltop p-link p-component",{"p-scrolltop-sticky":"window"!==e.props.target})},icon:"p-scrolltop-icon",transition:"p-scrolltop"},styles:"\n@layer primereact {\n .p-scrolltop {\n position: fixed;\n bottom: 20px;\n right: 20px;\n display: flex;\n align-items: center;\n justify-content: center;\n }\n \n .p-scrolltop-sticky {\n position: sticky;\n }\n \n .p-scrolltop-sticky.p-link {\n margin-left: auto;\n }\n \n .p-scrolltop-helper {\n display: none;\n }\n \n .p-scrolltop-enter {\n opacity: 0;\n }\n \n .p-scrolltop-enter-active {\n opacity: 1;\n transition: opacity .15s;\n }\n \n .p-scrolltop-exit {\n opacity: 1;\n }\n \n .p-scrolltop-exit-active {\n opacity: 0;\n transition: opacity .15s;\n }\n}\n"}});function x(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?x(Object(n),!0).forEach((function(t){v(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):x(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}var I=p.memo(p.forwardRef((function(e,t){var s=S(p.useState(!1),2),u=s[0],m=s[1],d=i.useMergeProps(),b=p.useContext(n.PrimeReactContext),v=E.getProps(e,b),g=E.setMetaData({props:v,state:{visible:u}}),h=g.ptm,O=g.cx;r.useHandleStyle(E.css.styles,g.isUnstyled,{name:"scrolltop"});var w=p.useRef(null),j=p.useRef(null),x="parent"===v.target,I=S(i.useEventListener({target:function(){return j.current&&j.current.parentElement},type:"scroll",listener:function(e){k(e.currentTarget.scrollTop)}}),1)[0],T=S(i.useEventListener({target:"window",type:"scroll",listener:function(e){e&&k(a.DomHandler.getWindowScrollTop())}}),1)[0],k=function(e){m(e>v.threshold)};p.useImperativeHandle(t,(function(){return{props:v,getElement:function(){return elementRef.current}}})),p.useEffect((function(){"window"===v.target?T():"parent"===v.target&&I()}),[]),i.useUnmountEffect((function(){a.ZIndexUtils.clear(w.current)}));var N=d({className:O("icon")},h("icon")),R=a.IconUtils.getJSXIcon(v.icon||p.createElement(l.ChevronUpIcon,N),P({},N),{props:v}),U=n.localeOption("aria")?n.localeOption("aria").scrollTop:void 0,C=d({ref:w,type:"button",className:a.classNames(v.className,O("root")),style:v.style,onClick:function(){("window"===v.target?window:j.current.parentElement).scroll({top:0,behavior:v.behavior})},"aria-label":U},E.getOtherProps(v),h("root")),D=d({classNames:O("transition"),in:u,timeout:{enter:150,exit:150},options:v.transitionOptions,unmountOnExit:!0,onEnter:function(){a.ZIndexUtils.set("overlay",w.current,b&&b.autoZIndex||f.default.autoZIndex,b&&b.zIndex.overlay||f.default.zIndex.overlay)},onEntered:function(){v.onShow&&v.onShow()},onExited:function(){a.ZIndexUtils.clear(w.current),v.onHide&&v.onHide()}},h("transition"));return p.createElement(p.Fragment,null,p.createElement(o.CSSTransition,y({nodeRef:w},D),p.createElement("button",C,R,p.createElement(c.Ripple,null))),x&&p.createElement("span",{ref:j,className:"p-scrolltop-helper"}))})));return I.displayName="ScrollTop",e.ScrollTop=I,Object.defineProperty(e,"__esModule",{value:!0}),e}({},React,primereact.api,primereact.componentbase,primereact.csstransition,primereact.hooks,primereact.icons.chevronup,primereact.ripple,primereact.utils);