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.07 kB
import*as e from"react";import{PrimeReactContext as t,localeOption as r}from"primereact/api";import{Button as n}from"primereact/button";import{ComponentBase as o,useHandleStyle as c}from"primereact/componentbase";import{Dialog as a}from"primereact/dialog";import{useMergeProps as i,useUpdateEffect as l,useUnmountEffect as u}from"primereact/hooks";import{OverlayService as s}from"primereact/overlayservice";import{Portal as p}from"primereact/portal";import{classNames as f,DomHandler as m,ObjectUtils as b,IconUtils as g}from"primereact/utils";function d(){return d=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},d.apply(null,arguments)}function v(e){if(Array.isArray(e))return e}function y(e,t){var r=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=r){var n,o,c,a,i=[],l=!0,u=!1;try{if(c=(r=r.call(e)).next,0===t){if(Object(r)!==r)return;l=!1}else for(;!(l=(n=c.call(r)).done)&&(i.push(n.value),i.length!==t);l=!0);}catch(e){u=!0,o=e}finally{try{if(!l&&null!=r.return&&(a=r.return(),Object(a)!==a))return}finally{if(u)throw o}}return i}}function j(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 O(e,t){if(e){if("string"==typeof e)return j(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)?j(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 N(e,t){return v(e)||y(e,t)||O(e,t)||h()}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 S(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 w(e){var t=S(e,"string");return"symbol"==P(t)?t:t+""}function C(e,t,r){return(t=w(t))in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}var E=o.extend({defaultProps:{__TYPE:"ConfirmDialog",accept:null,acceptClassName:null,acceptIcon:null,acceptLabel:null,appendTo:null,breakpoints:null,children:void 0,className:null,content:null,defaultFocus:"accept",footer:null,icon:null,message:null,onHide:null,reject:null,rejectClassName:null,rejectIcon:null,rejectLabel:null,tagKey:void 0,visible:void 0},css:{classes:{root:"p-confirm-dialog",message:"p-confirm-dialog-message",icon:"p-confirm-dialog-icon",acceptButton:"p-confirm-dialog-accept",rejectButton:function(e){return f("p-confirm-dialog-reject",{"p-button-text":!(0,e.getPropValue)("rejectClassName")})}}}});function I(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 B(e){for(var t=1;t<arguments.length;t++){var r=null!=arguments[t]?arguments[t]:{};t%2?I(Object(r),!0).forEach((function(t){C(e,t,r[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(r)):I(Object(r)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(r,t))}))}return e}var T=function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};(e=B(B({},e),{visible:void 0===e.visible||e.visible})).visible&&s.emit("confirm-dialog",e);return{show:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};s.emit("confirm-dialog",B(B(B({},e),t),{visible:!0}))},hide:function(){s.emit("confirm-dialog",{visible:!1})}}},_=e.memo(e.forwardRef((function(o,v){var y=i(),j=e.useContext(t),O=E.getProps(o,j),h=N(e.useState(O.visible),2),P=h[0],S=h[1],w=N(e.useState(!1),2),C=w[0],I=w[1],T=e.useRef(null),_=e.useRef(!1),k=e.useRef(null),x=function(){var e=O.group;return T.current&&(e=T.current.group),Object.assign({},O,T.current,{group:e})},A=function(e){return x()[e]},D=function(e){for(var t=arguments.length,r=new Array(t>1?t-1:0),n=1;n<t;n++)r[n-1]=arguments[n];return b.getPropValue(A(e),r)},L=A("acceptLabel")||r("accept"),F=A("rejectLabel")||r("reject"),M={props:O,state:{visible:P}},H=E.setMetaData(M),R=H.ptm,J=H.cx;c(E.css.styles,H.isUnstyled,{name:"confirmdialog"});var K=function(){_.current||(_.current=!0,D("accept"),U("accept"))},V=function(){_.current||(_.current=!0,D("reject"),U("reject"))},X=function(){x().group===O.group&&(S(!0),_.current=!1,k.current=document.activeElement)},U=function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"cancel";P&&("string"!=typeof e&&(e="cancel"),S(!1),D("onHide",e),m.focus(k.current),k.current=null)},Y=function(e){if(e.tagKey===O.tagKey){var t=P!==e.visible;A("target")!==e.target&&!O.target?(U(),T.current=e,I(!0)):t&&(T.current=e,e.visible?X():U())}};e.useEffect((function(){O.visible?X():U()}),[O.visible]),e.useEffect((function(){return O.target||O.message||s.on("confirm-dialog",Y),function(){s.off("confirm-dialog",Y)}}),[O.target]),l((function(){C&&X()}),[C]),u((function(){s.off("confirm-dialog",Y)})),e.useImperativeHandle(v,(function(){return{props:O,confirm:Y}}));var $,q,z,G,Q,W,Z,ee=function(){var t=A("defaultFocus"),r=f("p-confirm-dialog-accept",A("acceptClassName")),o=f("p-confirm-dialog-reject",{"p-button-text":!A("rejectClassName")},A("rejectClassName")),c=y({label:F,autoFocus:"reject"===t,icon:A("rejectIcon"),className:f(A("rejectClassName"),J("rejectButton",{getPropValue:A})),onClick:V,pt:R("rejectButton"),unstyled:O.unstyled,__parentMetadata:{parent:M}},R("rejectButton")),a=y({label:L,autoFocus:void 0===t||"accept"===t,icon:A("acceptIcon"),className:f(A("acceptClassName"),J("acceptButton")),onClick:K,pt:R("acceptButton"),unstyled:O.unstyled,__parentMetadata:{parent:M}},R("acceptButton")),i=e.createElement(e.Fragment,null,e.createElement(n,c),e.createElement(n,a));if(A("footer")){var l={accept:K,reject:V,acceptClassName:r,rejectClassName:o,acceptLabel:L,rejectLabel:F,element:i,props:x()};return b.getJSXElement(A("footer"),l)}return i},te=($=x(),q=b.getJSXElement(A("message"),$),z=y({className:J("icon")},R("icon")),G=g.getJSXIcon(A("icon"),B({},z),{props:$}),Q=ee(),W=y({className:J("message")},R("message")),Z=y({visible:P,className:f(A("className"),J("root")),footer:Q,onHide:U,breakpoints:A("breakpoints"),pt:$.pt,unstyled:O.unstyled,appendTo:A("appendTo"),__parentMetadata:{parent:M}},E.getOtherProps($)),e.createElement(a,d({},Z,{content:null==o?void 0:o.content}),G,e.createElement("span",W,q)));return e.createElement(p,{element:te,appendTo:A("appendTo")})})));_.displayName="ConfirmDialog";export{_ as ConfirmDialog,T as confirmDialog};