sweetalert2
Advanced tools
Comparing version 4.0.4 to 4.0.5
/*! | ||
* sweetalert2 v4.0.4 | ||
* sweetalert2 v4.0.5 | ||
* Released under the MIT License. | ||
@@ -80,3 +80,5 @@ */ | ||
inputAttributes: {}, | ||
inputValidator: null | ||
inputValidator: null, | ||
onOpen: null, | ||
onClose: null, | ||
}; | ||
@@ -566,3 +568,3 @@ | ||
*/ | ||
var openModal = function(animation) { | ||
var openModal = function(animation, onComplete) { | ||
var modal = getModal(); | ||
@@ -577,6 +579,7 @@ if (animation) { | ||
show(modal); | ||
states.previousActiveElement = document.activeElement; | ||
addClass(modal, 'visible'); | ||
if (onComplete !== null && typeof onComplete === 'function') { | ||
onComplete.call(this, modal); | ||
} | ||
}; | ||
@@ -644,3 +647,3 @@ | ||
modal.timeout = setTimeout(function() { | ||
sweetAlert.closeModal(); | ||
sweetAlert.closeModal(params.onClose); | ||
reject('timer'); | ||
@@ -650,3 +653,2 @@ }, params.timer); | ||
// input/select autofocus | ||
var getInput = function() { | ||
@@ -698,4 +700,4 @@ switch (params.input) { | ||
function(preConfirmValue) { | ||
sweetAlert.closeModal(params.onClose); | ||
resolve(preConfirmValue || value); | ||
sweetAlert.closeModal(); | ||
}, | ||
@@ -710,4 +712,4 @@ function(error) { | ||
} else { | ||
sweetAlert.closeModal(params.onClose); | ||
resolve(value); | ||
sweetAlert.closeModal(); | ||
} | ||
@@ -785,4 +787,3 @@ }; | ||
} else if (targetedCancel && modalIsVisible) { | ||
sweetAlert.closeModal(); | ||
sweetAlert.closeModal(params.onClose); | ||
reject('cancel'); | ||
@@ -812,6 +813,6 @@ } | ||
if (hasClass(target, swalClasses.close)) { | ||
sweetAlert.closeModal(); | ||
sweetAlert.closeModal(params.onClose); | ||
reject('close'); | ||
} else if (target === getOverlay() && params.allowOutsideClick) { | ||
sweetAlert.closeModal(); | ||
sweetAlert.closeModal(params.onClose); | ||
reject('overlay'); | ||
@@ -901,3 +902,3 @@ } | ||
} else if (keyCode === 27 && params.allowEscapeKey === true) { | ||
sweetAlert.closeModal(); | ||
sweetAlert.closeModal(params.onClose); | ||
reject('esc'); | ||
@@ -1127,3 +1128,3 @@ } | ||
fixVerticalPosition(); | ||
openModal(params.animation); | ||
openModal(params.animation, params.onOpen); | ||
@@ -1175,3 +1176,3 @@ // Focus the first element (input or button) | ||
*/ | ||
sweetAlert.close = sweetAlert.closeModal = function() { | ||
sweetAlert.close = sweetAlert.closeModal = function(onComplete) { | ||
var modal = getModal(); | ||
@@ -1209,2 +1210,5 @@ removeClass(modal, 'show-swal2'); | ||
} | ||
if (onComplete !== null && typeof onComplete === 'function') { | ||
onComplete.call(this, modal); | ||
} | ||
}; | ||
@@ -1296,3 +1300,3 @@ | ||
sweetAlert.version = '4.0.4'; | ||
sweetAlert.version = '4.0.5'; | ||
@@ -1299,0 +1303,0 @@ window.sweetAlert = window.swal = sweetAlert; |
/*! | ||
* sweetalert2 v4.0.4 | ||
* sweetalert2 v4.0.5 | ||
* Released under the MIT License. | ||
@@ -84,3 +84,5 @@ */ | ||
inputAttributes: {}, | ||
inputValidator: null | ||
inputValidator: null, | ||
onOpen: null, | ||
onClose: null, | ||
}; | ||
@@ -570,3 +572,3 @@ | ||
*/ | ||
var openModal = function(animation) { | ||
var openModal = function(animation, onComplete) { | ||
var modal = getModal(); | ||
@@ -581,6 +583,7 @@ if (animation) { | ||
show(modal); | ||
states.previousActiveElement = document.activeElement; | ||
addClass(modal, 'visible'); | ||
if (onComplete !== null && typeof onComplete === 'function') { | ||
onComplete.call(this, modal); | ||
} | ||
}; | ||
@@ -648,3 +651,3 @@ | ||
modal.timeout = setTimeout(function() { | ||
sweetAlert.closeModal(); | ||
sweetAlert.closeModal(params.onClose); | ||
reject('timer'); | ||
@@ -654,3 +657,2 @@ }, params.timer); | ||
// input/select autofocus | ||
var getInput = function() { | ||
@@ -702,4 +704,4 @@ switch (params.input) { | ||
function(preConfirmValue) { | ||
sweetAlert.closeModal(params.onClose); | ||
resolve(preConfirmValue || value); | ||
sweetAlert.closeModal(); | ||
}, | ||
@@ -714,4 +716,4 @@ function(error) { | ||
} else { | ||
sweetAlert.closeModal(params.onClose); | ||
resolve(value); | ||
sweetAlert.closeModal(); | ||
} | ||
@@ -789,4 +791,3 @@ }; | ||
} else if (targetedCancel && modalIsVisible) { | ||
sweetAlert.closeModal(); | ||
sweetAlert.closeModal(params.onClose); | ||
reject('cancel'); | ||
@@ -816,6 +817,6 @@ } | ||
if (hasClass(target, swalClasses.close)) { | ||
sweetAlert.closeModal(); | ||
sweetAlert.closeModal(params.onClose); | ||
reject('close'); | ||
} else if (target === getOverlay() && params.allowOutsideClick) { | ||
sweetAlert.closeModal(); | ||
sweetAlert.closeModal(params.onClose); | ||
reject('overlay'); | ||
@@ -905,3 +906,3 @@ } | ||
} else if (keyCode === 27 && params.allowEscapeKey === true) { | ||
sweetAlert.closeModal(); | ||
sweetAlert.closeModal(params.onClose); | ||
reject('esc'); | ||
@@ -1131,3 +1132,3 @@ } | ||
fixVerticalPosition(); | ||
openModal(params.animation); | ||
openModal(params.animation, params.onOpen); | ||
@@ -1179,3 +1180,3 @@ // Focus the first element (input or button) | ||
*/ | ||
sweetAlert.close = sweetAlert.closeModal = function() { | ||
sweetAlert.close = sweetAlert.closeModal = function(onComplete) { | ||
var modal = getModal(); | ||
@@ -1213,2 +1214,5 @@ removeClass(modal, 'show-swal2'); | ||
} | ||
if (onComplete !== null && typeof onComplete === 'function') { | ||
onComplete.call(this, modal); | ||
} | ||
}; | ||
@@ -1300,3 +1304,3 @@ | ||
sweetAlert.version = '4.0.4'; | ||
sweetAlert.version = '4.0.5'; | ||
@@ -1303,0 +1307,0 @@ window.sweetAlert = window.swal = sweetAlert; |
@@ -1,1 +0,1 @@ | ||
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t():"function"==typeof define&&define.amd?define(t):e.Sweetalert2=t()}(this,function(){"use strict";function e(){if(void 0===arguments[0])return console.error("sweetAlert2 expects at least 1 attribute!"),!1;var e=c({},N);switch(typeof arguments[0]){case"string":e.title=arguments[0],e.text=arguments[1]||"",e.type=arguments[2]||"";break;case"object":c(e,arguments[0]),e.extraParams=arguments[0].extraParams,"email"===e.input&&null===e.inputValidator&&(e.inputValidator=function(e){return new Promise(function(t,n){var o=/^[a-zA-Z0-9._-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,6}$/;o.test(e)?t():n("Invalid email address")})});break;default:return console.error('Unexpected type of argument! Expected "string" or "object", got '+typeof arguments[0]),!1}V(e);var o=f();return new Promise(function(r,a){function l(e,t){for(var n=0;n<O.length;n++)if(e+=t,e===O.length?e=0:-1===e&&(e=O.length-1),O[e].offsetWidth||O[e].offsetHeight||O[e].getClientRects().length)return void O[e].focus()}function c(n){var o=n||window.event,i=o.keyCode||o.which;if(-1!==[9,13,32,27].indexOf(i)){for(var r=o.target||o.srcElement,c=-1,s=0;s<O.length;s++)if(r===O[s]){c=s;break}9===i?(o.shiftKey?l(c,-1):l(c,1),T(o)):13===i||32===i?-1===c&&M(A,o):27===i&&e.allowEscapeKey===!0&&(t.closeModal(),a("esc"))}}e.timer&&(o.timeout=setTimeout(function(){t.closeModal(),a("timer")},e.timer));var u=function(){switch(e.input){case"select":return k(o,i.select);case"radio":return o.querySelector("."+i.radio+" input:checked")||o.querySelector("."+i.radio+" input:first-child");case"checkbox":return o.querySelector("#"+i.checkbox);case"textarea":return k(o,i.textarea);default:return k(o,i.input)}},p=function(){var t=u();switch(e.input){case"checkbox":return t.checked?1:0;case"radio":return t.checked?t.value:null;case"file":return t.files.length?t.files[0]:null;default:return e.inputAutoTrim?t.value.trim():t.value}};e.input&&setTimeout(function(){var e=u();e&&b(e)},0);var f,B=function(n){e.showLoaderOnConfirm&&t.showLoading(),e.preConfirm?e.preConfirm(n,e.extraParams).then(function(e){r(e||n),t.closeModal()},function(e){t.hideLoading(),e&&t.showValidationError(e)}):(r(n),t.closeModal())},L=function(n){var r=n||window.event,l=r.target||r.srcElement,c=h(l,i.confirm),u=h(l,i.cancel),d=h(o,"visible");switch(r.type){case"mouseover":case"mouseup":case"focus":e.buttonsStyling&&(c?l.style.backgroundColor=s(e.confirmButtonColor,-.1):u&&(l.style.backgroundColor=s(e.cancelButtonColor,-.1)));break;case"mouseout":case"blur":e.buttonsStyling&&(c?l.style.backgroundColor=e.confirmButtonColor:u&&(l.style.backgroundColor=e.cancelButtonColor));break;case"mousedown":e.buttonsStyling&&(c?l.style.backgroundColor=s(e.confirmButtonColor,-.2):u&&(l.style.backgroundColor=s(e.cancelButtonColor,-.2)));break;case"click":if(c&&d)if(e.input){var f=p();e.inputValidator?(t.disableInput(),e.inputValidator(f,e.extraParams).then(function(){t.enableInput(),B(f)},function(e){t.enableInput(),e&&t.showValidationError(e)})):B(f)}else B(!0);else u&&d&&(t.closeModal(),a("cancel"))}},q=o.querySelectorAll("button");for(f=0;f<q.length;f++)q[f].onclick=L,q[f].onmouseover=L,q[f].onmouseout=L,q[f].onmousedown=L;d.previousDocumentClick=document.onclick,document.onclick=function(n){var o=n||window.event,r=o.target||o.srcElement;h(r,i.close)?(t.closeModal(),a("close")):r===m()&&e.allowOutsideClick&&(t.closeModal(),a("overlay"))};var A=v(),P=y(),O=[A,P].concat(Array.prototype.slice.call(o.querySelectorAll("button:not([class^="+n+"]), input:not([type=hidden]), textarea, select")));for(f=0;f<O.length;f++)O[f].onfocus=L,O[f].onblur=L;e.reverseButtons&&A.parentNode.insertBefore(P,A),d.previousWindowKeyDown=window.onkeydown,window.onkeydown=c,e.buttonsStyling&&(A.style.borderLeftColor=e.confirmButtonColor,A.style.borderRightColor=e.confirmButtonColor),t.showLoading=t.enableLoading=function(){g(A,"loading"),g(o,"loading"),P.disabled=!0},t.hideLoading=t.disableLoading=function(){w(A,"loading"),w(o,"loading"),P.disabled=!1},t.enableButtons=function(){A.disabled=!1,P.disabled=!1},t.disableButtons=function(){A.disabled=!0,P.disabled=!0},t.enableInput=function(){var e=u();if("radio"===e.type)for(var t=e.parentNode.parentNode,n=t.querySelectorAll("input"),o=0;o<n.length;o++)n[o].disabled=!1;else e.disabled=!1},t.disableInput=function(){var e=u();if("radio"===e.type)for(var t=e.parentNode.parentNode,n=t.querySelectorAll("input"),o=0;o<n.length;o++)n[o].disabled=!0;else e.disabled=!0},t.showValidationError=function(e){var t=o.querySelector("."+i.validationerror);t.innerHTML=e,x(t);var n=u();b(n),g(n,"error")},t.resetValidationError=function(){var e=o.querySelector("."+i.validationerror);S(e);var t=u();t&&w(t,"error")},t.enableButtons(),t.hideLoading(),t.resetValidationError();var N,V=["input","select","radio","checkbox","textarea"];for(f=0;f<V.length;f++){var I=i[V[f]];for(N=k(o,I);N.attributes.length>0;)N.removeAttribute(N.attributes[0].name);for(var j in e.inputAttributes)N.setAttribute(j,e.inputAttributes[j]);N.className=I,e.inputClass&&g(N,e.inputClass),E(N)}var K;switch(e.input){case"text":case"email":case"password":case"file":N=k(o,i.input),N.value=e.inputValue,N.placeholder=e.inputPlaceholder,N.type=e.input,C(N);break;case"select":var W=k(o,i.select);if(W.innerHTML="",e.inputPlaceholder){var U=document.createElement("option");U.innerHTML=e.inputPlaceholder,U.value="",U.disabled=!0,U.selected=!0,W.appendChild(U)}K=function(t){for(var n in t){var o=document.createElement("option");o.value=n,o.innerHTML=t[n],e.inputValue===n&&(o.selected=!0),W.appendChild(o)}C(W),W.focus()};break;case"radio":var z=k(o,i.radio);z.innerHTML="",K=function(t){for(var n in t){var o=1,r=document.createElement("input"),a=document.createElement("label"),l=document.createElement("span");r.type="radio",r.name=i.radio,r.value=n,r.id=i.radio+"-"+o++,e.inputValue===n&&(r.checked=!0),l.innerHTML=t[n],a.appendChild(r),a.appendChild(l),a["for"]=r.id,z.appendChild(a)}C(z);var c=z.querySelectorAll("input");c.length&&c[0].focus()};break;case"checkbox":var R=k(o,i.checkbox),Z=o.querySelector("#"+i.checkbox);Z.value=1,Z.checked=Boolean(e.inputValue);var $=R.getElementsByTagName("span");$.length&&R.removeChild($[0]),$=document.createElement("span"),$.innerHTML=e.inputPlaceholder,R.appendChild($),C(R);break;case"textarea":var _=k(o,i.textarea);_.value=e.inputValue,_.placeholder=e.inputPlaceholder,C(_);break;case null:break;default:console.error('Unexpected type of input! Expected "text" or "email" or "password", "select", "checkbox", "textarea" or "file", got '+typeof arguments[0])}"select"!==e.input&&"radio"!==e.input||(e.inputOptions instanceof Promise?(t.showLoading(),e.inputOptions.then(function(e){t.hideLoading(),K(e)})):"object"==typeof e.inputOptions?K(e.inputOptions):console.error("Unexpected type of inputOptions! Expected object or Promise, got "+e.inputOptions)),D(),H(e.animation),l(-1,1)})}function t(){var n=arguments,o=f();return null===o&&(t.init(),o=f()),h(o,"visible")&&O(),e.apply(this,n)}var n="swal2-",o=function(e){var t={};for(var o in e)t[e[o]]=n+e[o];return t},i=o(["container","modal","overlay","close","content","spacer","confirm","cancel","icon","image","input","select","radio","checkbox","textarea","validationerror"]),r=o(["success","warning","info","question","error"]),a={title:"",text:"",html:"",type:null,animation:!0,allowOutsideClick:!0,allowEscapeKey:!0,showConfirmButton:!0,showCancelButton:!1,preConfirm:null,confirmButtonText:"OK",confirmButtonColor:"#3085d6",confirmButtonClass:null,cancelButtonText:"Cancel",cancelButtonColor:"#aaa",cancelButtonClass:null,buttonsStyling:!0,reverseButtons:!1,showCloseButton:!1,showLoaderOnConfirm:!1,imageUrl:null,imageWidth:null,imageHeight:null,imageClass:null,timer:null,width:500,padding:20,background:"#fff",input:null,inputPlaceholder:"",inputValue:"",inputOptions:{},inputAutoTrim:!0,inputClass:null,inputAttributes:{},inputValidator:null},l='<div class="'+i.overlay+'" tabIndex="-1"></div><div class="'+i.modal+'" style="display: none" tabIndex="-1"><div class="'+i.icon+" "+r.error+'"><span class="x-mark"><span class="line left"></span><span class="line right"></span></span></div><div class="'+i.icon+" "+r.question+'">?</div><div class="'+i.icon+" "+r.warning+'">!</div><div class="'+i.icon+" "+r.info+'">i</div><div class="'+i.icon+" "+r.success+'"><span class="line tip"></span> <span class="line long"></span><div class="placeholder"></div> <div class="fix"></div></div><img class="'+i.image+'"><h2></h2><div class="'+i.content+'"></div><input class="'+i.input+'"><select class="'+i.select+'"></select><div class="'+i.radio+'"></div><label for="'+i.checkbox+'" class="'+i.checkbox+'"><input type="checkbox" id="'+i.checkbox+'"></label><textarea class="'+i.textarea+'"></textarea><div class="'+i.validationerror+'"></div><hr class="'+i.spacer+'"><button class="'+i.confirm+'">OK</button><button class="'+i.cancel+'">Cancel</button><span class="'+i.close+'">×</span></div>',c=function(e,t){for(var n in t)t.hasOwnProperty(n)&&(e[n]=t[n]);return e},s=function(e,t){e=String(e).replace(/[^0-9a-f]/gi,""),e.length<6&&(e=e[0]+e[0]+e[1]+e[1]+e[2]+e[2]),t=t||0;for(var n="#",o=0;3>o;o++){var i=parseInt(e.substr(2*o,2),16);i=Math.round(Math.min(Math.max(0,i+i*t),255)).toString(16),n+=("00"+i).substr(i.length)}return n},u=n+"mediaquery",d={previousDocumentClick:null,previousWindowKeyDown:null,previousActiveElement:null},p=function(e){return document.querySelector("."+e)},f=function(){return p(i.modal)},m=function(){return p(i.overlay)},v=function(){return p(i.confirm)},y=function(){return p(i.cancel)},h=function(e,t){return new RegExp(" "+t+" ").test(" "+e.className+" ")},b=function(e){e.focus();var t=e.value;e.value="",e.value=t},g=function(e,t){t&&!h(e,t)&&(e.className+=" "+t)},w=function(e,t){var n=" "+e.className.replace(/[\t\r\n]/g," ")+" ";if(h(e,t)){for(;n.indexOf(" "+t+" ")>=0;)n=n.replace(" "+t+" "," ");e.className=n.replace(/^\s+|\s+$/g,"")}},k=function(e,t){for(var n=0;n<e.childNodes.length;n++)if(e.childNodes[n].classList.contains(t))return e.childNodes[n]},C=function(e){e.style.opacity="",e.style.display="block"},x=function(e){if(e&&!e.length)return C(e);for(var t=0;t<e.length;++t)C(e[t])},E=function(e){e.style.opacity="",e.style.display="none"},S=function(e){if(e&&!e.length)return E(e);for(var t=0;t<e.length;++t)E(e[t])},B=function(e,t){e.style.removeProperty?e.style.removeProperty(t):e.style.removeAttribute(t)},L=function(e){e.style.left="-9999px",e.style.display="block";var t=e.clientHeight;return e.style.left="",e.style.display="none","-"+parseInt(t/2,10)+"px"},q=function(e,t){if(+e.style.opacity<1){t=t||16,e.style.opacity=0,e.style.display="block";var n=+new Date,o=function(){var i=+e.style.opacity+(new Date-n)/100;e.style.opacity=i>1?1:i,n=+new Date,+e.style.opacity<1&&setTimeout(o,t)};o()}},A=function(e,t){if(+e.style.opacity>0){t=t||16;var n=e.style.opacity,o=+new Date,i=function(){var r=new Date-o,a=+e.style.opacity-r/(100*n);e.style.opacity=a,o=+new Date,+e.style.opacity>0?setTimeout(i,t):E(e)};i()}},M=function(e){if("function"==typeof MouseEvent){var t=new MouseEvent("click",{view:window,bubbles:!1,cancelable:!0});e.dispatchEvent(t)}else if(document.createEvent){var n=document.createEvent("MouseEvents");n.initEvent("click",!1,!1),e.dispatchEvent(n)}else document.createEventObject?e.fireEvent("onclick"):"function"==typeof e.onclick&&e.onclick()},T=function(e){"function"==typeof e.stopPropagation?(e.stopPropagation(),e.preventDefault()):window.event&&window.event.hasOwnProperty("cancelBubble")&&(window.event.cancelBubble=!0)},P=function(){var e=document.createElement("div"),t={WebkitAnimation:"webkitAnimationEnd",MozAnimation:"animationend",OAnimation:"oAnimationEnd oanimationend",msAnimation:"MSAnimationEnd",animation:"animationend"};for(var n in t)if(t.hasOwnProperty(n)&&void 0!==e.style[n])return t[n];return!1}(),O=function(){var e=f();window.onkeydown=d.previousWindowKeyDown,document.onclick=d.previousDocumentClick,d.previousActiveElement&&d.previousActiveElement.focus(),clearTimeout(e.timeout);var t=document.getElementsByTagName("head")[0],n=document.getElementById(u);n&&t.removeChild(n)},N=c({},a),V=function(e){var t,n=f();n.style.width=e.width+"px",n.style.padding=e.padding+"px",n.style.marginLeft=-e.width/2+"px",n.style.background=e.background;var o=document.getElementsByTagName("head")[0],a=document.createElement("style");a.type="text/css",a.id=u;var l=5,c=e.width+parseInt(e.width*(l/100)*2,10);a.innerHTML="@media screen and (max-width: "+c+"px) {."+i.modal+" {width: auto !important;left: "+l+"% !important;right: "+l+"% !important;margin-left: 0 !important;}}",o.appendChild(a);var s=n.querySelector("h2"),d=n.querySelector("."+i.content),p=v(),m=y(),h=n.querySelector("."+i.spacer),b=n.querySelector("."+i.close);if(s.innerHTML=e.title.split("\n").join("<br>"),e.text||e.html){if("object"==typeof e.html)if(d.innerHTML="",0 in e.html)for(t=0;t in e.html;t++)d.appendChild(e.html[t]);else d.appendChild(e.html);else d.innerHTML=e.html||e.text.split("\n").join("<br>");x(d)}else S(d);if(e.showCloseButton?x(b):S(b),n.className=i.modal,e.customClass&&g(n,e.customClass),S(n.querySelectorAll("."+i.icon)),e.type){var k=!1;for(var C in r)if(e.type===C){k=!0;break}if(!k)return console.error("Unknown alert type: "+e.type),!1;var E=n.querySelector("."+i.icon+"."+r[e.type]);switch(x(E),e.type){case"success":g(E,"animate"),g(E.querySelector(".tip"),"animate-success-tip"),g(E.querySelector(".long"),"animate-success-long");break;case"error":g(E,"animate-error-icon"),g(E.querySelector(".x-mark"),"animate-x-mark");break;case"warning":g(E,"pulse-warning")}}var L=n.querySelector("."+i.image);e.imageUrl?(L.setAttribute("src",e.imageUrl),x(L),e.imageWidth&&L.setAttribute("width",e.imageWidth),e.imageHeight&&L.setAttribute("height",e.imageHeight),e.imageClass&&g(L,e.imageClass)):S(L),e.showCancelButton?m.style.display="inline-block":S(m),e.showConfirmButton?B(p,"display"):S(p),e.showConfirmButton||e.showCancelButton?x(h):S(h),p.innerHTML=e.confirmButtonText,m.innerHTML=e.cancelButtonText,e.buttonsStyling&&(p.style.backgroundColor=e.confirmButtonColor,m.style.backgroundColor=e.cancelButtonColor),p.className=i.confirm,g(p,e.confirmButtonClass),m.className=i.cancel,g(m,e.cancelButtonClass),e.buttonsStyling?(g(p,"styled"),g(m,"styled")):(w(p,"styled"),w(m,"styled"),p.style.backgroundColor=p.style.borderLeftColor=p.style.borderRightColor="",m.style.backgroundColor=m.style.borderLeftColor=m.style.borderRightColor=""),e.animation===!0?w(n,"no-animation"):g(n,"no-animation")},H=function(e){var t=f();e?(q(m(),10),g(t,"show-swal2"),w(t,"hide-swal2")):x(m()),x(t),d.previousActiveElement=document.activeElement,g(t,"visible")},D=function(){var e=f();e.style.marginTop=L(e)};return t.queue=function(e){return new Promise(function(n,o){!function i(r,a){r<e.length?t(e[r]).then(function(){i(r+1,a)},function(e){o(e)}):n()}(0)})},t.close=t.closeModal=function(){var e=f();w(e,"show-swal2"),g(e,"hide-swal2"),w(e,"visible");var t=e.querySelector("."+i.icon+"."+r.success);w(t,"animate"),w(t.querySelector(".tip"),"animate-success-tip"),w(t.querySelector(".long"),"animate-success-long");var n=e.querySelector("."+i.icon+"."+r.error);w(n,"animate-error-icon"),w(n.querySelector(".x-mark"),"animate-x-mark");var o=e.querySelector("."+i.icon+"."+r.warning);w(o,"pulse-warning"),O(),P&&!h(e,"no-animation")?e.addEventListener(P,function a(){e.removeEventListener(P,a),h(e,"hide-swal2")&&(E(e),A(m(),0))}):(E(e),E(m()))},t.clickConfirm=function(){v().click()},t.clickCancel=function(){y().click()},t.init=function(){if("undefined"==typeof document)return void console.log("SweetAlert2 requires document to initialize");if(!document.getElementsByClassName(i.container).length){var e=document.createElement("div");e.className=i.container,e.innerHTML=l,document.body.appendChild(e);var n=f(),o=k(n,i.input),r=k(n,i.select),a=n.querySelector("#"+i.checkbox),c=k(n,i.textarea);o.oninput=function(){t.resetValidationError()},o.onkeyup=function(e){e.stopPropagation(),13===e.keyCode&&t.clickConfirm()},r.onchange=function(){t.resetValidationError()},a.onchange=function(){t.resetValidationError()},c.onchange=function(){t.resetValidationError()}}},t.setDefaults=function(e){if(!e)throw new Error("userParams is required");if("object"!=typeof e)throw new Error("userParams has to be a object");c(N,e)},t.resetDefaults=function(){N=c({},a)},t.version="4.0.4",window.sweetAlert=window.swal=t,function(){"complete"===document.readyState||"interactive"===document.readyState&&document.body?t.init():document.addEventListener("DOMContentLoaded",function e(){document.removeEventListener("DOMContentLoaded",e,!1),t.init()},!1)}(),t}); | ||
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t():"function"==typeof define&&define.amd?define(t):e.Sweetalert2=t()}(this,function(){"use strict";function e(){if(void 0===arguments[0])return console.error("sweetAlert2 expects at least 1 attribute!"),!1;var e=c({},N);switch(typeof arguments[0]){case"string":e.title=arguments[0],e.text=arguments[1]||"",e.type=arguments[2]||"";break;case"object":c(e,arguments[0]),e.extraParams=arguments[0].extraParams,"email"===e.input&&null===e.inputValidator&&(e.inputValidator=function(e){return new Promise(function(t,n){var o=/^[a-zA-Z0-9._-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,6}$/;o.test(e)?t():n("Invalid email address")})});break;default:return console.error('Unexpected type of argument! Expected "string" or "object", got '+typeof arguments[0]),!1}V(e);var o=f();return new Promise(function(r,a){function l(e,t){for(var n=0;n<O.length;n++)if(e+=t,e===O.length?e=0:-1===e&&(e=O.length-1),O[e].offsetWidth||O[e].offsetHeight||O[e].getClientRects().length)return void O[e].focus()}function c(n){var o=n||window.event,i=o.keyCode||o.which;if(-1!==[9,13,32,27].indexOf(i)){for(var r=o.target||o.srcElement,c=-1,s=0;s<O.length;s++)if(r===O[s]){c=s;break}9===i?(o.shiftKey?l(c,-1):l(c,1),T(o)):13===i||32===i?-1===c&&M(A,o):27===i&&e.allowEscapeKey===!0&&(t.closeModal(e.onClose),a("esc"))}}e.timer&&(o.timeout=setTimeout(function(){t.closeModal(e.onClose),a("timer")},e.timer));var u=function(){switch(e.input){case"select":return C(o,i.select);case"radio":return o.querySelector("."+i.radio+" input:checked")||o.querySelector("."+i.radio+" input:first-child");case"checkbox":return o.querySelector("#"+i.checkbox);case"textarea":return C(o,i.textarea);default:return C(o,i.input)}},p=function(){var t=u();switch(e.input){case"checkbox":return t.checked?1:0;case"radio":return t.checked?t.value:null;case"file":return t.files.length?t.files[0]:null;default:return e.inputAutoTrim?t.value.trim():t.value}};e.input&&setTimeout(function(){var e=u();e&&b(e)},0);var f,B=function(n){e.showLoaderOnConfirm&&t.showLoading(),e.preConfirm?e.preConfirm(n,e.extraParams).then(function(o){t.closeModal(e.onClose),r(o||n)},function(e){t.hideLoading(),e&&t.showValidationError(e)}):(t.closeModal(e.onClose),r(n))},L=function(n){var r=n||window.event,l=r.target||r.srcElement,c=h(l,i.confirm),u=h(l,i.cancel),d=h(o,"visible");switch(r.type){case"mouseover":case"mouseup":case"focus":e.buttonsStyling&&(c?l.style.backgroundColor=s(e.confirmButtonColor,-.1):u&&(l.style.backgroundColor=s(e.cancelButtonColor,-.1)));break;case"mouseout":case"blur":e.buttonsStyling&&(c?l.style.backgroundColor=e.confirmButtonColor:u&&(l.style.backgroundColor=e.cancelButtonColor));break;case"mousedown":e.buttonsStyling&&(c?l.style.backgroundColor=s(e.confirmButtonColor,-.2):u&&(l.style.backgroundColor=s(e.cancelButtonColor,-.2)));break;case"click":if(c&&d)if(e.input){var f=p();e.inputValidator?(t.disableInput(),e.inputValidator(f,e.extraParams).then(function(){t.enableInput(),B(f)},function(e){t.enableInput(),e&&t.showValidationError(e)})):B(f)}else B(!0);else u&&d&&(t.closeModal(e.onClose),a("cancel"))}},q=o.querySelectorAll("button");for(f=0;f<q.length;f++)q[f].onclick=L,q[f].onmouseover=L,q[f].onmouseout=L,q[f].onmousedown=L;d.previousDocumentClick=document.onclick,document.onclick=function(n){var o=n||window.event,r=o.target||o.srcElement;h(r,i.close)?(t.closeModal(e.onClose),a("close")):r===m()&&e.allowOutsideClick&&(t.closeModal(e.onClose),a("overlay"))};var A=v(),P=y(),O=[A,P].concat(Array.prototype.slice.call(o.querySelectorAll("button:not([class^="+n+"]), input:not([type=hidden]), textarea, select")));for(f=0;f<O.length;f++)O[f].onfocus=L,O[f].onblur=L;e.reverseButtons&&A.parentNode.insertBefore(P,A),d.previousWindowKeyDown=window.onkeydown,window.onkeydown=c,e.buttonsStyling&&(A.style.borderLeftColor=e.confirmButtonColor,A.style.borderRightColor=e.confirmButtonColor),t.showLoading=t.enableLoading=function(){g(A,"loading"),g(o,"loading"),P.disabled=!0},t.hideLoading=t.disableLoading=function(){w(A,"loading"),w(o,"loading"),P.disabled=!1},t.enableButtons=function(){A.disabled=!1,P.disabled=!1},t.disableButtons=function(){A.disabled=!0,P.disabled=!0},t.enableInput=function(){var e=u();if("radio"===e.type)for(var t=e.parentNode.parentNode,n=t.querySelectorAll("input"),o=0;o<n.length;o++)n[o].disabled=!1;else e.disabled=!1},t.disableInput=function(){var e=u();if("radio"===e.type)for(var t=e.parentNode.parentNode,n=t.querySelectorAll("input"),o=0;o<n.length;o++)n[o].disabled=!0;else e.disabled=!0},t.showValidationError=function(e){var t=o.querySelector("."+i.validationerror);t.innerHTML=e,x(t);var n=u();b(n),g(n,"error")},t.resetValidationError=function(){var e=o.querySelector("."+i.validationerror);S(e);var t=u();t&&w(t,"error")},t.enableButtons(),t.hideLoading(),t.resetValidationError();var N,V=["input","select","radio","checkbox","textarea"];for(f=0;f<V.length;f++){var I=i[V[f]];for(N=C(o,I);N.attributes.length>0;)N.removeAttribute(N.attributes[0].name);for(var j in e.inputAttributes)N.setAttribute(j,e.inputAttributes[j]);N.className=I,e.inputClass&&g(N,e.inputClass),E(N)}var K;switch(e.input){case"text":case"email":case"password":case"file":N=C(o,i.input),N.value=e.inputValue,N.placeholder=e.inputPlaceholder,N.type=e.input,k(N);break;case"select":var W=C(o,i.select);if(W.innerHTML="",e.inputPlaceholder){var U=document.createElement("option");U.innerHTML=e.inputPlaceholder,U.value="",U.disabled=!0,U.selected=!0,W.appendChild(U)}K=function(t){for(var n in t){var o=document.createElement("option");o.value=n,o.innerHTML=t[n],e.inputValue===n&&(o.selected=!0),W.appendChild(o)}k(W),W.focus()};break;case"radio":var z=C(o,i.radio);z.innerHTML="",K=function(t){for(var n in t){var o=1,r=document.createElement("input"),a=document.createElement("label"),l=document.createElement("span");r.type="radio",r.name=i.radio,r.value=n,r.id=i.radio+"-"+o++,e.inputValue===n&&(r.checked=!0),l.innerHTML=t[n],a.appendChild(r),a.appendChild(l),a["for"]=r.id,z.appendChild(a)}k(z);var c=z.querySelectorAll("input");c.length&&c[0].focus()};break;case"checkbox":var R=C(o,i.checkbox),Z=o.querySelector("#"+i.checkbox);Z.value=1,Z.checked=Boolean(e.inputValue);var $=R.getElementsByTagName("span");$.length&&R.removeChild($[0]),$=document.createElement("span"),$.innerHTML=e.inputPlaceholder,R.appendChild($),k(R);break;case"textarea":var _=C(o,i.textarea);_.value=e.inputValue,_.placeholder=e.inputPlaceholder,k(_);break;case null:break;default:console.error('Unexpected type of input! Expected "text" or "email" or "password", "select", "checkbox", "textarea" or "file", got '+typeof arguments[0])}"select"!==e.input&&"radio"!==e.input||(e.inputOptions instanceof Promise?(t.showLoading(),e.inputOptions.then(function(e){t.hideLoading(),K(e)})):"object"==typeof e.inputOptions?K(e.inputOptions):console.error("Unexpected type of inputOptions! Expected object or Promise, got "+e.inputOptions)),D(),H(e.animation,e.onOpen),l(-1,1)})}function t(){var n=arguments,o=f();return null===o&&(t.init(),o=f()),h(o,"visible")&&O(),e.apply(this,n)}var n="swal2-",o=function(e){var t={};for(var o in e)t[e[o]]=n+e[o];return t},i=o(["container","modal","overlay","close","content","spacer","confirm","cancel","icon","image","input","select","radio","checkbox","textarea","validationerror"]),r=o(["success","warning","info","question","error"]),a={title:"",text:"",html:"",type:null,animation:!0,allowOutsideClick:!0,allowEscapeKey:!0,showConfirmButton:!0,showCancelButton:!1,preConfirm:null,confirmButtonText:"OK",confirmButtonColor:"#3085d6",confirmButtonClass:null,cancelButtonText:"Cancel",cancelButtonColor:"#aaa",cancelButtonClass:null,buttonsStyling:!0,reverseButtons:!1,showCloseButton:!1,showLoaderOnConfirm:!1,imageUrl:null,imageWidth:null,imageHeight:null,imageClass:null,timer:null,width:500,padding:20,background:"#fff",input:null,inputPlaceholder:"",inputValue:"",inputOptions:{},inputAutoTrim:!0,inputClass:null,inputAttributes:{},inputValidator:null,onOpen:null,onClose:null},l='<div class="'+i.overlay+'" tabIndex="-1"></div><div class="'+i.modal+'" style="display: none" tabIndex="-1"><div class="'+i.icon+" "+r.error+'"><span class="x-mark"><span class="line left"></span><span class="line right"></span></span></div><div class="'+i.icon+" "+r.question+'">?</div><div class="'+i.icon+" "+r.warning+'">!</div><div class="'+i.icon+" "+r.info+'">i</div><div class="'+i.icon+" "+r.success+'"><span class="line tip"></span> <span class="line long"></span><div class="placeholder"></div> <div class="fix"></div></div><img class="'+i.image+'"><h2></h2><div class="'+i.content+'"></div><input class="'+i.input+'"><select class="'+i.select+'"></select><div class="'+i.radio+'"></div><label for="'+i.checkbox+'" class="'+i.checkbox+'"><input type="checkbox" id="'+i.checkbox+'"></label><textarea class="'+i.textarea+'"></textarea><div class="'+i.validationerror+'"></div><hr class="'+i.spacer+'"><button class="'+i.confirm+'">OK</button><button class="'+i.cancel+'">Cancel</button><span class="'+i.close+'">×</span></div>',c=function(e,t){for(var n in t)t.hasOwnProperty(n)&&(e[n]=t[n]);return e},s=function(e,t){e=String(e).replace(/[^0-9a-f]/gi,""),e.length<6&&(e=e[0]+e[0]+e[1]+e[1]+e[2]+e[2]),t=t||0;for(var n="#",o=0;3>o;o++){var i=parseInt(e.substr(2*o,2),16);i=Math.round(Math.min(Math.max(0,i+i*t),255)).toString(16),n+=("00"+i).substr(i.length)}return n},u=n+"mediaquery",d={previousDocumentClick:null,previousWindowKeyDown:null,previousActiveElement:null},p=function(e){return document.querySelector("."+e)},f=function(){return p(i.modal)},m=function(){return p(i.overlay)},v=function(){return p(i.confirm)},y=function(){return p(i.cancel)},h=function(e,t){return new RegExp(" "+t+" ").test(" "+e.className+" ")},b=function(e){e.focus();var t=e.value;e.value="",e.value=t},g=function(e,t){t&&!h(e,t)&&(e.className+=" "+t)},w=function(e,t){var n=" "+e.className.replace(/[\t\r\n]/g," ")+" ";if(h(e,t)){for(;n.indexOf(" "+t+" ")>=0;)n=n.replace(" "+t+" "," ");e.className=n.replace(/^\s+|\s+$/g,"")}},C=function(e,t){for(var n=0;n<e.childNodes.length;n++)if(e.childNodes[n].classList.contains(t))return e.childNodes[n]},k=function(e){e.style.opacity="",e.style.display="block"},x=function(e){if(e&&!e.length)return k(e);for(var t=0;t<e.length;++t)k(e[t])},E=function(e){e.style.opacity="",e.style.display="none"},S=function(e){if(e&&!e.length)return E(e);for(var t=0;t<e.length;++t)E(e[t])},B=function(e,t){e.style.removeProperty?e.style.removeProperty(t):e.style.removeAttribute(t)},L=function(e){e.style.left="-9999px",e.style.display="block";var t=e.clientHeight;return e.style.left="",e.style.display="none","-"+parseInt(t/2,10)+"px"},q=function(e,t){if(+e.style.opacity<1){t=t||16,e.style.opacity=0,e.style.display="block";var n=+new Date,o=function(){var i=+e.style.opacity+(new Date-n)/100;e.style.opacity=i>1?1:i,n=+new Date,+e.style.opacity<1&&setTimeout(o,t)};o()}},A=function(e,t){if(+e.style.opacity>0){t=t||16;var n=e.style.opacity,o=+new Date,i=function(){var r=new Date-o,a=+e.style.opacity-r/(100*n);e.style.opacity=a,o=+new Date,+e.style.opacity>0?setTimeout(i,t):E(e)};i()}},M=function(e){if("function"==typeof MouseEvent){var t=new MouseEvent("click",{view:window,bubbles:!1,cancelable:!0});e.dispatchEvent(t)}else if(document.createEvent){var n=document.createEvent("MouseEvents");n.initEvent("click",!1,!1),e.dispatchEvent(n)}else document.createEventObject?e.fireEvent("onclick"):"function"==typeof e.onclick&&e.onclick()},T=function(e){"function"==typeof e.stopPropagation?(e.stopPropagation(),e.preventDefault()):window.event&&window.event.hasOwnProperty("cancelBubble")&&(window.event.cancelBubble=!0)},P=function(){var e=document.createElement("div"),t={WebkitAnimation:"webkitAnimationEnd",MozAnimation:"animationend",OAnimation:"oAnimationEnd oanimationend",msAnimation:"MSAnimationEnd",animation:"animationend"};for(var n in t)if(t.hasOwnProperty(n)&&void 0!==e.style[n])return t[n];return!1}(),O=function(){var e=f();window.onkeydown=d.previousWindowKeyDown,document.onclick=d.previousDocumentClick,d.previousActiveElement&&d.previousActiveElement.focus(),clearTimeout(e.timeout);var t=document.getElementsByTagName("head")[0],n=document.getElementById(u);n&&t.removeChild(n)},N=c({},a),V=function(e){var t,n=f();n.style.width=e.width+"px",n.style.padding=e.padding+"px",n.style.marginLeft=-e.width/2+"px",n.style.background=e.background;var o=document.getElementsByTagName("head")[0],a=document.createElement("style");a.type="text/css",a.id=u;var l=5,c=e.width+parseInt(e.width*(l/100)*2,10);a.innerHTML="@media screen and (max-width: "+c+"px) {."+i.modal+" {width: auto !important;left: "+l+"% !important;right: "+l+"% !important;margin-left: 0 !important;}}",o.appendChild(a);var s=n.querySelector("h2"),d=n.querySelector("."+i.content),p=v(),m=y(),h=n.querySelector("."+i.spacer),b=n.querySelector("."+i.close);if(s.innerHTML=e.title.split("\n").join("<br>"),e.text||e.html){if("object"==typeof e.html)if(d.innerHTML="",0 in e.html)for(t=0;t in e.html;t++)d.appendChild(e.html[t]);else d.appendChild(e.html);else d.innerHTML=e.html||e.text.split("\n").join("<br>");x(d)}else S(d);if(e.showCloseButton?x(b):S(b),n.className=i.modal,e.customClass&&g(n,e.customClass),S(n.querySelectorAll("."+i.icon)),e.type){var C=!1;for(var k in r)if(e.type===k){C=!0;break}if(!C)return console.error("Unknown alert type: "+e.type),!1;var E=n.querySelector("."+i.icon+"."+r[e.type]);switch(x(E),e.type){case"success":g(E,"animate"),g(E.querySelector(".tip"),"animate-success-tip"),g(E.querySelector(".long"),"animate-success-long");break;case"error":g(E,"animate-error-icon"),g(E.querySelector(".x-mark"),"animate-x-mark");break;case"warning":g(E,"pulse-warning")}}var L=n.querySelector("."+i.image);e.imageUrl?(L.setAttribute("src",e.imageUrl),x(L),e.imageWidth&&L.setAttribute("width",e.imageWidth),e.imageHeight&&L.setAttribute("height",e.imageHeight),e.imageClass&&g(L,e.imageClass)):S(L),e.showCancelButton?m.style.display="inline-block":S(m),e.showConfirmButton?B(p,"display"):S(p),e.showConfirmButton||e.showCancelButton?x(h):S(h),p.innerHTML=e.confirmButtonText,m.innerHTML=e.cancelButtonText,e.buttonsStyling&&(p.style.backgroundColor=e.confirmButtonColor,m.style.backgroundColor=e.cancelButtonColor),p.className=i.confirm,g(p,e.confirmButtonClass),m.className=i.cancel,g(m,e.cancelButtonClass),e.buttonsStyling?(g(p,"styled"),g(m,"styled")):(w(p,"styled"),w(m,"styled"),p.style.backgroundColor=p.style.borderLeftColor=p.style.borderRightColor="",m.style.backgroundColor=m.style.borderLeftColor=m.style.borderRightColor=""),e.animation===!0?w(n,"no-animation"):g(n,"no-animation")},H=function(e,t){var n=f();e?(q(m(),10),g(n,"show-swal2"),w(n,"hide-swal2")):x(m()),x(n),d.previousActiveElement=document.activeElement,g(n,"visible"),null!==t&&"function"==typeof t&&t.call(this,n)},D=function(){var e=f();e.style.marginTop=L(e)};return t.queue=function(e){return new Promise(function(n,o){!function i(r,a){r<e.length?t(e[r]).then(function(){i(r+1,a)},function(e){o(e)}):n()}(0)})},t.close=t.closeModal=function(e){var t=f();w(t,"show-swal2"),g(t,"hide-swal2"),w(t,"visible");var n=t.querySelector("."+i.icon+"."+r.success);w(n,"animate"),w(n.querySelector(".tip"),"animate-success-tip"),w(n.querySelector(".long"),"animate-success-long");var o=t.querySelector("."+i.icon+"."+r.error);w(o,"animate-error-icon"),w(o.querySelector(".x-mark"),"animate-x-mark");var a=t.querySelector("."+i.icon+"."+r.warning);w(a,"pulse-warning"),O(),P&&!h(t,"no-animation")?t.addEventListener(P,function l(){t.removeEventListener(P,l),h(t,"hide-swal2")&&(E(t),A(m(),0))}):(E(t),E(m())),null!==e&&"function"==typeof e&&e.call(this,t)},t.clickConfirm=function(){v().click()},t.clickCancel=function(){y().click()},t.init=function(){if("undefined"==typeof document)return void console.log("SweetAlert2 requires document to initialize");if(!document.getElementsByClassName(i.container).length){var e=document.createElement("div");e.className=i.container,e.innerHTML=l,document.body.appendChild(e);var n=f(),o=C(n,i.input),r=C(n,i.select),a=n.querySelector("#"+i.checkbox),c=C(n,i.textarea);o.oninput=function(){t.resetValidationError()},o.onkeyup=function(e){e.stopPropagation(),13===e.keyCode&&t.clickConfirm()},r.onchange=function(){t.resetValidationError()},a.onchange=function(){t.resetValidationError()},c.onchange=function(){t.resetValidationError()}}},t.setDefaults=function(e){if(!e)throw new Error("userParams is required");if("object"!=typeof e)throw new Error("userParams has to be a object");c(N,e)},t.resetDefaults=function(){N=c({},a)},t.version="4.0.5",window.sweetAlert=window.swal=t,function(){"complete"===document.readyState||"interactive"===document.readyState&&document.body?t.init():document.addEventListener("DOMContentLoaded",function e(){document.removeEventListener("DOMContentLoaded",e,!1),t.init()},!1)}(),t}); |
{ | ||
"name": "sweetalert2", | ||
"version": "4.0.4", | ||
"version": "4.0.5", | ||
"repository": "https://github.com/limonte/sweetalert2.git", | ||
@@ -5,0 +5,0 @@ "homepage": "https://limonte.github.io/sweetalert2/", |
@@ -17,3 +17,3 @@ SweetAlert2 [![Build Status](https://travis-ci.org/limonte/sweetalert2.svg?branch=master)](https://travis-ci.org/limonte/sweetalert2) | ||
<img src="https://raw.github.com/limonte/sweetalert2/master/sweetalert2.gif" width="686" height="435"> | ||
<img src="https://raw.github.com/limonte/sweetalert2/master/sweetalert2.gif" width="686"> | ||
@@ -106,41 +106,42 @@ | ||
| Argument | Default value | Description | | ||
| --------------------- | ----------------- | ----------- | | ||
| `title` | `null` | The title of the modal. It can either be added to the object under the key "title" or passed as the first parameter of the function. | | ||
| `text` | `null` | A description for the modal. It can either be added to the object under the key "text" or passed as the second parameter of the function. | | ||
| `html` | `null` | A HTML description for the modal. If `text` and `html` parameters are provided in the same time, "text" will be used. | | ||
| `type ` | `null` | The type of the modal. SweetAlert2 comes with [5 built-in types](#modal-types) which will show a corresponding icon animation: `warning`, `error`, `success`, `info` and `question`. It can either be put in the array under the key `type` or passed as the third parameter of the function. | | ||
| `customClass` | `null` | A custom CSS class for the modal. | | ||
| `animation` | `true` | If set to `false`, modal CSS animation will be disabled. | | ||
| `allowOutsideClick` | `true` | If set to `false`, the user can't dismiss the modal by clicking outside it. | | ||
| `allowEscapeKey` | `true` | If set to `false`, the user can't dismiss the modal by pressing the Escape key. | | ||
| `showConfirmButton` | `true` | If set to `false`, a "Confirm"-button will not be shown. It can be useful when you're using `html` parameter for custom HTML description. | | ||
| `showCancelButton` | `false` | If set to `true`, a "Cancel"-button will be shown, which the user can click on to dismiss the modal. | | ||
| `confirmButtonText` | `"OK"` | Use this to change the text on the "Confirm"-button. | | ||
| `cancelButtonText` | `"Cancel"` | Use this to change the text on the "Cancel"-button. | | ||
| `confirmButtonColor` | `"#3085d6"` | Use this to change the background color of the "Confirm"-button (must be a HEX value). | | ||
| `cancelButtonColor` | `"#aaa"` | Use this to change the background color of the "Cancel"-button (must be a HEX value). | | ||
| `confirmButtonClass` | `null` | A custom CSS class for the "Confirm"-button. | | ||
| `cancelButtonClass` | `null` | A custom CSS class for the "Cancel"-button. | | ||
| `buttonsStyling` | `true` | Apply default swal2 styling to buttons. If you want to use your own classes (e.g. Bootstrap classes) set this parameter to `false`. | | ||
| `reverseButtons` | `false` | Set to `true` if you want to invert default buttons positions. | | ||
| `showCloseButton` | `false` | Set to `true` to show close button in top right corner of the modal. | | ||
| `showLoaderOnConfirm` | `false` | Set to `true` to disable buttons and show that something is loading. Useful for AJAX requests. | | ||
| `preConfirm` | `null` | Function to execute before confirm, should return Promise, see <a href="https://limonte.github.io/sweetalert2/#ajax-request">usage example</a>. | | ||
| `imageUrl` | `null` | Add a customized icon for the modal. Should contain a string with the path or URL to the image. | | ||
| `imageWidth` | `null` | If imageUrl is set, you can specify imageWidth to describes image width in px. | | ||
| `imageHeight` | `null` | Custom image height in px. | | ||
| `imageClass` | `null` | A custom CSS class for the customized icon. | | ||
| `timer` | `null` | Auto close timer of the modal. Set in ms (milliseconds). | | ||
| `width` | `500` | Modal window width, including paddings (`box-sizing: border-box`). | | ||
| `padding` | `20` | Modal window padding. | | ||
| `background` | `"#fff"` | Modal window background (CSS `background` property). | | ||
| `input` | `null` | Input field type, can be `"text"`, `"email"`, `"password"`, `"textarea"`, `"select"`, `"radio"`, `"checkbox"` and `"file"`. | | ||
| `inputPlaceholder` | `""` | Input field placeholder. | | ||
| `inputValue` | `""` | Input field initial value. | | ||
| `inputOptions` | `{}` or `Promise` | If `input` parameter is set to `"select"` or `"radio"`, you can provide options. Object keys will represent options values, object values will represent options text values. | | ||
| `inputAutoTrim` | `true` | Automatically remove whitespaces from both ends of a result string. Set this parameter to `false` to disable auto-trimming. | | ||
| `inputValidator` | `null` | Validator for input field, should return Promise, see <a href="https://limonte.github.io/sweetalert2/#select-box">usage example</a>. | | ||
| `inputClass` | `null` | A custom CSS class for the input field. | | ||
| Argument | Default value | Description | | ||
| --------------------- | -------------------- | ----------- | | ||
| `title` | `null` | The title of the modal. It can either be added to the object under the key "title" or passed as the first parameter of the function. | | ||
| `text` | `null` | A description for the modal. It can either be added to the object under the key "text" or passed as the second parameter of the function. | | ||
| `html` | `null` | A HTML description for the modal. If `text` and `html` parameters are provided in the same time, "text" will be used. | | ||
| `type ` | `null` | The type of the modal. SweetAlert2 comes with [5 built-in types](#modal-types) which will show a corresponding icon animation: `warning`, `error`, `success`, `info` and `question`. It can either be put in the array under the key `type` or passed as the third parameter of the function. | | ||
| `customClass` | `null` | A custom CSS class for the modal. | | ||
| `animation` | `true` | If set to `false`, modal CSS animation will be disabled. | | ||
| `allowOutsideClick` | `true` | If set to `false`, the user can't dismiss the modal by clicking outside it. | | ||
| `allowEscapeKey` | `true` | If set to `false`, the user can't dismiss the modal by pressing the Escape key. | | ||
| `showConfirmButton` | `true` | If set to `false`, a "Confirm"-button will not be shown. It can be useful when you're using `html` parameter for custom HTML description. | | ||
| `showCancelButton` | `false` | If set to `true`, a "Cancel"-button will be shown, which the user can click on to dismiss the modal. | | ||
| `confirmButtonText` | `"OK"` | Use this to change the text on the "Confirm"-button. | | ||
| `cancelButtonText` | `"Cancel"` | Use this to change the text on the "Cancel"-button. | | ||
| `confirmButtonColor` | `"#3085d6"` | Use this to change the background color of the "Confirm"-button (must be a HEX value). | | ||
| `cancelButtonColor` | `"#aaa"` | Use this to change the background color of the "Cancel"-button (must be a HEX value). | | ||
| `confirmButtonClass` | `null` | A custom CSS class for the "Confirm"-button. | | ||
| `cancelButtonClass` | `null` | A custom CSS class for the "Cancel"-button. | | ||
| `buttonsStyling` | `true` | Apply default swal2 styling to buttons. If you want to use your own classes (e.g. Bootstrap classes) set this parameter to `false`. | | ||
| `reverseButtons` | `false` | Set to `true` if you want to invert default buttons positions. | | ||
| `showCloseButton` | `false` | Set to `true` to show close button in top right corner of the modal. | | ||
| `showLoaderOnConfirm` | `false` | Set to `true` to disable buttons and show that something is loading. Useful for AJAX requests. | | ||
| `preConfirm` | `null` | Function to execute before confirm, should return Promise, see <a href="https://limonte.github.io/sweetalert2/#ajax-request">usage example</a>. | | ||
| `imageUrl` | `null` | Add a customized icon for the modal. Should contain a string with the path or URL to the image. | | ||
| `imageWidth` | `null` | If imageUrl is set, you can specify imageWidth to describes image width in px. | | ||
| `imageHeight` | `null` | Custom image height in px. | | ||
| `imageClass` | `null` | A custom CSS class for the customized icon. | | ||
| `timer` | `null` | Auto close timer of the modal. Set in ms (milliseconds). | | ||
| `width` | `500` | Modal window width, including paddings (`box-sizing: border-box`). | | ||
| `padding` | `20` | Modal window padding. | | ||
| `background` | `"#fff"` | Modal window background (CSS `background` property). | | ||
| `input` | `null` | Input field type, can be `"text"`, `"email"`, `"password"`, `"textarea"`, `"select"`, `"radio"`, `"checkbox"` and `"file"`. | | ||
| `inputPlaceholder` | `""` | Input field placeholder. | | ||
| `inputValue` | `""` | Input field initial value. | | ||
| `inputOptions` | `{}` or `Promise` | If `input` parameter is set to `"select"` or `"radio"`, you can provide options. Object keys will represent options values, object values will represent options text values. | | ||
| `inputAutoTrim` | `true` | Automatically remove whitespaces from both ends of a result string. Set this parameter to `false` to disable auto-trimming. | | ||
| `inputValidator` | `null` | Validator for input field, should return Promise, see <a href="https://limonte.github.io/sweetalert2/#select-box">usage example</a>. | | ||
| `inputClass` | `null` | A custom CSS class for the input field. | | ||
| `onOpen` | `null` | Function to run when modal opens, provides modal DOM element as first param. | | ||
| `onClose` | `null` | Function to run when modal closes, provides modal DOM element as first param. | | ||
You can redefine default params by using `swal.setDefaults(customParams)` where `customParams` is an object. | ||
@@ -147,0 +148,0 @@ |
@@ -201,3 +201,3 @@ 'use strict'; | ||
*/ | ||
var openModal = function(animation) { | ||
var openModal = function(animation, onComplete) { | ||
var modal = dom.getModal(); | ||
@@ -212,6 +212,7 @@ if (animation) { | ||
dom.show(modal); | ||
dom.states.previousActiveElement = document.activeElement; | ||
dom.addClass(modal, 'visible'); | ||
if (onComplete !== null && typeof onComplete === 'function') { | ||
onComplete.call(this, modal); | ||
} | ||
}; | ||
@@ -279,3 +280,3 @@ | ||
modal.timeout = setTimeout(function() { | ||
sweetAlert.closeModal(); | ||
sweetAlert.closeModal(params.onClose); | ||
reject('timer'); | ||
@@ -285,3 +286,2 @@ }, params.timer); | ||
// input/select autofocus | ||
var getInput = function() { | ||
@@ -333,4 +333,4 @@ switch (params.input) { | ||
function(preConfirmValue) { | ||
sweetAlert.closeModal(params.onClose); | ||
resolve(preConfirmValue || value); | ||
sweetAlert.closeModal(); | ||
}, | ||
@@ -345,4 +345,4 @@ function(error) { | ||
} else { | ||
sweetAlert.closeModal(params.onClose); | ||
resolve(value); | ||
sweetAlert.closeModal(); | ||
} | ||
@@ -420,4 +420,3 @@ }; | ||
} else if (targetedCancel && modalIsVisible) { | ||
sweetAlert.closeModal(); | ||
sweetAlert.closeModal(params.onClose); | ||
reject('cancel'); | ||
@@ -447,6 +446,6 @@ } | ||
if (dom.hasClass(target, swalClasses.close)) { | ||
sweetAlert.closeModal(); | ||
sweetAlert.closeModal(params.onClose); | ||
reject('close'); | ||
} else if (target === dom.getOverlay() && params.allowOutsideClick) { | ||
sweetAlert.closeModal(); | ||
sweetAlert.closeModal(params.onClose); | ||
reject('overlay'); | ||
@@ -536,3 +535,3 @@ } | ||
} else if (keyCode === 27 && params.allowEscapeKey === true) { | ||
sweetAlert.closeModal(); | ||
sweetAlert.closeModal(params.onClose); | ||
reject('esc'); | ||
@@ -762,3 +761,3 @@ } | ||
fixVerticalPosition(); | ||
openModal(params.animation); | ||
openModal(params.animation, params.onOpen); | ||
@@ -810,3 +809,3 @@ // Focus the first element (input or button) | ||
*/ | ||
sweetAlert.close = sweetAlert.closeModal = function() { | ||
sweetAlert.close = sweetAlert.closeModal = function(onComplete) { | ||
var modal = dom.getModal(); | ||
@@ -844,2 +843,5 @@ dom.removeClass(modal, 'show-swal2'); | ||
} | ||
if (onComplete !== null && typeof onComplete === 'function') { | ||
onComplete.call(this, modal); | ||
} | ||
}; | ||
@@ -846,0 +848,0 @@ |
@@ -39,3 +39,5 @@ import { swalClasses, iconTypes } from './classes.js'; | ||
inputAttributes: {}, | ||
inputValidator: null | ||
inputValidator: null, | ||
onOpen: null, | ||
onClose: null, | ||
}; | ||
@@ -42,0 +44,0 @@ |
Sorry, the diff of this file is not supported yet
187518
4008
196