D7net
Home
Console
Upload
information
Create File
Create Folder
About
Tools
:
/
home
/
everqlsh
/
www
/
wp-admin
/
user
/
577040
/
Filename :
front.zip
back
Copy
PK �K}\����?1 ?1 chartjs-plugin-datalabels.min.jsnu �[��� /*! * chartjs-plugin-datalabels v0.6.0 * https://chartjs-plugin-datalabels.netlify.com * (c) 2019 Chart.js Contributors * Released under the MIT license */ !function(t,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e(require("chart.js")):"function"==typeof define&&define.amd?define(["chart.js"],e):(t=t||self).ChartDataLabels=e(t.Chart)}(this,function(t){"use strict";var e=(t=t&&t.hasOwnProperty("default")?t.default:t).helpers,r=function(){if("undefined"!=typeof window){if(window.devicePixelRatio)return window.devicePixelRatio;var t=window.screen;if(t)return(t.deviceXDPI||1)/(t.logicalXDPI||1)}return 1}(),n={toTextLines:function(t){var r,n=[];for(t=[].concat(t);t.length;)"string"==typeof(r=t.pop())?n.unshift.apply(n,r.split("\n")):Array.isArray(r)?t.push.apply(t,r):e.isNullOrUndef(t)||n.unshift(""+r);return n},toFontString:function(t){return!t||e.isNullOrUndef(t.size)||e.isNullOrUndef(t.family)?null:(t.style?t.style+" ":"")+(t.weight?t.weight+" ":"")+t.size+"px "+t.family},textSize:function(t,e,r){var n,i=[].concat(e),a=i.length,o=t.font,l=0;for(t.font=r.string,n=0;n<a;++n)l=Math.max(t.measureText(i[n]).width,l);return t.font=o,{height:a*r.lineHeight,width:l}},parseFont:function(r){var i=t.defaults.global,a=e.valueOrDefault(r.size,i.defaultFontSize),o={family:e.valueOrDefault(r.family,i.defaultFontFamily),lineHeight:e.options.toLineHeight(r.lineHeight,a),size:a,style:e.valueOrDefault(r.style,i.defaultFontStyle),weight:e.valueOrDefault(r.weight,null),string:""};return o.string=n.toFontString(o),o},bound:function(t,e,r){return Math.max(t,Math.min(e,r))},arrayDiff:function(t,e){var r,n,i,a,o=t.slice(),l=[];for(r=0,i=e.length;r<i;++r)a=e[r],-1===(n=o.indexOf(a))?l.push([a,1]):o.splice(n,1);for(r=0,i=o.length;r<i;++r)l.push([o[r],-1]);return l},rasterize:function(t){return Math.round(t*r)/r}};function i(t,e){var r=e.x,n=e.y;if(null===r)return{x:0,y:-1};if(null===n)return{x:1,y:0};var i=t.x-r,a=t.y-n,o=Math.sqrt(i*i+a*a);return{x:o?i/o:0,y:o?a/o:-1}}var a=0,o=1,l=2,s=4,u=8;function d(t,e,r){var n=a;return t<r.left?n|=o:t>r.right&&(n|=l),e<r.top?n|=u:e>r.bottom&&(n|=s),n}function f(t,e){var r,n,i=e.anchor,a=t;return e.clamp&&(a=function(t,e){for(var r,n,i,a=t.x0,f=t.y0,c=t.x1,h=t.y1,x=d(a,f,e),y=d(c,h,e);x|y&&!(x&y);)(r=x||y)&u?(n=a+(c-a)*(e.top-f)/(h-f),i=e.top):r&s?(n=a+(c-a)*(e.bottom-f)/(h-f),i=e.bottom):r&l?(i=f+(h-f)*(e.right-a)/(c-a),n=e.right):r&o&&(i=f+(h-f)*(e.left-a)/(c-a),n=e.left),r===x?x=d(a=n,f=i,e):y=d(c=n,h=i,e);return{x0:a,x1:c,y0:f,y1:h}}(a,e.area)),"start"===i?(r=a.x0,n=a.y0):"end"===i?(r=a.x1,n=a.y1):(r=(a.x0+a.x1)/2,n=(a.y0+a.y1)/2),function(t,e,r,n,i){switch(i){case"center":r=n=0;break;case"bottom":r=0,n=1;break;case"right":r=1,n=0;break;case"left":r=-1,n=0;break;case"top":r=0,n=-1;break;case"start":r=-r,n=-n;break;case"end":break;default:i*=Math.PI/180,r=Math.cos(i),n=Math.sin(i)}return{x:t,y:e,vx:r,vy:n}}(r,n,t.vx,t.vy,e.align)}var c={arc:function(t,e){var r=(t.startAngle+t.endAngle)/2,n=Math.cos(r),i=Math.sin(r),a=t.innerRadius,o=t.outerRadius;return f({x0:t.x+n*a,y0:t.y+i*a,x1:t.x+n*o,y1:t.y+i*o,vx:n,vy:i},e)},point:function(t,e){var r=i(t,e.origin),n=r.x*t.radius,a=r.y*t.radius;return f({x0:t.x-n,y0:t.y-a,x1:t.x+n,y1:t.y+a,vx:r.x,vy:r.y},e)},rect:function(t,e){var r=i(t,e.origin),n=t.x,a=t.y,o=0,l=0;return t.horizontal?(n=Math.min(t.x,t.base),o=Math.abs(t.base-t.x)):(a=Math.min(t.y,t.base),l=Math.abs(t.base-t.y)),f({x0:n,y0:a+l,x1:n+o,y1:a,vx:r.x,vy:r.y},e)},fallback:function(t,e){var r=i(t,e.origin);return f({x0:t.x,y0:t.y,x1:t.x,y1:t.y,vx:r.x,vy:r.y},e)}},h=t.helpers,x=n.rasterize;function y(t){var e=t._model.horizontal,r=t._scale||e&&t._xScale||t._yScale;if(!r)return null;if(void 0!==r.xCenter&&void 0!==r.yCenter)return{x:r.xCenter,y:r.yCenter};var n=r.getBasePixel();return e?{x:n,y:null}:{x:null,y:n}}function v(t,e,r){var n=t.shadowBlur,i=r.stroked,a=x(r.x),o=x(r.y),l=x(r.w);i&&t.strokeText(e,a,o,l),r.filled&&(n&&i&&(t.shadowBlur=0),t.fillText(e,a,o,l),n&&i&&(t.shadowBlur=n))}var _=function(t,e,r,n){var i=this;i._config=t,i._index=n,i._model=null,i._rects=null,i._ctx=e,i._el=r};h.extend(_.prototype,{_modelize:function(e,r,i,a){var o,l=this._index,s=h.options.resolve,u=n.parseFont(s([i.font,{}],a,l)),d=s([i.color,t.defaults.global.defaultFontColor],a,l);return{align:s([i.align,"center"],a,l),anchor:s([i.anchor,"center"],a,l),area:a.chart.chartArea,backgroundColor:s([i.backgroundColor,null],a,l),borderColor:s([i.borderColor,null],a,l),borderRadius:s([i.borderRadius,0],a,l),borderWidth:s([i.borderWidth,0],a,l),clamp:s([i.clamp,!1],a,l),clip:s([i.clip,!1],a,l),color:d,display:e,font:u,lines:r,offset:s([i.offset,0],a,l),opacity:s([i.opacity,1],a,l),origin:y(this._el),padding:h.options.toPadding(s([i.padding,0],a,l)),positioner:(o=this._el,o instanceof t.elements.Arc?c.arc:o instanceof t.elements.Point?c.point:o instanceof t.elements.Rectangle?c.rect:c.fallback),rotation:s([i.rotation,0],a,l)*(Math.PI/180),size:n.textSize(this._ctx,r,u),textAlign:s([i.textAlign,"start"],a,l),textShadowBlur:s([i.textShadowBlur,0],a,l),textShadowColor:s([i.textShadowColor,d],a,l),textStrokeColor:s([i.textStrokeColor,d],a,l),textStrokeWidth:s([i.textStrokeWidth,0],a,l)}},update:function(t){var e,r,i,a=this,o=null,l=null,s=a._index,u=a._config,d=h.options.resolve([u.display,!0],t,s);d&&(e=t.dataset.data[s],r=h.valueOrDefault(h.callback(u.formatter,[e,t]),e),(i=h.isNullOrUndef(r)?[]:n.toTextLines(r)).length&&(l=function(t){var e=t.borderWidth||0,r=t.padding,n=t.size.height,i=t.size.width,a=-i/2,o=-n/2;return{frame:{x:a-r.left-e,y:o-r.top-e,w:i+r.width+2*e,h:n+r.height+2*e},text:{x:a,y:o,w:i,h:n}}}(o=a._modelize(d,i,u,t)))),a._model=o,a._rects=l},geometry:function(){return this._rects?this._rects.frame:{}},rotation:function(){return this._model?this._model.rotation:0},visible:function(){return this._model&&this._model.opacity},model:function(){return this._model},draw:function(t,e){var r,i=t.ctx,a=this._model,o=this._rects;this.visible()&&(i.save(),a.clip&&(r=a.area,i.beginPath(),i.rect(r.left,r.top,r.right-r.left,r.bottom-r.top),i.clip()),i.globalAlpha=n.bound(0,a.opacity,1),i.translate(x(e.x),x(e.y)),i.rotate(a.rotation),function(t,e,r){var n=r.backgroundColor,i=r.borderColor,a=r.borderWidth;(n||i&&a)&&(t.beginPath(),h.canvas.roundedRect(t,x(e.x)+a/2,x(e.y)+a/2,x(e.w)-a,x(e.h)-a,r.borderRadius),t.closePath(),n&&(t.fillStyle=n,t.fill()),i&&a&&(t.strokeStyle=i,t.lineWidth=a,t.lineJoin="miter",t.stroke()))}(i,o.frame,a),function(t,e,r,n){var i,a=n.textAlign,o=n.color,l=!!o,s=n.font,u=e.length,d=n.textStrokeColor,f=n.textStrokeWidth,c=d&&f;if(u&&(l||c))for(r=function(t,e,r){var n=r.lineHeight,i=t.w,a=t.x;return"center"===e?a+=i/2:"end"!==e&&"right"!==e||(a+=i),{h:n,w:i,x:a,y:t.y+n/2}}(r,a,s),t.font=s.string,t.textAlign=a,t.textBaseline="middle",t.shadowBlur=n.textShadowBlur,t.shadowColor=n.textShadowColor,l&&(t.fillStyle=o),c&&(t.lineJoin="round",t.lineWidth=f,t.strokeStyle=d),i=0,u=e.length;i<u;++i)v(t,e[i],{stroked:c,filled:l,w:r.w,x:r.x,y:r.y+r.h*i})}(i,a.lines,o.text,a),i.restore())}});var b=t.helpers,p=Number.MIN_SAFE_INTEGER||-9007199254740991,g=Number.MAX_SAFE_INTEGER||9007199254740991;function m(t,e,r){var n=Math.cos(r),i=Math.sin(r),a=e.x,o=e.y;return{x:a+n*(t.x-a)-i*(t.y-o),y:o+i*(t.x-a)+n*(t.y-o)}}function w(t,e){var r,n,i,a,o,l=g,s=p,u=e.origin;for(r=0;r<t.length;++r)i=(n=t[r]).x-u.x,a=n.y-u.y,o=e.vx*i+e.vy*a,l=Math.min(l,o),s=Math.max(s,o);return{min:l,max:s}}function k(t,e){var r=e.x-t.x,n=e.y-t.y,i=Math.sqrt(r*r+n*n);return{vx:(e.x-t.x)/i,vy:(e.y-t.y)/i,origin:t,ln:i}}var M=function(){this._rotation=0,this._rect={x:0,y:0,w:0,h:0}};function S(t,e,r){var n=e.positioner(t,e),i=n.vx,a=n.vy;if(!i&&!a)return{x:n.x,y:n.y};var o=r.w,l=r.h,s=e.rotation,u=Math.abs(o/2*Math.cos(s))+Math.abs(l/2*Math.sin(s)),d=Math.abs(o/2*Math.sin(s))+Math.abs(l/2*Math.cos(s)),f=1/Math.max(Math.abs(i),Math.abs(a));return u*=i*f,d*=a*f,u+=e.offset*i,d+=e.offset*a,{x:n.x+u,y:n.y+d}}b.extend(M.prototype,{center:function(){var t=this._rect;return{x:t.x+t.w/2,y:t.y+t.h/2}},update:function(t,e,r){this._rotation=r,this._rect={x:e.x+t.x,y:e.y+t.y,w:e.w,h:e.h}},contains:function(t){var e=this._rect;return!((t=m(t,this.center(),-this._rotation)).x<e.x-1||t.y<e.y-1||t.x>e.x+e.w+2||t.y>e.y+e.h+2)},intersects:function(t){var e,r,n,i=this._points(),a=t._points(),o=[k(i[0],i[1]),k(i[0],i[3])];for(this._rotation!==t._rotation&&o.push(k(a[0],a[1]),k(a[0],a[3])),e=0;e<o.length;++e)if(r=w(i,o[e]),n=w(a,o[e]),r.max<n.min||n.max<r.min)return!1;return!0},_points:function(){var t=this._rect,e=this._rotation,r=this.center();return[m({x:t.x,y:t.y},r,e),m({x:t.x+t.w,y:t.y},r,e),m({x:t.x+t.w,y:t.y+t.h},r,e),m({x:t.x,y:t.y+t.h},r,e)]}});var C={prepare:function(t){var e,r,n,i,a,o=[];for(e=0,n=t.length;e<n;++e)for(r=0,i=t[e].length;r<i;++r)a=t[e][r],o.push(a),a.$layout={_box:new M,_hidable:!1,_visible:!0,_set:e,_idx:r};return o.sort(function(t,e){var r=t.$layout,n=e.$layout;return r._idx===n._idx?r._set-n._set:n._idx-r._idx}),this.update(o),o},update:function(t){var e,r,n,i,a,o=!1;for(e=0,r=t.length;e<r;++e)i=(n=t[e]).model(),(a=n.$layout)._hidable=i&&"auto"===i.display,a._visible=n.visible(),o|=a._hidable;o&&function(t){var e,r,n,i,a,o;for(e=0,r=t.length;e<r;++e)(i=(n=t[e]).$layout)._visible&&(a=n.geometry(),o=S(n._el._model,n.model(),a),i._box.update(o,a,n.rotation()));(function(t,e){var r,n,i,a;for(r=t.length-1;r>=0;--r)for(i=t[r].$layout,n=r-1;n>=0&&i._visible;--n)(a=t[n].$layout)._visible&&i._box.intersects(a._box)&&e(i,a)})(t,function(t,e){var r=t._hidable,n=e._hidable;r&&n||n?e._visible=!1:r&&(t._visible=!1)})}(t)},lookup:function(t,e){var r,n;for(r=t.length-1;r>=0;--r)if((n=t[r].$layout)&&n._visible&&n._box.contains(e))return{dataset:n._set,label:t[r]};return null},draw:function(t,e){var r,n,i,a,o,l;for(r=0,n=e.length;r<n;++r)(a=(i=e[r]).$layout)._visible&&(o=i.geometry(),l=S(i._el._view,i.model(),o),a._box.update(l,o,i.rotation()),i.draw(t,l))}},z=t.helpers,A={align:"center",anchor:"center",backgroundColor:null,borderColor:null,borderRadius:0,borderWidth:0,clamp:!1,clip:!1,color:void 0,display:!0,font:{family:void 0,lineHeight:1.2,size:void 0,style:void 0,weight:null},formatter:function(t){if(z.isNullOrUndef(t))return null;var e,r,n,i=t;if(z.isObject(t))if(z.isNullOrUndef(t.label))if(z.isNullOrUndef(t.r))for(i="",n=0,r=(e=Object.keys(t)).length;n<r;++n)i+=(0!==n?", ":"")+e[n]+": "+t[e[n]];else i=t.r;else i=t.label;return""+i},listeners:{},offset:4,opacity:1,padding:{top:4,right:4,bottom:4,left:4},rotation:0,textAlign:"start",textStrokeColor:void 0,textStrokeWidth:0,textShadowBlur:0,textShadowColor:void 0},O=t.helpers,D="$datalabels";function $(t,e,r){var n=e&&e[r.dataset];if(n){var i=r.label,a=i.$context;!0===O.callback(n,[a])&&(t[D]._dirty=!0,i.update(a))}}function P(t,e){var r,n,i=t[D],a=i._listeners;if(a.enter||a.leave){if("mousemove"===e.type)n=C.lookup(i._labels,e);else if("mouseout"!==e.type)return;r=i._hovered,i._hovered=n,function(t,e,r,n){var i,a;(r||n)&&(r?n?r.label!==n.label&&(a=i=!0):a=!0:i=!0,a&&$(t,e.leave,r),i&&$(t,e.enter,n))}(t,a,r,n)}}t.defaults.global.plugins.datalabels=A;var N={id:"datalabels",beforeInit:function(t){t[D]={_actives:[]}},beforeUpdate:function(t){var e=t[D];e._listened=!1,e._listeners={},e._datasets=[],e._labels=[]},afterDatasetUpdate:function(t,e,r){var n,i,a,o=e.index,l=t[D],s=l._datasets[o]=[],u=t.isDatasetVisible(o),d=t.data.datasets[o],f=function(t,e){var r=t.datalabels;return!1===r?null:(!0===r&&(r={}),O.merge({},[e,r]))}(d,r),c=e.meta.data||[],h=c.length,x=t.ctx;for(x.save(),n=0;n<h;++n)i=c[n],u&&i&&!i.hidden&&!i._model.skip?(s.push(a=new _(f,x,i,n)),a.update(a.$context={active:!1,chart:t,dataIndex:n,dataset:d,datasetIndex:o})):a=null,i[D]=a;x.restore(),O.merge(l._listeners,f.listeners||{},{merger:function(t,r,n){r[t]=r[t]||{},r[t][e.index]=n[t],l._listened=!0}})},afterUpdate:function(t,e){t[D]._labels=C.prepare(t[D]._datasets,e)},afterDatasetsDraw:function(t){C.draw(t,t[D]._labels)},beforeEvent:function(t,e){if(t[D]._listened)switch(e.type){case"mousemove":case"mouseout":P(t,e);break;case"click":!function(t,e){var r=t[D],n=r._listeners.click,i=n&&C.lookup(r._labels,e);i&&$(t,n,i)}(t,e)}},afterEvent:function(e){var r,i,a,o,l=e[D],s=l._actives,u=l._actives=e.lastActive||[],d=n.arrayDiff(s,u);for(r=0,i=d.length;r<i;++r)(a=d[r])[1]&&(o=a[0][D])&&(o.$context.active=1===a[1],o.update(o.$context));(l._dirty||d.length)&&(C.update(l._labels),function(e){if(!e.animating){for(var r=t.animationService.animations,n=0,i=r.length;n<i;++n)if(r[n].chart===e)return;e.render({duration:1,lazy:!0})}}(e)),delete l._dirty}};return t.plugins.register(N),N}); PK �K}\T!p` ` front.pagination.jsnu �[��� // the semi-colon before function invocation is a safety net against concatenated // scripts and/or other plugins which may not be closed properly. ;// noinspection JSUnusedLocalSymbols (function ($, window, document, undefined) { "use strict"; // undefined is used here as the undefined global variable in ECMAScript 3 is // mutable (ie. it can be changed by someone else). undefined isn't really being // passed in so we can ensure the value of it is truly undefined. In ES5, undefined // can no longer be modified. // window and document are passed through as local variables rather than global // as this (slightly) quickens the resolution process and can be more efficiently // minified (especially when both are regularly referenced in your plugin). // Create the defaults once var pluginName = "forminatorFrontPagination", defaults = { totalSteps: 0, step: 0, hashStep: 0, inline_validation: false }; // The actual plugin constructor function ForminatorFrontPagination(element, options) { this.element = $(element); this.$el = this.element; this.totalSteps = 0; this.step = 0; this.finished = false; this.hashStep = false; this.next_button_txt = ''; this.prev_button_txt = ''; this.custom_label = []; this.form_id = 0; this.element = ''; // jQuery has an extend method which merges the contents of two or // more objects, storing the result in the first object. The first object // is generally empty as we don't want to alter the default options for // future instances of the plugin this.settings = $.extend({}, defaults, options); this._defaults = defaults; this._name = pluginName; this.init(); } // Avoid Plugin.prototype conflicts $.extend(ForminatorFrontPagination.prototype, { init: function () { var self = this; var draftPage = !! this.$el.data( 'draft-page' ) ? this.$el.data( 'draft-page' ) : 0; this.next_button = this.settings.next_button ? this.settings.next_button : window.ForminatorFront.cform.pagination_next; this.prev_button = this.settings.prev_button ? this.settings.prev_button : window.ForminatorFront.cform.pagination_prev; if (this.$el.find('input[name=form_id]').length > 0) { this.form_id = this.$el.find('input[name=form_id]').val(); } this.totalSteps = this.settings.totalSteps; this.step = this.settings.step; this.quiz = this.settings.quiz; this.element = this.$el.find('[data-step=' + this.step + ']').data('name'); if (this.form_id && typeof window.Forminator_Cform_Paginations === 'object' && typeof window.Forminator_Cform_Paginations[this.form_id] === 'object') { this.custom_label = window.Forminator_Cform_Paginations[this.form_id]; } if ( draftPage > 0 ) { this.go_to( draftPage, true ); } else if (this.settings.hashStep && this.step > 0) { this.go_to(this.step, true); } else if ( this.quiz ) { this.go_to(0, true); } else { this.go_to(0, false); } this.render_navigation(); this.render_bar_navigation(); this.render_footer_navigation( this.form_id ); this.init_events(); this.update_navigation(); this.$el.find('.forminator-button.forminator-button-back, .forminator-button.forminator-button-next, .forminator-button.forminator-button-submit').on("click", function (e) { e.preventDefault(); $(this).trigger('forminator.front.pagination.move'); self.resetRichTextEditorHeight(); }); this.$el.on('click', '.forminator-result--view-answers', function(e){ e.preventDefault(); $(this).trigger('forminator.front.pagination.move'); }); this.update_buttons(); }, init_events: function () { var self = this; this.$el.find('.forminator-button-back').on('forminator.front.pagination.move',function (e) { self.handle_click('prev'); }); this.$el.on('forminator.front.pagination.move', '.forminator-result--view-answers', function (e) { self.handle_click('prev'); }); this.$el.find('.forminator-button-next').on('forminator.front.pagination.move', function (e) { self.handle_click('next'); }); this.$el.find('.forminator-step').on("click", function (e) { e.preventDefault(); var step = $(this).data('nav'); self.handle_step(step); }); this.$el.on('reset', function (e) { self.on_form_reset(e); }); this.$el.on('forminator:quiz:submit:success', function (e, ajaxData, formData, resultText) { if ( resultText ) { self.move_to_results(e); } }); this.$el.on('forminator.front.pagination.focus.input', function (e, input) { self.on_focus_input(e, input); }); }, /** * Move quiz to rezult page */ move_to_results: function (e) { this.finished = true; if ( this.$el.find('.forminator-submit-rightaway').length ) { this.$el.find('#forminator-submit').removeClass('forminator-hidden'); } else { this.handle_click('next'); } }, /** * On reset event of Form * * @since 1.0.3 * * @param e */ on_form_reset: function (e) { // Trigger pagination to first page this.go_to(0, true); this.update_buttons(); }, /** * On Input focused * * @param e * @param input */ on_focus_input: function (e, input) { //Go to page where element exist var step = this.get_page_of_input(input); this.go_to(step, true); this.update_buttons(); }, render_footer_navigation: function( form_id ) { var footer_html = '', paypal_field = '', footer_align = ( this.custom_label['has-paypal'] === true ) ? ' style="align-items: flex-start;"' : '', save_draft_btn = this.$el.find( '.forminator-save-draft-link' ).length ? this.$el.find( '.forminator-save-draft-link' ) : '' ; if ( this.custom_label[ this.element ] && this.custom_label[ 'pagination-labels' ] === 'custom' ){ this.prev_button_txt = this.custom_label[ this.element ][ 'prev-text' ] !== '' ? this.custom_label[ this.element ][ 'prev-text' ] : this.prev_button; this.next_button_txt = this.custom_label[ this.element ][ 'next-text' ] !== '' ? this.custom_label[ this.element ][ 'next-text' ] : this.next_button; } else { this.prev_button_txt = this.prev_button; this.next_button_txt = this.next_button; } if ( this.$el.hasClass('forminator-design--material') ) { footer_html = '<div class="forminator-pagination-footer"' + footer_align + '>' + '<button class="forminator-button forminator-button-back"><span class="forminator-button--mask" aria-label="hidden"></span><span class="forminator-button--text">' + this.prev_button_txt + '</span></button>' + '<button class="forminator-button forminator-button-next"><span class="forminator-button--mask" aria-label="hidden"></span><span class="forminator-button--text">' + this.next_button_txt + '</span></button>'; if( this.custom_label[ 'has-paypal' ] === true ) { paypal_field = ( this.custom_label['paypal-id'] ) ? this.custom_label['paypal-id'] : ''; footer_html += '<div class="forminator-payment forminator-button-paypal forminator-hidden ' + paypal_field + '-payment" id="paypal-button-container-' + form_id + '">'; } footer_html += '</div>'; this.$el.append( footer_html ); } else { footer_html = '<div class="forminator-pagination-footer"' + footer_align + '>' + '<button class="forminator-button forminator-button-back">' + this.prev_button_txt + '</button>' + '<button class="forminator-button forminator-button-next">' + this.next_button_txt + '</button>'; if( this.custom_label['has-paypal'] === true ) { paypal_field = ( this.custom_label['paypal-id'] ) ? this.custom_label['paypal-id'] : ''; footer_html += '<div class="forminator-payment forminator-button-paypal forminator-hidden ' + paypal_field + '-payment" id="paypal-button-container-' + form_id + '">'; } footer_html += '</div>'; this.$el.append( footer_html ); } if ( '' !== save_draft_btn ) { save_draft_btn.insertBefore( this.$el.find( '.forminator-button-next' ) ); } }, render_bar_navigation: function () { var $navigation = this.$el.find( '.forminator-pagination-progress' ); var $progressLabel = '<div class="forminator-progress-label">0%</div>', $progressBar = '<div class="forminator-progress-bar"><span style="width: 0%"></span></div>' ; if ( ! $navigation.length ) return; $navigation.html( $progressLabel + $progressBar ); this.calculate_bar_percentage(); }, calculate_bar_percentage: function () { var total = this.totalSteps, current = this.step + 1, $progress = this.$el ; if ( ! $progress.length ) return; var percentage = Math.round( (current / total) * 100 ); $progress.find( '.forminator-progress-label' ).html( percentage + '%' ); $progress.find( '.forminator-progress-bar span' ).css( 'width', percentage + '%' ); }, encodeHTMLEntities( value ) { const textArea = document.createElement( 'textarea' ); textArea.innerText = value; return textArea.innerHTML; }, render_navigation: function () { var $navigation = this.$el.find('.forminator-pagination-steps'); var finalSteps = this.$el.find('.forminator-pagination-start'); if ( ! $navigation.length ) return; const render = $( this.$el ).data( 'forminator-render' ) || ''; var steps = this.$el.find( '.forminator-pagination' ).not( '.forminator-pagination-start' ); var basicDesign = this.$el.hasClass('forminator-design--basic'); $navigation.append( '<div class="forminator-break"></div>' ); var self = this; steps.each( function() { var $step = $( this ), $stepLabel = self.encodeHTMLEntities( $step.data( 'label' ) ), $stepNumb = $step.data('step') - 1, $stepControl = 'forminator-custom-form-' + self.form_id + '-' + render + '--page-' + $stepNumb, $stepId = $stepControl + '-label' ; var $stepClass = 'forminator-step forminator-step-' + $stepNumb; if ( basicDesign ) { $stepClass += ' has-text-color'; } var $stepMarkup = '<button role="tab" id="' + $stepId + '" class="' + $stepClass + '" aria-selected="false" aria-controls="' + $stepControl + '" data-nav="' + $stepNumb + '">' + '<span class="forminator-step-label">' + $stepLabel + '</span>' + '<span class="forminator-step-dot" aria-hidden="true"></span>' + '</button>'; var $stepBreak = '<div class="forminator-break" aria-hidden="true"></div>'; $navigation.append( $stepMarkup + $stepBreak ); }); finalSteps.each(function () { var $step = $(this), label = self.encodeHTMLEntities( $step.data( 'label' ) ), numb = steps.length, control = 'forminator-custom-form-' + self.form_id + '--page-' + numb, stepid = control + '-label' ; var $stepClass = 'forminator-step forminator-step-' + numb if ( basicDesign ) { $stepClass += ' has-text-color'; } var $stepMarkup = '<button role="tab" id="' + stepid + '" class="' + $stepClass + '" data-nav="' + numb + '" aria-selected="false" aria-controls="' + control + '">' + '<span class="forminator-step-label">' + label + '</span>' + '<span class="forminator-step-dot" aria-hidden="true"></span>' + '</button>'; var $stepBreak = '<div class="forminator-break" aria-hidden="true"></div>'; $navigation.append( $stepMarkup + $stepBreak ); }); }, /** * Handle step click * * @param step */ handle_step: function( step ) { if ( this.settings.inline_validation ) { for ( var i = 0; i < step; i++ ) { if ( this.step <= i ) { if ( ! this.is_step_inputs_valid( i ) ) { this.go_to( i, true ); return; } } } } this.go_to( step, true ); this.update_buttons(); }, handle_click: function (type) { var self = this; if (type === "prev" && this.step !== 0) { this.go_to(this.step - 1, true); this.update_buttons(); } else if (type === "next") { //do validation before next if inline validation enabled if (this.settings.inline_validation) { if ( ! this.is_step_inputs_valid( this.step ) ) { return; } } if(typeof this.$el.data().forminatorFrontPayment !== "undefined") { var payment = this.$el.data().forminatorFrontPayment, page = this.$el.find('[data-step=' + this.step + ']'), hasStripe = page.find(".forminator-stripe-element").not(".forminator-hidden .forminator-stripe-element") ; // Check if Stripe exists on current step if (hasStripe.length > 0) { payment._stripe.createToken(payment._cardElement).then(function (result) { if (result.error) { payment.showCardError(result.error.message, true); } else { payment.hideCardError(); self.go_to(self.step + 1, true); self.update_buttons(); } }); } else { this.go_to(this.step + 1, true); this.update_buttons(); } } else { this.go_to(this.step + 1, true); this.update_buttons(); } } // re-init textarea floating labels. var form = $( this.$el ); var textarea = form.find( '.forminator-textarea' ); var isMaterial = form.hasClass( 'forminator-design--material' ); if ( isMaterial ) { if ( textarea.length ) { textarea.each( function() { FUI.textareaMaterial( this ); }); } } }, /** * Check current inputs on step is in valid state */ is_step_inputs_valid: function ( step ) { var valid = true, errors = 0, validator = this.$el.data('validator'), page = this.$el.find('[data-step=' + step + ']'); //inline validation disabled if (typeof validator === 'undefined') { return true; } //get fields on current page page.find("input, select, textarea") .not(":submit, :reset, :image, :disabled") .not('[gramm="true"]') .each(function (key, element) { if ( $( element ).is( ':hidden:not(.forminator-wp-editor-required, .forminator-input-file-required, input[name$="_data"])' ) && ! $( element ).closest( '.forminator-pagination' ) .length ) { return; } valid = validator.element(element); if (!valid) { if (errors === 0) { // focus on first error element.focus(); } errors++; } }); return errors === 0; }, /** * Get page on the input * * @since 1.0.3 * * @param input * @returns {number|*} */ get_page_of_input: function(input) { var step_page = this.step; var page = $(input).closest('.forminator-pagination'); if (page.length > 0) { var step = $(page).data('step'); if (typeof step !== 'undefined') { step_page = +step; } } return step_page; }, update_buttons: function () { var hasDraft = this.$el.hasClass( 'draft-enabled' ), self = this; if (this.step === 0) { if ( ! hasDraft ) { this.$el.find('.forminator-button-back').closest( '.forminator-pagination-footer' ).css({ 'justify-content': 'flex-end' }); } this.$el.find('.forminator-button-back').addClass( 'forminator-hidden' ); this.$el.find('.forminator-button-next').removeClass('forminator-hidden'); } else { if ( this.totalSteps > 1 ) { if ( ! hasDraft ) { this.$el.find('.forminator-button-back').closest( '.forminator-pagination-footer' ).css({ 'justify-content': 'space-between' }); } this.$el.find('.forminator-button-back, .forminator-button-next').removeClass('forminator-hidden'); } } if (this.step === this.totalSteps && ! this.finished ) { //keep pagination content on last step before submit this.step--; this.$el.trigger( 'submit' ); } var submitButtonClass = this.settings.submitButtonClass; if ( this.step === ( this.totalSteps - 1 ) && ! this.finished ) { var submit_button_text = this.$el.find('.forminator-pagination-submit').html(), loadingText = this.$el.find('.forminator-pagination-submit').data('loading'), last_button_txt = ( this.custom_label[ 'pagination-labels' ] === 'custom' && this.custom_label['last-previous'] !== '' ) ? this.custom_label['last-previous'] : this.prev_button, forminatorPayment = self.$el.find('.forminator-payment'), nextBtn = this.$el.find('.forminator-button-next'), submitButton = this.$el.find( '.forminator-button-submit' ); if ( this.$el.hasClass('forminator-design--material') ) { this.$el.find('.forminator-button-back .forminator-button--text').html( last_button_txt ); nextBtn.removeClass('forminator-button-next').attr('id', 'forminator-submit'); setTimeout( function() { nextBtn .addClass('forminator-button-submit ' + submitButtonClass ) .find('.forminator-button--text') .html('') .html(submit_button_text).data('loading', loadingText); self.$el.trigger( 'forminator.front.pagination.buttons.updated' ); }, 20 ); } else { this.$el.find('.forminator-button-back').html( last_button_txt ); nextBtn.removeClass( 'forminator-button-next' ).attr( 'id', 'forminator-submit' ); setTimeout( function() { nextBtn .addClass( 'forminator-button-submit ' + submitButtonClass ) .html( submit_button_text ).data('loading', loadingText); self.$el.trigger( 'forminator.front.pagination.buttons.updated' ); }, 20 ); } // Redeclare submit button. setTimeout( function() { submitButton = self.$el.find( '.forminator-button-submit' ); }, 30 ); if ( this.$el.hasClass('forminator-quiz') && ! submit_button_text ) { submitButton.addClass('forminator-hidden'); if ( this.$el.find( '.forminator-submit-rightaway').length ) { submitButton.html( window.ForminatorFront.quiz.view_results ); } } if( this.custom_label['has-paypal'] === true ) { forminatorPayment.attr('id', 'forminator-paypal-submit'); setTimeout( function() { if ( ! window.paypalHasCondition.includes( self.$el.data( 'form-id' ) ) ) { submitButton.addClass('forminator-hidden'); forminatorPayment.removeClass( 'forminator-hidden' ); } }, 40 ); } if ( forminatorPayment.find('iframe').length > 0 ) { forminatorPayment.find('iframe').width('100%'); } } else { this.element = this.$el.find('.forminator-pagination[data-step=' + this.step + ']').data('name'); if ( this.custom_label[this.element] && this.custom_label['pagination-labels'] === 'custom'){ this.prev_button_txt = this.custom_label[this.element]['prev-text'] !== '' ? this.custom_label[this.element]['prev-text'] : this.prev_button; this.next_button_txt = this.custom_label[this.element]['next-text'] !== '' ? this.custom_label[this.element]['next-text'] : this.next_button; }else{ this.prev_button_txt = this.prev_button; this.next_button_txt = this.next_button; } if ( this.step === ( this.totalSteps - 1 ) && this.finished ) { this.next_button_txt = window.ForminatorFront.quiz.view_results; } if ( this.$el.hasClass('forminator-design--material') ) { this.$el.find( '#forminator-submit' ) .removeAttr( 'id' ) .removeClass( 'forminator-button-submit forminator-hidden ' + submitButtonClass ) .addClass( 'forminator-button-next' ); if( this.custom_label['has-paypal'] === true ) { this.$el.find( '#forminator-paypal-submit' ).removeAttr( 'id' ).addClass('forminator-hidden'); this.$el.find( '.forminator-button-next' ).removeClass( 'forminator-button-submit forminator-hidden ' + submitButtonClass ); } this.$el.find( '.forminator-button-back .forminator-button--text' ).html( this.prev_button_txt ); this.$el.find( '.forminator-button-next .forminator-button--text' ).html( this.next_button_txt ); } else { this.$el.find( '#forminator-submit' ) .removeAttr( 'id' ) .removeClass( 'forminator-button-submit forminator-hidden' ) .addClass( 'forminator-button-next' ); if( this.custom_label['has-paypal'] === true ) { this.$el.find( '#forminator-paypal-submit' ).removeAttr( 'id' ).addClass('forminator-hidden'); this.$el.find('.forminator-button-next').removeClass( 'forminator-button-submit forminator-hidden' ); } this.$el.find( '.forminator-button-back' ).html( this.prev_button_txt ); this.$el.find( '.forminator-button-next' ).html( this.next_button_txt ); } if ( this.step === this.totalSteps && this.finished ) { this.$el.find('.forminator-button-next, .forminator-button-back').addClass( 'forminator-hidden' ); } this.$el.trigger( 'forminator.front.pagination.buttons.updated' ); } // Reset the conditions to check if submit/paypal buttons should be visible this.$el.trigger( 'forminator.front.condition.restart' ); }, go_to: function (step, scrollToTop) { this.step = step; if (step === this.totalSteps && ! this.finished ) return false; // Hide all parts this.$el.find('.forminator-pagination').css({ 'height': '0', 'opacity': '0', 'visibility': 'hidden' }).attr( 'aria-hidden', 'true' ).attr( 'hidden', true ); this.$el.find('.forminator-pagination .forminator-pagination--content').hide(); // Show desired page this.$el.find('[data-step=' + step + ']').css({ 'height': 'auto', 'opacity': '1', 'visibility': 'visible' }).removeAttr( 'aria-hidden' ).removeAttr( 'hidden' ); this.$el.find('[data-step=' + step + '] .forminator-pagination--content').show(); //exec responsive captcha var forminatorFront = this.$el.data('forminatorFront'); if (typeof forminatorFront !== 'undefined') { forminatorFront.responsive_captcha(); } this.update_navigation(); if (scrollToTop) { this.scroll_to_top_form(); } }, update_navigation: function () { // Update navigation this.$el.find( '.forminator-current' ).attr( 'aria-selected', 'false' ); this.$el.find( '.forminator-current' ).removeClass('forminator-current' ); this.$el.find( '.forminator-step-' + this.step ).attr( 'aria-selected', 'true' ); this.$el.find( '.forminator-step-' + this.step ).addClass( 'forminator-current' ); this.$el.find( '.forminator-pagination:not(:hidden)' ).find( '.forminator-answer input' ).first().trigger( 'change' ); this.calculate_bar_percentage(); }, /** * Reset vertical screen position between sections * https://app.asana.com/0/385581670491499/784073712068017/f * Support Hustle Modal */ scroll_to_top_form: function () { var self = this; var $element = this.$el; // find first input row var first_input_row = this.$el.find('.forminator-row').not(':hidden').first(); if (first_input_row.length) { $element = first_input_row; } if ($element.length) { var parent_selector = 'html,body'; // check inside sui modal if (this.$el.closest('.sui-dialog').length > 0) { parent_selector = '.sui-dialog'; } // check inside hustle modal (prioritize) if (this.$el.closest('.wph-modal').length > 0) { parent_selector = '.wph-modal'; } $element.focus(); const minScrollHeight = $( window ).height() / 2; let scrollTop = $element.offset().top - Math.max( minScrollHeight, $( window ).height() - $element.outerHeight( true ) ) / 2; if ( this.quiz ) { scrollTop = $element.offset().top; if ( $( '#wpadminbar' ).length ) { scrollTop -= 35; } } $(parent_selector).animate({scrollTop: scrollTop}, 500, function () { if (!$element.attr("tabindex")) { $element.attr("tabindex", -1); } }); } }, resetRichTextEditorHeight: function () { if ( typeof tinyMCE !== 'undefined' ) { var form = this.$el, textarea = form.find( '.forminator-textarea' ); textarea.each( function() { var tmceId = $( this ).attr( 'id' ); if ( 0 !== form.find( '#'+ tmceId + '_ifr' ).length && form.find( '#'+ tmceId + '_ifr' ).is( ':visible' ) ) { form.find( '#' + tmceId + '_ifr' ).height( $( this ).height() ); } }); } }, }); // A really lightweight plugin wrapper around the constructor, // preventing against multiple instantiations $.fn[pluginName] = function (options) { return this.each(function () { if (!$.data(this, pluginName)) { $.data(this, pluginName, new ForminatorFrontPagination(this, options)); } }); }; })(jQuery, window, document); PK �K}\ن���a �a front.validate.jsnu �[��� // the semi-colon before function invocation is a safety net against concatenated // scripts and/or other plugins which may not be closed properly. ;// noinspection JSUnusedLocalSymbols (function ($, window, document, undefined) { "use strict"; // undefined is used here as the undefined global variable in ECMAScript 3 is // mutable (ie. it can be changed by someone else). undefined isn't really being // passed in so we can ensure the value of it is truly undefined. In ES5, undefined // can no longer be modified. // window and document are passed through as local variables rather than global // as this (slightly) quickens the resolution process and can be more efficiently // minified (especially when both are regularly referenced in your plugin). // Create the defaults once var pluginName = "forminatorFrontValidate", ownMethods = {}, defaults = { rules: {}, messages: {} }; // The actual plugin constructor function ForminatorFrontValidate(element, options) { this.element = element; this.$el = $(this.element); // jQuery has an extend method which merges the contents of two or // more objects, storing the result in the first object. The first object // is generally empty as we don't want to alter the default options for // future instances of the plugin this.settings = $.extend({}, defaults, options); this._defaults = defaults; this._name = pluginName; this.init(); } // Avoid Plugin.prototype conflicts $.extend( ForminatorFrontValidate.prototype, { init: function () { $( '.forminator-select2' ).on('change', this.element, function (e, param1) { if ( 'forminator_emulate_trigger' !== param1 ) { $( this ).trigger('focusout'); } }); var self = this; var submitted = false; var $form = this.$el; var rules = self.settings.rules; var messages = self.settings.messages; // Duplicate rules for new repeated Group fields. if ( $form.hasClass( 'forminator-grouped-fields' ) ) { let suffix = $form.data( 'suffix' ); $.each( rules, function ( key, val ) { // Separate keys with [] at the end. const newKey = key.replace( /(.+?)(\[\])?$/g, '$1' + '-' + suffix + '$2' ); if ( ! $form.find( '[name="' + newKey + '"]' ).length && ! $form.find( '#' + newKey.replace( '[]', '' ) ).length ) { return; } rules[ newKey ] = val; messages[ newKey ] = messages[ key ]; } ); $form = $form.closest( 'form.forminator-ui' ); } $form.data('validator', null).unbind('validate').validate({ ignore( index, element ) { const validationDisabled = $( '#forminator-field-disable_validations' ).is(':checked'); // Add support for hidden required fields (uploads, wp_editor) and for skipping pagination when required. return ( validationDisabled || ( $( element ).is( ':hidden:not(.do-validate)' ) && ! $( element ).closest( '.forminator-pagination' ).length ) || $( element ).closest( '.forminator-hidden' ).length ); }, errorPlacement: function (error, element) { $form.trigger('validation:error'); }, showErrors: function(errorMap, errorList) { if( submitted && errorList.length > 0 ) { $form.find( '.forminator-response-message' ).html( '<ul></ul>' ); jQuery.each( errorList, function( key, error ) { $form.find( '.forminator-response-message ul' ).append( '<li>' + error.message + '</li>' ); }); $form.find( '.forminator-response-message' ) .removeAttr( 'aria-hidden' ) .prop( 'tabindex', '-1' ) .addClass( 'forminator-accessible' ) ; } submitted = false; this.defaultShowErrors(); $form.trigger('validation:showError', errorList); }, invalidHandler: function(form, validator){ submitted = true; $form.trigger('validation:invalid'); }, onfocusout: function ( element ) { //datepicker will be validated when its closed if ( $( element ).hasClass('hasDatepicker') === false ) { $( element ).valid(); } //validate Confirm email. if ( $( element ).hasClass( 'forminator-email--field' ) ) { let name = $( element ).attr( 'name' ), confirmEmail = $( 'input[name="confirm_' + name + '"]' ); if ( confirmEmail.length && confirmEmail.val() ) { confirmEmail.valid(); } } $( element ).trigger('validation:focusout'); }, highlight: function (element, errorClass, message) { var holder = $( element ); var holderField = holder.closest( '.forminator-field' ); var holderDate = holder.closest( '.forminator-date-input' ); var holderTime = holder.closest( '.forminator-timepicker' ); var holderError = ''; var getColumn = false; var getError = false; var getDesc = false; var errorMessage = this.errorMap[element.name]; var errorId = holder.attr('id') + '-error'; var ariaDescribedby = holder.attr('aria-describedby'); var errorMarkup = '<span class="forminator-error-message" id="'+ errorId +'"></span>'; if ( holderDate.length > 0 ) { getColumn = holderDate.parent(); getError = getColumn.find( '.forminator-error-message[data-error-field="' + holder.data( 'field' ) + '"]' ); getDesc = getColumn.find( '.forminator-description' ); errorMarkup = '<span class="forminator-error-message" data-error-field="' + holder.data( 'field' ) + '" id="'+ errorId +'"></span>'; if ( 0 === getError.length ) { if ( 'day' === holder.data( 'field' ) ) { if ( getColumn.find( '.forminator-error-message[data-error-field="year"]' ).length ) { $( errorMarkup ).insertBefore( getColumn.find( '.forminator-error-message[data-error-field="year"]' ) ); } else { if ( 0 === getDesc.length ) { getColumn.append( errorMarkup ); } else { $( errorMarkup ).insertBefore( getDesc ); } } if ( 0 === holderField.find( '.forminator-error-message' ).length ) { holderField.append( '<span class="forminator-error-message" id="'+ errorId +'"></span>' ); } } if ( 'month' === holder.data( 'field' ) ) { if ( getColumn.find( '.forminator-error-message[data-error-field="day"]' ).length ) { $( errorMarkup ).insertBefore( getColumn.find( '.forminator-error-message[data-error-field="day"]' ) ); } else { if ( 0 === getDesc.length ) { getColumn.append( errorMarkup ); } else { $( errorMarkup ).insertBefore( getDesc ); } } if ( 0 === holderField.find( '.forminator-error-message' ).length ) { holderField.append( '<span class="forminator-error-message" id="'+ errorId +'"></span>' ); } } if ( 'year' === holder.data( 'field' ) ) { if ( 0 === getDesc.length ) { getColumn.append( errorMarkup ); } else { $( errorMarkup ).insertBefore( getDesc ); } if ( 0 === holderField.find( '.forminator-error-message' ).length ) { holderField.append( '<span class="forminator-error-message" id="'+ errorId +'"></span>' ); } } } holderError = getColumn.find( '.forminator-error-message[data-error-field="' + holder.data( 'field' ) + '"]' ); // Insert error message holderError.html( errorMessage ); holderField.find( '.forminator-error-message' ).html( errorMessage ); } else if ( holderTime.length > 0 ) { getColumn = holderTime.parent(); getError = getColumn.find( '.forminator-error-message[data-error-field="' + holder.data( 'field' ) + '"]' ); getDesc = getColumn.find( '.forminator-description' ); errorMarkup = '<span class="forminator-error-message" data-error-field="' + holder.data( 'field' ) + '" id="'+ errorId +'"></span>'; if ( 0 === getError.length ) { if ( 'hours' === holder.data( 'field' ) ) { if ( getColumn.find( '.forminator-error-message[data-error-field="minutes"]' ).length ) { $( errorMarkup ).insertBefore( getColumn.find( '.forminator-error-message[data-error-field="minutes"]' ) ); } else { if ( 0 === getDesc.length ) { getColumn.append( errorMarkup ); } else { $( errorMarkup ).insertBefore( getDesc ); } } if ( 0 === holderField.find( '.forminator-error-message' ).length ) { holderField.append( '<span class="forminator-error-message" id="'+ errorId +'"></span>' ); } } if ( 'minutes' === holder.data( 'field' ) ) { if ( 0 === getDesc.length ) { getColumn.append( errorMarkup ); } else { $( errorMarkup ).insertBefore( getDesc ); } if ( 0 === holderField.find( '.forminator-error-message' ).length ) { holderField.append( '<span class="forminator-error-message" id="'+ errorId +'"></span>' ); } } } holderError = getColumn.find( '.forminator-error-message[data-error-field="' + holder.data( 'field' ) + '"]' ); // Insert error message holderError.html( errorMessage ); holderField.find( '.forminator-error-message' ).html( errorMessage ); } else { var getError = holderField.find( '.forminator-error-message' ); var getDesc = holderField.find( '.forminator-description' ); if ( 0 === getError.length ) { if ( 0 === getDesc.length ) { holderField.append( errorMarkup ); } else { $( errorMarkup ).insertBefore( getDesc ); } } holderError = holderField.find( '.forminator-error-message' ); // Insert error message holderError.html( errorMessage ); } // Field aria describedby for screen readers if (ariaDescribedby) { var ids = ariaDescribedby.split(' '); var errorIdExists = ids.includes(errorId); if (!errorIdExists) { ids.push(errorId); } var updatedAriaDescribedby = ids.join(' '); holder.attr('aria-describedby', updatedAriaDescribedby); } else { holder.attr('aria-describedby', errorId); } // Field invalid status for screen readers holder.attr( 'aria-invalid', 'true' ); // Field error status holderField.addClass( 'forminator-has_error' ); holder.trigger('validation:highlight'); }, unhighlight: function (element, errorClass, validClass) { var holder = $( element ); var holderField = holder.closest( '.forminator-field' ); var holderTime = holder.closest( '.forminator-timepicker' ); var holderDate = holder.closest( '.forminator-date-input' ); var holderError = ''; var errorId = holder.attr('id') + '-error'; var ariaDescribedby = holder.attr('aria-describedby'); if ( holderDate.length > 0 ) { holderError = holderDate.parent().find( '.forminator-error-message[data-error-field="' + holder.data( 'field' ) + '"]' ); } else if ( holderTime.length > 0 ) { holderError = holderTime.parent().find( '.forminator-error-message[data-error-field="' + holder.data( 'field' ) + '"]' ); } else { holderError = holderField.find( '.forminator-error-message' ); } // Remove or Update describedby attribute for screen readers if (ariaDescribedby) { var ids = ariaDescribedby.split(' '); ids = ids.filter(function (id) { return id !== errorId; }); var updatedAriaDescribedby = ids.join(' '); holder.attr('aria-describedby', updatedAriaDescribedby); } else { holder.removeAttr('aria-describedby'); } // Remove invalid attribute for screen readers holder.removeAttr( 'aria-invalid' ); // Remove error message holderError.remove(); // Remove error class holderField.removeClass( 'forminator-has_error' ); holder.trigger('validation:unhighlight'); }, rules: rules, messages: messages }); $form.off('forminator.validate.signature').on('forminator.validate.signature', function () { var validator = $( this ).validate(); validator.element( $( this ).find( "input[id$='_data']" ) ); }); // Inline validation for upload field. $form.find( '.forminator-input-file, .forminator-input-file-required' ).on( 'change', function () { $( this ).trigger( 'focusout' ); }) // Trigger change for the hour field. $( '.time-minutes.has-time-limiter, .time-ampm.has-time-limiter' ).on( 'change', function () { var hourContainer = $( this ).closest( '.forminator-col' ).siblings( '.forminator-col' ).first(); hourContainer.find( '.time-hours' ).trigger( 'focusout' ); }); // Trigger change for the required checkbox field. $( '.forminator-field.required input[type="checkbox"]' ).on( 'input', function () { $( this ).not( ':checked' ).trigger( 'focusout' ); }); // Remove error messages after disabling validation. $(document).on('change', '#forminator-field-disable_validations', function () { const validationDisabled = $(this).is(':checked'); const validator = $form.data('validator'); if (validationDisabled && validator) { validator.resetForm(); // Manually call unhighlight to remove error messages. $form.find(':input').each(function () { validator.settings.unhighlight(this); }); } }); } }); // A really lightweight plugin wrapper around the constructor, // preventing against multiple instantiations $.fn[pluginName] = function (options) { // We need to restore our custom validation methods in case they were // lost or overwritten by another instantiation of the jquery.Validate plugin. $.each( ownMethods, function( key, method ) { if ( undefined === $.validator.methods[ key ] ) { $.validator.addMethod( key, method ); } else if ( key === 'number' ) { $.validator.methods.number = ownMethods.number; } }); return this.each(function () { if (!$.data(this, pluginName)) { $.data(this, pluginName, new ForminatorFrontValidate(this, options)); } }); }; $.validator.addMethod("validurl", function (value, element) { var url = $.validator.methods.url.bind(this); return url(value, element) || url('http://' + value, element); }); $.validator.addMethod("forminatorPhoneNational", function ( value, element ) { var iti = intlTelInput.getInstance( element ); var elem = $( element ); if ( !elem.data('required') && value === '+' +iti.getSelectedCountryData().dialCode ) { return true; } if ( 'undefined' !== typeof elem.data( 'country' ) && elem.data( 'country' ).toLowerCase() !== iti.getSelectedCountryData().iso2 ) { return false; } // Uses intlTelInput to check if the number is valid. return this.optional( element ) || iti.isValidNumberPrecise(); }); $.validator.addMethod("forminatorPhoneInternational", function (value, element) { const iti = intlTelInput.getInstance( element ); // check whether phone field is international and optional if ( !$(element).data('required') && value === '+' +iti.getSelectedCountryData().dialCode ) { return true; } // Uses intlTelInput to check if the number is valid. return this.optional(element) || iti.isValidNumberPrecise(); }); $.validator.addMethod("dateformat", function (value, element, param) { // dateITA method from jQuery Validator additional. Date method is deprecated and doesn't work for all formats var check = false, re = 'yy-mm-dd' === param || 'yy/mm/dd' === param || 'yy.mm.dd' === param ? /^\d{4}-\d{1,2}-\d{1,2}$/ : /^\d{1,2}-\d{1,2}-\d{4}$/, adata, gg, mm, aaaa, xdata; value = value.replace(/[ /.]/g, '-'); if (re.test(value)) { if ('dd/mm/yy' === param || 'dd-mm-yy' === param || 'dd.mm.yy' === param) { adata = value.split("-"); gg = parseInt(adata[0], 10); mm = parseInt(adata[1], 10); aaaa = parseInt(adata[2], 10); } else if ('mm/dd/yy' === param || 'mm.dd.yy' === param || 'mm-dd-yy' === param) { adata = value.split("-"); mm = parseInt(adata[0], 10); gg = parseInt(adata[1], 10); aaaa = parseInt(adata[2], 10); } else { adata = value.split("-"); aaaa = parseInt(adata[0], 10); mm = parseInt(adata[1], 10); gg = parseInt(adata[2], 10); } xdata = new Date(Date.UTC(aaaa, mm - 1, gg, 12, 0, 0, 0)); if ((xdata.getUTCFullYear() === aaaa) && (xdata.getUTCMonth() === mm - 1) && (xdata.getUTCDate() === gg)) { check = true; } else { check = false; } } else { check = false; } return this.optional(element) || check; }); function forminatorRetrieveEditorText( value, element ) { // Retrieve the text if it is an editor. if ( $( element ).hasClass( 'wp-editor-area' ) && $( element ).hasClass( 'forminator-textarea' ) ) { value = $( '<div/>' ).html( value ).text(); } return value; } $.validator.addMethod("maxwords", function (value, element, param) { value = forminatorRetrieveEditorText( value, element ); return this.optional(element) || value.trim().split(/\s+/).length <= param; }); // override core jquertvalidation maxlength. Ignore tags. $.validator.methods.maxlength = function ( value, element, length ) { value = value.replace( /<[^>]*>/g, '' ); value = forminatorRetrieveEditorText( value, element ); if ( value.length > length ) { return false; } return true; }; $.validator.addMethod("trim", function( value, element, param ) { return true === this.optional( element ) || 0 !== value.trim().length; }); $.validator.addMethod("equalToClosestEmail", function (value, element, param) { let target = $(element).closest('.forminator-row-with-confirmation-email').find('input[type="email"]').first(); return target.length && value === target.val(); } ); $.validator.addMethod("emailFilter", function (email, element, param) { if ( ! email ) { return true; } const emailList = param.email_list.split('|'), isDeny = 'deny' === param.filter_type; for (let item of emailList) { // Remove spaces in email addresses. item = item.replace(/[\s\n\r\t]/g, ''); // Escape special characters. item = item.replace(/[.*+?^${}()|[\]\\]/g, '\\$&'); // Support * as wildcard. item = item.replace(/\\\*/g, '.*'); // Add end delimiter. const regex = new RegExp(item + '$'); if (regex.test(email)) { return ! isDeny; } } return isDeny; } ); $.validator.addMethod("emailWP", function (value, element, param) { if (this.optional(element)) { return true; } // Test for the minimum length the email can be if (value.trim().length < 6) { return false; } // Test for an @ character after the first position if (value.indexOf('@', 1) < 0) { return false; } // Split out the local and domain parts var parts = value.split('@', 2); // LOCAL PART // Test for invalid characters if (!parts[0].match(/^[a-zA-Z0-9!#$%&'*+\/=?^_`{|}~\.-]+$/)) { return false; } // DOMAIN PART // Test for sequences of periods if (parts[1].match(/\.{2,}/)) { return false; } var domain = parts[1]; // Split the domain into subs var subs = domain.split('.'); if (subs.length < 2) { return false; } var subsLen = subs.length; for (var i = 0; i < subsLen; i++) { // Test for invalid characters if (!subs[i].match(/^[a-z0-9-]+$/i)) { return false; } } return true; }); $.validator.addMethod("forminatorPasswordStrength", function (value, element, param) { var passwordStrength = value.trim(); // Password is optional and is empty so don't check strength. if ( passwordStrength.length == 0 ) { return true; } //at least 8 characters if ( ! passwordStrength || passwordStrength.length < 8) { return false; } var symbolSize = 0, natLog, score; //at least one number if ( passwordStrength.match(/[0-9]/) ) { symbolSize += 10; } //at least one lowercase letter if ( passwordStrength.match(/[a-z]/) ) { symbolSize += 20; } //at least one uppercase letter if ( passwordStrength.match(/[A-Z]/) ) { symbolSize += 20; } if ( passwordStrength.match(/[^a-zA-Z0-9]/) ) { symbolSize += 30; } //at least one special character if ( passwordStrength.match(/[=!\-@.,_*#&?^`%$+\/{\[\]|}^?~]/) ) { symbolSize += 30; } natLog = Math.log( Math.pow(symbolSize, passwordStrength.length) ); score = natLog / Math.LN2; return score >= 54; }); $.validator.addMethod("extension", function (value, element, param) { var check = false; if (value.trim() !== '') { var extension = value.replace(/^.*\./, ''); if (extension == value) { extension = 'notExt'; } else { extension = extension.toLowerCase(); } if (param.indexOf(extension) != -1) { check = true; } } return this.optional(element) || check; }); // $.validator.methods.required = function(value, element, param) { // console.log("required", element); // // return someCondition && value != null; // } // override core jquertvalidation number, to use HTML5 spec $.validator.methods.number = function (value, element, param) { return this.optional(element) || /^[-+]?[0-9]+[.]?[0-9]*([eE][-+]?[0-9]+)?$/.test(value); }; $.validator.addMethod('minNumber', function (value, el, param) { if ( 0 === value.length ) { return true; } var minVal = parseFloatFromString( value ); return minVal >= param; }); $.validator.addMethod('maxNumber', function (value, el, param) { if ( 0 === value.length ) { return true; } var maxVal = parseFloatFromString( value ); return maxVal <= param; }); $.validator.addMethod( 'timeLimit', function ( value, el, limit ) { var chosenTime = forminatorGetTime( el, value ), startLimit = forminatorConvertToSeconds( limit.start_limit ), endLimit = forminatorConvertToSeconds( limit.end_limit ), comparison = chosenTime >= startLimit && chosenTime <= endLimit, hoursDiv = $( el ).closest( '.forminator-col' ), minutesField = hoursDiv.next().find( '.forminator-field' ) ; // Lets add error class to minutes field if hours has error. if ( ! comparison && true !== chosenTime ) { setTimeout( function() { minutesField.addClass( 'forminator-has_error' ); }, 10 ); } else { minutesField.removeClass( 'forminator-has_error' ); } // Check if chosenTime is not true, then compare if chosenTime in seconds is >= to the limit in seconds. return true !== chosenTime ? comparison: true; }); function parseFloatFromString( value ) { value = String( value ).trim(); var parsed = parseFloat( value ); if ( String( parsed ) === value ) { return fixDecimals( parsed, 2 ); } var split = value.split( /[^\dE-]+/ ); if ( 1 === split.length ) { return fixDecimals(parseFloat(value), 2); } var decimal = split.pop(); // reconstruct the number using dot as decimal separator return fixDecimals( parseFloat( split.join('') + '.' + decimal ), 2 ); } function fixDecimals( num, precision ) { return ( Math.floor( num * 100 ) / 100 ).toFixed( precision ); } function forminatorGetTime ( el, value ) { var hoursDiv, minutesDiv, hours, minutes, meridiem, final = ''; // Get the values minutes and meridiem. if ( el.name.includes( 'hours' ) ) { hoursDiv = $( el ).closest( '.forminator-col' ); hours = value; minutesDiv = hoursDiv.next(); minutes = minutesDiv.find( '.time-minutes' ); if ( 'select' === minutes.prop( 'tagName' ).toLowerCase() ) { minutes = minutesDiv.find( '.time-minutes option:selected' ).val(); } else { minutes = minutesDiv.find( '.time-minutes' ).val(); } meridiem = minutesDiv.next().find( 'select[name$="ampm"] option:selected' ).val(); } if ( 'undefined' !== typeof hours && '' !== hours && 'undefined' !== typeof minutes && '' !== minutes ) { final = hours + ':' + minutes; } else { return true; } if ( '' !== final && 'undefined' !== typeof meridiem ) { final += ' ' + meridiem; } final = forminatorConvertToSeconds( final ); return final; } function forminatorConvertToSeconds ( chosenTime ) { var [ time, modifier ] = chosenTime.split(' '); var [ hours, minutes ] = time.split(':'); if ( 'undefined' !== typeof modifier ) { if ( 12 === parseInt( hours, 10 ) ) { hours = 0; } if ( 'pm' === modifier.toLowerCase() ) { hours = parseInt( hours, 10 ) + 12; } } hours = hours * 60 * 60; minutes = minutes * 60; return hours + minutes; } // Backup the recently added custom validation methods (they will be // checked in the plugin wrapper later) ownMethods = $.validator.methods; })(jQuery, window, document);PK �K}\i�l�{� {� front.multi.jsnu �[��� // the semi-colon before function invocation is a safety net against concatenated // scripts and/or other plugins which may not be closed properly. ;// noinspection JSUnusedLocalSymbols (function ($, window, document, undefined) { "use strict"; // undefined is used here as the undefined global variable in ECMAScript 3 is // mutable (ie. it can be changed by someone else). undefined isn't really being // passed in so we can ensure the value of it is truly undefined. In ES5, undefined // can no longer be modified. // window and document are passed through as local variables rather than global // as this (slightly) quickens the resolution process and can be more efficiently // minified (especially when both are regularly referenced in your plugin). // Create the defaults once var pluginName = "forminatorFront", defaults = { form_type: 'custom-form', rules: {}, messages: {}, conditions: {}, inline_validation: false, print_value: false, chart_design: 'bar', chart_options: {}, forminator_fields: [], general_messages: { calculation_error: 'Failed to calculate field.', payment_require_ssl_error: 'SSL required to submit this form, please check your URL.', payment_require_amount_error: 'PayPal amount must be greater than 0.', form_has_error: 'Please correct the errors before submission.' }, payment_require_ssl : false, }; // The actual plugin constructor function ForminatorFront(element, options) { this.element = element; this.$el = $(this.element); this.forminator_selector = '#' + $(this.element).attr('id') + '[data-forminator-render="' + $(this.element).data('forminator-render') + '"]'; this.forminator_loader_selector = 'div[data-forminator-render="' + $(this.element).data('forminator-render') + '"]' + '[data-form="' + $(this.element).attr('id') + '"]'; // jQuery has an extend method which merges the contents of two or // more objects, storing the result in the first object. The first object // is generally empty as we don't want to alter the default options for // future instances of the plugin this.settings = $.extend({}, defaults, options); // special treatment for rules, messages, and conditions if (typeof this.settings.messages !== 'undefined') { this.settings.messages = this.maybeParseStringToJson(this.settings.messages, 'object'); } if (typeof this.settings.rules !== 'undefined') { this.settings.rules = this.maybeParseStringToJson(this.settings.rules, 'object'); } if (typeof this.settings.calendar !== 'undefined') { this.settings.calendar = this.maybeParseStringToJson(this.settings.calendar, 'array'); } this._defaults = defaults; this._name = pluginName; this.form_id = 0; this.template_type = ''; this.init(); this.handleDiviPopup(); } // Avoid Plugin.prototype conflicts $.extend(ForminatorFront.prototype, { init: function () { var self = this; if (this.$el.find('input[name="form_id"]').length > 0) { this.form_id = this.$el.find('input[name="form_id"]').val(); } if (this.$el.find('input[name="form_type"]').length > 0) { this.template_type = this.$el.find('input[name="form_type"]').val(); } $(this.forminator_loader_selector).remove(); // If form from hustle popup, do not show if (this.$el.closest('.wph-modal').length === 0) { this.$el.show(); } // Show form when popup trigger with click $(document).on("hustle:module:displayed", function (e, data) { var $modal = $('.wph-modal-active'); $modal.find('form').css('display', ''); }); self.reint_intlTelInput(); // Show form when popup trigger setTimeout(function () { var $modal = $('.wph-modal-active'); $modal.find('form').css('display', ''); }, 10); //selective activation based on type of form switch (this.settings.form_type) { case 'custom-form': $( this.element ).each( function() { self.init_custom_form( this ); }); this.$el.on( 'forminator-clone-group', function ( event ) { self.init_custom_form( event.target ); } ); break; case 'poll': this.init_poll_form(); break; case 'quiz': this.init_quiz_form(); break; } //init submit var submitOptions = { form_type: self.settings.form_type, forminator_selector: self.forminator_selector, chart_design: self.settings.chart_design, chart_options: self.settings.chart_options, has_quiz_loader: self.settings.has_quiz_loader, has_loader: self.settings.has_loader, loader_label: self.settings.loader_label, resetEnabled: self.settings.is_reset_enabled, inline_validation: self.settings.inline_validation, }; if( 'leads' === this.template_type || 'quiz' === this.settings.form_type ) { submitOptions.form_placement = self.settings.form_placement; submitOptions.hasLeads = self.settings.hasLeads; submitOptions.leads_id = self.settings.leads_id; submitOptions.quiz_id = self.settings.quiz_id; submitOptions.skip_form = self.settings.skip_form; } $(this.element).forminatorFrontSubmit( submitOptions ); // TODO: confirm usage on form type // Handle field activation classes this.activate_field(); // Handle special classes for material design // this.material_field(); // Init small form for all type of form this.small_form(); // trigger form added in the DOM $(document).trigger('forminator:form:added') }, init_custom_form: function ( form_selector ) { var self = this, $saveDraft = this.$el.find( '.forminator-save-draft-link' ), saveDraftExists = 0 !== $saveDraft.length ? true : false, draftTimer ; //initiate validator this.init_intlTelInput_validation( form_selector ); if (this.settings.inline_validation) { $( form_selector ).forminatorFrontValidate({ rules: self.settings.rules, messages: self.settings.messages }); } // initiate calculator $( form_selector ).forminatorFrontCalculate({ forminatorFields: self.settings.forminator_fields, generalMessages: self.settings.general_messages, memoizeTime: self.settings.calcs_memoize_time || 300, }); // initiate merge tags $( form_selector ).forminatorFrontMergeTags({ forminatorFields: self.settings.forminator_fields, print_value: self.settings.print_value, }); //initiate pagination this.init_pagination( form_selector ); if( self.settings.has_stripe ) { var stripe_payment = $(this.element).find('.forminator-stripe-element[data-type="stripe-ocs"]').first(); if ( 1 > stripe_payment.length ) { stripe_payment = $(this.element).find('.forminator-stripe-element').first(); } if ( $( self.element ).is( ':visible' ) ) { this.renderStripe( self, stripe_payment ); } // Show Stripe on modal display. $( document ).on( "forminator:form:added", function () { self.renderStripe( self, stripe_payment ); }); } if( self.settings.has_paypal // Fix for Divi popup. && ( ! $( self.element ).closest( '.et_pb_section' ).length || $( self.element ).is( ':visible' ) ) ) { $(this.element).forminatorFrontPayPal({ type: 'paypal', paymentEl: this.settings.paypal_config, paymentRequireSsl: self.settings.payment_require_ssl, generalMessages: self.settings.general_messages, has_loader: self.settings.has_loader, loader_label: self.settings.loader_label, }); } //initiate condition $( form_selector ).forminatorFrontCondition(this.settings.conditions, this.settings.calendar); //initiate forminator ui scripts this.init_fui( form_selector ); //initiate datepicker $( form_selector ).find('.forminator-datepicker').forminatorFrontDatePicker(this.settings.calendar); // Handle responsive captcha this.responsive_captcha( form_selector ); // Handle field counter this.field_counter( form_selector ); // Handle number input this.field_number( form_selector ); // Handle time fields this.field_time(); // Handle upload field change $( form_selector ).find('.forminator-multi-upload').forminatorFrontMultiFile( this.$el ); this.upload_field( form_selector ); this.init_login_2FA(); self.maybeRemoveDuplicateFields( form_selector ); self.checkComplianzBlocker(); // Handle function on resize $(window).on('resize', function () { self.responsive_captcha( form_selector ); }); // Handle function on load $( window ).on( 'load', function () { // Repeat the function here, just in case our scripts gets loaded late self.maybeRemoveDuplicateFields( form_selector ); }); // We have to declare initialData here, after everything has been set initially, to prevent triggering change event. var initialData = saveDraftExists ? this.$el.serializeArray() : ''; this.$el.find( ".forminator-field input, .forminator-row input[type=hidden], .forminator-field select, .forminator-field textarea, .forminator-field-signature").on( 'change input', function (e) { if ( saveDraftExists && $saveDraft.hasClass( 'disabled' ) ) { clearTimeout( draftTimer ); draftTimer = setTimeout( function() { self.maybe_enable_save_draft( $saveDraft, initialData ); }, 500 ); } }); if( 'undefined' !== typeof self.settings.hasLeads ) { if( 'beginning' === self.settings.form_placement ) { $('#forminator-module-' + this.settings.quiz_id ).css({ 'height': 0, 'opacity': 0, 'overflow': 'hidden', 'visibility': 'hidden', 'pointer-events': 'none', 'margin': 0, 'padding': 0, 'border': 0 }); } if( 'end' === self.settings.form_placement ) { $( form_selector ).css({ 'height': 0, 'opacity': 0, 'overflow': 'hidden', 'visibility': 'hidden', 'pointer-events': 'none', 'margin': 0, 'padding': 0, 'border': 0 }); } } }, init_poll_form: function() { var self = this, $fieldset = this.$el.find( 'fieldset' ), $selection = this.$el.find( '.forminator-radio input' ), $input = this.$el.find( '.forminator-input' ), $field = $input.closest( '.forminator-field' ) ; // Load input states FUI.inputStates( $input ); // Show input when option has been selected $selection.on( 'click', function() { // Reset $field.addClass( 'forminator-hidden' ); $field.attr( 'aria-hidden', 'true' ); $input.removeAttr( 'tabindex' ); $input.attr( 'name', '' ); var checked = this.checked, $id = $( this ).attr( 'id' ), $name = $( this ).attr( 'name' ) ; // Once an option has been chosen, remove error class. $fieldset.removeClass( 'forminator-has_error' ); if ( self.$el.find( '.forminator-input#' + $id + '-extra' ).length ) { var $extra = self.$el.find( '.forminator-input#' + $id + '-extra' ), $extraField = $extra.closest( '.forminator-field' ) ; if ( checked ) { $extra.attr( 'name', $name + '-extra' ); $extraField.removeClass( 'forminator-hidden' ); $extraField.removeAttr( 'aria-hidden' ); $extra.attr( 'tabindex', '-1' ); $extra.focus(); } else { $extraField.addClass( 'forminator-hidden' ); $extraField.attr( 'aria-hidden', 'true' ); $extra.removeAttr( 'tabindex' ); } } return true; }); // Disable options if ( this.$el.hasClass( 'forminator-poll-disabled' ) ) { this.$el.find( '.forminator-radio' ).each( function() { $( this ).addClass( 'forminator-disabled' ); $( this ).find( 'input' ).attr( 'disabled', true ); }); } }, init_quiz_form: function () { var self = this, lead_placement = 'undefined' !== typeof self.settings.form_placement ? self.settings.form_placement : '', quiz_id = 'undefined' !== typeof self.settings.quiz_id ? self.settings.quiz_id : 0; this.$el.find('.forminator-button:not(.forminator-quiz-start)').each(function () { $(this).prop("disabled", true); }); this.$el.find('.forminator-answer input').each(function () { $(this).attr('checked', false); }); this.$el.find('.forminator-result--info button').on('click', function () { location.reload(); }); $('#forminator-quiz-leads-' + quiz_id + ' .forminator-quiz-intro .forminator-quiz-start').on('click', function(e){ e.preventDefault(); $(this).closest( '.forminator-quiz-intro').hide(); self.$el.prepend('<button class="forminator-button forminator-quiz-start forminator-hidden"></button>') .find('.forminator-quiz-start').trigger('click').remove(); }); this.$el.on('click', '.forminator-quiz-start', function (e) { e.preventDefault(); self.$el.find('.forminator-quiz-intro').hide(); self.$el.find('.forminator-pagination').removeClass('forminator-hidden'); //initiate pagination var args = { totalSteps: self.$el.find('.forminator-pagination').length - 1, //subtract the last step with result step: 0, quiz: true }; if ( self.settings.text_next ) { args.next_button = self.settings.text_next; } if ( self.settings.text_prev ) { args.prev_button = self.settings.text_prev; } if ( self.settings.submit_class ) { args.submitButtonClass = self.settings.submit_class; } $(self.element).forminatorFrontPagination(args); }); if( 'end' !== lead_placement ) { this.$el.find('.forminator-submit-rightaway').on("click", function () { self.$el.submit(); $(this).closest('.forminator-question').find('.forminator-submit-rightaway').addClass('forminator-has-been-disabled').attr('disabled', 'disabled'); }); } if( self.settings.hasLeads ) { if( 'beginning' === lead_placement ) { self.$el.css({ 'height': 0, 'opacity': 0, 'overflow': 'hidden', 'visibility': 'hidden', 'pointer-events': 'none', 'margin': 0, 'padding': 0, 'border': 0 }); } if( 'end' === lead_placement ) { self.$el.closest('div').find('#forminator-module-' + self.settings.leads_id ).css({ 'height': 0, 'opacity': 0, 'overflow': 'hidden', 'visibility': 'hidden', 'pointer-events': 'none', 'margin': 0, 'padding': 0, 'border': 0 }); $('#forminator-quiz-leads-' + quiz_id + ' .forminator-lead-form-skip' ).hide(); } } this.$el.on('click', '.forminator-social--icon a', function (e) { e.preventDefault(); var social = $(this).data('social'), url = $(this).closest('.forminator-social--icons').data('url'), message = $(this).closest('.forminator-social--icons').data('message'), message = encodeURIComponent(message), social_shares = { 'facebook': 'https://www.facebook.com/sharer/sharer.php?u=' + url + '"e=' + message, 'twitter': 'https://twitter.com/intent/tweet?&url=' + url + '&text=' + message, 'google': 'https://plus.google.com/share?url=' + url, 'linkedin': 'https://www.linkedin.com/shareArticle?mini=true&url=' + url + '&title=' + message }; if (social_shares[social] !== undefined) { var newwindow = window.open(social_shares[social], social, 'height=' + $(window).height() + ',width=' + $(window).width()); if (window.focus) { newwindow.focus(); } return false; } }); this.$el.on('change', '.forminator-answer input', function (e) { var paginated = !!$( this ).closest('.forminator-pagination').length, parent = paginated ? $( this ).closest('.forminator-pagination') : self.$el, count = parent.find('.forminator-answer input:checked').length, amount_answers = parent.find('.forminator-question').length, parentQuestion = $( this ).closest( '.forminator-question' ), isMultiChoice = parentQuestion.data( 'multichoice' ) ; self.$el.find('.forminator-button:not(.forminator-button-back)').each(function () { var disabled = count < amount_answers; $( this ).prop('disabled', disabled); if ( paginated ) { if ( disabled ) { $( this ).addClass('forminator-disabled'); } else { $( this ).removeClass('forminator-disabled'); } } }); // If multichoice is false, uncheck other options if( this.checked && false === isMultiChoice ) { parentQuestion .find( '.forminator-answer' ) .not( $( this ).parent( '.forminator-answer' ) ) .each( function( i, el ){ $( el ).find( '> input' ).prop( 'checked', false ); }); } }); }, small_form: function () { var form = $( this.element ), formWidth = form.width() ; if ( 783 < Math.max( document.documentElement.clientWidth, window.innerWidth || 0 ) ) { if ( form.hasClass( 'forminator-size--small' ) ) { if ( 480 < formWidth ) { form.removeClass( 'forminator-size--small' ); } } else { var hasHustle = form.closest('.hustle-content'); if ( form.is(":visible") && 480 >= formWidth && ! hasHustle.length ) { form.addClass( 'forminator-size--small' ); } } } }, init_intlTelInput_validation: function ( form_selector ) { var form = $( form_selector ), is_material = form.is('.forminator-design--material'), fields = form.find('.forminator-field--phone'); if ( ! form.is('form') ) { // For cloning phone fields inside group fields. is_material = form.closest('form').is('.forminator-design--material'); } fields.each(function () { // Initialize intlTelInput plugin on each field with "format check" enabled and // set to check either "international" or "standard" phones. var self = this, is_national_phone = $(this).data('national_mode'), country = $(this).data('country'), validation = $(this).data('validation'), iti = window.intlTelInput.getInstance(self); if ('undefined' !== typeof (is_national_phone)) { if (is_material) { $(this).unwrap('.forminator-input--wrap'); } // If it's already intialised then first destroy it and then reinit. if ( iti ) { iti.destroy(); } var args = { nationalMode: ('enabled' === is_national_phone) ? true : false, initialCountry: 'undefined' !== typeof ( country ) ? country : 'us', validationNumberTypes: null, loadUtils: () => import(window.ForminatorFront.cform.intlTelInput_utils_script), strictMode: true, }; if ( 'undefined' !== typeof ( validation ) && 'standard' === validation ) { args.allowDropdown = false; } // stop from removing country code. if ( 'undefined' !== typeof ( validation ) && 'international' === validation ) { args.autoHideDialCode = false; args.separateDialCode = true; } var iti = window.intlTelInput(self, args); if ( 'undefined' !== typeof ( validation ) && 'standard' === validation ) { // Reset country to default if changed and invalid previously. $( this ).on( 'blur', function() { if ( '' === $( self ).val() ) { iti.setCountry( country ); form.validate().element( $( self ) ); } }); } if ( ! is_material ) { $(this).closest( '.forminator-field' ).find( 'div.iti' ).addClass( 'forminator-phone' ); } else { $(this).closest( '.forminator-field' ).find( 'div.iti' ).addClass( 'forminator-input-with-phone' ); if ( $(this).closest( '.forminator-field' ).find( 'div.iti' ).hasClass( 'iti--allow-dropdown' ) ) { $(this).closest( '.forminator-field' ).find( '.forminator-label' ).addClass( 'iti--allow-dropdown' ); } } // intlTelInput plugin adds a markup that's not compatible with 'material' theme when 'allowDropdown' is true (default). // If we're going to allow users to disable the dropdown, this should be adjusted accordingly. if (is_material) { //$(this).closest('.intl-tel-input.allow-dropdown').addClass('forminator-phone-intl').removeClass('intl-tel-input'); //$(this).wrap('<div class="forminator-input--wrap"></div>'); // Wrap Element if (!$(this).parent().hasClass('forminator-input--wrap')) { $(this).wrap('<div class="forminator-input--wrap"></div>'); } } } }); }, reint_intlTelInput: function () { var self = this; self.$el.on( 'after:forminator:form:submit', function (e, data) { self.init_intlTelInput_validation( self.forminator_selector ); } ); }, init_fui: function ( form_selector ) { var form = $( form_selector ), input = form.find( '.forminator-input' ), textarea = form.find( '.forminator-textarea' ), select2 = form.find( '.forminator-select2' ), multiselect = form.find( '.forminator-multiselect' ), stripe = form.find( '.forminator-stripe-element' ), slider = form.find( '.forminator-slider' ), rating = form.find( '.forminator-rating' ) ; var isDefault = ( form.attr( 'data-design' ) === 'default' ), isBold = ( form.attr( 'data-design' ) === 'bold' ), isFlat = ( form.attr( 'data-design' ) === 'flat' ), isMaterial = ( form.attr( 'data-design' ) === 'material' ) ; if ( input.length ) { input.each( function() { FUI.inputStates( this ); }); } if ( textarea.length ) { textarea.each( function() { FUI.textareaStates( this ); }); } if ( 'function' === typeof FUI.select2 ) { FUI.select2( select2.length ); } if ( 'function' === typeof FUI.slider ) { FUI.slider(); } if ( multiselect.length ) { FUI.multiSelectStates( multiselect ); } if ( rating.length && 'function' === typeof FUI.rating ) { FUI.rating( rating ); } if ( form.hasClass( 'forminator-design--material' ) ) { if ( input.length ) { input.each( function() { FUI.inputMaterial( this ); }); } if ( textarea.length ) { textarea.each( function() { FUI.textareaMaterial( this ); }); } if ( stripe.length ) { stripe.each( function() { if ($(this).hasClass('forminator-stripe-payment-element')) { return; // Skip to the next iteration } var field = $(this).closest('.forminator-field'); var label = field.find('.forminator-label'); if (label.length) { field.addClass('forminator-stripe-floating'); // Add floating class label.addClass('forminator-floating--input'); } }); } } }, responsive_captcha: function ( form_selector ) { $( form_selector ).find('.forminator-g-recaptcha').each(function () { var badge = $(this).data('badge'); // eslint-disable-line if ($(this).is(':visible') && 'inline' === badge ) { var width = $(this).parent().width(), scale = 1; if (width < 302) { scale = width / 302; } $(this).css('transform', 'scale(' + scale + ')'); $(this).css('-webkit-transform', 'scale(' + scale + ')'); $(this).css('transform-origin', '0 0'); $(this).css('-webkit-transform-origin', '0 0'); } }); }, init_pagination: function ( form_selector ) { var self = this, num_pages = $( form_selector ).find(".forminator-pagination").length, hash = window.location.hash, hashStep = false, step = 0; if (num_pages > 0) { //find from hash if (typeof hash !== "undefined" && hash.indexOf('step-') >= 0) { hashStep = true; step = hash.substr(6, 8); } $(this.element).forminatorFrontPagination({ totalSteps: num_pages, hashStep: hashStep, step: step, inline_validation: self.settings.inline_validation, submitButtonClass: self.settings.submit_button_class }); } }, activate_field: function () { var form = $( this.element ); var input = form.find( '.forminator-input' ); var textarea = form.find( '.forminator-textarea' ); function classFilled( el ) { var element = $( el ); var elementValue = element.val().trim(); var elementField = element.closest( '.forminator-field' ); var elementAnswer = element.closest( '.forminator-poll--answer' ); var filledClass = 'forminator-is_filled'; if ( '' !== elementValue ) { elementField.addClass( filledClass ); elementAnswer.addClass( filledClass ); } else { elementField.removeClass( filledClass ); elementAnswer.removeClass( filledClass ); } element.change( function( e ) { if ( '' !== elementValue ) { elementField.addClass( filledClass ); elementAnswer.addClass( filledClass ); } else { elementField.removeClass( filledClass ); elementAnswer.removeClass( filledClass ); } e.stopPropagation(); }); } function classHover( el ) { var element = $( el ); var elementField = element.closest( '.forminator-field' ); var elementAnswer = element.closest( '.forminator-poll--answer' ); var hoverClass = 'forminator-is_hover'; element.on( 'mouseover', function( e ) { elementField.addClass( hoverClass ); elementAnswer.addClass( hoverClass ); e.stopPropagation(); }).on( 'mouseout', function( e ) { elementField.removeClass( hoverClass ); elementAnswer.removeClass( hoverClass ); e.stopPropagation(); }); } function classActive( el ) { var element = $( el ); var elementField = element.closest( '.forminator-field' ); var elementAnswer = element.closest( '.forminator-poll--answer' ); var activeClass = 'forminator-is_active'; element.focus( function( e ) { elementField.addClass( activeClass ); elementAnswer.addClass( activeClass ); e.stopPropagation(); }).blur( function( e ) { elementField.removeClass( activeClass ); elementAnswer.removeClass( activeClass ); e.stopPropagation(); }); } function classError( el ) { var element = $( el ); var elementValue = element.val().trim(); var elementField = element.closest( '.forminator-field' ); var elementTime = element.attr( 'data-field' ); var timePicker = element.closest( '.forminator-timepicker' ); var timeColumn = timePicker.parent(); var errorField = elementField.find( '.forminator-error-message' ); var errorClass = 'forminator-has_error'; element.on( 'load change keyup keydown', function( e ) { if ( 'undefined' !== typeof elementTime && false !== elementTime ) { if ( 'hours' === element.data( 'field' ) ) { var hoursError = timeColumn.find( '.forminator-error-message[data-error-field="hours"]' ); if ( '' !== elementValue && 0 !== hoursError.length ) { hoursError.remove(); } } if ( 'minutes' === element.data( 'field' ) ) { var minutesError = timeColumn.find( '.forminator-error-message[data-error-field="minutes"]' ); if ( '' !== elementValue && 0 !== minutesError.length ) { minutesError.remove(); } } } else { if ( '' !== elementValue && errorField.text() ) { errorField.remove(); elementField.removeClass( errorClass ); } } e.stopPropagation(); }); } if ( input.length ) { input.each( function() { //classFilled( this ); //classHover( this ); //classActive( this ); classError( this ); }); } if ( textarea.length ) { textarea.each( function() { //classFilled( this ); //classHover( this ); //classActive( this ); classError( this ); }); } form.find('select.forminator-select2 + .forminator-select').each(function () { var $select = $(this); // Set field active class on hover $select.on('mouseover', function (e) { e.stopPropagation(); $(this).closest('.forminator-field').addClass('forminator-is_hover'); }).on('mouseout', function (e) { e.stopPropagation(); $(this).closest('.forminator-field').removeClass('forminator-is_hover'); }); // Set field active class on focus $select.on('click', function (e) { e.stopPropagation(); checkSelectActive(); if ($select.hasClass('select2-container--open')) { $(this).closest('.forminator-field').addClass('forminator-is_active'); } else { $(this).closest('.forminator-field').removeClass('forminator-is_active'); } }); }); function checkSelectActive() { if (form.find('.select2-container').hasClass('select2-container--open')) { setTimeout(checkSelectActive, 300); } else { form.find('.select2-container').closest('.forminator-field').removeClass('forminator-is_active'); } } }, field_counter: function ( form_selector ) { var form = $( form_selector ), submit_button = form.find('.forminator-button-submit'); form.find('.forminator-input, .forminator-input input, .forminator-textarea').each(function () { var $input = $(this), numwords = 0, count = 0; $input.on('keydown', function (e) { if ( ! $(this).hasClass('forminator-textarea') && e.keyCode === 13 ) { e.preventDefault(); if ( submit_button.is(":visible") ) { submit_button.trigger('click'); } return false; } }); $input.on('change keyup keydown', function (e) { e.stopPropagation(); var $field = $(this).closest('.forminator-col'), $limit = $field.find('.forminator-description span') ; if ($limit.length) { var textLimit = parseInt( $limit.data('limit') ); if (textLimit) { if ($limit.data('type') !== "words") { if ( $limit.data( 'editor' ) === 1 ) { const content = $( this ) .val() .replace( /<[^>]*>/g, '' ), content_text = $( '<textarea/>' ) .html( content ) .text(); count = content_text.length; const isCtrlPressed = e.ctrlKey || e.metaKey; // Handle macOS Command key (metaKey). const isSpecialKey = [ 37, 38, 39, 40, 8, 46 ].indexOf( e.keyCode ) !== -1; // Allow to delete and backspace when limit is reached. if ( count >= textLimit && ! isCtrlPressed && ! isSpecialKey ) { e.preventDefault(); } } else { count = $(this).val().length; } } else { var fieldVal = sanitize_text_field( $(this).val() ), field_value = fieldVal.replace( /<[^>]*>/g, '' ); count = field_value.trim().split(/\s+/).length; // Prevent additional words from being added when limit is reached. numwords = field_value.trim().split(/\s+/).length; if ( numwords >= textLimit ) { // Allow to delete and backspace when limit is reached. if( e.which === 32 ) { e.preventDefault(); } } } $limit.text(count + ' / ' + textLimit); } } }); }); }, field_number: function ( form_selector ) { // var form = $(this.element); // form.find('input[type=number]').on('change keyup', function () { // if( ! $(this).val().match(/^\d+$/) ){ // var sanitized = $(this).val().replace(/[^0-9]/g, ''); // $(this).val(sanitized); // } // }); var form = $( form_selector ); form.find('input[type=number]').each(function () { $(this).keypress(function (e) { var i; var allowed = [44, 45, 46]; var key = e.which; for (i = 48; i < 58; i++) { allowed.push(i); } if (!(allowed.indexOf(key) >= 0)) { e.preventDefault(); } }); }); form.find('.forminator-number--field, .forminator-currency, .forminator-calculation').each(function () { var inputType = $( this ).attr( 'type' ); if ( 'number' === inputType ) { var decimals = $( this ).data( 'decimals' ); $( this ).change( function ( e ) { this.value = parseFloat( this.value ).toFixed( decimals ); }); $( this ).trigger( 'change' ); } /* * If you need to retrieve the formatted (masked) value, you can use something like this: * $element.inputmask({'autoUnmask' : false}); * var value = $element.val(); * $element.inputmask({'autoUnmask' : true}); */ $( this ).inputmask({ 'alias': 'decimal', 'rightAlign': false, 'digitsOptional': false, 'showMaskOnHover': false, 'autoUnmask' : true, // Automatically unmask the value when retrieved - this prevents the "Maximum call stack size exceeded" console error that happens in some forms that contain number/calculation fields with localized masks. 'removeMaskOnSubmit': true, }); }); }, field_time: function () { var self = this; $('.forminator-input-time').on('input', function (e) { var $this = $(this), value = $this.val() ; // Allow only 2 digits for time fields if (value && value.length >= 2) { $this.val(value.substr(0, 2)); } }); // Apply time limits. this.$el.find( '.forminator-timepicker' ).each( function( i, el ) { var $tp = $( el ), start = $tp.data( 'start-limit' ), end = $tp.data( 'end-limit' ) ; if ( 'undefined' !== typeof start && 'undefined' !== typeof end ) { var hourSelect = $tp.find( '.time-hours' ), initHours = hourSelect.html() ; // Reset right away. self.resetTimePicker( $tp, start, end ); // Reset onchange. $tp.find( '.time-ampm' ).on( 'change', function() { hourSelect.val(''); hourSelect.html( initHours ); self.resetTimePicker( $tp, start, end ); setTimeout( function() { $tp.find( '.forminator-field' ).removeClass( 'forminator-has_error' ); }, 10 ); }); } }); }, // Remove hour options that are outside the limits. resetTimePicker: function ( timePicker, start, end ) { var meridiem = timePicker.find( '.time-ampm' ), [ startTime, startModifier ] = start.split(' '), [ startHour, startMinute ] = startTime.split(':'), startHour = parseInt( startHour ), [ endTime, endModifier ] = end.split(' '), [ endHour, endMinute ] = endTime.split(':'), endHour = parseInt( endHour ) ; if ( startModifier === endModifier ) { meridiem.find( 'option[value!="' + endModifier + '"]' ).remove(); } timePicker.find( '.time-hours' ).children().each( function( optionIndex, optionEl ) { var optionValue = parseInt( optionEl.value ); if ( '' !== optionValue && ( optionValue < startHour || ( 0 !== startHour && 12 === optionValue ) ) && meridiem.val() === startModifier ) { optionEl.remove(); } if ( '' !== optionValue && optionValue > endHour && 12 !== optionValue && meridiem.val() === endModifier ) { optionEl.remove(); } }); }, init_login_2FA: function () { var self = this; this.two_factor_providers( 'totp' ); $('body').on('click', '.forminator-2fa-link', function () { self.$el.find('#login_error').remove(); self.$el.find('.notification').empty(); var slug = $(this).data('slug'); self.two_factor_providers( slug ); if ('fallback-email' === slug) { self.resend_code(); } }); this.$el.find('.wpdef-2fa-email-resend input').on('click', function () { self.resend_code(); }); }, two_factor_providers: function ( slug ) { var self = this; self.$el.find('.forminator-authentication-box').hide(); self.$el.find('.forminator-authentication-box input').attr( 'disabled', true ); self.$el.find( '#forminator-2fa-' + slug ).show(); self.$el.find( '#forminator-2fa-' + slug + ' input' ).attr( 'disabled', false ); if ( self.$el.find('.forminator-2fa-link').length > 0 ) { self.$el.find('.forminator-2fa-link').hide(); self.$el.find('.forminator-2fa-link:not(#forminator-2fa-link-'+ slug +')').each(function() { self.$el.find('.forminator-auth-method').val( slug ); $( this ).find('input').attr( 'disabled', false ); $( this ).show(); }); } }, // Logic for FallbackEmail method. resend_code: function () { // Work with the button 'Resen Code'. var self = this; var that = $('input[name="button_resend_code"]'); var token = $('.forminator-auth-token'); let data = { action: 'forminator_2fa_fallback_email', data: JSON.stringify({ 'token': token }) }; $.ajax({ type: 'POST', url: window.ForminatorFront.ajaxUrl, data: data, beforeSend: function () { that.attr('disabled', 'disabled'); $('.def-ajaxloader').show(); }, success: function (data) { that.removeAttr('disabled'); $('.def-ajaxloader').hide(); $('.notification').text(data.data.message); } }) }, material_field: function () { /* var form = $(this.element); if (form.is('.forminator-design--material')) { var $input = form.find('.forminator-input--wrap'), $textarea = form.find('.forminator-textarea--wrap'), $date = form.find('.forminator-date'), $product = form.find('.forminator-product'); var $navigation = form.find('.forminator-pagination--nav'), $navitem = $navigation.find('li'); $('<span class="forminator-nav-border"></span>').insertAfter($navitem); $input.prev('.forminator-field--label').addClass('forminator-floating--input'); $input.closest('.forminator-phone-intl').prev('.forminator-field--label').addClass('forminator-floating--input'); $textarea.prev('.forminator-field--label').addClass('forminator-floating--textarea'); if ($date.hasClass('forminator-has_icon')) { $date.prev('.forminator-field--label').addClass('forminator-floating--date'); } else { $date.prev('.forminator-field--label').addClass('forminator-floating--input'); } } */ }, toggle_file_input: function() { var $form = $( this.element ); $form.find( '.forminator-file-upload' ).each( function() { var $field = $( this ); var $input = $field.find( 'input' ); var $remove = $field.find( '.forminator-button-delete' ); // Toggle remove button depend on input value if ( '' !== $input.val() ) { $remove.show(); // Show remove button } else { $remove.hide(); // Hide remove button } }); }, upload_field: function ( form_selector ) { var self = this, form = $( form_selector ) ; // Toggle file remove button this.toggle_file_input(); // Handle remove file button click form.find( '.forminator-button-delete' ).on('click', function (e) { e.preventDefault(); var $self = $( this ), $input = $self.siblings('input'), $label = $self.closest( '.forminator-file-upload' ).find('> span') ; // Cleanup $input.val(''); $label.html( $label.data( 'empty-text' ) ); $self.hide(); // Reset related conditional fields. $input.trigger( 'forminator.change', 'forminator_emulate_trigger' ); }); form.find( '.forminator-input-file, .forminator-input-file-required' ).on('change', function () { var $nameLabel = $(this).closest( '.forminator-file-upload' ).find( '> span' ), vals = $(this).val(), val = vals.length ? vals.split('\\').pop() : '' ; $nameLabel.text(val); self.toggle_file_input(); }); form.find( '.forminator-button-upload' ).off(); form.find( '.forminator-button-upload' ).on( 'click', function (e) { e.preventDefault(); var $id = $(this).attr('data-id'), $target = form.find('input#' + $id) ; $target.trigger('click'); }); form.find( '.forminator-input-file, .forminator-input-file-required' ).on('change', function (e) { e.preventDefault(); var $file = $(this)[0].files.length, $remove = $(this).find('.forminator-button-delete'); if ($file === 0) { $remove.hide(); } else { $remove.show(); } }); }, // Remove duplicate fields created by other plugins/themes maybeRemoveDuplicateFields: function ( form_selector ) { var form = $( form_selector ); // Check for Neira Lite theme if ( $( document ).find( "link[id='neira-lite-style-css']" ).length ) { var duplicateSelect = form.find( '.forminator-select-container' ).next( '.chosen-container' ), duplicateSelect2 = form.find( 'select.forminator-select2 + .forminator-select' ).next( '.chosen-container' ), duplicateAddress = form.find( '.forminator-select' ).next( '.chosen-container' ) ; if ( 0 !== duplicateSelect.length ) { duplicateSelect.remove(); } if ( 0 !== duplicateSelect2.length ) { duplicateSelect2.remove(); } if ( 0 !== duplicateAddress.length ) { duplicateAddress.remove(); } } }, renderCaptcha: function (captcha_field) { var self = this; //render captcha only if not rendered if (typeof $(captcha_field).data('forminator-recapchta-widget') === 'undefined') { var size = $(captcha_field).data('size'), data = { sitekey: $(captcha_field).data('sitekey'), theme: $(captcha_field).data('theme'), size: size }; if (size === 'invisible') { data.badge = $(captcha_field).data('badge'); data.callback = function (token) { $(self.element).trigger('submit.frontSubmit'); }; } else { data.callback = function () { $(captcha_field).parent( '.forminator-col' ) .removeClass( 'forminator-has_error' ) .remove( '.forminator-error-message' ); }; } if (data.sitekey !== "") { // noinspection Annotator var widget = window.grecaptcha.render(captcha_field, data); // mark as rendered $(captcha_field).data('forminator-recapchta-widget', widget); this.addCaptchaAria( captcha_field ); this.responsive_captcha(); } } }, renderHcaptcha: function ( captcha_field ) { var self = this; //render hcaptcha only if not rendered if (typeof $( captcha_field ).data( 'forminator-hcaptcha-widget' ) === 'undefined') { var size = $( captcha_field ).data( 'size' ), data = { sitekey: $( captcha_field ).data( 'sitekey' ), theme: $( captcha_field ).data( 'theme' ), size: size }; if ( size === 'invisible' ) { data.callback = function ( token ) { $( self.element ).trigger( 'submit.frontSubmit' ); }; } else { data.callback = function () { $( captcha_field ).parent( '.forminator-col' ) .removeClass( 'forminator-has_error' ) .remove( '.forminator-error-message' ); }; } if ( data.sitekey !== "" ) { // noinspection Annotator var widgetId = hcaptcha.render( captcha_field, data ); // mark as rendered $( captcha_field ).data( 'forminator-hcaptcha-widget', widgetId ); // this.addCaptchaAria( captcha_field ); // this.responsive_captcha(); } } }, renderTurnstileCaptcha: function ( captcha_field ) { var self = this; //render captcha only if not rendered if (typeof $( captcha_field ).data( 'forminator-turnstile-widget' ) === 'undefined') { var sitekey = $( captcha_field ).data( 'sitekey' ), data = { 'response-field-name': 'forminator-turnstile-response', callback: function (token, data, test) { $( captcha_field ).parent( '.forminator-col' ) .removeClass( 'forminator-has_error' ) .remove( '.forminator-error-message' ); } }; if ( sitekey !== "" ) { // noinspection Annotator var widgetId = turnstile.render( captcha_field, data ); // mark as rendered $( captcha_field ).data( 'forminator-turnstile-widget', widgetId ); } } }, addCaptchaAria: function ( captcha_field ) { var gRecaptchaResponse = $( captcha_field ).find( '.g-recaptcha-response' ), gRecaptcha = $( captcha_field ).find( '>div' ); if ( 0 !== gRecaptchaResponse.length ) { gRecaptchaResponse.attr( "aria-hidden", "true" ); gRecaptchaResponse.attr( "aria-label", "do not use" ); gRecaptchaResponse.attr( "aria-readonly", "true" ); } if ( 0 !== gRecaptcha.length ) { gRecaptcha.css( 'z-index', 99 ); } }, hide: function () { this.$el.hide(); }, /** * Return JSON object if possible * * We tried our best here * if there is an error/exception, it will return empty object/array * * @param string * @param type ('array'/'object') */ maybeParseStringToJson: function (string, type) { var object = {}; // already object if (typeof string === 'object') { return string; } if (type === 'object') { string = '{' + string.trim() + '}'; } else if (type === 'array') { string = '[' + string.trim() + ']'; } else { return {}; } try { // remove trailing comma, duh /** * find `,`, after which there is no any new attribute, object or array. * New attribute could start either with quotes (" or ') or with any word-character (\w). * New object could start only with character {. * New array could start only with character [. * New attribute, object or array could be placed after a bunch of space-like symbols (\s). * * Feel free to hack this regex if you got better idea * @type {RegExp} */ var trailingCommaRegex = /\,(?!\s*?[\{\[\"\'\w])/g; string = string.replace(trailingCommaRegex, ''); object = JSON.parse(string); } catch (e) { console.error(e.message); if (type === 'object') { object = {}; } else if (type === 'array') { object = []; } } return object; }, /** * Render Stripe once it's available * * @param string * @param type ('array'/'object') */ renderStripe: function( form, stripe_payment, stripeLoadCounter = 0 ) { var self = this; setTimeout( function() { stripeLoadCounter++; if ( 'undefined' !== typeof Stripe ) { let options= { type: 'stripe', paymentEl: stripe_payment, paymentRequireSsl: form.settings.payment_require_ssl, generalMessages: form.settings.general_messages, has_loader: form.settings.has_loader, loader_label: form.settings.loader_label, stripe_depends: form.settings.stripe_depends, }; if ( stripe_payment.data('is-ocs') ) { $( form.element ).forminatorFrontStripe( options ); } else { $( form.element ).forminatorFrontPayment( options ); } // Retry checking for 30 seconds } else if ( stripeLoadCounter < 300 ) { self.renderStripe( form, stripe_payment, stripeLoadCounter ); } else { console.error( 'Failed to load Stripe.' ); } }, 100 ); }, // Enable save draft button once a change is made maybe_enable_save_draft: function ( $saveDraft, initialData ) { var changedData = this.$el.serializeArray(), hasChanged = false, hasSig = this.$el.find( '.forminator-field-signature' ).length ? true : false ; // Remove signature field from changedData, will process later changedData = changedData.filter( function( val ) { return val.name.indexOf( 'ctlSignature' ) === -1 ; }); initialData = JSON.stringify( initialData ); changedData = JSON.stringify( changedData ); // Check for field changes if ( initialData !== changedData ) { hasChanged = true; } // Check for signature change if ( hasSig && false === hasChanged ) { this.$el.find( '.forminator-field-signature' ).each( function(e) { var sigPrefix = $( this ).find( '.signature-prefix' ).val(); if ( 0 !== $( this ).find( '#ctlSignature' + sigPrefix + '_data' ).length && '' !== $( this ).find( '#ctlSignature' + sigPrefix + '_data' ).val() ) { hasChanged = true; return false; } }); } if ( hasChanged ) { $saveDraft.removeClass( 'disabled' ); } else { $saveDraft.addClass( 'disabled' ); } }, handleDiviPopup: function () { var self = this; if ( 'undefined' !== typeof DiviArea ) { DiviArea.addAction( 'show_area', function( area ) { setTimeout( function() { self.init(); forminatorSignInit(); forminatorSignatureResize(); }, 100 ); }); } }, disableFields: function () { this.$el.addClass( 'forminator-fields-disabled' ); }, // Check if Complianz has added a blocker for reCaptcha. checkComplianzBlocker: function () { var complianzBlocker = this.$el.find( '.cmplz-blocked-content-container' ); if ( complianzBlocker.length > 0 ) { var row = complianzBlocker.closest( '.forminator-row' ); this.disableFields(); row.insertBefore( this.$el.find( '.forminator-row' ).first() ); row.css({ 'pointer-events': 'all', 'opacity': '1' }); row.find( '*' ).css( 'pointer-events', 'all' ); // For paginated. if ( row.closest( '.forminator-pagination--content' ).length > 0 ) { row.closest( '.forminator-pagination--content' ).css({ 'pointer-events': 'all', 'opacity': '1' }); row.nextAll( '.forminator-row' ).css({ 'opacity': '0.5' }); } // Reload window if accepted. $( 'body' ).on( 'click', '.cmplz-blocked-content-notice, .cmplz-accept', function() { setTimeout( function() { window.location.reload(); }, 50 ); }); } }, }); // A really lightweight plugin wrapper around the constructor, // preventing against multiple instantiations $.fn[pluginName] = function (options) { return this.each(function () { if (!$.data(this, pluginName)) { $.data(this, pluginName, new ForminatorFront(this, options)); } }); }; // hook from wp_editor tinymce $(document).on('tinymce-editor-init', function (event, editor) { var editor_id = editor.id, $field = $('#' + editor_id ).closest('.forminator-col') ; // Event listener to handle switching between Visual and Text tabs $( document ).on( 'click', '.wp-switch-editor', function () { setTimeout( function () { $field.find( '#' + editor_id ).trigger( 'change' ); }, 100 ); // Small timeout to ensure editor is ready when switching } ); // trigger editor change to save value to textarea, // default wp tinymce textarea update only triggered when submit var count = 0; editor.on('change', function () { // only forminator if ( -1 !== editor_id.indexOf( 'forminator-field-textarea-' ) ) { editor.save(); $field.find( '#' + editor_id ).trigger( 'change' ); } if ( -1 !== editor_id.indexOf( 'forminator-field-post-content-' ) ) { editor.save(); $field.find( '#' + editor_id ).trigger( 'change' ); } }); // Trigger onblur. editor.on( 'blur', function () { // only forminator if ( -1 !== editor_id.indexOf( 'forminator-field-textarea-' ) || -1 !== editor_id.indexOf( 'forminator-field-post-content-' ) ) { $field.find( '#' + editor_id ).valid(); } }); // Prevent typing when maximum characters/words is reached. editor.on( 'keydown', function ( e ) { let editor_id = editor.id, field = $( '#' + editor_id ).closest( '.forminator-col' ), limit = field.find( '.forminator-description span' ), content = editor.getContent().replace( /<[^>]*>/g, '' ); if ( limit.length ) { const maxLength = parseInt( limit.data( 'limit' ) ); if ( maxLength ) { content = $( '<div/>' ).html( content ).text(); const isCtrlPressed = e.ctrlKey || e.metaKey; // Handle macOS Command key (metaKey). const isSpecialKey = [ 37, 38, 39, 40, 8, 46 ].indexOf( e.keyCode ) !== -1; if ( limit.data( 'type' ) !== 'words' ) { if ( content.length >= maxLength && ! isCtrlPressed && ! isSpecialKey && e.keyCode !== 13 ) { e.preventDefault(); // Prevent any further typing. } } else { const numberOfWords = content .trim() .split( /\s+/ ).length; if ( numberOfWords >= maxLength && e.which === 32 ) { e.preventDefault(); // Prevent any further typing. } } } } } ); // Make the visual editor and html editor the same height if ( $( '#' + editor.id + '_ifr' ).is( ':visible' ) ) { $( '#' + editor.id + '_ifr' ).height( $( '#' + editor.id ).height() ); } // Add aria-describedby. if ( -1 !== editor_id.indexOf( 'forminator' ) ) { $( '#' + editor_id ).closest( '.wp-editor-wrap' ).attr( 'aria-describedby', editor_id + '-description' ); } }); $( document ).on( 'click', '.forminator-copy-btn', function( e ) { forminatorCopyTextToClipboard( $( this ).prev( '.forminator-draft-link' ).val() ); if ( ! $( this ).hasClass( 'copied' ) ) { $( this ).addClass( 'copied' ) $( this ).prepend( '✓ ' ); } } ); // Copy: Async + Fallback // https://stackoverflow.com/a/30810322 function forminatorFallbackCopyTextToClipboard( text ) { var textArea = document.createElement("textarea"); textArea.value = text; // Avoid scrolling to bottom textArea.style.top = "0"; textArea.style.left = "0"; textArea.style.position = "fixed"; document.body.appendChild(textArea); textArea.focus(); textArea.select(); try { var successful = document.execCommand('copy'); var msg = successful ? 'successful' : 'unsuccessful'; // console.log('Fallback: Copying text command was ' + msg); } catch (err) { // console.error('Fallback: Oops, unable to copy', err); } document.body.removeChild(textArea); } function forminatorCopyTextToClipboard (text ) { if (!navigator.clipboard) { forminatorFallbackCopyTextToClipboard(text); return; } navigator.clipboard.writeText(text).then(function() { // console.log('Async: Copying to clipboard was successful!'); }, function(err) { // console.error('Async: Could not copy text: ', err); }); } // Focus to nearest input when label is clicked function focus_to_nearest_input() { $( '.forminator-custom-form' ).find( '.forminator-label' ).on( 'click', function ( e ) { e.preventDefault(); var fieldLabel = $( this ); fieldLabel.next( '#' + fieldLabel.attr( 'for' ) ).focus(); }); } focus_to_nearest_input(); $( document ).on( 'after.load.forminator', focus_to_nearest_input ); $( document ).on( 'after.load.forminator', () => { forminator_render_captcha(); forminator_render_hcaptcha(); forminator_render_turnstile(); } ); // Elementor Popup show event jQuery( document ).on( 'elementor/popup/show', () => { forminator_render_captcha(); forminator_render_hcaptcha(); forminator_render_turnstile(); } ); /** * Sanitize the user input string. * * @param {string} string */ function sanitize_text_field( string ) { if ( typeof string === 'string') { var str = String(string).replace(/<\/?[^>]+(>|$)/g, ''); return str.trim(); } return string; } })(jQuery, window, document); // noinspection JSUnusedGlobalSymbols var forminator_render_turnstile = function () { jQuery('.forminator-turnstile').each(function () { // find closest form. var thisCaptcha = jQuery(this), form = thisCaptcha.closest('form'); if ( form.length > 0 && '' === thisCaptcha.html() ) { window.setTimeout( function() { var forminatorFront = form.data( 'forminatorFront' ); if ( typeof forminatorFront !== 'undefined' ) { forminatorFront.renderTurnstileCaptcha( thisCaptcha[0] ); } }, 100 ); } }); }; // noinspection JSUnusedGlobalSymbols var forminator_render_captcha = function () { // TODO: avoid conflict with another plugins that provide recaptcha // notify forminator front that grecaptcha has loaded and can be used jQuery('.forminator-g-recaptcha').each(function () { // find closest form var thisCaptcha = jQuery(this), form = thisCaptcha.closest('form'); if ( form.length > 0 && '' === thisCaptcha.html() ) { window.setTimeout( function() { var forminatorFront = form.data( 'forminatorFront' ); if ( typeof forminatorFront !== 'undefined' ) { forminatorFront.renderCaptcha( thisCaptcha[0] ); } }, 100 ); } }); }; // noinspection JSUnusedGlobalSymbols var forminator_render_hcaptcha = function () { // TODO: avoid conflict with another plugins that provide hcaptcha // notify forminator front that hcaptcha has loaded and can be used jQuery('.forminator-hcaptcha').each(function () { // find closest form var thisCaptcha = jQuery(this), form = thisCaptcha.closest('form'); if ( form.length > 0 && '' === thisCaptcha.html() ) { window.setTimeout( function() { var forminatorFront = form.data( 'forminatorFront' ); if ( typeof forminatorFront !== 'undefined' ) { forminatorFront.renderHcaptcha( thisCaptcha[0] ); } }, 100 ); } }); }; // Source: http://stackoverflow.com/questions/497790 var forminatorDateUtil = { month_number: function( v ) { var months_short = ['jan', 'feb', 'mar', 'apr', 'may', 'jun', 'jul', 'aug', 'sep', 'oct', 'nov', 'dec']; var months_full = ['january', 'february', 'march', 'april', 'may', 'june', 'july', 'august', 'september', 'october', 'november', 'december']; if( v.constructor === Number ) { return v; } var n = NaN; if( v.constructor === String ) { v = v.toLowerCase(); var index = months_short.indexOf( v ); if( index === -1 ) { index = months_full.indexOf( v ); } n = ( index === -1 ) ? NaN : index; } return n; }, convert: function( d ) { // Converts the date in d to a date-object. The input can be: // a date object: returned without modification // an array : Interpreted as [year,month,day]. NOTE: month is 0-11. // a number : Interpreted as number of milliseconds // since 1 Jan 1970 (a timestamp) // a string : Any format supported by the javascript engine, like // "YYYY/MM/DD", "MM/DD/YYYY", "Jan 31 2009" etc. // an object : Interpreted as an object with year, month and date // attributes. **NOTE** month is 0-11. return ( d.constructor === Date ? d : d.constructor === Array ? new Date( d[0], this.month_number( d[1] ), d[2] ) : jQuery.isNumeric( d ) ? new Date( 1 * d ) : d.constructor === Number ? new Date( d ) : d.constructor === String ? new Date( d ) : typeof d === "object" ? new Date( d.year, this.month_number( d.month ), d.date ) : NaN ); }, compare: function( a, b ) { // Compare two dates (could be of any type supported by the convert // function above) and returns: // -1 : if a < b // 0 : if a = b // 1 : if a > b // NaN : if a or b is an illegal date // NOTE: The code inside isFinite does an assignment (=). return ( isFinite( a = this.convert( a ).valueOf() ) && isFinite( b = this.convert( b ).valueOf() ) ? ( a > b ) - ( a < b ) : NaN ); }, inRange: function( d, start, end ) { // Checks if date in d is between dates in start and end. // Returns a boolean or NaN: // true : if d is between start and end (inclusive) // false : if d is before start or after end // NaN : if one or more of the dates is illegal. // NOTE: The code inside isFinite does an assignment (=). return ( isFinite( d = this.convert( d ).valueOf() ) && isFinite( start = this.convert( start ).valueOf() ) && isFinite( end = this.convert( end ).valueOf() ) ? start <= d && d <= end : NaN ); }, diffInDays: function( d1, d2 ) { d1 = this.convert( d1 ); d2 = this.convert( d2 ); if( typeof d1.getMonth !== 'function' || typeof d2.getMonth !== 'function' ) { return NaN; } var t2 = d2.getTime(); var t1 = d1.getTime(); return parseFloat((t2-t1)/(24*3600*1000)); }, diffInWeeks: function( d1, d2 ) { d1 = this.convert( d1 ); d2 = this.convert( d2 ); if( typeof d1.getMonth !== 'function' || typeof d2.getMonth !== 'function' ) { return NaN; } var t2 = d2.getTime(); var t1 = d1.getTime(); return parseInt((t2-t1)/(24*3600*1000*7)); }, diffInMonths: function( d1, d2 ) { d1 = this.convert( d1 ); d2 = this.convert( d2 ); if( typeof d1.getMonth !== 'function' || typeof d2.getMonth !== 'function' ) { return NaN; } var d1Y = d1.getFullYear(); var d2Y = d2.getFullYear(); var d1M = d1.getMonth(); var d2M = d2.getMonth(); return (d2M+12*d2Y)-(d1M+12*d1Y); }, diffInYears: function( d1, d2 ) { d1 = this.convert( d1 ); d2 = this.convert( d2 ); if( typeof d1.getMonth !== 'function' || typeof d2.getMonth !== 'function' ) { return NaN; } return d2.getFullYear()-d1.getFullYear(); }, }; PK �K}\k�;w� w� front.condition.jsnu �[��� // the semi-colon before function invocation is a safety net against concatenated // scripts and/or other plugins which may not be closed properly. ;// noinspection JSUnusedLocalSymbols (function ($, window, document, undefined) { "use strict"; // undefined is used here as the undefined global variable in ECMAScript 3 is // mutable (ie. it can be changed by someone else). undefined isn't really being // passed in so we can ensure the value of it is truly undefined. In ES5, undefined // can no longer be modified. // window and document are passed through as local variables rather than global // as this (slightly) quickens the resolution process and can be more efficiently // minified (especially when both are regularly referenced in your plugin). window.paypalHasCondition = []; // Create the defaults once var pluginName = "forminatorFrontCondition", defaults = { fields: {}, relations: {} }; // The actual plugin constructor function ForminatorFrontCondition(element, options, calendar) { this.element = element; this.$el = $(this.element); // jQuery has an extend method which merges the contents of two or // more objects, storing the result in the first object. The first object // is generally empty as we don't want to alter the default options for // future instances of the plugin this.settings = $.extend({}, defaults, options); this._defaults = defaults; this._name = pluginName; this.calendar = calendar[0]; this.init(); } // Avoid Plugin.prototype conflicts $.extend(ForminatorFrontCondition.prototype, { init: function () { var self = this, form = this.$el, $forminatorFields = this.$el.find( ".forminator-field input, .forminator-row input[type=hidden], .forminator-field select, .forminator-field textarea, .forminator-field-signature, .forminator-rating") ; // Duplicate rules for new repeated Group fields. if ( form.hasClass( 'forminator-grouped-fields' ) ) { let suffix = form.data( 'suffix' ); $.each( this.settings.fields, function ( key, val ) { let newKey = key + '-' + suffix; if ( ! form.find( '[name="' + newKey + '"]' ).length && ! form.find( '#' + newKey ).length ) { return; } let newVal = self.updateConditions( val, suffix, form ); self.settings['fields'][ newKey ] = newVal; } ); } this.add_missing_relations(); $forminatorFields.on( 'change input forminator.change', function (e) { var $element = $(this), element_id = $element.closest('.forminator-col').attr('id') ; if ( $element.is( 'input[type="radio"]' ) && 'input' === e.type ) { // Skip input events for radio buttons, handle only change events for them. return; } // Handle the email field when email confirmation is enabled. if ( $element.is( 'input[type="email"]' ) && element_id === undefined && $element.attr( 'id' ).startsWith( 'forminator-field-email-' ) ) { element_id = $element.closest( '.forminator-row-with-confirmation-email' ).parent( '.forminator-col' ).attr( 'id' ); } if (typeof element_id === 'undefined' || 0 === element_id.indexOf( 'slider-' ) ) { /* * data-multi attribute was added to Name field - multiple * We had to use name attribute for Name multi-field because we cannot change * the IDs of elements. Some functions rely on the ID text pattern already. */ if ( $element.attr( 'data-multi' ) === '1' || 'hidden' === $element.attr( 'type' ) ) { element_id = $element.attr( 'name' ); } else { element_id = $element.attr( 'id' ); } } element_id = element_id.trim(); //lookup condition of fields if (!self.has_relations(element_id) && !self.has_siblings(element_id)) return false; if( self.has_siblings(element_id) ) { self.trigger_fake_parent_date_field(element_id); } if(!self.has_relations(element_id) && self.has_siblings(element_id)){ self.trigger_siblings(element_id); return false; } self.process_relations( element_id, $element, e ); self.paypal_button_condition(); self.maybe_clear_upload_container(); }); // Trigger change event to textarea that has tinyMCE editor // For non-ajax form load $( document ).on( 'tinymce-editor-init', function ( event, editor ) { editor.on( 'change', function( e ) { form.find( '#' + $(this).attr( 'id' ) ).change(); }); }); // For ajax form load if ( typeof tinyMCE !== 'undefined' && tinyMCE.activeEditor ) { tinyMCE.activeEditor.on( 'change', function( e ) { form.find( '#' + $(this).attr( 'id' ) ).change(); }); } this.$el.find('.forminator-button.forminator-button-back, .forminator-button.forminator-button-next').on("click", function () { form.find('.forminator-field input:not([type="file"]), .forminator-row input[type=hidden], .forminator-field select, .forminator-field textarea').trigger( 'forminator.change', 'forminator_emulate_trigger' ); }); // Simulate change this.$el.find('.forminator-field input, .forminator-row input[type=hidden], .forminator-field select, .forminator-field textarea').trigger( 'forminator.change', 'forminator_emulate_trigger' ); this.init_events(); }, updateConditions: function( data, suffix, form ) { // Clone data. var newData = JSON.parse(JSON.stringify(data)); if ( ! newData.conditions || ! Array.isArray( newData.conditions ) ) { return newData; } const currentGroup = form.closest('.forminator-col').prop( 'id' ); newData.conditions.forEach( function ( condition ) { if ( ! condition.field || ! condition.group ) { return; } // Update dependency field from if it's in the same group. if ( condition.group === currentGroup ) { condition.field = condition.field + '-' + suffix; } } ); return newData; }, process_relations: function( element_id, $element, e ) { var self = this; // Check if the field has any relations var relations = self.get_relations( element_id ); // Loop all relations the field have relations.forEach(function (relation) { var logic = self.get_field_logic(relation), action = logic.action, rule = logic.rule, conditions = logic.conditions, // Conditions rules matches = 0 // Number of matches ; // If paypal has logic, add form id to paypalHasCondition. if ( 0 === relation.indexOf( 'paypal' ) ) { if ( 0 !== logic.length && ! window.paypalHasCondition.includes( self.$el.data( 'form-id' ) ) ) { window.paypalHasCondition.push( self.$el.data( 'form-id' ) ); } } conditions.forEach(function (condition) { // If rule is applicable save in matches if (self.is_applicable_rule(condition, action)) { matches++; } }); if ((rule === "all" && matches === conditions.length) || (rule === "any" && matches > 0)) { //check if the given $element is an jQuery object if( $element instanceof jQuery ) { var pagination = $element.closest('.forminator-pagination'); } if (relation === 'submit' && typeof pagination !== 'undefined') { self.toggle_field(relation, 'show', "valid"); } self.toggle_field(relation, action, "valid"); if (self.has_relations(relation)){ if(action === 'hide'){ self.hide_element(relation, e); }else{ self.show_element(relation, e); } } } else { self.toggle_field(relation, action, "invalid"); if (self.has_relations(relation)){ if(action === 'show'){ self.hide_element(relation, e); }else{ self.show_element(relation, e); } } } }); }, /** * Register related events * * @since 1.0.3 */ init_events: function () { var self = this; this.$el.on('forminator.front.condition.restart', function (e) { self.on_restart(e); }); }, /** * Restart conditions * * @since 1.0.3 * * @param e */ on_restart: function (e) { // restart condition this.$el.find('.forminator-field input, .forminator-row input[type=hidden], .forminator-field select, .forminator-field textarea').trigger( 'forminator.change', 'forminator_emulate_trigger' ); }, /** * Add missing relations based on fields.conditions */ add_missing_relations: function () { var self = this; var missedRelations = {}; if (typeof this.settings.fields !== "undefined") { var conditionsFields = this.settings.fields; Object.keys(conditionsFields).forEach(function (key) { var conditions = conditionsFields[key]['conditions']; conditions.forEach(function (condition) { var relatedField = condition.field; if (!self.has_relations(relatedField)) { if (typeof missedRelations[relatedField] === 'undefined') { missedRelations[relatedField] = []; } missedRelations[relatedField].push(key); } else { let relations = self.get_relations(relatedField); if ( -1 !== $.inArray( key, relations ) ) { return; } self.settings.relations[relatedField].push( key ); } }); }); } Object.keys(missedRelations).forEach(function (relatedField) { self.settings.relations[relatedField] = missedRelations[relatedField]; }); }, get_field_logic: function (element_id) { if (typeof this.settings.fields[element_id] === "undefined") return []; return this.settings.fields[element_id]; }, has_relations: function (element_id) { return typeof this.settings.relations[element_id] !== "undefined"; }, get_relations: function (element_id) { if (!this.has_relations(element_id)) return []; return $.unique( this.settings.relations[element_id] ); }, get_field_value: function (element_id) { if ( '' === element_id ) { return ''; } var $element = this.get_form_field(element_id), value = $element.val(); //check the type of input if (this.field_is_radio($element)) { value = $element.filter(":checked").val(); } else if (this.field_is_signature($element)) { value = $element.find( "input[id$='_data']" ).val(); } else if (this.field_is_checkbox($element)) { value = []; $element.each(function () { if ($(this).is(':checked')) { value.push($(this).val().toLowerCase()); } }); // if value is empty, return it as null if ( 0 === value.length ) { value = null; } // Check if the element is a multi-select. } else if (this.field_is_select($element) && $element.attr( "multiple" ) ) { value = []; var selected = $element.find("option").filter(':selected'); if (selected.length > 0) { selected.each(function () { value.push($(this).val().toLowerCase()); }); } else { value = null; } } else if ( this.field_is_textarea_wpeditor( $element ) ) { if ( typeof tinyMCE !== 'undefined' && tinyMCE.activeEditor ) { value = tinyMCE.activeEditor.getContent(); } } else if ( this.field_has_inputMask( $element ) ) { value = parseFloat( $element.inputmask('unmaskedvalue').replace(',','.') ); if ( 0 <= element_id.indexOf( 'calculation-' ) ) { return value; } } else if ( this.field_is_rating( $element ) ) { value = (typeof value === 'string' && value.split("/")[0]) || 0; return value; } if (!value) return ""; return value; }, get_date_field_value: function(element_id){ if ( '' === element_id ) { return ''; } var $element = this.get_form_field(element_id); //element may not be a real jQuery element for fake virtual parent date field var fake_field = true; if( $element instanceof jQuery ) { fake_field = false; //element may just be the wrapper div of child fields if( $element.hasClass('forminator-col') ) { fake_field = true; } } var value = ""; if ( !fake_field && this.field_is_datepicker($element) ){ value = $element.val(); //check if formats are accepted switch ( $element.data('format') ) { case 'dd/mm/yy': value = $element.val().split("/").reverse().join("-"); break; case 'dd.mm.yy': value = $element.val().split(".").reverse().join("-"); break; case 'dd-mm-yy': value = $element.val().split("-").reverse().join("-"); break; } if ( '' !== value ) { var formattedDate = new Date(value); value = {'year':formattedDate.getFullYear(), 'month':formattedDate.getMonth(), 'date':formattedDate.getDate(), 'day':formattedDate.getDay()}; } } else { var parent = ( fake_field === true )? element_id : $element.data('parent'); var year = this.get_form_field_value(parent+'-year'), mnth = this.get_form_field_value(parent+'-month'), day = this.get_form_field_value(parent+'-day'); if( year !== "" && mnth !== "" && day !== "" ){ var formattedDate = new Date( year + '-' + mnth + '-' + day ); value = {'year':formattedDate.getFullYear(), 'month':formattedDate.getMonth(), 'date':formattedDate.getDate(), 'day':formattedDate.getDay() }; } } if (!value) return ""; return value; }, field_has_inputMask: function ( $element ) { var hasMask = false; $element.each(function () { if ( undefined !== $( this ).attr( 'data-inputmask' ) ) { hasMask = true; //break return false; } }); return hasMask; }, field_is_radio: function ($element) { var is_radio = false; $element.each(function () { if ($(this).attr('type') === 'radio') { is_radio = true; //break return false; } }); return is_radio; }, field_is_signature: function($element) { var is_signature = false; $element.each(function () { if ($(this).find('.forminator-field-signature').length > 0) { is_signature = true; //break return false; } }); return is_signature; }, field_is_datepicker: function ($element) { var is_date = false; $element.each(function () { if ($(this).hasClass('forminator-datepicker')) { is_date = true; //break return false; } }); return is_date; }, field_is_checkbox: function ($element) { var is_checkbox = false; $element.each(function () { if ($(this).attr('type') === 'checkbox') { is_checkbox = true; //break return false; } }); return is_checkbox; }, /* field_is_consent: function ( $element ) { var is_consent = false; $( 'input[name="' + $element + '"]' ).each(function () { if ( $element.indexOf( 'consent' ) >= 0 ) { is_consent = true; //break return false; } }); return is_consent; }, */ field_is_select: function ($element) { return $element.is('select'); }, field_is_textarea_wpeditor: function ($element) { var is_textarea_wpeditor = false; $element.each(function () { if ( $(this).parent( '.wp-editor-container' ).parent( 'div' ).hasClass( 'tmce-active' ) ) { is_textarea_wpeditor = true; //break return false; } }); return is_textarea_wpeditor; }, field_is_upload: function ($element) { var is_upload = false; if ( -1 !== $element.indexOf( 'upload' ) ) { is_upload = true; } return is_upload; }, field_is_rating: function ($element) { var is_rating = false; $element.each(function () { if ( $(this).hasClass('forminator-rating') ) { is_rating = true; //break return false; } }); return is_rating; }, // used in forminatorFrontCalculate get_form_field: function (element_id) { let $form = this.$el; if ( $form.hasClass( 'forminator-grouped-fields' ) ) { $form = $form.closest( 'form.forminator-ui' ); } //find element by suffix -field on id input (default behavior) var $element = $form.find('#' + element_id + '-field'); if ($element.length === 0) { $element = $form.find('.' + element_id + '-payment'); if ($element.length === 0) { //find element by its on name (for radio on singlevalue) $element = $form.find('input[name="' + element_id + '"]'); if ($element.length === 0) { // for text area that have uniqid, so we check its name instead $element = $form.find('textarea[name="' + element_id + '"]'); if ($element.length === 0) { //find element by its on name[] (for checkbox on multivalue) $element = $form.find('input[name="' + element_id + '[]"]'); if ($element.length === 0) { //find element by select name $element = $form.find('select[name="' + element_id + '"]'); if ($element.length === 0) { $element = $form.find('select[name="' + element_id + '[]"]'); if ($element.length === 0) { //find element by direct id (for name field mostly) //will work for all field with element_id-[somestring] $element = $form.find('#' + element_id); } } } } } } } return $element; }, // Extension of get_form_field to get value get_form_field_value: function (element_id) { //find element by suffix -field on id input (default behavior) var $form_id = this.$el.data( 'form-id' ), $uid = this.$el.data( 'uid' ), $element = this.$el.find('#forminator-form-' + $form_id + '__field--' + element_id + '_' + $uid ); if ($element.length === 0) { var $element = this.$el.find('#' + element_id + '-field' ); if ($element.length === 0) { //find element by its on name (for radio on singlevalue) $element = this.$el.find('input[name="' + element_id + '"]'); if ($element.length === 0) { // for text area that have uniqid, so we check its name instead $element = this.$el.find('textarea[name="' + element_id + '"]'); if ($element.length === 0) { //find element by its on name[] (for checkbox on multivalue) $element = this.$el.find('input[name="' + element_id + '[]"]'); if ($element.length === 0) { //find element by select name $element = this.$el.find('select[name="' + element_id + '"]'); if ($element.length === 0) { $element = this.$el.find('select[name="' + element_id + '[]"]'); if ($element.length === 0) { //find element by direct id (for name field mostly) //will work for all field with element_id-[somestring] $element = this.$el.find('#' + element_id); } } } } } } } return $element.val(); }, is_numeric: function (number) { return !isNaN(parseFloat(number)) && isFinite(number); }, is_date_rule: function(operator){ var dateRules = ['day_is', 'day_is_not', 'month_is', 'month_is_not', 'is_before', 'is_after', 'is_before_n_or_more_days', 'is_before_less_than_n_days', 'is_after_n_or_more_days', 'is_after_less_than_n_days']; return dateRules.includes( operator ); }, has_siblings: function(element){ if ( '' === element ) { return false; } element = this.get_form_field(element); if( element.data('parent') ) return true; return false; }, trigger_fake_parent_date_field: function(element_id){ var element = this.get_form_field(element_id), parent = element.data('parent'); this.process_relations( parent, {}, {}); }, trigger_siblings: function(element_id){ var self = this, element = self.get_form_field(element_id), parent = element.data('parent'), siblings = []; siblings = [parent+'-year', parent+'-month', parent+'-day']; $.each(siblings, function( index, sibling ) { if( element_id !== sibling && self.has_relations(sibling) ){ self.get_form_field(sibling).trigger('change'); } }); }, is_applicable_rule: function (condition, action) { if (typeof condition === "undefined") return false; if( this.is_date_rule( condition.operator ) ){ var value1 = this.get_date_field_value(condition.field); }else{ var value1 = this.get_field_value(condition.field); } var value2 = condition.value, operator = condition.operator ; if (action === "show") { return this.is_matching(value1, value2, operator) && this.is_hidden(condition.field); } else { return this.is_matching(value1, value2, operator); } }, is_hidden: function (element_id) { var $element_id = this.get_form_field(element_id), $column_field = $element_id.closest('.forminator-col'), $row_field = $column_field.closest('.forminator-row') ; if ( $row_field.hasClass("forminator-hidden-option") ) { return true; } if( $row_field.hasClass("forminator-hidden") ) { return false; } return true; }, is_matching: function (value1, value2, operator) { // Match values case var isArrayValue = Array.isArray(value1); // Match values case if (typeof value1 === 'string') { value1 = value1.toLowerCase(); } if(typeof value2 === 'string'){ value2 = value2.toLowerCase(); if(operator === 'month_is' || operator === 'month_is_not'){ var months = { 'jan':0, 'feb':1, 'mar':2, 'apr':3, 'may':4, 'jun':5, 'jul':6, 'aug':7, 'sep':8, 'oct':9, 'nov':10, 'dec':11 }; if($.inArray(value2, months)){ value2 = months[ value2 ]; } } if(operator === 'day_is' || operator === 'day_is_not'){ var days = { 'su':0, 'mo':1, 'tu':2, 'we':3, 'th':4, 'fr':5, 'sa':6 }; if($.inArray(value2, days)){ value2 = days[ value2 ]; } } } switch (operator) { case "is": if (!isArrayValue) { if ( this.is_numeric( value1 ) && this.is_numeric( value2 ) ) { return Number( value1 ) === Number( value2 ); } return value1 === value2; } else { return $.inArray(value2, value1) > -1; } case "is_not": if (!isArrayValue) { if ( this.is_numeric( value1 ) && this.is_numeric( value2 ) ) { return Number( value1 ) !== Number( value2 ); } return value1 !== value2; } else { return $.inArray(value2, value1) === -1; } case "is_great": // typecasting to integer, with return `NaN` when its literal chars, so `is_numeric` will fail value1 = +value1; value2 = +value2; return this.is_numeric(value1) && this.is_numeric(value2) ? value1 > value2 : false; case "is_less": value1 = +value1; value2 = +value2; return this.is_numeric(value1) && this.is_numeric(value2) ? value1 < value2 : false; case "contains": return this.contains(value1, value2); case "does_not_contain": return !this.contains(value1, value2); case "starts": return value1.startsWith(value2); case "ends": return value1.endsWith(value2); case "month_is": return value1.month === value2; case "month_is_not": return value1.month !== value2; case "day_is": return value1.day === value2; case "day_is_not": return value1.day !== value2; case "is_before": return this.date_is_smaller( value1, value2 ); case "is_after": return this.date_is_grater( value1, value2 ); case "is_before_n_or_more_days": return this.date_is_n_days_before_current_date( value1, value2 ); case "is_before_less_than_n_days": return this.date_is_less_than_n_days_before_current_date( value1, value2 ); case "is_after_n_or_more_days": return this.date_is_n_days_after_current_date( value1, value2 ); case "is_after_less_than_n_days": return this.date_is_less_than_n_days_after_current_date( value1, value2 ); } // Return false if above are not valid return false; }, contains: function (field_value, value) { return field_value.toLowerCase().indexOf(value) >= 0; }, date_is_grater: function( date1, date2 ) { date1 = this.set_date_as_utc_time( date1 ); return forminatorDateUtil.compare( date1, date2 ) === 1; }, set_date_as_utc_time( date ) { if ( undefined !== date.month && undefined !== date.date && undefined !== date.year ) { const utcDate = new Date( `${ date.month + 1 }/${ date.date }/${ date.year } UTC` ); date = utcDate.getTime(); } return date; }, date_is_smaller: function( date1, date2 ) { date1 = this.set_date_as_utc_time( date1 ); return forminatorDateUtil.compare( date1, date2 ) === -1; }, date_is_equal: function( date1, date2 ) { return forminatorDateUtil.compare( date1, date2 ) === 0; }, date_is_n_days_before_current_date: function( date1, n ) { n = parseInt( n ); var current_date = this.get_current_date(); var diff = forminatorDateUtil.diffInDays( date1, current_date ); if( isNaN( diff ) ) { return false; } if( n === 0 ) { return ( diff === n ); } else { return ( diff >= n ); } }, date_is_less_than_n_days_before_current_date: function( date1, n ) { n = parseInt( n ); var current_date = this.get_current_date(); var diff = forminatorDateUtil.diffInDays( date1, current_date ); if( isNaN( diff ) ) { return false; } return ( diff < n && diff > 0 ); }, date_is_n_days_after_current_date: function( date1, n ) { n = parseInt( n ); var current_date = this.get_current_date(); var diff = forminatorDateUtil.diffInDays( current_date, date1 ); if( isNaN( diff ) ) { return false; } if( n === 0 ) { return ( diff === n ); } else { return ( diff >= n ); } }, date_is_less_than_n_days_after_current_date: function( date1, n ) { n = parseInt( n ); var current_date = this.get_current_date(); var diff = forminatorDateUtil.diffInDays( current_date, date1 ); if( isNaN( diff ) ) { return false; } return ( diff < n && diff > 0 ); }, get_current_date: function() { return new Date(); }, toggle_field: function (element_id, action, type) { var self = this, $element_id = this.get_form_field(element_id), $column_field = $element_id.closest('.forminator-col'), $hidden_upload = $column_field.find('.forminator-input-file-required'), $hidden_signature = $column_field.find('[id ^=ctlSignature][id $=_data]'), $hidden_wp_editor = $column_field.find('.forminator-wp-editor-required'), $row_field = $column_field.closest('.forminator-row'), $sub_row_field = $column_field.closest('.forminator-row-inside'), // Used for Email Confirmation. $sub_row_fields = $sub_row_field.add($sub_row_field.parent()), // Include Email Confirmation parent column. $pagination_next_field = this.$el.find('.forminator-pagination-footer').find('.forminator-button-next'), submit_selector = 'submit' === element_id ? '.forminator-button-submit' : '#forminator-paypal-submit', $pagination_field = this.$el.find( submit_selector ) ; // Handle show action if (action === "show") { if (type === "valid") { $row_field.removeClass('forminator-hidden'); $sub_row_fields.removeClass('forminator-hidden'); $column_field.removeClass('forminator-hidden'); $pagination_next_field.removeClass('forminator-hidden'); if ($hidden_upload.length > 0) { $hidden_upload.addClass('do-validate'); } if ($hidden_wp_editor.length > 0) { $hidden_wp_editor.addClass('do-validate'); } if ($hidden_signature.length > 0) { $hidden_signature.addClass('do-validate'); } setTimeout( function() { $pagination_field = self.$el.find( submit_selector ); if ( 'submit' === element_id ) { $pagination_field.removeClass('forminator-hidden'); } if ( 0 === element_id.indexOf( 'paypal' ) ) { self.$el.find( '.forminator-button-submit' ).addClass( 'forminator-hidden' ); $pagination_field.removeClass( 'forminator-hidden' ); } }, 100 ); } else { $column_field.addClass('forminator-hidden'); setTimeout( function() { $pagination_field = self.$el.find( submit_selector ); if ( 'submit' === element_id ) { $pagination_field.addClass('forminator-hidden'); } if ( 0 === element_id.indexOf( 'paypal' ) ) { self.$el.find( '.forminator-button-submit' ).removeClass( 'forminator-hidden' ); $pagination_field.addClass('forminator-hidden'); } }, 100 ); if ($hidden_upload.length > 0) { $hidden_upload.removeClass('do-validate'); } if ($hidden_wp_editor.length > 0) { $hidden_wp_editor.removeClass('do-validate'); } if ($hidden_signature.length > 0) { $hidden_signature.removeClass('do-validate'); } if ($sub_row_field.find('> .forminator-col:not(.forminator-hidden)').length === 0) { $sub_row_fields.addClass('forminator-hidden'); } if ($row_field.find('> .forminator-col:not(.forminator-hidden)').length === 0) { $row_field.addClass('forminator-hidden'); } } } // Handle hide action if (action === "hide") { if (type === "valid") { $column_field.addClass('forminator-hidden'); $pagination_field.addClass('forminator-hidden'); if ($hidden_upload.length > 0) { $hidden_upload.removeClass('do-validate'); } if ($hidden_wp_editor.length > 0) { $hidden_wp_editor.removeClass('do-validate'); } if ($hidden_signature.length > 0) { $hidden_signature.removeClass('do-validate'); } if ($row_field.find('> .forminator-col:not(.forminator-hidden)').length === 0) { $row_field.addClass('forminator-hidden'); } if ($sub_row_field.find('> .forminator-col:not(.forminator-hidden)').length === 0) { $sub_row_fields.addClass('forminator-hidden'); } setTimeout( function() { $pagination_field = self.$el.find( submit_selector ); if ( 'submit' === element_id ) { $pagination_field.addClass('forminator-hidden'); } if ( 0 === element_id.indexOf( 'paypal' ) ) { self.$el.find( '.forminator-button-submit' ).removeClass( 'forminator-hidden' ); $pagination_field.addClass( 'forminator-hidden' ); } }, 100 ); } else { $row_field.removeClass('forminator-hidden'); $sub_row_fields.removeClass('forminator-hidden'); $column_field.removeClass('forminator-hidden'); $pagination_field.removeClass('forminator-hidden'); if ($hidden_upload.length > 0) { $hidden_upload.addClass('do-validate'); } if ($hidden_wp_editor.length > 0) { $hidden_wp_editor.addClass('do-validate'); } if ($hidden_signature.length > 0) { $hidden_signature.addClass('do-validate'); } setTimeout( function() { $pagination_field = self.$el.find( submit_selector ); if ( 'submit' === element_id ) { $pagination_field.removeClass('forminator-hidden'); } if ( 0 === element_id.indexOf( 'paypal' ) ) { self.$el.find( '.forminator-button-submit' ).addClass( 'forminator-hidden' ); $pagination_field.removeClass( 'forminator-hidden' ); } }, 100 ); } } this.$el.trigger('forminator:field:condition:toggled'); this.toggle_confirm_field( element_id, action, type ); }, clear_value: function(element_id, e) { var $element = this.get_form_field(element_id), value = this.get_field_value(element_id) ; if ( $element.hasClass('forminator-cleared-value') ) { return; } $element.addClass('forminator-cleared-value'); // Execute only on human action if (e.originalEvent !== undefined) { if (this.field_is_radio($element)) { $element.attr('data-previous-value', value); $element.removeAttr('checked'); } else if (this.field_is_checkbox($element)) { $element.each(function () { $(this).attr('data-previous-value', value); $(this).prop('checked', false); }); } else { $element.attr('data-previous-value', value); $element.val(''); } } }, restore_value: function(element_id, e) { var $element = this.get_form_field(element_id), value = $element.attr('data-previous-value') ; if ( ! $element.hasClass('forminator-cleared-value') ) { return; } // Execute only on human action if (e.originalEvent === undefined) { return; } $element.removeClass('forminator-cleared-value'); // Return after class is removed if field is upload if ( this.field_is_upload( element_id ) ) { return; } if(!value) return; if (this.field_is_radio($element)) { $element.val([value]); } else if (this.field_is_checkbox($element)) { $element.each(function () { var value = $(this).attr('data-previous-value'); if (!value) return; if (value.indexOf($(this).val().toLowerCase()) >= 0) { $(this).prop( "checked", true ); } }); } else { $element.val(value); } }, hide_element: function (relation, e){ var self = this, sub_relations = self.get_relations(relation); self.clear_value(relation, e); sub_relations.forEach(function (sub_relation) { // Do opposite action because condition is definitely not met because dependent field is hidden. let logic = self.get_field_logic(sub_relation), action = 'hide' === logic.action ? 'show' : 'hide'; self.toggle_field(sub_relation, action, "valid"); if (self.has_relations(sub_relation)) { if ( 'hide' === action ) { self.hide_element(sub_relation, e); } else { self.show_element(sub_relation, e); } } }); }, show_element: function (relation, e){ var self = this, sub_relations = self.get_relations(relation) ; this.restore_value(relation, e); this.textareaFix(this.$el, relation, e); sub_relations.forEach(function (sub_relation) { var logic = self.get_field_logic(sub_relation), action = logic.action, rule = logic.rule, conditions = logic.conditions, // Conditions rules matches = 0 // Number of matches ; conditions.forEach(function (condition) { // If rule is applicable save in matches if (self.is_applicable_rule(condition, action)) { matches++; } }); if ((rule === "all" && matches === conditions.length) || (rule === "any" && matches > 0)) { self.toggle_field(sub_relation, action, "valid"); }else{ self.toggle_field(sub_relation, action, "invalid"); } if (self.has_relations(sub_relation)) { sub_relations = self.show_element(sub_relation, e); } }); }, paypal_button_condition: function() { var paymentElement = this.$el.find('.forminator-paypal-row'), paymentPageElement = this.$el.find('.forminator-pagination-footer').find('.forminator-button-paypal'); if( paymentElement.length > 0 ) { this.$el.find('.forminator-button-submit').closest('.forminator-row').removeClass('forminator-hidden'); if( ! paymentElement.hasClass('forminator-hidden') ) { this.$el.find('.forminator-button-submit').closest('.forminator-row').addClass('forminator-hidden'); } } if ( paymentPageElement.length > 0 ) { if( paymentPageElement.hasClass('forminator-hidden') ) { this.$el.find('.forminator-button-submit').removeClass('forminator-hidden'); } else{ this.$el.find('.forminator-button-submit').addClass('forminator-hidden'); } } }, maybe_clear_upload_container: function() { this.$el.find( '.forminator-row.forminator-hidden input[type="file"]' ).each( function () { if ( '' === $(this).val() ) { if ( $(this).parent().hasClass( 'forminator-multi-upload' ) ) { $(this).parent().siblings( '.forminator-uploaded-files' ).empty(); } else { $(this).siblings( 'span' ).text( $(this).siblings( 'span' ).data( 'empty-text' ) ); $(this).siblings( '.forminator-button-delete' ).hide(); } } }); }, // Fixes textarea bug with labels when using Material design style textareaFix: function (form ,relation, e){ var label = $( '#' + relation + ' .forminator-label' ) ; if ( relation.includes( 'textarea' ) && form.hasClass( 'forminator-design--material' ) && 0 < label.length ) { var materialTextarea = $( '#' + relation + ' .forminator-textarea'), labelPaddingTop = label.height() + 9 // Based on forminator-form.js ; label.css({ 'padding-top': labelPaddingTop + 'px' }); materialTextarea.css({ 'padding-top': labelPaddingTop + 'px' }); } }, // Maybe toggle confirm field if necessary. toggle_confirm_field: function ( element_id, action, type ) { const confirmFieldId = 'confirm_' + element_id, $confirmField = this.get_form_field( confirmFieldId ); if ( $confirmField.length ) { this.toggle_field(confirmFieldId, action, type); } }, }); // A really lightweight plugin wrapper around the constructor, // preventing against multiple instantiations $.fn[pluginName] = function (options, calendar) { return this.each(function () { if (!$.data(this, pluginName)) { $.data(this, pluginName, new ForminatorFrontCondition(this, options, calendar)); } }); }; })(jQuery, window, document); PK �K}\��i �a �a front.payment.jsnu �[��� // the semi-colon before function invocation is a safety net against concatenated // scripts and/or other plugins which may not be closed properly. ;// noinspection JSUnusedLocalSymbols (function ($, window, document, undefined) { "use strict"; // Polyfill if (!Object.assign) { Object.defineProperty(Object, 'assign', { enumerable: false, configurable: true, writable: true, value: function(target, firstSource) { 'use strict'; if (target === undefined || target === null) { throw new TypeError('Cannot convert first argument to object'); } var to = Object(target); for (var i = 1; i < arguments.length; i++) { var nextSource = arguments[i]; if (nextSource === undefined || nextSource === null) { continue; } var keysArray = Object.keys(Object(nextSource)); for (var nextIndex = 0, len = keysArray.length; nextIndex < len; nextIndex++) { var nextKey = keysArray[nextIndex]; var desc = Object.getOwnPropertyDescriptor(nextSource, nextKey); if (desc !== undefined && desc.enumerable) { to[nextKey] = nextSource[nextKey]; } } } return to; } }); } // undefined is used here as the undefined global variable in ECMAScript 3 is // mutable (ie. it can be changed by someone else). undefined isn't really being // passed in so we can ensure the value of it is truly undefined. In ES5, undefined // can no longer be modified. // window and document are passed through as local variables rather than global // as this (slightly) quickens the resolution process and can be more efficiently // minified (especially when both are regularly referenced in your plugin). // Create the defaults once var pluginName = "forminatorFrontPayment", defaults = { type: 'stripe', paymentEl: null, paymentRequireSsl: false, generalMessages: {}, }; // The actual plugin constructor function ForminatorFrontPayment(element, options) { this.element = element; this.$el = $(this.element); // jQuery has an extend method which merges the contents of two or // more objects, storing the result in the first object. The first object // is generally empty as we don't want to alter the default options for // future instances of the plugin this.settings = $.extend({}, defaults, options); this._defaults = defaults; this._name = pluginName; this._stripeData = null; this._stripe = null; this._cardElement = null; this._stripeToken = null; this._beforeSubmitCallback = null; this._form = null; this._paymentIntent = null; this.init(); } // Avoid Plugin.prototype conflicts $.extend(ForminatorFrontPayment.prototype, { init: function () { if (!this.settings.paymentEl || typeof this.settings.paymentEl.data() === 'undefined') { return; } var self = this; this._stripeData = this.settings.paymentEl.data(); if ( false === this.mountCardField() ) { return; } $(this.element).on('payment.before.submit.forminator', function (e, formData, callback) { self._form = self.getForm(e); self._beforeSubmitCallback = callback; self.validateStripe(e, formData); }); this.$el.on("forminator:form:submit:stripe:3dsecurity", function(e, secret, subscription) { self.validate3d(e, secret, subscription); }); // Listen for fields change to update ZIP mapping this.$el.find( 'input.forminator-input, .forminator-input input, .forminator-field-textarea textarea, .forminator-checkbox input, .forminator-radio input, select.forminator-select2' ).each(function () { $( this ).on( 'change', function ( e, param1 ) { if ( param1 !== 'forminator_emulate_trigger' ) { self.mapZip( e ); } } ); }).trigger( 'change' ); }, validate3d: function( e, secret, subscription ) { var self = this; if ( subscription ) { this._stripe.confirmCardPayment(secret, { payment_method: { card: self._cardElement, ...self.getBillingData(), }, }) .then(function(result) { self.$el.find('#forminator-stripe-subscriptionid').val( subscription ); if (self._beforeSubmitCallback) { self._beforeSubmitCallback.call(); } }); } else { this._stripe.retrievePaymentIntent( secret ).then(function(result) { if ( result.paymentIntent.status === 'requires_action' || result.paymentIntent.status === 'requires_source_action' ) { self._stripe .confirmCardPayment( secret, { payment_method: { card: self._cardElement, ...self.getBillingData(), }, } ) .then( function ( result ) { if ( self._beforeSubmitCallback ) { self._beforeSubmitCallback.call(); } } ); } }); } }, validateStripe: function(e, formData) { var self = this; this._stripe.createToken(this._cardElement).then(function (result) { if (result.error) { self.showCardError(result.error.message, true); self.$el.find( 'button' ).removeAttr( 'disabled' ); } else { self.hideCardError(); self._stripe.createPaymentMethod('card', self._cardElement, self.getBillingData()).then(function (result) { var paymentMethod = self.getObjectValue(result, 'paymentMethod'); self._stripeData['paymentMethod'] = self.getObjectValue(paymentMethod, 'id'); self.updateAmount(e, formData, result); }); } }); }, isValid: function(focus) { var self = this; this._stripe.createToken(this._cardElement).then(function (result) { if (result.error) { self.showCardError(result.error.message, focus); } else { self.hideCardError(); } }); }, getForm: function(e) { var $form = $( e.target ); if(!$form.hasClass('forminator-custom-form')) { $form = $form.closest('form.forminator-custom-form'); } return $form; }, updateAmount: function(e, formData, result) { e.preventDefault(); var self = this; var updateFormData = formData; var paymentMethod = this.getObjectValue(result, 'paymentMethod'); //Method set() doesn't work in IE11 updateFormData.append( 'action', 'forminator_update_payment_amount' ); updateFormData.append( 'paymentid', this.getStripeData('paymentid') ); updateFormData.append( 'payment_method', this.getObjectValue(paymentMethod, 'id') ); var receipt = this.getStripeData('receipt'); var receiptEmail = this.getStripeData('receiptEmail'); var receiptObject = {}; if( receipt && receiptEmail ) { var emailValue = this.get_field_value(receiptEmail) || ''; updateFormData.append( 'receipt_email', emailValue ); } $.ajax({ type: 'POST', url: window.ForminatorFront.ajaxUrl, data: updateFormData, cache: false, contentType: false, processData: false, beforeSend: function () { if( typeof self.settings.has_loader !== "undefined" && self.settings.has_loader ) { // Disable form fields self._form.addClass('forminator-fields-disabled'); var $target_message = self._form.find('.forminator-response-message'); $target_message.html('<p>' + self.settings.loader_label + '</p>'); self.focus_to_element($target_message); $target_message.removeAttr("aria-hidden") .prop("tabindex", "-1") .removeClass('forminator-success forminator-error') .addClass('forminator-loading forminator-show'); } self._form.find('button').attr('disabled', true); }, success: function (data) { if (data.success === true) { // Store payment id if (typeof data.data !== 'undefined' && typeof data.data.paymentid !== 'undefined') { self.$el.find('#forminator-stripe-paymentid').val(data.data.paymentid); self.$el.find('#forminator-stripe-paymentmethod').val(self._stripeData['paymentMethod']); self._stripeData['paymentid'] = data.data.paymentid; self._stripeData['secret'] = data.data.paymentsecret; self.handleCardPayment(data, e, formData); } else { self.show_error('Invalid Payment Intent ID'); } } else { self.show_error(data.data.message); if(data.data.errors.length) { self.show_messages(data.data.errors); } var $captcha_field = self._form.find('.forminator-g-recaptcha'); if ($captcha_field.length) { $captcha_field = $($captcha_field.get(0)); var recaptcha_widget = $captcha_field.data('forminator-recapchta-widget'), recaptcha_size = $captcha_field.data('size'); if (recaptcha_size === 'invisible') { window.grecaptcha.reset(recaptcha_widget); } } } }, error: function (err) { var $message = err.status === 400 ? window.ForminatorFront.cform.upload_error : window.ForminatorFront.cform.error; self.show_error($message); } }) }, show_error: function(message) { var $target_message = this._form.find('.forminator-response-message'); this._form.find('button').removeAttr('disabled'); $target_message.removeAttr("aria-hidden") .prop("tabindex", "-1") .removeClass('forminator-loading') .addClass('forminator-error forminator-show'); $target_message.html('<p>' + message + '</p>'); this.focus_to_element($target_message); this.enable_form(); }, enable_form: function() { if( typeof this.settings.has_loader !== "undefined" && this.settings.has_loader ) { var $target_message = this._form.find('.forminator-response-message'); // Enable form fields this._form.removeClass('forminator-fields-disabled'); $target_message.removeClass('forminator-loading'); } }, mapZip: function (e) { var verifyZip = this.getStripeData('veifyZip'); var zipField = this.getStripeData('zipField'); var changedField = $(e.currentTarget).attr('name'); const fieldType = $( e.currentTarget ).attr( 'type' ); // To handle the checkbox name[] if ( 'checkbox' === fieldType ) { changedField = changedField.replace( '[]', '' ); } // Verify ZIP is enabled, mapped field is not empty and changed field is the mapped field, proceed if (verifyZip && zipField !== "" && changedField === zipField) { // Get field var value = this.get_field_value(zipField).toString(); // Update card element this._cardElement.update({ value: { postalCode: value } }); } }, focus_to_element: function ($element) { // force show in case its hidden of fadeOut $element.show(); $('html,body').animate({scrollTop: ($element.offset().top - ($(window).height() - $element.outerHeight(true)) / 2)}, 500, function () { if (!$element.attr("tabindex")) { $element.attr("tabindex", -1); } $element.focus(); }); }, show_messages: function (errors) { var self = this, forminatorFrontCondition = self.$el.data('forminatorFrontCondition'); if (typeof forminatorFrontCondition !== 'undefined') { // clear all validation message before show new one this.$el.find('.forminator-error-message').remove(); var i = 0; errors.forEach(function (value) { var element_id = Object.keys(value), message = Object.values(value), element = forminatorFrontCondition.get_form_field(element_id); if (element.length) { if (i === 0) { // focus on first error self.$el.trigger('forminator.front.pagination.focus.input',[element]); self.focus_to_element(element); } if ($(element).hasClass('forminator-input-time')) { var $time_field_holder = $(element).closest('.forminator-field:not(.forminator-field--inner)'), $time_error_holder = $time_field_holder.children('.forminator-error-message'); if ($time_error_holder.length === 0) { $time_field_holder.append('<span class="forminator-error-message" aria-hidden="true"></span>'); $time_error_holder = $time_field_holder.children('.forminator-error-message'); } $time_error_holder.html(message); } var $field_holder = $(element).closest('.forminator-field--inner'); if ($field_holder.length === 0) { $field_holder = $(element).closest('.forminator-field'); if ($field_holder.length === 0) { // handling postdata field $field_holder = $(element).find('.forminator-field'); if ($field_holder.length > 1) { $field_holder = $field_holder.first(); } } } var $error_holder = $field_holder.find('.forminator-error-message'); if ($error_holder.length === 0) { $field_holder.append('<span class="forminator-error-message" aria-hidden="true"></span>'); $error_holder = $field_holder.find('.forminator-error-message'); } $(element).attr('aria-invalid', 'true'); $error_holder.html(message); $field_holder.addClass('forminator-has_error'); i++; } }); } return this; }, getBillingData: function (formData) { var billing = this.getStripeData('billing'); // If billing is disabled, return if (!billing) { return {} }; // Get billing fields var billingName = this.getStripeData('billingName'); var billingEmail = this.getStripeData('billingEmail'); var billingAddress = this.getStripeData('billingAddress'); // Create billing object var billingObject = { address: {} } if( billingName ) { var nameField = this.get_field_value(billingName); // Check if Name field is multiple if (!nameField) { var fName = this.get_field_value(billingName + '-first-name') || ''; var lName = this.get_field_value(billingName + '-last-name') || ''; nameField = fName + ' ' + lName; } // Check if Name field is empty in the end, if not assign to the object if (nameField) { billingObject.name = nameField; } } // Map email field if(billingEmail) { var billingEmailValue = this.get_field_value(billingEmail) || ''; if (billingEmailValue) { billingObject.email = billingEmailValue; } } // Map address line 1 field var addressLine1 = this.get_field_value(billingAddress + '-street_address') || ''; if (addressLine1) { billingObject.address.line1 = addressLine1; } // Map address line 2 field var addressLine2 = this.get_field_value(billingAddress + '-address_line') || ''; if (addressLine2) { billingObject.address.line2 = addressLine2; } // Map address city field var addressCity = this.get_field_value(billingAddress + '-city') || ''; if (addressCity) { billingObject.address.city = addressCity; } // Map address state field var addressState = this.get_field_value(billingAddress + '-state') || ''; if (addressState) { billingObject.address.state = addressState; } // Map address country field var countryField = this.get_form_field(billingAddress + '-country'); var addressCountry = countryField.find(':selected').data('country-code'); if (addressCountry) { billingObject.address.country = addressCountry; } // Map address country field var addressZip = this.get_field_value(billingAddress + '-zip') || ''; if (addressZip) { billingObject.address.postal_code = addressZip; } return { billing_details: billingObject } }, handleCardPayment: function (data, e, formData) { var self = this, secret = data.data.paymentsecret || false, input = $( '.forminator-number--field, .forminator-currency, .forminator-calculation' ); if ( input.inputmask ) { input.inputmask('remove'); } if (self._beforeSubmitCallback) { self._beforeSubmitCallback.call(); } }, mountCardField: function () { var key = this.getStripeData('key'); var cardIcon = this.getStripeData('cardIcon'); var verifyZip = this.getStripeData('veifyZip'); var zipField = this.getStripeData('zipField'); var fieldId = this.getStripeData('fieldId'); if ( null === key ) { return false; } // Init Stripe this._stripe = Stripe( key, { locale: this.getStripeData('language') } ); // Create empty ZIP object var zipObject = {} if (!verifyZip) { // If verify ZIP is disabled, disable ZIP zipObject.hidePostalCode = true; } else { // Set empty post code, later will be updated when field is changed zipObject.value = { postalCode: '', }; } var stripeObject = {}; var fontFamily = this.getStripeData('fontFamily'); var customFonts = this.getStripeData('customFonts'); if (fontFamily && customFonts) { stripeObject.fonts = [ { cssSrc: 'https://fonts.bunny.net/css?family=' + fontFamily, } ]; } var elements = this._stripe.elements(stripeObject); this._cardElement = elements.create('card', Object.assign( { classes: { base: this.getStripeData('baseClass'), complete: this.getStripeData('completeClass'), empty: this.getStripeData('emptyClass'), focus: this.getStripeData('focusedClass'), invalid: this.getStripeData('invalidClass'), webkitAutofill: this.getStripeData('autofilledClass'), }, style: { base: { iconColor: this.getStripeData( 'iconColor' ), color: this.getStripeData( 'fontColor' ), lineHeight: this.getStripeData( 'lineHeight' ), fontWeight: this.getStripeData( 'fontWeight' ), fontFamily: this.getStripeData( 'fontFamily' ), fontSmoothing: 'antialiased', fontSize: this.getStripeData( 'fontSize' ), '::placeholder': { color: this.getStripeData( 'placeholder' ), }, ':hover': { iconColor: this.getStripeData( 'iconColorHover' ), }, ':focus': { iconColor: this.getStripeData( 'iconColorFocus' ), } }, invalid: { iconColor: this.getStripeData( 'iconColorError' ), color: this.getStripeData( 'fontColorError' ), }, }, iconStyle: 'solid', hideIcon: !cardIcon, }, zipObject )); this._cardElement.mount('#card-element-' + fieldId); this.validateCard(); }, validateCard: function () { var self = this; this._cardElement.on( 'change', function( event ) { if ( self.$el.find( '.forminator-stripe-element' ).hasClass( 'StripeElement--empty' ) ) { self.$el.find( '.forminator-stripe-element' ).closest( '.forminator-field' ).removeClass( 'forminator-is_filled' ); } else { self.$el.find( '.forminator-stripe-element' ).closest( '.forminator-field' ).addClass( 'forminator-is_filled' ); } if ( self.$el.find( '.forminator-stripe-element' ).hasClass( 'StripeElement--invalid' ) ) { self.$el.find( '.forminator-stripe-element' ).closest( '.forminator-field' ).addClass( 'forminator-has_error' ); } }); this._cardElement.on('focus', function(event) { self.$el.find('.forminator-stripe-element').closest('.forminator-field').addClass('forminator-is_active'); }); this._cardElement.on('blur', function(event) { self.$el.find('.forminator-stripe-element').closest('.forminator-field').removeClass('forminator-is_active'); self.isValid(false); }); }, hideCardError: function () { var $field_holder = this.$el.find('.forminator-card-message'); var $error_holder = $field_holder.find('.forminator-error-message'); if ($error_holder.length === 0) { $field_holder.append('<span class="forminator-error-message" aria-hidden="true"></span>'); $error_holder = $field_holder.find('.forminator-error-message'); } $field_holder.closest('.forminator-field').removeClass('forminator-has_error'); $error_holder.html(''); }, showCardError: function (message, focus) { var $field_holder = this.$el.find('.forminator-card-message'); var $error_holder = $field_holder.find('.forminator-error-message'); if ($error_holder.length === 0) { $field_holder.append('<span class="forminator-error-message" aria-hidden="true"></span>'); $error_holder = $field_holder.find('.forminator-error-message'); } $field_holder.closest('.forminator-field').addClass('forminator-has_error'); $field_holder.closest('.forminator-field').addClass( 'forminator-is_filled' ); $error_holder.html(message); if(focus) { this.focus_to_element($field_holder.closest('.forminator-field')); } }, getStripeData: function (key) { if ( (typeof this._stripeData !== 'undefined') && (typeof this._stripeData[key] !== 'undefined') ) { return this._stripeData[key]; } return null; }, getObjectValue: function(object, key) { if (typeof object[key] !== 'undefined') { return object[key]; } return null; }, // taken from forminatorFrontCondition get_form_field: function (element_id) { //find element by suffix -field on id input (default behavior) var $element = this.$el.find('#' + element_id + '-field'); if ($element.length === 0) { //find element by its on name (for radio on singlevalue) $element = this.$el.find('input[name=' + element_id + ']'); if ($element.length === 0) { // for text area that have uniqid, so we check its name instead $element = this.$el.find('textarea[name=' + element_id + ']'); if ($element.length === 0) { //find element by its on name[] (for checkbox on multivalue) $element = this.$el.find('input[name="' + element_id + '[]"]'); if ($element.length === 0) { //find element by select name $element = this.$el.find('select[name="' + element_id + '"]'); if ($element.length === 0) { $element = this.$el.find('select[name="' + element_id + '[]"]'); if ($element.length === 0) { //find element by direct id (for name field mostly) //will work for all field with element_id-[somestring] $element = this.$el.find('#' + element_id); } } } } } } return $element; }, get_field_value: function (element_id) { var $element = this.get_form_field(element_id); var value = ''; var checked = null; if (this.field_is_radio($element)) { checked = $element.filter(":checked"); if (checked.length) { value = checked.val(); } } else if (this.field_is_checkbox($element)) { $element.each(function () { if ($(this).is(':checked')) { value = $(this).val(); } }); } else if (this.field_is_select($element)) { value = $element.val(); } else if ( this.field_has_inputMask( $element ) ) { value = parseFloat( $element.inputmask( 'unmaskedvalue' ) ); } else { value = $element.val() } return value; }, get_field_calculation: function (element_id) { var $element = this.get_form_field(element_id); var value = 0; var calculation = 0; var checked = null; if (this.field_is_radio($element)) { checked = $element.filter(":checked"); if (checked.length) { calculation = checked.data('calculation'); if (calculation !== undefined) { value = Number(calculation); } } } else if (this.field_is_checkbox($element)) { $element.each(function () { if ($(this).is(':checked')) { calculation = $(this).data('calculation'); if (calculation !== undefined) { value += Number(calculation); } } }); } else if (this.field_is_select($element)) { checked = $element.find("option").filter(':selected'); if (checked.length) { calculation = checked.data('calculation'); if (calculation !== undefined) { value = Number(calculation); } } } else { value = Number($element.val()); } return isNaN(value) ? 0 : value; }, field_has_inputMask: function ( $element ) { var hasMask = false; $element.each(function () { if ( undefined !== $( this ).attr( 'data-inputmask' ) ) { hasMask = true; //break return false; } }); return hasMask; }, field_is_radio: function ($element) { var is_radio = false; $element.each(function () { if ($(this).attr('type') === 'radio') { is_radio = true; //break return false; } }); return is_radio; }, field_is_checkbox: function ($element) { var is_checkbox = false; $element.each(function () { if ($(this).attr('type') === 'checkbox') { is_checkbox = true; //break return false; } }); return is_checkbox; }, field_is_select: function ($element) { return $element.is('select'); }, }); // A really lightweight plugin wrapper around the constructor, // preventing against multiple instantiations $.fn[pluginName] = function (options) { return this.each(function () { if (!$.data(this, pluginName)) { $.data(this, pluginName, new ForminatorFrontPayment(this, options)); } }); }; })(jQuery, window, document); PK �K}\��&�0 0 "