@cntrl-site/components 1.0.1-alpha.9 → 1.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/Components/ControlSlider/ControlSliderComponent.d.ts +2 -571
- package/dist/Components/Form/Form.d.ts +16 -20
- package/dist/Components/ImageRevealSlider/ControlImageRevealSliderComponent.d.ts +2 -248
- package/dist/Components/OnelinerForm/OnelinerForm.d.ts +14 -24
- package/dist/Components/OnelinerForm/OnelinerFormComponent.d.ts +2 -1
- package/dist/Components/utils/buildColorVars.d.ts +2 -0
- package/dist/Components/utils/formFieldValidation.d.ts +0 -2
- package/dist/Components/utils/index.d.ts +1 -0
- package/dist/Components/utils/textStylesToCss.d.ts +19 -0
- package/dist/components.css +1 -1
- package/dist/index.js +878 -244
- package/dist/index.mjs +3539 -2662
- package/dist/types/Component.d.ts +13 -0
- package/dist/types/SchemaV1.d.ts +1 -0
- package/dist/useScopedStyles-BSwFAT27.mjs +49 -0
- package/dist/useScopedStyles-DpVdqfXj.js +1 -0
- package/dist/utils.js +1 -1
- package/dist/utils.mjs +7 -6
- package/package.json +1 -1
- package/dist/useScopedStyles-Bibm8h9Z.js +0 -1
- package/dist/useScopedStyles-Da2iLz5N.mjs +0 -34
package/dist/index.js
CHANGED
|
@@ -1,140 +1,143 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const S=require("react/jsx-runtime"),D=require("react"),ue=require("classnames"),k=require("./useScopedStyles-Bibm8h9Z.js"),or=require("react-dom");function rr(e){return e.type==="object"&&e.version===1}const ir="ControlSlider-module__wrapper___sHEkd",ar="ControlSlider-module__hoverArrow___A-dOH",lr="ControlSlider-module__sliderItem___QQSkR",sr="ControlSlider-module__sliderImage___9hRl-",cr="ControlSlider-module__arrow___05ghY",ur="ControlSlider-module__arrowVertical___tBfVN",pr="ControlSlider-module__nextArrow___-30Yc",dr="ControlSlider-module__arrowInner___aEra3",gr="ControlSlider-module__arrowIcon___S4ztF",fr="ControlSlider-module__arrowImg___2dwJW",mr="ControlSlider-module__mirror___brd6U",yr="ControlSlider-module__pagination___bicLF",hr="ControlSlider-module__paginationInner___bT-P-",vr="ControlSlider-module__paginationVertical___zYqKw",br="ControlSlider-module__paginationItem___nTRbk",Sr="ControlSlider-module__dot___p1Qun",xr="ControlSlider-module__activeDot___LHFaj",Cr="ControlSlider-module__paginationInsideBottom___R3FWn",_r="ControlSlider-module__paginationInsideTop___V-qb-",wr="ControlSlider-module__paginationOutsideBottom___14w8D",$r="ControlSlider-module__paginationOutsideTop___SCLqB",Tr="ControlSlider-module__paginationInsideLeft___yOBRZ",Ar="ControlSlider-module__paginationInsideRight___Rtt3o",Er="ControlSlider-module__paginationOutsideLeft___lahaw",Lr="ControlSlider-module__paginationOutsideRight___EtuQa",Ir="ControlSlider-module__imgWrapper___UjEgB",kr="ControlSlider-module__captionBlock___dJ6-j",Rr="ControlSlider-module__captionTextWrapper___HFlpf",Fr="ControlSlider-module__captionText___uGBVc",Vr="ControlSlider-module__active___WZK4G",Nr="ControlSlider-module__withPointerEvents___t-18M",Or="ControlSlider-module__topLeftAlignment___zjnGM",jr="ControlSlider-module__topCenterAlignment___gD1xW",Br="ControlSlider-module__topRightAlignment___NMapS",zr="ControlSlider-module__middleLeftAlignment___OnUrY",Wr="ControlSlider-module__middleCenterAlignment___Tdkl0",Mr="ControlSlider-module__middleRightAlignment___wEbfX",Dr="ControlSlider-module__bottomLeftAlignment___cTP2-",Hr="ControlSlider-module__bottomCenterAlignment___c54fB",Pr="ControlSlider-module__bottomRightAlignment___kEwrz",Ur="ControlSlider-module__clickOverlay___DZA28",Gr="ControlSlider-module__contain___pLyq7",Yr="ControlSlider-module__cover___KdDat",Y={wrapper:ir,hoverArrow:ar,sliderItem:lr,sliderImage:sr,arrow:cr,arrowVertical:ur,nextArrow:pr,arrowInner:dr,arrowIcon:gr,arrowImg:fr,mirror:mr,pagination:yr,paginationInner:hr,paginationVertical:vr,paginationItem:br,dot:Sr,activeDot:xr,paginationInsideBottom:Cr,paginationInsideTop:_r,paginationOutsideBottom:wr,paginationOutsideTop:$r,paginationInsideLeft:Tr,paginationInsideRight:Ar,paginationOutsideLeft:Er,paginationOutsideRight:Lr,imgWrapper:Ir,captionBlock:kr,captionTextWrapper:Rr,captionText:Fr,active:Vr,withPointerEvents:Nr,topLeftAlignment:Or,topCenterAlignment:jr,topRightAlignment:Br,middleLeftAlignment:zr,middleCenterAlignment:Wr,middleRightAlignment:Mr,bottomLeftAlignment:Dr,bottomCenterAlignment:Hr,bottomRightAlignment:Pr,clickOverlay:Ur,contain:Gr,cover:Yr};function qr(e,t){for(var n=0;n<t.length;n++){var o=t[n];o.enumerable=o.enumerable||!1,o.configurable=!0,"value"in o&&(o.writable=!0),Object.defineProperty(e,o.key,o)}}function Xr(e,t,n){return t&&qr(e.prototype,t),Object.defineProperty(e,"prototype",{writable:!1}),e}var Dn="(prefers-reduced-motion: reduce)",lt=1,Kr=2,ut=3,gt=4,Tt=5,jt=6,Mt=7,Jr={CREATED:lt,MOUNTED:Kr,IDLE:ut,MOVING:gt,SCROLLING:Tt,DRAGGING:jt,DESTROYED:Mt};function We(e){e.length=0}function Ye(e,t,n){return Array.prototype.slice.call(e,t,n)}function se(e){return e.bind.apply(e,[null].concat(Ye(arguments,1)))}var fo=setTimeout,pn=function(){};function Hn(e){return requestAnimationFrame(e)}function Gt(e,t){return typeof t===e}function bt(e){return!xn(e)&&Gt("object",e)}var Sn=Array.isArray,mo=se(Gt,"function"),Ue=se(Gt,"string"),At=se(Gt,"undefined");function xn(e){return e===null}function yo(e){try{return e instanceof(e.ownerDocument.defaultView||window).HTMLElement}catch{return!1}}function Et(e){return Sn(e)?e:[e]}function Te(e,t){Et(e).forEach(t)}function Cn(e,t){return e.indexOf(t)>-1}function Bt(e,t){return e.push.apply(e,Et(t)),e}function je(e,t,n){e&&Te(t,function(o){o&&e.classList[n?"add":"remove"](o)})}function Re(e,t){je(e,Ue(t)?t.split(" "):t,!0)}function Lt(e,t){Te(t,e.appendChild.bind(e))}function _n(e,t){Te(e,function(n){var o=(t||n).parentNode;o&&o.insertBefore(n,t)})}function St(e,t){return yo(e)&&(e.msMatchesSelector||e.matches).call(e,t)}function ho(e,t){var n=e?Ye(e.children):[];return t?n.filter(function(o){return St(o,t)}):n}function It(e,t){return t?ho(e,t)[0]:e.firstElementChild}var xt=Object.keys;function Je(e,t,n){return e&&(n?xt(e).reverse():xt(e)).forEach(function(o){o!=="__proto__"&&t(e[o],o)}),e}function Ct(e){return Ye(arguments,1).forEach(function(t){Je(t,function(n,o){e[o]=t[o]})}),e}function Pe(e){return Ye(arguments,1).forEach(function(t){Je(t,function(n,o){Sn(n)?e[o]=n.slice():bt(n)?e[o]=Pe({},bt(e[o])?e[o]:{},n):e[o]=n})}),e}function Pn(e,t){Te(t||xt(e),function(n){delete e[n]})}function Fe(e,t){Te(e,function(n){Te(t,function(o){n&&n.removeAttribute(o)})})}function te(e,t,n){bt(t)?Je(t,function(o,r){te(e,r,o)}):Te(e,function(o){xn(n)||n===""?Fe(o,t):o.setAttribute(t,String(n))})}function st(e,t,n){var o=document.createElement(e);return t&&(Ue(t)?Re(o,t):te(o,t)),n&&Lt(n,o),o}function Ee(e,t,n){if(At(n))return getComputedStyle(e)[t];xn(n)||(e.style[t]=""+n)}function _t(e,t){Ee(e,"display",t)}function vo(e){e.setActive&&e.setActive()||e.focus({preventScroll:!0})}function Le(e,t){return e.getAttribute(t)}function Un(e,t){return e&&e.classList.contains(t)}function we(e){return e.getBoundingClientRect()}function Ze(e){Te(e,function(t){t&&t.parentNode&&t.parentNode.removeChild(t)})}function bo(e){return It(new DOMParser().parseFromString(e,"text/html").body)}function Oe(e,t){e.preventDefault(),t&&(e.stopPropagation(),e.stopImmediatePropagation())}function So(e,t){return e&&e.querySelector(t)}function wn(e,t){return t?Ye(e.querySelectorAll(t)):[]}function Be(e,t){je(e,t,!1)}function dn(e){return e.timeStamp}function Ke(e){return Ue(e)?e:e?e+"px":""}var kt="splide",$n="data-"+kt;function yt(e,t){if(!e)throw new Error("["+kt+"] "+(t||""))}var Ge=Math.min,Dt=Math.max,Ht=Math.floor,wt=Math.ceil,xe=Math.abs;function xo(e,t,n){return xe(e-t)<n}function zt(e,t,n,o){var r=Ge(t,n),a=Dt(t,n);return o?r<e&&e<a:r<=e&&e<=a}function it(e,t,n){var o=Ge(t,n),r=Dt(t,n);return Ge(Dt(o,e),r)}function gn(e){return+(e>0)-+(e<0)}function fn(e,t){return Te(t,function(n){e=e.replace("%s",""+n)}),e}function Tn(e){return e<10?"0"+e:""+e}var Gn={};function Zr(e){return""+e+Tn(Gn[e]=(Gn[e]||0)+1)}function Co(){var e=[];function t(i,s,l,d){r(i,s,function(p,_,m){var h="addEventListener"in p,c=h?p.removeEventListener.bind(p,_,l,d):p.removeListener.bind(p,l);h?p.addEventListener(_,l,d):p.addListener(l),e.push([p,_,m,l,c])})}function n(i,s,l){r(i,s,function(d,p,_){e=e.filter(function(m){return m[0]===d&&m[1]===p&&m[2]===_&&(!l||m[3]===l)?(m[4](),!1):!0})})}function o(i,s,l){var d,p=!0;return typeof CustomEvent=="function"?d=new CustomEvent(s,{bubbles:p,detail:l}):(d=document.createEvent("CustomEvent"),d.initCustomEvent(s,p,!1,l)),i.dispatchEvent(d),d}function r(i,s,l){Te(i,function(d){d&&Te(s,function(p){p.split(" ").forEach(function(_){var m=_.split(".");l(d,m[0],m[1])})})})}function a(){e.forEach(function(i){i[4]()}),We(e)}return{bind:t,unbind:n,dispatch:o,destroy:a}}var qe="mounted",mn="ready",Me="move",ft="moved",An="click",_o="active",wo="inactive",$o="visible",To="hidden",he="refresh",Se="updated",pt="resize",Yt="resized",Ao="drag",Eo="dragging",Lo="dragged",qt="scroll",et="scrolled",Qr="overflow",En="destroy",Io="arrows:mounted",ko="arrows:updated",Ro="pagination:mounted",Fo="pagination:updated",Ln="navigation:mounted",In="autoplay:play",Vo="autoplay:playing",kn="autoplay:pause",Rn="lazyload:loaded",No="sk",Oo="sh",Pt="ei";function pe(e){var t=e?e.event.bus:document.createDocumentFragment(),n=Co();function o(a,i){n.bind(t,Et(a).join(" "),function(s){i.apply(i,Sn(s.detail)?s.detail:[])})}function r(a){n.dispatch(t,a,Ye(arguments,1))}return e&&e.event.on(En,n.destroy),Ct(n,{bus:t,on:o,off:se(n.unbind,t),emit:r})}function Xt(e,t,n,o){var r=Date.now,a,i=0,s,l=!0,d=0;function p(){if(!l){if(i=e?Ge((r()-a)/e,1):1,n&&n(i),i>=1&&(t(),a=r(),o&&++d>=o))return m();s=Hn(p)}}function _($){$||c(),a=r()-($?i*e:0),l=!1,s=Hn(p)}function m(){l=!0}function h(){a=r(),i=0,n&&n(i)}function c(){s&&cancelAnimationFrame(s),i=0,s=0,l=!0}function u($){e=$}function b(){return l}return{start:_,rewind:h,pause:m,cancel:c,set:u,isPaused:b}}function ei(e){var t=e;function n(r){t=r}function o(r){return Cn(Et(r),t)}return{set:n,is:o}}function ti(e,t){var n=Xt(0,e,null,1);return function(){n.isPaused()&&n.start()}}function ni(e,t,n){var o=e.state,r=n.breakpoints||{},a=n.reducedMotion||{},i=Co(),s=[];function l(){var c=n.mediaQuery==="min";xt(r).sort(function(u,b){return c?+u-+b:+b-+u}).forEach(function(u){p(r[u],"("+(c?"min":"max")+"-width:"+u+"px)")}),p(a,Dn),_()}function d(c){c&&i.destroy()}function p(c,u){var b=matchMedia(u);i.bind(b,"change",_),s.push([c,b])}function _(){var c=o.is(Mt),u=n.direction,b=s.reduce(function($,f){return Pe($,f[1].matches?f[0]:{})},{});Pn(n),h(b),n.destroy?e.destroy(n.destroy==="completely"):c?(d(!0),e.mount()):u!==n.direction&&e.refresh()}function m(c){matchMedia(Dn).matches&&(c?Pe(n,a):Pn(n,xt(a)))}function h(c,u,b){Pe(n,c),u&&Pe(Object.getPrototypeOf(n),c),(b||!o.is(lt))&&e.emit(Se,n)}return{setup:l,destroy:d,reduce:m,set:h}}var Kt="Arrow",Jt=Kt+"Left",Zt=Kt+"Right",jo=Kt+"Up",Bo=Kt+"Down",Yn="rtl",Qt="ttb",on={width:["height"],left:["top","right"],right:["bottom","left"],x:["y"],X:["Y"],Y:["X"],ArrowLeft:[jo,Zt],ArrowRight:[Bo,Jt]};function oi(e,t,n){function o(a,i,s){s=s||n.direction;var l=s===Yn&&!i?1:s===Qt?0:-1;return on[a]&&on[a][l]||a.replace(/width|left|right/i,function(d,p){var _=on[d.toLowerCase()][l]||d;return p>0?_.charAt(0).toUpperCase()+_.slice(1):_})}function r(a){return a*(n.direction===Yn?1:-1)}return{resolve:o,orient:r}}var ze="role",ct="tabindex",ri="disabled",Ie="aria-",Rt=Ie+"controls",zo=Ie+"current",qn=Ie+"selected",$e=Ie+"label",Fn=Ie+"labelledby",Wo=Ie+"hidden",Vn=Ie+"orientation",$t=Ie+"roledescription",Xn=Ie+"live",Kn=Ie+"busy",Jn=Ie+"atomic",Nn=[ze,ct,ri,Rt,zo,$e,Fn,Wo,Vn,$t],Ve=kt+"__",Xe="is-",rn=kt,Zn=Ve+"track",ii=Ve+"list",en=Ve+"slide",Mo=en+"--clone",ai=en+"__container",On=Ve+"arrows",tn=Ve+"arrow",Do=tn+"--prev",Ho=tn+"--next",nn=Ve+"pagination",Po=nn+"__page",li=Ve+"progress",si=li+"__bar",ci=Ve+"toggle",ui=Ve+"spinner",pi=Ve+"sr",di=Xe+"initialized",Qe=Xe+"active",Uo=Xe+"prev",Go=Xe+"next",yn=Xe+"visible",hn=Xe+"loading",Yo=Xe+"focus-in",qo=Xe+"overflow",gi=[Qe,yn,Uo,Go,hn,Yo,qo],fi={slide:en,clone:Mo,arrows:On,arrow:tn,prev:Do,next:Ho,pagination:nn,page:Po,spinner:ui};function mi(e,t){if(mo(e.closest))return e.closest(t);for(var n=e;n&&n.nodeType===1&&!St(n,t);)n=n.parentElement;return n}var yi=5,Qn=200,Xo="touchstart mousedown",an="touchmove mousemove",ln="touchend touchcancel mouseup click";function hi(e,t,n){var o=pe(e),r=o.on,a=o.bind,i=e.root,s=n.i18n,l={},d=[],p=[],_=[],m,h,c;function u(){w(),B(),f()}function b(){r(he,$),r(he,u),r(Se,f),a(document,Xo+" keydown",function(v){c=v.type==="keydown"},{capture:!0}),a(i,"focusin",function(){je(i,Yo,!!c)})}function $(v){var T=Nn.concat("style");We(d),Be(i,p),Be(m,_),Fe([m,h],T),Fe(i,v?T:["style",$t])}function f(){Be(i,p),Be(m,_),p=E(rn),_=E(Zn),Re(i,p),Re(m,_),te(i,$e,n.label),te(i,Fn,n.labelledby)}function w(){m=z("."+Zn),h=It(m,"."+ii),yt(m&&h,"A track/list element is missing."),Bt(d,ho(h,"."+en+":not(."+Mo+")")),Je({arrows:On,pagination:nn,prev:Do,next:Ho,bar:si,toggle:ci},function(v,T){l[T]=z("."+v)}),Ct(l,{root:i,track:m,list:h,slides:d})}function B(){var v=i.id||Zr(kt),T=n.role;i.id=v,m.id=m.id||v+"-track",h.id=h.id||v+"-list",!Le(i,ze)&&i.tagName!=="SECTION"&&T&&te(i,ze,T),te(i,$t,s.carousel),te(h,ze,"presentation")}function z(v){var T=So(i,v);return T&&mi(T,"."+rn)===i?T:void 0}function E(v){return[v+"--"+n.type,v+"--"+n.direction,n.drag&&v+"--draggable",n.isNavigation&&v+"--nav",v===rn&&Qe]}return Ct(l,{setup:u,mount:b,destroy:$})}var dt="slide",mt="loop",Ft="fade";function vi(e,t,n,o){var r=pe(e),a=r.on,i=r.emit,s=r.bind,l=e.Components,d=e.root,p=e.options,_=p.isNavigation,m=p.updateOnMove,h=p.i18n,c=p.pagination,u=p.slideFocus,b=l.Direction.resolve,$=Le(o,"style"),f=Le(o,$e),w=n>-1,B=It(o,"."+ai),z;function E(){w||(o.id=d.id+"-slide"+Tn(t+1),te(o,ze,c?"tabpanel":"group"),te(o,$t,h.slide),te(o,$e,f||fn(h.slideLabel,[t+1,e.length]))),v()}function v(){s(o,"click",se(i,An,x)),s(o,"keydown",se(i,No,x)),a([ft,Oo,et],L),a(Ln,V),m&&a(Me,W)}function T(){z=!0,r.destroy(),Be(o,gi),Fe(o,Nn),te(o,"style",$),te(o,$e,f||"")}function V(){var A=e.splides.map(function(C){var N=C.splide.Components.Slides.getAt(t);return N?N.slide.id:""}).join(" ");te(o,$e,fn(h.slideX,(w?n:t)+1)),te(o,Rt,A),te(o,ze,u?"button":""),u&&Fe(o,$t)}function W(){z||L()}function L(){if(!z){var A=e.index;F(),O(),je(o,Uo,t===A-1),je(o,Go,t===A+1)}}function F(){var A=H();A!==Un(o,Qe)&&(je(o,Qe,A),te(o,zo,_&&A||""),i(A?_o:wo,x))}function O(){var A=g(),C=!A&&(!H()||w);if(e.state.is([gt,Tt])||te(o,Wo,C||""),te(wn(o,p.focusableNodes||""),ct,C?-1:""),u&&te(o,ct,C?-1:0),A!==Un(o,yn)&&(je(o,yn,A),i(A?$o:To,x)),!A&&document.activeElement===o){var N=l.Slides.getAt(e.index);N&&vo(N.slide)}}function U(A,C,N){Ee(N&&B||o,A,C)}function H(){var A=e.index;return A===t||p.cloneStatus&&A===n}function g(){if(e.is(Ft))return H();var A=we(l.Elements.track),C=we(o),N=b("left",!0),q=b("right",!0);return Ht(A[N])<=wt(C[N])&&Ht(C[q])<=wt(A[q])}function R(A,C){var N=xe(A-t);return!w&&(p.rewind||e.is(mt))&&(N=Ge(N,e.length-N)),N<=C}var x={index:t,slideIndex:n,slide:o,container:B,isClone:w,mount:E,destroy:T,update:L,style:U,isWithin:R};return x}function bi(e,t,n){var o=pe(e),r=o.on,a=o.emit,i=o.bind,s=t.Elements,l=s.slides,d=s.list,p=[];function _(){m(),r(he,h),r(he,m)}function m(){l.forEach(function(L,F){u(L,F,-1)})}function h(){z(function(L){L.destroy()}),We(p)}function c(){z(function(L){L.update()})}function u(L,F,O){var U=vi(e,F,O,L);U.mount(),p.push(U),p.sort(function(H,g){return H.index-g.index})}function b(L){return L?E(function(F){return!F.isClone}):p}function $(L){var F=t.Controller,O=F.toIndex(L),U=F.hasFocus()?1:n.perPage;return E(function(H){return zt(H.index,O,O+U-1)})}function f(L){return E(L)[0]}function w(L,F){Te(L,function(O){if(Ue(O)&&(O=bo(O)),yo(O)){var U=l[F];U?_n(O,U):Lt(d,O),Re(O,n.classes.slide),T(O,se(a,pt))}}),a(he)}function B(L){Ze(E(L).map(function(F){return F.slide})),a(he)}function z(L,F){b(F).forEach(L)}function E(L){return p.filter(mo(L)?L:function(F){return Ue(L)?St(F.slide,L):Cn(Et(L),F.index)})}function v(L,F,O){z(function(U){U.style(L,F,O)})}function T(L,F){var O=wn(L,"img"),U=O.length;U?O.forEach(function(H){i(H,"load error",function(){--U||F()})}):F()}function V(L){return L?l.length:p.length}function W(){return p.length>n.perPage}return{mount:_,destroy:h,update:c,register:u,get:b,getIn:$,getAt:f,add:w,remove:B,forEach:z,filter:E,style:v,getLength:V,isEnough:W}}function Si(e,t,n){var o=pe(e),r=o.on,a=o.bind,i=o.emit,s=t.Slides,l=t.Direction.resolve,d=t.Elements,p=d.root,_=d.track,m=d.list,h=s.getAt,c=s.style,u,b,$;function f(){w(),a(window,"resize load",ti(se(i,pt))),r([Se,he],w),r(pt,B)}function w(){u=n.direction===Qt,Ee(p,"maxWidth",Ke(n.width)),Ee(_,l("paddingLeft"),z(!1)),Ee(_,l("paddingRight"),z(!0)),B(!0)}function B(x){var A=we(p);(x||b.width!==A.width||b.height!==A.height)&&(Ee(_,"height",E()),c(l("marginRight"),Ke(n.gap)),c("width",T()),c("height",V(),!0),b=A,i(Yt),$!==($=R())&&(je(p,qo,$),i(Qr,$)))}function z(x){var A=n.padding,C=l(x?"right":"left");return A&&Ke(A[C]||(bt(A)?0:A))||"0px"}function E(){var x="";return u&&(x=v(),yt(x,"height or heightRatio is missing."),x="calc("+x+" - "+z(!1)+" - "+z(!0)+")"),x}function v(){return Ke(n.height||we(m).width*n.heightRatio)}function T(){return n.autoWidth?null:Ke(n.fixedWidth)||(u?"":W())}function V(){return Ke(n.fixedHeight)||(u?n.autoHeight?null:W():v())}function W(){var x=Ke(n.gap);return"calc((100%"+(x&&" + "+x)+")/"+(n.perPage||1)+(x&&" - "+x)+")"}function L(){return we(m)[l("width")]}function F(x,A){var C=h(x||0);return C?we(C.slide)[l("width")]+(A?0:H()):0}function O(x,A){var C=h(x);if(C){var N=we(C.slide)[l("right")],q=we(m)[l("left")];return xe(N-q)+(A?0:H())}return 0}function U(x){return O(e.length-1)-O(0)+F(0,x)}function H(){var x=h(0);return x&&parseFloat(Ee(x.slide,l("marginRight")))||0}function g(x){return parseFloat(Ee(_,l("padding"+(x?"Right":"Left"))))||0}function R(){return e.is(Ft)||U(!0)>L()}return{mount:f,resize:B,listSize:L,slideSize:F,sliderSize:U,totalSize:O,getPadding:g,isOverflow:R}}var xi=2;function Ci(e,t,n){var o=pe(e),r=o.on,a=t.Elements,i=t.Slides,s=t.Direction.resolve,l=[],d;function p(){r(he,_),r([Se,pt],h),(d=b())&&(c(d),t.Layout.resize(!0))}function _(){m(),p()}function m(){Ze(l),We(l),o.destroy()}function h(){var $=b();d!==$&&(d<$||!$)&&o.emit(he)}function c($){var f=i.get().slice(),w=f.length;if(w){for(;f.length<$;)Bt(f,f);Bt(f.slice(-$),f.slice(0,$)).forEach(function(B,z){var E=z<$,v=u(B.slide,z);E?_n(v,f[0].slide):Lt(a.list,v),Bt(l,v),i.register(v,z-$+(E?0:w),B.index)})}}function u($,f){var w=$.cloneNode(!0);return Re(w,n.classes.clone),w.id=e.root.id+"-clone"+Tn(f+1),w}function b(){var $=n.clones;if(!e.is(mt))$=0;else if(At($)){var f=n[s("fixedWidth")]&&t.Layout.slideSize(0),w=f&&wt(we(a.track)[s("width")]/f);$=w||n[s("autoWidth")]&&e.length||n.perPage*xi}return $}return{mount:p,destroy:m}}function _i(e,t,n){var o=pe(e),r=o.on,a=o.emit,i=e.state.set,s=t.Layout,l=s.slideSize,d=s.getPadding,p=s.totalSize,_=s.listSize,m=s.sliderSize,h=t.Direction,c=h.resolve,u=h.orient,b=t.Elements,$=b.list,f=b.track,w;function B(){w=t.Transition,r([qe,Yt,Se,he],z)}function z(){t.Controller.isBusy()||(t.Scroll.cancel(),v(e.index),t.Slides.update())}function E(C,N,q,ie){C!==N&&x(C>q)&&(L(),T(W(U(),C>q),!0)),i(gt),a(Me,N,q,C),w.start(N,function(){i(ut),a(ft,N,q,C),ie&&ie()})}function v(C){T(O(C,!0))}function T(C,N){if(!e.is(Ft)){var q=N?C:V(C);Ee($,"transform","translate"+c("X")+"("+q+"px)"),C!==q&&a(Oo)}}function V(C){if(e.is(mt)){var N=F(C),q=N>t.Controller.getEnd(),ie=N<0;(ie||q)&&(C=W(C,q))}return C}function W(C,N){var q=C-R(N),ie=m();return C-=u(ie*(wt(xe(q)/ie)||1))*(N?1:-1),C}function L(){T(U(),!0),w.cancel()}function F(C){for(var N=t.Slides.get(),q=0,ie=1/0,Q=0;Q<N.length;Q++){var me=N[Q].index,I=xe(O(me,!0)-C);if(I<=ie)ie=I,q=me;else break}return q}function O(C,N){var q=u(p(C-1)-g(C));return N?H(q):q}function U(){var C=c("left");return we($)[C]-we(f)[C]+u(d(!1))}function H(C){return n.trimSpace&&e.is(dt)&&(C=it(C,0,u(m(!0)-_()))),C}function g(C){var N=n.focus;return N==="center"?(_()-l(C,!0))/2:+N*l(C)||0}function R(C){return O(C?t.Controller.getEnd():0,!!n.trimSpace)}function x(C){var N=u(W(U(),C));return C?N>=0:N<=$[c("scrollWidth")]-we(f)[c("width")]}function A(C,N){N=At(N)?U():N;var q=C!==!0&&u(N)<u(R(!1)),ie=C!==!1&&u(N)>u(R(!0));return q||ie}return{mount:B,move:E,jump:v,translate:T,shift:W,cancel:L,toIndex:F,toPosition:O,getPosition:U,getLimit:R,exceededLimit:A,reposition:z}}function wi(e,t,n){var o=pe(e),r=o.on,a=o.emit,i=t.Move,s=i.getPosition,l=i.getLimit,d=i.toPosition,p=t.Slides,_=p.isEnough,m=p.getLength,h=n.omitEnd,c=e.is(mt),u=e.is(dt),b=se(U,!1),$=se(U,!0),f=n.start||0,w,B=f,z,E,v;function T(){V(),r([Se,he,Pt],V),r(Yt,W)}function V(){z=m(!0),E=n.perMove,v=n.perPage,w=x();var I=it(f,0,h?w:z-1);I!==f&&(f=I,i.reposition())}function W(){w!==x()&&a(Pt)}function L(I,K,ye){if(!me()){var ae=O(I),de=R(ae);de>-1&&(K||de!==f)&&(q(de),i.move(ae,de,B,ye))}}function F(I,K,ye,ae){t.Scroll.scroll(I,K,ye,function(){var de=R(i.toIndex(s()));q(h?Ge(de,w):de),ae&&ae()})}function O(I){var K=f;if(Ue(I)){var ye=I.match(/([+\-<>])(\d+)?/)||[],ae=ye[1],de=ye[2];ae==="+"||ae==="-"?K=H(f+ +(""+ae+(+de||1)),f):ae===">"?K=de?A(+de):b(!0):ae==="<"&&(K=$(!0))}else K=c?I:it(I,0,w);return K}function U(I,K){var ye=E||(Q()?1:v),ae=H(f+ye*(I?-1:1),f,!(E||Q()));return ae===-1&&u&&!xo(s(),l(!I),1)?I?0:w:K?ae:R(ae)}function H(I,K,ye){if(_()||Q()){var ae=g(I);ae!==I&&(K=I,I=ae,ye=!1),I<0||I>w?!E&&(zt(0,I,K,!0)||zt(w,K,I,!0))?I=A(C(I)):c?I=ye?I<0?-(z%v||v):z:I:n.rewind?I=I<0?w:0:I=-1:ye&&I!==K&&(I=A(C(K)+(I<K?-1:1)))}else I=-1;return I}function g(I){if(u&&n.trimSpace==="move"&&I!==f)for(var K=s();K===d(I,!0)&&zt(I,0,e.length-1,!n.rewind);)I<f?--I:++I;return I}function R(I){return c?(I+z)%z||0:I}function x(){for(var I=z-(Q()||c&&E?1:v);h&&I-- >0;)if(d(z-1,!0)!==d(I,!0)){I++;break}return it(I,0,z-1)}function A(I){return it(Q()?I:v*I,0,w)}function C(I){return Q()?Ge(I,w):Ht((I>=w?z-1:I)/v)}function N(I){var K=i.toIndex(I);return u?it(K,0,w):K}function q(I){I!==f&&(B=f,f=I)}function ie(I){return I?B:f}function Q(){return!At(n.focus)||n.isNavigation}function me(){return e.state.is([gt,Tt])&&!!n.waitForTransition}return{mount:T,go:L,scroll:F,getNext:b,getPrev:$,getAdjacent:U,getEnd:x,setIndex:q,getIndex:ie,toIndex:A,toPage:C,toDest:N,hasFocus:Q,isBusy:me}}var $i="http://www.w3.org/2000/svg",Ti="m15.5 0.932-4.3 4.38 14.5 14.6-14.5 14.5 4.3 4.4 14.6-14.6 4.4-4.3-4.4-4.4-14.6-14.6z",Vt=40;function Ai(e,t,n){var o=pe(e),r=o.on,a=o.bind,i=o.emit,s=n.classes,l=n.i18n,d=t.Elements,p=t.Controller,_=d.arrows,m=d.track,h=_,c=d.prev,u=d.next,b,$,f={};function w(){z(),r(Se,B)}function B(){E(),w()}function z(){var F=n.arrows;F&&!(c&&u)&&V(),c&&u&&(Ct(f,{prev:c,next:u}),_t(h,F?"":"none"),Re(h,$=On+"--"+n.direction),F&&(v(),L(),te([c,u],Rt,m.id),i(Io,c,u)))}function E(){o.destroy(),Be(h,$),b?(Ze(_?[c,u]:h),c=u=null):Fe([c,u],Nn)}function v(){r([qe,ft,he,et,Pt],L),a(u,"click",se(T,">")),a(c,"click",se(T,"<"))}function T(F){p.go(F,!0)}function V(){h=_||st("div",s.arrows),c=W(!0),u=W(!1),b=!0,Lt(h,[c,u]),!_&&_n(h,m)}function W(F){var O='<button class="'+s.arrow+" "+(F?s.prev:s.next)+'" type="button"><svg xmlns="'+$i+'" viewBox="0 0 '+Vt+" "+Vt+'" width="'+Vt+'" height="'+Vt+'" focusable="false"><path d="'+(n.arrowPath||Ti)+'" />';return bo(O)}function L(){if(c&&u){var F=e.index,O=p.getPrev(),U=p.getNext(),H=O>-1&&F<O?l.last:l.prev,g=U>-1&&F>U?l.first:l.next;c.disabled=O<0,u.disabled=U<0,te(c,$e,H),te(u,$e,g),i(ko,c,u,O,U)}}return{arrows:f,mount:w,destroy:E,update:L}}var Ei=$n+"-interval";function Li(e,t,n){var o=pe(e),r=o.on,a=o.bind,i=o.emit,s=Xt(n.interval,e.go.bind(e,">"),v),l=s.isPaused,d=t.Elements,p=t.Elements,_=p.root,m=p.toggle,h=n.autoplay,c,u,b=h==="pause";function $(){h&&(f(),m&&te(m,Rt,d.track.id),b||w(),E())}function f(){n.pauseOnHover&&a(_,"mouseenter mouseleave",function(V){c=V.type==="mouseenter",z()}),n.pauseOnFocus&&a(_,"focusin focusout",function(V){u=V.type==="focusin",z()}),m&&a(m,"click",function(){b?w():B(!0)}),r([Me,qt,he],s.rewind),r(Me,T)}function w(){l()&&t.Slides.isEnough()&&(s.start(!n.resetProgress),u=c=b=!1,E(),i(In))}function B(V){V===void 0&&(V=!0),b=!!V,E(),l()||(s.pause(),i(kn))}function z(){b||(c||u?B(!1):w())}function E(){m&&(je(m,Qe,!b),te(m,$e,n.i18n[b?"play":"pause"]))}function v(V){var W=d.bar;W&&Ee(W,"width",V*100+"%"),i(Vo,V)}function T(V){var W=t.Slides.getAt(V);s.set(W&&+Le(W.slide,Ei)||n.interval)}return{mount:$,destroy:s.cancel,play:w,pause:B,isPaused:l}}function Ii(e,t,n){var o=pe(e),r=o.on;function a(){n.cover&&(r(Rn,se(s,!0)),r([qe,Se,he],se(i,!0)))}function i(l){t.Slides.forEach(function(d){var p=It(d.container||d.slide,"img");p&&p.src&&s(l,p,d)})}function s(l,d,p){p.style("background",l?'center/cover no-repeat url("'+d.src+'")':"",!0),_t(d,l?"none":"")}return{mount:a,destroy:se(i,!1)}}var ki=10,Ri=600,Fi=.6,Vi=1.5,Ni=800;function Oi(e,t,n){var o=pe(e),r=o.on,a=o.emit,i=e.state.set,s=t.Move,l=s.getPosition,d=s.getLimit,p=s.exceededLimit,_=s.translate,m=e.is(dt),h,c,u=1;function b(){r(Me,B),r([Se,he],z)}function $(v,T,V,W,L){var F=l();if(B(),V&&(!m||!p())){var O=t.Layout.sliderSize(),U=gn(v)*O*Ht(xe(v)/O)||0;v=s.toPosition(t.Controller.toDest(v%O))+U}var H=xo(F,v,1);u=1,T=H?0:T||Dt(xe(v-F)/Vi,Ni),c=W,h=Xt(T,f,se(w,F,v,L),1),i(Tt),a(qt),h.start()}function f(){i(ut),c&&c(),a(et)}function w(v,T,V,W){var L=l(),F=v+(T-v)*E(W),O=(F-L)*u;_(L+O),m&&!V&&p()&&(u*=Fi,xe(O)<ki&&$(d(p(!0)),Ri,!1,c,!0))}function B(){h&&h.cancel()}function z(){h&&!h.isPaused()&&(B(),f())}function E(v){var T=n.easingFunc;return T?T(v):1-Math.pow(1-v,4)}return{mount:b,destroy:B,scroll:$,cancel:z}}var at={passive:!1,capture:!0};function ji(e,t,n){var o=pe(e),r=o.on,a=o.emit,i=o.bind,s=o.unbind,l=e.state,d=t.Move,p=t.Scroll,_=t.Controller,m=t.Elements.track,h=t.Media.reduce,c=t.Direction,u=c.resolve,b=c.orient,$=d.getPosition,f=d.exceededLimit,w,B,z,E,v,T=!1,V,W,L;function F(){i(m,an,pn,at),i(m,ln,pn,at),i(m,Xo,U,at),i(m,"click",R,{capture:!0}),i(m,"dragstart",Oe),r([qe,Se],O)}function O(){var M=n.drag;De(!M),E=M==="free"}function U(M){if(V=!1,!W){var y=de(M);ae(M.target)&&(y||!M.button)&&(_.isBusy()?Oe(M,!0):(L=y?m:window,v=l.is([gt,Tt]),z=null,i(L,an,H,at),i(L,ln,g,at),d.cancel(),p.cancel(),x(M)))}}function H(M){if(l.is(jt)||(l.set(jt),a(Ao)),M.cancelable)if(v){d.translate(w+ye(Q(M)));var y=me(M)>Qn,P=T!==(T=f());(y||P)&&x(M),V=!0,a(Eo),Oe(M)}else N(M)&&(v=C(M),Oe(M))}function g(M){l.is(jt)&&(l.set(ut),a(Lo)),v&&(A(M),Oe(M)),s(L,an,H),s(L,ln,g),v=!1}function R(M){!W&&V&&Oe(M,!0)}function x(M){z=B,B=M,w=$()}function A(M){var y=q(M),P=ie(y),G=n.rewind&&n.rewindByDrag;h(!1),E?_.scroll(P,0,n.snap):e.is(Ft)?_.go(b(gn(y))<0?G?"<":"-":G?">":"+"):e.is(dt)&&T&&G?_.go(f(!0)?">":"<"):_.go(_.toDest(P),!0),h(!0)}function C(M){var y=n.dragMinThreshold,P=bt(y),G=P&&y.mouse||0,J=(P?y.touch:+y)||10;return xe(Q(M))>(de(M)?J:G)}function N(M){return xe(Q(M))>xe(Q(M,!0))}function q(M){if(e.is(mt)||!T){var y=me(M);if(y&&y<Qn)return Q(M)/y}return 0}function ie(M){return $()+gn(M)*Ge(xe(M)*(n.flickPower||600),E?1/0:t.Layout.listSize()*(n.flickMaxPages||1))}function Q(M,y){return K(M,y)-K(I(M),y)}function me(M){return dn(M)-dn(I(M))}function I(M){return B===M&&z||B}function K(M,y){return(de(M)?M.changedTouches[0]:M)["page"+u(y?"Y":"X")]}function ye(M){return M/(T&&e.is(dt)?yi:1)}function ae(M){var y=n.noDrag;return!St(M,"."+Po+", ."+tn)&&(!y||!St(M,y))}function de(M){return typeof TouchEvent<"u"&&M instanceof TouchEvent}function ge(){return v}function De(M){W=M}return{mount:F,disable:De,isDragging:ge}}var Bi={Spacebar:" ",Right:Zt,Left:Jt,Up:jo,Down:Bo};function jn(e){return e=Ue(e)?e:e.key,Bi[e]||e}var eo="keydown";function zi(e,t,n){var o=pe(e),r=o.on,a=o.bind,i=o.unbind,s=e.root,l=t.Direction.resolve,d,p;function _(){m(),r(Se,h),r(Se,m),r(Me,u)}function m(){var $=n.keyboard;$&&(d=$==="global"?window:s,a(d,eo,b))}function h(){i(d,eo)}function c($){p=$}function u(){var $=p;p=!0,fo(function(){p=$})}function b($){if(!p){var f=jn($);f===l(Jt)?e.go("<"):f===l(Zt)&&e.go(">")}}return{mount:_,destroy:h,disable:c}}var ht=$n+"-lazy",Wt=ht+"-srcset",Wi="["+ht+"], ["+Wt+"]";function Mi(e,t,n){var o=pe(e),r=o.on,a=o.off,i=o.bind,s=o.emit,l=n.lazyLoad==="sequential",d=[ft,et],p=[];function _(){n.lazyLoad&&(m(),r(he,m))}function m(){We(p),h(),l?$():(a(d),r(d,c),c())}function h(){t.Slides.forEach(function(f){wn(f.slide,Wi).forEach(function(w){var B=Le(w,ht),z=Le(w,Wt);if(B!==w.src||z!==w.srcset){var E=n.classes.spinner,v=w.parentElement,T=It(v,"."+E)||st("span",E,v);p.push([w,f,T]),w.src||_t(w,"none")}})})}function c(){p=p.filter(function(f){var w=n.perPage*((n.preloadPages||1)+1)-1;return f[1].isWithin(e.index,w)?u(f):!0}),p.length||a(d)}function u(f){var w=f[0];Re(f[1].slide,hn),i(w,"load error",se(b,f)),te(w,"src",Le(w,ht)),te(w,"srcset",Le(w,Wt)),Fe(w,ht),Fe(w,Wt)}function b(f,w){var B=f[0],z=f[1];Be(z.slide,hn),w.type!=="error"&&(Ze(f[2]),_t(B,""),s(Rn,B,z),s(pt)),l&&$()}function $(){p.length&&u(p.shift())}return{mount:_,destroy:se(We,p),check:c}}function Di(e,t,n){var o=pe(e),r=o.on,a=o.emit,i=o.bind,s=t.Slides,l=t.Elements,d=t.Controller,p=d.hasFocus,_=d.getIndex,m=d.go,h=t.Direction.resolve,c=l.pagination,u=[],b,$;function f(){w(),r([Se,he,Pt],f);var W=n.pagination;c&&_t(c,W?"":"none"),W&&(r([Me,qt,et],V),B(),V(),a(Ro,{list:b,items:u},T(e.index)))}function w(){b&&(Ze(c?Ye(b.children):b),Be(b,$),We(u),b=null),o.destroy()}function B(){var W=e.length,L=n.classes,F=n.i18n,O=n.perPage,U=p()?d.getEnd()+1:wt(W/O);b=c||st("ul",L.pagination,l.track.parentElement),Re(b,$=nn+"--"+v()),te(b,ze,"tablist"),te(b,$e,F.select),te(b,Vn,v()===Qt?"vertical":"");for(var H=0;H<U;H++){var g=st("li",null,b),R=st("button",{class:L.page,type:"button"},g),x=s.getIn(H).map(function(C){return C.slide.id}),A=!p()&&O>1?F.pageX:F.slideX;i(R,"click",se(z,H)),n.paginationKeyboard&&i(R,"keydown",se(E,H)),te(g,ze,"presentation"),te(R,ze,"tab"),te(R,Rt,x.join(" ")),te(R,$e,fn(A,H+1)),te(R,ct,-1),u.push({li:g,button:R,page:H})}}function z(W){m(">"+W,!0)}function E(W,L){var F=u.length,O=jn(L),U=v(),H=-1;O===h(Zt,!1,U)?H=++W%F:O===h(Jt,!1,U)?H=(--W+F)%F:O==="Home"?H=0:O==="End"&&(H=F-1);var g=u[H];g&&(vo(g.button),m(">"+H),Oe(L,!0))}function v(){return n.paginationDirection||n.direction}function T(W){return u[d.toPage(W)]}function V(){var W=T(_(!0)),L=T(_());if(W){var F=W.button;Be(F,Qe),Fe(F,qn),te(F,ct,-1)}if(L){var O=L.button;Re(O,Qe),te(O,qn,!0),te(O,ct,"")}a(Fo,{list:b,items:u},W,L)}return{items:u,mount:f,destroy:w,getAt:T,update:V}}var Hi=[" ","Enter"];function Pi(e,t,n){var o=n.isNavigation,r=n.slideFocus,a=[];function i(){e.splides.forEach(function(c){c.isParent||(d(e,c.splide),d(c.splide,e))}),o&&p()}function s(){a.forEach(function(c){c.destroy()}),We(a)}function l(){s(),i()}function d(c,u){var b=pe(c);b.on(Me,function($,f,w){u.go(u.is(mt)?w:$)}),a.push(b)}function p(){var c=pe(e),u=c.on;u(An,m),u(No,h),u([qe,Se],_),a.push(c),c.emit(Ln,e.splides)}function _(){te(t.Elements.list,Vn,n.direction===Qt?"vertical":"")}function m(c){e.go(c.index)}function h(c,u){Cn(Hi,jn(u))&&(m(c),Oe(u))}return{setup:se(t.Media.set,{slideFocus:At(r)?o:r},!0),mount:i,destroy:s,remount:l}}function Ui(e,t,n){var o=pe(e),r=o.bind,a=0;function i(){n.wheel&&r(t.Elements.track,"wheel",s,at)}function s(d){if(d.cancelable){var p=d.deltaY,_=p<0,m=dn(d),h=n.wheelMinThreshold||0,c=n.wheelSleep||0;xe(p)>h&&m-a>c&&(e.go(_?"<":">"),a=m),l(_)&&Oe(d)}}function l(d){return!n.releaseWheel||e.state.is(gt)||t.Controller.getAdjacent(d)!==-1}return{mount:i}}var Gi=90;function Yi(e,t,n){var o=pe(e),r=o.on,a=t.Elements.track,i=n.live&&!n.isNavigation,s=st("span",pi),l=Xt(Gi,se(p,!1));function d(){i&&(m(!t.Autoplay.isPaused()),te(a,Jn,!0),s.textContent="…",r(In,se(m,!0)),r(kn,se(m,!1)),r([ft,et],se(p,!0)))}function p(h){te(a,Kn,h),h?(Lt(a,s),l.start()):(Ze(s),l.cancel())}function _(){Fe(a,[Xn,Jn,Kn]),Ze(s)}function m(h){i&&te(a,Xn,h?"off":"polite")}return{mount:d,disable:m,destroy:_}}var qi=Object.freeze({__proto__:null,Media:ni,Direction:oi,Elements:hi,Slides:bi,Layout:Si,Clones:Ci,Move:_i,Controller:wi,Arrows:Ai,Autoplay:Li,Cover:Ii,Scroll:Oi,Drag:ji,Keyboard:zi,LazyLoad:Mi,Pagination:Di,Sync:Pi,Wheel:Ui,Live:Yi}),Xi={prev:"Previous slide",next:"Next slide",first:"Go to first slide",last:"Go to last slide",slideX:"Go to slide %s",pageX:"Go to page %s",play:"Start autoplay",pause:"Pause autoplay",carousel:"carousel",slide:"slide",select:"Select a slide to show",slideLabel:"%s of %s"},Ki={type:"slide",role:"region",speed:400,perPage:1,cloneStatus:!0,arrows:!0,pagination:!0,paginationKeyboard:!0,interval:5e3,pauseOnHover:!0,pauseOnFocus:!0,resetProgress:!0,easing:"cubic-bezier(0.25, 1, 0.5, 1)",drag:!0,direction:"ltr",trimSpace:!0,focusableNodes:"a, button, textarea, input, select, iframe",live:!0,classes:fi,i18n:Xi,reducedMotion:{speed:0,rewindSpeed:0,autoplay:"pause"}};function Ji(e,t,n){var o=t.Slides;function r(){pe(e).on([qe,he],a)}function a(){o.forEach(function(s){s.style("transform","translateX(-"+100*s.index+"%)")})}function i(s,l){o.style("transition","opacity "+n.speed+"ms "+n.easing),fo(l)}return{mount:r,start:i,cancel:pn}}function Zi(e,t,n){var o=t.Move,r=t.Controller,a=t.Scroll,i=t.Elements.list,s=se(Ee,i,"transition"),l;function d(){pe(e).bind(i,"transitionend",function(h){h.target===i&&l&&(_(),l())})}function p(h,c){var u=o.toPosition(h,!0),b=o.getPosition(),$=m(h);xe(u-b)>=1&&$>=1?n.useScroll?a.scroll(u,$,!1,c):(s("transform "+$+"ms "+n.easing),o.translate(u,!0),l=c):(o.jump(h),c())}function _(){s(""),a.cancel()}function m(h){var c=n.rewindSpeed;if(e.is(dt)&&c){var u=r.getIndex(!0),b=r.getEnd();if(u===0&&h>=b||u>=b&&h===0)return c}return n.speed}return{mount:d,start:p,cancel:_}}var Qi=(function(){function e(n,o){this.event=pe(),this.Components={},this.state=ei(lt),this.splides=[],this._o={},this._E={};var r=Ue(n)?So(document,n):n;yt(r,r+" is invalid."),this.root=r,o=Pe({label:Le(r,$e)||"",labelledby:Le(r,Fn)||""},Ki,e.defaults,o||{});try{Pe(o,JSON.parse(Le(r,$n)))}catch{yt(!1,"Invalid JSON")}this._o=Object.create(Pe({},o))}var t=e.prototype;return t.mount=function(o,r){var a=this,i=this.state,s=this.Components;yt(i.is([lt,Mt]),"Already mounted!"),i.set(lt),this._C=s,this._T=r||this._T||(this.is(Ft)?Ji:Zi),this._E=o||this._E;var l=Ct({},qi,this._E,{Transition:this._T});return Je(l,function(d,p){var _=d(a,s,a._o);s[p]=_,_.setup&&_.setup()}),Je(s,function(d){d.mount&&d.mount()}),this.emit(qe),Re(this.root,di),i.set(ut),this.emit(mn),this},t.sync=function(o){return this.splides.push({splide:o}),o.splides.push({splide:this,isParent:!0}),this.state.is(ut)&&(this._C.Sync.remount(),o.Components.Sync.remount()),this},t.go=function(o){return this._C.Controller.go(o),this},t.on=function(o,r){return this.event.on(o,r),this},t.off=function(o){return this.event.off(o),this},t.emit=function(o){var r;return(r=this.event).emit.apply(r,[o].concat(Ye(arguments,1))),this},t.add=function(o,r){return this._C.Slides.add(o,r),this},t.remove=function(o){return this._C.Slides.remove(o),this},t.is=function(o){return this._o.type===o},t.refresh=function(){return this.emit(he),this},t.destroy=function(o){o===void 0&&(o=!0);var r=this.event,a=this.state;return a.is(lt)?pe(this).on(mn,this.destroy.bind(this,o)):(Je(this._C,function(i){i.destroy&&i.destroy(o)},!0),r.emit(En),r.destroy(),o&&We(this.splides),a.set(Mt)),this},Xr(e,[{key:"options",get:function(){return this._o},set:function(o){this._C.Media.set(o,!0,!0)}},{key:"length",get:function(){return this._C.Slides.getLength(!0)}},{key:"index",get:function(){return this._C.Controller.getIndex()}}]),e})(),Bn=Qi;Bn.defaults={};Bn.STATES=Jr;var to=[[qe,"onMounted"],[mn,"onReady"],[Me,"onMove"],[ft,"onMoved"],[An,"onClick"],[_o,"onActive"],[wo,"onInactive"],[$o,"onVisible"],[To,"onHidden"],[he,"onRefresh"],[Se,"onUpdated"],[pt,"onResize"],[Yt,"onResized"],[Ao,"onDrag"],[Eo,"onDragging"],[Lo,"onDragged"],[qt,"onScroll"],[et,"onScrolled"],[En,"onDestroy"],[Io,"onArrowsMounted"],[ko,"onArrowsUpdated"],[Ro,"onPaginationMounted"],[Fo,"onPaginationUpdated"],[Ln,"onNavigationMounted"],[In,"onAutoplayPlay"],[Vo,"onAutoplayPlaying"],[kn,"onAutoplayPause"],[Rn,"onLazyLoadLoaded"]];function zn(...e){return e.filter(Boolean).join(" ")}function Ut(e){return e!==null&&typeof e=="object"}function vn(e,t){if(Array.isArray(e)&&Array.isArray(t))return e.length===t.length&&!e.some((n,o)=>!vn(n,t[o]));if(Ut(e)&&Ut(t)){const n=Object.keys(e),o=Object.keys(t);return n.length===o.length&&!n.some(r=>!Object.prototype.hasOwnProperty.call(t,r)||!vn(e[r],t[r]))}return e===t}function ea(e,t){return e.length===t.length&&!e.some((n,o)=>n!==t[o])}function ta(e,t){if(e){const n=Object.keys(e);for(let o=0;o<n.length;o++){const r=n[o];if(r!=="__proto__"&&t(e[r],r)===!1)break}}return e}function bn(e,t){const n=e;return ta(t,(o,r)=>{Array.isArray(o)?n[r]=o.slice():Ut(o)?n[r]=bn(Ut(n[r])?n[r]:{},o):n[r]=o}),n}var na=({children:e,className:t,...n})=>D.createElement("div",{className:zn("splide__track",t),...n},D.createElement("ul",{className:"splide__list"},e)),Ko=class extends D.Component{constructor(){super(...arguments),this.splideRef=D.createRef(),this.slides=[]}componentDidMount(){const{options:e,extensions:t,transition:n}=this.props,{current:o}=this.splideRef;o&&(this.splide=new Bn(o,e),this.bind(this.splide),this.splide.mount(t,n),this.options=bn({},e||{}),this.slides=this.getSlides())}componentWillUnmount(){this.splide&&(this.splide.destroy(),this.splide=void 0),this.options=void 0,this.slides.length=0}componentDidUpdate(){if(!this.splide)return;const{options:e}=this.props;e&&!vn(this.options,e)&&(this.splide.options=e,this.options=bn({},e));const t=this.getSlides();ea(this.slides,t)||(this.splide.refresh(),this.slides=t)}sync(e){var t;(t=this.splide)==null||t.sync(e)}go(e){var t;(t=this.splide)==null||t.go(e)}getSlides(){var e;if(this.splide){const t=(e=this.splide.Components.Elements)==null?void 0:e.list.children;return t&&Array.prototype.slice.call(t)||[]}return[]}bind(e){to.forEach(([t,n])=>{const o=this.props[n];typeof o=="function"&&e.on(t,(...r)=>{o(e,...r)})})}omit(e,t){return t.forEach(n=>{Object.prototype.hasOwnProperty.call(e,n)&&delete e[n]}),e}render(){const{className:e,tag:t="div",hasTrack:n=!0,children:o,...r}=this.props;return D.createElement(t,{className:zn("splide",e),ref:this.splideRef,...this.omit(r,["options",...to.map(a=>a[1])])},n?D.createElement(na,null,o):o)}},Jo=({children:e,className:t,...n})=>D.createElement("li",{className:zn("splide__slide",t),...n},e);/*!
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const x=require("react/jsx-runtime"),j=require("react"),dt=require("classnames"),F=require("./useScopedStyles-DpVdqfXj.js"),pr=require("react-dom");function dr(t){return t.type==="object"&&t.version===1}const gr="ControlSlider-module__wrapper___sHEkd",mr="ControlSlider-module__hoverArrow___A-dOH",fr="ControlSlider-module__sliderItem___QQSkR",hr="ControlSlider-module__sliderImage___9hRl-",vr="ControlSlider-module__arrow___05ghY",yr="ControlSlider-module__arrowVertical___tBfVN",br="ControlSlider-module__nextArrow___-30Yc",Sr="ControlSlider-module__arrowInner___aEra3",xr="ControlSlider-module__arrowIcon___S4ztF",Cr="ControlSlider-module__arrowImg___2dwJW",$r="ControlSlider-module__mirror___brd6U",_r="ControlSlider-module__pagination___bicLF",wr="ControlSlider-module__paginationInner___bT-P-",Tr="ControlSlider-module__paginationVertical___zYqKw",Er="ControlSlider-module__paginationItem___nTRbk",Lr="ControlSlider-module__dot___p1Qun",Ar="ControlSlider-module__activeDot___LHFaj",Ir="ControlSlider-module__paginationInsideBottom___R3FWn",kr="ControlSlider-module__paginationInsideTop___V-qb-",Fr="ControlSlider-module__paginationOutsideBottom___14w8D",Rr="ControlSlider-module__paginationOutsideTop___SCLqB",Br="ControlSlider-module__paginationInsideLeft___yOBRZ",Vr="ControlSlider-module__paginationInsideRight___Rtt3o",Or="ControlSlider-module__paginationOutsideLeft___lahaw",Pr="ControlSlider-module__paginationOutsideRight___EtuQa",Nr="ControlSlider-module__imgWrapper___UjEgB",Wr="ControlSlider-module__captionBlock___dJ6-j",zr="ControlSlider-module__captionTextWrapper___HFlpf",jr="ControlSlider-module__captionText___uGBVc",Mr="ControlSlider-module__active___WZK4G",Hr="ControlSlider-module__withPointerEvents___t-18M",Dr="ControlSlider-module__topLeftAlignment___zjnGM",Ur="ControlSlider-module__topCenterAlignment___gD1xW",Yr="ControlSlider-module__topRightAlignment___NMapS",Gr="ControlSlider-module__middleLeftAlignment___OnUrY",qr="ControlSlider-module__middleCenterAlignment___Tdkl0",Xr="ControlSlider-module__middleRightAlignment___wEbfX",Kr="ControlSlider-module__bottomLeftAlignment___cTP2-",Jr="ControlSlider-module__bottomCenterAlignment___c54fB",Zr="ControlSlider-module__bottomRightAlignment___kEwrz",Qr="ControlSlider-module__clickOverlay___DZA28",ti="ControlSlider-module__contain___pLyq7",ei="ControlSlider-module__cover___KdDat",Y={wrapper:gr,hoverArrow:mr,sliderItem:fr,sliderImage:hr,arrow:vr,arrowVertical:yr,nextArrow:br,arrowInner:Sr,arrowIcon:xr,arrowImg:Cr,mirror:$r,pagination:_r,paginationInner:wr,paginationVertical:Tr,paginationItem:Er,dot:Lr,activeDot:Ar,paginationInsideBottom:Ir,paginationInsideTop:kr,paginationOutsideBottom:Fr,paginationOutsideTop:Rr,paginationInsideLeft:Br,paginationInsideRight:Vr,paginationOutsideLeft:Or,paginationOutsideRight:Pr,imgWrapper:Nr,captionBlock:Wr,captionTextWrapper:zr,captionText:jr,active:Mr,withPointerEvents:Hr,topLeftAlignment:Dr,topCenterAlignment:Ur,topRightAlignment:Yr,middleLeftAlignment:Gr,middleCenterAlignment:qr,middleRightAlignment:Xr,bottomLeftAlignment:Kr,bottomCenterAlignment:Jr,bottomRightAlignment:Zr,clickOverlay:Qr,contain:ti,cover:ei};function ni(t,e){for(var n=0;n<e.length;n++){var o=e[n];o.enumerable=o.enumerable||!1,o.configurable=!0,"value"in o&&(o.writable=!0),Object.defineProperty(t,o.key,o)}}function oi(t,e,n){return e&&ni(t.prototype,e),Object.defineProperty(t,"prototype",{writable:!1}),t}var Zn="(prefers-reduced-motion: reduce)",ue=1,ri=2,me=3,ve=4,ke=5,Ue=6,Xe=7,ii={CREATED:ue,MOUNTED:ri,IDLE:me,MOVING:ve,SCROLLING:ke,DRAGGING:Ue,DESTROYED:Xe};function zt(t){t.length=0}function qt(t,e,n){return Array.prototype.slice.call(t,e,n)}function at(t){return t.bind.apply(t,[null].concat(qt(arguments,1)))}var So=setTimeout,bn=function(){};function Qn(t){return requestAnimationFrame(t)}function tn(t,e){return typeof e===t}function _e(t){return!An(t)&&tn("object",t)}var Ln=Array.isArray,xo=at(tn,"function"),Yt=at(tn,"string"),Fe=at(tn,"undefined");function An(t){return t===null}function Co(t){try{return t instanceof(t.ownerDocument.defaultView||window).HTMLElement}catch{return!1}}function Re(t){return Ln(t)?t:[t]}function Tt(t,e){Re(t).forEach(e)}function In(t,e){return t.indexOf(e)>-1}function Ye(t,e){return t.push.apply(t,Re(e)),t}function Pt(t,e,n){t&&Tt(e,function(o){o&&t.classList[n?"add":"remove"](o)})}function Rt(t,e){Pt(t,Yt(e)?e.split(" "):e,!0)}function Be(t,e){Tt(e,t.appendChild.bind(t))}function kn(t,e){Tt(t,function(n){var o=(e||n).parentNode;o&&o.insertBefore(n,e)})}function we(t,e){return Co(t)&&(t.msMatchesSelector||t.matches).call(t,e)}function $o(t,e){var n=t?qt(t.children):[];return e?n.filter(function(o){return we(o,e)}):n}function Ve(t,e){return e?$o(t,e)[0]:t.firstElementChild}var Te=Object.keys;function te(t,e,n){return t&&(n?Te(t).reverse():Te(t)).forEach(function(o){o!=="__proto__"&&e(t[o],o)}),t}function Ee(t){return qt(arguments,1).forEach(function(e){te(e,function(n,o){t[o]=e[o]})}),t}function Ut(t){return qt(arguments,1).forEach(function(e){te(e,function(n,o){Ln(n)?t[o]=n.slice():_e(n)?t[o]=Ut({},_e(t[o])?t[o]:{},n):t[o]=n})}),t}function to(t,e){Tt(e||Te(t),function(n){delete t[n]})}function Bt(t,e){Tt(t,function(n){Tt(e,function(o){n&&n.removeAttribute(o)})})}function Z(t,e,n){_e(e)?te(e,function(o,r){Z(t,r,o)}):Tt(t,function(o){An(n)||n===""?Bt(o,e):o.setAttribute(e,String(n))})}function pe(t,e,n){var o=document.createElement(t);return e&&(Yt(e)?Rt(o,e):Z(o,e)),n&&Be(n,o),o}function Lt(t,e,n){if(Fe(n))return getComputedStyle(t)[e];An(n)||(t.style[e]=""+n)}function Le(t,e){Lt(t,"display",e)}function _o(t){t.setActive&&t.setActive()||t.focus({preventScroll:!0})}function At(t,e){return t.getAttribute(e)}function eo(t,e){return t&&t.classList.contains(e)}function _t(t){return t.getBoundingClientRect()}function ee(t){Tt(t,function(e){e&&e.parentNode&&e.parentNode.removeChild(e)})}function wo(t){return Ve(new DOMParser().parseFromString(t,"text/html").body)}function Ot(t,e){t.preventDefault(),e&&(t.stopPropagation(),t.stopImmediatePropagation())}function To(t,e){return t&&t.querySelector(e)}function Fn(t,e){return e?qt(t.querySelectorAll(e)):[]}function Nt(t,e){Pt(t,e,!1)}function Sn(t){return t.timeStamp}function Zt(t){return Yt(t)?t:t?t+"px":""}var Oe="splide",Rn="data-"+Oe;function Ce(t,e){if(!t)throw new Error("["+Oe+"] "+(e||""))}var Gt=Math.min,Ke=Math.max,Je=Math.floor,Ae=Math.ceil,xt=Math.abs;function Eo(t,e,n){return xt(t-e)<n}function Ge(t,e,n,o){var r=Gt(e,n),a=Ke(e,n);return o?r<t&&t<a:r<=t&&t<=a}function se(t,e,n){var o=Gt(e,n),r=Ke(e,n);return Gt(Ke(o,t),r)}function xn(t){return+(t>0)-+(t<0)}function Cn(t,e){return Tt(e,function(n){t=t.replace("%s",""+n)}),t}function Bn(t){return t<10?"0"+t:""+t}var no={};function ai(t){return""+t+Bn(no[t]=(no[t]||0)+1)}function Lo(){var t=[];function e(i,c,l,p){r(i,c,function(s,w,v){var m="addEventListener"in s,u=m?s.removeEventListener.bind(s,w,l,p):s.removeListener.bind(s,l);m?s.addEventListener(w,l,p):s.addListener(l),t.push([s,w,v,l,u])})}function n(i,c,l){r(i,c,function(p,s,w){t=t.filter(function(v){return v[0]===p&&v[1]===s&&v[2]===w&&(!l||v[3]===l)?(v[4](),!1):!0})})}function o(i,c,l){var p,s=!0;return typeof CustomEvent=="function"?p=new CustomEvent(c,{bubbles:s,detail:l}):(p=document.createEvent("CustomEvent"),p.initCustomEvent(c,s,!1,l)),i.dispatchEvent(p),p}function r(i,c,l){Tt(i,function(p){p&&Tt(c,function(s){s.split(" ").forEach(function(w){var v=w.split(".");l(p,v[0],v[1])})})})}function a(){t.forEach(function(i){i[4]()}),zt(t)}return{bind:e,unbind:n,dispatch:o,destroy:a}}var Xt="mounted",$n="ready",jt="move",ye="moved",Vn="click",Ao="active",Io="inactive",ko="visible",Fo="hidden",vt="refresh",St="updated",fe="resize",en="resized",Ro="drag",Bo="dragging",Vo="dragged",nn="scroll",oe="scrolled",li="overflow",On="destroy",Oo="arrows:mounted",Po="arrows:updated",No="pagination:mounted",Wo="pagination:updated",Pn="navigation:mounted",Nn="autoplay:play",zo="autoplay:playing",Wn="autoplay:pause",zn="lazyload:loaded",jo="sk",Mo="sh",Ze="ei";function gt(t){var e=t?t.event.bus:document.createDocumentFragment(),n=Lo();function o(a,i){n.bind(e,Re(a).join(" "),function(c){i.apply(i,Ln(c.detail)?c.detail:[])})}function r(a){n.dispatch(e,a,qt(arguments,1))}return t&&t.event.on(On,n.destroy),Ee(n,{bus:e,on:o,off:at(n.unbind,e),emit:r})}function on(t,e,n,o){var r=Date.now,a,i=0,c,l=!0,p=0;function s(){if(!l){if(i=t?Gt((r()-a)/t,1):1,n&&n(i),i>=1&&(e(),a=r(),o&&++p>=o))return v();c=Qn(s)}}function w(b){b||u(),a=r()-(b?i*t:0),l=!1,c=Qn(s)}function v(){l=!0}function m(){a=r(),i=0,n&&n(i)}function u(){c&&cancelAnimationFrame(c),i=0,c=0,l=!0}function d(b){t=b}function C(){return l}return{start:w,rewind:m,pause:v,cancel:u,set:d,isPaused:C}}function si(t){var e=t;function n(r){e=r}function o(r){return In(Re(r),e)}return{set:n,is:o}}function ci(t,e){var n=on(0,t,null,1);return function(){n.isPaused()&&n.start()}}function ui(t,e,n){var o=t.state,r=n.breakpoints||{},a=n.reducedMotion||{},i=Lo(),c=[];function l(){var u=n.mediaQuery==="min";Te(r).sort(function(d,C){return u?+d-+C:+C-+d}).forEach(function(d){s(r[d],"("+(u?"min":"max")+"-width:"+d+"px)")}),s(a,Zn),w()}function p(u){u&&i.destroy()}function s(u,d){var C=matchMedia(d);i.bind(C,"change",w),c.push([u,C])}function w(){var u=o.is(Xe),d=n.direction,C=c.reduce(function(b,f){return Ut(b,f[1].matches?f[0]:{})},{});to(n),m(C),n.destroy?t.destroy(n.destroy==="completely"):u?(p(!0),t.mount()):d!==n.direction&&t.refresh()}function v(u){matchMedia(Zn).matches&&(u?Ut(n,a):to(n,Te(a)))}function m(u,d,C){Ut(n,u),d&&Ut(Object.getPrototypeOf(n),u),(C||!o.is(ue))&&t.emit(St,n)}return{setup:l,destroy:p,reduce:v,set:m}}var rn="Arrow",an=rn+"Left",ln=rn+"Right",Ho=rn+"Up",Do=rn+"Down",oo="rtl",sn="ttb",gn={width:["height"],left:["top","right"],right:["bottom","left"],x:["y"],X:["Y"],Y:["X"],ArrowLeft:[Ho,ln],ArrowRight:[Do,an]};function pi(t,e,n){function o(a,i,c){c=c||n.direction;var l=c===oo&&!i?1:c===sn?0:-1;return gn[a]&&gn[a][l]||a.replace(/width|left|right/i,function(p,s){var w=gn[p.toLowerCase()][l]||p;return s>0?w.charAt(0).toUpperCase()+w.slice(1):w})}function r(a){return a*(n.direction===oo?1:-1)}return{resolve:o,orient:r}}var Wt="role",de="tabindex",di="disabled",It="aria-",Pe=It+"controls",Uo=It+"current",ro=It+"selected",wt=It+"label",jn=It+"labelledby",Yo=It+"hidden",Mn=It+"orientation",Ie=It+"roledescription",io=It+"live",ao=It+"busy",lo=It+"atomic",Hn=[Wt,de,di,Pe,Uo,wt,jn,Yo,Mn,Ie],Vt=Oe+"__",Kt="is-",mn=Oe,so=Vt+"track",gi=Vt+"list",cn=Vt+"slide",Go=cn+"--clone",mi=cn+"__container",Dn=Vt+"arrows",un=Vt+"arrow",qo=un+"--prev",Xo=un+"--next",pn=Vt+"pagination",Ko=pn+"__page",fi=Vt+"progress",hi=fi+"__bar",vi=Vt+"toggle",yi=Vt+"spinner",bi=Vt+"sr",Si=Kt+"initialized",ne=Kt+"active",Jo=Kt+"prev",Zo=Kt+"next",_n=Kt+"visible",wn=Kt+"loading",Qo=Kt+"focus-in",tr=Kt+"overflow",xi=[ne,_n,Jo,Zo,wn,Qo,tr],Ci={slide:cn,clone:Go,arrows:Dn,arrow:un,prev:qo,next:Xo,pagination:pn,page:Ko,spinner:yi};function $i(t,e){if(xo(t.closest))return t.closest(e);for(var n=t;n&&n.nodeType===1&&!we(n,e);)n=n.parentElement;return n}var _i=5,co=200,er="touchstart mousedown",fn="touchmove mousemove",hn="touchend touchcancel mouseup click";function wi(t,e,n){var o=gt(t),r=o.on,a=o.bind,i=t.root,c=n.i18n,l={},p=[],s=[],w=[],v,m,u;function d(){$(),M(),f()}function C(){r(vt,b),r(vt,d),r(St,f),a(document,er+" keydown",function(h){u=h.type==="keydown"},{capture:!0}),a(i,"focusin",function(){Pt(i,Qo,!!u)})}function b(h){var L=Hn.concat("style");zt(p),Nt(i,s),Nt(v,w),Bt([v,m],L),Bt(i,h?L:["style",Ie])}function f(){Nt(i,s),Nt(v,w),s=T(mn),w=T(so),Rt(i,s),Rt(v,w),Z(i,wt,n.label),Z(i,jn,n.labelledby)}function $(){v=P("."+so),m=Ve(v,"."+gi),Ce(v&&m,"A track/list element is missing."),Ye(p,$o(m,"."+cn+":not(."+Go+")")),te({arrows:Dn,pagination:pn,prev:qo,next:Xo,bar:hi,toggle:vi},function(h,L){l[L]=P("."+h)}),Ee(l,{root:i,track:v,list:m,slides:p})}function M(){var h=i.id||ai(Oe),L=n.role;i.id=h,v.id=v.id||h+"-track",m.id=m.id||h+"-list",!At(i,Wt)&&i.tagName!=="SECTION"&&L&&Z(i,Wt,L),Z(i,Ie,c.carousel),Z(m,Wt,"presentation")}function P(h){var L=To(i,h);return L&&$i(L,"."+mn)===i?L:void 0}function T(h){return[h+"--"+n.type,h+"--"+n.direction,n.drag&&h+"--draggable",n.isNavigation&&h+"--nav",h===mn&&ne]}return Ee(l,{setup:d,mount:C,destroy:b})}var he="slide",be="loop",Ne="fade";function Ti(t,e,n,o){var r=gt(t),a=r.on,i=r.emit,c=r.bind,l=t.Components,p=t.root,s=t.options,w=s.isNavigation,v=s.updateOnMove,m=s.i18n,u=s.pagination,d=s.slideFocus,C=l.Direction.resolve,b=At(o,"style"),f=At(o,wt),$=n>-1,M=Ve(o,"."+mi),P;function T(){$||(o.id=p.id+"-slide"+Bn(e+1),Z(o,Wt,u?"tabpanel":"group"),Z(o,Ie,m.slide),Z(o,wt,f||Cn(m.slideLabel,[e+1,t.length]))),h()}function h(){c(o,"click",at(i,Vn,I)),c(o,"keydown",at(i,jo,I)),a([ye,Mo,oe],k),a(Pn,R),v&&a(jt,W)}function L(){P=!0,r.destroy(),Nt(o,xi),Bt(o,Hn),Z(o,"style",b),Z(o,wt,f||"")}function R(){var _=t.splides.map(function(y){var V=y.splide.Components.Slides.getAt(e);return V?V.slide.id:""}).join(" ");Z(o,wt,Cn(m.slideX,($?n:e)+1)),Z(o,Pe,_),Z(o,Wt,d?"button":""),d&&Bt(o,Ie)}function W(){P||k()}function k(){if(!P){var _=t.index;B(),O(),Pt(o,Jo,e===_-1),Pt(o,Zo,e===_+1)}}function B(){var _=D();_!==eo(o,ne)&&(Pt(o,ne,_),Z(o,Uo,w&&_||""),i(_?Ao:Io,I))}function O(){var _=g(),y=!_&&(!D()||$);if(t.state.is([ve,ke])||Z(o,Yo,y||""),Z(Fn(o,s.focusableNodes||""),de,y?-1:""),d&&Z(o,de,y?-1:0),_!==eo(o,_n)&&(Pt(o,_n,_),i(_?ko:Fo,I)),!_&&document.activeElement===o){var V=l.Slides.getAt(t.index);V&&_o(V.slide)}}function U(_,y,V){Lt(V&&M||o,_,y)}function D(){var _=t.index;return _===e||s.cloneStatus&&_===n}function g(){if(t.is(Ne))return D();var _=_t(l.Elements.track),y=_t(o),V=C("left",!0),X=C("right",!0);return Je(_[V])<=Ae(y[V])&&Je(y[X])<=Ae(_[X])}function A(_,y){var V=xt(_-e);return!$&&(s.rewind||t.is(be))&&(V=Gt(V,t.length-V)),V<=y}var I={index:e,slideIndex:n,slide:o,container:M,isClone:$,mount:T,destroy:L,update:k,style:U,isWithin:A};return I}function Ei(t,e,n){var o=gt(t),r=o.on,a=o.emit,i=o.bind,c=e.Elements,l=c.slides,p=c.list,s=[];function w(){v(),r(vt,m),r(vt,v)}function v(){l.forEach(function(k,B){d(k,B,-1)})}function m(){P(function(k){k.destroy()}),zt(s)}function u(){P(function(k){k.update()})}function d(k,B,O){var U=Ti(t,B,O,k);U.mount(),s.push(U),s.sort(function(D,g){return D.index-g.index})}function C(k){return k?T(function(B){return!B.isClone}):s}function b(k){var B=e.Controller,O=B.toIndex(k),U=B.hasFocus()?1:n.perPage;return T(function(D){return Ge(D.index,O,O+U-1)})}function f(k){return T(k)[0]}function $(k,B){Tt(k,function(O){if(Yt(O)&&(O=wo(O)),Co(O)){var U=l[B];U?kn(O,U):Be(p,O),Rt(O,n.classes.slide),L(O,at(a,fe))}}),a(vt)}function M(k){ee(T(k).map(function(B){return B.slide})),a(vt)}function P(k,B){C(B).forEach(k)}function T(k){return s.filter(xo(k)?k:function(B){return Yt(k)?we(B.slide,k):In(Re(k),B.index)})}function h(k,B,O){P(function(U){U.style(k,B,O)})}function L(k,B){var O=Fn(k,"img"),U=O.length;U?O.forEach(function(D){i(D,"load error",function(){--U||B()})}):B()}function R(k){return k?l.length:s.length}function W(){return s.length>n.perPage}return{mount:w,destroy:m,update:u,register:d,get:C,getIn:b,getAt:f,add:$,remove:M,forEach:P,filter:T,style:h,getLength:R,isEnough:W}}function Li(t,e,n){var o=gt(t),r=o.on,a=o.bind,i=o.emit,c=e.Slides,l=e.Direction.resolve,p=e.Elements,s=p.root,w=p.track,v=p.list,m=c.getAt,u=c.style,d,C,b;function f(){$(),a(window,"resize load",ci(at(i,fe))),r([St,vt],$),r(fe,M)}function $(){d=n.direction===sn,Lt(s,"maxWidth",Zt(n.width)),Lt(w,l("paddingLeft"),P(!1)),Lt(w,l("paddingRight"),P(!0)),M(!0)}function M(I){var _=_t(s);(I||C.width!==_.width||C.height!==_.height)&&(Lt(w,"height",T()),u(l("marginRight"),Zt(n.gap)),u("width",L()),u("height",R(),!0),C=_,i(en),b!==(b=A())&&(Pt(s,tr,b),i(li,b)))}function P(I){var _=n.padding,y=l(I?"right":"left");return _&&Zt(_[y]||(_e(_)?0:_))||"0px"}function T(){var I="";return d&&(I=h(),Ce(I,"height or heightRatio is missing."),I="calc("+I+" - "+P(!1)+" - "+P(!0)+")"),I}function h(){return Zt(n.height||_t(v).width*n.heightRatio)}function L(){return n.autoWidth?null:Zt(n.fixedWidth)||(d?"":W())}function R(){return Zt(n.fixedHeight)||(d?n.autoHeight?null:W():h())}function W(){var I=Zt(n.gap);return"calc((100%"+(I&&" + "+I)+")/"+(n.perPage||1)+(I&&" - "+I)+")"}function k(){return _t(v)[l("width")]}function B(I,_){var y=m(I||0);return y?_t(y.slide)[l("width")]+(_?0:D()):0}function O(I,_){var y=m(I);if(y){var V=_t(y.slide)[l("right")],X=_t(v)[l("left")];return xt(V-X)+(_?0:D())}return 0}function U(I){return O(t.length-1)-O(0)+B(0,I)}function D(){var I=m(0);return I&&parseFloat(Lt(I.slide,l("marginRight")))||0}function g(I){return parseFloat(Lt(w,l("padding"+(I?"Right":"Left"))))||0}function A(){return t.is(Ne)||U(!0)>k()}return{mount:f,resize:M,listSize:k,slideSize:B,sliderSize:U,totalSize:O,getPadding:g,isOverflow:A}}var Ai=2;function Ii(t,e,n){var o=gt(t),r=o.on,a=e.Elements,i=e.Slides,c=e.Direction.resolve,l=[],p;function s(){r(vt,w),r([St,fe],m),(p=C())&&(u(p),e.Layout.resize(!0))}function w(){v(),s()}function v(){ee(l),zt(l),o.destroy()}function m(){var b=C();p!==b&&(p<b||!b)&&o.emit(vt)}function u(b){var f=i.get().slice(),$=f.length;if($){for(;f.length<b;)Ye(f,f);Ye(f.slice(-b),f.slice(0,b)).forEach(function(M,P){var T=P<b,h=d(M.slide,P);T?kn(h,f[0].slide):Be(a.list,h),Ye(l,h),i.register(h,P-b+(T?0:$),M.index)})}}function d(b,f){var $=b.cloneNode(!0);return Rt($,n.classes.clone),$.id=t.root.id+"-clone"+Bn(f+1),$}function C(){var b=n.clones;if(!t.is(be))b=0;else if(Fe(b)){var f=n[c("fixedWidth")]&&e.Layout.slideSize(0),$=f&&Ae(_t(a.track)[c("width")]/f);b=$||n[c("autoWidth")]&&t.length||n.perPage*Ai}return b}return{mount:s,destroy:v}}function ki(t,e,n){var o=gt(t),r=o.on,a=o.emit,i=t.state.set,c=e.Layout,l=c.slideSize,p=c.getPadding,s=c.totalSize,w=c.listSize,v=c.sliderSize,m=e.Direction,u=m.resolve,d=m.orient,C=e.Elements,b=C.list,f=C.track,$;function M(){$=e.Transition,r([Xt,en,St,vt],P)}function P(){e.Controller.isBusy()||(e.Scroll.cancel(),h(t.index),e.Slides.update())}function T(y,V,X,rt){y!==V&&I(y>X)&&(k(),L(W(U(),y>X),!0)),i(ve),a(jt,V,X,y),$.start(V,function(){i(me),a(ye,V,X,y),rt&&rt()})}function h(y){L(O(y,!0))}function L(y,V){if(!t.is(Ne)){var X=V?y:R(y);Lt(b,"transform","translate"+u("X")+"("+X+"px)"),y!==X&&a(Mo)}}function R(y){if(t.is(be)){var V=B(y),X=V>e.Controller.getEnd(),rt=V<0;(rt||X)&&(y=W(y,X))}return y}function W(y,V){var X=y-A(V),rt=v();return y-=d(rt*(Ae(xt(X)/rt)||1))*(V?1:-1),y}function k(){L(U(),!0),$.cancel()}function B(y){for(var V=e.Slides.get(),X=0,rt=1/0,Q=0;Q<V.length;Q++){var ut=V[Q].index,E=xt(O(ut,!0)-y);if(E<=rt)rt=E,X=ut;else break}return X}function O(y,V){var X=d(s(y-1)-g(y));return V?D(X):X}function U(){var y=u("left");return _t(b)[y]-_t(f)[y]+d(p(!1))}function D(y){return n.trimSpace&&t.is(he)&&(y=se(y,0,d(v(!0)-w()))),y}function g(y){var V=n.focus;return V==="center"?(w()-l(y,!0))/2:+V*l(y)||0}function A(y){return O(y?e.Controller.getEnd():0,!!n.trimSpace)}function I(y){var V=d(W(U(),y));return y?V>=0:V<=b[u("scrollWidth")]-_t(f)[u("width")]}function _(y,V){V=Fe(V)?U():V;var X=y!==!0&&d(V)<d(A(!1)),rt=y!==!1&&d(V)>d(A(!0));return X||rt}return{mount:M,move:T,jump:h,translate:L,shift:W,cancel:k,toIndex:B,toPosition:O,getPosition:U,getLimit:A,exceededLimit:_,reposition:P}}function Fi(t,e,n){var o=gt(t),r=o.on,a=o.emit,i=e.Move,c=i.getPosition,l=i.getLimit,p=i.toPosition,s=e.Slides,w=s.isEnough,v=s.getLength,m=n.omitEnd,u=t.is(be),d=t.is(he),C=at(U,!1),b=at(U,!0),f=n.start||0,$,M=f,P,T,h;function L(){R(),r([St,vt,Ze],R),r(en,W)}function R(){P=v(!0),T=n.perMove,h=n.perPage,$=I();var E=se(f,0,m?$:P-1);E!==f&&(f=E,i.reposition())}function W(){$!==I()&&a(Ze)}function k(E,K,ht){if(!ut()){var it=O(E),mt=A(it);mt>-1&&(K||mt!==f)&&(X(mt),i.move(it,mt,M,ht))}}function B(E,K,ht,it){e.Scroll.scroll(E,K,ht,function(){var mt=A(i.toIndex(c()));X(m?Gt(mt,$):mt),it&&it()})}function O(E){var K=f;if(Yt(E)){var ht=E.match(/([+\-<>])(\d+)?/)||[],it=ht[1],mt=ht[2];it==="+"||it==="-"?K=D(f+ +(""+it+(+mt||1)),f):it===">"?K=mt?_(+mt):C(!0):it==="<"&&(K=b(!0))}else K=u?E:se(E,0,$);return K}function U(E,K){var ht=T||(Q()?1:h),it=D(f+ht*(E?-1:1),f,!(T||Q()));return it===-1&&d&&!Eo(c(),l(!E),1)?E?0:$:K?it:A(it)}function D(E,K,ht){if(w()||Q()){var it=g(E);it!==E&&(K=E,E=it,ht=!1),E<0||E>$?!T&&(Ge(0,E,K,!0)||Ge($,K,E,!0))?E=_(y(E)):u?E=ht?E<0?-(P%h||h):P:E:n.rewind?E=E<0?$:0:E=-1:ht&&E!==K&&(E=_(y(K)+(E<K?-1:1)))}else E=-1;return E}function g(E){if(d&&n.trimSpace==="move"&&E!==f)for(var K=c();K===p(E,!0)&&Ge(E,0,t.length-1,!n.rewind);)E<f?--E:++E;return E}function A(E){return u?(E+P)%P||0:E}function I(){for(var E=P-(Q()||u&&T?1:h);m&&E-- >0;)if(p(P-1,!0)!==p(E,!0)){E++;break}return se(E,0,P-1)}function _(E){return se(Q()?E:h*E,0,$)}function y(E){return Q()?Gt(E,$):Je((E>=$?P-1:E)/h)}function V(E){var K=i.toIndex(E);return d?se(K,0,$):K}function X(E){E!==f&&(M=f,f=E)}function rt(E){return E?M:f}function Q(){return!Fe(n.focus)||n.isNavigation}function ut(){return t.state.is([ve,ke])&&!!n.waitForTransition}return{mount:L,go:k,scroll:B,getNext:C,getPrev:b,getAdjacent:U,getEnd:I,setIndex:X,getIndex:rt,toIndex:_,toPage:y,toDest:V,hasFocus:Q,isBusy:ut}}var Ri="http://www.w3.org/2000/svg",Bi="m15.5 0.932-4.3 4.38 14.5 14.6-14.5 14.5 4.3 4.4 14.6-14.6 4.4-4.3-4.4-4.4-14.6-14.6z",ze=40;function Vi(t,e,n){var o=gt(t),r=o.on,a=o.bind,i=o.emit,c=n.classes,l=n.i18n,p=e.Elements,s=e.Controller,w=p.arrows,v=p.track,m=w,u=p.prev,d=p.next,C,b,f={};function $(){P(),r(St,M)}function M(){T(),$()}function P(){var B=n.arrows;B&&!(u&&d)&&R(),u&&d&&(Ee(f,{prev:u,next:d}),Le(m,B?"":"none"),Rt(m,b=Dn+"--"+n.direction),B&&(h(),k(),Z([u,d],Pe,v.id),i(Oo,u,d)))}function T(){o.destroy(),Nt(m,b),C?(ee(w?[u,d]:m),u=d=null):Bt([u,d],Hn)}function h(){r([Xt,ye,vt,oe,Ze],k),a(d,"click",at(L,">")),a(u,"click",at(L,"<"))}function L(B){s.go(B,!0)}function R(){m=w||pe("div",c.arrows),u=W(!0),d=W(!1),C=!0,Be(m,[u,d]),!w&&kn(m,v)}function W(B){var O='<button class="'+c.arrow+" "+(B?c.prev:c.next)+'" type="button"><svg xmlns="'+Ri+'" viewBox="0 0 '+ze+" "+ze+'" width="'+ze+'" height="'+ze+'" focusable="false"><path d="'+(n.arrowPath||Bi)+'" />';return wo(O)}function k(){if(u&&d){var B=t.index,O=s.getPrev(),U=s.getNext(),D=O>-1&&B<O?l.last:l.prev,g=U>-1&&B>U?l.first:l.next;u.disabled=O<0,d.disabled=U<0,Z(u,wt,D),Z(d,wt,g),i(Po,u,d,O,U)}}return{arrows:f,mount:$,destroy:T,update:k}}var Oi=Rn+"-interval";function Pi(t,e,n){var o=gt(t),r=o.on,a=o.bind,i=o.emit,c=on(n.interval,t.go.bind(t,">"),h),l=c.isPaused,p=e.Elements,s=e.Elements,w=s.root,v=s.toggle,m=n.autoplay,u,d,C=m==="pause";function b(){m&&(f(),v&&Z(v,Pe,p.track.id),C||$(),T())}function f(){n.pauseOnHover&&a(w,"mouseenter mouseleave",function(R){u=R.type==="mouseenter",P()}),n.pauseOnFocus&&a(w,"focusin focusout",function(R){d=R.type==="focusin",P()}),v&&a(v,"click",function(){C?$():M(!0)}),r([jt,nn,vt],c.rewind),r(jt,L)}function $(){l()&&e.Slides.isEnough()&&(c.start(!n.resetProgress),d=u=C=!1,T(),i(Nn))}function M(R){R===void 0&&(R=!0),C=!!R,T(),l()||(c.pause(),i(Wn))}function P(){C||(u||d?M(!1):$())}function T(){v&&(Pt(v,ne,!C),Z(v,wt,n.i18n[C?"play":"pause"]))}function h(R){var W=p.bar;W&&Lt(W,"width",R*100+"%"),i(zo,R)}function L(R){var W=e.Slides.getAt(R);c.set(W&&+At(W.slide,Oi)||n.interval)}return{mount:b,destroy:c.cancel,play:$,pause:M,isPaused:l}}function Ni(t,e,n){var o=gt(t),r=o.on;function a(){n.cover&&(r(zn,at(c,!0)),r([Xt,St,vt],at(i,!0)))}function i(l){e.Slides.forEach(function(p){var s=Ve(p.container||p.slide,"img");s&&s.src&&c(l,s,p)})}function c(l,p,s){s.style("background",l?'center/cover no-repeat url("'+p.src+'")':"",!0),Le(p,l?"none":"")}return{mount:a,destroy:at(i,!1)}}var Wi=10,zi=600,ji=.6,Mi=1.5,Hi=800;function Di(t,e,n){var o=gt(t),r=o.on,a=o.emit,i=t.state.set,c=e.Move,l=c.getPosition,p=c.getLimit,s=c.exceededLimit,w=c.translate,v=t.is(he),m,u,d=1;function C(){r(jt,M),r([St,vt],P)}function b(h,L,R,W,k){var B=l();if(M(),R&&(!v||!s())){var O=e.Layout.sliderSize(),U=xn(h)*O*Je(xt(h)/O)||0;h=c.toPosition(e.Controller.toDest(h%O))+U}var D=Eo(B,h,1);d=1,L=D?0:L||Ke(xt(h-B)/Mi,Hi),u=W,m=on(L,f,at($,B,h,k),1),i(ke),a(nn),m.start()}function f(){i(me),u&&u(),a(oe)}function $(h,L,R,W){var k=l(),B=h+(L-h)*T(W),O=(B-k)*d;w(k+O),v&&!R&&s()&&(d*=ji,xt(O)<Wi&&b(p(s(!0)),zi,!1,u,!0))}function M(){m&&m.cancel()}function P(){m&&!m.isPaused()&&(M(),f())}function T(h){var L=n.easingFunc;return L?L(h):1-Math.pow(1-h,4)}return{mount:C,destroy:M,scroll:b,cancel:P}}var ce={passive:!1,capture:!0};function Ui(t,e,n){var o=gt(t),r=o.on,a=o.emit,i=o.bind,c=o.unbind,l=t.state,p=e.Move,s=e.Scroll,w=e.Controller,v=e.Elements.track,m=e.Media.reduce,u=e.Direction,d=u.resolve,C=u.orient,b=p.getPosition,f=p.exceededLimit,$,M,P,T,h,L=!1,R,W,k;function B(){i(v,fn,bn,ce),i(v,hn,bn,ce),i(v,er,U,ce),i(v,"click",A,{capture:!0}),i(v,"dragstart",Ot),r([Xt,St],O)}function O(){var z=n.drag;Mt(!z),T=z==="free"}function U(z){if(R=!1,!W){var S=mt(z);it(z.target)&&(S||!z.button)&&(w.isBusy()?Ot(z,!0):(k=S?v:window,h=l.is([ve,ke]),P=null,i(k,fn,D,ce),i(k,hn,g,ce),p.cancel(),s.cancel(),I(z)))}}function D(z){if(l.is(Ue)||(l.set(Ue),a(Ro)),z.cancelable)if(h){p.translate($+ht(Q(z)));var S=ut(z)>co,H=L!==(L=f());(S||H)&&I(z),R=!0,a(Bo),Ot(z)}else V(z)&&(h=y(z),Ot(z))}function g(z){l.is(Ue)&&(l.set(me),a(Vo)),h&&(_(z),Ot(z)),c(k,fn,D),c(k,hn,g),h=!1}function A(z){!W&&R&&Ot(z,!0)}function I(z){P=M,M=z,$=b()}function _(z){var S=X(z),H=rt(S),G=n.rewind&&n.rewindByDrag;m(!1),T?w.scroll(H,0,n.snap):t.is(Ne)?w.go(C(xn(S))<0?G?"<":"-":G?">":"+"):t.is(he)&&L&&G?w.go(f(!0)?">":"<"):w.go(w.toDest(H),!0),m(!0)}function y(z){var S=n.dragMinThreshold,H=_e(S),G=H&&S.mouse||0,J=(H?S.touch:+S)||10;return xt(Q(z))>(mt(z)?J:G)}function V(z){return xt(Q(z))>xt(Q(z,!0))}function X(z){if(t.is(be)||!L){var S=ut(z);if(S&&S<co)return Q(z)/S}return 0}function rt(z){return b()+xn(z)*Gt(xt(z)*(n.flickPower||600),T?1/0:e.Layout.listSize()*(n.flickMaxPages||1))}function Q(z,S){return K(z,S)-K(E(z),S)}function ut(z){return Sn(z)-Sn(E(z))}function E(z){return M===z&&P||M}function K(z,S){return(mt(z)?z.changedTouches[0]:z)["page"+d(S?"Y":"X")]}function ht(z){return z/(L&&t.is(he)?_i:1)}function it(z){var S=n.noDrag;return!we(z,"."+Ko+", ."+un)&&(!S||!we(z,S))}function mt(z){return typeof TouchEvent<"u"&&z instanceof TouchEvent}function bt(){return h}function Mt(z){W=z}return{mount:B,disable:Mt,isDragging:bt}}var Yi={Spacebar:" ",Right:ln,Left:an,Up:Ho,Down:Do};function Un(t){return t=Yt(t)?t:t.key,Yi[t]||t}var uo="keydown";function Gi(t,e,n){var o=gt(t),r=o.on,a=o.bind,i=o.unbind,c=t.root,l=e.Direction.resolve,p,s;function w(){v(),r(St,m),r(St,v),r(jt,d)}function v(){var b=n.keyboard;b&&(p=b==="global"?window:c,a(p,uo,C))}function m(){i(p,uo)}function u(b){s=b}function d(){var b=s;s=!0,So(function(){s=b})}function C(b){if(!s){var f=Un(b);f===l(an)?t.go("<"):f===l(ln)&&t.go(">")}}return{mount:w,destroy:m,disable:u}}var $e=Rn+"-lazy",qe=$e+"-srcset",qi="["+$e+"], ["+qe+"]";function Xi(t,e,n){var o=gt(t),r=o.on,a=o.off,i=o.bind,c=o.emit,l=n.lazyLoad==="sequential",p=[ye,oe],s=[];function w(){n.lazyLoad&&(v(),r(vt,v))}function v(){zt(s),m(),l?b():(a(p),r(p,u),u())}function m(){e.Slides.forEach(function(f){Fn(f.slide,qi).forEach(function($){var M=At($,$e),P=At($,qe);if(M!==$.src||P!==$.srcset){var T=n.classes.spinner,h=$.parentElement,L=Ve(h,"."+T)||pe("span",T,h);s.push([$,f,L]),$.src||Le($,"none")}})})}function u(){s=s.filter(function(f){var $=n.perPage*((n.preloadPages||1)+1)-1;return f[1].isWithin(t.index,$)?d(f):!0}),s.length||a(p)}function d(f){var $=f[0];Rt(f[1].slide,wn),i($,"load error",at(C,f)),Z($,"src",At($,$e)),Z($,"srcset",At($,qe)),Bt($,$e),Bt($,qe)}function C(f,$){var M=f[0],P=f[1];Nt(P.slide,wn),$.type!=="error"&&(ee(f[2]),Le(M,""),c(zn,M,P),c(fe)),l&&b()}function b(){s.length&&d(s.shift())}return{mount:w,destroy:at(zt,s),check:u}}function Ki(t,e,n){var o=gt(t),r=o.on,a=o.emit,i=o.bind,c=e.Slides,l=e.Elements,p=e.Controller,s=p.hasFocus,w=p.getIndex,v=p.go,m=e.Direction.resolve,u=l.pagination,d=[],C,b;function f(){$(),r([St,vt,Ze],f);var W=n.pagination;u&&Le(u,W?"":"none"),W&&(r([jt,nn,oe],R),M(),R(),a(No,{list:C,items:d},L(t.index)))}function $(){C&&(ee(u?qt(C.children):C),Nt(C,b),zt(d),C=null),o.destroy()}function M(){var W=t.length,k=n.classes,B=n.i18n,O=n.perPage,U=s()?p.getEnd()+1:Ae(W/O);C=u||pe("ul",k.pagination,l.track.parentElement),Rt(C,b=pn+"--"+h()),Z(C,Wt,"tablist"),Z(C,wt,B.select),Z(C,Mn,h()===sn?"vertical":"");for(var D=0;D<U;D++){var g=pe("li",null,C),A=pe("button",{class:k.page,type:"button"},g),I=c.getIn(D).map(function(y){return y.slide.id}),_=!s()&&O>1?B.pageX:B.slideX;i(A,"click",at(P,D)),n.paginationKeyboard&&i(A,"keydown",at(T,D)),Z(g,Wt,"presentation"),Z(A,Wt,"tab"),Z(A,Pe,I.join(" ")),Z(A,wt,Cn(_,D+1)),Z(A,de,-1),d.push({li:g,button:A,page:D})}}function P(W){v(">"+W,!0)}function T(W,k){var B=d.length,O=Un(k),U=h(),D=-1;O===m(ln,!1,U)?D=++W%B:O===m(an,!1,U)?D=(--W+B)%B:O==="Home"?D=0:O==="End"&&(D=B-1);var g=d[D];g&&(_o(g.button),v(">"+D),Ot(k,!0))}function h(){return n.paginationDirection||n.direction}function L(W){return d[p.toPage(W)]}function R(){var W=L(w(!0)),k=L(w());if(W){var B=W.button;Nt(B,ne),Bt(B,ro),Z(B,de,-1)}if(k){var O=k.button;Rt(O,ne),Z(O,ro,!0),Z(O,de,"")}a(Wo,{list:C,items:d},W,k)}return{items:d,mount:f,destroy:$,getAt:L,update:R}}var Ji=[" ","Enter"];function Zi(t,e,n){var o=n.isNavigation,r=n.slideFocus,a=[];function i(){t.splides.forEach(function(u){u.isParent||(p(t,u.splide),p(u.splide,t))}),o&&s()}function c(){a.forEach(function(u){u.destroy()}),zt(a)}function l(){c(),i()}function p(u,d){var C=gt(u);C.on(jt,function(b,f,$){d.go(d.is(be)?$:b)}),a.push(C)}function s(){var u=gt(t),d=u.on;d(Vn,v),d(jo,m),d([Xt,St],w),a.push(u),u.emit(Pn,t.splides)}function w(){Z(e.Elements.list,Mn,n.direction===sn?"vertical":"")}function v(u){t.go(u.index)}function m(u,d){In(Ji,Un(d))&&(v(u),Ot(d))}return{setup:at(e.Media.set,{slideFocus:Fe(r)?o:r},!0),mount:i,destroy:c,remount:l}}function Qi(t,e,n){var o=gt(t),r=o.bind,a=0;function i(){n.wheel&&r(e.Elements.track,"wheel",c,ce)}function c(p){if(p.cancelable){var s=p.deltaY,w=s<0,v=Sn(p),m=n.wheelMinThreshold||0,u=n.wheelSleep||0;xt(s)>m&&v-a>u&&(t.go(w?"<":">"),a=v),l(w)&&Ot(p)}}function l(p){return!n.releaseWheel||t.state.is(ve)||e.Controller.getAdjacent(p)!==-1}return{mount:i}}var ta=90;function ea(t,e,n){var o=gt(t),r=o.on,a=e.Elements.track,i=n.live&&!n.isNavigation,c=pe("span",bi),l=on(ta,at(s,!1));function p(){i&&(v(!e.Autoplay.isPaused()),Z(a,lo,!0),c.textContent="…",r(Nn,at(v,!0)),r(Wn,at(v,!1)),r([ye,oe],at(s,!0)))}function s(m){Z(a,ao,m),m?(Be(a,c),l.start()):(ee(c),l.cancel())}function w(){Bt(a,[io,lo,ao]),ee(c)}function v(m){i&&Z(a,io,m?"off":"polite")}return{mount:p,disable:v,destroy:w}}var na=Object.freeze({__proto__:null,Media:ui,Direction:pi,Elements:wi,Slides:Ei,Layout:Li,Clones:Ii,Move:ki,Controller:Fi,Arrows:Vi,Autoplay:Pi,Cover:Ni,Scroll:Di,Drag:Ui,Keyboard:Gi,LazyLoad:Xi,Pagination:Ki,Sync:Zi,Wheel:Qi,Live:ea}),oa={prev:"Previous slide",next:"Next slide",first:"Go to first slide",last:"Go to last slide",slideX:"Go to slide %s",pageX:"Go to page %s",play:"Start autoplay",pause:"Pause autoplay",carousel:"carousel",slide:"slide",select:"Select a slide to show",slideLabel:"%s of %s"},ra={type:"slide",role:"region",speed:400,perPage:1,cloneStatus:!0,arrows:!0,pagination:!0,paginationKeyboard:!0,interval:5e3,pauseOnHover:!0,pauseOnFocus:!0,resetProgress:!0,easing:"cubic-bezier(0.25, 1, 0.5, 1)",drag:!0,direction:"ltr",trimSpace:!0,focusableNodes:"a, button, textarea, input, select, iframe",live:!0,classes:Ci,i18n:oa,reducedMotion:{speed:0,rewindSpeed:0,autoplay:"pause"}};function ia(t,e,n){var o=e.Slides;function r(){gt(t).on([Xt,vt],a)}function a(){o.forEach(function(c){c.style("transform","translateX(-"+100*c.index+"%)")})}function i(c,l){o.style("transition","opacity "+n.speed+"ms "+n.easing),So(l)}return{mount:r,start:i,cancel:bn}}function aa(t,e,n){var o=e.Move,r=e.Controller,a=e.Scroll,i=e.Elements.list,c=at(Lt,i,"transition"),l;function p(){gt(t).bind(i,"transitionend",function(m){m.target===i&&l&&(w(),l())})}function s(m,u){var d=o.toPosition(m,!0),C=o.getPosition(),b=v(m);xt(d-C)>=1&&b>=1?n.useScroll?a.scroll(d,b,!1,u):(c("transform "+b+"ms "+n.easing),o.translate(d,!0),l=u):(o.jump(m),u())}function w(){c(""),a.cancel()}function v(m){var u=n.rewindSpeed;if(t.is(he)&&u){var d=r.getIndex(!0),C=r.getEnd();if(d===0&&m>=C||d>=C&&m===0)return u}return n.speed}return{mount:p,start:s,cancel:w}}var la=(function(){function t(n,o){this.event=gt(),this.Components={},this.state=si(ue),this.splides=[],this._o={},this._E={};var r=Yt(n)?To(document,n):n;Ce(r,r+" is invalid."),this.root=r,o=Ut({label:At(r,wt)||"",labelledby:At(r,jn)||""},ra,t.defaults,o||{});try{Ut(o,JSON.parse(At(r,Rn)))}catch{Ce(!1,"Invalid JSON")}this._o=Object.create(Ut({},o))}var e=t.prototype;return e.mount=function(o,r){var a=this,i=this.state,c=this.Components;Ce(i.is([ue,Xe]),"Already mounted!"),i.set(ue),this._C=c,this._T=r||this._T||(this.is(Ne)?ia:aa),this._E=o||this._E;var l=Ee({},na,this._E,{Transition:this._T});return te(l,function(p,s){var w=p(a,c,a._o);c[s]=w,w.setup&&w.setup()}),te(c,function(p){p.mount&&p.mount()}),this.emit(Xt),Rt(this.root,Si),i.set(me),this.emit($n),this},e.sync=function(o){return this.splides.push({splide:o}),o.splides.push({splide:this,isParent:!0}),this.state.is(me)&&(this._C.Sync.remount(),o.Components.Sync.remount()),this},e.go=function(o){return this._C.Controller.go(o),this},e.on=function(o,r){return this.event.on(o,r),this},e.off=function(o){return this.event.off(o),this},e.emit=function(o){var r;return(r=this.event).emit.apply(r,[o].concat(qt(arguments,1))),this},e.add=function(o,r){return this._C.Slides.add(o,r),this},e.remove=function(o){return this._C.Slides.remove(o),this},e.is=function(o){return this._o.type===o},e.refresh=function(){return this.emit(vt),this},e.destroy=function(o){o===void 0&&(o=!0);var r=this.event,a=this.state;return a.is(ue)?gt(this).on($n,this.destroy.bind(this,o)):(te(this._C,function(i){i.destroy&&i.destroy(o)},!0),r.emit(On),r.destroy(),o&&zt(this.splides),a.set(Xe)),this},oi(t,[{key:"options",get:function(){return this._o},set:function(o){this._C.Media.set(o,!0,!0)}},{key:"length",get:function(){return this._C.Slides.getLength(!0)}},{key:"index",get:function(){return this._C.Controller.getIndex()}}]),t})(),Yn=la;Yn.defaults={};Yn.STATES=ii;var po=[[Xt,"onMounted"],[$n,"onReady"],[jt,"onMove"],[ye,"onMoved"],[Vn,"onClick"],[Ao,"onActive"],[Io,"onInactive"],[ko,"onVisible"],[Fo,"onHidden"],[vt,"onRefresh"],[St,"onUpdated"],[fe,"onResize"],[en,"onResized"],[Ro,"onDrag"],[Bo,"onDragging"],[Vo,"onDragged"],[nn,"onScroll"],[oe,"onScrolled"],[On,"onDestroy"],[Oo,"onArrowsMounted"],[Po,"onArrowsUpdated"],[No,"onPaginationMounted"],[Wo,"onPaginationUpdated"],[Pn,"onNavigationMounted"],[Nn,"onAutoplayPlay"],[zo,"onAutoplayPlaying"],[Wn,"onAutoplayPause"],[zn,"onLazyLoadLoaded"]];function Gn(...t){return t.filter(Boolean).join(" ")}function Qe(t){return t!==null&&typeof t=="object"}function Tn(t,e){if(Array.isArray(t)&&Array.isArray(e))return t.length===e.length&&!t.some((n,o)=>!Tn(n,e[o]));if(Qe(t)&&Qe(e)){const n=Object.keys(t),o=Object.keys(e);return n.length===o.length&&!n.some(r=>!Object.prototype.hasOwnProperty.call(e,r)||!Tn(t[r],e[r]))}return t===e}function sa(t,e){return t.length===e.length&&!t.some((n,o)=>n!==e[o])}function ca(t,e){if(t){const n=Object.keys(t);for(let o=0;o<n.length;o++){const r=n[o];if(r!=="__proto__"&&e(t[r],r)===!1)break}}return t}function En(t,e){const n=t;return ca(e,(o,r)=>{Array.isArray(o)?n[r]=o.slice():Qe(o)?n[r]=En(Qe(n[r])?n[r]:{},o):n[r]=o}),n}var ua=({children:t,className:e,...n})=>j.createElement("div",{className:Gn("splide__track",e),...n},j.createElement("ul",{className:"splide__list"},t)),nr=class extends j.Component{constructor(){super(...arguments),this.splideRef=j.createRef(),this.slides=[]}componentDidMount(){const{options:t,extensions:e,transition:n}=this.props,{current:o}=this.splideRef;o&&(this.splide=new Yn(o,t),this.bind(this.splide),this.splide.mount(e,n),this.options=En({},t||{}),this.slides=this.getSlides())}componentWillUnmount(){this.splide&&(this.splide.destroy(),this.splide=void 0),this.options=void 0,this.slides.length=0}componentDidUpdate(){if(!this.splide)return;const{options:t}=this.props;t&&!Tn(this.options,t)&&(this.splide.options=t,this.options=En({},t));const e=this.getSlides();sa(this.slides,e)||(this.splide.refresh(),this.slides=e)}sync(t){var e;(e=this.splide)==null||e.sync(t)}go(t){var e;(e=this.splide)==null||e.go(t)}getSlides(){var t;if(this.splide){const e=(t=this.splide.Components.Elements)==null?void 0:t.list.children;return e&&Array.prototype.slice.call(e)||[]}return[]}bind(t){po.forEach(([e,n])=>{const o=this.props[n];typeof o=="function"&&t.on(e,(...r)=>{o(t,...r)})})}omit(t,e){return e.forEach(n=>{Object.prototype.hasOwnProperty.call(t,n)&&delete t[n]}),t}render(){const{className:t,tag:e="div",hasTrack:n=!0,children:o,...r}=this.props;return j.createElement(e,{className:Gn("splide",t),ref:this.splideRef,...this.omit(r,["options",...po.map(a=>a[1])])},n?j.createElement(ua,null,o):o)}},or=({children:t,className:e,...n})=>j.createElement("li",{className:Gn("splide__slide",e),...n},t);/*!
|
|
2
2
|
* Splide.js
|
|
3
3
|
* Version : 4.1.3
|
|
4
4
|
* License : MIT
|
|
5
5
|
* Copyright: 2022 Naotoshi Fujita
|
|
6
|
-
*/const oa="RichTextRenderer-module__link___BWeZ2",ra={link:oa},Zo=({content:e})=>{const t=n=>n.map((o,r)=>o.type==="link"?S.jsx("a",{className:ra.link,href:o.value,target:o.target,children:t(o.children)},r):S.jsx("span",{style:ia(o),children:o.text},r));return S.jsx(S.Fragment,{children:e.map((n,o)=>{const r=n.children;return S.jsx("div",{children:t(r)},o)})})};function ia(e){return{...e.fontFamily&&{fontFamily:e.fontFamily},...e.fontWeight&&{fontWeight:e.fontWeight},...e.fontStyle&&{fontStyle:e.fontStyle},...e.textDecoration&&{textDecoration:e.textDecoration},...e.textTransform&&{textTransform:e.textTransform},...e.fontVariant&&{fontVariant:e.fontVariant},...e.verticalAlign&&{verticalAlign:e.verticalAlign,lineHeight:"0px"}}}const aa="SvgImage-module__svg___q3xE-",la="SvgImage-module__img___VsTm-",no={svg:aa,img:la},vt=({url:e,fill:t="#000000",hoverFill:n="#CCCCCC",className:o=""})=>{const[r,a]=D.useState(!0);return D.useEffect(()=>{if(typeof window<"u"&&window.CSS){const i=CSS.supports("mask-image",'url("")')||CSS.supports("-webkit-mask-image",'url("")');a(i)}},[]),!e.endsWith(".svg")||!r?S.jsx("img",{src:e,alt:"",className:ue(no.img,o)}):S.jsx("span",{"data-supports-mask":r,className:ue(no.svg,o),style:{"--svg":`url(${e})`,"--fill":t,"--hover-fill":n}})},sa={"top-left":Y.topLeftAlignment,"top-center":Y.topCenterAlignment,"top-right":Y.topRightAlignment,"middle-left":Y.middleLeftAlignment,"middle-center":Y.middleCenterAlignment,"middle-right":Y.middleRightAlignment,"bottom-left":Y.bottomLeftAlignment,"bottom-center":Y.bottomCenterAlignment,"bottom-right":Y.bottomRightAlignment};function ca({settings:e,content:t,styles:n,isEditor:o}){const[r,a]=D.useState(null),{widthSettings:i,fontSettings:s,letterSpacing:l,textAlign:d,wordSpacing:p,fontSizeLineHeight:_,textAppearance:m,color:h}=n.imageCaption,[c,u]=D.useState(void 0),[b,$]=D.useState(null),[f,w]=D.useState(0),[B,z]=D.useState(0),{direction:E,transition:v,controls:T,pagination:V,imageCaption:W,triggers:L}=e,F=D.useRef(v.type),{x:O,y:U}=e.controls.offset,H=g=>{r&&r.go(g)};return D.useEffect(()=>{if(!b)return;const g=new ResizeObserver(R=>{if(!r)return;const[x]=R;u({width:Math.round(x.contentRect.width),height:Math.round(x.contentRect.height)})});return g.observe(b),()=>g.unobserve(b)},[b]),D.useEffect(()=>{!r||F.current===v.type||(z(g=>g+1),F.current=v.type)},[v.type]),S.jsx("div",{className:ue(Y.wrapper,{[Y.editor]:o}),ref:$,children:S.jsxs("div",{className:Y.sliderInner,style:{width:c?c.width:"100%",height:c?c.height:"100%",backgroundColor:v.backgroundColor&&v.type==="fade in"?v.backgroundColor:"transparent"},children:[e.imageCaption.isActive&&S.jsx("div",{className:ue(Y.captionBlock),children:S.jsx("div",{className:Y.captionTextWrapper,children:t.map((g,R)=>S.jsx("div",{className:ue(Y.captionText,sa[W.alignment],{[Y.withPointerEvents]:R===f&&o,[Y.active]:R===f}),style:{fontFamily:s.fontFamily,fontWeight:s.fontWeight,fontStyle:s.fontStyle,width:i.sizing==="auto"?"max-content":k.scalingValue(i.width,o),letterSpacing:k.scalingValue(l,o),wordSpacing:k.scalingValue(p,o),textAlign:d,fontSize:k.scalingValue(_.fontSize,o),lineHeight:k.scalingValue(_.lineHeight,o),textTransform:m.textTransform??"none",textDecoration:m.textDecoration??"none",fontVariant:m.fontVariant??"normal",color:h,transitionDuration:v.duration?`${Math.round(parseInt(v.duration)/2)}ms`:"500ms"},children:S.jsx("div",{"data-styles":"imageCaption",className:Y.captionTextInner,style:{"--link-hover-color":W.linkHoverColor,"--link-color":W.linkColor,position:"relative",top:k.scalingValue(W.offset.y,o),left:k.scalingValue(W.offset.x,o)},children:S.jsx(Zo,{content:g.imageCaption})})},R))})}),S.jsx(Ko,{onMove:g=>{w(g.index)},ref:a,options:{arrows:!1,speed:v.duration?parseInt(v.duration):500,autoplay:L.autoPlay!==null,...L.autoPlay!==null&&{interval:parseInt(L.autoPlay)*1e3},direction:E==="horiz"||v.type==="fade in"?"ltr":"ttb",pagination:!1,drag:L.triggersList.drag,perPage:1,width:c?c.width:"100%",height:c?c.height:"100%",type:v.type==="fade in"?"fade":"loop",rewind:!0},children:t.map((g,R)=>S.jsx(Jo,{children:S.jsx("div",{className:Y.sliderItem,children:S.jsx("div",{className:Y.imgWrapper,children:S.jsx("img",{className:ue(Y.sliderImage,{[Y.contain]:g.image.objectFit==="contain",[Y.cover]:g.image.objectFit==="cover"}),src:g.image.url,alt:g.image.name??""})})})},R))},B),T.isActive&&S.jsxs(S.Fragment,{children:[S.jsx("div",{className:ue(Y.arrow,{[Y.arrowVertical]:E==="vert",[Y.hoverArrow]:T.show==="on hover"}),style:{color:T.color,"--arrow-hover-color":T.hover},children:S.jsxs("button",{onClick:()=>{H("-1")},className:Y.arrowInner,style:{transform:`translate(${k.scalingValue(O,o)}, ${k.scalingValue(U*(E==="horiz"?1:-1),o)}) scale(${e.controls.scale/100}) rotate(${E==="horiz"?"0deg":"90deg"})`},children:[T.arrowsImgUrl&&S.jsx(vt,{url:T.arrowsImgUrl,fill:T.color,hoverFill:T.hover,className:ue(Y.arrowImg,Y.mirror)}),!T.arrowsImgUrl&&S.jsx(oo,{color:T.color,className:ue(Y.arrowIcon,Y.arrowImg,Y.mirror)})]})}),S.jsx("div",{className:ue(Y.arrow,Y.nextArrow,{[Y.arrowVertical]:E==="vert",[Y.hoverArrow]:T.show==="on hover"}),style:{color:T.color,"--arrow-hover-color":T.hover},children:S.jsxs("button",{className:Y.arrowInner,onClick:()=>H("+1"),style:{transform:`translate(${k.scalingValue(O*(E==="horiz"?-1:1),o)}, ${k.scalingValue(U,o)}) scale(${e.controls.scale/100}) rotate(${E==="horiz"?"0deg":"90deg"})`},children:[T.arrowsImgUrl&&S.jsx(vt,{url:T.arrowsImgUrl,fill:T.color,hoverFill:T.hover,className:Y.arrowImg}),!T.arrowsImgUrl&&S.jsx(oo,{color:T.color,className:ue(Y.arrowIcon,Y.arrowImg)})]})})]}),L.triggersList.click&&S.jsx("div",{className:Y.clickOverlay,onClick:()=>{r&&r.go("+1")}}),V.isActive&&S.jsx("div",{className:ue(Y.pagination,{[Y.paginationInsideBottom]:V.position==="inside-1"&&E==="horiz",[Y.paginationInsideTop]:V.position==="inside-2"&&E==="horiz",[Y.paginationOutsideBottom]:V.position==="outside-1"&&E==="horiz",[Y.paginationOutsideTop]:V.position==="outside-2"&&E==="horiz",[Y.paginationInsideLeft]:V.position==="inside-1"&&E==="vert",[Y.paginationInsideRight]:V.position==="inside-2"&&E==="vert",[Y.paginationOutsideLeft]:V.position==="outside-1"&&E==="vert",[Y.paginationOutsideRight]:V.position==="outside-2"&&E==="vert",[Y.paginationVertical]:E==="vert"}),children:S.jsx("div",{className:Y.paginationInner,style:{backgroundColor:V.colors[2],transform:`scale(${V.scale/100}) translate(${k.scalingValue(V.offset.x,o)}, ${k.scalingValue(V.offset.y,o)}) rotate(${E==="horiz"?"0deg":"90deg"})`},children:t.map((g,R)=>S.jsx("button",{onClick:()=>{r&&r.go(R)},className:ue(Y.paginationItem),children:S.jsx("div",{className:ue(Y.dot,{[Y.activeDot]:R===f}),style:{backgroundColor:R===f?V.colors[0]:V.colors[1],"--pagination-hover-color":V.hover}})},R))})})]})})}function oo({color:e,className:t}){return S.jsx("svg",{viewBox:"0 0 10 18",className:t,children:S.jsx("g",{id:"Symbols",stroke:"none",strokeWidth:"1",fillRule:"evenodd",children:S.jsx("path",{d:"M-3.70710678,4.29289322 C-3.34662282,3.93240926 -2.77939176,3.90467972 -2.38710056,4.20970461 L-2.29289322,4.29289322 L5,11.585 L12.2928932,4.29289322 C12.6533772,3.93240926 13.2206082,3.90467972 13.6128994,4.20970461 L13.7071068,4.29289322 C14.0675907,4.65337718 14.0953203,5.22060824 13.7902954,5.61289944 L13.7071068,5.70710678 L5.70710678,13.7071068 C5.34662282,14.0675907 4.77939176,14.0953203 4.38710056,13.7902954 L4.29289322,13.7071068 L-3.70710678,5.70710678 C-4.09763107,5.31658249 -4.09763107,4.68341751 -3.70710678,4.29289322 Z",id:"Shape-Copy",fill:e,transform:"translate(5, 9) rotate(-90) translate(-5, -9)"})})})}const ua={element:ca,id:"control-slider",name:"Slider",preview:{type:"image",url:"https://cdn.cntrl.site/component-assets/sliderImg.png"},defaultSize:{width:400,height:400},schema:{type:"object",properties:{settings:{type:"object",display:{type:"settings-block"},properties:{triggers:{title:"triggers",icon:"target",tooltip:"Triggers",type:"object",properties:{triggersList:{type:"object",display:{type:"toggle-ratio-group"},properties:{click:{type:"boolean"},drag:{type:"boolean"}}},autoPlay:{type:["string","null"],label:"Auto",display:{type:"step-selector"},enum:[null,"1s","2s","3s","4s","5s"]}}},direction:{icon:"horizontal-resize",tooltip:"Direction",type:"string",display:{type:"ratio-group"},enum:["horiz","vert"]},transition:{title:"transit",icon:"transition",tooltip:"Transition",type:"object",properties:{type:{type:"string",display:{type:"ratio-group"},enum:["slide","fade in"]},backgroundColor:{type:["string","null"],title:"BG Color",display:{visible:!1,type:"settings-color-picker",format:"single"}},duration:{type:"string",label:"icon:hourglass",display:{type:"step-selector"},enum:["100ms","250ms","500ms","1000ms","1500ms","2000ms"]}}},controls:{title:"controls",icon:"controls",tooltip:"Controls",type:"object",properties:{isActive:{type:"boolean",display:{type:"setting-toggle"}},arrowsImgUrl:{type:["string","null"],display:{type:"settings-image-input"}},offset:{type:"object",title:"Offset",display:{type:"group"},properties:{x:{type:"number",label:"X",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}},y:{type:"number",label:"Y",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}}}},scale:{type:"number",title:"scale",min:50,max:600,display:{type:"range-control"}},color:{title:"color",type:"string",display:{type:"settings-color-picker",format:"single"}},hover:{title:"hover",type:"string",display:{type:"settings-color-picker",format:"single"}},show:{title:"Show",type:"string",display:{type:"ratio-group"},enum:["always","on hover"]}}},pagination:{title:"nav",icon:"pagination",tooltip:"Navigation",type:"object",properties:{isActive:{type:"boolean",display:{type:"setting-toggle"}},position:{display:{type:"socket",direction:"horizontal"},type:"string",enum:["outside-1","outside-2","inside-1","inside-2"]},offset:{type:"object",title:"Offset",display:{type:"group"},properties:{x:{type:"number",label:"X",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}},y:{type:"number",label:"Y",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}}}},scale:{type:"number",title:"scale",min:10,max:400,display:{type:"range-control"}},colors:{display:{type:"settings-color-picker",format:"multiple"},title:"color",type:"array",items:{type:"string"}},hover:{title:"hover",type:"string",display:{type:"settings-color-picker",format:"single"}}}},imageCaption:{title:"Caption",icon:"text-icon",tooltip:"Caption",type:"object",properties:{isActive:{type:"boolean",display:{type:"setting-toggle"}},alignment:{type:"string",display:{type:"align-grid"},enum:["top-left","top-center","top-right","middle-left","middle-center","middle-right","bottom-left","bottom-center","bottom-right"]},offset:{type:"object",title:"Offset",display:{type:"group"},properties:{x:{type:"number",label:"X",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}},y:{type:"number",label:"Y",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}}}},linkColor:{title:"Link",type:"string",display:{type:"settings-color-picker",format:"single"}},linkHoverColor:{title:"Link Hov",type:"string",display:{type:"settings-color-picker",format:"single"}}}}},default:{triggers:{triggersList:{click:!1,drag:!0},autoPlay:null},controls:{isActive:!0,arrowsImgUrl:null,offset:{x:0,y:0},scale:100,color:"#000000",hover:"#cccccc",show:"always"},transition:{type:"slide",duration:"500ms",backgroundColor:null},pagination:{isActive:!0,scale:50,position:"outside-1",offset:{x:0,y:0},colors:["#cccccc","#cccccc","#000000"],hover:"#cccccc"},direction:"horiz",imageCaption:{offset:{x:0,y:0},isActive:!0,alignment:"middle-center",linkColor:"#cccccc",linkHoverColor:"#cccccc"}},displayRules:[{if:{name:"direction",value:"vert"},then:{name:"properties.pagination.properties.position.display.direction",value:"vertical"}},{if:{name:"transition.type",value:"fade in"},then:{name:"properties.transition.properties.backgroundColor.display.visible",value:!0}}]},content:{type:"array",settings:{addItemFromFileExplorer:!0,defaultWidth:500},items:{type:"object",properties:{image:{type:"object",label:"Image",display:{minWidth:58,maxWidth:108,type:"media-input"},properties:{url:{type:"string"},name:{type:"string"},objectFit:{type:"string",enum:["cover","contain"]}},required:["url","name"]},imageCaption:{placeholder:"Add Caption...",label:"Description",display:{type:"rich-text",minWidth:300,maxWidth:550}}},required:["image"]},default:[{image:{objectFit:"cover",url:"https://cdn.cntrl.site/component-assets/Control-slider-default-picture-1.png",name:"Slider-1.png"},imageCaption:[{type:"paragraph",children:[{text:""}]}]},{image:{objectFit:"cover",url:"https://cdn.cntrl.site/component-assets/Control-slider-default-picture-2.png",name:"Slider-2.png"},imageCaption:[{type:"paragraph",children:[{text:""}]}]},{image:{objectFit:"cover",url:"https://cdn.cntrl.site/component-assets/Control-slider-default-picture-3.png",name:"Slider-3.png"},imageCaption:[{type:"paragraph",children:[{text:""}]}]}]},styles:{type:"object",properties:{imageCaption:{dataName:"caption",type:"object",properties:{fontSettings:{type:"object",display:{type:"font-settings"},properties:{fontFamily:{type:"string"},fontWeight:{type:"number"},fontStyle:{type:"string"}}},widthSettings:{display:{type:"text-width-control"},type:"object",properties:{width:{type:"number"},sizing:{type:"string",enum:["auto","manual"]}}},fontSizeLineHeight:{type:"object",display:{type:"font-size-line-height"},properties:{fontSize:{type:"number"},lineHeight:{type:"number"}}},letterSpacing:{display:{type:"letter-spacing-input"},type:"number"},wordSpacing:{display:{type:"word-spacing-input"},type:"number"},textAlign:{display:{type:"text-align-control"},type:"string",enum:["left","center","right","justify"]},textAppearance:{display:{type:"text-appearance"},properties:{textTransform:{type:"string",enum:["none","uppercase","lowercase","capitalize"]},textDecoration:{type:"string",enum:["none","underline"]},fontVariant:{type:"string",enum:["normal","small-caps"]}}},color:{display:{type:"style-panel-color-picker"},type:"string"}}}},default:{imageCaption:{widthSettings:{width:.13,sizing:"auto"},fontSettings:{fontFamily:"Arial",fontWeight:400,fontStyle:"normal"},fontSizeLineHeight:{fontSize:.02,lineHeight:.02},letterSpacing:0,wordSpacing:0,textAlign:"left",textAppearance:{textTransform:"none",textDecoration:"none",fontVariant:"normal"},color:"#000000"}}}},required:["settings","content","styles"]}},pa="ImageRevealSlider-module__imageRevealSlider___UE5Ob",da="ImageRevealSlider-module__image___Qjt-e",ga="ImageRevealSlider-module__link___N-iLG",fa="ImageRevealSlider-module__cursor___2U03d",ot={imageRevealSlider:pa,image:da,link:ga,cursor:fa};function ro(e,t,n){for(const o of n){const r=new Image;r.src=o.url;const a=o.width?Number.parseFloat(o.width):r.naturalWidth,i=r.naturalHeight/r.naturalWidth*a,s=a/2,l=i/2;if(e>=o.x-s&&e<=o.x+s&&t>=o.y-l&&t<=o.y+l)return!0}return!1}function sn(e){return new Promise(t=>{const n=new Image;n.src=e,n.onload=()=>{t({width:n.naturalWidth,height:n.naturalHeight})}})}async function ma(e,t,n,o){let r,a;if(t==="custom"){r=n;const i=await sn(e);a=i.height/i.width*r}else if(t==="random"){r=Math.random()*(o.max-o.min)+o.min;const i=await sn(e);a=i.height/i.width*r}else{const i=await sn(e);r=i.width,a=i.height}return{width:r,height:a,finalWidth:`${r}px`}}function ya({settings:e,content:t,isEditor:n}){const[o,r]=D.useState(null),[a,i]=D.useState([]),[s,l]=D.useState(0),d=D.useRef(0),[p,_]=D.useState({x:0,y:0}),[m,h]=D.useState(1),[c,u]=D.useState("none"),b=D.useRef({x:0,y:0}),[$,f]=D.useState(!1),{sizeType:w,imageWidth:B,randomRangeImageWidth:z}=e.imageSize,{revealPosition:E,visible:v}=e.position,{cursorType:T,target:V,defaultCursorScale:W,defaultCursor:L,hoverCursorScale:F,hoverCursor:O}=e.cursor;D.useEffect(()=>{if(!o)return;const g=(A,C)=>{const N=o.getBoundingClientRect(),q=A-N.left,ie=C-N.top;if(_({x:q,y:ie}),T==="system"){u("none"),h(1);return}const Q=q,me=ie,I=document.elementFromPoint(N.left+Q,N.top+me);if(I&&I.closest("a")){u("none"),h(1);return}const K=ro(Q,me,a)||V==="area"?{img:O??"none",scale:F}:{img:L??"none",scale:W};u(K.img),h(K.scale)},R=A=>{A.stopPropagation(),b.current={x:A.clientX,y:A.clientY},g(A.clientX,A.clientY)},x=()=>{$&&g(b.current.x,b.current.y)};return o.addEventListener("mousemove",R),window.addEventListener("scroll",x,!0),()=>{o.removeEventListener("mousemove",R),window.removeEventListener("scroll",x,!0)}},[o,$,p,T,V,O,L,F,W,a]),D.useEffect(()=>{$||(u("none"),h(0))},[$]);const U=async(g,R,x,A={})=>{const{width:C,height:N,finalWidth:q}=await ma(g.image.url,w,B,z);let ie=0,Q=0;E==="same"?(ie=R/2,Q=x/2):(ie=A.x??Math.random()*R,Q=A.y??Math.random()*x);const me=Math.min(Math.max(ie,C/2),R-C/2),I=Math.min(Math.max(Q,N/2),x-N/2);return{id:d.current++,url:g.image.url,link:g.link,name:g.image.name,x:me,y:I,width:q}};D.useEffect(()=>{if(!o||t.length===0)return;const g=o.getBoundingClientRect(),R=g.width,x=g.height,A=[];(async()=>{const N=t[0],q=await U(N,R,x);A.push(q),i(A),l(1)})()},[w,B,z,E,o]),D.useEffect(()=>{v==="last One"&&i(g=>g.length>0?[g[g.length-1]]:[])},[v]);const H=async g=>{if(!o)return;const R=o.getBoundingClientRect(),x=g.clientX-R.left,A=g.clientY-R.top;if(V==="image"&&!ro(x,A,a))return;let C=0,N=0;E==="on Click"?(C=x,N=A):E==="same"?(C=R.width/2,N=R.height/2):(C=Math.random()*R.width,N=Math.random()*R.height);const q=t[s],ie=await U(q,R.width,R.height,{x:C,y:N});i(Q=>v==="all"?[...Q,ie]:[ie]),l(Q=>Q>=t.length-1?0:Q+1)};return S.jsxs("div",{ref:r,onClick:H,onMouseEnter:()=>f(!0),onMouseLeave:()=>f(!1),className:ot.imageRevealSlider,style:{cursor:c==="none"?"default":"none"},children:[a.map(g=>S.jsx("div",{className:ot.wrapper,style:{top:`${g.y}px`,left:`${g.x}px`,position:"absolute",transform:"translate(-50%, -50%)",width:g.width??"auto",height:"auto",cursor:c==="none"?"default":"none"},children:V==="area"&&g.link?S.jsx("a",{href:g.link,target:"_blank",className:ot.link,children:S.jsx("img",{src:g.url,alt:g.name,className:ot.image},g.id)}):S.jsx("img",{src:g.url,alt:g.name,className:ot.image},g.id)},g.id)),$&&S.jsx("div",{className:ot.cursor,style:{left:`${p.x}px`,top:`${p.y}px`,transform:`translate(-50%, -50%) scale(${m})`,backgroundImage:`url('${c}')`,backgroundSize:"cover",backgroundPosition:"center",position:"absolute",pointerEvents:"none"}})]})}const ha={element:ya,id:"control-image-reveal",name:"Click Gallery",preview:{type:"image",url:"https://cdn.cntrl.site/component-assets/clickGalleryImg.png"},defaultSize:{width:"100%",height:"100%"},schema:{type:"object",properties:{settings:{type:"object",display:{type:"settings-block"},properties:{imageSize:{title:"IMG SIZE",icon:"size",tooltip:"IMG SIZE",type:"object",properties:{sizeType:{type:"string",display:{type:"ratio-group"},enum:["as Is","custom","random"]},imageWidth:{type:"number",label:"W",display:{type:"numeric-input",visible:!1}},randomRangeImageWidth:{type:"object",display:{type:"random-range-controls",visible:!1},properties:{min:{type:"number"},max:{type:"number"}}}}},cursor:{title:"cursor",icon:"cursor",tooltip:"cursor",type:"object",properties:{cursorType:{type:"string",display:{type:"ratio-group"},enum:["system","custom"]},target:{type:"string",title:"Target",display:{type:"ratio-group"},enum:["area","image"]},defaultCursor:{type:["string","null"],title:"Default",display:{type:"settings-image-input",visible:!1}},defaultCursorScale:{type:"number",title:"Scale",min:1,max:5,step:.1,display:{type:"range-control",visible:!1}},hoverCursor:{type:["string","null"],title:"Hover",display:{type:"settings-image-input",visible:!1}},hoverCursorScale:{type:"number",title:"Scale",min:1,max:5,step:.1,display:{type:"range-control",visible:!1}}}},position:{title:"position",icon:"transition",tooltip:"Position",type:"object",properties:{revealPosition:{type:"string",display:{type:"ratio-group"},enum:["random","same","on Click"]},visible:{type:"string",title:"Visible",display:{type:"ratio-group"},enum:["all","last One"]}}}},default:{imageSize:{sizeType:"custom",imageWidth:500,randomRangeImageWidth:{min:100,max:1e3}},cursor:{cursorType:"system",target:"area",defaultCursor:null,defaultCursorScale:2,hoverCursor:null,hoverCursorScale:2},position:{revealPosition:"random",visible:"all"}},displayRules:[{if:{name:"imageSize.sizeType",value:"custom"},then:{name:"properties.imageSize.properties.imageWidth.display.visible",value:!0}},{if:{name:"imageSize.sizeType",value:"random"},then:{name:"properties.imageSize.properties.randomRangeImageWidth.display.visible",value:!0}},{if:[{name:"cursor.target",value:"image"},{name:"cursor.cursorType",value:"custom"}],then:{name:"properties.cursor.properties.defaultCursor.display.visible",value:!0}},{if:[{name:"cursor.target",value:"image"},{name:"cursor.cursorType",value:"custom"},{name:"cursor.defaultCursor",value:null,isNotEqual:!0}],then:{name:"properties.cursor.properties.defaultCursorScale.display.visible",value:!0}},{if:{name:"cursor.cursorType",value:"custom"},then:{name:"properties.cursor.properties.hoverCursor.display.visible",value:!0}},{if:[{name:"cursor.cursorType",value:"custom"},{name:"cursor.hoverCursor",value:null,isNotEqual:!0}],then:{name:"properties.cursor.properties.hoverCursorScale.display.visible",value:!0}}]},content:{type:"array",settings:{addItemFromFileExplorer:!0,defaultWidth:500},items:{type:"object",properties:{image:{type:"object",label:"Image",display:{isObjectFitEditable:!1,minWidth:58,maxWidth:108,type:"media-input"},properties:{url:{type:"string"},name:{type:"string"},objectFit:{type:"string",enum:["cover","contain"]}},required:["url","name"]},link:{label:"URL",placeholder:"Enter link...",display:{type:"text-input",minWidth:300,maxWidth:550}}},required:["image"]},default:[{image:{objectFit:"cover",url:"https://cdn.cntrl.site/projects/01JJKT02AWY2FGN2QJ7A173RNZ/articles-assets/01K7ERQK9211QXBE9W284ZNKB8.png",name:"Slider-1.png"},link:""},{image:{objectFit:"cover",url:"https://cdn.cntrl.site/projects/01JJKT02AWY2FGN2QJ7A173RNZ/articles-assets/01K7ERQMFT72JD18WKP0Q2DVAT.png",name:"Slider-2.png"},link:""},{image:{objectFit:"cover",url:"https://cdn.cntrl.site/projects/01JJKT02AWY2FGN2QJ7A173RNZ/articles-assets/01K7ERQNEVRXPSRX5K1YTMJQY9.png",name:"Slider-3.png"},link:""},{image:{objectFit:"cover",url:"https://cdn.cntrl.site/projects/01JJKT02AWY2FGN2QJ7A173RNZ/articles-assets/01K7ERQP84JKRDT7WNWDQZR4Y9.png",name:"Slider-4.png"},link:""}]}}}},va="LightBox-module__hidden___9s-9x",ba="LightBox-module__heroImage___sTxNF",Sa="LightBox-module__background___rm9ml",xa="LightBox-module__editor___4ACaY",Ca="LightBox-module__contentStyle___Bgnsq",_a="LightBox-module__imageStyle___tLIlB",wa="LightBox-module__imgWrapper___LuFUp",$a="LightBox-module__contain___8-yaS",Ta="LightBox-module__cover___hNvOG",Aa="LightBox-module__caption___b6L2I",Ea="LightBox-module__captionTextInner___rCGNH",La="LightBox-module__lightboxSplide___XFuWC",Ia="LightBox-module__arrow___iz38X",ka="LightBox-module__arrowVertical___Zfz81",Ra="LightBox-module__nextArrow___zkAQN",Fa="LightBox-module__arrowInner___p48sW",Va="LightBox-module__arrowIcon___3VaFf",Na="LightBox-module__arrowImg___pNV88",Oa="LightBox-module__mirror___pjeXc",ja="LightBox-module__thumbsWrapper___GB-nU",Ba="LightBox-module__thumbsContainerVertical___wttk5",za="LightBox-module__thumbsContainer___osSma",Wa="LightBox-module__thumbsAlignStart___MO6tY",Ma="LightBox-module__thumbsAlignCenter___Q4sUx",Da="LightBox-module__thumbsAlignEnd___p4y9R",Ha="LightBox-module__thumbItem___HvnF3",Pa="LightBox-module__closeButton___g2khP",Ua="LightBox-module__fadeIn___0m5GW",Ga="LightBox-module__slideInLeft___gPYwC",Ya="LightBox-module__slideInRight___S-pPp",qa="LightBox-module__slideInTop___DFdAj",Xa="LightBox-module__slideInBottom___m27kZ",Ka="LightBox-module__fadeOut___55qBR",Ja="LightBox-module__slideOutLeft___NvU7P",Za="LightBox-module__slideOutRight___SK7eC",Qa="LightBox-module__slideOutTop___Vgg0z",el="LightBox-module__slideOutBottom___nJ0Ef",tl="LightBox-module__scaleSlide___vZriG",j={hidden:va,heroImage:ba,background:Sa,editor:xa,contentStyle:Ca,imageStyle:_a,imgWrapper:wa,contain:$a,cover:Ta,caption:Aa,captionTextInner:Ea,lightboxSplide:La,arrow:Ia,arrowVertical:ka,nextArrow:Ra,arrowInner:Fa,arrowIcon:Va,arrowImg:Na,mirror:Oa,thumbsWrapper:ja,thumbsContainerVertical:Ba,thumbsContainer:za,thumbsAlignStart:Wa,thumbsAlignCenter:Ma,thumbsAlignEnd:Da,thumbItem:Ha,closeButton:Pa,fadeIn:Ua,slideInLeft:Ga,slideInRight:Ya,slideInTop:qa,slideInBottom:Xa,fadeOut:Ka,slideOutLeft:Ja,slideOutRight:Za,slideOutTop:Qa,slideOutBottom:el,scaleSlide:tl},Nt=(e,t,n)=>{const o={},[r,a]=e.split("-");return r==="top"?(o.top="0",o.bottom="auto"):r==="middle"?(o.top="50%",o.bottom="auto"):r==="bottom"&&(o.top="auto",o.bottom="0"),a==="left"?(o.left="0",o.right="auto"):a==="center"?(o.left="50%",o.right="auto"):a==="right"&&(o.left="auto",o.right="0"),r==="middle"&&a==="center"?o.transform=`translate(calc(-50% + ${k.scalingValue(t.x,n)}), calc(-50% + ${k.scalingValue(t.y,n)}))`:r==="middle"?o.transform=`translate(${k.scalingValue(t.x,n)}, calc(-50% + ${k.scalingValue(t.y,n)}))`:a==="center"?o.transform=`translate(calc(-50% + ${k.scalingValue(t.x,n)}), ${k.scalingValue(t.y,n)})`:o.transform=`translate(${k.scalingValue(t.x,n)}, ${k.scalingValue(t.y,n)})`,o};function Qo(e){const t=window.getComputedStyle(e);return{top:parseFloat(t.paddingTop)||0,right:parseFloat(t.paddingRight)||0,bottom:parseFloat(t.paddingBottom)||0,left:parseFloat(t.paddingLeft)||0}}function io(e){const t=e.getBoundingClientRect(),n=Qo(e),o=Math.max(0,t.width-n.left-n.right),r=Math.max(0,t.height-n.top-n.bottom),a=e.naturalWidth,i=e.naturalHeight,s=o/r,l=a/i;let d,p;l>s?(d=o,p=o/l):(p=r,d=r*l);const _=t.left+n.left,m=t.top+n.top,h=(o-d)/2+_,c=(r-p)/2+m;return{x:h,y:c,width:d,height:p}}function ao(e){const t=e.getBoundingClientRect(),n=Qo(e);return{left:t.left+n.left,right:t.right-n.right,top:t.top+n.top,bottom:t.bottom-n.bottom}}function lo(e){const t=e.match(/rgba?\(([^)]+)\)/);if(t){const o=t[1].split(",").map(r=>parseFloat(r.trim()));return o.length===4?o[3]:1}const n=e.match(/^#([0-9a-fA-F]{8})$/);if(n){const o=n[1].substring(6,8);return parseInt(o,16)/255}return e.match(/^#([0-9a-fA-F]{3}|[0-9a-fA-F]{6})$/),1}function nl(e,t){const n=(()=>{if(e==="fade in")return j.fadeIn;if(e==="slide in"||e==="mix")switch(t){case"left":return j.slideInLeft;case"right":return j.slideInRight;case"top":return j.slideInTop;case"bottom":return j.slideInBottom;default:return j.slideInRight}return j.fadeIn})(),o=(()=>{if(e==="fade in"||e==="mix")return j.fadeIn;if(e==="slide in")switch(t){case"left":return j.slideInLeft;case"right":return j.slideInRight;case"top":return j.slideInTop;case"bottom":return j.slideInBottom;default:return j.slideInRight}return j.fadeIn})(),r=(()=>{if(e==="fade in"||e==="mix")return j.fadeOut;if(e==="slide in")switch(t){case"left":return j.slideOutLeft;case"right":return j.slideOutRight;case"top":return j.slideOutTop;case"bottom":return j.slideOutBottom;default:return j.slideOutRight}return j.fadeOut})(),a=(()=>{if(e==="fade in")return j.fadeOut;if(e==="slide in"||e==="mix")switch(t){case"left":return j.slideOutLeft;case"right":return j.slideOutRight;case"top":return j.slideOutTop;case"bottom":return j.slideOutBottom;default:return j.slideOutRight}return j.fadeOut})();return{appearClass:n,backdropAppearClass:o,backdropDisappearClass:r,disappearClass:a}}const ol=({settings:e,content:t,styles:n,portalId:o,activeEvent:r,isEditor:a})=>{const[i,s]=D.useState(!1),{url:l}=e.thumbnailBlock.cover;return D.useEffect(()=>{r==="close"&&s(!1),r==="open"&&s(!0)},[r]),S.jsxs(S.Fragment,{children:[S.jsx("img",{src:l,alt:"Cover",className:j.heroImage,onClick:()=>s(!0)}),S.jsx(rl,{isOpen:i,onClose:()=>s(!1),content:t,settings:e,lightboxStyles:n,portalId:o,isEditor:a})]})},rl=({isOpen:e,onClose:t,content:n,lightboxStyles:o,settings:r,portalId:a,isEditor:i,metadata:s})=>{var M;const[l,d]=D.useState(0),[p,_]=D.useState(0),[m,h]=D.useState(!1),[c,u]=D.useState(!1),[b,$]=D.useState({}),f=D.useRef(null),w=D.useRef(null),B=D.useRef(null),z=D.useRef(!1),E=D.useRef(null),v=D.useRef(null),T=D.useRef(null),V=D.useRef(null),W=D.useRef(!1),L=D.useRef(null),[F,O]=D.useState(!1),{appear:U,triggers:H,slider:g,thumbnail:R,controls:x,area:A,caption:C,layout:N}=r.lightboxBlock,{appearClass:q,backdropAppearClass:ie,backdropDisappearClass:Q,disappearClass:me}=nl(U.type,U.direction),I=(s==null?void 0:s.itemId)??null;D.useEffect(()=>{const y=()=>{setTimeout(()=>{var G,J;(J=(G=f.current)==null?void 0:G.splide)==null||J.refresh()},16)},P=()=>{_(G=>G+1)};return window.addEventListener("ArticleEditor.Layout:change",y),window.addEventListener("ArticleEditor.ComponentContent:change",P),()=>{window.removeEventListener("ArticleEditor.Layout:change",y),window.removeEventListener("ArticleEditor.ComponentContent:change",P)}},[]),D.useEffect(()=>{if(!e||!R.isActive){O(!1);return}const y=L.current;if(!y)return;const P=()=>{g.direction==="horiz"?O(y.scrollWidth>y.clientWidth):O(y.scrollHeight>y.clientHeight)};P();const G=new ResizeObserver(P);return G.observe(y),()=>G.disconnect()},[e,R.isActive,n.length,b,g.direction]);const K=D.useCallback(()=>{const y=window.matchMedia("(max-width: 768px)").matches,P=lo(A.color);y&&!i&&P>.9&&(document.body.style.backgroundColor=""),h(!0),z.current=!0;const G=J=>{J.target===E.current&&J.animationName&&(E.current&&v.current&&E.current.removeEventListener("animationend",v.current),v.current=null,z.current&&(z.current=!1,t()),h(!1))};E.current&&(v.current=G,E.current.addEventListener("animationend",G))},[t,A.color,i]),ye=(y,P,G)=>{var J,re;if(y){if(H.type==="click"&&H.switch==="image")H.repeat==="close"&&l===n.length-1?K():(J=f.current)==null||J.go("+1");else if(H.type==="click"&&H.switch==="50/50"){const Z=y.getBoundingClientRect(),X=P-Z.left,oe=G-Z.top,ve=Z.width,le=Z.height;let ce;g.direction==="horiz"?ce=X<ve/2?"-1":"+1":ce=oe<le/2?"-1":"+1",(re=f.current)==null||re.go(ce)}}},ae=y=>{if(W.current){W.current=!1;return}const P=n[l],G=(P==null?void 0:P.image.objectFit)==="cover";let J,re;if("changedTouches"in y&&y.changedTouches.length>0)J=y.changedTouches[0].clientX,re=y.changedTouches[0].clientY;else if("clientX"in y)J=y.clientX,re=y.clientY;else return;let Z;if(G&&B.current){const X=ao(B.current);Z=J>=X.left&&J<=X.right&&re>=X.top&&re<=X.bottom}else{const X=B.current?io(B.current):null;if(!X){y.target===y.currentTarget&&K();return}Z=J>=X.x&&J<=X.x+X.width&&re>=X.y&&re<=X.y+X.height}Z?ye(B.current,J,re):K()},de=y=>{const P=y.target;(P.classList.contains(j.thumbsWrapper)||P.classList.contains(j.thumbsContainer))&&ae(y)};D.useEffect(()=>{if(!e)return;const y=P=>{var G,J;if(P.key==="Escape"){K();return}if(P.key==="ArrowRight"){d(re=>(re+1)%Math.max(n.length,1)),(G=f.current)==null||G.go("+1");return}P.key==="ArrowLeft"&&(d(re=>(re-1+Math.max(n.length,1))%Math.max(n.length,1)),(J=f.current)==null||J.go("-1"))};return window.addEventListener("keydown",y),()=>{window.removeEventListener("keydown",y)}},[e,K,n.length]),D.useEffect(()=>{if(e){if(d(0),_(P=>P+1),z.current=!1,h(!1),u(!1),$({}),!I)return;const y=new CustomEvent("page-overlay",{detail:{itemId:I}});window.dispatchEvent(y)}return()=>{E.current&&v.current&&(E.current.removeEventListener("animationend",v.current),v.current=null),u(!1)}},[e,I]),D.useEffect(()=>{w.current!==null&&w.current!==g.type&&_(y=>y+1),w.current=g.type},[g.type]),D.useEffect(()=>{if(!e)return;const y=document.body.style.overflow,P=window.matchMedia("(max-width: 768px)").matches,G=lo(A.color);document.body.style.overflow="hidden",u(!1);const J=Z=>{Z.target===E.current&&!z.current&&Z.animationName&&(P&&!i&&G>.9&&(document.body.style.backgroundColor=A.color),u(!0),E.current&&T.current&&E.current.removeEventListener("animationend",T.current),T.current=null)};E.current&&(T.current=J,E.current.addEventListener("animationend",J));const re=Z=>{const X=Z.target;X&&(X.closest(`.${j.thumbsWrapper}`)||X.closest(`.${j.thumbsContainer}`))||g.type!=="slide"&&Z.preventDefault()};return document.addEventListener("touchmove",re,{passive:!1}),()=>{document.body.style.overflow=y,document.removeEventListener("touchmove",re),E.current&&T.current&&(E.current.removeEventListener("animationend",T.current),T.current=null),u(!1)}},[e,i,A.color,g.type]),D.useEffect(()=>{if(!e)return;const y=P=>{var J,re;if(z.current){P.stopPropagation();return}if(W.current){W.current=!1;return}const G=P.target;if(!(G&&(G.closest(`.${j.thumbsContainer}`)||G.closest(`.${j.thumbItem}`)))){if(g.type==="slide"&&H.type==="drag"&&((re=(J=f.current)==null?void 0:J.splide)!=null&&re.root)){const Z=f.current.splide.root;if(G&&(Z.contains(G)||Z===G))return}if(P.touches.length===0&&P.changedTouches.length>0){const Z=n[l],X=(Z==null?void 0:Z.image.objectFit)==="cover",oe=P.changedTouches[0];let ve;if(X&&B.current){const le=ao(B.current);ve=oe.clientX>=le.left&&oe.clientX<=le.right&&oe.clientY>=le.top&&oe.clientY<=le.bottom}else{const le=B.current?io(B.current):null;if(!le)return;ve=oe.clientX>=le.x&&oe.clientX<=le.x+le.width&&oe.clientY>=le.y&&oe.clientY<=le.y+le.height}if(!ve){P.stopPropagation(),z.current=!0;const le=ce=>{ce.stopPropagation(),ce.preventDefault(),document.removeEventListener("click",le,!0)};document.addEventListener("click",le,!0),K()}}}};return document.addEventListener("touchend",y,{passive:!0}),()=>{document.removeEventListener("touchend",y)}},[e,K,l,n]);const ge=(g.type==="scale"||g.type==="fade")&&g.direction==="vert"&&H.type==="drag";D.useEffect(()=>{var ce,Ne;if(!e||!ge||!((Ne=(ce=f.current)==null?void 0:ce.splide)!=null&&Ne.root))return;const y=f.current.splide.root,P=30,G=(ee,ne)=>{if(V.current){const be=Math.abs(ee-V.current.x),Ce=Math.abs(ne-V.current.y);(be>0||Ce>0)&&(W.current=!0)}},J=ee=>{V.current&&(ee.preventDefault(),G(ee.clientX,ee.clientY))},re=ee=>{V.current&&ee.touches.length>0&&(ee.preventDefault(),G(ee.touches[0].clientX,ee.touches[0].clientY))},Z=(ee,ne)=>{if(!V.current||!f.current){V.current=null;return}const be=Math.abs(ee-V.current.x),Ce=Math.abs(ne-V.current.y);Ce>P&&Ce>be&&f.current.go(ne<V.current.y?"+1":"-1"),V.current=null},X=ee=>{V.current&&Z(ee.clientX,ee.clientY),document.removeEventListener("pointerup",X),document.removeEventListener("pointercancel",X),document.removeEventListener("pointermove",J)},oe=ee=>{if(V.current){if(ee.changedTouches.length>0){const ne=ee.changedTouches[0];Z(ne.clientX,ne.clientY)}document.removeEventListener("touchend",oe),document.removeEventListener("touchcancel",oe),document.removeEventListener("touchmove",re)}},ve=ee=>{V.current={x:ee.clientX,y:ee.clientY},W.current=!1,document.addEventListener("pointermove",J,{passive:!1}),document.addEventListener("pointerup",X),document.addEventListener("pointercancel",X)},le=ee=>{ee.touches.length>0&&(V.current={x:ee.touches[0].clientX,y:ee.touches[0].clientY},W.current=!1,document.addEventListener("touchmove",re,{passive:!1}),document.addEventListener("touchend",oe),document.addEventListener("touchcancel",oe))};return y.addEventListener("pointerdown",ve),y.addEventListener("touchstart",le),()=>{y.removeEventListener("pointerdown",ve),y.removeEventListener("touchstart",le),document.removeEventListener("pointermove",J),document.removeEventListener("pointerup",X),document.removeEventListener("pointercancel",X),document.removeEventListener("touchmove",re),document.removeEventListener("touchend",oe),document.removeEventListener("touchcancel",oe),V.current=null,W.current=!1}},[e,ge,p]);const De={backgroundColor:A.color,backdropFilter:`blur(${A.blur}px)`,animationDuration:`${parseInt(U.duration)}ms`,animationTimingFunction:"ease",animationFillMode:"both"};return document.getElementById(a)?or.createPortal(S.jsxs(S.Fragment,{children:[S.jsx("div",{ref:i?null:E,className:ue(j.background,m?Q:ie,{[j.editor]:i},{[j.hidden]:!e}),style:{...De,...c&&!i&&!m?{position:"absolute"}:{}}}),S.jsxs("div",{ref:i?E:null,className:ue(j.contentStyle,m?me:q,{[j.editor]:i},{[j.hidden]:!e}),style:{animationDuration:`${parseInt(U.duration)}ms`,animationTimingFunction:"ease",animationFillMode:"both"},children:[S.jsx(Ko,{onMove:y=>d(y.index),ref:f,className:j.lightboxSplide,options:{arrows:!1,speed:g.duration?parseInt(g.duration):500,direction:g.direction==="horiz"||g.type==="fade"||g.type==="scale"?"ltr":"ttb",pagination:!1,drag:H.type==="drag"&&!ge,perPage:1,width:"100%",height:"100%",type:g.type==="fade"||g.type==="scale"?"fade":"loop",padding:0,rewind:H.repeat!=="close",start:0},style:{"--splide-speed":g.duration},children:n.map((y,P)=>{const G=Nt(N.position,N.offset,i),J=`${k.scalingValue(N.padding.top,i)} ${k.scalingValue(N.padding.right,i)} ${k.scalingValue(N.padding.bottom,i)} ${k.scalingValue(N.padding.left,i)}`,re=g.type==="scale"?(()=>{const{transform:Z,...X}=G;return{...X,position:"absolute",padding:J,boxSizing:"border-box","--position-transform":Z||"none"}})():{...G,position:"absolute",padding:J,boxSizing:"border-box"};return S.jsx(Jo,{children:S.jsx("div",{className:j.imgWrapper,onClick:ae,children:S.jsx("img",{ref:P===l?B:null,className:ue(j.imageStyle,{[j.contain]:y.image.objectFit==="contain",[j.cover]:y.image.objectFit==="cover",[j.scaleSlide]:g.type==="scale"}),src:y.image.url,alt:y.image.name??"",style:{...re,pointerEvents:y.image.objectFit==="contain"?"none":"auto"}})})},P)})},p),x.isActive&&S.jsxs(S.Fragment,{children:[S.jsx("div",{className:ue(j.arrow,{[j.arrowVertical]:g.direction==="vert"}),style:{color:x.color,"--arrow-hover-color":x.hover},children:S.jsxs("button",{className:j.arrowInner,style:{transform:`translate(${k.scalingValue(x.offset.x,i)}, ${k.scalingValue(x.offset.y*(g.direction==="horiz"?1:-1),i)}) scale(${x.scale}) rotate(${g.direction==="horiz"?"0deg":"90deg"})`},onClick:()=>{var y;return(y=f.current)==null?void 0:y.go("-1")},"aria-label":"Previous",children:[x.arrowsImgUrl&&S.jsx(vt,{url:x.arrowsImgUrl,fill:x.color,hoverFill:x.hover,className:ue(j.arrowImg,j.mirror)}),!x.arrowsImgUrl&&S.jsx(so,{color:x.color,className:ue(j.arrowIcon,j.arrowImg,j.mirror)})]})}),S.jsx("div",{className:ue(j.arrow,j.nextArrow,{[j.arrowVertical]:g.direction==="vert"}),style:{color:x.color,"--arrow-hover-color":x.hover},children:S.jsxs("button",{className:j.arrowInner,style:{transform:`translate(${k.scalingValue(x.offset.x*(g.direction==="horiz"?-1:1),i)}, ${k.scalingValue(x.offset.y,i)}) scale(${x.scale}) rotate(${g.direction==="horiz"?"0deg":"90deg"})`},onClick:()=>{var y;return(y=f.current)==null?void 0:y.go("+1")},"aria-label":"Next",children:[x.arrowsImgUrl&&S.jsx(vt,{url:x.arrowsImgUrl,fill:x.color,hoverFill:x.hover,className:j.arrowImg}),!x.arrowsImgUrl&&S.jsx(so,{color:x.color,className:ue(j.arrowIcon,j.arrowImg)})]})})]}),A.closeIconUrl&&(()=>{const y=Nt(A.closeIconAlign,A.closeIconOffset,i),P=`scale(${A.closeIconScale})`,G=y.transform?`${y.transform} ${P}`:P;return S.jsx("button",{className:j.closeButton,style:{...y,transform:G},onClick:K,"aria-label":"Close lightbox",children:S.jsx(vt,{url:A.closeIconUrl,fill:A.closeIconColor??"#000000",hoverFill:A.closeIconHover??"#cccccc"})})})(),C&&C.isActive&&o.imageCaption&&((M=n[l])==null?void 0:M.imageCaption)&&(()=>{const{widthSettings:y,fontSettings:P,letterSpacing:G,textAlign:J,wordSpacing:re,fontSizeLineHeight:Z,textAppearance:X,color:oe}=o.imageCaption;return S.jsx("div",{className:j.caption,style:{...Nt(C.alignment,C.offset,i),fontFamily:P.fontFamily,fontWeight:P.fontWeight,fontStyle:P.fontStyle,width:y.sizing==="auto"?"max-content":k.scalingValue(y.width,i),letterSpacing:k.scalingValue(G,i),wordSpacing:k.scalingValue(re,i),textAlign:J,fontSize:k.scalingValue(Z.fontSize,i),lineHeight:k.scalingValue(Z.lineHeight,i),textTransform:X.textTransform??"none",textDecoration:X.textDecoration??"none",fontVariant:X.fontVariant??"normal",color:oe},onClick:ve=>ve.stopPropagation(),children:S.jsx("div",{"data-styles":"imageCaption",className:j.captionTextInner,style:{"--link-color":C.linkColor,"--link-hover-color":C.linkHoverColor},children:S.jsx(Zo,{content:n[l].imageCaption})})})})(),R.isActive&&(()=>{const[y,P]=R.position.split("-"),G=g.direction==="horiz"?`${y}-left`:R.position,J=Nt(G,R.offset,i),re=()=>{if(g.direction==="horiz"){if(P==="left")return"flex-start";if(P==="center")return"center";if(P==="right")return"flex-end"}else{if(y==="top")return"flex-start";if(y==="middle")return"center";if(y==="bottom")return"flex-end"}return"flex-start"};return S.jsx("div",{ref:L,className:j.thumbsWrapper,onClick:Z=>de(Z),style:{position:i?"absolute":"fixed",...J,...g.direction==="horiz"?{maxWidth:"100vw",width:"100%",overflowX:"auto",overflowY:"hidden"}:{maxHeight:"100vh",overflowY:"auto",overflowX:"hidden"}},children:S.jsx("div",{className:ue(j.thumbsContainer,{[j.thumbsContainerVertical]:g.direction==="vert",[j.thumbsAlignStart]:R.align==="start",[j.thumbsAlignCenter]:R.align==="center",[j.thumbsAlignEnd]:R.align==="end"}),style:{gap:k.scalingValue(R.grid.gap,i),justifyContent:F?"flex-start":re()},children:n.map((Z,X)=>{const oe=X===l,ve=b[X],ce=R.grid.size*(oe?R.activeState.scale:1),Ne=()=>{if(R.fit!=="fit")return{};if(!ve)return g.direction==="horiz"?{height:k.scalingValue(ce,i)}:{width:k.scalingValue(ce,i)};const ee=ve.width/ve.height;if(g.direction==="horiz"){const ne=ce,be=ne*ee;return{width:k.scalingValue(be,i),height:k.scalingValue(ne,i)}}else{const ne=ce,be=ne/ee;return{width:k.scalingValue(ne,i),height:k.scalingValue(be,i)}}};return S.jsx("button",{className:j.thumbItem,style:{...g.direction==="horiz"&&R.fit!=="fit"?{height:k.scalingValue(ce,i)}:{},...g.direction==="vert"&&R.fit!=="fit"?{width:k.scalingValue(ce,i)}:{},...R.fit==="cover"?{width:k.scalingValue(ce,i),height:k.scalingValue(ce,i)}:{},...Ne(),transition:oe?"all 0.25s ease-out":"none",opacity:oe?R.activeState.opacity/100:R.opacity/100,"--thumb-hover":R.activeState.opacity/100},onClick:ee=>{var ne;ee.stopPropagation(),d(X),(ne=f.current)==null||ne.go(X)},onMouseEnter:()=>{var ee;R.triggers==="hov"&&((ee=f.current)==null||ee.go(X))},children:S.jsx("img",{src:Z.image.url,alt:Z.image.name??"",onLoad:ee=>{const ne=ee.currentTarget;ne.naturalWidth&&ne.naturalHeight&&$(be=>({...be,[X]:{width:ne.naturalWidth,height:ne.naturalHeight}}))},style:{objectFit:R.fit==="cover"?"cover":"contain",...R.fit==="fit"?{maxWidth:"100%",maxHeight:"100%",objectFit:"contain"}:{},...R.fit==="cover"?{width:"100%",height:"100%"}:{}}})},`${Z.image.name}-${X}`)})})})})()]})]}),document.getElementById(a)):null};function so({color:e,className:t}){return S.jsx("svg",{viewBox:"0 0 10 18",className:t,children:S.jsx("g",{id:"Symbols",stroke:"none",strokeWidth:"1",fillRule:"evenodd",children:S.jsx("path",{d:"M-3.70710678,4.29289322 C-3.34662282,3.93240926 -2.77939176,3.90467972 -2.38710056,4.20970461 L-2.29289322,4.29289322 L5,11.585 L12.2928932,4.29289322 C12.6533772,3.93240926 13.2206082,3.90467972 13.6128994,4.20970461 L13.7071068,4.29289322 C14.0675907,4.65337718 14.0953203,5.22060824 13.7902954,5.61289944 L13.7071068,5.70710678 L5.70710678,13.7071068 C5.34662282,14.0675907 4.77939176,14.0953203 4.38710056,13.7902954 L4.29289322,13.7071068 L-3.70710678,5.70710678 C-4.09763107,5.31658249 -4.09763107,4.68341751 -3.70710678,4.29289322 Z",id:"Shape-Copy",fill:e,transform:"translate(5, 9) rotate(-90) translate(-5, -9)"})})})}const il={element:ol,id:"lightbox",name:"Lightbox",preview:{type:"image",url:"https://cdn.cntrl.site/component-assets/lightboxImg.png"},defaultSize:{width:440,height:550},schema:{type:"object",properties:{settings:{type:"object",properties:{thumbnailBlock:{display:{type:"settings-block",triggerEvent:"close"},type:"object",properties:{cover:{title:"COVER",icon:"cover",tooltip:"Cover Image",type:"object",properties:{url:{type:"string",display:{type:"cover-image-input"}}}}}},lightboxBlock:{display:{type:"settings-block",triggerEvent:"open"},type:"object",properties:{appear:{title:"APPEAR",icon:"transition",tooltip:"Appearance",type:"object",properties:{type:{type:"string",display:{type:"ratio-group"},enum:["slide in","fade in","mix"]},duration:{type:"string",label:"T",display:{type:"step-selector"},enum:["100ms","250ms","500ms","1000ms","1500ms","2000ms"]},direction:{type:"string",title:"From",display:{type:"direction-control"},enum:["top","left","right","bottom"]}}},triggers:{title:"TRIGGERS",icon:"target",tooltip:"Triggers",type:"object",properties:{type:{type:"string",display:{type:"ratio-group"},enum:["click","drag"]},switch:{type:"string",display:{type:"ratio-group"},enum:["image","50/50"]},repeat:{type:"string",title:"Repeat",display:{visible:!1,type:"ratio-group"},enum:["close","loop"]}}},slider:{title:"SLIDER",icon:"horizontal-resize",tooltip:"Slider",type:"object",properties:{type:{type:"string",display:{type:"ratio-group"},enum:["slide","fade","scale"]},direction:{type:"string",display:{type:"ratio-group"},enum:["horiz","vert"]},duration:{type:"string",label:"T",display:{type:"step-selector"},enum:["100ms","250ms","500ms","1000ms","1500ms","2000ms"]}}},thumbnail:{title:"THUMB",icon:"thumbnail",tooltip:"Thumbnail",type:"object",properties:{isActive:{type:"boolean",display:{type:"setting-toggle"}},position:{display:{type:"align-grid"},type:"string",enum:["top-left","top-center","top-right","middle-left","middle-center","middle-right","bottom-left","bottom-center","bottom-right"]},fit:{type:"string",display:{type:"ratio-group"},enum:["cover","fit"]},align:{type:"string",title:"Align",display:{type:"align-group",direction:"horizontal"},enum:["start","center","end"]},triggers:{type:"string",title:"Triggers",display:{type:"ratio-group",direction:"horizontal"},enum:["clk","hov"]},grid:{type:"object",title:"Grid",display:{type:"group"},properties:{size:{type:"number",label:"Box",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}},gap:{type:"number",label:"Gap",scalingEnabled:!0,min:0,display:{type:"numeric-input"}}}},offset:{type:"object",title:"Offset",display:{type:"group"},properties:{x:{type:"number",label:"X",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}},y:{type:"number",label:"Y",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}}}},opacity:{type:"number",title:"Opacity",label:"icon:opacity",min:0,max:100,step:1,display:{type:"numeric-input"}},activeState:{type:"object",title:"ACTIVE",display:{type:"group"},properties:{scale:{type:"number",title:"Scale",min:1,max:5,step:.1,display:{type:"range-control"}},opacity:{type:"number",title:"Opacity",label:"icon:opacity",min:0,max:100,step:1,display:{type:"numeric-input"}}}}}},layout:{title:"LAYOUT",icon:"layout",tooltip:"Layout",type:"object",properties:{position:{display:{type:"align-grid"},type:"string",enum:["top-left","top-center","top-right","middle-left","middle-center","middle-right","bottom-left","bottom-center","bottom-right"]},offset:{type:"object",title:"Offset",display:{type:"group"},properties:{x:{type:"number",label:"X",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}},y:{type:"number",label:"Y",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}}}},padding:{type:"object",title:"Padding",display:{type:"padding-controls"},properties:{top:{min:0,step:1,type:"number"},left:{min:0,step:1,type:"number"},right:{min:0,step:1,type:"number"},bottom:{min:0,step:1,type:"number"}}}}},controls:{title:"CONTROLS",icon:"controls",tooltip:"Controls",type:"object",properties:{isActive:{type:"boolean",display:{type:"setting-toggle"}},arrowsImgUrl:{type:["string","null"],display:{type:"settings-image-input"}},offset:{title:"Offset",type:"object",display:{type:"group"},properties:{x:{type:"number",label:"X",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}},y:{type:"number",label:"Y",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}}}},scale:{type:"number",title:"Scale",min:.5,max:5,step:.1,display:{type:"range-control"}},color:{title:"Color",type:"string",display:{type:"settings-color-picker",format:"single"}},hover:{title:"Hover",type:"string",display:{type:"settings-color-picker",format:"single"}}}},area:{title:"AREA",icon:"area",tooltip:"Area",type:"object",properties:{color:{type:"string",display:{type:"settings-color-picker",format:"single"}},blur:{type:"number",label:"icon:blur",display:{type:"numeric-input"}},closeIconUrl:{type:["string","null"],title:"Close Icon",display:{type:"settings-image-input"}},closeIconAlign:{display:{type:"align-grid",direction:"horizontal"},type:"string",enum:["top-left","top-center","top-right","middle-left","middle-center","middle-right","bottom-left","bottom-center","bottom-right"]},closeIconScale:{type:"number",title:"Scale",min:.5,max:5,step:.1,display:{type:"range-control"}},closeIconOffset:{type:"object",title:"Offset",display:{type:"group"},properties:{x:{type:"number",label:"X",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}},y:{type:"number",label:"Y",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}}}},closeIconColor:{title:"Color",type:"string",display:{type:"settings-color-picker",format:"single"}},closeIconHover:{title:"Hover",type:"string",display:{type:"settings-color-picker",format:"single"}}}},caption:{title:"DESC",icon:"text-icon",tooltip:"Description",type:"object",properties:{isActive:{type:"boolean",display:{type:"setting-toggle"}},alignment:{type:"string",display:{type:"align-grid"},enum:["top-left","top-center","top-right","middle-left","middle-center","middle-right","bottom-left","bottom-center","bottom-right"]},offset:{title:"Offset",type:"object",display:{type:"group"},properties:{x:{type:"number",label:"X",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}},y:{type:"number",label:"Y",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}}}},linkColor:{title:"Link",type:"string",display:{type:"settings-color-picker",format:"single"}},linkHoverColor:{title:"Link Hov",type:"string",display:{type:"settings-color-picker",format:"single"}}}}}}},default:{d:{thumbnailBlock:{cover:{url:"https://cdn.cntrl.site/component-assets/Cover.jpg"}},lightboxBlock:{appear:{type:"slide in",duration:"1000ms",direction:"bottom"},triggers:{type:"click",switch:"image",repeat:"loop"},slider:{type:"slide",direction:"vert",duration:"1000ms"},thumbnail:{isActive:!0,position:"middle-left",fit:"fit",align:"start",triggers:"hov",grid:{size:.05,gap:.01},offset:{x:.01,y:0},opacity:50,activeState:{scale:1,opacity:100}},layout:{position:"middle-center",offset:{x:0,y:0},padding:{top:.06,right:0,bottom:.06,left:0}},controls:{isActive:!1,arrowsImgUrl:null,offset:{x:0,y:0},scale:1,color:"#000000",hover:"#cccccc"},area:{color:"rgba(28,31,34,0.9)",blur:0,closeIconUrl:null,closeIconColor:"#000000",closeIconHover:"#cccccc",closeIconAlign:"top-right",closeIconOffset:{x:0,y:0},closeIconScale:1},caption:{isActive:!0,alignment:"middle-center",offset:{x:0,y:0},linkColor:"#cccccc",linkHoverColor:"#cccccc"}}},m:{thumbnailBlock:{cover:{url:"https://cdn.cntrl.site/component-assets/Cover.jpg"}},lightboxBlock:{appear:{type:"fade in",duration:"500ms",direction:"bottom"},triggers:{type:"click",switch:"image",repeat:"loop"},slider:{type:"slide",direction:"horiz",duration:"1000ms"},thumbnail:{isActive:!0,position:"bottom-center",fit:"fit",align:"start",triggers:"hov",grid:{size:.1,gap:.05},offset:{x:.01,y:-.05},opacity:50,activeState:{scale:1,opacity:100}},layout:{position:"middle-center",offset:{x:0,y:0},padding:{top:.06,right:.05,bottom:.06,left:.05}},controls:{isActive:!1,arrowsImgUrl:null,offset:{x:0,y:0},scale:1,color:"#000000",hover:"#cccccc"},area:{color:"rgba(28,31,34,0.9)",blur:0,closeIconUrl:null,closeIconColor:"#000000",closeIconHover:"#cccccc",closeIconAlign:"top-right",closeIconOffset:{x:0,y:0},closeIconScale:1},caption:{isActive:!0,alignment:"middle-center",offset:{x:0,y:0},hover:"#cccccc"}}},t:{thumbnailBlock:{cover:{url:"https://cdn.cntrl.site/component-assets/Cover.jpg"}},lightboxBlock:{appear:{type:"fade in",duration:"500ms",direction:"bottom"},triggers:{type:"click",switch:"image",repeat:"loop"},slider:{type:"slide",direction:"vert",duration:"1000ms"},thumbnail:{isActive:!0,position:"middle-left",fit:"fit",align:"start",triggers:"hov",grid:{size:.05,gap:.01},offset:{x:.03,y:0},opacity:50,activeState:{scale:1,opacity:100}},layout:{position:"middle-center",offset:{x:0,y:0},padding:{top:.06,right:.1,bottom:.06,left:.1}},controls:{isActive:!1,arrowsImgUrl:null,offset:{x:0,y:0},scale:1,color:"#000000",hover:"#cccccc"},area:{color:"rgba(28,31,34,0.9)",blur:0,closeIconUrl:null,closeIconColor:"#000000",closeIconHover:"#cccccc",closeIconAlign:"top-right",closeIconOffset:{x:0,y:0},closeIconScale:1},caption:{isActive:!0,alignment:"middle-center",offset:{x:0,y:0},hover:"#cccccc"}}}},displayRules:[{if:{name:"lightboxBlock.appear.type",value:"slide in"},then:{name:"properties.lightboxBlock.properties.appear.properties.direction.display.visible",value:!0}},{if:{name:"lightboxBlock.slider.direction",value:"vert"},then:{name:"properties.lightboxBlock.properties.thumbnail.properties.align.display.direction",value:"vertical"}},{if:{name:"lightboxBlock.appear.type",value:"mix"},then:{name:"properties.lightboxBlock.properties.appear.properties.direction.display.visible",value:!0}},{if:{name:"lightboxBlock.appear.type",value:"fade in"},then:{name:"properties.lightboxBlock.properties.appear.properties.direction.display.visible",value:!1}},{if:[{name:"lightboxBlock.triggers.type",value:"click"},{name:"lightboxBlock.triggers.switch",value:"image"}],then:{name:"properties.lightboxBlock.properties.triggers.properties.repeat.display.visible",value:!0}}]},content:{type:"array",settings:{addItemFromFileExplorer:!0,defaultWidth:500},items:{type:"object",properties:{image:{type:"object",label:"Image",display:{type:"media-input",minWidth:58,maxWidth:108},properties:{url:{type:"string"},name:{type:"string"},objectFit:{type:"string",enum:["cover","contain"]}},required:["url","name"]},imageCaption:{label:"Description",placeholder:"Add Caption...",display:{type:"rich-text",minWidth:300,maxWidth:550}}},required:["image"]},default:[{image:{objectFit:"contain",url:"https://cdn.cntrl.site/component-assets/2.jpg",name:"Slider-1.png"},imageCaption:[{type:"paragraph",children:[{text:""}]}]},{image:{objectFit:"contain",url:"https://cdn.cntrl.site/component-assets/3.jpg",name:"Slider-2.png"},imageCaption:[{type:"paragraph",children:[{text:""}]}]},{image:{objectFit:"contain",url:"https://cdn.cntrl.site/component-assets/4.jpg",name:"Slider-3.png"},imageCaption:[{type:"paragraph",children:[{text:""}]}]}]},styles:{type:"object",properties:{imageCaption:{dataName:"caption",type:"object",properties:{fontSettings:{type:"object",display:{type:"font-settings"},properties:{fontFamily:{type:"string"},fontWeight:{type:"number"},fontStyle:{type:"string"}}},widthSettings:{display:{type:"text-width-control"},type:"object",properties:{width:{type:"number"},sizing:{type:"string",enum:["auto","manual"]}}},fontSizeLineHeight:{type:"object",display:{type:"font-size-line-height"},properties:{fontSize:{type:"number"},lineHeight:{type:"number"}}},letterSpacing:{display:{type:"letter-spacing-input"},type:"number"},wordSpacing:{display:{type:"word-spacing-input"},type:"number"},textAlign:{display:{type:"text-align-control"},type:"string",enum:["left","center","right","justify"]},textAppearance:{display:{type:"text-appearance"},properties:{textTransform:{type:"string",enum:["none","uppercase","lowercase","capitalize"]},textDecoration:{type:"string",enum:["none","underline"]},fontVariant:{type:"string",enum:["normal","small-caps"]}}},color:{display:{type:"style-panel-color-picker"},type:"string"}}}},default:{imageCaption:{widthSettings:{width:.13,sizing:"auto"},fontSettings:{fontFamily:"Arial",fontWeight:400,fontStyle:"normal"},fontSizeLineHeight:{fontSize:.02,lineHeight:.02},letterSpacing:0,wordSpacing:0,textAlign:"left",textAppearance:{textTransform:"none",textDecoration:"none",fontVariant:"normal"},color:"#000000"}}}},required:["settings","content","styles"]}};function rt(e){return`calc(var(--cntrl-article-width, 100vw) * ${e/1440})`}function al(e){return`
|
|
7
|
-
.${
|
|
6
|
+
*/const pa="RichTextRenderer-module__link___BWeZ2",da={link:pa},rr=({content:t})=>{const e=n=>n.map((o,r)=>o.type==="link"?x.jsx("a",{className:da.link,href:o.value,target:o.target,children:e(o.children)},r):x.jsx("span",{style:ga(o),children:o.text},r));return x.jsx(x.Fragment,{children:t.map((n,o)=>{const r=n.children;return x.jsx("div",{children:e(r)},o)})})};function ga(t){return{...t.fontFamily&&{fontFamily:t.fontFamily},...t.fontWeight&&{fontWeight:t.fontWeight},...t.fontStyle&&{fontStyle:t.fontStyle},...t.textDecoration&&{textDecoration:t.textDecoration},...t.textTransform&&{textTransform:t.textTransform},...t.fontVariant&&{fontVariant:t.fontVariant},...t.verticalAlign&&{verticalAlign:t.verticalAlign,lineHeight:"0px"}}}const ma="SvgImage-module__svg___q3xE-",fa="SvgImage-module__img___VsTm-",go={svg:ma,img:fa},ha=t=>{const e=t.trim();return e.startsWith("data:image/svg+xml")?!0:(e.split(/[?#]/)[0]??e).endsWith(".svg")},va=t=>`url("${t.replace(/\\/g,"\\\\").replace(/"/g,'\\"')}")`,ge=({url:t,fill:e="#000000",hoverFill:n="#CCCCCC",className:o=""})=>{const[r,a]=j.useState(()=>typeof window>"u"?!0:CSS.supports("mask-image",'url("")')||CSS.supports("-webkit-mask-image",'url("")'));return j.useEffect(()=>{if(typeof window<"u"&&window.CSS){const i=CSS.supports("mask-image",'url("")')||CSS.supports("-webkit-mask-image",'url("")');a(i)}},[]),!ha(t)||!r?x.jsx("img",{src:t,alt:"",className:dt(go.img,o)}):x.jsx("span",{"data-supports-mask":r,className:dt(go.svg,o),style:{"--svg":va(t),"--fill":e,"--hover-fill":n}})},ya={"top-left":Y.topLeftAlignment,"top-center":Y.topCenterAlignment,"top-right":Y.topRightAlignment,"middle-left":Y.middleLeftAlignment,"middle-center":Y.middleCenterAlignment,"middle-right":Y.middleRightAlignment,"bottom-left":Y.bottomLeftAlignment,"bottom-center":Y.bottomCenterAlignment,"bottom-right":Y.bottomRightAlignment};function ba({settings:t,content:e,styles:n,isEditor:o}){const[r,a]=j.useState(null),{widthSettings:i,fontSettings:c,letterSpacing:l,textAlign:p,wordSpacing:s,fontSizeLineHeight:w,textAppearance:v,color:m}=n.imageCaption,[u,d]=j.useState(void 0),[C,b]=j.useState(null),[f,$]=j.useState(0),[M,P]=j.useState(0),{direction:T,transition:h,controls:L,pagination:R,imageCaption:W,triggers:k}=t,B=j.useRef(h.type),{x:O,y:U}=t.controls.offset,D=g=>{r&&r.go(g)};return j.useEffect(()=>{if(!C)return;const g=new ResizeObserver(A=>{if(!r)return;const[I]=A;d({width:Math.round(I.contentRect.width),height:Math.round(I.contentRect.height)})});return g.observe(C),()=>g.unobserve(C)},[C]),j.useEffect(()=>{!r||B.current===h.type||(P(g=>g+1),B.current=h.type)},[h.type]),x.jsx("div",{className:dt(Y.wrapper,{[Y.editor]:o}),ref:b,children:x.jsxs("div",{className:Y.sliderInner,style:{width:u?u.width:"100%",height:u?u.height:"100%",backgroundColor:h.backgroundColor&&h.type==="fade in"?h.backgroundColor:"transparent"},children:[t.imageCaption.isActive&&x.jsx("div",{className:dt(Y.captionBlock),children:x.jsx("div",{className:Y.captionTextWrapper,children:e.map((g,A)=>x.jsx("div",{className:dt(Y.captionText,ya[W.alignment],{[Y.withPointerEvents]:A===f&&o,[Y.active]:A===f}),style:{fontFamily:c.fontFamily,fontWeight:c.fontWeight,fontStyle:c.fontStyle,width:i.sizing==="auto"?"max-content":F.scalingValue(i.width,o),letterSpacing:F.scalingValue(l,o),wordSpacing:F.scalingValue(s,o),textAlign:p,fontSize:F.scalingValue(w.fontSize,o),lineHeight:F.scalingValue(w.lineHeight,o),textTransform:v.textTransform??"none",textDecoration:v.textDecoration??"none",fontVariant:v.fontVariant??"normal",color:m,transitionDuration:h.duration?`${Math.round(parseInt(h.duration)/2)}ms`:"500ms"},children:x.jsx("div",{"data-styles":"imageCaption",className:Y.captionTextInner,style:{"--link-hover-color":W.linkHoverColor,"--link-color":W.linkColor,position:"relative",top:F.scalingValue(W.offset.y,o),left:F.scalingValue(W.offset.x,o)},children:x.jsx(rr,{content:g.imageCaption})})},A))})}),x.jsx(nr,{onMove:g=>{$(g.index)},ref:a,options:{arrows:!1,speed:h.duration?parseInt(h.duration):500,autoplay:k.autoPlay!==null,...k.autoPlay!==null&&{interval:parseInt(k.autoPlay)*1e3},direction:T==="horiz"||h.type==="fade in"?"ltr":"ttb",pagination:!1,drag:k.triggersList.drag,perPage:1,width:u?u.width:"100%",height:u?u.height:"100%",type:h.type==="fade in"?"fade":"loop",rewind:!0},children:e.map((g,A)=>x.jsx(or,{children:x.jsx("div",{className:Y.sliderItem,children:x.jsx("div",{className:Y.imgWrapper,children:x.jsx("img",{className:dt(Y.sliderImage,{[Y.contain]:g.image.objectFit==="contain",[Y.cover]:g.image.objectFit==="cover"}),src:g.image.url,alt:g.image.name??""})})})},A))},M),L.isActive&&x.jsxs(x.Fragment,{children:[x.jsx("div",{className:dt(Y.arrow,{[Y.arrowVertical]:T==="vert",[Y.hoverArrow]:L.show==="on hover"}),style:{color:L.color,"--arrow-hover-color":L.hover},children:x.jsxs("button",{onClick:()=>{D("-1")},className:Y.arrowInner,style:{transform:`translate(${F.scalingValue(O,o)}, ${F.scalingValue(U*(T==="horiz"?1:-1),o)}) scale(${t.controls.scale/100}) rotate(${T==="horiz"?"0deg":"90deg"})`},children:[L.arrowsImgUrl&&x.jsx(ge,{url:L.arrowsImgUrl,fill:L.color,hoverFill:L.hover,className:dt(Y.arrowImg,Y.mirror)}),!L.arrowsImgUrl&&x.jsx(mo,{color:L.color,className:dt(Y.arrowIcon,Y.arrowImg,Y.mirror)})]})}),x.jsx("div",{className:dt(Y.arrow,Y.nextArrow,{[Y.arrowVertical]:T==="vert",[Y.hoverArrow]:L.show==="on hover"}),style:{color:L.color,"--arrow-hover-color":L.hover},children:x.jsxs("button",{className:Y.arrowInner,onClick:()=>D("+1"),style:{transform:`translate(${F.scalingValue(O*(T==="horiz"?-1:1),o)}, ${F.scalingValue(U,o)}) scale(${t.controls.scale/100}) rotate(${T==="horiz"?"0deg":"90deg"})`},children:[L.arrowsImgUrl&&x.jsx(ge,{url:L.arrowsImgUrl,fill:L.color,hoverFill:L.hover,className:Y.arrowImg}),!L.arrowsImgUrl&&x.jsx(mo,{color:L.color,className:dt(Y.arrowIcon,Y.arrowImg)})]})})]}),k.triggersList.click&&x.jsx("div",{className:Y.clickOverlay,onClick:()=>{r&&r.go("+1")}}),R.isActive&&x.jsx("div",{className:dt(Y.pagination,{[Y.paginationInsideBottom]:R.position==="inside-1"&&T==="horiz",[Y.paginationInsideTop]:R.position==="inside-2"&&T==="horiz",[Y.paginationOutsideBottom]:R.position==="outside-1"&&T==="horiz",[Y.paginationOutsideTop]:R.position==="outside-2"&&T==="horiz",[Y.paginationInsideLeft]:R.position==="inside-1"&&T==="vert",[Y.paginationInsideRight]:R.position==="inside-2"&&T==="vert",[Y.paginationOutsideLeft]:R.position==="outside-1"&&T==="vert",[Y.paginationOutsideRight]:R.position==="outside-2"&&T==="vert",[Y.paginationVertical]:T==="vert"}),children:x.jsx("div",{className:Y.paginationInner,style:{backgroundColor:R.colors[2],transform:`scale(${R.scale/100}) translate(${F.scalingValue(R.offset.x,o)}, ${F.scalingValue(R.offset.y,o)}) rotate(${T==="horiz"?"0deg":"90deg"})`},children:e.map((g,A)=>x.jsx("button",{onClick:()=>{r&&r.go(A)},className:dt(Y.paginationItem),children:x.jsx("div",{className:dt(Y.dot,{[Y.activeDot]:A===f}),style:{backgroundColor:A===f?R.colors[0]:R.colors[1],"--pagination-hover-color":R.hover}})},A))})})]})})}function mo({color:t,className:e}){return x.jsx("svg",{viewBox:"0 0 10 18",className:e,children:x.jsx("g",{id:"Symbols",stroke:"none",strokeWidth:"1",fillRule:"evenodd",children:x.jsx("path",{d:"M-3.70710678,4.29289322 C-3.34662282,3.93240926 -2.77939176,3.90467972 -2.38710056,4.20970461 L-2.29289322,4.29289322 L5,11.585 L12.2928932,4.29289322 C12.6533772,3.93240926 13.2206082,3.90467972 13.6128994,4.20970461 L13.7071068,4.29289322 C14.0675907,4.65337718 14.0953203,5.22060824 13.7902954,5.61289944 L13.7071068,5.70710678 L5.70710678,13.7071068 C5.34662282,14.0675907 4.77939176,14.0953203 4.38710056,13.7902954 L4.29289322,13.7071068 L-3.70710678,5.70710678 C-4.09763107,5.31658249 -4.09763107,4.68341751 -3.70710678,4.29289322 Z",id:"Shape-Copy",fill:t,transform:"translate(5, 9) rotate(-90) translate(-5, -9)"})})})}const Sa={element:ba,id:"control-slider",name:"Slider",preview:{type:"image",url:"https://cdn.cntrl.site/component-assets/sliderImg.png"},defaultSize:{width:400,height:400},assetsPaths:{content:[{path:"image.url",placeholderEnabled:!0}],parameters:[{path:"settings.controls.arrowsImgUrl"}]},fontSettingsPaths:{content:[],parameters:[{path:"styles.imageCaption.fontSettings"}]},schema:{type:"object",properties:{settings:{type:"object",display:{type:"settings-block"},properties:{triggers:{title:"triggers",icon:"target",tooltip:"Triggers",type:"object",properties:{triggersList:{type:"object",display:{type:"toggle-ratio-group"},properties:{click:{type:"boolean"},drag:{type:"boolean"}}},autoPlay:{type:["string","null"],label:"Auto",display:{type:"step-selector"},enum:[null,"1s","2s","3s","4s","5s"]}}},direction:{icon:"horizontal-resize",tooltip:"Direction",type:"string",display:{type:"ratio-group"},enum:["horiz","vert"]},transition:{title:"transit",icon:"transition",tooltip:"Transition",type:"object",properties:{type:{type:"string",display:{type:"ratio-group"},enum:["slide","fade in"]},backgroundColor:{type:["string","null"],title:"BG Color",display:{visible:!1,type:"settings-color-picker",format:"single"}},duration:{type:"string",label:"icon:hourglass",display:{type:"step-selector"},enum:["100ms","250ms","500ms","1000ms","1500ms","2000ms"]}}},controls:{title:"controls",icon:"controls",tooltip:"Controls",type:"object",properties:{isActive:{type:"boolean",display:{type:"setting-toggle"}},arrowsImgUrl:{type:["string","null"],display:{type:"settings-image-input"}},offset:{type:"object",title:"Offset",display:{type:"group"},properties:{x:{type:"number",label:"X",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}},y:{type:"number",label:"Y",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}}}},scale:{type:"number",title:"scale",min:50,max:600,display:{type:"range-control"}},color:{title:"color",type:"string",display:{type:"settings-color-picker",format:"single"}},hover:{title:"hover",type:"string",display:{type:"settings-color-picker",format:"single"}},show:{title:"Show",type:"string",display:{type:"ratio-group"},enum:["always","on hover"]}}},pagination:{title:"nav",icon:"pagination",tooltip:"Navigation",type:"object",properties:{isActive:{type:"boolean",display:{type:"setting-toggle"}},position:{display:{type:"socket",direction:"horizontal"},type:"string",enum:["outside-1","outside-2","inside-1","inside-2"]},offset:{type:"object",title:"Offset",display:{type:"group"},properties:{x:{type:"number",label:"X",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}},y:{type:"number",label:"Y",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}}}},scale:{type:"number",title:"scale",min:10,max:400,display:{type:"range-control"}},colors:{display:{type:"settings-color-picker",format:"multiple"},title:"color",type:"array",items:{type:"string"}},hover:{title:"hover",type:"string",display:{type:"settings-color-picker",format:"single"}}}},imageCaption:{title:"Caption",icon:"text-icon",tooltip:"Caption",type:"object",properties:{isActive:{type:"boolean",display:{type:"setting-toggle"}},alignment:{type:"string",display:{type:"align-grid"},enum:["top-left","top-center","top-right","middle-left","middle-center","middle-right","bottom-left","bottom-center","bottom-right"]},offset:{type:"object",title:"Offset",display:{type:"group"},properties:{x:{type:"number",label:"X",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}},y:{type:"number",label:"Y",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}}}},linkColor:{title:"Link",type:"string",display:{type:"settings-color-picker",format:"single"}},linkHoverColor:{title:"Link Hov",type:"string",display:{type:"settings-color-picker",format:"single"}}}}},default:{triggers:{triggersList:{click:!1,drag:!0},autoPlay:null},controls:{isActive:!0,arrowsImgUrl:null,offset:{x:0,y:0},scale:100,color:"#000000",hover:"#cccccc",show:"always"},transition:{type:"slide",duration:"500ms",backgroundColor:null},pagination:{isActive:!0,scale:50,position:"outside-1",offset:{x:0,y:0},colors:["#cccccc","#cccccc","#000000"],hover:"#cccccc"},direction:"horiz",imageCaption:{offset:{x:0,y:0},isActive:!0,alignment:"middle-center",linkColor:"#cccccc",linkHoverColor:"#cccccc"}},displayRules:[{if:{name:"direction",value:"vert"},then:{name:"properties.pagination.properties.position.display.direction",value:"vertical"}},{if:{name:"transition.type",value:"fade in"},then:{name:"properties.transition.properties.backgroundColor.display.visible",value:!0}}]},content:{type:"array",settings:{addItemFromFileExplorer:!0},items:{type:"object",properties:{image:{type:"object",label:"Image",display:{type:"media-input"},properties:{url:{type:"string"},name:{type:"string"},objectFit:{type:"string",enum:["cover","contain"]}},required:["url","name"]},imageCaption:{placeholder:"Add Caption...",label:"Description",display:{type:"rich-text"}}},required:["image"]},default:[{image:{objectFit:"cover",url:"https://cdn.cntrl.site/component-assets/Control-slider-default-picture-1.png",name:"Slider-1.png"},imageCaption:[{type:"paragraph",children:[{text:""}]}]},{image:{objectFit:"cover",url:"https://cdn.cntrl.site/component-assets/Control-slider-default-picture-2.png",name:"Slider-2.png"},imageCaption:[{type:"paragraph",children:[{text:""}]}]},{image:{objectFit:"cover",url:"https://cdn.cntrl.site/component-assets/Control-slider-default-picture-3.png",name:"Slider-3.png"},imageCaption:[{type:"paragraph",children:[{text:""}]}]}]},styles:{type:"object",properties:{imageCaption:{dataName:"caption",type:"object",properties:{fontSettings:{type:"object",display:{type:"font-settings"},properties:{fontFamily:{type:"string"},fontWeight:{type:"number"},fontStyle:{type:"string"}}},widthSettings:{display:{type:"text-width-control"},type:"object",properties:{width:{type:"number"},sizing:{type:"string",enum:["auto","manual"]}}},fontSizeLineHeight:{type:"object",display:{type:"font-size-line-height"},properties:{fontSize:{type:"number"},lineHeight:{type:"number"}}},letterSpacing:{display:{type:"letter-spacing-input"},type:"number"},wordSpacing:{display:{type:"word-spacing-input"},type:"number"},textAlign:{display:{type:"text-align-control"},type:"string",enum:["left","center","right","justify"]},textAppearance:{display:{type:"text-appearance"},properties:{textTransform:{type:"string",enum:["none","uppercase","lowercase","capitalize"]},textDecoration:{type:"string",enum:["none","underline"]},fontVariant:{type:"string",enum:["normal","small-caps"]}}},color:{display:{type:"style-panel-color-picker"},type:"string"}}}},default:{imageCaption:{widthSettings:{width:.13,sizing:"auto"},fontSettings:{fontFamily:"Arial",fontWeight:400,fontStyle:"normal"},fontSizeLineHeight:{fontSize:.02,lineHeight:.02},letterSpacing:0,wordSpacing:0,textAlign:"left",textAppearance:{textTransform:"none",textDecoration:"none",fontVariant:"normal"},color:"#000000"}}}},required:["settings","content","styles"]}},xa="ImageRevealSlider-module__imageRevealSlider___UE5Ob",Ca="ImageRevealSlider-module__image___Qjt-e",$a="ImageRevealSlider-module__link___N-iLG",_a="ImageRevealSlider-module__cursor___2U03d",le={imageRevealSlider:xa,image:Ca,link:$a,cursor:_a};function fo(t,e,n){for(const o of n){const r=new Image;r.src=o.url;const a=o.width?Number.parseFloat(o.width):r.naturalWidth,i=r.naturalHeight/r.naturalWidth*a,c=a/2,l=i/2;if(t>=o.x-c&&t<=o.x+c&&e>=o.y-l&&e<=o.y+l)return!0}return!1}function vn(t){return new Promise(e=>{const n=new Image;n.src=t,n.onload=()=>{e({width:n.naturalWidth,height:n.naturalHeight})}})}async function wa(t,e,n,o){let r,a;if(e==="custom"){r=n;const i=await vn(t);a=i.height/i.width*r}else if(e==="random"){r=Math.random()*(o.max-o.min)+o.min;const i=await vn(t);a=i.height/i.width*r}else{const i=await vn(t);r=i.width,a=i.height}return{width:r,height:a,finalWidth:`${r}px`}}function Ta({settings:t,content:e,isEditor:n}){const[o,r]=j.useState(null),[a,i]=j.useState([]),[c,l]=j.useState(0),p=j.useRef(0),[s,w]=j.useState({x:0,y:0}),[v,m]=j.useState(1),[u,d]=j.useState("none"),C=j.useRef({x:0,y:0}),[b,f]=j.useState(!1),{sizeType:$,imageWidth:M,randomRangeImageWidth:P}=t.imageSize,{revealPosition:T,visible:h}=t.position,{cursorType:L,target:R,defaultCursorScale:W,defaultCursor:k,hoverCursorScale:B,hoverCursor:O}=t.cursor;j.useEffect(()=>{if(!o)return;const g=(_,y)=>{const V=o.getBoundingClientRect(),X=_-V.left,rt=y-V.top;if(w({x:X,y:rt}),L==="system"){d("none"),m(1);return}const Q=X,ut=rt,E=document.elementFromPoint(V.left+Q,V.top+ut);if(E&&E.closest("a")){d("none"),m(1);return}const K=fo(Q,ut,a)||R==="area"?{img:O??"none",scale:B}:{img:k??"none",scale:W};d(K.img),m(K.scale)},A=_=>{_.stopPropagation(),C.current={x:_.clientX,y:_.clientY},g(_.clientX,_.clientY)},I=()=>{b&&g(C.current.x,C.current.y)};return o.addEventListener("mousemove",A),window.addEventListener("scroll",I,!0),()=>{o.removeEventListener("mousemove",A),window.removeEventListener("scroll",I,!0)}},[o,b,s,L,R,O,k,B,W,a]),j.useEffect(()=>{b||(d("none"),m(0))},[b]);const U=async(g,A,I,_={})=>{const{width:y,height:V,finalWidth:X}=await wa(g.image.url,$,M,P);let rt=0,Q=0;T==="same"?(rt=A/2,Q=I/2):(rt=_.x??Math.random()*A,Q=_.y??Math.random()*I);const ut=Math.min(Math.max(rt,y/2),A-y/2),E=Math.min(Math.max(Q,V/2),I-V/2);return{id:p.current++,url:g.image.url,link:g.link,name:g.image.name,x:ut,y:E,width:X}};j.useEffect(()=>{if(!o||e.length===0)return;const g=o.getBoundingClientRect(),A=g.width,I=g.height,_=[];(async()=>{const V=e[0],X=await U(V,A,I);_.push(X),i(_),l(1)})()},[$,M,P,T,o]),j.useEffect(()=>{h==="last One"&&i(g=>g.length>0?[g[g.length-1]]:[])},[h]);const D=async g=>{if(!o)return;const A=o.getBoundingClientRect(),I=g.clientX-A.left,_=g.clientY-A.top;if(R==="image"&&!fo(I,_,a))return;let y=0,V=0;T==="on Click"?(y=I,V=_):T==="same"?(y=A.width/2,V=A.height/2):(y=Math.random()*A.width,V=Math.random()*A.height);const X=e[c],rt=await U(X,A.width,A.height,{x:y,y:V});i(Q=>h==="all"?[...Q,rt]:[rt]),l(Q=>Q>=e.length-1?0:Q+1)};return x.jsxs("div",{ref:r,onClick:D,onMouseEnter:()=>f(!0),onMouseLeave:()=>f(!1),className:le.imageRevealSlider,style:{cursor:u==="none"?"default":"none"},children:[a.map(g=>x.jsx("div",{className:le.wrapper,style:{top:`${g.y}px`,left:`${g.x}px`,position:"absolute",transform:"translate(-50%, -50%)",width:g.width??"auto",height:"auto",cursor:u==="none"?"default":"none"},children:R==="area"&&g.link?x.jsx("a",{href:g.link,target:"_blank",className:le.link,children:x.jsx("img",{src:g.url,alt:g.name,className:le.image},g.id)}):x.jsx("img",{src:g.url,alt:g.name,className:le.image},g.id)},g.id)),b&&x.jsx("div",{className:le.cursor,style:{left:`${s.x}px`,top:`${s.y}px`,transform:`translate(-50%, -50%) scale(${v})`,backgroundImage:`url('${u}')`,backgroundSize:"cover",backgroundPosition:"center",position:"absolute",pointerEvents:"none"}})]})}const Ea={element:Ta,id:"control-image-reveal",name:"Click Gallery",preview:{type:"image",url:"https://cdn.cntrl.site/component-assets/clickGalleryImg.png"},defaultSize:{width:"100%",height:"100%"},assetsPaths:{content:[{path:"image.url",placeholderEnabled:!0}],parameters:[{path:"settings.cursor.defaultCursor"},{path:"settings.cursor.hoverCursor"}]},fontSettingsPaths:{content:[],parameters:[]},schema:{type:"object",properties:{settings:{type:"object",display:{type:"settings-block"},properties:{imageSize:{title:"IMG SIZE",icon:"size",tooltip:"IMG SIZE",type:"object",properties:{sizeType:{type:"string",display:{type:"ratio-group"},enum:["as Is","custom","random"]},imageWidth:{type:"number",label:"W",display:{type:"numeric-input",visible:!1}},randomRangeImageWidth:{type:"object",display:{type:"random-range-controls",visible:!1},properties:{min:{type:"number"},max:{type:"number"}}}}},cursor:{title:"cursor",icon:"cursor",tooltip:"cursor",type:"object",properties:{cursorType:{type:"string",display:{type:"ratio-group"},enum:["system","custom"]},target:{type:"string",title:"Target",display:{type:"ratio-group"},enum:["area","image"]},defaultCursor:{type:["string","null"],title:"Default",display:{type:"settings-image-input",visible:!1}},defaultCursorScale:{type:"number",title:"Scale",min:1,max:5,step:.1,display:{type:"range-control",visible:!1}},hoverCursor:{type:["string","null"],title:"Hover",display:{type:"settings-image-input",visible:!1}},hoverCursorScale:{type:"number",title:"Scale",min:1,max:5,step:.1,display:{type:"range-control",visible:!1}}}},position:{title:"position",icon:"transition",tooltip:"Position",type:"object",properties:{revealPosition:{type:"string",display:{type:"ratio-group"},enum:["random","same","on Click"]},visible:{type:"string",title:"Visible",display:{type:"ratio-group"},enum:["all","last One"]}}}},default:{imageSize:{sizeType:"custom",imageWidth:500,randomRangeImageWidth:{min:100,max:1e3}},cursor:{cursorType:"system",target:"area",defaultCursor:null,defaultCursorScale:2,hoverCursor:null,hoverCursorScale:2},position:{revealPosition:"random",visible:"all"}},displayRules:[{if:{name:"imageSize.sizeType",value:"custom"},then:{name:"properties.imageSize.properties.imageWidth.display.visible",value:!0}},{if:{name:"imageSize.sizeType",value:"random"},then:{name:"properties.imageSize.properties.randomRangeImageWidth.display.visible",value:!0}},{if:[{name:"cursor.target",value:"image"},{name:"cursor.cursorType",value:"custom"}],then:{name:"properties.cursor.properties.defaultCursor.display.visible",value:!0}},{if:[{name:"cursor.target",value:"image"},{name:"cursor.cursorType",value:"custom"},{name:"cursor.defaultCursor",value:null,isNotEqual:!0}],then:{name:"properties.cursor.properties.defaultCursorScale.display.visible",value:!0}},{if:{name:"cursor.cursorType",value:"custom"},then:{name:"properties.cursor.properties.hoverCursor.display.visible",value:!0}},{if:[{name:"cursor.cursorType",value:"custom"},{name:"cursor.hoverCursor",value:null,isNotEqual:!0}],then:{name:"properties.cursor.properties.hoverCursorScale.display.visible",value:!0}}]},content:{type:"array",settings:{addItemFromFileExplorer:!0},items:{type:"object",properties:{image:{type:"object",label:"Image",display:{isObjectFitEditable:!1,type:"media-input"},properties:{url:{type:"string"},name:{type:"string"},objectFit:{type:"string",enum:["cover","contain"]}},required:["url","name"]},link:{label:"URL",placeholder:"Enter link...",display:{type:"text-input"}}},required:["image"]},default:[{image:{objectFit:"cover",url:"https://cdn.cntrl.site/projects/01JJKT02AWY2FGN2QJ7A173RNZ/articles-assets/01K7ERQK9211QXBE9W284ZNKB8.png",name:"Slider-1.png"},link:""},{image:{objectFit:"cover",url:"https://cdn.cntrl.site/projects/01JJKT02AWY2FGN2QJ7A173RNZ/articles-assets/01K7ERQMFT72JD18WKP0Q2DVAT.png",name:"Slider-2.png"},link:""},{image:{objectFit:"cover",url:"https://cdn.cntrl.site/projects/01JJKT02AWY2FGN2QJ7A173RNZ/articles-assets/01K7ERQNEVRXPSRX5K1YTMJQY9.png",name:"Slider-3.png"},link:""},{image:{objectFit:"cover",url:"https://cdn.cntrl.site/projects/01JJKT02AWY2FGN2QJ7A173RNZ/articles-assets/01K7ERQP84JKRDT7WNWDQZR4Y9.png",name:"Slider-4.png"},link:""}]}}}},La="LightBox-module__hidden___9s-9x",Aa="LightBox-module__heroImage___sTxNF",Ia="LightBox-module__background___rm9ml",ka="LightBox-module__editor___4ACaY",Fa="LightBox-module__contentStyle___Bgnsq",Ra="LightBox-module__imageStyle___tLIlB",Ba="LightBox-module__imgWrapper___LuFUp",Va="LightBox-module__contain___8-yaS",Oa="LightBox-module__cover___hNvOG",Pa="LightBox-module__caption___b6L2I",Na="LightBox-module__captionTextInner___rCGNH",Wa="LightBox-module__lightboxSplide___XFuWC",za="LightBox-module__arrow___iz38X",ja="LightBox-module__arrowVertical___Zfz81",Ma="LightBox-module__nextArrow___zkAQN",Ha="LightBox-module__arrowInner___p48sW",Da="LightBox-module__arrowIcon___3VaFf",Ua="LightBox-module__arrowImg___pNV88",Ya="LightBox-module__mirror___pjeXc",Ga="LightBox-module__thumbsWrapper___GB-nU",qa="LightBox-module__thumbsContainerVertical___wttk5",Xa="LightBox-module__thumbsContainer___osSma",Ka="LightBox-module__thumbsAlignStart___MO6tY",Ja="LightBox-module__thumbsAlignCenter___Q4sUx",Za="LightBox-module__thumbsAlignEnd___p4y9R",Qa="LightBox-module__thumbItem___HvnF3",tl="LightBox-module__closeButton___g2khP",el="LightBox-module__fadeIn___0m5GW",nl="LightBox-module__slideInLeft___gPYwC",ol="LightBox-module__slideInRight___S-pPp",rl="LightBox-module__slideInTop___DFdAj",il="LightBox-module__slideInBottom___m27kZ",al="LightBox-module__fadeOut___55qBR",ll="LightBox-module__slideOutLeft___NvU7P",sl="LightBox-module__slideOutRight___SK7eC",cl="LightBox-module__slideOutTop___Vgg0z",ul="LightBox-module__slideOutBottom___nJ0Ef",pl="LightBox-module__scaleSlide___vZriG",N={hidden:La,heroImage:Aa,background:Ia,editor:ka,contentStyle:Fa,imageStyle:Ra,imgWrapper:Ba,contain:Va,cover:Oa,caption:Pa,captionTextInner:Na,lightboxSplide:Wa,arrow:za,arrowVertical:ja,nextArrow:Ma,arrowInner:Ha,arrowIcon:Da,arrowImg:Ua,mirror:Ya,thumbsWrapper:Ga,thumbsContainerVertical:qa,thumbsContainer:Xa,thumbsAlignStart:Ka,thumbsAlignCenter:Ja,thumbsAlignEnd:Za,thumbItem:Qa,closeButton:tl,fadeIn:el,slideInLeft:nl,slideInRight:ol,slideInTop:rl,slideInBottom:il,fadeOut:al,slideOutLeft:ll,slideOutRight:sl,slideOutTop:cl,slideOutBottom:ul,scaleSlide:pl},je=(t,e,n)=>{const o={},[r,a]=t.split("-");return r==="top"?(o.top="0",o.bottom="auto"):r==="middle"?(o.top="50%",o.bottom="auto"):r==="bottom"&&(o.top="auto",o.bottom="0"),a==="left"?(o.left="0",o.right="auto"):a==="center"?(o.left="50%",o.right="auto"):a==="right"&&(o.left="auto",o.right="0"),r==="middle"&&a==="center"?o.transform=`translate(calc(-50% + ${F.scalingValue(e.x,n)}), calc(-50% + ${F.scalingValue(e.y,n)}))`:r==="middle"?o.transform=`translate(${F.scalingValue(e.x,n)}, calc(-50% + ${F.scalingValue(e.y,n)}))`:a==="center"?o.transform=`translate(calc(-50% + ${F.scalingValue(e.x,n)}), ${F.scalingValue(e.y,n)})`:o.transform=`translate(${F.scalingValue(e.x,n)}, ${F.scalingValue(e.y,n)})`,o};function ir(t){const e=window.getComputedStyle(t);return{top:parseFloat(e.paddingTop)||0,right:parseFloat(e.paddingRight)||0,bottom:parseFloat(e.paddingBottom)||0,left:parseFloat(e.paddingLeft)||0}}function ho(t){const e=t.getBoundingClientRect(),n=ir(t),o=Math.max(0,e.width-n.left-n.right),r=Math.max(0,e.height-n.top-n.bottom),a=t.naturalWidth,i=t.naturalHeight,c=o/r,l=a/i;let p,s;l>c?(p=o,s=o/l):(s=r,p=r*l);const w=e.left+n.left,v=e.top+n.top,m=(o-p)/2+w,u=(r-s)/2+v;return{x:m,y:u,width:p,height:s}}function vo(t){const e=t.getBoundingClientRect(),n=ir(t);return{left:e.left+n.left,right:e.right-n.right,top:e.top+n.top,bottom:e.bottom-n.bottom}}function yo(t){const e=t.match(/rgba?\(([^)]+)\)/);if(e){const o=e[1].split(",").map(r=>parseFloat(r.trim()));return o.length===4?o[3]:1}const n=t.match(/^#([0-9a-fA-F]{8})$/);if(n){const o=n[1].substring(6,8);return parseInt(o,16)/255}return t.match(/^#([0-9a-fA-F]{3}|[0-9a-fA-F]{6})$/),1}function dl(t,e){const n=(()=>{if(t==="fade in")return N.fadeIn;if(t==="slide in"||t==="mix")switch(e){case"left":return N.slideInLeft;case"right":return N.slideInRight;case"top":return N.slideInTop;case"bottom":return N.slideInBottom;default:return N.slideInRight}return N.fadeIn})(),o=(()=>{if(t==="fade in"||t==="mix")return N.fadeIn;if(t==="slide in")switch(e){case"left":return N.slideInLeft;case"right":return N.slideInRight;case"top":return N.slideInTop;case"bottom":return N.slideInBottom;default:return N.slideInRight}return N.fadeIn})(),r=(()=>{if(t==="fade in"||t==="mix")return N.fadeOut;if(t==="slide in")switch(e){case"left":return N.slideOutLeft;case"right":return N.slideOutRight;case"top":return N.slideOutTop;case"bottom":return N.slideOutBottom;default:return N.slideOutRight}return N.fadeOut})(),a=(()=>{if(t==="fade in")return N.fadeOut;if(t==="slide in"||t==="mix")switch(e){case"left":return N.slideOutLeft;case"right":return N.slideOutRight;case"top":return N.slideOutTop;case"bottom":return N.slideOutBottom;default:return N.slideOutRight}return N.fadeOut})();return{appearClass:n,backdropAppearClass:o,backdropDisappearClass:r,disappearClass:a}}const gl=({settings:t,content:e,styles:n,portalId:o,activeEvent:r,isEditor:a})=>{const[i,c]=j.useState(!1),{url:l}=t.thumbnailBlock.cover;return j.useEffect(()=>{r==="close"&&c(!1),r==="open"&&c(!0)},[r]),x.jsxs(x.Fragment,{children:[x.jsx("img",{src:l,alt:"Cover",className:N.heroImage,onClick:()=>c(!0)}),x.jsx(ml,{isOpen:i,onClose:()=>c(!1),content:e,settings:t,lightboxStyles:n,portalId:o,isEditor:a})]})},ml=({isOpen:t,onClose:e,content:n,lightboxStyles:o,settings:r,portalId:a,isEditor:i,metadata:c})=>{var z;const[l,p]=j.useState(0),[s,w]=j.useState(0),[v,m]=j.useState(!1),[u,d]=j.useState(!1),[C,b]=j.useState({}),f=j.useRef(null),$=j.useRef(null),M=j.useRef(null),P=j.useRef(!1),T=j.useRef(null),h=j.useRef(null),L=j.useRef(null),R=j.useRef(null),W=j.useRef(!1),k=j.useRef(null),[B,O]=j.useState(!1),{appear:U,triggers:D,slider:g,thumbnail:A,controls:I,area:_,caption:y,layout:V}=r.lightboxBlock,{appearClass:X,backdropAppearClass:rt,backdropDisappearClass:Q,disappearClass:ut}=dl(U.type,U.direction),E=(c==null?void 0:c.itemId)??null;j.useEffect(()=>{const S=()=>{setTimeout(()=>{var G,J;(J=(G=f.current)==null?void 0:G.splide)==null||J.refresh()},16)},H=()=>{w(G=>G+1)};return window.addEventListener("ArticleEditor.Layout:change",S),window.addEventListener("ArticleEditor.ComponentContent:change",H),()=>{window.removeEventListener("ArticleEditor.Layout:change",S),window.removeEventListener("ArticleEditor.ComponentContent:change",H)}},[]),j.useEffect(()=>{if(!t||!A.isActive){O(!1);return}const S=k.current;if(!S)return;const H=()=>{g.direction==="horiz"?O(S.scrollWidth>S.clientWidth):O(S.scrollHeight>S.clientHeight)};H();const G=new ResizeObserver(H);return G.observe(S),()=>G.disconnect()},[t,A.isActive,n.length,C,g.direction]);const K=j.useCallback(()=>{const S=window.matchMedia("(max-width: 768px)").matches,H=yo(_.color);S&&!i&&H>.9&&(document.body.style.backgroundColor=""),m(!0),P.current=!0;const G=J=>{J.target===T.current&&J.animationName&&(T.current&&h.current&&T.current.removeEventListener("animationend",h.current),h.current=null,P.current&&(P.current=!1,e()),m(!1))};T.current&&(h.current=G,T.current.addEventListener("animationend",G))},[e,_.color,i]),ht=(S,H,G)=>{var J,ot;if(S){if(D.type==="click"&&D.switch==="image")D.repeat==="close"&&l===n.length-1?K():(J=f.current)==null||J.go("+1");else if(D.type==="click"&&D.switch==="50/50"){const tt=S.getBoundingClientRect(),q=H-tt.left,nt=G-tt.top,yt=tt.width,lt=tt.height;let pt;g.direction==="horiz"?pt=q<yt/2?"-1":"+1":pt=nt<lt/2?"-1":"+1",(ot=f.current)==null||ot.go(pt)}}},it=S=>{if(W.current){W.current=!1;return}const H=n[l],G=(H==null?void 0:H.image.objectFit)==="cover";let J,ot;if("changedTouches"in S&&S.changedTouches.length>0)J=S.changedTouches[0].clientX,ot=S.changedTouches[0].clientY;else if("clientX"in S)J=S.clientX,ot=S.clientY;else return;let tt;if(G&&M.current){const q=vo(M.current);tt=J>=q.left&&J<=q.right&&ot>=q.top&&ot<=q.bottom}else{const q=M.current?ho(M.current):null;if(!q){S.target===S.currentTarget&&K();return}tt=J>=q.x&&J<=q.x+q.width&&ot>=q.y&&ot<=q.y+q.height}tt?ht(M.current,J,ot):K()},mt=S=>{const H=S.target;(H.classList.contains(N.thumbsWrapper)||H.classList.contains(N.thumbsContainer))&&it(S)};j.useEffect(()=>{if(!t)return;const S=H=>{var G,J;if(H.key==="Escape"){K();return}if(H.key==="ArrowRight"){p(ot=>(ot+1)%Math.max(n.length,1)),(G=f.current)==null||G.go("+1");return}H.key==="ArrowLeft"&&(p(ot=>(ot-1+Math.max(n.length,1))%Math.max(n.length,1)),(J=f.current)==null||J.go("-1"))};return window.addEventListener("keydown",S),()=>{window.removeEventListener("keydown",S)}},[t,K,n.length]),j.useEffect(()=>{if(t){if(p(0),w(H=>H+1),P.current=!1,m(!1),d(!1),b({}),!E)return;const S=new CustomEvent("page-overlay",{detail:{itemId:E}});window.dispatchEvent(S)}return()=>{T.current&&h.current&&(T.current.removeEventListener("animationend",h.current),h.current=null),d(!1)}},[t,E]),j.useEffect(()=>{$.current!==null&&$.current!==g.type&&w(S=>S+1),$.current=g.type},[g.type]),j.useEffect(()=>{if(!t)return;const S=document.body.style.overflow,H=window.matchMedia("(max-width: 768px)").matches,G=yo(_.color);document.body.style.overflow="hidden",d(!1);const J=tt=>{tt.target===T.current&&!P.current&&tt.animationName&&(H&&!i&&G>.9&&(document.body.style.backgroundColor=_.color),d(!0),T.current&&L.current&&T.current.removeEventListener("animationend",L.current),L.current=null)};T.current&&(L.current=J,T.current.addEventListener("animationend",J));const ot=tt=>{const q=tt.target;q&&(q.closest(`.${N.thumbsWrapper}`)||q.closest(`.${N.thumbsContainer}`))||g.type!=="slide"&&tt.preventDefault()};return document.addEventListener("touchmove",ot,{passive:!1}),()=>{document.body.style.overflow=S,document.removeEventListener("touchmove",ot),T.current&&L.current&&(T.current.removeEventListener("animationend",L.current),L.current=null),d(!1)}},[t,i,_.color,g.type]),j.useEffect(()=>{if(!t)return;const S=H=>{var J,ot;if(P.current){H.stopPropagation();return}if(W.current){W.current=!1;return}const G=H.target;if(!(G&&(G.closest(`.${N.thumbsContainer}`)||G.closest(`.${N.thumbItem}`)))){if(g.type==="slide"&&D.type==="drag"&&((ot=(J=f.current)==null?void 0:J.splide)!=null&&ot.root)){const tt=f.current.splide.root;if(G&&(tt.contains(G)||tt===G))return}if(H.touches.length===0&&H.changedTouches.length>0){const tt=n[l],q=(tt==null?void 0:tt.image.objectFit)==="cover",nt=H.changedTouches[0];let yt;if(q&&M.current){const lt=vo(M.current);yt=nt.clientX>=lt.left&&nt.clientX<=lt.right&&nt.clientY>=lt.top&&nt.clientY<=lt.bottom}else{const lt=M.current?ho(M.current):null;if(!lt)return;yt=nt.clientX>=lt.x&&nt.clientX<=lt.x+lt.width&&nt.clientY>=lt.y&&nt.clientY<=lt.y+lt.height}if(!yt){H.stopPropagation(),P.current=!0;const lt=pt=>{pt.stopPropagation(),pt.preventDefault(),document.removeEventListener("click",lt,!0)};document.addEventListener("click",lt,!0),K()}}}};return document.addEventListener("touchend",S,{passive:!0}),()=>{document.removeEventListener("touchend",S)}},[t,K,l,n]);const bt=(g.type==="scale"||g.type==="fade")&&g.direction==="vert"&&D.type==="drag";j.useEffect(()=>{var pt,kt;if(!t||!bt||!((kt=(pt=f.current)==null?void 0:pt.splide)!=null&&kt.root))return;const S=f.current.splide.root,H=30,G=(et,st)=>{if(R.current){const Ct=Math.abs(et-R.current.x),Ht=Math.abs(st-R.current.y);(Ct>0||Ht>0)&&(W.current=!0)}},J=et=>{R.current&&(et.preventDefault(),G(et.clientX,et.clientY))},ot=et=>{R.current&&et.touches.length>0&&(et.preventDefault(),G(et.touches[0].clientX,et.touches[0].clientY))},tt=(et,st)=>{if(!R.current||!f.current){R.current=null;return}const Ct=Math.abs(et-R.current.x),Ht=Math.abs(st-R.current.y);Ht>H&&Ht>Ct&&f.current.go(st<R.current.y?"+1":"-1"),R.current=null},q=et=>{R.current&&tt(et.clientX,et.clientY),document.removeEventListener("pointerup",q),document.removeEventListener("pointercancel",q),document.removeEventListener("pointermove",J)},nt=et=>{if(R.current){if(et.changedTouches.length>0){const st=et.changedTouches[0];tt(st.clientX,st.clientY)}document.removeEventListener("touchend",nt),document.removeEventListener("touchcancel",nt),document.removeEventListener("touchmove",ot)}},yt=et=>{R.current={x:et.clientX,y:et.clientY},W.current=!1,document.addEventListener("pointermove",J,{passive:!1}),document.addEventListener("pointerup",q),document.addEventListener("pointercancel",q)},lt=et=>{et.touches.length>0&&(R.current={x:et.touches[0].clientX,y:et.touches[0].clientY},W.current=!1,document.addEventListener("touchmove",ot,{passive:!1}),document.addEventListener("touchend",nt),document.addEventListener("touchcancel",nt))};return S.addEventListener("pointerdown",yt),S.addEventListener("touchstart",lt),()=>{S.removeEventListener("pointerdown",yt),S.removeEventListener("touchstart",lt),document.removeEventListener("pointermove",J),document.removeEventListener("pointerup",q),document.removeEventListener("pointercancel",q),document.removeEventListener("touchmove",ot),document.removeEventListener("touchend",nt),document.removeEventListener("touchcancel",nt),R.current=null,W.current=!1}},[t,bt,s]);const Mt={backgroundColor:_.color,backdropFilter:`blur(${_.blur}px)`,animationDuration:`${parseInt(U.duration)}ms`,animationTimingFunction:"ease",animationFillMode:"both"};return typeof document>"u"||!document.getElementById(a)?null:pr.createPortal(x.jsxs(x.Fragment,{children:[x.jsx("div",{ref:i?null:T,className:dt(N.background,v?Q:rt,{[N.editor]:i},{[N.hidden]:!t}),style:{...Mt,...u&&!i&&!v?{position:"absolute"}:{}}}),x.jsxs("div",{ref:i?T:null,className:dt(N.contentStyle,v?ut:X,{[N.editor]:i},{[N.hidden]:!t}),style:{animationDuration:`${parseInt(U.duration)}ms`,animationTimingFunction:"ease",animationFillMode:"both"},children:[x.jsx(nr,{onMove:S=>p(S.index),ref:f,className:N.lightboxSplide,options:{arrows:!1,speed:g.duration?parseInt(g.duration):500,direction:g.direction==="horiz"||g.type==="fade"||g.type==="scale"?"ltr":"ttb",pagination:!1,drag:D.type==="drag"&&!bt,perPage:1,width:"100%",height:"100%",type:g.type==="fade"||g.type==="scale"?"fade":"loop",padding:0,rewind:D.repeat!=="close",start:0},style:{"--splide-speed":g.duration},children:n.map((S,H)=>{const G=je(V.position,V.offset,i),J=`${F.scalingValue(V.padding.top,i)} ${F.scalingValue(V.padding.right,i)} ${F.scalingValue(V.padding.bottom,i)} ${F.scalingValue(V.padding.left,i)}`,ot=g.type==="scale"?(()=>{const{transform:tt,...q}=G;return{...q,position:"absolute",padding:J,boxSizing:"border-box","--position-transform":tt||"none"}})():{...G,position:"absolute",padding:J,boxSizing:"border-box"};return x.jsx(or,{children:x.jsx("div",{className:N.imgWrapper,onClick:it,children:x.jsx("img",{ref:H===l?M:null,className:dt(N.imageStyle,{[N.contain]:S.image.objectFit==="contain",[N.cover]:S.image.objectFit==="cover",[N.scaleSlide]:g.type==="scale"}),src:S.image.url,alt:S.image.name??"",style:{...ot,pointerEvents:S.image.objectFit==="contain"?"none":"auto"}})})},H)})},s),I.isActive&&x.jsxs(x.Fragment,{children:[x.jsx("div",{className:dt(N.arrow,{[N.arrowVertical]:g.direction==="vert"}),style:{color:I.color,"--arrow-hover-color":I.hover},children:x.jsxs("button",{className:N.arrowInner,style:{transform:`translate(${F.scalingValue(I.offset.x,i)}, ${F.scalingValue(I.offset.y*(g.direction==="horiz"?1:-1),i)}) scale(${I.scale}) rotate(${g.direction==="horiz"?"0deg":"90deg"})`},onClick:()=>{var S;return(S=f.current)==null?void 0:S.go("-1")},"aria-label":"Previous",children:[I.arrowsImgUrl&&x.jsx(ge,{url:I.arrowsImgUrl,fill:I.color,hoverFill:I.hover,className:dt(N.arrowImg,N.mirror)}),!I.arrowsImgUrl&&x.jsx(bo,{color:I.color,className:dt(N.arrowIcon,N.arrowImg,N.mirror)})]})}),x.jsx("div",{className:dt(N.arrow,N.nextArrow,{[N.arrowVertical]:g.direction==="vert"}),style:{color:I.color,"--arrow-hover-color":I.hover},children:x.jsxs("button",{className:N.arrowInner,style:{transform:`translate(${F.scalingValue(I.offset.x*(g.direction==="horiz"?-1:1),i)}, ${F.scalingValue(I.offset.y,i)}) scale(${I.scale}) rotate(${g.direction==="horiz"?"0deg":"90deg"})`},onClick:()=>{var S;return(S=f.current)==null?void 0:S.go("+1")},"aria-label":"Next",children:[I.arrowsImgUrl&&x.jsx(ge,{url:I.arrowsImgUrl,fill:I.color,hoverFill:I.hover,className:N.arrowImg}),!I.arrowsImgUrl&&x.jsx(bo,{color:I.color,className:dt(N.arrowIcon,N.arrowImg)})]})})]}),_.closeIconUrl&&(()=>{const S=je(_.closeIconAlign,_.closeIconOffset,i),H=`scale(${_.closeIconScale})`,G=S.transform?`${S.transform} ${H}`:H;return x.jsx("button",{className:N.closeButton,style:{...S,transform:G},onClick:K,"aria-label":"Close lightbox",children:x.jsx(ge,{url:_.closeIconUrl,fill:_.closeIconColor??"#000000",hoverFill:_.closeIconHover??"#cccccc"})})})(),y&&y.isActive&&o.imageCaption&&((z=n[l])==null?void 0:z.imageCaption)&&(()=>{const{widthSettings:S,fontSettings:H,letterSpacing:G,textAlign:J,wordSpacing:ot,fontSizeLineHeight:tt,textAppearance:q,color:nt}=o.imageCaption;return x.jsx("div",{className:N.caption,style:{...je(y.alignment,y.offset,i),fontFamily:H.fontFamily,fontWeight:H.fontWeight,fontStyle:H.fontStyle,width:S.sizing==="auto"?"max-content":F.scalingValue(S.width,i),letterSpacing:F.scalingValue(G,i),wordSpacing:F.scalingValue(ot,i),textAlign:J,fontSize:F.scalingValue(tt.fontSize,i),lineHeight:F.scalingValue(tt.lineHeight,i),textTransform:q.textTransform??"none",textDecoration:q.textDecoration??"none",fontVariant:q.fontVariant??"normal",color:nt},onClick:yt=>yt.stopPropagation(),children:x.jsx("div",{"data-styles":"imageCaption",className:N.captionTextInner,style:{"--link-color":y.linkColor,"--link-hover-color":y.linkHoverColor},children:x.jsx(rr,{content:n[l].imageCaption})})})})(),A.isActive&&(()=>{const[S,H]=A.position.split("-"),G=g.direction==="horiz"?`${S}-left`:A.position,J=je(G,A.offset,i),ot=()=>{if(g.direction==="horiz"){if(H==="left")return"flex-start";if(H==="center")return"center";if(H==="right")return"flex-end"}else{if(S==="top")return"flex-start";if(S==="middle")return"center";if(S==="bottom")return"flex-end"}return"flex-start"};return x.jsx("div",{ref:k,className:N.thumbsWrapper,onClick:tt=>mt(tt),style:{position:i?"absolute":"fixed",...J,...g.direction==="horiz"?{maxWidth:"100vw",width:"100%",overflowX:"auto",overflowY:"hidden"}:{maxHeight:"100vh",overflowY:"auto",overflowX:"hidden"}},children:x.jsx("div",{className:dt(N.thumbsContainer,{[N.thumbsContainerVertical]:g.direction==="vert",[N.thumbsAlignStart]:A.align==="start",[N.thumbsAlignCenter]:A.align==="center",[N.thumbsAlignEnd]:A.align==="end"}),style:{gap:F.scalingValue(A.grid.gap,i),justifyContent:B?"flex-start":ot()},children:n.map((tt,q)=>{const nt=q===l,yt=C[q],pt=A.grid.size*(nt?A.activeState.scale:1),kt=()=>{if(A.fit!=="fit")return{};if(!yt)return g.direction==="horiz"?{height:F.scalingValue(pt,i)}:{width:F.scalingValue(pt,i)};const et=yt.width/yt.height;if(g.direction==="horiz"){const st=pt,Ct=st*et;return{width:F.scalingValue(Ct,i),height:F.scalingValue(st,i)}}else{const st=pt,Ct=st/et;return{width:F.scalingValue(st,i),height:F.scalingValue(Ct,i)}}};return x.jsx("button",{className:N.thumbItem,style:{...g.direction==="horiz"&&A.fit!=="fit"?{height:F.scalingValue(pt,i)}:{},...g.direction==="vert"&&A.fit!=="fit"?{width:F.scalingValue(pt,i)}:{},...A.fit==="cover"?{width:F.scalingValue(pt,i),height:F.scalingValue(pt,i)}:{},...kt(),transition:nt?"all 0.25s ease-out":"none",opacity:nt?A.activeState.opacity/100:A.opacity/100,"--thumb-hover":A.activeState.opacity/100},onClick:et=>{var st;et.stopPropagation(),p(q),(st=f.current)==null||st.go(q)},onMouseEnter:()=>{var et;A.triggers==="hov"&&((et=f.current)==null||et.go(q))},children:x.jsx("img",{src:tt.image.url,alt:tt.image.name??"",onLoad:et=>{const st=et.currentTarget;st.naturalWidth&&st.naturalHeight&&b(Ct=>({...Ct,[q]:{width:st.naturalWidth,height:st.naturalHeight}}))},style:{objectFit:A.fit==="cover"?"cover":"contain",...A.fit==="fit"?{maxWidth:"100%",maxHeight:"100%",objectFit:"contain"}:{},...A.fit==="cover"?{width:"100%",height:"100%"}:{}}})},`${tt.image.name}-${q}`)})})})})()]})]}),document.getElementById(a))};function bo({color:t,className:e}){return x.jsx("svg",{viewBox:"0 0 10 18",className:e,children:x.jsx("g",{id:"Symbols",stroke:"none",strokeWidth:"1",fillRule:"evenodd",children:x.jsx("path",{d:"M-3.70710678,4.29289322 C-3.34662282,3.93240926 -2.77939176,3.90467972 -2.38710056,4.20970461 L-2.29289322,4.29289322 L5,11.585 L12.2928932,4.29289322 C12.6533772,3.93240926 13.2206082,3.90467972 13.6128994,4.20970461 L13.7071068,4.29289322 C14.0675907,4.65337718 14.0953203,5.22060824 13.7902954,5.61289944 L13.7071068,5.70710678 L5.70710678,13.7071068 C5.34662282,14.0675907 4.77939176,14.0953203 4.38710056,13.7902954 L4.29289322,13.7071068 L-3.70710678,5.70710678 C-4.09763107,5.31658249 -4.09763107,4.68341751 -3.70710678,4.29289322 Z",id:"Shape-Copy",fill:t,transform:"translate(5, 9) rotate(-90) translate(-5, -9)"})})})}const fl={element:gl,id:"lightbox",name:"Lightbox",preview:{type:"image",url:"https://cdn.cntrl.site/component-assets/lightboxImg.png"},defaultSize:{width:440,height:550},fontSettingsPaths:{content:[],parameters:[{path:"styles.imageCaption.fontSettings"}]},assetsPaths:{content:[{path:"image.url",placeholderEnabled:!0}],parameters:[{path:"settings.thumbnailBlock.cover.url",placeholderEnabled:!0},{path:"settings.controls.arrowsImgUrl"},{path:"settings.area.closeIconUrl"}]},schema:{type:"object",properties:{settings:{type:"object",properties:{thumbnailBlock:{display:{type:"settings-block",triggerEvent:"close"},type:"object",properties:{cover:{title:"COVER",icon:"cover",tooltip:"Cover Image",type:"object",properties:{url:{type:"string",display:{type:"cover-image-input"}}}}}},lightboxBlock:{display:{type:"settings-block",triggerEvent:"open"},type:"object",properties:{appear:{title:"APPEAR",icon:"transition",tooltip:"Appearance",type:"object",properties:{type:{type:"string",display:{type:"ratio-group"},enum:["slide in","fade in","mix"]},duration:{type:"string",label:"T",display:{type:"step-selector"},enum:["100ms","250ms","500ms","1000ms","1500ms","2000ms"]},direction:{type:"string",title:"From",display:{type:"direction-control"},enum:["top","left","right","bottom"]}}},triggers:{title:"TRIGGERS",icon:"target",tooltip:"Triggers",type:"object",properties:{type:{type:"string",display:{type:"ratio-group"},enum:["click","drag"]},switch:{type:"string",display:{type:"ratio-group"},enum:["image","50/50"]},repeat:{type:"string",title:"Repeat",display:{visible:!1,type:"ratio-group"},enum:["close","loop"]}}},slider:{title:"SLIDER",icon:"horizontal-resize",tooltip:"Slider",type:"object",properties:{type:{type:"string",display:{type:"ratio-group"},enum:["slide","fade","scale"]},direction:{type:"string",display:{type:"ratio-group"},enum:["horiz","vert"]},duration:{type:"string",label:"T",display:{type:"step-selector"},enum:["100ms","250ms","500ms","1000ms","1500ms","2000ms"]}}},thumbnail:{title:"THUMB",icon:"thumbnail",tooltip:"Thumbnail",type:"object",properties:{isActive:{type:"boolean",display:{type:"setting-toggle"}},position:{display:{type:"align-grid"},type:"string",enum:["top-left","top-center","top-right","middle-left","middle-center","middle-right","bottom-left","bottom-center","bottom-right"]},fit:{type:"string",display:{type:"ratio-group"},enum:["cover","fit"]},align:{type:"string",title:"Align",display:{type:"align-group",direction:"horizontal"},enum:["start","center","end"]},triggers:{type:"string",title:"Triggers",display:{type:"ratio-group",direction:"horizontal"},enum:["clk","hov"]},grid:{type:"object",title:"Grid",display:{type:"group"},properties:{size:{type:"number",label:"Box",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}},gap:{type:"number",label:"Gap",scalingEnabled:!0,min:0,display:{type:"numeric-input"}}}},offset:{type:"object",title:"Offset",display:{type:"group"},properties:{x:{type:"number",label:"X",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}},y:{type:"number",label:"Y",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}}}},opacity:{type:"number",title:"Opacity",label:"icon:opacity",min:0,max:100,step:1,display:{type:"numeric-input"}},activeState:{type:"object",title:"ACTIVE",display:{type:"group"},properties:{scale:{type:"number",title:"Scale",min:1,max:5,step:.1,display:{type:"range-control"}},opacity:{type:"number",title:"Opacity",label:"icon:opacity",min:0,max:100,step:1,display:{type:"numeric-input"}}}}}},layout:{title:"LAYOUT",icon:"layout",tooltip:"Layout",type:"object",properties:{position:{display:{type:"align-grid"},type:"string",enum:["top-left","top-center","top-right","middle-left","middle-center","middle-right","bottom-left","bottom-center","bottom-right"]},offset:{type:"object",title:"Offset",display:{type:"group"},properties:{x:{type:"number",label:"X",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}},y:{type:"number",label:"Y",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}}}},padding:{type:"object",title:"Padding",display:{type:"padding-controls"},properties:{top:{min:0,step:1,type:"number"},left:{min:0,step:1,type:"number"},right:{min:0,step:1,type:"number"},bottom:{min:0,step:1,type:"number"}}}}},controls:{title:"CONTROLS",icon:"controls",tooltip:"Controls",type:"object",properties:{isActive:{type:"boolean",display:{type:"setting-toggle"}},arrowsImgUrl:{type:["string","null"],display:{type:"settings-image-input"}},offset:{title:"Offset",type:"object",display:{type:"group"},properties:{x:{type:"number",label:"X",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}},y:{type:"number",label:"Y",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}}}},scale:{type:"number",title:"Scale",min:.5,max:5,step:.1,display:{type:"range-control"}},color:{title:"Color",type:"string",display:{type:"settings-color-picker",format:"single"}},hover:{title:"Hover",type:"string",display:{type:"settings-color-picker",format:"single"}}}},area:{title:"AREA",icon:"area",tooltip:"Area",type:"object",properties:{color:{type:"string",display:{type:"settings-color-picker",format:"single"}},blur:{type:"number",label:"icon:blur",display:{type:"numeric-input"}},closeIconUrl:{type:["string","null"],title:"Close Icon",display:{type:"settings-image-input"}},closeIconAlign:{display:{type:"align-grid",direction:"horizontal"},type:"string",enum:["top-left","top-center","top-right","middle-left","middle-center","middle-right","bottom-left","bottom-center","bottom-right"]},closeIconScale:{type:"number",title:"Scale",min:.5,max:5,step:.1,display:{type:"range-control"}},closeIconOffset:{type:"object",title:"Offset",display:{type:"group"},properties:{x:{type:"number",label:"X",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}},y:{type:"number",label:"Y",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}}}},closeIconColor:{title:"Color",type:"string",display:{type:"settings-color-picker",format:"single"}},closeIconHover:{title:"Hover",type:"string",display:{type:"settings-color-picker",format:"single"}}}},caption:{title:"DESC",icon:"text-icon",tooltip:"Description",type:"object",properties:{isActive:{type:"boolean",display:{type:"setting-toggle"}},alignment:{type:"string",display:{type:"align-grid"},enum:["top-left","top-center","top-right","middle-left","middle-center","middle-right","bottom-left","bottom-center","bottom-right"]},offset:{title:"Offset",type:"object",display:{type:"group"},properties:{x:{type:"number",label:"X",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}},y:{type:"number",label:"Y",scalingEnabled:!0,display:{type:"numeric-input",visible:!0}}}},linkColor:{title:"Link",type:"string",display:{type:"settings-color-picker",format:"single"}},linkHoverColor:{title:"Link Hov",type:"string",display:{type:"settings-color-picker",format:"single"}}}}}}},default:{d:{thumbnailBlock:{cover:{url:"https://cdn.cntrl.site/component-assets/Cover.jpg"}},lightboxBlock:{appear:{type:"slide in",duration:"1000ms",direction:"bottom"},triggers:{type:"click",switch:"image",repeat:"loop"},slider:{type:"slide",direction:"vert",duration:"1000ms"},thumbnail:{isActive:!0,position:"middle-left",fit:"fit",align:"start",triggers:"hov",grid:{size:.05,gap:.01},offset:{x:.01,y:0},opacity:50,activeState:{scale:1,opacity:100}},layout:{position:"middle-center",offset:{x:0,y:0},padding:{top:.06,right:0,bottom:.06,left:0}},controls:{isActive:!1,arrowsImgUrl:null,offset:{x:0,y:0},scale:1,color:"#000000",hover:"#cccccc"},area:{color:"rgba(28,31,34,0.9)",blur:0,closeIconUrl:null,closeIconColor:"#000000",closeIconHover:"#cccccc",closeIconAlign:"top-right",closeIconOffset:{x:0,y:0},closeIconScale:1},caption:{isActive:!0,alignment:"middle-center",offset:{x:0,y:0},linkColor:"#cccccc",linkHoverColor:"#cccccc"}}},m:{thumbnailBlock:{cover:{url:"https://cdn.cntrl.site/component-assets/Cover.jpg"}},lightboxBlock:{appear:{type:"fade in",duration:"500ms",direction:"bottom"},triggers:{type:"click",switch:"image",repeat:"loop"},slider:{type:"slide",direction:"horiz",duration:"1000ms"},thumbnail:{isActive:!0,position:"bottom-center",fit:"fit",align:"start",triggers:"hov",grid:{size:.1,gap:.05},offset:{x:.01,y:-.05},opacity:50,activeState:{scale:1,opacity:100}},layout:{position:"middle-center",offset:{x:0,y:0},padding:{top:.06,right:.05,bottom:.06,left:.05}},controls:{isActive:!1,arrowsImgUrl:null,offset:{x:0,y:0},scale:1,color:"#000000",hover:"#cccccc"},area:{color:"rgba(28,31,34,0.9)",blur:0,closeIconUrl:null,closeIconColor:"#000000",closeIconHover:"#cccccc",closeIconAlign:"top-right",closeIconOffset:{x:0,y:0},closeIconScale:1},caption:{isActive:!0,alignment:"middle-center",offset:{x:0,y:0},hover:"#cccccc"}}},t:{thumbnailBlock:{cover:{url:"https://cdn.cntrl.site/component-assets/Cover.jpg"}},lightboxBlock:{appear:{type:"fade in",duration:"500ms",direction:"bottom"},triggers:{type:"click",switch:"image",repeat:"loop"},slider:{type:"slide",direction:"vert",duration:"1000ms"},thumbnail:{isActive:!0,position:"middle-left",fit:"fit",align:"start",triggers:"hov",grid:{size:.05,gap:.01},offset:{x:.03,y:0},opacity:50,activeState:{scale:1,opacity:100}},layout:{position:"middle-center",offset:{x:0,y:0},padding:{top:.06,right:.1,bottom:.06,left:.1}},controls:{isActive:!1,arrowsImgUrl:null,offset:{x:0,y:0},scale:1,color:"#000000",hover:"#cccccc"},area:{color:"rgba(28,31,34,0.9)",blur:0,closeIconUrl:null,closeIconColor:"#000000",closeIconHover:"#cccccc",closeIconAlign:"top-right",closeIconOffset:{x:0,y:0},closeIconScale:1},caption:{isActive:!0,alignment:"middle-center",offset:{x:0,y:0},hover:"#cccccc"}}}},displayRules:[{if:{name:"lightboxBlock.appear.type",value:"slide in"},then:{name:"properties.lightboxBlock.properties.appear.properties.direction.display.visible",value:!0}},{if:{name:"lightboxBlock.slider.direction",value:"vert"},then:{name:"properties.lightboxBlock.properties.thumbnail.properties.align.display.direction",value:"vertical"}},{if:{name:"lightboxBlock.appear.type",value:"mix"},then:{name:"properties.lightboxBlock.properties.appear.properties.direction.display.visible",value:!0}},{if:{name:"lightboxBlock.appear.type",value:"fade in"},then:{name:"properties.lightboxBlock.properties.appear.properties.direction.display.visible",value:!1}},{if:[{name:"lightboxBlock.triggers.type",value:"click"},{name:"lightboxBlock.triggers.switch",value:"image"}],then:{name:"properties.lightboxBlock.properties.triggers.properties.repeat.display.visible",value:!0}}]},content:{type:"array",settings:{addItemFromFileExplorer:!0},items:{type:"object",properties:{image:{type:"object",label:"Image",display:{type:"media-input"},properties:{url:{type:"string"},name:{type:"string"},objectFit:{type:"string",enum:["cover","contain"]}},required:["url","name"]},imageCaption:{label:"Description",placeholder:"Add Caption...",display:{type:"rich-text"}}},required:["image"]},default:[{image:{objectFit:"contain",url:"https://cdn.cntrl.site/component-assets/2.jpg",name:"Slider-1.png"},imageCaption:[{type:"paragraph",children:[{text:""}]}]},{image:{objectFit:"contain",url:"https://cdn.cntrl.site/component-assets/3.jpg",name:"Slider-2.png"},imageCaption:[{type:"paragraph",children:[{text:""}]}]},{image:{objectFit:"contain",url:"https://cdn.cntrl.site/component-assets/4.jpg",name:"Slider-3.png"},imageCaption:[{type:"paragraph",children:[{text:""}]}]}]},styles:{type:"object",properties:{imageCaption:{dataName:"caption",type:"object",properties:{fontSettings:{type:"object",display:{type:"font-settings"},properties:{fontFamily:{type:"string"},fontWeight:{type:"number"},fontStyle:{type:"string"}}},widthSettings:{display:{type:"text-width-control"},type:"object",properties:{width:{type:"number"},sizing:{type:"string",enum:["auto","manual"]}}},fontSizeLineHeight:{type:"object",display:{type:"font-size-line-height"},properties:{fontSize:{type:"number"},lineHeight:{type:"number"}}},letterSpacing:{display:{type:"letter-spacing-input"},type:"number"},wordSpacing:{display:{type:"word-spacing-input"},type:"number"},textAlign:{display:{type:"text-align-control"},type:"string",enum:["left","center","right","justify"]},textAppearance:{display:{type:"text-appearance"},properties:{textTransform:{type:"string",enum:["none","uppercase","lowercase","capitalize"]},textDecoration:{type:"string",enum:["none","underline"]},fontVariant:{type:"string",enum:["normal","small-caps"]}}},color:{display:{type:"style-panel-color-picker"},type:"string"}}}},default:{imageCaption:{widthSettings:{width:.13,sizing:"auto"},fontSettings:{fontFamily:"Arial",fontWeight:400,fontStyle:"normal"},fontSizeLineHeight:{fontSize:.02,lineHeight:.02},letterSpacing:0,wordSpacing:0,textAlign:"left",textAppearance:{textTransform:"none",textDecoration:"none",fontVariant:"normal"},color:"#000000"}}}},required:["settings","content","styles"]}};function Qt(t,e){var n,o,r;return{fontFamily:t.fontSettings.fontFamily,fontWeight:t.fontSettings.fontWeight,fontStyle:t.fontSettings.fontStyle,letterSpacing:F.scalingValue(t.letterSpacing,e),wordSpacing:F.scalingValue(t.wordSpacing,e),fontSize:F.scalingValue(t.fontSize,e),lineHeight:t.lineHeight!==void 0?F.scalingValue(t.lineHeight,e):void 0,textTransform:(n=t.textAppearance)==null?void 0:n.textTransform,textDecoration:(o=t.textAppearance)==null?void 0:o.textDecoration,fontVariant:(r=t.textAppearance)==null?void 0:r.fontVariant,color:t.color}}function Me(t){return`calc(var(--cntrl-article-width, 100vw) * ${t/1440})`}function hl(t){return`
|
|
7
|
+
.${t}-wrapper {
|
|
8
8
|
display: flex;
|
|
9
9
|
flex-direction: column;
|
|
10
10
|
width: 100%;
|
|
11
|
-
min-height: ${
|
|
11
|
+
min-height: ${Me(48)};
|
|
12
12
|
}
|
|
13
|
-
.${
|
|
13
|
+
.${t}-wrapper.${t}-type-C .${t}-input:focus-visible,
|
|
14
|
+
.${t}-wrapper.${t}-type-C .${t}-button:focus-visible {
|
|
15
|
+
outline: none;
|
|
16
|
+
}
|
|
17
|
+
.${t}-form {
|
|
14
18
|
display: flex;
|
|
15
19
|
flex-direction: column;
|
|
16
20
|
width: 100%;
|
|
17
21
|
}
|
|
18
|
-
.${
|
|
22
|
+
.${t}-fields {
|
|
19
23
|
display: flex;
|
|
20
24
|
flex-direction: column;
|
|
21
25
|
flex: 1;
|
|
22
26
|
min-width: 0;
|
|
23
27
|
}
|
|
24
|
-
.${
|
|
28
|
+
.${t}-field-group {
|
|
25
29
|
display: flex;
|
|
26
30
|
flex-direction: column;
|
|
27
31
|
flex: 1;
|
|
28
32
|
min-width: 0;
|
|
29
33
|
}
|
|
30
|
-
.${
|
|
31
|
-
gap: ${
|
|
34
|
+
.${t}-field-group.${t}-labeled {
|
|
35
|
+
gap: ${Me(4)};
|
|
32
36
|
}
|
|
33
|
-
.${
|
|
37
|
+
.${t}-field-label {
|
|
34
38
|
white-space: nowrap;
|
|
35
|
-
color: var(--${
|
|
39
|
+
color: var(--${t}-label-text-color);
|
|
36
40
|
}
|
|
37
|
-
.${
|
|
41
|
+
.${t}-input {
|
|
38
42
|
width: 100%;
|
|
39
43
|
box-sizing: border-box;
|
|
40
|
-
line-height: 1.4;
|
|
41
44
|
outline: none;
|
|
42
|
-
|
|
43
|
-
color: var(--${
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
45
|
+
-webkit-tap-highlight-color: transparent;
|
|
46
|
+
background-color: var(--${t}-input-color);
|
|
47
|
+
color: var(--${t}-input-text-color);
|
|
48
|
+
border-color: var(--${t}-input-border-color);
|
|
49
|
+
transition: color 250ms, border-color 250ms, background-color 250ms;
|
|
50
|
+
}
|
|
51
|
+
.${t}-input::placeholder {
|
|
52
|
+
color: var(--${t}-placeholder-color);
|
|
49
53
|
opacity: 1;
|
|
50
54
|
transition: color 250ms, opacity 250ms;
|
|
51
55
|
}
|
|
52
|
-
.${
|
|
53
|
-
background-color: var(--${
|
|
54
|
-
color: var(--${
|
|
55
|
-
border-color: var(--${
|
|
56
|
-
}
|
|
57
|
-
.${
|
|
58
|
-
background-color: var(--${
|
|
59
|
-
color: var(--${
|
|
60
|
-
border-color: var(--${
|
|
61
|
-
}
|
|
62
|
-
.${
|
|
63
|
-
.${
|
|
64
|
-
.${
|
|
65
|
-
background-color: var(--${
|
|
66
|
-
color: var(--${
|
|
67
|
-
border-color: var(--${
|
|
68
|
-
}
|
|
69
|
-
.${
|
|
70
|
-
background-color: var(--${
|
|
71
|
-
color: var(--${
|
|
72
|
-
border-color: var(--${
|
|
73
|
-
}
|
|
74
|
-
.${
|
|
75
|
-
.${
|
|
56
|
+
.${t}-input:hover {
|
|
57
|
+
background-color: var(--${t}-hover-input-color, var(--${t}-input-color));
|
|
58
|
+
color: var(--${t}-hover-input-text-color, var(--${t}-input-text-color));
|
|
59
|
+
border-color: var(--${t}-hover-input-border-color, var(--${t}-input-border-color));
|
|
60
|
+
}
|
|
61
|
+
.${t}-wrapper.${t}-state-hover .${t}-input {
|
|
62
|
+
background-color: var(--${t}-hover-input-color, var(--${t}-input-color));
|
|
63
|
+
color: var(--${t}-hover-input-text-color, var(--${t}-input-text-color));
|
|
64
|
+
border-color: var(--${t}-hover-input-border-color, var(--${t}-input-border-color));
|
|
65
|
+
}
|
|
66
|
+
.${t}-input:focus,
|
|
67
|
+
.${t}-input:focus-visible,
|
|
68
|
+
.${t}-wrapper.${t}-state-focus .${t}-input {
|
|
69
|
+
background-color: var(--${t}-focus-input-color, var(--${t}-input-color));
|
|
70
|
+
color: var(--${t}-focus-input-text-color, var(--${t}-input-text-color));
|
|
71
|
+
border-color: var(--${t}-focus-input-border-color, var(--${t}-input-border-color));
|
|
72
|
+
}
|
|
73
|
+
.${t}-input[data-filled="true"] {
|
|
74
|
+
background-color: var(--${t}-filled-input-color, var(--${t}-input-color));
|
|
75
|
+
color: var(--${t}-filled-input-text-color, var(--${t}-input-text-color));
|
|
76
|
+
border-color: var(--${t}-filled-input-border-color, var(--${t}-input-border-color));
|
|
77
|
+
}
|
|
78
|
+
.${t}-wrapper.${t}-state-success .${t}-input,
|
|
79
|
+
.${t}-wrapper.${t}-state-success .${t}-button {
|
|
76
80
|
pointer-events: none;
|
|
77
81
|
}
|
|
78
|
-
.${
|
|
82
|
+
.${t}-wrapper.${t}-state-error .${t}-input {
|
|
79
83
|
}
|
|
80
|
-
.${
|
|
84
|
+
.${t}-input[data-field-type="textarea"] {
|
|
81
85
|
resize: vertical;
|
|
82
86
|
}
|
|
83
|
-
.${
|
|
84
|
-
background: #f5f5f5;
|
|
87
|
+
.${t}-input:disabled {
|
|
85
88
|
cursor: not-allowed;
|
|
86
89
|
}
|
|
87
|
-
.${
|
|
90
|
+
.${t}-button {
|
|
88
91
|
cursor: pointer;
|
|
89
92
|
white-space: nowrap;
|
|
93
|
+
box-sizing: border-box;
|
|
94
|
+
outline: none;
|
|
95
|
+
background-color: var(--${t}-button-color);
|
|
96
|
+
color: var(--${t}-button-text-color);
|
|
97
|
+
border-color: var(--${t}-button-border-color);
|
|
98
|
+
transition: color 250ms, background-color 250ms, border-color 250ms;
|
|
99
|
+
}
|
|
100
|
+
.${t}-button:hover {
|
|
101
|
+
background-color: var(--${t}-hover-button-color, var(--${t}-button-color));
|
|
102
|
+
color: var(--${t}-hover-button-text-color, var(--${t}-button-text-color));
|
|
103
|
+
border-color: var(--${t}-hover-button-border-color, var(--${t}-button-border-color));
|
|
104
|
+
}
|
|
105
|
+
.${t}-wrapper.${t}-state-hover .${t}-button {
|
|
106
|
+
background-color: var(--${t}-hover-button-color, var(--${t}-button-color));
|
|
107
|
+
color: var(--${t}-hover-button-text-color, var(--${t}-button-text-color));
|
|
108
|
+
border-color: var(--${t}-hover-button-border-color, var(--${t}-button-border-color));
|
|
109
|
+
}
|
|
110
|
+
.${t}-button:focus,
|
|
111
|
+
.${t}-button:focus-visible,
|
|
112
|
+
.${t}-wrapper.${t}-state-focus .${t}-button {
|
|
113
|
+
background-color: var(--${t}-focus-button-color, var(--${t}-button-color));
|
|
114
|
+
color: var(--${t}-focus-button-text-color, var(--${t}-button-text-color));
|
|
115
|
+
border-color: var(--${t}-focus-button-border-color, var(--${t}-button-border-color));
|
|
116
|
+
}
|
|
117
|
+
.${t}-input:focus-visible,
|
|
118
|
+
.${t}-wrapper.${t}-state-focus .${t}-input {
|
|
119
|
+
outline: none;
|
|
120
|
+
}
|
|
121
|
+
.${t}-button:focus-visible,
|
|
122
|
+
.${t}-wrapper.${t}-state-focus .${t}-button {
|
|
90
123
|
outline: none;
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
}
|
|
96
|
-
.${
|
|
97
|
-
|
|
98
|
-
color: var(--${
|
|
99
|
-
|
|
100
|
-
}
|
|
101
|
-
.${e}-wrapper.${e}-state-hover .${e}-button {
|
|
102
|
-
background-color: var(--${e}-hover-button-color, var(--${e}-button-color));
|
|
103
|
-
color: var(--${e}-hover-button-text-color, var(--${e}-button-text-color));
|
|
104
|
-
border-color: var(--${e}-hover-button-border-color, var(--${e}-button-border-color));
|
|
105
|
-
}
|
|
106
|
-
.${e}-button:focus,
|
|
107
|
-
.${e}-button:focus-visible,
|
|
108
|
-
.${e}-wrapper.${e}-state-focus .${e}-button {
|
|
109
|
-
background-color: var(--${e}-focus-button-color, var(--${e}-button-color));
|
|
110
|
-
color: var(--${e}-focus-button-text-color, var(--${e}-button-text-color));
|
|
111
|
-
border-color: var(--${e}-focus-button-border-color, var(--${e}-button-border-color));
|
|
112
|
-
}
|
|
113
|
-
.${e}-input:focus-visible,
|
|
114
|
-
.${e}-wrapper.${e}-state-focus .${e}-input {
|
|
115
|
-
outline: 1px solid var(--${e}-focus-input-border-color, var(--${e}-input-border-color));
|
|
116
|
-
}
|
|
117
|
-
.${e}-button:focus-visible,
|
|
118
|
-
.${e}-wrapper.${e}-state-focus .${e}-button {
|
|
119
|
-
outline: 1px solid var(--${e}-focus-button-border-color, var(--${e}-button-border-color));
|
|
120
|
-
}
|
|
121
|
-
.${e}-success {
|
|
122
|
-
margin-top: ${rt(8)};
|
|
123
|
-
font-size: ${rt(14)};
|
|
124
|
-
color: var(--${e}-success-success-color, var(--${e}-success-color));
|
|
125
|
-
}
|
|
126
|
-
.${e}-error {
|
|
127
|
-
margin-top: ${rt(8)};
|
|
128
|
-
font-size: ${rt(14)};
|
|
129
|
-
color: var(--${e}-error-error-color, var(--${e}-error-color));
|
|
130
|
-
}
|
|
131
|
-
.${e}-overlay-anchor {
|
|
124
|
+
}
|
|
125
|
+
.${t}-success {
|
|
126
|
+
margin-top: ${Me(8)};
|
|
127
|
+
color: var(--${t}-success-success-color, var(--${t}-success-color));
|
|
128
|
+
}
|
|
129
|
+
.${t}-error {
|
|
130
|
+
margin-top: ${Me(8)};
|
|
131
|
+
color: var(--${t}-error-error-color, var(--${t}-error-color));
|
|
132
|
+
}
|
|
133
|
+
.${t}-overlay-anchor {
|
|
132
134
|
position: relative;
|
|
133
135
|
height: auto;
|
|
134
136
|
}
|
|
135
|
-
`}function
|
|
137
|
+
`}function vl({settings:t,isEditor:e,metadata:n,activeEvent:o}){const{prefix:r}=F.useScopedStyles(),{type:a="A",fieldsToShow:i=2,fields:c=[],buttonLabel:l,gap:p,fieldsGap:s,buttonCorners:w,buttonStroke:v,buttonPadding:m,isButtonFullWidth:u,inputCorners:d,inputStroke:C,inputPadding:b,inputColor:f,inputTextColor:$,inputBorderColor:M,placeholderColor:P,buttonColor:T,buttonTextColor:h,buttonBorderColor:L,labelTextColor:R,successColor:W,errorColor:k,fontFamily:B,inputFontSettings:O,inputFontSize:U,inputLineHeight:D,inputLetterSpacing:g,inputWordSpacing:A,inputTextAppearance:I,buttonFontSettings:_,buttonFontSize:y,buttonLineHeight:V,buttonLetterSpacing:X,buttonWordSpacing:rt,buttonTextAppearance:Q,labelFontSettings:ut,labelFontSize:E,labelLineHeight:K,labelLetterSpacing:ht,labelWordSpacing:it,labelTextAppearance:mt,statusFontSettings:bt,statusFontSize:Mt,statusLineHeight:z,statusLetterSpacing:S,statusWordSpacing:H,statusTextAppearance:G,successMessage:J,errorMessage:ot,stateOverrides:tt}=t,q=a==="B",nt=c.slice(0,Math.min(i,c.length)),yt={fontSettings:{fontFamily:B,fontWeight:(O==null?void 0:O.fontWeight)??400,fontStyle:(O==null?void 0:O.fontStyle)??"normal"},fontSize:U??.01,lineHeight:D,letterSpacing:g??0,wordSpacing:A??0,textAppearance:I,color:$},lt=Qt(yt,e),pt=F.scalingValue(C??0,e),kt={...lt,borderStyle:"solid",borderRadius:a==="C"?0:F.scalingValue(d??0,e),...a==="C"?{borderTopWidth:0,borderRightWidth:0,borderBottomWidth:pt,borderLeftWidth:0}:{borderWidth:pt},paddingTop:F.scalingValue((b==null?void 0:b.top)??0,e),paddingRight:F.scalingValue((b==null?void 0:b.right)??0,e),paddingBottom:F.scalingValue((b==null?void 0:b.bottom)??0,e),paddingLeft:F.scalingValue((b==null?void 0:b.left)??0,e)},et={fontSettings:{fontFamily:B,fontWeight:(_==null?void 0:_.fontWeight)??400,fontStyle:(_==null?void 0:_.fontStyle)??"normal"},fontSize:y??.01,lineHeight:V,letterSpacing:X??0,wordSpacing:rt??0,textAppearance:Q,color:h},st=Qt(et,e),Ct=F.scalingValue(v??0,e),Ht={fontSettings:{fontFamily:B,fontWeight:(ut==null?void 0:ut.fontWeight)??400,fontStyle:(ut==null?void 0:ut.fontStyle)??"normal"},fontSize:E??.01,lineHeight:K,letterSpacing:ht??0,wordSpacing:it??0,textAppearance:mt,color:R},ft=Qt(Ht,e),re={fontSettings:{fontFamily:B,fontWeight:(bt==null?void 0:bt.fontWeight)??400,fontStyle:(bt==null?void 0:bt.fontStyle)??"normal"},fontSize:Mt??.01,lineHeight:z,letterSpacing:S??0,wordSpacing:H??0,textAppearance:G,color:W},Jt=Qt(re,e),$t=F.buildColorVars(r,{inputColor:f,inputTextColor:$,inputBorderColor:M,placeholderColor:P!=null&&P.trim()?P:"#cccccc",buttonColor:T,buttonTextColor:h,buttonBorderColor:L,labelTextColor:R,successColor:W,errorColor:k},yl,bl,tt),[Ft,qn]=j.useState(()=>Object.fromEntries(nt.map(ct=>[ct.name,""]))),[Xn,Se]=j.useState("idle"),[ar,We]=j.useState(null),dn=o==="success"?"success":o==="error"?"error":Xn,lr=o==="error"?ot:ar,xe=o==="filled"?Object.fromEntries(nt.map(ct=>[ct.name,"Filled"])):Ft,sr=dn==="error"?F.getFormFieldValidationError(nt,xe):null,cr=`${o&&o!=="default"?`${r}-state-${o}`:""}`.trim(),Kn=n==null?void 0:n.submitUrl,Jn=(ct,ie)=>{qn(Dt=>({...Dt,[ct]:ie}))},ur=async ct=>{ct.preventDefault();const ie=Object.fromEntries(nt.map(Et=>{var ae;return[Et.name,((ae=Ft[Et.name])==null?void 0:ae.trim())??""]}).filter(([,Et])=>Et));if(!Kn){Se("error"),We("No integrations were found for this form.");return}if(Object.keys(ie).length===0)return;const Dt=F.getFormFieldValidationError(nt,Ft);if(Dt){Se("error"),We(Dt);return}Se("submitting"),We(null);try{const Et=await fetch(Kn,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(ie)});if(!Et.ok){const ae=await Et.text();throw new Error(ae||`Request failed: ${Et.status}`)}Se("success"),qn(Object.fromEntries(nt.map(ae=>[ae.name,""])))}catch(Et){Se("error"),We(Et instanceof Error?Et.message:"Something went wrong")}};return x.jsxs("div",{className:`${r}-wrapper ${r}-type-${a} ${cr}`.trim(),style:$t,children:[x.jsx("style",{dangerouslySetInnerHTML:{__html:hl(r)}}),x.jsxs("form",{onSubmit:ur,className:`${r}-form`,style:{gap:F.scalingValue(p??0,e)},children:[x.jsx("div",{className:`${r}-fields`,style:{gap:F.scalingValue(s??0,e)},children:nt.map((ct,ie)=>x.jsxs("div",{className:`${r}-field-group${q?` ${r}-labeled`:""}`,children:[q&&x.jsx("span",{className:`${r}-field-label`,style:ft?{...ft,lineHeight:ft.fontSize}:void 0,children:ct.label||ct.name}),ct.type==="textarea"?x.jsx("textarea",{name:ct.name,autoComplete:"off",value:xe[ct.name]??"",onChange:Dt=>Jn(ct.name,Dt.target.value),placeholder:ct.placeholder,className:`${r}-input`,style:kt,rows:1,"data-filled":(xe[ct.name]??"").trim().length>0,"data-field-type":"textarea"}):x.jsx("input",{type:ct.type==="phone"?"tel":ct.type==="email"?"email":"text",name:ct.name,autoComplete:"off",value:xe[ct.name]??"",onChange:Dt=>Jn(ct.name,Dt.target.value),placeholder:ct.placeholder,required:ct.isRequired??ct.type==="email",className:`${r}-input`,style:kt,"data-filled":(xe[ct.name]??"").trim().length>0})]},ie))}),x.jsx("div",{className:`${r}-overlay-anchor`,children:x.jsx("button",{type:"submit",className:`${r}-button`,style:{borderStyle:"solid",borderRadius:F.scalingValue(w??0,e),borderWidth:Ct,paddingTop:F.scalingValue((m==null?void 0:m.top)??0,e),paddingRight:F.scalingValue((m==null?void 0:m.right)??0,e),paddingBottom:F.scalingValue((m==null?void 0:m.bottom)??0,e),paddingLeft:F.scalingValue((m==null?void 0:m.left)??0,e),...st,...u?{width:"100%",textAlign:"center",whiteSpace:"normal"}:{}},children:x.jsx("span",{className:`${r}-overlay-anchor`,style:u?{display:"inline-block",maxWidth:"100%",whiteSpace:"normal",textAlign:"center"}:void 0,children:Xn==="submitting"?"...":l})})})]}),dn==="success"&&x.jsx("p",{className:`${r}-success`,style:{...Jt},children:J}),dn==="error"&&x.jsx("p",{className:`${r}-error`,style:{...Jt},role:"alert",children:sr??lr??ot})]})}const yl={inputColor:"input-color",inputTextColor:"input-text-color",inputBorderColor:"input-border-color",placeholderColor:"placeholder-color",buttonColor:"button-color",buttonTextColor:"button-text-color",buttonBorderColor:"button-border-color",labelTextColor:"label-text-color",successColor:"success-color",errorColor:"error-color"},bl=["hover","focus","filled","success","error"],Sl=`import React, { useState } from 'react';
|
|
136
138
|
import { CommonComponentProps } from '../props';
|
|
137
|
-
import { getFormFieldValidationError, scalingValue, useScopedStyles } from '../utils/index';
|
|
139
|
+
import { buildColorVars, getFormFieldValidationError, scalingValue, useScopedStyles } from '../utils/index';
|
|
140
|
+
import { textStylesToCss, type TextStyles } from '../utils/textStylesToCss';
|
|
138
141
|
|
|
139
142
|
function sv(px: number): string {
|
|
140
143
|
return \`calc(var(--cntrl-article-width, 100vw) * \${px / 1440})\`;
|
|
@@ -148,6 +151,10 @@ function getCSS(P: string): string {
|
|
|
148
151
|
width: 100%;
|
|
149
152
|
min-height: \${sv(48)};
|
|
150
153
|
}
|
|
154
|
+
.\${P}-wrapper.\${P}-type-C .\${P}-input:focus-visible,
|
|
155
|
+
.\${P}-wrapper.\${P}-type-C .\${P}-button:focus-visible {
|
|
156
|
+
outline: none;
|
|
157
|
+
}
|
|
151
158
|
.\${P}-form {
|
|
152
159
|
display: flex;
|
|
153
160
|
flex-direction: column;
|
|
@@ -175,12 +182,12 @@ function getCSS(P: string): string {
|
|
|
175
182
|
.\${P}-input {
|
|
176
183
|
width: 100%;
|
|
177
184
|
box-sizing: border-box;
|
|
178
|
-
line-height: 1.4;
|
|
179
185
|
outline: none;
|
|
186
|
+
-webkit-tap-highlight-color: transparent;
|
|
180
187
|
background-color: var(--\${P}-input-color);
|
|
181
188
|
color: var(--\${P}-input-text-color);
|
|
182
189
|
border-color: var(--\${P}-input-border-color);
|
|
183
|
-
transition: color
|
|
190
|
+
transition: color 250ms, border-color 250ms, background-color 250ms;
|
|
184
191
|
}
|
|
185
192
|
.\${P}-input::placeholder {
|
|
186
193
|
color: var(--\${P}-placeholder-color);
|
|
@@ -204,7 +211,7 @@ function getCSS(P: string): string {
|
|
|
204
211
|
color: var(--\${P}-focus-input-text-color, var(--\${P}-input-text-color));
|
|
205
212
|
border-color: var(--\${P}-focus-input-border-color, var(--\${P}-input-border-color));
|
|
206
213
|
}
|
|
207
|
-
.\${P}-
|
|
214
|
+
.\${P}-input[data-filled="true"] {
|
|
208
215
|
background-color: var(--\${P}-filled-input-color, var(--\${P}-input-color));
|
|
209
216
|
color: var(--\${P}-filled-input-text-color, var(--\${P}-input-text-color));
|
|
210
217
|
border-color: var(--\${P}-filled-input-border-color, var(--\${P}-input-border-color));
|
|
@@ -219,17 +226,17 @@ function getCSS(P: string): string {
|
|
|
219
226
|
resize: vertical;
|
|
220
227
|
}
|
|
221
228
|
.\${P}-input:disabled {
|
|
222
|
-
background: #f5f5f5;
|
|
223
229
|
cursor: not-allowed;
|
|
224
230
|
}
|
|
225
231
|
.\${P}-button {
|
|
226
232
|
cursor: pointer;
|
|
227
233
|
white-space: nowrap;
|
|
234
|
+
box-sizing: border-box;
|
|
228
235
|
outline: none;
|
|
229
236
|
background-color: var(--\${P}-button-color);
|
|
230
237
|
color: var(--\${P}-button-text-color);
|
|
231
238
|
border-color: var(--\${P}-button-border-color);
|
|
232
|
-
transition: color 250ms;
|
|
239
|
+
transition: color 250ms, background-color 250ms, border-color 250ms;
|
|
233
240
|
}
|
|
234
241
|
.\${P}-button:hover {
|
|
235
242
|
background-color: var(--\${P}-hover-button-color, var(--\${P}-button-color));
|
|
@@ -250,20 +257,18 @@ function getCSS(P: string): string {
|
|
|
250
257
|
}
|
|
251
258
|
.\${P}-input:focus-visible,
|
|
252
259
|
.\${P}-wrapper.\${P}-state-focus .\${P}-input {
|
|
253
|
-
outline:
|
|
260
|
+
outline: none;
|
|
254
261
|
}
|
|
255
262
|
.\${P}-button:focus-visible,
|
|
256
263
|
.\${P}-wrapper.\${P}-state-focus .\${P}-button {
|
|
257
|
-
outline:
|
|
264
|
+
outline: none;
|
|
258
265
|
}
|
|
259
266
|
.\${P}-success {
|
|
260
267
|
margin-top: \${sv(8)};
|
|
261
|
-
font-size: \${sv(14)};
|
|
262
268
|
color: var(--\${P}-success-success-color, var(--\${P}-success-color));
|
|
263
269
|
}
|
|
264
270
|
.\${P}-error {
|
|
265
271
|
margin-top: \${sv(8)};
|
|
266
|
-
font-size: \${sv(14)};
|
|
267
272
|
color: var(--\${P}-error-error-color, var(--\${P}-error-color));
|
|
268
273
|
}
|
|
269
274
|
.\${P}-overlay-anchor {
|
|
@@ -287,14 +292,15 @@ export function Form({ settings, isEditor, metadata, activeEvent }: FormProps) {
|
|
|
287
292
|
type = 'A',
|
|
288
293
|
fieldsToShow = 2,
|
|
289
294
|
fields = [],
|
|
290
|
-
buttonLabel
|
|
291
|
-
gap
|
|
292
|
-
fieldsGap
|
|
295
|
+
buttonLabel,
|
|
296
|
+
gap,
|
|
297
|
+
fieldsGap,
|
|
293
298
|
buttonCorners,
|
|
294
299
|
buttonStroke,
|
|
300
|
+
buttonPadding,
|
|
301
|
+
isButtonFullWidth,
|
|
295
302
|
inputCorners,
|
|
296
303
|
inputStroke,
|
|
297
|
-
buttonPadding,
|
|
298
304
|
inputPadding,
|
|
299
305
|
inputColor,
|
|
300
306
|
inputTextColor,
|
|
@@ -325,6 +331,12 @@ export function Form({ settings, isEditor, metadata, activeEvent }: FormProps) {
|
|
|
325
331
|
labelLetterSpacing,
|
|
326
332
|
labelWordSpacing,
|
|
327
333
|
labelTextAppearance,
|
|
334
|
+
statusFontSettings,
|
|
335
|
+
statusFontSize,
|
|
336
|
+
statusLineHeight,
|
|
337
|
+
statusLetterSpacing,
|
|
338
|
+
statusWordSpacing,
|
|
339
|
+
statusTextAppearance,
|
|
328
340
|
successMessage,
|
|
329
341
|
errorMessage: errorMessageText,
|
|
330
342
|
stateOverrides,
|
|
@@ -347,11 +359,19 @@ export function Form({ settings, isEditor, metadata, activeEvent }: FormProps) {
|
|
|
347
359
|
color: inputTextColor,
|
|
348
360
|
};
|
|
349
361
|
const inputCss = textStylesToCss(resolvedInputTextStyle, isEditor);
|
|
362
|
+
const strokeForInput = scalingValue(inputStroke ?? 0, isEditor);
|
|
350
363
|
const inputFieldCss = {
|
|
351
364
|
...inputCss,
|
|
352
365
|
borderStyle: 'solid',
|
|
353
|
-
borderRadius: scalingValue(inputCorners ?? 0, isEditor),
|
|
354
|
-
|
|
366
|
+
borderRadius: type === 'C' ? 0 : scalingValue(inputCorners ?? 0, isEditor),
|
|
367
|
+
...(type === 'C'
|
|
368
|
+
? {
|
|
369
|
+
borderTopWidth: 0,
|
|
370
|
+
borderRightWidth: 0,
|
|
371
|
+
borderBottomWidth: strokeForInput,
|
|
372
|
+
borderLeftWidth: 0,
|
|
373
|
+
}
|
|
374
|
+
: { borderWidth: strokeForInput }),
|
|
355
375
|
paddingTop: scalingValue(inputPadding?.top ?? 0, isEditor),
|
|
356
376
|
paddingRight: scalingValue(inputPadding?.right ?? 0, isEditor),
|
|
357
377
|
paddingBottom: scalingValue(inputPadding?.bottom ?? 0, isEditor),
|
|
@@ -372,6 +392,7 @@ export function Form({ settings, isEditor, metadata, activeEvent }: FormProps) {
|
|
|
372
392
|
color: buttonTextColor,
|
|
373
393
|
};
|
|
374
394
|
const buttonTextCss = textStylesToCss(resolvedButtonTextStyle, isEditor);
|
|
395
|
+
const strokeForButton = scalingValue(buttonStroke ?? 0, isEditor);
|
|
375
396
|
|
|
376
397
|
const resolvedLabelTextStyle: TextStyles = {
|
|
377
398
|
fontSettings: {
|
|
@@ -388,6 +409,21 @@ export function Form({ settings, isEditor, metadata, activeEvent }: FormProps) {
|
|
|
388
409
|
};
|
|
389
410
|
const labelTextCss = textStylesToCss(resolvedLabelTextStyle, isEditor);
|
|
390
411
|
|
|
412
|
+
const resolvedStatusTextStyle: TextStyles = {
|
|
413
|
+
fontSettings: {
|
|
414
|
+
fontFamily,
|
|
415
|
+
fontWeight: statusFontSettings?.fontWeight ?? 400,
|
|
416
|
+
fontStyle: statusFontSettings?.fontStyle ?? 'normal',
|
|
417
|
+
},
|
|
418
|
+
fontSize: statusFontSize ?? 0.01,
|
|
419
|
+
lineHeight: statusLineHeight,
|
|
420
|
+
letterSpacing: statusLetterSpacing ?? 0,
|
|
421
|
+
wordSpacing: statusWordSpacing ?? 0,
|
|
422
|
+
textAppearance: statusTextAppearance,
|
|
423
|
+
color: successColor,
|
|
424
|
+
};
|
|
425
|
+
const statusTextCss = textStylesToCss(resolvedStatusTextStyle, isEditor);
|
|
426
|
+
|
|
391
427
|
const colorVars = buildColorVars(P, {
|
|
392
428
|
inputColor,
|
|
393
429
|
inputTextColor,
|
|
@@ -399,7 +435,7 @@ export function Form({ settings, isEditor, metadata, activeEvent }: FormProps) {
|
|
|
399
435
|
labelTextColor,
|
|
400
436
|
successColor,
|
|
401
437
|
errorColor,
|
|
402
|
-
}, stateOverrides);
|
|
438
|
+
}, COLOR_VAR_MAP, STATE_KEYS, stateOverrides);
|
|
403
439
|
|
|
404
440
|
const [fieldValues, setFieldValues] = useState<Record<string, string>>(() =>
|
|
405
441
|
Object.fromEntries(visibleFields.map((f) => [f.name, '']))
|
|
@@ -419,6 +455,7 @@ export function Form({ settings, isEditor, metadata, activeEvent }: FormProps) {
|
|
|
419
455
|
? getFormFieldValidationError(visibleFields, displayValues)
|
|
420
456
|
: null;
|
|
421
457
|
const stateClass = activeEvent && activeEvent !== 'default' ? \`\${P}-state-\${activeEvent}\` : '';
|
|
458
|
+
const wrapperStateClasses = \`\${stateClass}\`.trim();
|
|
422
459
|
|
|
423
460
|
const submitUrl = metadata?.submitUrl as string | undefined;
|
|
424
461
|
const handleFieldChange = (name: string, value: string) => {
|
|
@@ -430,7 +467,12 @@ export function Form({ settings, isEditor, metadata, activeEvent }: FormProps) {
|
|
|
430
467
|
const payload = Object.fromEntries(
|
|
431
468
|
visibleFields.map((f) => [f.name, fieldValues[f.name]?.trim() ?? '']).filter(([, v]) => v)
|
|
432
469
|
);
|
|
433
|
-
if (!submitUrl
|
|
470
|
+
if (!submitUrl) {
|
|
471
|
+
setStatus('error');
|
|
472
|
+
setErrorMessage('No integrations were found for this form.');
|
|
473
|
+
return;
|
|
474
|
+
}
|
|
475
|
+
if (Object.keys(payload).length === 0) return;
|
|
434
476
|
|
|
435
477
|
const validationError = getFormFieldValidationError(visibleFields, fieldValues);
|
|
436
478
|
if (validationError) {
|
|
@@ -462,16 +504,16 @@ export function Form({ settings, isEditor, metadata, activeEvent }: FormProps) {
|
|
|
462
504
|
};
|
|
463
505
|
|
|
464
506
|
return (
|
|
465
|
-
<div className={\`\${P}-wrapper \${
|
|
466
|
-
<style
|
|
507
|
+
<div className={\`\${P}-wrapper \${P}-type-\${type} \${wrapperStateClasses}\`.trim()} style={colorVars}>
|
|
508
|
+
<style dangerouslySetInnerHTML={{ __html: getCSS(P) }} />
|
|
467
509
|
<form
|
|
468
510
|
onSubmit={handleSubmit}
|
|
469
511
|
className={\`\${P}-form\`}
|
|
470
|
-
style={{ gap: scalingValue(gap, isEditor) }}
|
|
512
|
+
style={{ gap: scalingValue(gap ?? 0, isEditor) }}
|
|
471
513
|
>
|
|
472
514
|
<div
|
|
473
515
|
className={\`\${P}-fields\`}
|
|
474
|
-
style={{ gap: scalingValue(fieldsGap, isEditor) }}
|
|
516
|
+
style={{ gap: scalingValue(fieldsGap ?? 0, isEditor) }}
|
|
475
517
|
>
|
|
476
518
|
{visibleFields.map((field, index) => (
|
|
477
519
|
<div key={index} className={\`\${P}-field-group\${showLabels ? \` \${P}-labeled\` : ''}\`}>
|
|
@@ -490,6 +532,7 @@ export function Form({ settings, isEditor, metadata, activeEvent }: FormProps) {
|
|
|
490
532
|
className={\`\${P}-input\`}
|
|
491
533
|
style={inputFieldCss}
|
|
492
534
|
rows={1}
|
|
535
|
+
data-filled={((displayValues[field.name] ?? '') as string).trim().length > 0}
|
|
493
536
|
data-field-type="textarea"
|
|
494
537
|
/>
|
|
495
538
|
) : (
|
|
@@ -500,9 +543,10 @@ export function Form({ settings, isEditor, metadata, activeEvent }: FormProps) {
|
|
|
500
543
|
value={displayValues[field.name] ?? ''}
|
|
501
544
|
onChange={(e) => handleFieldChange(field.name, e.target.value)}
|
|
502
545
|
placeholder={field.placeholder}
|
|
503
|
-
required={field.type === 'email'}
|
|
546
|
+
required={field.isRequired ?? field.type === 'email'}
|
|
504
547
|
className={\`\${P}-input\`}
|
|
505
548
|
style={inputFieldCss}
|
|
549
|
+
data-filled={((displayValues[field.name] ?? '') as string).trim().length > 0}
|
|
506
550
|
/>
|
|
507
551
|
)}
|
|
508
552
|
</div>
|
|
@@ -515,15 +559,32 @@ export function Form({ settings, isEditor, metadata, activeEvent }: FormProps) {
|
|
|
515
559
|
style={{
|
|
516
560
|
borderStyle: 'solid',
|
|
517
561
|
borderRadius: scalingValue(buttonCorners ?? 0, isEditor),
|
|
518
|
-
borderWidth:
|
|
562
|
+
borderWidth: strokeForButton,
|
|
519
563
|
paddingTop: scalingValue(buttonPadding?.top ?? 0, isEditor),
|
|
520
564
|
paddingRight: scalingValue(buttonPadding?.right ?? 0, isEditor),
|
|
521
565
|
paddingBottom: scalingValue(buttonPadding?.bottom ?? 0, isEditor),
|
|
522
566
|
paddingLeft: scalingValue(buttonPadding?.left ?? 0, isEditor),
|
|
523
567
|
...buttonTextCss,
|
|
568
|
+
...(isButtonFullWidth
|
|
569
|
+
? {
|
|
570
|
+
width: '100%',
|
|
571
|
+
textAlign: 'center',
|
|
572
|
+
whiteSpace: 'normal',
|
|
573
|
+
}
|
|
574
|
+
: {}),
|
|
524
575
|
}}
|
|
525
576
|
>
|
|
526
|
-
<span
|
|
577
|
+
<span
|
|
578
|
+
className={\`\${P}-overlay-anchor\`}
|
|
579
|
+
style={isButtonFullWidth
|
|
580
|
+
? {
|
|
581
|
+
display: 'inline-block',
|
|
582
|
+
maxWidth: '100%',
|
|
583
|
+
whiteSpace: 'normal',
|
|
584
|
+
textAlign: 'center',
|
|
585
|
+
}
|
|
586
|
+
: undefined}
|
|
587
|
+
>
|
|
527
588
|
{status === 'submitting' ? '...' : buttonLabel}
|
|
528
589
|
</span>
|
|
529
590
|
</button>
|
|
@@ -532,7 +593,7 @@ export function Form({ settings, isEditor, metadata, activeEvent }: FormProps) {
|
|
|
532
593
|
{displayStatus === 'success' && (
|
|
533
594
|
<p
|
|
534
595
|
className={\`\${P}-success\`}
|
|
535
|
-
style={{ ...
|
|
596
|
+
style={{ ...statusTextCss }}
|
|
536
597
|
>
|
|
537
598
|
{successMessage}
|
|
538
599
|
</p>
|
|
@@ -540,7 +601,7 @@ export function Form({ settings, isEditor, metadata, activeEvent }: FormProps) {
|
|
|
540
601
|
{displayStatus === 'error' && (
|
|
541
602
|
<p
|
|
542
603
|
className={\`\${P}-error\`}
|
|
543
|
-
style={{ ...
|
|
604
|
+
style={{ ...statusTextCss}}
|
|
544
605
|
role="alert"
|
|
545
606
|
>
|
|
546
607
|
{validationErrorMessage ?? displayError ?? errorMessageText}
|
|
@@ -557,24 +618,8 @@ export type FormFieldItem = {
|
|
|
557
618
|
type: FormFieldType;
|
|
558
619
|
placeholder: string;
|
|
559
620
|
label?: string;
|
|
560
|
-
|
|
561
|
-
|
|
562
|
-
type TextStyles = {
|
|
563
|
-
fontSettings: {
|
|
564
|
-
fontFamily?: string;
|
|
565
|
-
fontWeight: number;
|
|
566
|
-
fontStyle: string;
|
|
567
|
-
};
|
|
568
|
-
letterSpacing: number;
|
|
569
|
-
wordSpacing: number;
|
|
570
|
-
fontSize: number;
|
|
571
|
-
lineHeight?: number;
|
|
572
|
-
textAppearance?: {
|
|
573
|
-
textTransform?: 'none' | 'uppercase' | 'lowercase' | 'capitalize';
|
|
574
|
-
textDecoration?: 'none' | 'underline';
|
|
575
|
-
fontVariant?: 'normal' | 'small-caps';
|
|
576
|
-
};
|
|
577
|
-
color: string;
|
|
621
|
+
isRequired?: boolean;
|
|
622
|
+
error?: string;
|
|
578
623
|
};
|
|
579
624
|
|
|
580
625
|
type Padding = {
|
|
@@ -599,7 +644,7 @@ type ColorKeys =
|
|
|
599
644
|
type StateColorOverrides = Partial<Record<ColorKeys, string>>;
|
|
600
645
|
|
|
601
646
|
type FormSettings = {
|
|
602
|
-
type: 'A' | 'B';
|
|
647
|
+
type: 'A' | 'B' | 'C';
|
|
603
648
|
fontFamily: string;
|
|
604
649
|
fieldsToShow: number;
|
|
605
650
|
fields: FormFieldItem[];
|
|
@@ -624,19 +669,26 @@ type FormSettings = {
|
|
|
624
669
|
labelLetterSpacing?: number;
|
|
625
670
|
labelWordSpacing?: number;
|
|
626
671
|
labelTextAppearance?: TextStyles['textAppearance'];
|
|
672
|
+
statusFontSettings?: { fontWeight: number; fontStyle: string };
|
|
673
|
+
statusFontSize?: number;
|
|
674
|
+
statusLineHeight?: number;
|
|
675
|
+
statusLetterSpacing?: number;
|
|
676
|
+
statusWordSpacing?: number;
|
|
677
|
+
statusTextAppearance?: TextStyles['textAppearance'];
|
|
627
678
|
buttonCorners?: number;
|
|
628
679
|
buttonStroke?: number;
|
|
680
|
+
buttonPadding?: Padding;
|
|
681
|
+
isButtonFullWidth?: boolean;
|
|
629
682
|
inputCorners?: number;
|
|
630
683
|
inputStroke?: number;
|
|
631
|
-
buttonPadding?: Padding;
|
|
632
684
|
inputPadding?: Padding;
|
|
633
685
|
inputColor: string;
|
|
634
686
|
inputTextColor: string;
|
|
635
687
|
inputBorderColor: string;
|
|
636
|
-
placeholderColor: string;
|
|
637
688
|
buttonColor: string;
|
|
638
689
|
buttonTextColor: string;
|
|
639
690
|
buttonBorderColor: string;
|
|
691
|
+
placeholderColor: string;
|
|
640
692
|
labelTextColor: string;
|
|
641
693
|
successColor: string;
|
|
642
694
|
errorColor: string;
|
|
@@ -659,47 +711,210 @@ const COLOR_VAR_MAP: Record<ColorKeys, string> = {
|
|
|
659
711
|
};
|
|
660
712
|
|
|
661
713
|
const STATE_KEYS = ['hover', 'focus', 'filled', 'success', 'error'] as const;
|
|
714
|
+
`,xl=[{name:"email",type:"email",placeholder:"Enter your email",label:"Email",isRequired:!0,error:"Please, enter a valid e-mail."},{name:"name",type:"text",placeholder:"Enter your name",label:"Name",isRequired:!1,error:"Please, enter your name."},{name:"company",type:"text",placeholder:"Enter company",label:"Company",isRequired:!1,error:"Please, enter your company name."},{name:"phone",type:"phone",placeholder:"Enter your phone",label:"Phone",isRequired:!1,error:"Please, enter a valid phone number."},{name:"message",type:"textarea",placeholder:"Enter your message",label:"Message",isRequired:!1,error:"Message is required"},{name:"message2",type:"textarea",placeholder:"Enter your message 2",label:"Message 2",isRequired:!1,error:"Message 2 is required"},{name:"message3",type:"textarea",placeholder:"Enter your message 3",label:"Message 3",isRequired:!1,error:"Message 3 is required"}],He={fontSettings:{type:"object",display:{type:"font-settings-weight"},properties:{fontWeight:{type:"number"},fontStyle:{type:"string"}}}},Cl=["inputColor","inputTextColor","inputBorderColor","placeholderColor","buttonColor","buttonTextColor","buttonBorderColor","labelTextColor","successColor","errorColor"],$l={type:"object",version:1,settings:{sizing:"auto manual",properties:{fieldsToShow:{type:"number",scope:"common",title:"Fields",display:{type:"number"},min:1,max:7},fields:{type:"array",scope:"common",display:{type:"fields-group"},items:{type:"object",properties:{name:{type:"string"},type:{type:"string",enum:["text","textarea","phone","email"]},placeholder:{type:"string"},label:{type:"string"},isRequired:{type:"boolean"},error:{type:"string"}}}},buttonLabel:{type:"string",scope:"common",title:"Button Label",display:{type:"text-input"}},successMessage:{type:"string",scope:"common",title:"Success Message",display:{type:"text-input"}},errorMessage:{type:"string",scope:"common",title:"Error Message",display:{type:"text-input"}},type:{type:"string",scope:"common",title:"",display:{type:"radio-group"},enum:["A","B","C"]},gap:{type:"number",scope:"layout",title:"Gap",display:{type:"range-control"},min:0,max:100},fieldsGap:{type:"number",scope:"layout",title:"Gap",display:{type:"range-control"},min:0,max:100},buttonPadding:{type:"object",scope:"layout",title:"Padding",display:{type:"padding-controls"}},inputPadding:{type:"object",scope:"layout",title:"Padding",display:{type:"padding-controls"}},buttonStroke:{type:"number",scope:"layout",title:"Stroke",display:{type:"range-control"},min:0,max:20},buttonCorners:{type:"number",scope:"layout",title:"Corners",display:{type:"range-control"},min:0,max:100},inputStroke:{type:"number",scope:"layout",title:"Stroke",display:{type:"range-control"},min:0,max:20},inputCorners:{type:"number",scope:"layout",title:"Corners",display:{type:"range-control"},min:0,max:100},inputColor:{type:"string",scope:"common",title:"Input Fill",display:{type:"palette-color-picker"}},inputTextColor:{type:"string",scope:"common",title:"Input Label",display:{type:"palette-color-picker"}},inputBorderColor:{type:"string",scope:"common",title:"Input Stroke",display:{type:"palette-color-picker"}},placeholderColor:{type:"string",scope:"common",title:"Filler text",display:{type:"palette-color-picker"}},buttonColor:{type:"string",scope:"common",title:"Button Fill",display:{type:"palette-color-picker"}},buttonTextColor:{type:"string",scope:"common",title:"Button Label",display:{type:"palette-color-picker"}},isButtonFullWidth:{type:"boolean",scope:"common",title:"Full Width",display:{type:"toggle",enum:["On","Off"]}},buttonBorderColor:{type:"string",scope:"common",title:"Button Stroke",display:{type:"palette-color-picker"}},labelTextColor:{type:"string",scope:"common",title:"Label Color",display:{type:"palette-color-picker",visible:!1}},successColor:{type:"string",scope:"common",title:"Success Message Color",display:{type:"palette-color-picker"}},errorColor:{type:"string",scope:"common",title:"Error Message Color",display:{type:"palette-color-picker"}},stateOverrides:{type:"object",scope:"common"},fontFamily:{type:"string",scope:"common",title:"Font family",display:{type:"font-family-select"}},inputFontSettings:{...He.fontSettings,scope:"common",title:"Input",display:{type:"font-settings-weight"}},inputFontSize:{type:"number",scope:"layout",title:"Input Font Size",display:{type:"font-size"}},inputLineHeight:{type:"number",scope:"layout",title:"Input Line Height",display:{type:"line-height-input"}},inputLetterSpacing:{type:"number",scope:"layout",title:"Input Letter Spacing",display:{type:"letter-spacing-input"}},inputWordSpacing:{type:"number",scope:"layout",title:"Input Word Spacing",display:{type:"word-spacing-input"}},inputTextAppearance:{type:"object",scope:"layout",title:"Input Text Appearance",display:{type:"text-appearance"}},buttonFontSettings:{...He.fontSettings,scope:"common",title:"Button",display:{type:"font-settings-weight"}},buttonFontSize:{type:"number",scope:"layout",title:"Button Font Size",display:{type:"font-size"}},buttonLineHeight:{type:"number",scope:"layout",title:"Button Line Height",display:{type:"line-height-input"}},buttonLetterSpacing:{type:"number",scope:"layout",title:"Button Letter Spacing",display:{type:"letter-spacing-input"}},buttonWordSpacing:{type:"number",scope:"layout",title:"Button Word Spacing",display:{type:"word-spacing-input"}},buttonTextAppearance:{type:"object",scope:"layout",title:"Button Text Appearance",display:{type:"text-appearance"}},labelFontSettings:{...He.fontSettings,scope:"common",title:"Label",display:{type:"font-settings-weight",visible:!1}},labelFontSize:{type:"number",scope:"layout",title:"Label Font Size",display:{type:"font-size",visible:!1}},labelLineHeight:{type:"number",scope:"layout",title:"Label Line Height",display:{type:"line-height-input",visible:!1}},labelLetterSpacing:{type:"number",scope:"layout",title:"Label Letter Spacing",display:{type:"letter-spacing-input",visible:!1}},labelWordSpacing:{type:"number",scope:"layout",title:"Label Word Spacing",display:{type:"word-spacing-input",visible:!1}},labelTextAppearance:{type:"object",scope:"layout",title:"Label Text Appearance",display:{type:"text-appearance",visible:!1}},statusFontSettings:{...He.fontSettings,scope:"common",title:"Success/Error"},statusFontSize:{type:"number",scope:"layout",title:"Success/Error Font Size",display:{type:"font-size"}},statusLineHeight:{type:"number",scope:"layout",title:"Success/Error Line Height",display:{type:"line-height-input"}},statusLetterSpacing:{type:"number",scope:"layout",title:"Success/Error Letter Spacing",display:{type:"letter-spacing-input"}},statusWordSpacing:{type:"number",scope:"layout",title:"Success/Error Word Spacing",display:{type:"word-spacing-input"}},statusTextAppearance:{type:"object",scope:"layout",title:"Success/Error Text Appearance",display:{type:"text-appearance"}}},defaults:{fieldsToShow:2,fields:xl,type:"A",inputColor:"#FFFFFF",inputTextColor:"#0A00F8",inputBorderColor:"#0A00F8",placeholderColor:"#808080",buttonColor:"#0A00F8",buttonTextColor:"#ffffff",buttonBorderColor:"#0A00F8",labelTextColor:"#999999",successColor:"#22c55e",errorColor:"#ef4444",stateOverrides:{hover:{buttonColor:"#194EFF"}},fontFamily:"Arial",inputFontSettings:{fontWeight:400,fontStyle:"normal"},inputLetterSpacing:0,inputWordSpacing:0,inputTextAppearance:{textTransform:"none",textDecoration:"none",fontVariant:"normal"},buttonFontSettings:{fontWeight:400,fontStyle:"normal"},buttonLetterSpacing:0,buttonWordSpacing:0,buttonTextAppearance:{textTransform:"none",textDecoration:"none",fontVariant:"normal"},labelFontSettings:{fontWeight:400,fontStyle:"normal"},labelLetterSpacing:0,labelWordSpacing:0,labelTextAppearance:{textTransform:"none",textDecoration:"none",fontVariant:"normal"},statusFontSettings:{fontWeight:400,fontStyle:"normal"},statusLetterSpacing:0,statusWordSpacing:0,statusTextAppearance:{textTransform:"none",textDecoration:"none",fontVariant:"normal"},isButtonFullWidth:!1,buttonLabel:"Sign up",successMessage:"Thanks for subscribing!",errorMessage:"Please, fill all required fields."},layoutDefaults:{m:{gap:.032,fieldsGap:.032,buttonStroke:0,buttonCorners:.192,inputStroke:0,inputCorners:.192,buttonPadding:{top:.0373,right:.0373,bottom:.0373,left:.0373},inputPadding:{top:.0373,right:.0373,bottom:.0373,left:.0373},inputFontSize:.043,inputLineHeight:.043,buttonFontSize:.0373,buttonLineHeight:.0373,labelFontSize:.0373,labelLineHeight:.0373,statusFontSize:.0373,statusLineHeight:.0373},d:{gap:.0083,fieldsGap:.0083,buttonStroke:0,buttonCorners:.05,inputStroke:0,inputCorners:.05,buttonPadding:{top:.01,right:.01,bottom:.01,left:.01},inputPadding:{top:.01,right:.01,bottom:.01,left:.01},inputFontSize:.01,inputLineHeight:.01,buttonFontSize:.01,buttonLineHeight:.01,labelFontSize:.01,labelLineHeight:.01,statusFontSize:.01,statusLineHeight:.01}},displayRules:[{if:{name:"type",value:"B"},then:{name:"properties.labelTextColor.display.visible",value:!0}},{if:{name:"type",value:"B"},then:{name:"properties.labelFontSettings.display.visible",value:!0}},{if:{name:"type",value:"B"},then:{name:"properties.labelFontSize.display.visible",value:!0}},{if:{name:"type",value:"B"},then:{name:"properties.labelLineHeight.display.visible",value:!0}},{if:{name:"type",value:"B"},then:{name:"properties.labelLetterSpacing.display.visible",value:!0}},{if:{name:"type",value:"B"},then:{name:"properties.labelWordSpacing.display.visible",value:!0}},{if:{name:"type",value:"B"},then:{name:"properties.labelTextAppearance.display.visible",value:!0}},{if:{name:"type",value:"C"},then:{name:"properties.buttonCorners.display.visible",value:!1}},{if:{name:"type",value:"C"},then:{name:"properties.inputCorners.display.visible",value:!1}},{if:{name:"buttonStroke",value:0},then:{name:"properties.buttonBorderColor.display.visible",value:!1}},{if:{name:"inputStroke",value:0},then:{name:"properties.inputBorderColor.display.visible",value:!1}}]},panels:[{id:"general",icon:"cursor",title:"General",tooltip:"General Settings",layout:[{type:"row",items:["__componentName__","name","fieldsToShow"]},"type",{type:"group",title:"",items:[{type:"row",title:"Input",items:[{type:"group",title:"",items:["fieldsGap","inputStroke","inputCorners"]},{type:"group",title:"",items:["inputPadding"]}]},{type:"group",title:"Button",items:[{type:"row",items:["isButtonFullWidth"]},{type:"row",items:[{type:"group",title:"",items:["gap","buttonStroke","buttonCorners"]},{type:"group",title:"",items:["buttonPadding"]}]}]}]}]},{id:"typeStyle",icon:"text-icon",title:"Type Style",tooltip:"Typography",layout:["fontFamily",{type:"group",title:"",items:["inputFontSettings",{type:"row",items:["inputFontSize","inputLineHeight","inputLetterSpacing","inputWordSpacing"]},"inputTextAppearance"]},{type:"group",title:"",items:["buttonFontSettings",{type:"row",items:["buttonFontSize","buttonLineHeight","buttonLetterSpacing","buttonWordSpacing"]},"buttonTextAppearance"]},{type:"group",title:"",items:["labelFontSettings",{type:"row",items:["labelFontSize","labelLineHeight","labelLetterSpacing","labelWordSpacing"]},"labelTextAppearance"]},{type:"group",title:"",items:["statusFontSettings",{type:"row",items:["statusFontSize","statusLineHeight","statusLetterSpacing","statusWordSpacing"]},"statusTextAppearance"]}]},{id:"fields",icon:"layers",title:"Fields",tooltip:"Fields",layout:["fields","buttonLabel","successMessage","errorMessage"]}],paletteBookmark:{items:[...Cl],panelIds:["general","typeStyle"],stateItems:{default:["placeholderColor","inputColor","inputBorderColor","buttonTextColor","buttonColor","buttonBorderColor","labelTextColor"],hover:["inputColor","inputBorderColor","buttonTextColor","buttonColor","buttonBorderColor"],focus:["inputColor","inputBorderColor","buttonTextColor","buttonColor","buttonBorderColor"],filled:["inputTextColor","inputColor","inputBorderColor","buttonTextColor"],success:["successColor"],error:["errorColor"]}},allowedPlugins:["newsletter"],states:["default","hover","focus","filled","success","error"]},_l={element:vl,id:"form",name:"Newsletter Stacked",preview:{type:"image",url:"https://cdn.cntrl.site/component-assets/formImg.png"},version:1,defaultSize:{width:300,height:42},schema:$l,sourceCode:Sl};function De(t){return`calc(var(--cntrl-article-width, 100vw) * ${t/1440})`}function wl(t){return`
|
|
715
|
+
.${t}-wrapper {
|
|
716
|
+
display: flex;
|
|
717
|
+
flex-direction: column;
|
|
718
|
+
width: 100%;
|
|
719
|
+
height: 100%;
|
|
720
|
+
align-items: stretch;
|
|
721
|
+
justify-content: center;
|
|
722
|
+
}
|
|
723
|
+
.${t}-form {
|
|
724
|
+
display: flex;
|
|
725
|
+
width: 100%;
|
|
726
|
+
align-items: stretch;
|
|
727
|
+
overflow: hidden;
|
|
728
|
+
border-color: var(--${t}-stroke-color);
|
|
729
|
+
transition: border-color 250ms;
|
|
730
|
+
}
|
|
731
|
+
.${t}-form:hover {
|
|
732
|
+
border-color: var(--${t}-hover-stroke-color, var(--${t}-stroke-color));
|
|
733
|
+
}
|
|
734
|
+
.${t}-form:focus-within {
|
|
735
|
+
border-color: var(--${t}-focus-stroke-color, var(--${t}-stroke-color));
|
|
736
|
+
}
|
|
737
|
+
.${t}-wrapper.${t}-state-hover .${t}-form {
|
|
738
|
+
border-color: var(--${t}-hover-stroke-color, var(--${t}-stroke-color));
|
|
739
|
+
}
|
|
740
|
+
.${t}-wrapper.${t}-state-focus .${t}-form {
|
|
741
|
+
border-color: var(--${t}-focus-stroke-color, var(--${t}-stroke-color));
|
|
742
|
+
}
|
|
743
|
+
.${t}-wrapper.${t}-state-filled .${t}-form {
|
|
744
|
+
border-color: var(--${t}-filled-stroke-color, var(--${t}-stroke-color));
|
|
745
|
+
}
|
|
746
|
+
.${t}-inputWrap {
|
|
747
|
+
position: relative;
|
|
748
|
+
display: flex;
|
|
749
|
+
align-items: center;
|
|
750
|
+
flex: 1;
|
|
751
|
+
min-width: 0;
|
|
752
|
+
background-color: var(--${t}-input-color);
|
|
753
|
+
transition: background-color 250ms;
|
|
754
|
+
}
|
|
755
|
+
.${t}-inputWrap:hover,
|
|
756
|
+
.${t}-wrapper.${t}-state-hover .${t}-inputWrap {
|
|
757
|
+
background-color: var(--${t}-hover-input-color, var(--${t}-input-color));
|
|
758
|
+
}
|
|
759
|
+
.${t}-inputWrap:focus-within,
|
|
760
|
+
.${t}-wrapper.${t}-state-focus .${t}-inputWrap {
|
|
761
|
+
background-color: var(--${t}-focus-input-color, var(--${t}-input-color));
|
|
762
|
+
}
|
|
763
|
+
.${t}-wrapper.${t}-state-filled .${t}-inputWrap {
|
|
764
|
+
background-color: var(--${t}-filled-input-color, var(--${t}-input-color));
|
|
765
|
+
}
|
|
766
|
+
.${t}-input {
|
|
767
|
+
flex: 1;
|
|
768
|
+
min-width: 0;
|
|
769
|
+
background: transparent;
|
|
770
|
+
border: none;
|
|
771
|
+
outline: none;
|
|
772
|
+
-webkit-tap-highlight-color: transparent;
|
|
773
|
+
color: var(--${t}-input-text-color);
|
|
774
|
+
transition: color 250ms, background-color 250ms, border-color 250ms;
|
|
775
|
+
}
|
|
776
|
+
.${t}-input:hover {
|
|
777
|
+
color: var(--${t}-hover-input-text-color, var(--${t}-input-text-color));
|
|
778
|
+
}
|
|
779
|
+
.${t}-inputWrap:hover .${t}-input,
|
|
780
|
+
.${t}-wrapper.${t}-state-hover .${t}-input {
|
|
781
|
+
color: var(--${t}-hover-input-text-color, var(--${t}-input-text-color));
|
|
782
|
+
}
|
|
783
|
+
.${t}-input:focus,
|
|
784
|
+
.${t}-wrapper.${t}-state-focus .${t}-input {
|
|
785
|
+
color: var(--${t}-focus-input-text-color, var(--${t}-input-text-color));
|
|
786
|
+
}
|
|
787
|
+
.${t}-wrapper.${t}-state-filled .${t}-input {
|
|
788
|
+
color: var(--${t}-filled-input-text-color, var(--${t}-input-text-color));
|
|
789
|
+
}
|
|
790
|
+
.${t}-input::placeholder {
|
|
791
|
+
color: var(--${t}-placeholder-color);
|
|
792
|
+
opacity: 1;
|
|
793
|
+
transition: color 250ms, opacity 250ms;
|
|
794
|
+
}
|
|
795
|
+
.${t}-inputWrap:hover .${t}-input::placeholder,
|
|
796
|
+
.${t}-wrapper.${t}-state-hover .${t}-input::placeholder {
|
|
797
|
+
color: var(--${t}-hover-placeholder-color, var(--${t}-placeholder-color));
|
|
798
|
+
}
|
|
799
|
+
.${t}-inputWrap:focus-within .${t}-input::placeholder,
|
|
800
|
+
.${t}-wrapper.${t}-state-focus .${t}-input::placeholder {
|
|
801
|
+
color: var(--${t}-focus-placeholder-color, var(--${t}-placeholder-color));
|
|
802
|
+
}
|
|
803
|
+
.${t}-wrapper.${t}-state-filled .${t}-input::placeholder {
|
|
804
|
+
color: var(--${t}-filled-placeholder-color, var(--${t}-placeholder-color));
|
|
805
|
+
}
|
|
806
|
+
.${t}-submitBtn {
|
|
807
|
+
box-sizing: border-box;
|
|
808
|
+
height: 100%;
|
|
809
|
+
display: flex;
|
|
810
|
+
align-items: center;
|
|
811
|
+
justify-content: center;
|
|
812
|
+
border: none;
|
|
813
|
+
cursor: pointer;
|
|
814
|
+
white-space: nowrap;
|
|
815
|
+
background-color: var(--${t}-button-color);
|
|
816
|
+
color: var(--${t}-button-text-color);
|
|
817
|
+
border-left-style: solid;
|
|
818
|
+
border-left-color: var(--${t}-stroke-color);
|
|
819
|
+
transition: color 250ms, background-color 250ms, border-color 250ms;
|
|
820
|
+
}
|
|
821
|
+
.${t}-submitBtn img {
|
|
822
|
+
display: block;
|
|
823
|
+
box-sizing: border-box;
|
|
824
|
+
flex: 0 1 auto;
|
|
825
|
+
min-width: 0;
|
|
826
|
+
height: 100%;
|
|
827
|
+
width: auto;
|
|
828
|
+
max-width: 100%;
|
|
829
|
+
max-height: 100%;
|
|
830
|
+
object-fit: contain;
|
|
831
|
+
}
|
|
832
|
+
.${t}-submitBtn svg {
|
|
833
|
+
display: block;
|
|
834
|
+
box-sizing: border-box;
|
|
835
|
+
flex: 0 1 auto;
|
|
836
|
+
min-width: 0;
|
|
837
|
+
height: 100%;
|
|
838
|
+
width: auto;
|
|
839
|
+
max-width: 100%;
|
|
840
|
+
max-height: 100%;
|
|
841
|
+
}
|
|
842
|
+
.${t}-submitBtn .${t}-submitBtnIcon {
|
|
843
|
+
position: relative;
|
|
844
|
+
top: auto;
|
|
845
|
+
left: auto;
|
|
846
|
+
transform: none;
|
|
847
|
+
display: block;
|
|
848
|
+
box-sizing: border-box;
|
|
849
|
+
flex: 0 1 auto;
|
|
850
|
+
align-self: stretch;
|
|
851
|
+
min-width: 0;
|
|
852
|
+
width: auto;
|
|
853
|
+
height: auto;
|
|
854
|
+
aspect-ratio: 1;
|
|
855
|
+
max-width: 100%;
|
|
856
|
+
max-height: 100%;
|
|
857
|
+
}
|
|
858
|
+
.${t}-submitBtn:hover,
|
|
859
|
+
.${t}-wrapper.${t}-state-hover .${t}-submitBtn {
|
|
860
|
+
background-color: var(--${t}-hover-button-color, var(--${t}-button-color));
|
|
861
|
+
color: var(--${t}-hover-button-text-color, var(--${t}-button-text-color));
|
|
862
|
+
border-left-color: var(--${t}-hover-stroke-color, var(--${t}-stroke-color));
|
|
863
|
+
}
|
|
864
|
+
.${t}-submitBtn:focus,
|
|
865
|
+
.${t}-wrapper.${t}-state-focus .${t}-submitBtn {
|
|
866
|
+
background-color: var(--${t}-focus-button-color, var(--${t}-button-color));
|
|
867
|
+
color: var(--${t}-focus-button-text-color, var(--${t}-button-text-color));
|
|
868
|
+
border-left-color: var(--${t}-focus-stroke-color, var(--${t}-stroke-color));
|
|
869
|
+
}
|
|
870
|
+
.${t}-wrapper.${t}-state-filled .${t}-submitBtn {
|
|
871
|
+
background-color: var(--${t}-filled-button-color, var(--${t}-button-color));
|
|
872
|
+
color: var(--${t}-filled-button-text-color, var(--${t}-button-text-color));
|
|
873
|
+
border-left-color: var(--${t}-filled-stroke-color, var(--${t}-stroke-color));
|
|
874
|
+
}
|
|
875
|
+
.${t}-submitBtn:hover .${t}-submitBtnIcon,
|
|
876
|
+
.${t}-wrapper.${t}-state-hover .${t}-submitBtn .${t}-submitBtnIcon {
|
|
877
|
+
background-color: var(--${t}-hover-button-text-color, var(--${t}-button-text-color));
|
|
878
|
+
}
|
|
879
|
+
.${t}-submitBtn:focus .${t}-submitBtnIcon,
|
|
880
|
+
.${t}-wrapper.${t}-state-focus .${t}-submitBtn .${t}-submitBtnIcon {
|
|
881
|
+
background-color: var(--${t}-focus-button-text-color, var(--${t}-button-text-color));
|
|
882
|
+
}
|
|
883
|
+
.${t}-wrapper.${t}-state-filled .${t}-submitBtn .${t}-submitBtnIcon {
|
|
884
|
+
background-color: var(--${t}-filled-button-text-color, var(--${t}-button-text-color));
|
|
885
|
+
}
|
|
886
|
+
.${t}-wrapper.${t}-state-success .${t}-input,
|
|
887
|
+
.${t}-wrapper.${t}-state-success .${t}-submitBtn {
|
|
888
|
+
pointer-events: none;
|
|
889
|
+
}
|
|
890
|
+
.${t}-overlayAnchor {
|
|
891
|
+
position: relative;
|
|
892
|
+
display: flex;
|
|
893
|
+
align-items: center;
|
|
894
|
+
}
|
|
895
|
+
.${t}-success {
|
|
896
|
+
margin-top: ${De(8)};
|
|
897
|
+
font-size: ${De(14)};
|
|
898
|
+
color: var(--${t}-success-success-color, var(--${t}-success-color));
|
|
899
|
+
}
|
|
900
|
+
.${t}-error {
|
|
901
|
+
margin-top: ${De(8)};
|
|
902
|
+
font-size: ${De(14)};
|
|
903
|
+
color: var(--${t}-error-error-color, var(--${t}-error-color));
|
|
904
|
+
}
|
|
905
|
+
`}const Tl=({settings:t,isEditor:e,metadata:n,activeEvent:o})=>{const{prefix:r}=F.useScopedStyles(),{fields:a=[{name:"email",type:"email",placeholder:"Your email"}],buttonContent:i,buttonLabel:c,fieldsToShow:l=1,fontFamily:p,inputFontSettings:s,inputFontSize:w,inputLineHeight:v,inputLetterSpacing:m,inputWordSpacing:u,inputTextAppearance:d,buttonFontSettings:C,buttonFontSize:b,buttonLineHeight:f,buttonLetterSpacing:$,buttonWordSpacing:M,buttonTextAppearance:P,statusFontSettings:T,statusFontSize:h,statusLineHeight:L,statusLetterSpacing:R,statusWordSpacing:W,statusTextAppearance:k,minHeight:B,corners:O,stroke:U,stateOverrides:D,inputPadding:g,buttonPadding:A,successMessage:I="Thanks for subscribing!",errorMessage:_="Please, fill all required fields."}=t,y=a.slice(0,Math.min(l,a.length)),[V,X]=j.useState(()=>Object.fromEntries(y.map(ft=>[ft.name,""]))),[rt,Q]=j.useState("idle"),[ut,E]=j.useState(null),K=o==="success"?"success":o==="error"?"error":rt,ht=o==="error"?_:ut,it=o==="filled"?Object.fromEntries(y.map(ft=>[ft.name,"Filled"])):V,mt=K==="error"?F.getFormFieldValidationError(y,it):null,bt=o&&o!=="default"?`${r}-state-${o}`:"",Mt=y.some(ft=>(it[ft.name]??"").trim().length>0),z=bt!==`${r}-state-filled`&&Mt?`${r}-state-filled`:"",S=`${bt} ${z}`.trim(),H=n==null?void 0:n.submitUrl,G=c??"",J=(i==null?void 0:i.icon)??"",ot=(i==null?void 0:i.mode)==="On",tt=G||"Submit",q={fontSettings:{fontFamily:p,fontWeight:(s==null?void 0:s.fontWeight)??400,fontStyle:(s==null?void 0:s.fontStyle)??"normal"},fontSize:w??.01,lineHeight:v,letterSpacing:m??0,wordSpacing:u??0,textAppearance:d,color:t.inputTextColor??"#111111"},nt={fontSettings:{fontFamily:p,fontWeight:(C==null?void 0:C.fontWeight)??400,fontStyle:(C==null?void 0:C.fontStyle)??"normal"},fontSize:b??.01,lineHeight:f,letterSpacing:$??0,wordSpacing:M??0,textAppearance:P,color:t.buttonTextColor??"#ffffff"},yt={fontSettings:{fontFamily:p,fontWeight:(T==null?void 0:T.fontWeight)??400,fontStyle:(T==null?void 0:T.fontStyle)??"normal"},fontSize:h??.01,lineHeight:L,letterSpacing:R??0,wordSpacing:W??0,textAppearance:k,color:t.successColor??"#22c55e"},lt=Qt(q,e),pt=Qt(nt,e),kt=Qt(yt,e),et=F.buildColorVars(r,{strokeColor:t.strokeColor,inputColor:t.inputColor,placeholderColor:t.placeholderColor,buttonColor:t.buttonColor,successColor:t.successColor,errorColor:t.errorColor,inputTextColor:t.inputTextColor??(q==null?void 0:q.color)??"#111111",buttonTextColor:t.buttonTextColor??(nt==null?void 0:nt.color)??"#ffffff"},El,Ll,D),st={borderRadius:F.scalingValue(O,e),borderWidth:F.scalingValue(U,e),borderStyle:"solid"},Ct={borderLeftWidth:F.scalingValue(U,e)},Ht=async ft=>{ft.preventDefault();const re=Object.fromEntries(y.map($t=>{var Ft;return[$t.name,((Ft=V[$t.name])==null?void 0:Ft.trim())??""]}).filter(([,$t])=>$t));if(!H){Q("error"),E("No integrations were found for this form.");return}if(Object.keys(re).length===0)return;const Jt=F.getFormFieldValidationError(y,V);if(Jt){Q("error"),E(Jt);return}Q("submitting"),E(null);try{const $t=await fetch(H,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(re)});if(!$t.ok){const Ft=await $t.text();throw new Error(Ft||`Request failed: ${$t.status}`)}Q("success"),X(Object.fromEntries(y.map(Ft=>[Ft.name,""])))}catch($t){Q("error"),E($t instanceof Error?$t.message:"Something went wrong")}};return x.jsxs("div",{className:`${r}-wrapper ${S}`.trim(),style:et,children:[x.jsx("style",{dangerouslySetInnerHTML:{__html:wl(r)}}),x.jsxs("form",{onSubmit:Ht,className:`${r}-form`,style:{...st,height:F.scalingValue(B,e),minHeight:F.scalingValue(B,e)},children:[x.jsx("div",{className:`${r}-inputWrap ${r}-overlayAnchor`,style:{flex:1,minWidth:0},children:y.map(ft=>x.jsx("input",{type:ft.type==="email"?"email":ft.type==="phone"?"tel":"text",name:ft.name,autoComplete:"off",value:it[ft.name]??"",onChange:re=>X(Jt=>({...Jt,[ft.name]:re.target.value})),placeholder:ft.placeholder,required:ft.isRequired??ft.type==="email",className:`${r}-input`,style:{...lt,paddingRight:F.scalingValue(g.right,e),paddingLeft:F.scalingValue(g.left,e),paddingTop:F.scalingValue(g.top,e),paddingBottom:F.scalingValue(g.bottom,e)}},ft.name))}),x.jsx("div",{className:`${r}-overlayAnchor`,children:x.jsx("button",{type:"submit",className:`${r}-submitBtn`,"aria-label":tt,style:{...pt,...Ct,paddingRight:F.scalingValue(A.right,e),paddingLeft:F.scalingValue(A.left,e),paddingTop:F.scalingValue(A.top,e),paddingBottom:F.scalingValue(A.bottom,e)},children:rt==="submitting"?"...":ot?J&&x.jsx(ge,{url:J,className:`${r}-submitBtnIcon`,fill:`var(--${r}-button-text-color)`,hoverFill:`var(--${r}-button-text-color)`}):G})})]}),K==="success"&&x.jsx("p",{className:`${r}-success`,style:{...kt},children:I}),K==="error"&&x.jsx("p",{className:`${r}-error`,style:{...kt},role:"alert",children:mt??ht??_})]})},El={strokeColor:"stroke-color",inputColor:"input-color",placeholderColor:"placeholder-color",buttonColor:"button-color",inputTextColor:"input-text-color",buttonTextColor:"button-text-color",successColor:"success-color",errorColor:"error-color"},Ll=["hover","focus","filled","success","error"],Al=`import React, { useState } from 'react';
|
|
906
|
+
import { CommonComponentProps } from '../props';
|
|
907
|
+
import { buildColorVars, getFormFieldValidationError, scalingValue, useScopedStyles } from '../utils/index';
|
|
908
|
+
import { textStylesToCss, type TextStyles } from '../utils/textStylesToCss';
|
|
909
|
+
import { SvgImage } from '../helpers/SvgImage/SvgImage';
|
|
662
910
|
|
|
663
|
-
function
|
|
664
|
-
|
|
665
|
-
defaults: Record<ColorKeys, string>,
|
|
666
|
-
stateOverrides?: Record<string, StateColorOverrides>,
|
|
667
|
-
): React.CSSProperties {
|
|
668
|
-
const vars: Record<string, string> = {};
|
|
669
|
-
for (const [key, varSuffix] of Object.entries(COLOR_VAR_MAP)) {
|
|
670
|
-
vars[\`--\${P}-\${varSuffix}\`] = defaults[key as ColorKeys];
|
|
671
|
-
}
|
|
672
|
-
if (stateOverrides) {
|
|
673
|
-
for (const state of STATE_KEYS) {
|
|
674
|
-
const overrides = stateOverrides[state];
|
|
675
|
-
if (!overrides) continue;
|
|
676
|
-
for (const [key, varSuffix] of Object.entries(COLOR_VAR_MAP)) {
|
|
677
|
-
const val = overrides[key as ColorKeys];
|
|
678
|
-
if (val !== undefined) {
|
|
679
|
-
vars[\`--\${P}-\${state}-\${varSuffix}\`] = val;
|
|
680
|
-
}
|
|
681
|
-
}
|
|
682
|
-
}
|
|
683
|
-
}
|
|
684
|
-
return vars as unknown as React.CSSProperties;
|
|
685
|
-
}
|
|
686
|
-
|
|
687
|
-
function textStylesToCss(textStyles: TextStyles, isEditor?: boolean): React.CSSProperties {
|
|
688
|
-
return {
|
|
689
|
-
fontFamily: textStyles.fontSettings.fontFamily,
|
|
690
|
-
fontWeight: textStyles.fontSettings.fontWeight,
|
|
691
|
-
fontStyle: textStyles.fontSettings.fontStyle,
|
|
692
|
-
letterSpacing: scalingValue(textStyles.letterSpacing, isEditor),
|
|
693
|
-
wordSpacing: scalingValue(textStyles.wordSpacing, isEditor),
|
|
694
|
-
fontSize: scalingValue(textStyles.fontSize, isEditor),
|
|
695
|
-
lineHeight: textStyles.lineHeight !== undefined ? scalingValue(textStyles.lineHeight, isEditor) : undefined,
|
|
696
|
-
textTransform: textStyles.textAppearance?.textTransform,
|
|
697
|
-
textDecoration: textStyles.textAppearance?.textDecoration,
|
|
698
|
-
fontVariant: textStyles.textAppearance?.fontVariant
|
|
699
|
-
};
|
|
911
|
+
function sv(px: number): string {
|
|
912
|
+
return \`calc(var(--cntrl-article-width, 100vw) * \${px / 1440})\`;
|
|
700
913
|
}
|
|
701
|
-
`,pl=[{name:"email",type:"email",placeholder:"Enter your email",label:"Email",isRequired:!0,error:"Please, enter a valid e-mail."},{name:"name",type:"text",placeholder:"Enter your name",label:"Name",isRequired:!1,error:"Please, enter your name."},{name:"company",type:"text",placeholder:"Enter company",label:"Company",isRequired:!1,error:"Please, enter your company name."},{name:"phone",type:"phone",placeholder:"Enter your phone",label:"Phone",isRequired:!1,error:"Please, enter a valid phone number."},{name:"message",type:"textarea",placeholder:"Enter your message",label:"Message",isRequired:!1,error:"Message is required"},{name:"message2",type:"textarea",placeholder:"Enter your message 2",label:"Message 2",isRequired:!1,error:"Message 2 is required"},{name:"message3",type:"textarea",placeholder:"Enter your message 3",label:"Message 3",isRequired:!1,error:"Message 3 is required"}],un={fontSettings:{type:"object",display:{type:"font-settings-weight"},properties:{fontWeight:{type:"number"},fontStyle:{type:"string"}}}},dl=["inputColor","inputTextColor","inputBorderColor","placeholderColor","buttonColor","buttonTextColor","buttonBorderColor","labelTextColor","successColor","errorColor"],gl={type:"object",version:1,settings:{sizing:"auto",properties:{fieldsToShow:{type:"number",scope:"common",title:"Fields",display:{type:"number"},min:1,max:8},fields:{type:"array",scope:"common",display:{type:"fields-group"},items:{type:"object",properties:{name:{type:"string"},type:{type:"string",enum:["text","textarea","phone","email"]},placeholder:{type:"string"},label:{type:"string"},isRequired:{type:"boolean"},error:{type:"string"}}}},successMessage:{type:"string",scope:"common",title:"Success Message",display:{type:"text-input"}},errorMessage:{type:"string",scope:"common",title:"Error Message",display:{type:"text-input"}},type:{type:"string",scope:"common",title:"",display:{type:"radio-group"},enum:["A","B"]},gap:{type:"number",scope:"layout",title:"Gap",display:{type:"range-control"},min:0,max:100},fieldsGap:{type:"number",scope:"layout",title:"Gap",display:{type:"range-control"},min:0,max:100},buttonPadding:{type:"object",scope:"layout",title:"Padding",display:{type:"padding-controls"}},inputPadding:{type:"object",scope:"layout",title:"Padding",display:{type:"padding-controls"}},buttonStroke:{type:"number",scope:"layout",title:"Stroke",display:{type:"range-control"},min:0,max:20},buttonCorners:{type:"number",scope:"layout",title:"Corners",display:{type:"range-control"},min:0,max:100},inputStroke:{type:"number",scope:"layout",title:"Stroke",display:{type:"range-control"},min:0,max:20},inputCorners:{type:"number",scope:"layout",title:"Corners",display:{type:"range-control"},min:0,max:100},inputColor:{type:"string",scope:"layout",title:"Input Color",display:{type:"palette-color-picker"}},inputTextColor:{type:"string",scope:"layout",title:"Input Text Color",display:{type:"palette-color-picker"}},inputBorderColor:{type:"string",scope:"layout",title:"Input Border Color",display:{type:"palette-color-picker"}},placeholderColor:{type:"string",scope:"layout",title:"Placeholder Color",display:{type:"palette-color-picker"}},buttonColor:{type:"string",scope:"layout",title:"Button Color",display:{type:"palette-color-picker"}},buttonTextColor:{type:"string",scope:"layout",title:"Button Text Color",display:{type:"palette-color-picker"}},buttonBorderColor:{type:"string",scope:"layout",title:"Button Border Color",display:{type:"palette-color-picker"}},labelTextColor:{type:"string",scope:"layout",title:"Label Color",display:{type:"palette-color-picker",visible:!1}},successColor:{type:"string",scope:"layout",title:"Success Message Color",display:{type:"palette-color-picker"}},errorColor:{type:"string",scope:"layout",title:"Error Message Color",display:{type:"palette-color-picker"}},stateOverrides:{type:"object",scope:"layout"},fontFamily:{type:"string",scope:"layout",title:"Font family",display:{type:"font-family-select"}},inputFontSettings:{...un.fontSettings,scope:"layout",title:"Input",display:{type:"font-settings-weight"}},inputFontSize:{type:"number",scope:"layout",title:"Input Font Size",display:{type:"font-size"}},inputLineHeight:{type:"number",scope:"layout",title:"Input Line Height",display:{type:"line-height-input"}},inputLetterSpacing:{type:"number",scope:"layout",title:"Input Letter Spacing",display:{type:"letter-spacing-input"}},inputWordSpacing:{type:"number",scope:"layout",title:"Input Word Spacing",display:{type:"word-spacing-input"}},inputTextAppearance:{type:"object",scope:"layout",title:"Input Text Appearance",display:{type:"text-appearance"}},buttonFontSettings:{...un.fontSettings,scope:"layout",title:"Button",display:{type:"font-settings-weight"}},buttonFontSize:{type:"number",scope:"layout",title:"Button Font Size",display:{type:"font-size"}},buttonLineHeight:{type:"number",scope:"layout",title:"Button Line Height",display:{type:"line-height-input"}},buttonLetterSpacing:{type:"number",scope:"layout",title:"Button Letter Spacing",display:{type:"letter-spacing-input"}},buttonWordSpacing:{type:"number",scope:"layout",title:"Button Word Spacing",display:{type:"word-spacing-input"}},buttonTextAppearance:{type:"object",scope:"layout",title:"Button Text Appearance",display:{type:"text-appearance"}},labelFontSettings:{...un.fontSettings,scope:"layout",title:"Label",display:{type:"font-settings-weight",visible:!1}},labelFontSize:{type:"number",scope:"layout",title:"Label Font Size",display:{type:"font-size",visible:!1}},labelLineHeight:{type:"number",scope:"layout",title:"Label Line Height",display:{type:"line-height-input",visible:!1}},labelLetterSpacing:{type:"number",scope:"layout",title:"Label Letter Spacing",display:{type:"letter-spacing-input",visible:!1}},labelWordSpacing:{type:"number",scope:"layout",title:"Label Word Spacing",display:{type:"word-spacing-input",visible:!1}},labelTextAppearance:{type:"object",scope:"layout",title:"Label Text Appearance",display:{type:"text-appearance",visible:!1}}},defaults:{fieldsToShow:2,fields:pl,type:"A",gap:.008,fieldsGap:.008,buttonStroke:.001,buttonCorners:.05,inputStroke:.001,inputCorners:.05,buttonPadding:{top:.01,right:.01,bottom:.01,left:.01},inputPadding:{top:.01,right:.01,bottom:.01,left:.01},inputColor:"#FFFFFF",inputTextColor:"#999999",inputBorderColor:"#0A00F8",placeholderColor:"#0A00F8",buttonColor:"#0A00F8",buttonTextColor:"#ffffff",buttonBorderColor:"#cccccc",labelTextColor:"#999999",successColor:"#22c55e",errorColor:"#ef4444",stateOverrides:{},fontFamily:"Arial",inputFontSettings:{fontWeight:400,fontStyle:"normal"},inputFontSize:.01,inputLineHeight:.01,inputLetterSpacing:0,inputWordSpacing:0,inputTextAppearance:{textTransform:"none",textDecoration:"none",fontVariant:"normal"},buttonFontSettings:{fontWeight:400,fontStyle:"normal"},buttonFontSize:.01,buttonLineHeight:.01,buttonLetterSpacing:0,buttonWordSpacing:0,buttonTextAppearance:{textTransform:"none",textDecoration:"none",fontVariant:"normal"},labelFontSettings:{fontWeight:400,fontStyle:"normal"},labelFontSize:.01,labelLineHeight:.01,labelLetterSpacing:0,labelWordSpacing:0,labelTextAppearance:{textTransform:"none",textDecoration:"none",fontVariant:"normal"},successMessage:"Thanks for subscribing!",errorMessage:"Please, fill all required fields."},displayRules:[{if:{name:"type",value:"B"},then:{name:"properties.labelTextColor.display.visible",value:!0}},{if:{name:"type",value:"B"},then:{name:"properties.labelFontSettings.display.visible",value:!0}},{if:{name:"type",value:"B"},then:{name:"properties.labelFontSize.display.visible",value:!0}},{if:{name:"type",value:"B"},then:{name:"properties.labelLineHeight.display.visible",value:!0}},{if:{name:"type",value:"B"},then:{name:"properties.labelLetterSpacing.display.visible",value:!0}},{if:{name:"type",value:"B"},then:{name:"properties.labelWordSpacing.display.visible",value:!0}},{if:{name:"type",value:"B"},then:{name:"properties.labelTextAppearance.display.visible",value:!0}}]},panels:[{id:"general",icon:"cursor",title:"General",tooltip:"General Settings",layout:[{type:"row",items:["__componentName__","name","fieldsToShow"]},"type",{type:"group",title:"",items:[{type:"row",title:"Input",items:[{type:"group",title:"",items:["fieldsGap","inputStroke","inputCorners"]},{type:"group",title:"",items:["inputPadding"]}]},{type:"row",title:"Button",items:[{type:"group",title:"",items:["gap","buttonStroke","buttonCorners"]},{type:"group",title:"",items:["buttonPadding"]}]}]}]},{id:"typeStyle",icon:"text-icon",title:"Type Style",tooltip:"Typography",layout:["fontFamily",{type:"group",title:"Input",items:["inputFontSettings",{type:"row",items:["inputFontSize","inputLineHeight","inputLetterSpacing","inputWordSpacing"]},"inputTextAppearance"]},{type:"group",title:"Button",items:["buttonFontSettings",{type:"row",items:["buttonFontSize","buttonLineHeight","buttonLetterSpacing","buttonWordSpacing"]},"buttonTextAppearance"]},{type:"group",title:"Label",items:["labelFontSettings",{type:"row",items:["labelFontSize","labelLineHeight","labelLetterSpacing","labelWordSpacing"]},"labelTextAppearance"]}]},{id:"fields",icon:"layers",title:"Fields",tooltip:"Fields",layout:["fields","successMessage","errorMessage"]}],paletteBookmark:{items:[...dl],panelIds:["general","typeStyle"],stateItems:{default:["inputColor","inputBorderColor","placeholderColor","placeholderTextColor","buttonColor","buttonTextColor","buttonBorderColor","labelTextColor"],hover:["inputColor","inputBorderColor","placeholderColor","buttonColor","buttonTextColor","buttonBorderColor"],focus:["inputColor","inputBorderColor","placeholderColor","buttonColor","buttonTextColor","buttonBorderColor"],filled:["inputColor","inputTextColor","inputBorderColor"],success:["successColor"],error:["errorColor"]}},allowedPlugins:["newsletter"],states:["default","hover","focus","filled","success","error"]},fl={element:ll,id:"form",name:"Newsletter Stacked",preview:{type:"image",url:"https://cdn.cntrl.site/component-assets/formImg.png"},version:1,defaultSize:{width:400,height:42},schema:gl,sourceCode:ul};function Ot(e){return`calc(var(--cntrl-article-width, 100vw) * ${e/1440})`}function ml(e){return`
|
|
702
|
-
|
|
914
|
+
|
|
915
|
+
function getCSS(P: string): string {
|
|
916
|
+
return \`
|
|
917
|
+
.\${P}-wrapper {
|
|
703
918
|
display: flex;
|
|
704
919
|
flex-direction: column;
|
|
705
920
|
width: 100%;
|
|
@@ -707,65 +922,90 @@ function textStylesToCss(textStyles: TextStyles, isEditor?: boolean): React.CSSP
|
|
|
707
922
|
align-items: stretch;
|
|
708
923
|
justify-content: center;
|
|
709
924
|
}
|
|
710
|
-
|
|
925
|
+
.\${P}-form {
|
|
711
926
|
display: flex;
|
|
712
927
|
width: 100%;
|
|
713
928
|
align-items: stretch;
|
|
714
929
|
overflow: hidden;
|
|
930
|
+
border-color: var(--\${P}-stroke-color);
|
|
931
|
+
transition: border-color 250ms;
|
|
932
|
+
}
|
|
933
|
+
.\${P}-form:hover {
|
|
934
|
+
border-color: var(--\${P}-hover-stroke-color, var(--\${P}-stroke-color));
|
|
935
|
+
}
|
|
936
|
+
.\${P}-form:focus-within {
|
|
937
|
+
border-color: var(--\${P}-focus-stroke-color, var(--\${P}-stroke-color));
|
|
938
|
+
}
|
|
939
|
+
.\${P}-wrapper.\${P}-state-hover .\${P}-form {
|
|
940
|
+
border-color: var(--\${P}-hover-stroke-color, var(--\${P}-stroke-color));
|
|
941
|
+
}
|
|
942
|
+
.\${P}-wrapper.\${P}-state-focus .\${P}-form {
|
|
943
|
+
border-color: var(--\${P}-focus-stroke-color, var(--\${P}-stroke-color));
|
|
715
944
|
}
|
|
716
|
-
|
|
945
|
+
.\${P}-wrapper.\${P}-state-filled .\${P}-form {
|
|
946
|
+
border-color: var(--\${P}-filled-stroke-color, var(--\${P}-stroke-color));
|
|
947
|
+
}
|
|
948
|
+
.\${P}-inputWrap {
|
|
717
949
|
position: relative;
|
|
718
950
|
display: flex;
|
|
719
951
|
align-items: center;
|
|
720
952
|
flex: 1;
|
|
721
953
|
min-width: 0;
|
|
722
|
-
background-color: var(
|
|
723
|
-
transition:
|
|
954
|
+
background-color: var(--\${P}-input-color);
|
|
955
|
+
transition: background-color 250ms;
|
|
724
956
|
}
|
|
725
|
-
|
|
726
|
-
|
|
727
|
-
background-color: var(
|
|
957
|
+
.\${P}-inputWrap:hover,
|
|
958
|
+
.\${P}-wrapper.\${P}-state-hover .\${P}-inputWrap {
|
|
959
|
+
background-color: var(--\${P}-hover-input-color, var(--\${P}-input-color));
|
|
728
960
|
}
|
|
729
|
-
|
|
730
|
-
|
|
731
|
-
background-color: var(
|
|
961
|
+
.\${P}-inputWrap:focus-within,
|
|
962
|
+
.\${P}-wrapper.\${P}-state-focus .\${P}-inputWrap {
|
|
963
|
+
background-color: var(--\${P}-focus-input-color, var(--\${P}-input-color));
|
|
732
964
|
}
|
|
733
|
-
|
|
734
|
-
background-color: var(
|
|
965
|
+
.\${P}-wrapper.\${P}-state-filled .\${P}-inputWrap {
|
|
966
|
+
background-color: var(--\${P}-filled-input-color, var(--\${P}-input-color));
|
|
735
967
|
}
|
|
736
|
-
|
|
968
|
+
.\${P}-input {
|
|
737
969
|
flex: 1;
|
|
738
970
|
min-width: 0;
|
|
739
971
|
background: transparent;
|
|
740
972
|
border: none;
|
|
741
973
|
outline: none;
|
|
742
|
-
|
|
743
|
-
|
|
974
|
+
-webkit-tap-highlight-color: transparent;
|
|
975
|
+
color: var(--\${P}-input-text-color);
|
|
976
|
+
transition: color 250ms, background-color 250ms, border-color 250ms;
|
|
744
977
|
}
|
|
745
|
-
|
|
746
|
-
color: var(
|
|
978
|
+
.\${P}-input:hover {
|
|
979
|
+
color: var(--\${P}-hover-input-text-color, var(--\${P}-input-text-color));
|
|
747
980
|
}
|
|
748
|
-
|
|
749
|
-
|
|
750
|
-
color: var(
|
|
981
|
+
.\${P}-inputWrap:hover .\${P}-input,
|
|
982
|
+
.\${P}-wrapper.\${P}-state-hover .\${P}-input {
|
|
983
|
+
color: var(--\${P}-hover-input-text-color, var(--\${P}-input-text-color));
|
|
751
984
|
}
|
|
752
|
-
|
|
753
|
-
|
|
754
|
-
color: var(
|
|
985
|
+
.\${P}-input:focus,
|
|
986
|
+
.\${P}-wrapper.\${P}-state-focus .\${P}-input {
|
|
987
|
+
color: var(--\${P}-focus-input-text-color, var(--\${P}-input-text-color));
|
|
755
988
|
}
|
|
756
|
-
|
|
757
|
-
color: var(
|
|
989
|
+
.\${P}-wrapper.\${P}-state-filled .\${P}-input {
|
|
990
|
+
color: var(--\${P}-filled-input-text-color, var(--\${P}-input-text-color));
|
|
758
991
|
}
|
|
759
|
-
|
|
760
|
-
color: var(
|
|
992
|
+
.\${P}-input::placeholder {
|
|
993
|
+
color: var(--\${P}-placeholder-color);
|
|
761
994
|
opacity: 1;
|
|
762
|
-
transition:
|
|
995
|
+
transition: color 250ms, opacity 250ms;
|
|
763
996
|
}
|
|
764
|
-
|
|
765
|
-
|
|
766
|
-
color: var(
|
|
997
|
+
.\${P}-inputWrap:hover .\${P}-input::placeholder,
|
|
998
|
+
.\${P}-wrapper.\${P}-state-hover .\${P}-input::placeholder {
|
|
999
|
+
color: var(--\${P}-hover-placeholder-color, var(--\${P}-placeholder-color));
|
|
767
1000
|
}
|
|
768
|
-
|
|
1001
|
+
.\${P}-inputWrap:focus-within .\${P}-input::placeholder,
|
|
1002
|
+
.\${P}-wrapper.\${P}-state-focus .\${P}-input::placeholder {
|
|
1003
|
+
color: var(--\${P}-focus-placeholder-color, var(--\${P}-placeholder-color));
|
|
1004
|
+
}
|
|
1005
|
+
.\${P}-wrapper.\${P}-state-filled .\${P}-input::placeholder {
|
|
1006
|
+
color: var(--\${P}-filled-placeholder-color, var(--\${P}-placeholder-color));
|
|
1007
|
+
}
|
|
1008
|
+
.\${P}-submitBtn {
|
|
769
1009
|
box-sizing: border-box;
|
|
770
1010
|
height: 100%;
|
|
771
1011
|
display: flex;
|
|
@@ -774,13 +1014,13 @@ function textStylesToCss(textStyles: TextStyles, isEditor?: boolean): React.CSSP
|
|
|
774
1014
|
border: none;
|
|
775
1015
|
cursor: pointer;
|
|
776
1016
|
white-space: nowrap;
|
|
777
|
-
background-color: var(
|
|
778
|
-
color: var(
|
|
1017
|
+
background-color: var(--\${P}-button-color);
|
|
1018
|
+
color: var(--\${P}-button-text-color);
|
|
779
1019
|
border-left-style: solid;
|
|
780
|
-
border-left-color: var(
|
|
781
|
-
transition:
|
|
1020
|
+
border-left-color: var(--\${P}-stroke-color);
|
|
1021
|
+
transition: color 250ms, background-color 250ms, border-color 250ms;
|
|
782
1022
|
}
|
|
783
|
-
|
|
1023
|
+
.\${P}-submitBtn img {
|
|
784
1024
|
display: block;
|
|
785
1025
|
box-sizing: border-box;
|
|
786
1026
|
flex: 0 1 auto;
|
|
@@ -791,40 +1031,434 @@ function textStylesToCss(textStyles: TextStyles, isEditor?: boolean): React.CSSP
|
|
|
791
1031
|
max-height: 100%;
|
|
792
1032
|
object-fit: contain;
|
|
793
1033
|
}
|
|
794
|
-
|
|
795
|
-
|
|
796
|
-
|
|
797
|
-
|
|
798
|
-
|
|
799
|
-
|
|
800
|
-
|
|
801
|
-
|
|
802
|
-
|
|
803
|
-
|
|
804
|
-
|
|
805
|
-
|
|
806
|
-
|
|
807
|
-
|
|
808
|
-
|
|
809
|
-
|
|
810
|
-
|
|
811
|
-
|
|
812
|
-
|
|
1034
|
+
.\${P}-submitBtn svg {
|
|
1035
|
+
display: block;
|
|
1036
|
+
box-sizing: border-box;
|
|
1037
|
+
flex: 0 1 auto;
|
|
1038
|
+
min-width: 0;
|
|
1039
|
+
height: 100%;
|
|
1040
|
+
width: auto;
|
|
1041
|
+
max-width: 100%;
|
|
1042
|
+
max-height: 100%;
|
|
1043
|
+
}
|
|
1044
|
+
.\${P}-submitBtn .\${P}-submitBtnIcon {
|
|
1045
|
+
position: relative;
|
|
1046
|
+
top: auto;
|
|
1047
|
+
left: auto;
|
|
1048
|
+
transform: none;
|
|
1049
|
+
display: block;
|
|
1050
|
+
box-sizing: border-box;
|
|
1051
|
+
flex: 0 1 auto;
|
|
1052
|
+
align-self: stretch;
|
|
1053
|
+
min-width: 0;
|
|
1054
|
+
width: auto;
|
|
1055
|
+
height: auto;
|
|
1056
|
+
aspect-ratio: 1;
|
|
1057
|
+
max-width: 100%;
|
|
1058
|
+
max-height: 100%;
|
|
1059
|
+
}
|
|
1060
|
+
.\${P}-submitBtn:hover,
|
|
1061
|
+
.\${P}-wrapper.\${P}-state-hover .\${P}-submitBtn {
|
|
1062
|
+
background-color: var(--\${P}-hover-button-color, var(--\${P}-button-color));
|
|
1063
|
+
color: var(--\${P}-hover-button-text-color, var(--\${P}-button-text-color));
|
|
1064
|
+
border-left-color: var(--\${P}-hover-stroke-color, var(--\${P}-stroke-color));
|
|
1065
|
+
}
|
|
1066
|
+
.\${P}-submitBtn:focus,
|
|
1067
|
+
.\${P}-wrapper.\${P}-state-focus .\${P}-submitBtn {
|
|
1068
|
+
background-color: var(--\${P}-focus-button-color, var(--\${P}-button-color));
|
|
1069
|
+
color: var(--\${P}-focus-button-text-color, var(--\${P}-button-text-color));
|
|
1070
|
+
border-left-color: var(--\${P}-focus-stroke-color, var(--\${P}-stroke-color));
|
|
1071
|
+
}
|
|
1072
|
+
.\${P}-wrapper.\${P}-state-filled .\${P}-submitBtn {
|
|
1073
|
+
background-color: var(--\${P}-filled-button-color, var(--\${P}-button-color));
|
|
1074
|
+
color: var(--\${P}-filled-button-text-color, var(--\${P}-button-text-color));
|
|
1075
|
+
border-left-color: var(--\${P}-filled-stroke-color, var(--\${P}-stroke-color));
|
|
1076
|
+
}
|
|
1077
|
+
.\${P}-submitBtn:hover .\${P}-submitBtnIcon,
|
|
1078
|
+
.\${P}-wrapper.\${P}-state-hover .\${P}-submitBtn .\${P}-submitBtnIcon {
|
|
1079
|
+
background-color: var(--\${P}-hover-button-text-color, var(--\${P}-button-text-color));
|
|
1080
|
+
}
|
|
1081
|
+
.\${P}-submitBtn:focus .\${P}-submitBtnIcon,
|
|
1082
|
+
.\${P}-wrapper.\${P}-state-focus .\${P}-submitBtn .\${P}-submitBtnIcon {
|
|
1083
|
+
background-color: var(--\${P}-focus-button-text-color, var(--\${P}-button-text-color));
|
|
1084
|
+
}
|
|
1085
|
+
.\${P}-wrapper.\${P}-state-filled .\${P}-submitBtn .\${P}-submitBtnIcon {
|
|
1086
|
+
background-color: var(--\${P}-filled-button-text-color, var(--\${P}-button-text-color));
|
|
1087
|
+
}
|
|
1088
|
+
.\${P}-wrapper.\${P}-state-success .\${P}-input,
|
|
1089
|
+
.\${P}-wrapper.\${P}-state-success .\${P}-submitBtn {
|
|
813
1090
|
pointer-events: none;
|
|
814
1091
|
}
|
|
815
|
-
|
|
1092
|
+
.\${P}-overlayAnchor {
|
|
816
1093
|
position: relative;
|
|
817
1094
|
display: flex;
|
|
818
1095
|
align-items: center;
|
|
819
1096
|
}
|
|
820
|
-
|
|
821
|
-
margin-top:
|
|
822
|
-
font-size:
|
|
823
|
-
color: var(
|
|
1097
|
+
.\${P}-success {
|
|
1098
|
+
margin-top: \${sv(8)};
|
|
1099
|
+
font-size: \${sv(14)};
|
|
1100
|
+
color: var(--\${P}-success-success-color, var(--\${P}-success-color));
|
|
1101
|
+
}
|
|
1102
|
+
.\${P}-error {
|
|
1103
|
+
margin-top: \${sv(8)};
|
|
1104
|
+
font-size: \${sv(14)};
|
|
1105
|
+
color: var(--\${P}-error-error-color, var(--\${P}-error-color));
|
|
824
1106
|
}
|
|
825
|
-
|
|
826
|
-
margin-top: ${Ot(8)};
|
|
827
|
-
font-size: ${Ot(14)};
|
|
828
|
-
color: var(--${e}-error-error-color, var(--${e}-error-color));
|
|
1107
|
+
\`;
|
|
829
1108
|
}
|
|
830
|
-
`}const yl=({settings:e,isEditor:t,metadata:n,activeEvent:o})=>{const{prefix:r}=k.useScopedStyles(),{fields:a=[{name:"email",type:"email",placeholder:"Your email"}],buttonContent:i,submitButtonContent:s,buttonLabel:l,buttonIcon:d,fieldsToShow:p=1,fontFamily:_,input:m,button:h,inputFontSettings:c,inputFontSize:u,inputLineHeight:b,inputLetterSpacing:$,inputWordSpacing:f,inputTextAppearance:w,buttonFontSettings:B,buttonFontSize:z,buttonLineHeight:E,buttonLetterSpacing:v,buttonWordSpacing:T,buttonTextAppearance:V,minHeight:W,corners:L,stroke:F,stateOverrides:O,inputPadding:U,buttonPadding:H,successMessage:g="Thanks for subscribing!",errorMessage:R="Please, fill all required fields."}=e,x=a.slice(0,Math.min(p,a.length)),[A,C]=D.useState(()=>Object.fromEntries(x.map(ne=>[ne.name,""]))),[N,q]=D.useState("idle"),[ie,Q]=D.useState(null),me=o==="success"?"success":o==="error"?"error":N,I=o==="error"?R:ie,K=o==="filled"?Object.fromEntries(x.map(ne=>[ne.name,"Filled"])):A,ye=me==="error"?k.getFormFieldValidationError(x,K):null,ae=o&&o!=="default"?`${r}-state-${o}`:"",de=n==null?void 0:n.submitUrl,ge=i,De=(ge==null?void 0:ge.mode)==="Icon"||(ge==null?void 0:ge.mode)==="Label"?ge.mode:s==="Icon"?"Icon":"Label",M=ge===void 0?l:ge.label!==void 0?ge.label:l,y=ge===void 0?d:ge.icon!==void 0?ge.icon:d,P=M??"",G=y??"",J=De==="Icon",re=P||"Submit",Z=c||u!==void 0||b!==void 0||$!==void 0||f!==void 0||w!==void 0?{fontSettings:{fontFamily:_,fontWeight:(c==null?void 0:c.fontWeight)??400,fontStyle:(c==null?void 0:c.fontStyle)??"normal"},fontSize:u??.01,lineHeight:b,letterSpacing:$??0,wordSpacing:f??0,textAppearance:w,color:e.inputTextColor??"#111111"}:m?{...m,fontSettings:{...m.fontSettings,fontFamily:_??m.fontSettings.fontFamily},color:e.inputTextColor??m.color??"#111111"}:void 0,X=B||z!==void 0||E!==void 0||v!==void 0||T!==void 0||V!==void 0?{fontSettings:{fontFamily:_,fontWeight:(B==null?void 0:B.fontWeight)??400,fontStyle:(B==null?void 0:B.fontStyle)??"normal"},fontSize:z??.01,lineHeight:E,letterSpacing:v??0,wordSpacing:T??0,textAppearance:V,color:e.buttonTextColor??"#ffffff"}:h?{...h,fontSettings:{...h.fontSettings,fontFamily:_??h.fontSettings.fontFamily},color:e.buttonTextColor??h.color??"#ffffff"}:void 0,oe=Z?po(Z,t):void 0,ve=X?po(X,t):void 0,le=vl(r,{strokeColor:e.strokeColor,inputColor:e.inputColor,placeholderColor:e.placeholderColor,buttonColor:e.buttonColor,successColor:e.successColor,errorColor:e.errorColor,inputTextColor:e.inputTextColor??(Z==null?void 0:Z.color)??"#111111",buttonTextColor:e.buttonTextColor??(X==null?void 0:X.color)??"#ffffff"},O),ce={borderRadius:k.scalingValue(L,t),borderWidth:k.scalingValue(F,t),borderStyle:"solid",borderColor:`var(--${r}-stroke-color)`},Ne={borderLeftWidth:k.scalingValue(F,t)},ee=async ne=>{ne.preventDefault();const be=Object.fromEntries(x.map(_e=>{var ke;return[_e.name,((ke=A[_e.name])==null?void 0:ke.trim())??""]}).filter(([,_e])=>_e));if(!de||Object.keys(be).length===0)return;const Ce=k.getFormFieldValidationError(x,A);if(Ce){q("error"),Q(Ce);return}q("submitting"),Q(null);try{const _e=await fetch(de,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(be)});if(!_e.ok){const ke=await _e.text();throw new Error(ke||`Request failed: ${_e.status}`)}q("success"),C(Object.fromEntries(x.map(ke=>[ke.name,""])))}catch(_e){q("error"),Q(_e instanceof Error?_e.message:"Something went wrong")}};return S.jsxs("div",{className:`${r}-wrapper ${ae}`.trim(),style:le,children:[S.jsx("style",{children:ml(r)}),S.jsxs("form",{onSubmit:ee,className:`${r}-form`,style:{...ce,minHeight:k.scalingValue(W,t)},children:[S.jsx("div",{className:`${r}-inputWrap ${r}-overlayAnchor`,style:{flex:1,minWidth:0},children:x.map(ne=>S.jsx("input",{type:ne.type==="email"?"email":ne.type==="phone"?"tel":"text",name:ne.name,autoComplete:"off",value:K[ne.name]??"",onChange:be=>C(Ce=>({...Ce,[ne.name]:be.target.value})),placeholder:ne.placeholder,required:ne.type==="email",className:`${r}-input`,style:{...oe,paddingRight:k.scalingValue(U.right,t),paddingLeft:k.scalingValue(U.left,t),paddingTop:k.scalingValue(U.top,t),paddingBottom:k.scalingValue(U.bottom,t)}},ne.name))}),S.jsx("div",{className:`${r}-overlayAnchor`,children:S.jsx("button",{type:"submit",className:`${r}-submitBtn`,"aria-label":re,style:{...ve,...Ne,paddingRight:k.scalingValue(H.right,t),paddingLeft:k.scalingValue(H.left,t),paddingTop:k.scalingValue(H.top,t),paddingBottom:k.scalingValue(H.bottom,t)},children:N==="submitting"?"...":J?G?S.jsx("img",{src:G,alt:"",draggable:!1}):null:P})})]}),me==="success"&&S.jsx("p",{className:`${r}-success`,style:{...oe,lineHeight:oe==null?void 0:oe.fontSize},children:g}),me==="error"&&S.jsx("p",{className:`${r}-error`,style:{...oe,lineHeight:oe==null?void 0:oe.fontSize},role:"alert",children:ye??I??R})]})},uo={strokeColor:"stroke-color",inputColor:"input-color",placeholderColor:"placeholder-color",buttonColor:"button-color",inputTextColor:"input-text-color",buttonTextColor:"button-text-color",successColor:"success-color",errorColor:"error-color"},hl=["hover","focus","filled","success","error"];function vl(e,t,n){const o={};for(const[r,a]of Object.entries(uo))o[`--${e}-${a}`]=t[r];if(n)for(const r of hl){const a=n[r];if(a)for(const[i,s]of Object.entries(uo)){const l=a[i];l!==void 0&&(o[`--${e}-${r}-${s}`]=l)}}return o}function po(e,t){var n,o,r;return{fontFamily:e.fontSettings.fontFamily,fontWeight:e.fontSettings.fontWeight,fontStyle:e.fontSettings.fontStyle,letterSpacing:k.scalingValue(e.letterSpacing,t),wordSpacing:k.scalingValue(e.wordSpacing,t),fontSize:k.scalingValue(e.fontSize,t),lineHeight:e.lineHeight!==void 0?k.scalingValue(e.lineHeight,t):void 0,textTransform:(n=e.textAppearance)==null?void 0:n.textTransform,textDecoration:(o=e.textAppearance)==null?void 0:o.textDecoration,fontVariant:(r=e.textAppearance)==null?void 0:r.fontVariant}}const bl=[{name:"email",type:"email",placeholder:"Enter your email",label:"Email",isRequired:!0,error:"Please, enter a valid e-mail."},{name:"name",type:"text",placeholder:"Enter your name",label:"Name",isRequired:!1,error:"Please, enter your name."},{name:"company",type:"text",placeholder:"Enter company",label:"Company",isRequired:!1,error:"Please, enter your company name."},{name:"phone",type:"phone",placeholder:"Enter your phone",label:"Phone",isRequired:!1,error:"Please, enter a valid phone number."}],go={fontSettings:{type:"object",display:{type:"font-settings-weight"},properties:{fontWeight:{type:"number"},fontStyle:{type:"string"}}}},Sl=["strokeColor","inputColor","inputTextColor","placeholderColor","buttonColor","buttonTextColor","successColor","errorColor"],xl={type:"object",version:1,settings:{sizing:"auto manual",properties:{fieldsToShow:{type:"number",scope:"layout",title:"Fields",display:{type:"number"},min:1,max:3},fields:{type:"array",scope:"common",display:{type:"fields-group"},items:{type:"object",properties:{name:{type:"string"},type:{type:"string",enum:["text","textarea","phone","email"]},placeholder:{type:"string"},label:{type:"string"},isRequired:{type:"boolean"},error:{type:"string"}}}},buttonContent:{type:"object",scope:"common",display:{type:"button-content-switch"},properties:{mode:{type:"string",enum:["Label","Icon"]},label:{type:["string","null"],title:"Label",message:"Subscribe",display:{type:"text-input"}},icon:{type:["string","null"],title:"Icon",display:{type:"settings-image-input"}}}},fontFamily:{type:"string",scope:"layout",title:"Font family",display:{type:"font-family-select"}},inputPadding:{type:"object",scope:"layout",title:"",display:{type:"padding-controls"}},buttonPadding:{type:"object",scope:"layout",title:"",display:{type:"padding-controls"}},minHeight:{type:"number",scope:"layout",title:"min Height",display:{type:"range-control"},min:0,max:200},corners:{type:"number",scope:"layout",title:"Corners",display:{type:"range-control"},min:0,max:100},stroke:{type:"number",scope:"layout",title:"Stroke",display:{type:"range-control"},min:0,max:20},strokeColor:{type:"string",scope:"layout",title:"Border Color",display:{type:"palette-color-picker"}},inputColor:{type:"string",scope:"layout",title:"Input Color",display:{type:"palette-color-picker"}},inputTextColor:{type:"string",scope:"layout",title:"Input Text Color",display:{type:"palette-color-picker"}},placeholderColor:{type:"string",scope:"layout",title:"Placeholder Color",display:{type:"palette-color-picker"}},buttonColor:{type:"string",scope:"layout",title:"Button Color",display:{type:"palette-color-picker"}},buttonTextColor:{type:"string",scope:"layout",title:"Button Text Color",display:{type:"palette-color-picker"}},successColor:{type:"string",scope:"layout",title:"Success Message Color",display:{type:"palette-color-picker"}},errorColor:{type:"string",scope:"layout",title:"Error Message Color",display:{type:"palette-color-picker"}},successMessage:{type:"string",scope:"layout",title:"Success Message",display:{type:"text-input"}},errorMessage:{type:"string",scope:"layout",title:"Error Message",display:{type:"text-input"}},stateOverrides:{type:"object",scope:"layout"},inputFontSettings:{...go.fontSettings,scope:"layout",title:"Input"},inputFontSize:{type:"number",scope:"layout",title:"Input Font Size",display:{type:"font-size"}},inputLineHeight:{type:"number",scope:"layout",title:"Input Line Height",display:{type:"line-height-input"}},inputLetterSpacing:{type:"number",scope:"layout",title:"Input Letter Spacing",display:{type:"letter-spacing-input"}},inputWordSpacing:{type:"number",scope:"layout",title:"Input Word Spacing",display:{type:"word-spacing-input"}},inputTextAppearance:{type:"object",scope:"layout",title:"Input Text Appearance",display:{type:"text-appearance"}},buttonFontSettings:{...go.fontSettings,scope:"layout",title:"Button"},buttonFontSize:{type:"number",scope:"layout",title:"Button Font Size",display:{type:"font-size"}},buttonLineHeight:{type:"number",scope:"layout",title:"Button Line Height",display:{type:"line-height-input"}},buttonLetterSpacing:{type:"number",scope:"layout",title:"Button Letter Spacing",display:{type:"letter-spacing-input"}},buttonWordSpacing:{type:"number",scope:"layout",title:"Button Word Spacing",display:{type:"word-spacing-input"}},buttonTextAppearance:{type:"object",scope:"layout",title:"Button Text Appearance",display:{type:"text-appearance"}}},defaults:{fields:bl,fieldsToShow:1,buttonContent:{mode:"Label",label:"Submit",icon:null},fontFamily:"Arial",inputPadding:{right:.01,left:.01,top:.01,bottom:.01},buttonPadding:{right:.01,left:.01,top:.01,bottom:.01},minHeight:.028,corners:.05,stroke:.001,strokeColor:"#0A00F8",inputColor:"#ffffff",inputTextColor:"#0A00F8",placeholderColor:"#0A00F8",buttonColor:"#0A00F8",buttonTextColor:"#ffffff",errorColor:"#ef4444",successColor:"#22c55e",successMessage:"Thanks for subscribing!",errorMessage:"Please, fill all required fields.",stateOverrides:{},inputFontSettings:{fontWeight:400,fontStyle:"normal"},inputFontSize:.01,inputLineHeight:.01,inputLetterSpacing:0,inputWordSpacing:0,inputTextAppearance:{textTransform:"none",textDecoration:"none",fontVariant:"normal"},buttonFontSettings:{fontWeight:400,fontStyle:"normal"},buttonFontSize:.01,buttonLineHeight:.01,buttonLetterSpacing:0,buttonWordSpacing:0,buttonTextAppearance:{textTransform:"none",textDecoration:"none",fontVariant:"normal"}}},panels:[{id:"general",icon:"cursor",title:"General",tooltip:"General Settings",layout:[{type:"row",items:["__componentName__","fieldsToShow"]},{type:"row",items:["minHeight","corners"]},{type:"row",items:[{type:"group",title:"",items:["stroke","buttonContent"]},{type:"switcher",title:"Padding",options:{Input:["inputPadding"],Button:["buttonPadding"]}}]}]},{id:"typeStyle",icon:"text-icon",title:"Type Style",tooltip:"Typography",layout:["fontFamily",{type:"group",title:"Input",items:["inputFontSettings",{type:"row",items:["inputFontSize","inputLineHeight","inputLetterSpacing","inputWordSpacing"]},"inputTextAppearance"]},{type:"group",title:"Button",items:["buttonFontSettings",{type:"row",items:["buttonFontSize","buttonLineHeight","buttonLetterSpacing","buttonWordSpacing"]},"buttonTextAppearance"]}]},{id:"fields",icon:"layers",title:"Fields",tooltip:"Fields",layout:["fields","successMessage","errorMessage"]}],paletteBookmark:{items:[...Sl],panelIds:["general","typeStyle"],stateItems:{default:["strokeColor","inputColor","inputTextColor","placeholderColor","buttonColor","buttonTextColor"],hover:["strokeColor","inputColor","inputTextColor","buttonColor","buttonTextColor"],focus:["strokeColor","inputColor","inputTextColor","buttonColor","buttonTextColor"],filled:["strokeColor","inputColor","inputTextColor","buttonColor","buttonTextColor"],success:["successColor"],error:["errorColor"]}},states:["default","hover","focus","filled","success","error"]},Cl={element:yl,id:"oneliner-form",name:"Newsletter Single Line",version:1,preview:{type:"image",url:"https://cdn.cntrl.site/component-assets/onelinerImg.png"},defaultSize:{width:"30%",height:60},schema:xl},_l=[ua,ha,il,fl,Cl];exports.components=_l;exports.isSchemaV1=rr;
|
|
1109
|
+
|
|
1110
|
+
type OnelinerFormProps = {
|
|
1111
|
+
settings: OnelinerFormSettings;
|
|
1112
|
+
content?: unknown;
|
|
1113
|
+
isEditor?: boolean;
|
|
1114
|
+
activeEvent?: string;
|
|
1115
|
+
} & CommonComponentProps;
|
|
1116
|
+
|
|
1117
|
+
export const OnelinerForm = ({ settings, isEditor, metadata, activeEvent }: OnelinerFormProps) => {
|
|
1118
|
+
const { prefix: P } = useScopedStyles();
|
|
1119
|
+
const {
|
|
1120
|
+
fields = [{ name: 'email', type: 'email', placeholder: 'Your email' }],
|
|
1121
|
+
buttonContent,
|
|
1122
|
+
buttonLabel,
|
|
1123
|
+
fieldsToShow = 1,
|
|
1124
|
+
fontFamily,
|
|
1125
|
+
inputFontSettings,
|
|
1126
|
+
inputFontSize,
|
|
1127
|
+
inputLineHeight,
|
|
1128
|
+
inputLetterSpacing,
|
|
1129
|
+
inputWordSpacing,
|
|
1130
|
+
inputTextAppearance,
|
|
1131
|
+
buttonFontSettings,
|
|
1132
|
+
buttonFontSize,
|
|
1133
|
+
buttonLineHeight,
|
|
1134
|
+
buttonLetterSpacing,
|
|
1135
|
+
buttonWordSpacing,
|
|
1136
|
+
buttonTextAppearance,
|
|
1137
|
+
statusFontSettings,
|
|
1138
|
+
statusFontSize,
|
|
1139
|
+
statusLineHeight,
|
|
1140
|
+
statusLetterSpacing,
|
|
1141
|
+
statusWordSpacing,
|
|
1142
|
+
statusTextAppearance,
|
|
1143
|
+
minHeight,
|
|
1144
|
+
corners,
|
|
1145
|
+
stroke,
|
|
1146
|
+
stateOverrides,
|
|
1147
|
+
inputPadding,
|
|
1148
|
+
buttonPadding,
|
|
1149
|
+
successMessage = 'Thanks for subscribing!',
|
|
1150
|
+
errorMessage: errorMessageText = 'Please, fill all required fields.',
|
|
1151
|
+
} = settings;
|
|
1152
|
+
|
|
1153
|
+
const visibleFields = fields.slice(0, Math.min(fieldsToShow, fields.length));
|
|
1154
|
+
const [values, setValues] = useState<Record<string, string>>(() =>
|
|
1155
|
+
Object.fromEntries(visibleFields.map((f) => [f.name, '']))
|
|
1156
|
+
);
|
|
1157
|
+
const [status, setStatus] = useState<'idle' | 'submitting' | 'success' | 'error'>('idle');
|
|
1158
|
+
const [errorMessage, setErrorMessage] = useState<string | null>(null);
|
|
1159
|
+
|
|
1160
|
+
const displayStatus = activeEvent === 'success' ? 'success'
|
|
1161
|
+
: activeEvent === 'error' ? 'error'
|
|
1162
|
+
: status;
|
|
1163
|
+
const displayError = activeEvent === 'error' ? errorMessageText : errorMessage;
|
|
1164
|
+
const displayValues = activeEvent === 'filled'
|
|
1165
|
+
? Object.fromEntries(visibleFields.map((f) => [f.name, 'Filled']))
|
|
1166
|
+
: values;
|
|
1167
|
+
const validationErrorMessage = displayStatus === 'error'
|
|
1168
|
+
? getFormFieldValidationError(visibleFields, displayValues)
|
|
1169
|
+
: null;
|
|
1170
|
+
const stateClass = activeEvent && activeEvent !== 'default' ? \`\${P}-state-\${activeEvent}\` : '';
|
|
1171
|
+
const hasFilledFieldValue = visibleFields.some((f) => (displayValues[f.name] ?? '').trim().length > 0);
|
|
1172
|
+
const filledStateClass =
|
|
1173
|
+
stateClass !== \`\${P}-state-filled\` && hasFilledFieldValue ? \`\${P}-state-filled\` : '';
|
|
1174
|
+
const wrapperStateClasses = \`\${stateClass} \${filledStateClass}\`.trim();
|
|
1175
|
+
|
|
1176
|
+
const submitUrl = metadata?.submitUrl as string | undefined;
|
|
1177
|
+
const labelText = buttonLabel ?? '';
|
|
1178
|
+
const iconSrc = buttonContent?.icon ?? '';
|
|
1179
|
+
const useIconButton = buttonContent?.mode === 'On';
|
|
1180
|
+
const submitAriaLabel = labelText || 'Submit';
|
|
1181
|
+
|
|
1182
|
+
const resolvedInputTextStyle: TextStyles = {
|
|
1183
|
+
fontSettings: {
|
|
1184
|
+
fontFamily,
|
|
1185
|
+
fontWeight: inputFontSettings?.fontWeight ?? 400,
|
|
1186
|
+
fontStyle: inputFontSettings?.fontStyle ?? 'normal',
|
|
1187
|
+
},
|
|
1188
|
+
fontSize: inputFontSize ?? 0.01,
|
|
1189
|
+
lineHeight: inputLineHeight,
|
|
1190
|
+
letterSpacing: inputLetterSpacing ?? 0,
|
|
1191
|
+
wordSpacing: inputWordSpacing ?? 0,
|
|
1192
|
+
textAppearance: inputTextAppearance,
|
|
1193
|
+
color: settings.inputTextColor ?? '#111111',
|
|
1194
|
+
};
|
|
1195
|
+
|
|
1196
|
+
const resolvedButtonTextStyle: TextStyles = {
|
|
1197
|
+
fontSettings: {
|
|
1198
|
+
fontFamily,
|
|
1199
|
+
fontWeight: buttonFontSettings?.fontWeight ?? 400,
|
|
1200
|
+
fontStyle: buttonFontSettings?.fontStyle ?? 'normal',
|
|
1201
|
+
},
|
|
1202
|
+
fontSize: buttonFontSize ?? 0.01,
|
|
1203
|
+
lineHeight: buttonLineHeight,
|
|
1204
|
+
letterSpacing: buttonLetterSpacing ?? 0,
|
|
1205
|
+
wordSpacing: buttonWordSpacing ?? 0,
|
|
1206
|
+
textAppearance: buttonTextAppearance,
|
|
1207
|
+
color: settings.buttonTextColor ?? '#ffffff',
|
|
1208
|
+
};
|
|
1209
|
+
|
|
1210
|
+
const resolvedStatusTextStyle: TextStyles = {
|
|
1211
|
+
fontSettings: {
|
|
1212
|
+
fontFamily,
|
|
1213
|
+
fontWeight: statusFontSettings?.fontWeight ?? 400,
|
|
1214
|
+
fontStyle: statusFontSettings?.fontStyle ?? 'normal',
|
|
1215
|
+
},
|
|
1216
|
+
fontSize: statusFontSize ?? 0.01,
|
|
1217
|
+
lineHeight: statusLineHeight,
|
|
1218
|
+
letterSpacing: statusLetterSpacing ?? 0,
|
|
1219
|
+
wordSpacing: statusWordSpacing ?? 0,
|
|
1220
|
+
textAppearance: statusTextAppearance,
|
|
1221
|
+
color: settings.successColor ?? '#22c55e',
|
|
1222
|
+
};
|
|
1223
|
+
|
|
1224
|
+
const inputCss = textStylesToCss(resolvedInputTextStyle, isEditor);
|
|
1225
|
+
const buttonCss = textStylesToCss(resolvedButtonTextStyle, isEditor);
|
|
1226
|
+
const statusCss = textStylesToCss(resolvedStatusTextStyle, isEditor);
|
|
1227
|
+
const colorVars = buildColorVars(P, {
|
|
1228
|
+
strokeColor: settings.strokeColor,
|
|
1229
|
+
inputColor: settings.inputColor,
|
|
1230
|
+
placeholderColor: settings.placeholderColor,
|
|
1231
|
+
buttonColor: settings.buttonColor,
|
|
1232
|
+
successColor: settings.successColor,
|
|
1233
|
+
errorColor: settings.errorColor,
|
|
1234
|
+
inputTextColor: settings.inputTextColor ?? resolvedInputTextStyle?.color ?? '#111111',
|
|
1235
|
+
buttonTextColor: settings.buttonTextColor ?? resolvedButtonTextStyle?.color ?? '#ffffff',
|
|
1236
|
+
}, COLOR_VAR_MAP, STATE_KEYS, stateOverrides);
|
|
1237
|
+
|
|
1238
|
+
const formStyle: React.CSSProperties = {
|
|
1239
|
+
borderRadius: scalingValue(corners, isEditor),
|
|
1240
|
+
borderWidth: scalingValue(stroke, isEditor),
|
|
1241
|
+
borderStyle: 'solid',
|
|
1242
|
+
};
|
|
1243
|
+
|
|
1244
|
+
const dividerWidthStyle = { borderLeftWidth: scalingValue(stroke, isEditor) };
|
|
1245
|
+
|
|
1246
|
+
const handleSubmit = async (e: React.FormEvent) => {
|
|
1247
|
+
e.preventDefault();
|
|
1248
|
+
const payload = Object.fromEntries(
|
|
1249
|
+
visibleFields.map((f) => [f.name, values[f.name]?.trim() ?? '']).filter(([, v]) => v)
|
|
1250
|
+
);
|
|
1251
|
+
if (!submitUrl) {
|
|
1252
|
+
setStatus('error');
|
|
1253
|
+
setErrorMessage('No integrations were found for this form.');
|
|
1254
|
+
return;
|
|
1255
|
+
}
|
|
1256
|
+
if (Object.keys(payload).length === 0) return;
|
|
1257
|
+
|
|
1258
|
+
const validationError = getFormFieldValidationError(visibleFields, values);
|
|
1259
|
+
if (validationError) {
|
|
1260
|
+
setStatus('error');
|
|
1261
|
+
setErrorMessage(validationError);
|
|
1262
|
+
return;
|
|
1263
|
+
}
|
|
1264
|
+
|
|
1265
|
+
setStatus('submitting');
|
|
1266
|
+
setErrorMessage(null);
|
|
1267
|
+
|
|
1268
|
+
try {
|
|
1269
|
+
const res = await fetch(submitUrl, {
|
|
1270
|
+
method: 'POST',
|
|
1271
|
+
headers: { 'Content-Type': 'application/json' },
|
|
1272
|
+
body: JSON.stringify(payload),
|
|
1273
|
+
});
|
|
1274
|
+
|
|
1275
|
+
if (!res.ok) {
|
|
1276
|
+
const text = await res.text();
|
|
1277
|
+
throw new Error(text || \`Request failed: \${res.status}\`);
|
|
1278
|
+
}
|
|
1279
|
+
|
|
1280
|
+
setStatus('success');
|
|
1281
|
+
setValues(Object.fromEntries(visibleFields.map((f) => [f.name, ''])));
|
|
1282
|
+
} catch (err) {
|
|
1283
|
+
setStatus('error');
|
|
1284
|
+
setErrorMessage(err instanceof Error ? err.message : 'Something went wrong');
|
|
1285
|
+
}
|
|
1286
|
+
};
|
|
1287
|
+
|
|
1288
|
+
return (
|
|
1289
|
+
<div className={\`\${P}-wrapper \${wrapperStateClasses}\`.trim()} style={colorVars}>
|
|
1290
|
+
<style dangerouslySetInnerHTML={{ __html: getCSS(P) }} />
|
|
1291
|
+
<form
|
|
1292
|
+
onSubmit={handleSubmit}
|
|
1293
|
+
className={\`\${P}-form\`}
|
|
1294
|
+
style={{
|
|
1295
|
+
...formStyle,
|
|
1296
|
+
height: scalingValue(minHeight, isEditor),
|
|
1297
|
+
minHeight: scalingValue(minHeight, isEditor),
|
|
1298
|
+
}}
|
|
1299
|
+
>
|
|
1300
|
+
<div
|
|
1301
|
+
className={\`\${P}-inputWrap \${P}-overlayAnchor\`}
|
|
1302
|
+
style={{ flex: 1, minWidth: 0 }}
|
|
1303
|
+
>
|
|
1304
|
+
{visibleFields.map((field) => (
|
|
1305
|
+
<input
|
|
1306
|
+
key={field.name}
|
|
1307
|
+
type={field.type === 'email' ? 'email' : field.type === 'phone' ? 'tel' : 'text'}
|
|
1308
|
+
name={field.name}
|
|
1309
|
+
autoComplete="off"
|
|
1310
|
+
value={displayValues[field.name] ?? ''}
|
|
1311
|
+
onChange={(e) => setValues((prev) => ({ ...prev, [field.name]: e.target.value }))}
|
|
1312
|
+
placeholder={field.placeholder}
|
|
1313
|
+
required={field.isRequired ?? field.type === 'email'}
|
|
1314
|
+
className={\`\${P}-input\`}
|
|
1315
|
+
style={{
|
|
1316
|
+
...inputCss,
|
|
1317
|
+
paddingRight: scalingValue(inputPadding.right, isEditor),
|
|
1318
|
+
paddingLeft: scalingValue(inputPadding.left, isEditor),
|
|
1319
|
+
paddingTop: scalingValue(inputPadding.top, isEditor),
|
|
1320
|
+
paddingBottom: scalingValue(inputPadding.bottom, isEditor),
|
|
1321
|
+
}}
|
|
1322
|
+
/>
|
|
1323
|
+
))}
|
|
1324
|
+
</div>
|
|
1325
|
+
<div className={\`\${P}-overlayAnchor\`}>
|
|
1326
|
+
<button
|
|
1327
|
+
type="submit"
|
|
1328
|
+
className={\`\${P}-submitBtn\`}
|
|
1329
|
+
aria-label={submitAriaLabel}
|
|
1330
|
+
style={{
|
|
1331
|
+
...buttonCss,
|
|
1332
|
+
...dividerWidthStyle,
|
|
1333
|
+
paddingRight: scalingValue(buttonPadding.right, isEditor),
|
|
1334
|
+
paddingLeft: scalingValue(buttonPadding.left, isEditor),
|
|
1335
|
+
paddingTop: scalingValue(buttonPadding.top, isEditor),
|
|
1336
|
+
paddingBottom: scalingValue(buttonPadding.bottom, isEditor),
|
|
1337
|
+
}}
|
|
1338
|
+
>
|
|
1339
|
+
{status === 'submitting'
|
|
1340
|
+
? '...'
|
|
1341
|
+
: useIconButton
|
|
1342
|
+
? (iconSrc && (
|
|
1343
|
+
<SvgImage
|
|
1344
|
+
url={iconSrc}
|
|
1345
|
+
className={\`\${P}-submitBtnIcon\`}
|
|
1346
|
+
fill={\`var(--\${P}-button-text-color)\`}
|
|
1347
|
+
hoverFill={\`var(--\${P}-button-text-color)\`}
|
|
1348
|
+
/>
|
|
1349
|
+
))
|
|
1350
|
+
: labelText}
|
|
1351
|
+
</button>
|
|
1352
|
+
</div>
|
|
1353
|
+
</form>
|
|
1354
|
+
{displayStatus === 'success' && (
|
|
1355
|
+
<p
|
|
1356
|
+
className={\`\${P}-success\`}
|
|
1357
|
+
style={{ ...statusCss }}
|
|
1358
|
+
>
|
|
1359
|
+
{successMessage}
|
|
1360
|
+
</p>
|
|
1361
|
+
)}
|
|
1362
|
+
{displayStatus === 'error' && (
|
|
1363
|
+
<p
|
|
1364
|
+
className={\`\${P}-error\`}
|
|
1365
|
+
style={{ ...statusCss }}
|
|
1366
|
+
role="alert"
|
|
1367
|
+
>
|
|
1368
|
+
{validationErrorMessage ?? displayError ?? errorMessageText}
|
|
1369
|
+
</p>
|
|
1370
|
+
)}
|
|
1371
|
+
</div>
|
|
1372
|
+
);
|
|
1373
|
+
};
|
|
1374
|
+
|
|
1375
|
+
type FieldConfig = {
|
|
1376
|
+
name: string;
|
|
1377
|
+
type: 'text' | 'phone' | 'email';
|
|
1378
|
+
placeholder: string;
|
|
1379
|
+
isRequired?: boolean;
|
|
1380
|
+
error?: string;
|
|
1381
|
+
};
|
|
1382
|
+
|
|
1383
|
+
type OnelinerColorKeys =
|
|
1384
|
+
| 'strokeColor'
|
|
1385
|
+
| 'inputColor'
|
|
1386
|
+
| 'placeholderColor'
|
|
1387
|
+
| 'buttonColor'
|
|
1388
|
+
| 'inputTextColor'
|
|
1389
|
+
| 'buttonTextColor'
|
|
1390
|
+
| 'successColor'
|
|
1391
|
+
| 'errorColor';
|
|
1392
|
+
|
|
1393
|
+
type StateColorOverrides = Partial<Record<OnelinerColorKeys, string>>;
|
|
1394
|
+
|
|
1395
|
+
export type OnelinerFormButtonContent = {
|
|
1396
|
+
mode?: 'On' | 'Off';
|
|
1397
|
+
icon?: string | null;
|
|
1398
|
+
};
|
|
1399
|
+
|
|
1400
|
+
export type OnelinerFormSettings = {
|
|
1401
|
+
fields: FieldConfig[];
|
|
1402
|
+
fieldsToShow: number;
|
|
1403
|
+
buttonLabel?: string | null;
|
|
1404
|
+
buttonContent?: OnelinerFormButtonContent | null;
|
|
1405
|
+
fontFamily?: string;
|
|
1406
|
+
inputFontSettings?: { fontWeight: number; fontStyle: string };
|
|
1407
|
+
inputFontSize?: number;
|
|
1408
|
+
inputLineHeight?: number;
|
|
1409
|
+
inputLetterSpacing?: number;
|
|
1410
|
+
inputWordSpacing?: number;
|
|
1411
|
+
inputTextAppearance?: TextStyles['textAppearance'];
|
|
1412
|
+
buttonFontSettings?: { fontWeight: number; fontStyle: string };
|
|
1413
|
+
buttonFontSize?: number;
|
|
1414
|
+
buttonLineHeight?: number;
|
|
1415
|
+
buttonLetterSpacing?: number;
|
|
1416
|
+
buttonWordSpacing?: number;
|
|
1417
|
+
buttonTextAppearance?: TextStyles['textAppearance'];
|
|
1418
|
+
statusFontSettings?: { fontWeight: number; fontStyle: string };
|
|
1419
|
+
statusFontSize?: number;
|
|
1420
|
+
statusLineHeight?: number;
|
|
1421
|
+
statusLetterSpacing?: number;
|
|
1422
|
+
statusWordSpacing?: number;
|
|
1423
|
+
statusTextAppearance?: TextStyles['textAppearance'];
|
|
1424
|
+
minHeight: number;
|
|
1425
|
+
corners: number;
|
|
1426
|
+
stroke: number;
|
|
1427
|
+
inputPadding: {
|
|
1428
|
+
left: number;
|
|
1429
|
+
right: number;
|
|
1430
|
+
top: number;
|
|
1431
|
+
bottom: number;
|
|
1432
|
+
};
|
|
1433
|
+
buttonPadding: {
|
|
1434
|
+
left: number;
|
|
1435
|
+
right: number;
|
|
1436
|
+
top: number;
|
|
1437
|
+
bottom: number;
|
|
1438
|
+
};
|
|
1439
|
+
strokeColor: string;
|
|
1440
|
+
inputColor: string;
|
|
1441
|
+
placeholderColor: string;
|
|
1442
|
+
buttonColor: string;
|
|
1443
|
+
successColor: string;
|
|
1444
|
+
errorColor: string;
|
|
1445
|
+
inputTextColor?: string;
|
|
1446
|
+
buttonTextColor?: string;
|
|
1447
|
+
stateOverrides?: Record<string, StateColorOverrides>;
|
|
1448
|
+
successMessage?: string;
|
|
1449
|
+
errorMessage?: string;
|
|
1450
|
+
};
|
|
1451
|
+
|
|
1452
|
+
const COLOR_VAR_MAP: Record<OnelinerColorKeys, string> = {
|
|
1453
|
+
strokeColor: 'stroke-color',
|
|
1454
|
+
inputColor: 'input-color',
|
|
1455
|
+
placeholderColor: 'placeholder-color',
|
|
1456
|
+
buttonColor: 'button-color',
|
|
1457
|
+
inputTextColor: 'input-text-color',
|
|
1458
|
+
buttonTextColor: 'button-text-color',
|
|
1459
|
+
successColor: 'success-color',
|
|
1460
|
+
errorColor: 'error-color',
|
|
1461
|
+
};
|
|
1462
|
+
|
|
1463
|
+
const STATE_KEYS = ['hover', 'focus', 'filled', 'success', 'error'] as const;
|
|
1464
|
+
`,Il="data:image/svg+xml,"+encodeURIComponent('<svg xmlns="http://www.w3.org/2000/svg" width="6" height="9"><path fill="white" transform="translate(0.0625 0.0595703)" d="M0.18305826 0.18305826C0.40836075 -0.042244215 0.76288015 -0.059575174 1.0080621 0.13106538L1.0669417 0.18305826L4.8169417 3.9330583C5.0422444 4.158361 5.0595751 4.5128803 4.8689346 4.7580624L4.8169417 4.8169417L1.0669417 8.5669422C0.82286406 8.8110189 0.42713594 8.8110189 0.18305826 8.5669422C-0.042244215 8.3416395 -0.059575174 7.9871197 0.13106538 7.7419376L0.18305826 7.6830583L3.4906249 4.375L0.18305826 1.0669417C-0.042244215 0.84163928 -0.059575174 0.48711985 0.13106538 0.24193785L0.18305826 0.18305826Z" fill-rule="evenodd"/></svg>'),kl=[{name:"email",type:"email",placeholder:"Enter your email",label:"Email",isRequired:!0,error:"Please, enter a valid e-mail."},{name:"name",type:"text",placeholder:"Enter your name",label:"Name",isRequired:!1,error:"Please, enter your name."},{name:"company",type:"text",placeholder:"Enter company",label:"Company",isRequired:!1,error:"Please, enter your company name."},{name:"phone",type:"phone",placeholder:"Enter your phone",label:"Phone",isRequired:!1,error:"Please, enter a valid phone number."}],yn={fontSettings:{type:"object",display:{type:"font-settings-weight",visible:!0},properties:{fontWeight:{type:"number"},fontStyle:{type:"string"}}}},Fl=["strokeColor","inputColor","inputTextColor","placeholderColor","buttonColor","buttonTextColor","successColor","errorColor"],Rl={type:"object",version:1,settings:{sizing:"auto manual",properties:{fieldsToShow:{type:"number",scope:"common",title:"Fields",display:{type:"number"},min:1,max:3},fields:{type:"array",scope:"common",display:{type:"fields-group"},items:{type:"object",properties:{name:{type:"string"},type:{type:"string",enum:["text","phone","email"]},placeholder:{type:"string"},label:{type:"string"},isRequired:{type:"boolean"},error:{type:"string"}}}},buttonLabel:{type:"string",scope:"common",title:"Button Label",display:{type:"text-input"}},buttonContent:{type:"object",scope:"common",title:"Button Icon",display:{type:"button-content-switch"},properties:{mode:{type:"string",enum:["On","Off"]},icon:{type:["string","null"],title:"Icon",display:{type:"settings-image-input"}}}},fontFamily:{type:"string",scope:"common",title:"Font family",display:{type:"font-family-select"}},inputPadding:{type:"object",scope:"layout",title:"",display:{type:"padding-controls"}},buttonPadding:{type:"object",scope:"layout",title:"",display:{type:"padding-controls"}},minHeight:{type:"number",scope:"layout",title:"min Height",display:{type:"range-control"},min:0,max:200},corners:{type:"number",scope:"layout",title:"Corners",display:{type:"range-control"},min:0,max:100},stroke:{type:"number",scope:"layout",title:"Stroke",display:{type:"range-control"},min:0,max:20},strokeColor:{type:"string",scope:"common",title:"Stroke",display:{type:"palette-color-picker"}},inputColor:{type:"string",scope:"common",title:"Input Fill",display:{type:"palette-color-picker"}},inputTextColor:{type:"string",scope:"common",title:"Input Label",display:{type:"palette-color-picker"}},placeholderColor:{type:"string",scope:"common",title:"Filler Text",display:{type:"palette-color-picker"}},buttonColor:{type:"string",scope:"common",title:"Button Fill",display:{type:"palette-color-picker"}},buttonTextColor:{type:"string",scope:"common",title:"Button Label",display:{type:"palette-color-picker"}},successColor:{type:"string",scope:"common",title:"Success Message Color",display:{type:"palette-color-picker"}},errorColor:{type:"string",scope:"common",title:"Error Message Color",display:{type:"palette-color-picker"}},successMessage:{type:"string",scope:"common",title:"Success Message",display:{type:"text-input"}},errorMessage:{type:"string",scope:"common",title:"Error Message",display:{type:"text-input"}},stateOverrides:{type:"object",scope:"common"},inputFontSettings:{...yn.fontSettings,scope:"common",title:"Input"},inputFontSize:{type:"number",scope:"layout",title:"Input Font Size",display:{type:"font-size"}},inputLineHeight:{type:"number",scope:"layout",title:"Input Line Height",display:{type:"line-height-input"}},inputLetterSpacing:{type:"number",scope:"layout",title:"Input Letter Spacing",display:{type:"letter-spacing-input"}},inputWordSpacing:{type:"number",scope:"layout",title:"Input Word Spacing",display:{type:"word-spacing-input"}},inputTextAppearance:{type:"object",scope:"layout",title:"Input Text Appearance",display:{type:"text-appearance"}},buttonFontSettings:{...yn.fontSettings,scope:"common",title:"Button"},buttonFontSize:{type:"number",scope:"layout",title:"Button Font Size",display:{type:"font-size"}},buttonLineHeight:{type:"number",scope:"layout",title:"Button Line Height",display:{type:"line-height-input"}},buttonLetterSpacing:{type:"number",scope:"layout",title:"Button Letter Spacing",display:{type:"letter-spacing-input"}},buttonWordSpacing:{type:"number",scope:"layout",title:"Button Word Spacing",display:{type:"word-spacing-input"}},buttonTextAppearance:{type:"object",scope:"layout",title:"Button Text Appearance",display:{type:"text-appearance"}},statusFontSettings:{...yn.fontSettings,scope:"common",title:"Success/Error"},statusFontSize:{type:"number",scope:"layout",title:"Success/Error Font Size",display:{type:"font-size"}},statusLineHeight:{type:"number",scope:"layout",title:"Success/Error Line Height",display:{type:"line-height-input"}},statusLetterSpacing:{type:"number",scope:"layout",title:"Success/Error Letter Spacing",display:{type:"letter-spacing-input"}},statusWordSpacing:{type:"number",scope:"layout",title:"Success/Error Word Spacing",display:{type:"word-spacing-input"}},statusTextAppearance:{type:"object",scope:"layout",title:"Success/Error Text Appearance",display:{type:"text-appearance"}}},defaults:{fields:kl,fieldsToShow:1,buttonLabel:"Subscribe",buttonContent:{mode:"Off",icon:Il},fontFamily:"Arial",strokeColor:"#0A00F8",inputColor:"#ffffff",inputTextColor:"#0A00F8",placeholderColor:"#000000",buttonColor:"#0088D7",buttonTextColor:"#ffffff",errorColor:"#ef4444",successColor:"#22c55e",successMessage:"Thanks for subscribing!",errorMessage:"Please, fill all required fields.",stateOverrides:{hover:{buttonColor:"#33A2F2"}},inputFontSettings:{fontWeight:400,fontStyle:"normal"},inputLetterSpacing:0,inputWordSpacing:0,inputTextAppearance:{textTransform:"none",textDecoration:"none",fontVariant:"normal"},buttonFontSettings:{fontWeight:400,fontStyle:"normal"},buttonLetterSpacing:0,buttonWordSpacing:0,buttonTextAppearance:{textTransform:"uppercase",textDecoration:"none",fontVariant:"normal"},statusFontSettings:{fontWeight:400,fontStyle:"normal"},statusLetterSpacing:0,statusWordSpacing:0,statusTextAppearance:{textTransform:"none",textDecoration:"none",fontVariant:"normal"}},layoutDefaults:{m:{minHeight:.1,stroke:0,corners:0,buttonPadding:{top:.02,right:.04,bottom:.02,left:.04},inputPadding:{top:.01,right:.03,bottom:.01,left:.03},inputFontSize:.043,inputLineHeight:.043,buttonFontSize:.0373,buttonLineHeight:.0373,statusFontSize:.0373,statusLineHeight:.0373},d:{minHeight:.028,stroke:0,corners:0,buttonPadding:{right:.0175,left:.0175,top:.005,bottom:.004},inputPadding:{top:.01,right:.01,bottom:.01,left:.01},inputFontSize:.01,inputLineHeight:.01,buttonFontSize:.009,buttonLineHeight:.01,statusFontSize:.01,statusLineHeight:.01}},displayRules:[{if:{name:"stroke",value:0},then:{name:"properties.strokeColor.display.visible",value:!1}},{if:{name:"buttonContent.mode",value:"On"},then:{name:"properties.buttonFontSettings.display.visible",value:!1}},{if:{name:"buttonContent.mode",value:"On"},then:{name:"properties.buttonFontSize.display.visible",value:!1}},{if:{name:"buttonContent.mode",value:"On"},then:{name:"properties.buttonLineHeight.display.visible",value:!1}},{if:{name:"buttonContent.mode",value:"On"},then:{name:"properties.buttonLetterSpacing.display.visible",value:!1}},{if:{name:"buttonContent.mode",value:"On"},then:{name:"properties.buttonWordSpacing.display.visible",value:!1}},{if:{name:"buttonContent.mode",value:"On"},then:{name:"properties.buttonTextAppearance.display.visible",value:!1}}]},panels:[{id:"general",icon:"cursor",title:"General",tooltip:"General Settings",layout:[{type:"row",items:["__componentName__","fieldsToShow"]},{type:"row",items:["minHeight","corners"]},{type:"row",items:[{type:"group",title:"",items:["stroke","buttonContent"]},{type:"switcher",title:"Padding",options:{Input:["inputPadding"],Button:["buttonPadding"]}}]}]},{id:"typeStyle",icon:"text-icon",title:"Type Style",tooltip:"Typography",layout:["fontFamily",{type:"group",title:"",items:["inputFontSettings",{type:"row",items:["inputFontSize","inputLineHeight","inputLetterSpacing","inputWordSpacing"]},"inputTextAppearance"]},{type:"group",title:"",items:["buttonFontSettings",{type:"row",items:["buttonFontSize","buttonLineHeight","buttonLetterSpacing","buttonWordSpacing"]},"buttonTextAppearance"]},{type:"group",title:"",items:["statusFontSettings",{type:"row",items:["statusFontSize","statusLineHeight","statusLetterSpacing","statusWordSpacing"]},"statusTextAppearance"]}]},{id:"fields",icon:"layers",title:"Fields",tooltip:"Fields",layout:["fields","buttonLabel","successMessage","errorMessage"]}],paletteBookmark:{items:[...Fl],panelIds:["general","typeStyle"],stateItems:{default:["strokeColor","placeholderColor","inputColor","buttonTextColor","buttonColor"],hover:["strokeColor","inputColor","buttonTextColor","buttonColor"],focus:["strokeColor","inputTextColor","buttonTextColor","buttonColor"],filled:["strokeColor","inputColor","inputTextColor","buttonTextColor"],success:["successColor"],error:["errorColor"]}},allowedPlugins:["newsletter"],states:["default","hover","focus","filled","success","error"]},Bl={element:Tl,id:"oneliner-form",name:"Newsletter Single Line",version:1,preview:{type:"image",url:"https://cdn.cntrl.site/component-assets/onelinerImg.png"},defaultSize:{width:400,height:60},schema:Rl,sourceCode:Al},Vl=[Sa,Ea,fl,_l,Bl];exports.components=Vl;exports.isSchemaV1=dr;
|