freemium-survey-components 0.10.40 → 0.10.41

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/lib/index.cjs.js CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e,n=require("react"),t=(e=n)&&"object"==typeof e&&"default"in e?e.default:e,r=require("react-transition-group");function o(e,n){void 0===n&&(n={});var t=n.insertAt;if(e&&"undefined"!=typeof document){var r=document.head||document.getElementsByTagName("head")[0],o=document.createElement("style");o.type="text/css","top"===t&&r.firstChild?r.insertBefore(o,r.firstChild):r.appendChild(o),o.styleSheet?o.styleSheet.cssText=e:o.appendChild(document.createTextNode(e))}}o(".freemium-survey-components .nps-container {\n margin: 0 auto;\n width: 100%;\n display: flex;\n flex-direction: column;\n grid-gap: 28px;\n gap: 28px;\n}\n.freemium-survey-components .nps-container .footer {\n border-top: 1px solid var(--default-background-color);\n border-top: 1px solid var(--background-color, var(--default-background-color));\n padding-top: 20px;\n display: flex;\n justify-content: center;\n font-size: 0.875rem;\n line-height: 1.5;\n color: #666;\n}\n.freemium-survey-components .nps-container .footer:empty {\n display: none;\n}\n.freemium-survey-components .nps-container .nps-scale {\n position: relative;\n}\n.freemium-survey-components .nps-container .nps-scale .button-container {\n display: flex;\n border-radius: 4px;\n justify-content: space-between;\n background: var(--default-background-color);\n background: var(--background-color, var(--default-background-color));\n position: relative;\n margin-bottom: 40px;\n}\n.freemium-survey-components .nps-container .nps-scale .positive-text {\n position: absolute;\n color: #475867;\n bottom: -40px;\n font-size: 12px;\n right: 0px;\n text-align: right;\n}\n.freemium-survey-components .nps-container .nps-scale .negative-text {\n position: absolute;\n color: #475867;\n bottom: -40px;\n font-size: 12px;\n left: 0;\n text-align: left;\n}\n.freemium-survey-components .nps-container .nps-scale span {\n color: #aaa;\n font-size: 0.75rem;\n}\n.freemium-survey-components .nps-container .nps-scale button {\n display: inline-block;\n font-size: 1rem;\n white-space: nowrap;\n vertical-align: middle;\n background: none;\n border: none;\n box-shadow: none;\n cursor: pointer;\n text-align: center;\n font-weight: 400;\n border-radius: 4px;\n margin: 0;\n outline: none;\n margin-left: -1px;\n width: 40px;\n height: 40px;\n transform: scale(1);\n}\n.freemium-survey-components .nps-container .nps-scale button:hover {\n transition: background 0.2s ease-in, border-color 0.2s ease-in, transform 0.2s cubic-bezier(0.5, 2, 0.5, 0.75);\n}\n.freemium-survey-components .nps-container .nps-scale button:hover, .freemium-survey-components .nps-container .nps-scale button:focus {\n color: white;\n transform: scale(1.2);\n z-index: 2;\n position: relative;\n}\n.freemium-survey-components .nps-container .nps-scale button.active {\n color: white;\n transform: scale(1.2);\n z-index: 2;\n position: relative;\n}\n.freemium-survey-components .nps-container .nps-scale.rounded button {\n border-radius: 50%;\n}\n.freemium-survey-components .nps-container .nps-scale.square button {\n border-radius: 0;\n}\n.freemium-survey-components .nps-container .nps-scale.curved button {\n border-radius: 3px;\n}\n.freemium-survey-components .nps-container .nps-scale.highlighted button:hover, .freemium-survey-components .nps-container .nps-scale.highlighted button:focus, .freemium-survey-components .nps-container .nps-scale.highlighted button.active {\n background: var(--default-brand-color) !important;\n background: var(--brand-color, var(--default-brand-color)) !important;\n}\n.freemium-survey-components .nps-container .nps-scale .choices {\n width: 100%;\n display: flex;\n justify-content: space-between;\n font-weight: 500;\n}\n.freemium-survey-components .nps-container .nps-scale.standard .button-container {\n background-color: transparent;\n}\n.freemium-survey-components .nps-container .nps-scale.standard .choice {\n background: #EBEFF3;\n color: #000;\n}\n.freemium-survey-components .nps-container .nps-scale.standard .choice:focus, .freemium-survey-components .nps-container .nps-scale.standard .choice.active, .freemium-survey-components .nps-container .nps-scale.standard .choice:hover {\n background: #E43E3D;\n}\n.freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(1):focus, .freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(1).active, .freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(1):hover, .freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(2):focus, .freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(2).active, .freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(2):hover {\n background: #00AF50;\n}\n.freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(3):hover, .freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(4):hover {\n background: #F8C43E;\n}\n.freemium-survey-components .nps-container .nps-scale.standard .choice:hover, .freemium-survey-components .nps-container .nps-scale.standard .choice:focus, .freemium-survey-components .nps-container .nps-scale.standard .choice.active {\n color: #fff;\n transform: scale(1.2);\n}\n\n.freemium-survey-components.mobile-preview .nps-container .nps-scale .button-container {\n background: transparent;\n}\n.freemium-survey-components.mobile-preview .nps-container .nps-scale .choices {\n flex-wrap: wrap;\n justify-content: center;\n grid-gap: 16px;\n gap: 16px;\n background: transparent;\n}\n.freemium-survey-components.mobile-preview .nps-container .nps-scale button {\n border-radius: 50%;\n background: #ebeff3;\n}\n\n@media (max-width: 550px) {\n .freemium-survey-components .nps-container .nps-scale .button-container,\n.card-survey-style .nps-container .nps-scale .button-container {\n background: transparent;\n }\n .freemium-survey-components .nps-container .nps-scale .choices,\n.card-survey-style .nps-container .nps-scale .choices {\n flex-wrap: wrap;\n justify-content: center;\n grid-gap: 16px;\n gap: 16px;\n background: transparent;\n }\n .freemium-survey-components .nps-container .nps-scale button,\n.card-survey-style .nps-container .nps-scale button {\n border-radius: 50%;\n background: #ebeff3;\n }\n}\n.widget-survey-components .nps-container .nps-scale .button-container {\n background: transparent;\n}\n.widget-survey-components .nps-container .nps-scale .choices {\n flex-wrap: wrap;\n justify-content: center;\n grid-gap: 16px;\n gap: 16px;\n background: transparent;\n}\n.widget-survey-components .nps-container .nps-scale button {\n border-radius: 50%;\n background: #ebeff3;\n}");const s=e=>{const{type_info:{linear_scale:{button_style:r="highlighted",button_shape:o="rounded"}={},rating_presets:{start:s="Very unlikely",end:i="Very likely"}={},validation:{min:a},footer_text:u}}=e,c=e=>{switch(e){case e<=6:return"detractor";case e<=8:return"passive";default:return"promoter"}},l=n.useRef(Array.from({length:10+(0===a?1:0)},((e,n)=>n+a)));return t.createElement("div",{className:"nps-container","data-test-input":"nps"},t.createElement("div",{className:`nps-scale ${o} ${r}`},t.createElement("div",{className:"button-container"},t.createElement("span",{className:"negative-text",role:"note"},`${a} - ${s}`),t.createElement("span",{className:"positive-text",role:"note"},`${l.current[l.current.length-1]} - ${i}`),t.createElement("div",{className:"choices",role:"radiogroup","aria-required":!0},l.current.map((n=>t.createElement("button",{role:"radio","aria-checked":e.npsValue===n,key:n,"data-test-nps-choice":n,onClick:t=>{e.onChangeHandler(n)},className:`choice ${c(n)} ${e.npsValue===n&&"active"}`},n)))))),t.createElement("div",{className:"footer",role:"note"},u))},i=(e,n)=>(e.defaultProps=n,e);o('.freemium-survey-components .input-container,\n.freemium-survey-components .textarea-container {\n display: flex;\n flex-direction: column;\n width: 100%;\n border-radius: 4px;\n position: relative;\n}\n.freemium-survey-components label.input-label {\n display: inline-block;\n padding-bottom: 8px;\n padding-left: 2px;\n font-size: 0.75rem;\n font-weight: 400;\n}\n.freemium-survey-components label.required::after {\n content: "*";\n position: relative;\n top: 2px;\n font-weight: 500;\n font-size: 0.85rem;\n padding-left: 3px;\n color: #d72d30;\n}\n.freemium-survey-components .input-basic {\n width: 100%;\n display: flex;\n align-items: center;\n border-radius: 4px;\n border: 1px solid var(--default-brand-color);\n border: 1px solid var(--brand-color, var(--default-brand-color));\n transition: border-color 0.2s linear;\n background: #fff;\n}\n.freemium-survey-components .textarea-container .input-basic {\n flex-direction: column;\n align-items: unset;\n}\n.freemium-survey-components .input-basic.error {\n border: 1px solid #d72d30;\n}\n.freemium-survey-components .input-basic.error:hover {\n border: 1px solid #d72d30;\n}\n.freemium-survey-components .input-basic.error[focus-within] {\n box-shadow: none;\n}\n.freemium-survey-components .input-basic.error:focus-within {\n box-shadow: none;\n}\n.freemium-survey-components .input-basic:hover {\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n transition: 0.2s linear;\n}\n.freemium-survey-components .input-basic[focus-within] {\n border: 1px solid transparent;\n box-shadow: 0 0 0 2px var(--default-brand-color);\n box-shadow: 0 0 0 2px var(--brand-color, var(--default-brand-color));\n}\n.freemium-survey-components .input-basic:focus-within {\n border: 1px solid transparent;\n box-shadow: 0 0 0 2px var(--default-brand-color);\n box-shadow: 0 0 0 2px var(--brand-color, var(--default-brand-color));\n}\n.freemium-survey-components .input-basic[focus-within] .end-max-length {\n opacity: 1;\n}\n.freemium-survey-components .input-basic:focus-within .end-max-length {\n opacity: 1;\n}\n.freemium-survey-components .end-max-length {\n transition: opacity ease 0.2s;\n opacity: 0;\n padding: 0 8px;\n font-size: 0.75rem;\n color: #264966;\n}\n.freemium-survey-components .textarea-container .end-max-length {\n padding: 8px;\n align-self: flex-end;\n}\n.freemium-survey-components span.input-error {\n display: block;\n padding-left: 2px;\n padding-top: 4px;\n font-size: 0.9rem;\n color: #d72d30;\n}\n.freemium-survey-components input[type=text] {\n padding: 6px 12px;\n flex: 1;\n border: unset;\n height: 32px;\n font-size: 1rem;\n /* line-height: ${typography.input.text.lineHeight}; */\n border-radius: 4px;\n}\n.freemium-survey-components input[type=text],\n.freemium-survey-components textarea {\n outline: none;\n border: none;\n}\n.freemium-survey-components input[type=text]::-moz-placeholder {\n color: #92a2b2;\n font-weight: 400;\n font-size: 0.85rem;\n}\n.freemium-survey-components input[type=text]:-ms-input-placeholder {\n color: #92a2b2;\n font-weight: 400;\n font-size: 0.85rem;\n}\n.freemium-survey-components input[type=text]::placeholder {\n color: #92a2b2;\n font-weight: 400;\n font-size: 0.85rem;\n}\n.freemium-survey-components textarea {\n min-height: 116px;\n padding: 12px;\n flex: 1;\n border: unset;\n resize: none;\n font-size: 1rem;\n /* line-height: ${typography.input.text.lineHeight}; */\n border-radius: 4px;\n}\n.freemium-survey-components textarea::-moz-placeholder {\n color: #92a2b2;\n font-weight: 400;\n font-size: 0.85rem;\n}\n.freemium-survey-components textarea:-ms-input-placeholder {\n color: #92a2b2;\n font-weight: 400;\n font-size: 0.85rem;\n}\n.freemium-survey-components textarea::placeholder {\n color: #92a2b2;\n font-weight: 400;\n font-size: 0.85rem;\n}');const a=["RANGE","NPS","RADIO","DROPDOWN"],u={default:500,compact:500,cozy:400},c={isRequired:!1,showCount:!0,isErrored:!1,inline:!1,spellCheck:!1,autoFocusInput:!0},l=n.forwardRef(((e,r)=>{const o=n.useRef(null);n.useEffect((()=>{e.autoFocusInput&&setTimeout((()=>{o.current?.focus()}),300+e.autoFocusDelay)}),[e.autoFocusInput]);const{inputStyle:s,style:i,className:a,showCount:u,isErrored:c,startLabel:l,isRequired:m,errorText:d,endLabel:p,maxLength:f=300,onChange:y,autoFocusInput:v,...h}=e;return t.createElement("div",{className:"input-container",style:i},e.label&&t.createElement("label",{className:"input-label "+(m?"required":"")},e.label),t.createElement("div",null,l&&t.createElement("div",{className:"start-label"},l),t.createElement("div",{className:`input-basic ${c?"error":""}${a||""}`},t.createElement("input",Object.assign({},h,{type:"text",autoComplete:"off",ref:o,style:s,onChange:e=>{e.target.value?.length>f||y?.(e)}})),u&&f>0&&t.createElement("div",{className:"end-max-length"},`${e.value&&e.value.length||0}/${f}`)),p&&t.createElement("div",{className:"end-label"},p)),c&&d&&t.createElement("span",{className:"input-error"},e.errorText))})),m=n.forwardRef(((e,r)=>{const o=n.useRef(null);n.useEffect((()=>{e.autoFocusInput&&setTimeout((()=>{o.current?.focus()}),300+e.autoFocusDelay)}),[e.autoFocusInput]);const{inputStyle:s,style:i,className:a,showCount:u,maxLength:c=1500,startLabel:l,isRequired:m,autoFocusInput:d,onChange:p,...f}=e;return t.createElement(t.Fragment,null,t.createElement("div",{className:"textarea-container",style:i},e.label&&t.createElement("label",{className:"input-label "+(m?"required":"")},e.label),l&&t.createElement("div",{className:"start-label"},l),t.createElement("div",{className:`input-basic ${a||""}`},t.createElement("textarea",Object.assign({},f,{autoComplete:"off",ref:o,style:s,onChange:e=>{e.target.value?.length>c||p?.(e)}})),u&&c&&c>0&&t.createElement("div",{className:"end-max-length"},`${e.value&&e.value.length||0}/${c}`)),e.endLabel&&t.createElement("div",{className:"end-label"},e.endLabel)))})),d=i(l,c),p=i(m,c);o('.freemium-survey-components .checkbox-group {\n width: 100%;\n display: flex;\n grid-gap: 12px;\n gap: 12px;\n flex-direction: column;\n white-space: nowrap;\n flex-wrap: wrap;\n}\n.freemium-survey-components .icon-container {\n display: inline-block;\n flex: 0 0 12px;\n width: 12px;\n height: 12px;\n min-width: 12px;\n min-height: 12px;\n color: inherit;\n position: absolute;\n left: 1px;\n top: 2px;\n}\n.freemium-survey-components .tick-icon {\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n height: 100%;\n width: 100%;\n color: inherit;\n fill: currentColor;\n}\n.freemium-survey-components input[type=checkbox] {\n position: absolute;\n clip: rect(0px 0px 0px 0px);\n width: 0px;\n height: 0px;\n}\n.freemium-survey-components input[type=checkbox]:focus ~ .checkbox {\n /* box-shadow: ${pseudo.focus} 0px 0px 0px 2px; */\n box-shadow: var(--default-brand-color) 0px 0px 0px 2px;\n box-shadow: var(--brand-color, var(--default-brand-color)) 0px 0px 0px 2px;\n border-color: transparent;\n}\n.freemium-survey-components .checkbox-label {\n display: flex;\n align-items: baseline;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n text-align: left;\n opacity: 1;\n line-height: 1.2;\n cursor: pointer;\n font-size: 1rem;\n padding: 16px 24px;\n min-width: 200px;\n border: 1px solid #ebeff3;\n border-radius: 4px;\n white-space: pre-wrap;\n}\n.freemium-survey-components .checkbox-label:hover .checkbox {\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n box-shadow: var(--default-background-color) 0px 0px 0px 5px;\n box-shadow: var(--background-color, var(--default-background-color)) 0px 0px 0px 5px;\n}\n.freemium-survey-components .checkbox-label.disabled {\n opacity: 0.5;\n cursor: "not-allowed";\n}\n.freemium-survey-components .checkbox {\n transition: background-color ease-in 0.2s;\n min-width: 14px;\n min-height: 14px;\n min-height: 14px;\n max-height: 14px;\n border-radius: 2px;\n position: relative;\n margin-right: 16px;\n background-color: #fff;\n border: 1px solid;\n text-align: left;\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n}\n.freemium-survey-components .checkbox:hover {\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n box-shadow: var(--default-background-color) 0px 0px 0px 5px;\n box-shadow: var(--background-color, var(--default-background-color)) 0px 0px 0px 5px;\n}\n.freemium-survey-components input[type=checkbox]:checked ~ .checkbox {\n background-color: var(--default-brand-color);\n background-color: var(--brand-color, var(--default-brand-color));\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n}\n.freemium-survey-components input[type=checkbox]:checked ~ .checkbox:hover {\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n}\n.freemium-survey-components input[type=checkbox]:disabled ~ .checkbox:hover {\n box-shadow: unset;\n border-color: unset;\n}');const f=()=>t.createElement("svg",{id:"tick",className:"tick-icon",xmlns:"http://www.w3.org/2000/svg","aria-labelledby":"title",viewBox:"0 0 10 10"},t.createElement("path",{d:"M3 5.87c-.18666814.00267463-.36667109-.06932655-.5-.2L.21 3.41c-.1786328-.17863279-.24839684-.43899577-.1830127-.6830127.06538414-.24401694.25598306-.43461586.5-.5C.77100423 2.16160316 1.0313672 2.23136721 1.21 2.41L3 4.18 6.8.33c.27679776-.27455556.72320224-.27455556 1 0 .13696438.13025306.21450026.31098915.21450026.5S7.93696438 1.19974694 7.8 1.33L3.45 5.67c-.12082534.11896945-.28072735.19003701-.45.2Z",fill:"#fff",fillRule:"evenodd"})),y=({values:e=[],othersValue:r="",options:o,name:s,autoFocusGroup:i,autoFocusDelay:a,onChangeHandler:u,saveOthersValue:c,othersOption:l,othersRequired:m})=>{const[p,f]=n.useState(!1),y=n.useRef(null);return n.useEffect((()=>{i&&setTimeout((()=>{y.current?.focus()}),300+a)}),[i]),t.createElement("div",{className:"checkbox-group"},t.createElement("button",{ref:y,className:"autofocus-button","aria-hidden":!0}),o?.map(((n,r)=>t.createElement(v,{key:n.id,checked:e?.includes(n.value),name:n.value,id:n.id,onChange:(t,r)=>{if(r)u([...e||[],n.value]);else{const t=e.indexOf(n.value);t>-1&&e.splice(t,1),u([...e])}}},n.value))),l&&t.createElement(v,{key:"others",checked:p,name:"others",id:"others",onChange:(n,t)=>{if(f(t),t)u([...e,"others"]);else{const n=e.findIndex((e=>"others"===e));e.splice(n,1),u(e)}}},"Others"),p&&t.createElement(t.Fragment,null,t.createElement(d,{placeholder:"Enter your comment",value:r[s],onChange:e=>{c(s,e.target.value)},autoFocusDelay:10,label:""})))},v=i((e=>{const r=n.useRef(null);return n.useEffect((()=>{e.autoFocus&&setTimeout((()=>{r.current?.focus()}),320)}),[]),t.createElement("label",{className:`checkbox-label ${e.disabled&&"disabled"}`},t.createElement("input",{ref:r,id:e.id,type:"checkbox",name:e.name,readOnly:e.readOnly,disabled:e.disabled,"aria-disabled":e.disabled,checked:e.checked,onChange:e.readOnly?()=>{}:n=>e.onChange(n,n.target.checked)}),t.createElement("div",{className:"checkbox"},e.checked&&t.createElement("div",{className:"icon-container"},t.createElement(f,null)," ")),t.createElement("div",null,e.children))}),{checked:!1});o('.freemium-survey-components .radio-group {\n display: flex;\n grid-gap: 12px;\n gap: 12px;\n white-space: nowrap;\n flex-direction: column;\n width: 100%;\n}\n.freemium-survey-components .radio {\n background-color: #fff;\n border: 1px solid;\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n transition: background-color ease-in 0.2s;\n min-width: 18px;\n max-width: 18px;\n min-height: 18px;\n max-height: 18px;\n border-radius: 50%;\n position: relative;\n margin-right: 16px;\n text-align: left;\n}\n.freemium-survey-components .radio:before {\n left: 3px;\n top: 3px;\n content: "";\n position: absolute;\n width: 10px;\n height: 10px;\n border-radius: 50%;\n transition: all ease-in 0.2s;\n background-color: #fff;\n}\n.freemium-survey-components .radio-label {\n display: flex;\n align-items: baseline;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n text-align: left;\n cursor: pointer;\n line-height: 1.2;\n font-size: 1rem;\n font-weight: 400;\n padding: 16px 24px;\n min-width: 200px;\n border: 1px solid #ebeff3;\n border-radius: 4px;\n white-space: pre-wrap;\n}\n.freemium-survey-components input[type=radio] {\n position: absolute;\n clip: rect(0, 0, 0, 0);\n width: 0px;\n height: 0px;\n}\n.freemium-survey-components input[type=radio]:focus ~ .radio {\n /* box-shadow: ${pseudo.focus} 0px 0px 0px 3px; */\n box-shadow: var(--default-brand-color) 0px 0px 0px 3px;\n box-shadow: var(--brand-color, var(--default-brand-color)) 0px 0px 0px 3px;\n border-color: transparent;\n}\n.freemium-survey-components input[type=radio]:checked ~ .radio:before {\n background-color: var(--default-brand-color);\n background-color: var(--brand-color, var(--default-brand-color));\n}\n.freemium-survey-components .radio-label:hover .radio {\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n box-shadow: var(--default-background-color) 0px 0px 0px 5px;\n box-shadow: var(--background-color, var(--default-background-color)) 0px 0px 0px 5px;\n}');const h=({name:e,options:r,value:o,autoFocusGroup:s,autoFocusDelay:i,onChangeHandler:a,saveOthersValue:u,othersOption:c,othersRequired:l,othersValue:m})=>{const[p,f]=n.useState(m??""),[y,v]=n.useState(o),h=n.useRef(null);return n.useEffect((()=>{s&&setTimeout((()=>{h.current?.focus()}),300+i)}),[s]),n.useEffect((()=>{o||(f(""),v(null))}),[o]),n.useEffect((()=>{y&&r.find((e=>e.value===y))&&y!==o&&a(y)}),[y]),t.createElement("div",{className:"radio-group",role:"radiogroup"},t.createElement("button",{ref:h,className:"autofocus-button","aria-hidden":!0,tabIndex:-1}),r?.map(((n,r)=>t.createElement(x,{key:n.value,value:n.value,name:e,onChange:e=>{v(e.currentTarget.value)},checked:y===n.value},n.value))),c&&t.createElement(x,{key:"others",value:"others",name:e,onChange:e=>{v("others")},checked:"others"===y},"Others"),"others"===y&&t.createElement(t.Fragment,null,t.createElement(d,{value:p,onChange:e=>f(e.target.value),placeholder:"Enter your comment",label:"",autoFocusDelay:10}),p!==o&&t.createElement(w,{inline:!0,disabled:l&&0===p.length,onClick:()=>{a("others"),u(e,p)}},"Next")))},x=i((e=>{const r=n.useRef(null);return n.useEffect((()=>{e.autoFocus&&setTimeout((()=>{r.current?.focus()}),320)}),[]),t.createElement("label",{className:"radio-label"},t.createElement("input",{ref:r,type:"radio",name:e.name,value:e.value,checked:e.checked,onChange:e.onChange}),t.createElement("div",{className:"radio"}),t.createElement("div",null,e.children))}),{checked:!1,autoFocus:!1});o(".progressbar-container {\n width: 100%;\n height: 4px;\n position: fixed;\n top: 0;\n left: 0;\n z-index: 1;\n text-align: left;\n}\n\n.progressbar {\n transition: transform 0.3s linear 200ms;\n transform-origin: left;\n height: 100%;\n background-color: var(--default-brand-color);\n background-color: var(--brand-color, var(--default-brand-color));\n}");const g=e=>{const{totalSteps:n,completedSteps:r}=e;return t.createElement("div",{className:"progressbar-container"},t.createElement("div",{className:"progressbar",style:{width:(r>0?100/n:0)+"%",transform:`scaleX(${r})`}}))};o(".freemium-survey-components .action-button {\n width: auto;\n display: block;\n padding: 8px 16px;\n cursor: pointer;\n line-height: 1.5;\n text-align: center;\n font-weight: 600;\n letter-spacing: 0.3px;\n border-radius: 4px;\n white-space: nowrap;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n color: --default-button-text-color;\n color: var(--button-text-color, --default-button-text-color);\n background: var(--default-brand-color);\n background: var(--brand-color, var(--default-brand-color));\n border: 1px solid var(--default-brand-color);\n border: 1px solid var(--brand-color, var(--default-brand-color));\n border-radius: 4px;\n min-width: 200px;\n max-width: -webkit-fit-content;\n max-width: -moz-fit-content;\n max-width: fit-content;\n transform: translateY(0px);\n transition: transform ease 0.2s;\n}\n.freemium-survey-components .action-button:not([disabled]):hover {\n transform: translateY(-4px);\n}\n.freemium-survey-components .action-button[disabled] {\n cursor: not-allowed;\n opacity: 0.6;\n}\n.freemium-survey-components button:focus:not(:active) {\n /* box-shadow: 0 0 0 2px ${pseudo.focus}; */\n}\n\n@media (max-width: 550px) {\n .freemium-survey-components .action-button {\n min-width: 120px;\n }\n}\n.widget-survey-components .action-button {\n min-width: 120px;\n}\n\n.freemium-survey-components.mobile-preview .action-button {\n min-width: 120px;\n}");const b=()=>t.createElement(t.Fragment,null,"..."),w=e=>{const{inline:n=!1,children:r,disabled:o,className:s="",htmlType:i,type:a="primary",onClick:u,size:c,overrideStyleClassName:l="",loading:m=!1,...d}=e;return t.createElement("button",Object.assign({style:n?{display:"inline-block"}:{},disabled:o,className:`action-button ${s} ${l}`,type:i,onClick:u},d),m?t.createElement(b,null):r)},k=()=>t.createElement("svg",{style:{display:"block"},width:"9",height:"14",viewBox:"0 0 10 16",fill:"none",xmlns:"http://www.w3.org/2000/svg"},t.createElement("path",{d:"M7.82585 6.15754C7.98999 6.32147 8.08232 6.54389 8.08252 6.77587L8.08252 7.2192C8.07983 7.45069 7.98788 7.6722 7.82585 7.83754L1.82919 13.8225C1.77496 13.8772 1.71044 13.9206 1.63936 13.9502C1.56827 13.9798 1.49203 13.9951 1.41502 13.9951C1.33801 13.9951 1.26177 13.9798 1.19068 13.9502C1.1196 13.9206 1.05508 13.8772 1.00085 13.8225L0.172521 12.9942C0.118197 12.941 0.0750381 12.8774 0.0455752 12.8073C0.0161124 12.7372 0.000937578 12.6619 0.000937585 12.5859C0.000937592 12.5098 0.0161125 12.4345 0.0455753 12.3644C0.0750381 12.2943 0.118197 12.2308 0.172521 12.1775L5.36419 6.99754L0.172522 1.81754C0.117847 1.76331 0.0744506 1.69879 0.0448352 1.62771C0.0152208 1.55662 -2.75162e-05 1.48038 -2.75094e-05 1.40337C-2.75027e-05 1.32636 0.0152208 1.25012 0.0448353 1.17904C0.0744507 1.10795 0.117847 1.04343 0.172522 0.989205L1.00086 0.172537C1.05508 0.117862 1.1196 0.0744661 1.19069 0.0448507C1.26177 0.0152353 1.33801 -1.20337e-05 1.41502 -1.2027e-05C1.49203 -1.20203e-05 1.56827 0.0152353 1.63936 0.0448507C1.71044 0.0744661 1.77496 0.117862 1.82919 0.172537L7.82585 6.15754Z",fill:"#6B6B6B"})),q=()=>t.createElement("svg",{style:{display:"block"},width:"9",height:"14",viewBox:"0 0 10 16",fill:"none",xmlns:"http://www.w3.org/2000/svg"},t.createElement("path",{d:"M0.256667 7.83755C0.0925257 7.67361 0.000204227 7.4512 0 7.21921V6.77588C0.00268801 6.5444 0.0946357 6.32289 0.256667 6.15755L6.25333 0.172549C6.30756 0.117874 6.37208 0.0744776 6.44316 0.0448625C6.51425 0.0152474 6.59049 0 6.6675 0C6.74451 0 6.82075 0.0152474 6.89184 0.0448625C6.96292 0.0744776 7.02744 0.117874 7.08167 0.172549L7.91 1.00088C7.96432 1.05411 8.00748 1.11764 8.03694 1.18776C8.06641 1.25787 8.08158 1.33316 8.08158 1.40922C8.08158 1.48527 8.06641 1.56056 8.03694 1.63067C8.00748 1.70079 7.96432 1.76432 7.91 1.81755L2.71833 6.99755L7.91 12.1775C7.96467 12.2318 8.00807 12.2963 8.03769 12.3674C8.0673 12.4385 8.08255 12.5147 8.08255 12.5917C8.08255 12.6687 8.0673 12.745 8.03769 12.8161C8.00807 12.8871 7.96467 12.9517 7.91 13.0059L7.08167 13.8225C7.02744 13.8772 6.96292 13.9206 6.89184 13.9502C6.82075 13.9799 6.74451 13.9951 6.6675 13.9951C6.59049 13.9951 6.51425 13.9799 6.44316 13.9502C6.37208 13.9206 6.30756 13.8772 6.25333 13.8225L0.256667 7.83755Z",fill:"#6B6B6B"})),E=({question:e,formValues:n,othersMeta:r,onChangeHandler:o,saveOthersValue:i,autoFocus:a,autoFocusDelay:u})=>{switch(e.type_info.question_type){case"RANGE":return t.createElement(s,{type_info:e.type_info,onChangeHandler:o,npsValue:n[e.name]});case"CHECKBOX":case"MULTI_SELECT":return t.createElement(y,{name:e.name,autoFocusGroup:a,values:n[e.name],othersValue:r[e.name],options:e.type_info.choices,onChangeHandler:o,saveOthersValue:i,othersOption:e.type_info.meta?.othersOption,othersRequired:e.type_info.meta?.othersRequired,autoFocusDelay:u});case"RADIO":case"DROPDOWN":return t.createElement(h,{autoFocusGroup:a,autoFocusDelay:u,name:e.name,onChangeHandler:o,saveOthersValue:i,options:e.type_info.choices,value:n[e.name],othersValue:r[e.name],othersOption:e.type_info.meta?.othersOption,othersRequired:e.type_info.meta?.othersRequired});case"INPUT":case"TEXT":return e.type_info?.meta?.readOnly?t.createElement("div",{className:"message-container"},e.type_info?.meta?.value):t.createElement("div",{className:"responsive-text-field"},t.createElement(d,{autoFocusInput:a,autoFocusDelay:u,label:"",isRequired:e.is_required,value:n[e.name]||"",placeholder:e.type_info?.meta?.placeholder??"",onChange:e=>o(e.target.value)}),t.createElement(p,{autoFocusInput:a,autoFocusDelay:u,label:"",isRequired:e.is_required,placeholder:e.type_info?.meta?.placeholder??"",value:n[e.name]||"",onChange:e=>o(e.target.value)}));case"PARAGRAPH":return t.createElement(p,{autoFocusInput:a,autoFocusDelay:u,label:"",isRequired:e.is_required,placeholder:e.type_info?.meta?.placeholder??"",value:n[e.name]||"",onChange:e=>o(e.target.value)});default:return console.error(`Question type ${e.type_info.question_type} not found`),null}},_=(e,n,t)=>{if(e){let r={"{{nps.rating}}":t};n&&(r={...r,...n});const o=new RegExp(Object.keys(r).join("|"),"gi");e=e.replace(o,(function(e){return r[e.toLowerCase()]}))}return e},C=e=>n.useMemo((()=>{const n=JSON.parse(JSON.stringify(e)),t=[];return(n.question_details?.questions||[]).forEach((e=>{const n=e.type_info?.meta?.block;n&&(n.question_names||(n.question_names=[e.name]),t.push(n))})),{...n,meta:{...n.meta,blocks:t}}}),[e]);o(":root {\n --default-brand-color: #264966;\n --default-question-text-color: #000;\n --default-question-background-color: #fff;\n --default-background-color: #f8f8f8;\n --default-button-text-color: #fff;\n --default-secondary-button-text-color: #000;\n --default-input-placeholder-color: #92a2b1;\n --compact-widget-max-height: 560px;\n --default-widget-max-height: 400px;\n --cozy-widget-max-height: 380px;\n}\n\n.freemium-survey-components.card-survey-style {\n padding: 20px 0;\n}\n.freemium-survey-components.card-survey-style .freemium-survey-step-navigation {\n white-space: nowrap;\n border-radius: 3px;\n border: 1px solid #efefef;\n}\n.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button {\n width: 38px;\n text-align: -webkit-center;\n height: 38px;\n background-color: #fff;\n border: none;\n cursor: pointer;\n border-radius: 0 3px 3px 0;\n}\n.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button svg {\n transform: rotate(90deg);\n}\n.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button:first-of-type {\n border-right: 1px solid #efefef;\n border-radius: 3px 0 0 3px;\n}\n.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button:disabled {\n cursor: not-allowed;\n opacity: 0.5;\n}\n.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button:focus {\n position: relative;\n z-index: 1;\n}\n.freemium-survey-components.card-survey-style .question-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n text-align: center;\n max-width: 700px;\n margin: 0 auto;\n background: var(--default-question-background-color);\n background: var(--question-background-color, var(--default-question-background-color));\n border-radius: 4px;\n transition: transform 500ms ease 0ms, opacity 200ms ease 0ms;\n box-shadow: 0px 12px 15px rgba(18, 52, 77, 0.03);\n padding: 28px;\n grid-gap: 28px;\n gap: 28px;\n position: relative;\n height: -webkit-fit-content;\n height: -moz-fit-content;\n height: fit-content;\n transition: opacity 50ms ease-out;\n overflow: auto;\n}\n.freemium-survey-components.card-survey-style .hide-question-container {\n opacity: 0;\n}\n.freemium-survey-components.card-survey-style .question-text {\n font-size: 1rem;\n font-weight: 600;\n line-height: 1.8;\n width: 100%;\n text-align: left;\n color: var(--default-question-text-color);\n color: var(--question-text-color, var(--default-question-text-color));\n}\n.freemium-survey-components.card-survey-style .autofocus-button {\n border: none;\n width: 0;\n height: 0;\n opacity: 0;\n margin-top: -12px;\n margin-left: -12px;\n position: absolute;\n}\n.freemium-survey-components.card-survey-style .fade-enter .question-container {\n opacity: 0;\n transform: translateY(15px);\n}\n.freemium-survey-components.card-survey-style .fade-enter-active .question-container {\n opacity: 1;\n transform: translateY(0);\n}\n.freemium-survey-components.card-survey-style .fade-exit .question-container {\n opacity: 1;\n transform: translateY(0);\n}\n.freemium-survey-components.card-survey-style .fade-exit-active .question-container {\n opacity: 0.05;\n transform: translateY(-15px);\n}\n.freemium-survey-components.card-survey-style .fade-reverse-enter .question-container {\n opacity: 0;\n transform: translateY(-15px);\n}\n.freemium-survey-components.card-survey-style .fade-reverse-enter-active .question-container {\n opacity: 1;\n transform: translateY(0);\n}\n.freemium-survey-components.card-survey-style .fade-reverse-exit .question-container {\n opacity: 1;\n transform: translateY(0);\n}\n.freemium-survey-components.card-survey-style .fade-reverse-exit-active .question-container {\n opacity: 0.05;\n transform: translateY(15px);\n}\n.freemium-survey-components.card-survey-style .fade-enter-active .question-container,\n.freemium-survey-components.card-survey-style .fade-exit-active .question-container,\n.freemium-survey-components.card-survey-style .fade-reverse-enter-active .question-container,\n.freemium-survey-components.card-survey-style .fade-reverse-exit-active .question-container {\n transition: opacity 300ms, transform 300ms;\n}\n.freemium-survey-components.card-survey-style .question-footer {\n display: flex;\n grid-gap: 40px;\n gap: 40px;\n width: 100%;\n align-items: center;\n}\n.freemium-survey-components.card-survey-style .question-footer:empty {\n display: none;\n}\n.freemium-survey-components.card-survey-style .question-footer:only-child {\n margin-left: auto;\n}\n.freemium-survey-components.card-survey-style .action-buttons {\n display: flex;\n grid-gap: 20px;\n gap: 20px;\n flex-direction: row-reverse;\n width: 100%;\n}\n.freemium-survey-components.card-survey-style .action-buttons:empty {\n display: none;\n}\n.freemium-survey-components.card-survey-style .skip-button {\n font-weight: 500;\n cursor: pointer;\n background: transparent;\n border: none;\n min-width: 40px;\n padding: 8px 16px;\n border-radius: 4px;\n color: var(--default-secondary-button-text-color);\n color: var(--secondary-button-text-color, var(--default-secondary-button-text-color));\n letter-spacing: 0.05rem;\n line-height: 1.5;\n border: 1px solid transparent;\n transform: translateY(0px);\n transition: transform ease 0.2s;\n}\n.freemium-survey-components.card-survey-style .skip-button:hover {\n background-color: #f3f3f3;\n transform: translateY(-4px);\n}\n.freemium-survey-components.card-survey-style .next-button {\n color: var(--default-button-text-color);\n color: var(--button-text-color, var(--default-button-text-color));\n}\n.freemium-survey-components.card-survey-style .submit {\n max-width: 700px;\n text-align: left;\n background: transparent;\n box-shadow: none;\n color: var(--default-button-text-color);\n color: var(--button-text-color, var(--default-button-text-color));\n}\n.freemium-survey-components.card-survey-style .thankyou {\n display: flex;\n align-items: center;\n justify-content: center;\n grid-gap: 20px;\n gap: 20px;\n min-height: 180px;\n}\n.freemium-survey-components.card-survey-style .thankyou .heading {\n font-weight: 600;\n font-size: 28px;\n}\n.freemium-survey-components.card-survey-style .thankyou .text {\n white-space: pre-wrap;\n font-weight: 500;\n font-size: 0.875rem;\n line-height: 1.6;\n color: #12344d;\n width: 75%;\n}\n.freemium-survey-components.card-survey-style .thankyou .redirection-text {\n color: #929292;\n margin-bottom: 12px;\n font-weight: 300;\n}\n.freemium-survey-components.card-survey-style .thankyou .link {\n width: 100%;\n display: inline-block;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n color: #666;\n font-weight: 500;\n text-decoration: underline;\n}\n.freemium-survey-components.card-survey-style .responsive-text-field {\n width: 100%;\n}\n.freemium-survey-components.card-survey-style .responsive-text-field .textarea-container {\n display: none;\n}\n.freemium-survey-components.card-survey-style .message-container:empty {\n display: none;\n}\n\n@media (max-width: 550px) {\n div.freemium-survey-components.card-survey-style .responsive-text-field .input-container {\n display: none;\n }\n div.freemium-survey-components.card-survey-style .responsive-text-field .textarea-container {\n display: flex;\n }\n div.freemium-survey-components.card-survey-style .question-footer {\n flex-direction: column-reverse;\n grid-gap: 20px;\n gap: 20px;\n }\n div.freemium-survey-components.card-survey-style .freemium-survey-step-navigation {\n width: 100%;\n }\n div.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button {\n width: 50%;\n }\n div.freemium-survey-components.card-survey-style .action-buttons {\n flex-direction: column;\n width: 100%;\n }\n div.freemium-survey-components.card-survey-style .action-buttons button {\n max-width: unset;\n }\n div.freemium-survey-components.card-survey-style .action-button {\n max-width: unset;\n width: 100%;\n }\n div.freemium-survey-components.card-survey-style .thankyou .text {\n width: auto;\n }\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .responsive-text-field .input-container {\n display: none;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .responsive-text-field .textarea-container {\n display: flex;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .question-footer {\n flex-direction: column-reverse;\n grid-gap: 20px;\n gap: 20px;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .freemium-survey-step-navigation {\n width: 100%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .freemium-survey-step-navigation .navigation-button {\n width: 50%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .action-buttons {\n flex-direction: column;\n width: 100%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .action-buttons button {\n max-width: unset;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .action-button {\n max-width: unset;\n width: 100%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .thankyou .text {\n width: auto;\n}\n\n.freemium-survey-components.mobile-preview .thankyou .text {\n width: unset;\n}");const S=({thankYouQuestion:e,preview:r,placeholders:o,npsValue:s})=>(n.useEffect((()=>{r||e.type_info.meta?.redirectUrl&&setTimeout((()=>{window.location.href=e.type_info.meta?.redirectUrl}),e.type_info.meta?.redirectDelay??1e4)}),[]),t.createElement("div",{className:"question-container thankyou"},t.createElement("div",{className:"heading"},"Thank you!"),t.createElement("div",{className:"text",dangerouslySetInnerHTML:{__html:_(e.text,o,s)}}),e.type_info.meta?.redirectUrl&&t.createElement("div",{style:{width:"100%"}},t.createElement("div",{className:"redirection-text"},"You will be redirected to the below URL automatically in"," ",e.type_info.meta?.redirectDelay," seconds.",t.createElement("br",null)),t.createElement("a",{className:"link",href:e.type_info.meta?.redirectUrl},e?.type_info.meta?.redirectUrl)))),N=({currentBlockIndex:e,currentBlockIndexOfBlocksWithQns:n,blocksWithQns:r,blocks:o,setHorizontalScrollUnits:s,preventQuestionAnimation:i,tempCurrentBlockIndexOfBlocksWithQns:a,setReverse:u,reverse:c})=>t.createElement("div",{className:"freemium-survey-step-navigation","data-navigation-element":"1"},t.createElement("button",{disabled:0==n.current,className:"navigation-button",onClick:()=>{c?n.current=Math.max(n.current-1,0):a.current=Math.max(n.current-1,0),i.current=!1,u(!0),s(n.current)}},t.createElement(q,null)),t.createElement("button",{className:"navigation-button",disabled:n.current>=r.length-1,onClick:()=>{i.current=!1,c?a.current=Math.min(n.current+1,r.length-1):n.current=Math.min(n.current+1,r.length-1),u(!1),s(n.current)}},t.createElement(k,null))),B=({widget:e,surveyStyle:n,formValues:r,blocksWithQns:o,blocks:s,thankYouQuestion:i,currentBlockIndexOfBlocksWithQns:u,currentBlockIndexOfBlocks:c,currentEditingBlock:l,isSubmitting:m,isValuesCommitted:d,isCurrentBlockFinal:p,setHorizontalScrollUnits:f,handleFormValues:y,skipBlock:v,setIsSubmitting:h,onSubmit:x,setIsSurveyCompleted:g,preventQuestionAnimation:b,preview:k,closePreview:q,setReverse:E,tempCurrentBlockIndexOfBlocksWithQns:_,question:C,reverse:S,othersMeta:B,...I})=>{const R=I.blockIndex??u.current,z=()=>!a.includes(C.type_info.question_type)&&!p(),O=()=>"RANGE"!==C.type_info.question_type&&!C.required&&!p(),T=()=>("DROPDOWN"===C.type_info.question_type&&!C.required&&r[C.name],!1),Q=()=>p()&&(e||"standard"!==n),F="MULTI_SELECT"===l.current.question.type_info.question_type&&r[l.current.question.name]?.includes("others")&&(!B[l.current.question.name]||""===B[l.current.question.name]);return t.createElement("div",{className:"question-footer"},!(!e&&"standard"===n||0===R&&void 0===r[C.name]||0===u.current&&!S)&&t.createElement(N,{currentBlockIndex:c,currentBlockIndexOfBlocksWithQns:u,blocksWithQns:o,blocks:s,setHorizontalScrollUnits:f,preventQuestionAnimation:b,setReverse:E,tempCurrentBlockIndexOfBlocksWithQns:_,reverse:S}),(z()||T()||O()||Q())&&t.createElement("div",{className:"action-buttons"},z()&&t.createElement(w,{onClick:()=>{E(!1),y(o[R],null,!0)},disabled:l.current.question.required&&(!r[l.current.question.name]||Array.isArray(r[l.current.question.name])&&0===r[l.current.question.name].length)||l.current.question.type_info.meta?.othersRequired&&F,className:"next-button"},"Next"),O()&&t.createElement("button",{className:"skip-button",onClick:()=>{E(!1),v(C)}},"Skip"),Q()&&t.createElement("div",{className:"submit"},t.createElement(w,{disabled:(l.current.question.required||l.current.question.type_info.pivot_question)&&(null==r[l.current.question.name]||0===r[l.current.question.name]?.length)||l.current.question.type_info.meta?.othersRequired&&F||m,onClick:()=>{h(!0),x({...r,others_meta:B},(()=>{i?.type_info.meta?.skipThankYouPage?k?setTimeout((()=>{q?.()}),300):window.location.href=i?.type_info.meta?.redirectUrl:g(!0)}))}},m?"Submitting":"Submit survey")),T()&&t.createElement("button",{className:"skip-button",onClick:()=>{E(!1),l.current=o[R],c.current=s.findIndex((e=>e.name===o[R].name)),v(C)}},"Clear selection")))},I=({survey:e,surveyStyle:o="standard",placeholders:s,onSubmit:i,widget:u,npsValue:c,preview:l,mobilePreview:m,closePreview:d})=>{const p=e.question_details?.questions||[],f=e.meta?.blocks||[],[y,v]=n.useState(null),[h,x]=n.useState({}),[b,w]=n.useState(!1),[k,q]=n.useState([]),[C,N]=n.useState(0),[I,R]=n.useState(!1),[z,O]=n.useState(null),[T,Q]=n.useState({}),F=n.useRef(null),L=n.useRef(null),V=n.useRef(-1),Y=n.useRef(null),A=n.useRef(0),U=n.useRef(0),$=n.useRef(!1),M=n.useRef([]),D=t.useRef(!!c&&"card"===o),H=n.useRef(null),W=n.useRef(0),[P,j]=n.useState(!1);n.useEffect((()=>{f&&(H.current=f.find((e=>"TY"===e.name)),v(f.filter((e=>"TY"!==e.name))))}),[f]),n.useEffect((()=>{U.current=W.current,y&&k&&(A.current=y.findIndex((e=>e.name===k[W.current].name))),N(C+1)}),[P]),n.useEffect((()=>{if(y)if(L.current=p.find((e=>e.type_info?.pivot_question))??p.find((e=>"RANGE"===e.type_info?.question_type))??p[0],null!=c){V.current=c;const e=p.find((e=>e.name===y[0].question_names[0]));F.current={...y[0],question:e},M.current=[...M.current,{...y[0],question:e}],q(M.current),x({Q_1:c})}else if(!F.current&&y.length>0)return F.current=y[0],void X(y[0])}),[y,c]),t.useEffect((()=>{k.length&&(M.current=k,U.current=k.length-1),N(k.length-1)}),[k]),n.useEffect((()=>{Object.keys(h).length>0&&F.current.question&&(a.includes(F.current.question.type_info.question_type)||$.current)&&!G()&&(c&&1==k.length?setTimeout((()=>{Z()}),1500):Z())}),[h]),n.useEffect((()=>{if(null!=h?.[L.current?.name])if(H.current?.is_based_on_rating){const e=L.current?.type_info?.choices[h?.[L.current?.name]-L.current?.type_info?.validation?.min??0]?.dependent_question_names,n=H.current?.question_names.find((n=>e?.includes(n))),t=p.find((e=>e.name===n));O(t)}else{const e=p.find((e=>e.name==H.current?.question_names[0]));O(e)}}),[h?.[L.current?.name]]);const G=()=>(A.current===y.length-1||"end"===F.current.branchOption)&&U.current===k.length-1,X=e=>{let n={};if(e.is_based_on_rating){const t=L.current?.type_info?.choices[h?.[L.current?.name]-L.current?.type_info?.validation?.min??0]?.dependent_question_names,r=e.question_names.find((e=>t?.includes(e)));n=p.find((e=>e.name===r))}else n=p.find((n=>n.name===e.question_names[0]));F.current.question=n;M.current.find((e=>e.question.name===n.name))?(N(C+1),U.current+=1):q([...M.current,{...e,question:n}])},Z=()=>{if(G())w(!0);else{if(F.current.nextBlock)A.current=y.findIndex((e=>e.name===F.current.nextBlock));else if(F.current.question.type_info?.meta?.branches){const e=F.current.question.type_info?.meta?.branches,n=h[F.current.question.name];let t;if(t="RANGE"===F.current.question.type_info.question_type?e.find((e=>n>=e.min&&n<=e.max)):e.find((e=>n===e.value)),t?.nextBlock){if("TY"===t.nextBlock)return void w(!0);A.current=y.findIndex((e=>e.name===t.nextBlock))}else A.current+=1}else A.current+=1;F.current=y[A.current],X(y[A.current])}},K=(e,n,t)=>{if(D.current=!1,t){if($.current=!0,null!=h[e.question.name]&&e.name!==k[k.length-1].name){const[t,r]=(e=>{const n=k.findIndex((n=>n.name===e.name)),t=k.slice(0,n+1),r=t.reduce(((e,n)=>(e[n.question.name]=h[n.question.name],e)),{});return A.current=y.findIndex((n=>n.name===e.name)),[t,r]})(e);x({...r,...null!=n&&{[e.question.name]:n}}),M.current=t}else x({...h,...null!=n&&{[e.question.name]:n}});L?.current?.name==e?.question?.name&&(V.current=n)}else x({...h,...null!=n&&{[e.question.name]:n}})};if(!F.current||!F.current.question)return null;const J=k[U.current];return t.createElement("div",{className:`freemium-survey-components ${m?"mobile-preview":""} ${o}-survey-style`,id:"freemium-survey"},t.createElement(g,{totalSteps:y.length,completedSteps:A.current+(b?1:0)}),t.createElement(r.SwitchTransition,{mode:"out-in"},t.createElement(r.CSSTransition,{key:U.current+String(b),addEndListener:(e,n)=>{e.addEventListener("transitionend",n,!1)},classNames:P?"fade-reverse":"fade"},t.createElement("div",{className:"questions"},b?t.createElement(S,{thankYouQuestion:z,preview:l,placeholders:s,npsValue:V.current}):t.createElement("div",{ref:Y,id:`${J.question.name}`,className:`question-container ${u||"card"===o}`,"data-test-question-name":J.question.name},t.createElement("div",{className:"question-text",dangerouslySetInnerHTML:{__html:_(J.question.text,s,V.current)},title:`question-${U.current}`,role:"heading","aria-level":1}),t.createElement("div",{onTransitionEndCapture:e=>e.stopPropagation(),style:{width:"100%"}},t.createElement(E,{question:J.question,formValues:h,othersMeta:T,autoFocus:!0,autoFocusDelay:"standard"===o?350:0,saveOthersValue:(e,n)=>{Q({...T,[e]:n})},onChangeHandler:e=>{$.current=!1,A.current=y.findIndex((e=>e.name===J.name)),F.current=J,j(!1),K(J,e,a.includes(J.question.type_info.question_type)&&!G())}})),t.createElement(B,{question:J.question,widget:u,surveyStyle:o,formValues:h,othersMeta:T,blocksWithQns:k,blocks:y,thankYouQuestion:z,currentBlockIndexOfBlocksWithQns:U,reverse:P,setReverse:j,currentBlockIndexOfBlocks:A,currentEditingBlock:F,isSubmitting:I,isValuesCommitted:$,isCurrentBlockFinal:G,setHorizontalScrollUnits:N,handleFormValues:K,skipBlock:e=>{$.current=!0,delete h[e.name],x({...h})},setIsSubmitting:R,onSubmit:i,setIsSurveyCompleted:w,preventQuestionAnimation:D,preview:l,closePreview:d,tempCurrentBlockIndexOfBlocksWithQns:W}))))))};o(":root {\n --default-brand-color: #264966;\n --default-question-text-color: #000;\n --default-question-background-color: #fff;\n --default-background-color: #f8f8f8;\n --default-button-text-color: #fff;\n --default-secondary-button-text-color: #000;\n --default-input-placeholder-color: #92a2b1;\n}\n\n.freemium-survey-components.widget-survey-components .freemium-survey-step-navigation {\n white-space: nowrap;\n border-radius: 3px;\n border: 1px solid #efefef;\n}\n.freemium-survey-components.widget-survey-components .freemium-survey-step-navigation .navigation-button {\n width: 38px;\n text-align: -webkit-center;\n height: 38px;\n background-color: #fff;\n border: none;\n cursor: pointer;\n border-radius: 0 3px 3px 0;\n}\n.freemium-survey-components.widget-survey-components .freemium-survey-step-navigation .navigation-button svg {\n transform: rotate(90deg);\n}\n.freemium-survey-components.widget-survey-components .freemium-survey-step-navigation .navigation-button:first-of-type {\n border-right: 1px solid #efefef;\n border-radius: 3px 0 0 3px;\n}\n.freemium-survey-components.widget-survey-components .freemium-survey-step-navigation .navigation-button:disabled {\n cursor: not-allowed;\n opacity: 0.5;\n}\n.freemium-survey-components.widget-survey-components .freemium-survey-step-navigation .navigation-button:focus {\n position: relative;\n z-index: 1;\n}\n.freemium-survey-components.widget-survey-components .question-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n text-align: center;\n max-width: 700px;\n margin: 0 auto;\n border-radius: 4px;\n box-shadow: 0px 12px 15px rgba(18, 52, 77, 0.03);\n padding: 28px;\n grid-gap: 28px;\n gap: 28px;\n position: relative;\n overflow: auto;\n}\n.freemium-survey-components.widget-survey-components .hide-question-container {\n opacity: 0;\n}\n.freemium-survey-components.widget-survey-components .question-text {\n font-size: 1rem;\n font-weight: 600;\n line-height: 1.8;\n width: 100%;\n text-align: left;\n color: var(--default-question-text-color);\n color: var(--question-text-color, var(--default-question-text-color));\n}\n.freemium-survey-components.widget-survey-components .autofocus-button {\n border: none;\n width: 0;\n height: 0;\n opacity: 0;\n margin-top: -12px;\n margin-left: -12px;\n position: absolute;\n}\n.freemium-survey-components.widget-survey-components .fade-enter {\n opacity: 1;\n transform: translateX(80px);\n position: absolute;\n}\n.freemium-survey-components.widget-survey-components .fade-enter-active {\n position: absolute;\n opacity: 1;\n transform: translateX(0);\n}\n.freemium-survey-components.widget-survey-components .fade-enter-done {\n position: absolute;\n}\n.freemium-survey-components.widget-survey-components .fade-exit {\n opacity: 0.05;\n pointer-events: none;\n transform: translateX(0);\n}\n.freemium-survey-components.widget-survey-components .fade-exit-active {\n pointer-events: none;\n opacity: 0;\n transform: translateX(-80px);\n}\n.freemium-survey-components.widget-survey-components .fade-reverse-enter {\n opacity: 0;\n position: absolute;\n transform: translateX(-80px);\n}\n.freemium-survey-components.widget-survey-components .fade-reverse-enter-active {\n opacity: 1;\n position: absolute;\n transform: translateX(0);\n}\n.freemium-survey-components.widget-survey-components .fade-reverse-exit {\n opacity: 0.05;\n transform: translateX(0);\n}\n.freemium-survey-components.widget-survey-components .fade-reverse-exit-active {\n opacity: 0;\n transform: translateX(80px);\n}\n.freemium-survey-components.widget-survey-components .fade-enter-active,\n.freemium-survey-components.widget-survey-components .fade-reverse-enter-active {\n transition: opacity 400ms, transform 400ms;\n}\n.freemium-survey-components.widget-survey-components .fade-reverse-exit-active,\n.freemium-survey-components.widget-survey-components .fade-exit-active {\n transition: opacity 300ms, transform 300ms;\n}\n.freemium-survey-components.widget-survey-components .question-footer {\n display: flex;\n grid-gap: 40px;\n gap: 40px;\n width: 100%;\n align-items: center;\n}\n.freemium-survey-components.widget-survey-components .question-footer:empty {\n display: none;\n}\n.freemium-survey-components.widget-survey-components .question-footer:only-child {\n margin-left: auto;\n}\n.freemium-survey-components.widget-survey-components .action-buttons {\n display: flex;\n grid-gap: 20px;\n gap: 20px;\n flex-direction: row-reverse;\n width: 100%;\n}\n.freemium-survey-components.widget-survey-components .action-buttons:empty {\n display: none;\n}\n.freemium-survey-components.widget-survey-components .skip-button {\n font-weight: 500;\n cursor: pointer;\n background: transparent;\n border: none;\n min-width: 40px;\n padding: 8px 16px;\n border-radius: 4px;\n color: var(--default-secondary-button-text-color);\n color: var(--secondary-button-text-color, var(--default-secondary-button-text-color));\n letter-spacing: 0.05rem;\n line-height: 1.5;\n border: 1px solid transparent;\n transform: translateY(0px);\n transition: transform ease 0.2s;\n}\n.freemium-survey-components.widget-survey-components .skip-button:hover {\n background-color: #f3f3f3;\n transform: translateY(-4px);\n}\n.freemium-survey-components.widget-survey-components .next-button {\n color: var(--default-button-text-color);\n color: var(--button-text-color, var(--default-button-text-color));\n}\n.freemium-survey-components.widget-survey-components .submit {\n max-width: 700px;\n text-align: left;\n background: transparent;\n box-shadow: none;\n color: var(--default-button-text-color);\n color: var(--button-text-color, var(--default-button-text-color));\n}\n.freemium-survey-components.widget-survey-components .thankyou {\n display: flex;\n align-items: center;\n justify-content: center;\n grid-gap: 20px;\n gap: 20px;\n min-height: 180px;\n}\n.freemium-survey-components.widget-survey-components .thankyou .heading {\n font-weight: 600;\n font-size: 28px;\n}\n.freemium-survey-components.widget-survey-components .thankyou .text {\n white-space: pre-wrap;\n font-weight: 500;\n font-size: 0.875rem;\n line-height: 1.6;\n color: #12344d;\n width: 75%;\n}\n.freemium-survey-components.widget-survey-components .thankyou .redirection-text {\n color: #929292;\n margin-bottom: 12px;\n font-weight: 300;\n}\n.freemium-survey-components.widget-survey-components .thankyou .link {\n width: 100%;\n display: inline-block;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n color: #666;\n font-weight: 500;\n text-decoration: underline;\n}\n.freemium-survey-components.widget-survey-components .responsive-text-field {\n width: 100%;\n}\n.freemium-survey-components.widget-survey-components .responsive-text-field .textarea-container {\n display: none;\n}\n.freemium-survey-components.widget-survey-components .message-container:empty {\n display: none;\n}\n\n@media (max-width: 550px) {\n div.freemium-survey-components.card-survey-style .responsive-text-field .input-container {\n display: none;\n }\n div.freemium-survey-components.card-survey-style .responsive-text-field .textarea-container {\n display: flex;\n }\n div.freemium-survey-components.card-survey-style .question-footer {\n flex-direction: column-reverse;\n grid-gap: 20px;\n gap: 20px;\n }\n div.freemium-survey-components.card-survey-style .freemium-survey-step-navigation {\n width: 100%;\n }\n div.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button {\n width: 50%;\n }\n div.freemium-survey-components.card-survey-style .action-buttons {\n flex-direction: column;\n width: 100%;\n }\n div.freemium-survey-components.card-survey-style .action-buttons button {\n max-width: unset;\n }\n div.freemium-survey-components.card-survey-style .action-button {\n max-width: unset;\n width: 100%;\n }\n div.freemium-survey-components.card-survey-style .thankyou .text {\n width: auto;\n }\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .responsive-text-field .input-container {\n display: none;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .responsive-text-field .textarea-container {\n display: flex;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .question-footer {\n flex-direction: column-reverse;\n grid-gap: 20px;\n gap: 20px;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .freemium-survey-step-navigation {\n width: 100%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .freemium-survey-step-navigation .navigation-button {\n width: 50%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .action-buttons {\n flex-direction: column;\n width: 100%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .action-buttons button {\n max-width: unset;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .action-button {\n max-width: unset;\n width: 100%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .thankyou .text {\n width: auto;\n}\n\n.widget-survey-components.compact-style .freemium-survey-step-navigation {\n padding: 0 2px;\n margin-left: 4px;\n box-shadow: 0px 0px 6px #eee;\n margin-top: 4px;\n}\n.widget-survey-components.compact-style .nps-container .footer {\n padding-top: 12px;\n}\n.widget-survey-components.compact-style .nps-container .choices {\n grid-gap: 12px;\n gap: 12px;\n}\n\n.widget-survey-components,\n.card-survey-style {\n display: flex;\n flex-direction: column;\n grid-gap: 28px;\n gap: 28px;\n flex-grow: 1;\n font-size: 0.875rem;\n position: relative;\n overflow: hidden;\n}\n.widget-survey-components .questions,\n.card-survey-style .questions {\n min-width: 100%;\n max-width: 100%;\n background: var(--default-question-background-color);\n background: var(--question-background-color, var(--default-question-background-color));\n position: relative;\n display: flex;\n justify-content: row;\n align-items: flex-end;\n height: 100%;\n transition: height 400ms ease;\n}\n.widget-survey-components .question-text,\n.card-survey-style .question-text {\n width: 100%;\n text-align: left;\n}\n.widget-survey-components .focus-lock,\n.card-survey-style .focus-lock {\n width: 100%;\n}\n.widget-survey-components .question-container,\n.card-survey-style .question-container {\n height: -webkit-fit-content;\n height: -moz-fit-content;\n height: fit-content;\n max-height: 100%;\n min-width: 100%;\n max-width: 100%;\n margin-bottom: 0;\n padding: 28px;\n grid-gap: 28px;\n gap: 28px;\n flex-grow: 1;\n align-self: flex-end;\n margin-top: auto;\n position: absolute;\n}\n.widget-survey-components .question-footer,\n.card-survey-style .question-footer {\n margin: 0px auto;\n justify-content: space-between;\n position: -webkit-sticky;\n position: sticky;\n bottom: -28px;\n padding: 20px 0;\n background: var(--default-question-background-color);\n background: var(--question-background-color, var(--default-question-background-color));\n}\n.widget-survey-components .submit,\n.card-survey-style .submit {\n padding-bottom: 0;\n margin: unset;\n}\n.widget-survey-components .nps-container .footer,\n.card-survey-style .nps-container .footer {\n padding-top: 12px;\n}\n.widget-survey-components .nps-container .widget .choices,\n.card-survey-style .nps-container .widget .choices {\n grid-gap: 8px;\n gap: 8px;\n}\n.widget-survey-components .radio-group,\n.card-survey-style .radio-group {\n width: 100%;\n overflow: auto;\n}\n.widget-survey-components .checkbox-group,\n.card-survey-style .checkbox-group {\n width: 100%;\n overflow: auto;\n}\n\ndiv.widget-survey-components .question-container {\n box-shadow: none;\n border-radius: 0;\n}\ndiv.widget-survey-components .question-text {\n font-size: 0.875rem;\n}\ndiv.widget-survey-components .progressbar-container {\n position: absolute;\n}\ndiv.widget-survey-components .progressbar-container .progressbar {\n border-radius: 3px 0 0 0;\n}\ndiv.widget-survey-components .textarea-container .end-max-length {\n padding: 4px;\n}\ndiv.widget-survey-components .responsive-text-field .input-container {\n display: none;\n}\ndiv.widget-survey-components .responsive-text-field .textarea-container {\n display: flex;\n}\ndiv.widget-survey-components div.thankyou {\n min-height: unset;\n}\ndiv.widget-survey-components div.thankyou .text {\n width: 85%;\n}\ndiv.widget-survey-components div.thankyou svg {\n width: 140px;\n height: 120px;\n}\n\ndiv.widget-survey-components.default-style .freemium-survey-step-navigation {\n margin: 0;\n}\ndiv.widget-survey-components.default-style .question-container {\n padding: 28px;\n}\ndiv.widget-survey-components.default-style .question-footer {\n justify-content: space-between;\n}\ndiv.widget-survey-components.default-style .nps-container .footer {\n padding-top: 12px;\n}\ndiv.widget-survey-components.default-style .nps-container .choices {\n flex-wrap: unset;\n grid-gap: 12px;\n gap: 12px;\n}\ndiv.widget-survey-components.default-style .action-button {\n line-height: 1.2;\n}\ndiv.widget-survey-components.default-style .radio-group {\n flex-direction: column;\n flex-wrap: nowrap;\n overflow: auto;\n}\ndiv.widget-survey-components.default-style .radio-group .radio-label {\n padding: 12px 16px;\n min-width: 160px;\n font-size: 0.9rem;\n}\ndiv.widget-survey-components.default-style .checkbox-group {\n flex-direction: row;\n flex-wrap: wrap;\n}\ndiv.widget-survey-components.default-style .checkbox-group .checkbox-label {\n padding: 12px 16px;\n min-width: 160px;\n font-size: 0.9rem;\n}\ndiv.widget-survey-components.default-style textarea {\n min-height: 84px;\n}\ndiv.widget-survey-components.default-style .end-max-length {\n font-size: 0.8rem;\n font-weight: 300;\n padding: 4px;\n}\n\n.widget-survey-components.cozy-style .freemium-survey-step-navigation {\n margin: 0;\n}\n.widget-survey-components.cozy-style .question-text {\n font-size: 1rem;\n}\n.widget-survey-components.cozy-style .question-text.nps {\n text-align: center;\n width: 60%;\n min-width: 600px;\n margin: auto;\n}\n.widget-survey-components.cozy-style .question-container {\n padding: 12px 28px;\n}\n.widget-survey-components.cozy-style .question-footer {\n justify-content: space-between;\n}\n.widget-survey-components.cozy-style .nps-container {\n grid-gap: 44px;\n gap: 44px;\n}\n.widget-survey-components.cozy-style .nps-container .widget {\n display: flex;\n justify-content: center;\n}\n.widget-survey-components.cozy-style .nps-container .button-container {\n width: 60%;\n min-width: 600px;\n margin: 0 auto;\n}\n.widget-survey-components.cozy-style .nps-container .button-container .choices {\n justify-content: space-around;\n}\n.widget-survey-components.cozy-style .nps-container .footer {\n padding-top: 8px;\n}\n.widget-survey-components.cozy-style .action-button {\n line-height: 1.2;\n}\n.widget-survey-components.cozy-style .radio-group {\n flex-direction: row;\n flex-wrap: wrap;\n}\n.widget-survey-components.cozy-style .radio-group .radio-label {\n padding: 12px 16px;\n min-width: 160px;\n font-size: 0.9rem;\n}\n.widget-survey-components.cozy-style .checkbox-group {\n flex-direction: row;\n flex-wrap: wrap;\n}\n.widget-survey-components.cozy-style .checkbox-group .checkbox-label {\n padding: 12px 16px;\n min-width: 160px;\n font-size: 0.9rem;\n}\n.widget-survey-components.cozy-style textarea {\n min-height: 60px;\n}\n.widget-survey-components.cozy-style .end-max-length {\n font-size: 0.8rem;\n font-weight: 300;\n padding: 4px;\n}\n\n.freemium-survey-components.mobile-preview .thankyou .text {\n width: unset;\n}");const R=({thankYouQuestion:e,preview:r,placeholders:o,npsValue:s,setBlockElementRef:i},a)=>(n.useEffect((()=>{r||e.type_info.meta?.redirectUrl&&setTimeout((()=>{window.location.href=e.type_info.meta?.redirectUrl}),e.type_info.meta?.redirectDelay??1e4)}),[]),t.createElement(t.Fragment,null,t.createElement("div",{className:"heading"},"Thank you!"),t.createElement("div",{className:"text",dangerouslySetInnerHTML:{__html:_(e.text,o,s)}}),e.type_info.meta?.redirectUrl&&t.createElement("div",{style:{width:"100%"}},t.createElement("div",{className:"redirection-text"},"You will be redirected to the below URL automatically in"," ",e.type_info.meta?.redirectDelay," seconds.",t.createElement("br",null)),t.createElement("a",{className:"link",href:e.type_info.meta?.redirectUrl},e?.type_info.meta?.redirectUrl)))),z=({currentBlockIndex:e,currentBlockIndexOfBlocksWithQns:n,blocksWithQns:r,blocks:o,setHorizontalScrollUnits:s,preventQuestionAnimation:i,tempCurrentBlockIndexOfBlocksWithQns:a,setReverse:u,reverse:c})=>t.createElement("div",{className:"freemium-survey-step-navigation","data-navigation-element":"1"},t.createElement("button",{disabled:0==n.current,className:"navigation-button",onClick:()=>{c?n.current=Math.max(n.current-1,0):a.current=Math.max(n.current-1,0),i.current=!1,u(!0),s(n.current)}},t.createElement(q,null)),t.createElement("button",{className:"navigation-button",disabled:n.current>=r.length-1,onClick:()=>{i.current=!1,c?a.current=Math.min(n.current+1,r.length-1):n.current=Math.min(n.current+1,r.length-1),u(!1),s(n.current)}},t.createElement(k,null))),O=({widget:e,widgetStyle:n,surveyStyle:r,formValues:o,blocksWithQns:s,blocks:i,thankYouQuestion:u,currentBlockIndexOfBlocksWithQns:c,currentBlockIndexOfBlocks:l,currentEditingBlock:m,isSubmitting:d,isValuesCommitted:p,isCurrentBlockFinal:f,setHorizontalScrollUnits:y,handleFormValues:v,skipBlock:h,setIsSubmitting:x,onSubmit:g,setIsSurveyCompleted:b,preventQuestionAnimation:k,preview:q,closePreview:E,setReverse:_,tempCurrentBlockIndexOfBlocksWithQns:C,question:S,reverse:N,othersMeta:B,...I})=>{const R=I.blockIndex??c.current,O=()=>!a.includes(S.type_info.question_type)&&!f(),T=()=>"RANGE"!==S.type_info.question_type&&!S.required&&!f(),Q=()=>("DROPDOWN"===S.type_info.question_type&&!S.required&&o[S.name],!1),F=()=>f()&&(e||"standard"!==r),L="MULTI_SELECT"===m.current.question.type_info.question_type&&o[m.current.question.name]?.includes("others")&&(!B[m.current.question.name]||""===B[m.current.question.name]);return t.createElement("div",{className:"question-footer"},!(!e&&"standard"===r||0===R&&void 0===o[S.name]||"compact"===n||0===c.current&&!N)&&t.createElement(z,{currentBlockIndex:l,currentBlockIndexOfBlocksWithQns:c,blocksWithQns:s,blocks:i,setHorizontalScrollUnits:y,preventQuestionAnimation:k,setReverse:_,tempCurrentBlockIndexOfBlocksWithQns:C,reverse:N}),(O()||Q()||T()||F())&&t.createElement("div",{className:"action-buttons"},O()&&t.createElement(w,{onClick:()=>{_(!1),v(s[R],null,!0)},disabled:m.current.question.required&&(!o[m.current.question.name]||Array.isArray(o[m.current.question.name])&&0===o[m.current.question.name].length)||m.current.question.type_info.meta?.othersRequired&&L,className:"next-button"},"Next"),T()&&t.createElement("button",{className:"skip-button",onClick:()=>{_(!1),h(S)}},"Skip"),F()&&t.createElement("div",{className:"submit"},t.createElement(w,{disabled:(m.current.question.required||m.current.question.type_info.pivot_question)&&(null==o[m.current.question.name]||0===o[m.current.question.name]?.length)||m.current.question.type_info.meta?.othersRequired&&L||d,onClick:()=>{x(!0),g({...o,others_meta:B},(()=>{u?.type_info.meta?.skipThankYouPage?q?setTimeout((()=>{E?.()}),300):window.location.href=u?.type_info.meta?.redirectUrl:b(!0)}))}},d?"Submitting":"Submit survey")),Q()&&t.createElement("button",{className:"skip-button",onClick:()=>{_(!1),m.current=s[R],l.current=i.findIndex((e=>e.name===s[R].name)),h(S)}},"Clear selection")))},T=({survey:e,surveyStyle:o="standard",placeholders:s,onSubmit:i,widget:c,npsValue:l,widgetStyle:m,widgetNavigatorQuerySelector:d,preview:p,mobilePreview:f,closePreview:y})=>{const v=e.question_details?.questions||[],h=e.meta?.blocks||[],[x,b]=n.useState(null),[w,k]=n.useState({}),[q,C]=n.useState(!1),[S,N]=n.useState([]),[B,I]=n.useState(0),[z,T]=n.useState(!1),[Q,F]=n.useState(null),[L,V]=n.useState({}),Y=n.useRef(null),A=n.useRef(null),U=n.useRef(-1),[$,M]=n.useState(null),D=n.useRef(0),H=n.useRef(0),W=n.useRef(!1),P=n.useRef([]),j=n.useRef(!!l&&"card"===o),G=n.useRef(null),X=n.useRef(0),[Z,K]=n.useState(!1),J=n.useRef(0);n.useEffect((()=>{h&&(G.current=h.find((e=>"TY"===e.name)),b(h.filter((e=>"TY"!==e.name))))}),[h]),n.useEffect((()=>{H.current=X.current,x&&S&&(D.current=x.findIndex((e=>e.name===S[X.current].name))),I(B+1)}),[Z]),n.useEffect((()=>{if(x)if(A.current=v.find((e=>e.type_info?.pivot_question))??v.find((e=>"RANGE"===e.type_info?.question_type))??v[0],null!=l){U.current=l;const e=v.find((e=>e.name===x[0].question_names[0]));Y.current={...x[0],question:e},P.current=[...P.current,{...x[0],question:e}],N(P.current),k({Q_1:l})}else if(!Y.current&&x.length>0)return Y.current=x[0],void ne(x[0])}),[x,l]),n.useEffect((()=>{S.length&&(P.current=S,H.current=S.length-1,I(S.length-1))}),[S]),n.useEffect((()=>{Object.keys(w).length>0&&Y.current.question&&(a.includes(Y.current.question.type_info.question_type)||W.current)&&!ee()&&(l&&1==S.length?setTimeout((()=>{te()}),1500):te())}),[w]),n.useEffect((()=>{if(null!=w?.[A.current?.name])if(G.current?.is_based_on_rating){const e=A.current?.type_info?.choices[w?.[A.current?.name]-A.current?.type_info?.validation?.min??0]?.dependent_question_names,n=G.current?.question_names.find((n=>e?.includes(n))),t=v.find((e=>e.name===n));F(t)}else{const e=v.find((e=>e.name==G.current?.question_names[0]));F(e)}}),[w?.[A.current?.name]]);n.useMemo((()=>{(()=>{if($){$.style.minHeight="unset",$.style.height="min-content";const e=Math.min($?.scrollHeight,u[m]);$.style.height=e+"px",$.style.minHeight=e+"px",J.current=e}})()}),[$]);const ee=()=>(D.current===x.length-1||"end"===Y.current.branchOption)&&H.current===S.length-1,ne=e=>{let n={};if(e.is_based_on_rating){const t=A.current?.type_info?.choices[w?.[A.current?.name]-A.current?.type_info?.validation?.min??0]?.dependent_question_names,r=e.question_names.find((e=>t?.includes(e)));n=v.find((e=>e.name===r))}else n=v.find((n=>n.name===e.question_names[0]));Y.current.question=n;P.current.find((e=>e.question.name===n.name))?(I(B+1),H.current+=1):N([...P.current,{...e,question:n}])},te=()=>{if(ee())C(!0);else{if(Y.current.nextBlock)D.current=x.findIndex((e=>e.name===Y.current.nextBlock));else if(Y.current.question.type_info?.meta?.branches){const e=Y.current.question.type_info?.meta?.branches,n=w[Y.current.question.name];let t;if(t="RANGE"===Y.current.question.type_info.question_type?e.find((e=>n>=e.min&&n<=e.max)):e.find((e=>n===e.value)),t?.nextBlock){if("TY"===t.nextBlock)return void C(!0);D.current=x.findIndex((e=>e.name===t.nextBlock))}else D.current+=1}else D.current+=1;Y.current=x[D.current],ne(x[D.current])}},re=(e,n,t)=>{if(j.current=!1,t){if(W.current=!0,null!=w[e.question.name]&&e.name!==S[S.length-1].name){const[t,r]=(e=>{const n=S.findIndex((n=>n.name===e.name)),t=S.slice(0,n+1),r=t.reduce(((e,n)=>(e[n.question.name]=w[n.question.name],e)),{});return D.current=x.findIndex((n=>n.name===e.name)),[t,r]})(e);k({...r,...null!=n&&{[e.question.name]:n}}),P.current=t}else k({...w,...null!=n&&{[e.question.name]:n}});A?.current?.name==e?.question?.name&&(U.current=n)}else k({...w,...null!=n&&{[e.question.name]:n}})},oe=S[H.current];return Y.current&&Y.current.question?t.createElement("div",{className:`freemium-survey-components ${c?"widget-survey-components":""} ${m}-style ${f?"mobile-preview":""}`,id:"freemium-survey"},t.createElement(g,{totalSteps:x.length,completedSteps:D.current+(q?1:0)}),t.createElement("div",{className:"questions",style:{height:J.current,...1===S.length?{transition:"none"}:{}}},t.createElement(r.TransitionGroup,{component:null},t.createElement(r.CSSTransition,{key:oe.question.name+String(q),unmountOnExit:!0,addEndListener:(e,n)=>{e.addEventListener("transitionend",n,!1)},classNames:Z?"fade-reverse":"fade"},t.createElement("div",{ref:e=>e?M(e):null,id:`${oe.question.name}`,className:"question-container "+(q?"thankyou":""),"data-test-question-name":oe.question.name},q?t.createElement(R,{thankYouQuestion:Q,preview:p,placeholders:s,npsValue:U.current,setBlockElementRef:M}):t.createElement(t.Fragment,null,t.createElement("div",{className:"question-text",dangerouslySetInnerHTML:{__html:_(oe.question.text,s,U.current)},title:`question-${H.current}`,role:"heading","aria-level":1}),t.createElement("div",{onTransitionEndCapture:e=>e.stopPropagation(),style:{width:"100%",flexGrow:"1"}},t.createElement(E,{question:oe.question,formValues:w,othersMeta:L,autoFocus:!0,autoFocusDelay:"standard"===o?350:0,saveOthersValue:(e,n)=>{V({...L,[e]:n})},onChangeHandler:e=>{W.current=!1,D.current=x.findIndex((e=>e.name===oe.name)),Y.current=oe,K(!1),re(oe,e,a.includes(oe.question.type_info.question_type)&&!ee())}})),t.createElement(O,{question:oe.question,widget:c,widgetStyle:m,surveyStyle:o,formValues:w,othersMeta:L,blocksWithQns:S,blocks:x,thankYouQuestion:Q,currentBlockIndexOfBlocksWithQns:H,reverse:Z,setReverse:K,currentBlockIndexOfBlocks:D,currentEditingBlock:Y,isSubmitting:z,isValuesCommitted:W,isCurrentBlockFinal:ee,setHorizontalScrollUnits:I,handleFormValues:re,skipBlock:e=>{W.current=!0,delete w[e.name],k({...w})},setIsSubmitting:T,onSubmit:i,setIsSurveyCompleted:C,preventQuestionAnimation:j,preview:p,closePreview:y,tempCurrentBlockIndexOfBlocksWithQns:X}))))))):null};o(":root {\n --default-brand-color: #264966;\n --default-question-text-color: #000;\n --default-question-background-color: #fff;\n --default-background-color: #f8f8f8;\n --default-button-text-color: #fff;\n --default-secondary-button-text-color: #000;\n --default-input-placeholder-color: #92a2b1;\n --compact-widget-max-height: 480px;\n --default-widget-max-height: 460px;\n --cozy-widget-max-height: 380px;\n}\n\n.freemium-survey-step-navigation {\n border-radius: 3px;\n border: 1px solid #efefef;\n white-space: nowrap;\n}\n.freemium-survey-step-navigation .navigation-button {\n width: 38px;\n text-align: -webkit-center;\n height: 38px;\n background-color: #fff;\n border: none;\n cursor: pointer;\n border-radius: 0 3px 3px 0;\n}\n.freemium-survey-step-navigation .navigation-button:first-of-type {\n border-right: 1px solid #efefef;\n border-radius: 3px 0 0 3px;\n}\n.freemium-survey-step-navigation .navigation-button:disabled {\n cursor: not-allowed;\n opacity: 0.5;\n}\n.freemium-survey-step-navigation .navigation-button:focus {\n position: relative;\n z-index: 1;\n}\n\n.freemium-survey-components.standard-survey-style .question-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n text-align: center;\n max-width: 700px;\n margin: 0 auto;\n background: var(--default-question-background-color);\n background: var(--question-background-color, var(--default-question-background-color));\n border-radius: 4px;\n transition: transform 500ms ease 0ms, opacity 800ms ease 0ms;\n box-shadow: 0px 12px 15px rgba(18, 52, 77, 0.03);\n margin-bottom: 28px;\n padding: 28px;\n grid-gap: 28px;\n gap: 28px;\n position: relative;\n height: -webkit-fit-content;\n height: -moz-fit-content;\n height: fit-content;\n overflow: auto;\n opacity: 1;\n}\n.freemium-survey-components.standard-survey-style .hide-question-container {\n pointer-events: none;\n opacity: 0;\n}\n.freemium-survey-components.standard-survey-style .question-text {\n font-size: 1rem;\n font-weight: 600;\n line-height: 1.8;\n width: 100%;\n text-align: left;\n color: var(--default-question-text-color);\n color: var(--question-text-color, var(--default-question-text-color));\n}\n.freemium-survey-components.standard-survey-style .autofocus-button {\n border: none;\n width: 0;\n height: 0;\n opacity: 0;\n margin-top: -12px;\n margin-left: -12px;\n position: absolute;\n}\n.freemium-survey-components.standard-survey-style .question-footer {\n display: flex;\n justify-content: flex-start;\n grid-gap: 40px;\n gap: 40px;\n width: 100%;\n align-items: center;\n}\n.freemium-survey-components.standard-survey-style .question-footer:empty {\n display: none;\n}\n.freemium-survey-components.standard-survey-style .action-buttons {\n display: flex;\n grid-gap: 20px;\n gap: 20px;\n flex-direction: row-reverse;\n}\n.freemium-survey-components.standard-survey-style .action-buttons:empty {\n display: none;\n}\n.freemium-survey-components.standard-survey-style .skip-button {\n font-weight: 500;\n cursor: pointer;\n background: transparent;\n border: none;\n min-width: 40px;\n padding: 8px 16px;\n border-radius: 4px;\n color: var(--default-secondary-button-text-color);\n color: var(--secondary-button-text-color, var(--default-secondary-button-text-color));\n letter-spacing: 0.05rem;\n line-height: 1.5;\n border: 1px solid transparent;\n transform: translateY(0px);\n transition: transform ease 0.2s;\n}\n.freemium-survey-components.standard-survey-style .skip-button:hover {\n background-color: #f3f3f3;\n transform: translateY(-4px);\n}\n.freemium-survey-components.standard-survey-style .next-button {\n color: var(--default-button-text-color);\n color: var(--button-text-color, var(--default-button-text-color));\n}\n.freemium-survey-components.standard-survey-style .submit {\n max-width: 700px;\n margin: 0 auto;\n text-align: left;\n background: transparent;\n box-shadow: none;\n padding-bottom: 40px;\n color: var(--default-button-text-color);\n color: var(--button-text-color, var(--default-button-text-color));\n}\n.freemium-survey-components.standard-survey-style .fade-enter {\n transition: all ease 400ms;\n opacity: 0;\n transform: translateY(40px);\n}\n.freemium-survey-components.standard-survey-style .fade-enter-active {\n transition: all ease 400ms;\n opacity: 1;\n transform: translateY(0);\n}\n.freemium-survey-components.standard-survey-style .fade-exit {\n transition: all ease 400ms;\n opacity: 1;\n transform: translateY(0);\n}\n.freemium-survey-components.standard-survey-style .fade-exit-active {\n transition: all ease 400ms;\n opacity: 0;\n transform: translateY(-40px);\n}\n.freemium-survey-components.standard-survey-style .thankyou {\n display: flex;\n align-items: center;\n justify-content: center;\n grid-gap: 20px;\n gap: 20px;\n min-height: 180px;\n}\n.freemium-survey-components.standard-survey-style .thankyou .heading {\n font-weight: 600;\n font-size: 28px;\n}\n.freemium-survey-components.standard-survey-style .thankyou .text {\n white-space: pre-wrap;\n font-weight: 500;\n font-size: 0.875rem;\n line-height: 1.6;\n color: #12344d;\n width: 75%;\n}\n.freemium-survey-components.standard-survey-style .thankyou .redirection-text {\n color: #929292;\n margin-bottom: 12px;\n font-weight: 300;\n}\n.freemium-survey-components.standard-survey-style .thankyou .link {\n width: 100%;\n display: inline-block;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n color: #666;\n font-weight: 500;\n text-decoration: underline;\n}\n.freemium-survey-components.standard-survey-style .responsive-text-field {\n width: 100%;\n}\n.freemium-survey-components.standard-survey-style .responsive-text-field .textarea-container {\n display: none;\n}\n.freemium-survey-components.standard-survey-style .message-container:empty {\n display: none;\n}\n@media (max-width: 550px) {\n .freemium-survey-components.standard-survey-style .action-buttons {\n flex-direction: column;\n width: 100%;\n }\n .freemium-survey-components.standard-survey-style .action-buttons button {\n max-width: unset;\n }\n .freemium-survey-components.standard-survey-style .action-button {\n max-width: unset;\n width: 100%;\n }\n .freemium-survey-components.standard-survey-style .thankyou .text {\n width: auto;\n }\n}\n\n@media (max-width: 550px) {\n .freemium-survey-component .responsive-text-field .input-container,\n.card-survey-style .responsive-text-field .input-container {\n display: none;\n }\n .freemium-survey-component .responsive-text-field .textarea-container,\n.card-survey-style .responsive-text-field .textarea-container {\n display: flex;\n }\n}\n.freemium-survey-components.mobile-preview .thankyou .text {\n width: unset;\n}");const Q=({thankYouQuestion:e,preview:r,placeholders:o,npsValue:s})=>(n.useEffect((()=>{r||e.type_info.meta?.redirectUrl&&setTimeout((()=>{window.location.href=e.type_info.meta?.redirectUrl}),1e3*(e.type_info.meta?.redirectDelay??1e4))}),[]),t.createElement("div",{className:"question-container thankyou"},t.createElement("div",{className:"heading"},"Thank you!"),t.createElement("div",{className:"text",dangerouslySetInnerHTML:{__html:_(e.text,o,s)}}),e.type_info.meta?.redirectUrl&&t.createElement("div",{style:{width:"100%"}},t.createElement("div",{className:"redirection-text"},"You will be redirected to the below URL automatically in"," ",e.type_info.meta?.redirectDelay," seconds.",t.createElement("br",null)),t.createElement("a",{className:"link",href:e.type_info.meta?.redirectUrl},e?.type_info.meta?.redirectUrl)))),F=({currentBlockIndex:e,currentBlockIndexOfBlocksWithQns:n,blocksWithQns:r,blocks:o,setHorizontalScrollUnits:s,preventQuestionAnimation:i})=>t.createElement("div",{className:"freemium-survey-step-navigation","data-navigation-element":"1"},t.createElement("button",{disabled:0==n.current,className:"navigation-button",onClick:()=>{n.current=Math.max(n.current-1,0),e.current=o.findIndex((e=>e.name===r[n.current].name)),i.current=!1,s(n.current)}},t.createElement(q,null)),t.createElement("button",{className:"navigation-button",disabled:n.current>=r.length-1,onClick:()=>{i.current=!1,n.current=Math.min(n.current+1,r.length-1),e.current=o.findIndex((e=>e.name===r[n.current].name)),s(n.current)}},t.createElement(k,null))),L=({widget:e,surveyStyle:n,formValues:r,othersMeta:o,blocksWithQns:s,blocks:i,thankYouQuestion:u,currentBlockIndexOfBlocksWithQns:c,currentBlockIndexOfBlocks:l,currentEditingBlock:m,isSubmitting:d,isValuesCommitted:p,isCurrentBlockFinal:f,setHorizontalScrollUnits:y,handleFormValues:v,skipBlock:h,setIsSubmitting:x,onSubmit:g,setIsSurveyCompleted:b,preventQuestionAnimation:k,preview:q,closePreview:E,..._})=>{const C=_.blockIndex??c.current,S=_.question??s[C].question,N=()=>S.name===m.current.question.name&&!a.includes(S.type_info.question_type)&&!f(),B=()=>"RANGE"!==S.type_info.question_type&&!S.required&&S.name===m.current.question.name&&!f(),I=()=>("DROPDOWN"===S.type_info.question_type&&S.name!==m.current.question.name&&!S.required&&r[S.name],!1),R=()=>f()&&(e||"standard"!==n)&&S.name===m.current.question.name,z="MULTI_SELECT"===m.current.question.type_info.question_type&&r[m.current.question.name]?.includes("others")&&(!o[m.current.question.name]||""===o[m.current.question.name]);return t.createElement("div",{className:"question-footer"},!(!e&&"standard"===n||0===C&&!r[S.name])&&t.createElement(F,{currentBlockIndex:l,currentBlockIndexOfBlocksWithQns:c,blocksWithQns:s,blocks:i,setHorizontalScrollUnits:y,preventQuestionAnimation:k}),(N()||I()||B()||R())&&t.createElement("div",{className:"action-buttons"},N()&&t.createElement(w,{onClick:()=>{v(s[C],null,!0)},disabled:m.current.question.required&&(!r[m.current.question.name]||Array.isArray(r[m.current.question.name])&&0===r[m.current.question.name].length)||m.current.question.type_info.meta?.othersRequired&&z,className:"next-button"},"Next"),B()&&t.createElement("button",{className:"skip-button",onClick:()=>h(S)},"Skip"),I()&&t.createElement("button",{className:"skip-button",onClick:()=>{m.current=s[C],l.current=i.findIndex((e=>e.name===s[C].name)),h(S)}},"Clear selection"),R()&&t.createElement("div",{className:"submit"},t.createElement(w,{disabled:(m.current.question.required||m.current.question.type_info.pivot_question)&&(null==r[m.current.question.name]||0===r[m.current.question.name]?.length)||m.current.question.type_info.meta?.othersRequired&&z||d,onClick:()=>{x(!0),g({...r,others_meta:o},(()=>{u?.type_info.meta?.skipThankYouPage?q?setTimeout((()=>{E?.()}),300):window.location.href=u?.type_info.meta?.redirectUrl:b(!0)}))}},d?"Submitting":"Submit survey"))))},V=({survey:e,surveyStyle:o="standard",placeholders:s,onSubmit:i,widget:u,npsValue:c,preview:l,mobilePreview:m,closePreview:d})=>{const p=e.question_details?.questions||[],f=e.meta?.blocks||[],[y,v]=n.useState(null),[h,x]=n.useState({}),[b,k]=n.useState(!1),[q,C]=n.useState([]),[S,N]=n.useState(0),[B,I]=n.useState(!1),[R,z]=n.useState(null),[O,T]=n.useState({}),F=n.useRef(null),V=n.useRef(null),Y=n.useRef(-1),A=n.useRef(null),U=n.useRef(0),$=n.useRef(0),M=n.useRef(!1),D=n.useRef([]),H=n.useRef(!!c&&"card"===o),W=n.useRef(null),P=n.useRef([]);n.useEffect((()=>{f&&(W.current=f.find((e=>"TY"===e.name)),v(f.filter((e=>"TY"!==e.name))))}),[f]),n.useEffect((()=>{if(y)if(V.current=p.find((e=>e.type_info?.pivot_question))??p.find((e=>"RANGE"===e.type_info?.question_type))??p[0],null!=c){Y.current=c;const e=p.find((e=>e.name===y[0].question_names[0]));F.current={...y[0],question:e},D.current=[...D.current,{...y[0],question:e}],C(D.current),x({Q_1:c})}else if(!F.current&&y.length>0)return F.current=y[0],void G(y[0])}),[y,c]),n.useEffect((()=>{q.length&&(D.current=q,$.current=q.length-1),u||"standard"!==o?(A.current&&(A.current.style.maxHeight="unset"),P.current[U.current]=A.current?.scrollHeight||P.current[U.current]||0,A.current&&(A.current.style.maxHeight="100%")):A.current?.scrollIntoView({block:"start",behavior:"smooth"}),N(q.length-1)}),[q]),n.useEffect((()=>{Object.keys(h).length>0&&F.current.question&&(a.includes(F.current.question.type_info.question_type)||M.current)&&!j()&&X()}),[h]),n.useEffect((()=>{if(null!=h?.[V.current?.name])if(W.current?.is_based_on_rating){const e=V.current?.type_info?.choices[h?.[V.current?.name]-V.current?.type_info?.validation?.min??0]?.dependent_question_names,n=W.current?.question_names.find((n=>e?.includes(n))),t=p.find((e=>e.name===n));z(t)}else{const e=p.find((e=>e.name==W.current?.question_names[0]));z(e)}}),[h?.[V.current?.name]]);const j=()=>U.current===y.length-1||"end"===F.current.branchOption,G=e=>{let n={};if(e.is_based_on_rating){const t=V.current?.type_info?.choices[h?.[V.current?.name]-V.current?.type_info?.validation?.min??0]?.dependent_question_names,r=e.question_names.find((e=>t?.includes(e)));n=p.find((e=>e.name===r))}else n=p.find((n=>n.name===e.question_names[0]));F.current.question=n;D.current.find((e=>e.question.name===n.name))?(N(S+1),$.current+=1):C([...D.current,{...e,question:n}])},X=()=>{if(j())k(!0);else{if(F.current.nextBlock)U.current=y.findIndex((e=>e.name===F.current.nextBlock));else if(F.current.question.type_info?.meta?.branches){const e=F.current.question.type_info?.meta?.branches,n=h[F.current.question.name];let t;if(t="RANGE"===F.current.question.type_info.question_type?e.find((e=>n>=e.min&&n<=e.max)):e.find((e=>n===e.value)),t?.nextBlock){if("TY"===t.nextBlock)return void k(!0);U.current=y.findIndex((e=>e.name===t.nextBlock))}else U.current+=1}else U.current+=1;F.current=y[U.current],G(y[U.current])}},Z=e=>{M.current=!0,delete h[e.name],x({...h})},K=(e,n,t)=>{if(H.current=!1,t){if(M.current=!0,null!=h[e.question.name]&&e.name!==q[q.length-1].name){const[t,r]=(e=>{const n=q.findIndex((n=>n.name===e.name)),t=q.slice(0,n+1),r=t.reduce(((e,n)=>(e[n.question.name]=h[n.question.name],e)),{});return U.current=y.findIndex((n=>n.name===e.name)),[t,r]})(e);x({...r,...null!=n&&{[e.question.name]:n}}),D.current=t}else x({...h,...null!=n&&{[e.question.name]:n}});V?.current?.name==e?.question?.name&&(Y.current=n)}else x({...h,...null!=n&&{[e.question.name]:n}})},J=(e,n)=>{T({...O,[e]:n})};return F.current&&F.current.question?t.createElement("div",{className:`freemium-survey-components ${u?"widget-survey-components":""} ${m?"mobile-preview":""} ${o}-survey-style`,id:"freemium-survey"},b?null:t.createElement(g,{totalSteps:y.length,completedSteps:U.current}),t.createElement(r.SwitchTransition,{mode:"out-in"},t.createElement(r.CSSTransition,{key:String(b),addEndListener:(e,n)=>{e.addEventListener("transitionend",n,!1)},classNames:u?"":"fade"},t.createElement("div",null,b?t.createElement(Q,{thankYouQuestion:R,preview:l,placeholders:s,npsValue:Y.current}):t.createElement(t.Fragment,null,t.createElement("div",{onTransitionEndCapture:e=>e.stopPropagation(),style:u||"card"===o?{transform:`translateX(calc(-${S} * 100%))`,height:`${P.current[U.current]}px`,transition:H.current||q?.length<=1?"none":"all 300ms ease-out 0ms"}:{},className:"questions"},q.map(((e,n)=>t.createElement("div",{key:e.question.name,ref:A,className:"question-container "+(!u&&"card"!==o||$.current===n?"":"hide-question-container")},t.createElement("div",{className:"question-text "+(0===n?"nps":""),dangerouslySetInnerHTML:{__html:_(e.question.text,s,Y.current)},title:`question-${n}`,role:"heading","aria-level":1}),t.createElement("button",{disabled:!u&&"standard"===o,className:"autofocus-button",onKeyDown:e=>{"Tab"===e.key&&(e.stopPropagation(),e.preventDefault())}}),t.createElement(E,{question:e.question,formValues:h,othersMeta:O,autoFocus:$.current===n,autoFocusDelay:"standard"===o?350:20,saveOthersValue:J,onChangeHandler:n=>{M.current=!1,U.current=y.findIndex((n=>n.name===e.name)),F.current=e,K(e,n,a.includes(e.question.type_info.question_type)&&!j())}}),t.createElement("button",{disabled:!u&&"standard"===o,className:"autofocus-button",onKeyDown:e=>{"Tab"===e.key&&(e.stopPropagation(),e.preventDefault())}}),t.createElement(L,{question:e.question,blockIndex:n,widget:u,surveyStyle:o,formValues:h,othersMeta:O,blocksWithQns:q,blocks:y,thankYouQuestion:R,currentBlockIndexOfBlocksWithQns:$,currentBlockIndexOfBlocks:U,currentEditingBlock:F,isSubmitting:B,isValuesCommitted:M,isCurrentBlockFinal:j,setHorizontalScrollUnits:N,handleFormValues:K,skipBlock:Z,setIsSubmitting:I,onSubmit:i,setIsSurveyCompleted:k,preventQuestionAnimation:H,preview:l,closePreview:d})))),!u&&"card"!==o&&j()&&t.createElement("div",{className:"submit"},t.createElement(w,{disabled:(F.current.question.required||F.current.question.type_info.pivot_question)&&(null==h[F.current.question.name]||0===h[F.current.question.name]?.length)||F.current.question.type_info.meta?.othersRequired&&"MULTI_SELECT"===F.current.question.type_info.question_type&&h[F.current.question.name]?.includes("")||B,onClick:()=>{I(!0),i({...h,others_meta:O},(()=>{R?.type_info.meta?.skipThankYouPage?l?setTimeout((()=>{d?.()}),300):window.location.href=R?.type_info.meta?.redirectUrl:k(!0)}))}},B?"Submitting":"Submit survey")))))))):null};exports.BUTTON_SIZE_VARIANTS={LARGE:"large",MINI:"mini",NORMAL:"normal"},exports.Button=w,exports.CheckboxGroup=y,exports.Input=d,exports.NPS=s,exports.ProgressBar=g,exports.Radio=x,exports.RadioGroup=h,exports.Survey=e=>{const n=C(e.survey);return t.createElement(t.Fragment,null,"standard"===e.surveyStyle?t.createElement(V,Object.assign({},e,{survey:n})):t.createElement(I,Object.assign({},e,{survey:n})))},exports.TextArea=p,exports.WebInAppSurvey=e=>{const n=C(e.survey);return t.createElement(T,Object.assign({},e,{survey:n}))};
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e,n=require("react"),t=(e=n)&&"object"==typeof e&&"default"in e?e.default:e,r=require("react-transition-group");function o(e,n){void 0===n&&(n={});var t=n.insertAt;if(e&&"undefined"!=typeof document){var r=document.head||document.getElementsByTagName("head")[0],o=document.createElement("style");o.type="text/css","top"===t&&r.firstChild?r.insertBefore(o,r.firstChild):r.appendChild(o),o.styleSheet?o.styleSheet.cssText=e:o.appendChild(document.createTextNode(e))}}o(".freemium-survey-components .nps-container {\n margin: 0 auto;\n width: 100%;\n display: flex;\n flex-direction: column;\n grid-gap: 28px;\n gap: 28px;\n}\n.freemium-survey-components .nps-container .footer {\n border-top: 1px solid var(--default-background-color);\n border-top: 1px solid var(--background-color, var(--default-background-color));\n padding-top: 20px;\n display: flex;\n justify-content: center;\n font-size: 0.875rem;\n line-height: 1.5;\n color: #666;\n}\n.freemium-survey-components .nps-container .footer:empty {\n display: none;\n}\n.freemium-survey-components .nps-container .nps-scale {\n position: relative;\n}\n.freemium-survey-components .nps-container .nps-scale .button-container {\n display: flex;\n border-radius: 4px;\n justify-content: space-between;\n background: var(--default-background-color);\n background: var(--background-color, var(--default-background-color));\n position: relative;\n margin-bottom: 40px;\n}\n.freemium-survey-components .nps-container .nps-scale .positive-text {\n position: absolute;\n color: #475867;\n bottom: -40px;\n font-size: 12px;\n right: 0px;\n text-align: right;\n}\n.freemium-survey-components .nps-container .nps-scale .negative-text {\n position: absolute;\n color: #475867;\n bottom: -40px;\n font-size: 12px;\n left: 0;\n text-align: left;\n}\n.freemium-survey-components .nps-container .nps-scale span {\n color: #aaa;\n font-size: 0.75rem;\n}\n.freemium-survey-components .nps-container .nps-scale button {\n display: inline-block;\n font-size: 1rem;\n white-space: nowrap;\n vertical-align: middle;\n background: none;\n border: none;\n box-shadow: none;\n cursor: pointer;\n text-align: center;\n font-weight: 400;\n border-radius: 4px;\n margin: 0;\n outline: none;\n margin-left: -1px;\n width: 40px;\n height: 40px;\n transform: scale(1);\n}\n.freemium-survey-components .nps-container .nps-scale button:hover {\n transition: background 0.2s ease-in, border-color 0.2s ease-in, transform 0.2s cubic-bezier(0.5, 2, 0.5, 0.75);\n}\n.freemium-survey-components .nps-container .nps-scale button:hover, .freemium-survey-components .nps-container .nps-scale button:focus {\n color: white;\n transform: scale(1.2);\n z-index: 2;\n position: relative;\n}\n.freemium-survey-components .nps-container .nps-scale button.active {\n color: white;\n transform: scale(1.2);\n z-index: 2;\n position: relative;\n}\n.freemium-survey-components .nps-container .nps-scale.rounded button {\n border-radius: 50%;\n}\n.freemium-survey-components .nps-container .nps-scale.square button {\n border-radius: 0;\n}\n.freemium-survey-components .nps-container .nps-scale.curved button {\n border-radius: 3px;\n}\n.freemium-survey-components .nps-container .nps-scale.highlighted button:hover, .freemium-survey-components .nps-container .nps-scale.highlighted button:focus, .freemium-survey-components .nps-container .nps-scale.highlighted button.active {\n background: var(--default-brand-color) !important;\n background: var(--brand-color, var(--default-brand-color)) !important;\n}\n.freemium-survey-components .nps-container .nps-scale .choices {\n width: 100%;\n display: flex;\n justify-content: space-between;\n font-weight: 500;\n}\n.freemium-survey-components .nps-container .nps-scale.standard .button-container {\n background-color: transparent;\n}\n.freemium-survey-components .nps-container .nps-scale.standard .choice {\n background: #EBEFF3;\n color: #000;\n}\n.freemium-survey-components .nps-container .nps-scale.standard .choice:focus, .freemium-survey-components .nps-container .nps-scale.standard .choice.active, .freemium-survey-components .nps-container .nps-scale.standard .choice:hover {\n background: #E43E3D;\n}\n.freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(1):focus, .freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(1).active, .freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(1):hover, .freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(2):focus, .freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(2).active, .freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(2):hover {\n background: #00AF50;\n}\n.freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(3):hover, .freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(4):hover {\n background: #F8C43E;\n}\n.freemium-survey-components .nps-container .nps-scale.standard .choice:hover, .freemium-survey-components .nps-container .nps-scale.standard .choice:focus, .freemium-survey-components .nps-container .nps-scale.standard .choice.active {\n color: #fff;\n transform: scale(1.2);\n}\n\n.freemium-survey-components.mobile-preview .nps-container .nps-scale .button-container {\n background: transparent;\n}\n.freemium-survey-components.mobile-preview .nps-container .nps-scale .choices {\n flex-wrap: wrap;\n justify-content: center;\n grid-gap: 16px;\n gap: 16px;\n background: transparent;\n}\n.freemium-survey-components.mobile-preview .nps-container .nps-scale button {\n border-radius: 50%;\n background: #ebeff3;\n}\n\n@media (max-width: 550px) {\n .freemium-survey-components .nps-container .nps-scale .button-container,\n.card-survey-style .nps-container .nps-scale .button-container {\n background: transparent;\n }\n .freemium-survey-components .nps-container .nps-scale .choices,\n.card-survey-style .nps-container .nps-scale .choices {\n flex-wrap: wrap;\n justify-content: center;\n grid-gap: 16px;\n gap: 16px;\n background: transparent;\n }\n .freemium-survey-components .nps-container .nps-scale button,\n.card-survey-style .nps-container .nps-scale button {\n border-radius: 50%;\n background: #ebeff3;\n }\n}\n.widget-survey-components .nps-container .nps-scale .button-container {\n background: transparent;\n}\n.widget-survey-components .nps-container .nps-scale .choices {\n flex-wrap: wrap;\n justify-content: center;\n grid-gap: 16px;\n gap: 16px;\n background: transparent;\n}\n.widget-survey-components .nps-container .nps-scale button {\n border-radius: 50%;\n background: #ebeff3;\n}");const s=e=>{const{type_info:{linear_scale:{button_style:r="highlighted",button_shape:o="rounded"}={},rating_presets:{start:s="Very unlikely",end:i="Very likely"}={},validation:{min:a},footer_text:u}}=e,c=e=>{switch(e){case e<=6:return"detractor";case e<=8:return"passive";default:return"promoter"}},l=n.useRef(Array.from({length:10+(0===a?1:0)},((e,n)=>n+a)));return t.createElement("div",{className:"nps-container","data-test-input":"nps"},t.createElement("div",{className:`nps-scale ${o} ${r}`},t.createElement("div",{className:"button-container"},t.createElement("span",{className:"negative-text",role:"note"},`${a} - ${s}`),t.createElement("span",{className:"positive-text",role:"note"},`${l.current[l.current.length-1]} - ${i}`),t.createElement("div",{className:"choices",role:"radiogroup","aria-required":!0},l.current.map((n=>t.createElement("button",{role:"radio","aria-checked":e.npsValue===n,key:n,"data-test-nps-choice":n,onClick:t=>{e.onChangeHandler(n)},className:`choice ${c(n)} ${e.npsValue===n&&"active"}`},n)))))),t.createElement("div",{className:"footer",role:"note"},u))},i=(e,n)=>(e.defaultProps=n,e);o('.freemium-survey-components .input-container,\n.freemium-survey-components .textarea-container {\n display: flex;\n flex-direction: column;\n width: 100%;\n border-radius: 4px;\n position: relative;\n}\n.freemium-survey-components label.input-label {\n display: inline-block;\n padding-bottom: 8px;\n padding-left: 2px;\n font-size: 0.75rem;\n font-weight: 400;\n}\n.freemium-survey-components label.required::after {\n content: "*";\n position: relative;\n top: 2px;\n font-weight: 500;\n font-size: 0.85rem;\n padding-left: 3px;\n color: #d72d30;\n}\n.freemium-survey-components .input-basic {\n width: 100%;\n display: flex;\n align-items: center;\n border-radius: 4px;\n border: 1px solid var(--default-brand-color);\n border: 1px solid var(--brand-color, var(--default-brand-color));\n transition: border-color 0.2s linear;\n background: #fff;\n}\n.freemium-survey-components .textarea-container .input-basic {\n flex-direction: column;\n align-items: unset;\n}\n.freemium-survey-components .input-basic.error {\n border: 1px solid #d72d30;\n}\n.freemium-survey-components .input-basic.error:hover {\n border: 1px solid #d72d30;\n}\n.freemium-survey-components .input-basic.error[focus-within] {\n box-shadow: none;\n}\n.freemium-survey-components .input-basic.error:focus-within {\n box-shadow: none;\n}\n.freemium-survey-components .input-basic:hover {\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n transition: 0.2s linear;\n}\n.freemium-survey-components .input-basic[focus-within] {\n border: 1px solid transparent;\n box-shadow: 0 0 0 2px var(--default-brand-color);\n box-shadow: 0 0 0 2px var(--brand-color, var(--default-brand-color));\n}\n.freemium-survey-components .input-basic:focus-within {\n border: 1px solid transparent;\n box-shadow: 0 0 0 2px var(--default-brand-color);\n box-shadow: 0 0 0 2px var(--brand-color, var(--default-brand-color));\n}\n.freemium-survey-components .input-basic[focus-within] .end-max-length {\n opacity: 1;\n}\n.freemium-survey-components .input-basic:focus-within .end-max-length {\n opacity: 1;\n}\n.freemium-survey-components .end-max-length {\n transition: opacity ease 0.2s;\n opacity: 0;\n padding: 0 8px;\n font-size: 0.75rem;\n color: #264966;\n}\n.freemium-survey-components .textarea-container .end-max-length {\n padding: 8px;\n align-self: flex-end;\n}\n.freemium-survey-components span.input-error {\n display: block;\n padding-left: 2px;\n padding-top: 4px;\n font-size: 0.9rem;\n color: #d72d30;\n}\n.freemium-survey-components input[type=text] {\n padding: 6px 12px;\n flex: 1;\n border: unset;\n height: 32px;\n font-size: 1rem;\n /* line-height: ${typography.input.text.lineHeight}; */\n border-radius: 4px;\n}\n.freemium-survey-components input[type=text],\n.freemium-survey-components textarea {\n outline: none;\n border: none;\n}\n.freemium-survey-components input[type=text]::-moz-placeholder {\n color: #92a2b2;\n font-weight: 400;\n font-size: 0.85rem;\n}\n.freemium-survey-components input[type=text]:-ms-input-placeholder {\n color: #92a2b2;\n font-weight: 400;\n font-size: 0.85rem;\n}\n.freemium-survey-components input[type=text]::placeholder {\n color: #92a2b2;\n font-weight: 400;\n font-size: 0.85rem;\n}\n.freemium-survey-components textarea {\n min-height: 116px;\n padding: 12px;\n flex: 1;\n border: unset;\n resize: none;\n font-size: 1rem;\n /* line-height: ${typography.input.text.lineHeight}; */\n border-radius: 4px;\n}\n.freemium-survey-components textarea::-moz-placeholder {\n color: #92a2b2;\n font-weight: 400;\n font-size: 0.85rem;\n}\n.freemium-survey-components textarea:-ms-input-placeholder {\n color: #92a2b2;\n font-weight: 400;\n font-size: 0.85rem;\n}\n.freemium-survey-components textarea::placeholder {\n color: #92a2b2;\n font-weight: 400;\n font-size: 0.85rem;\n}');const a=["RANGE","NPS","RADIO","DROPDOWN"],u={default:500,compact:500,cozy:400},c={isRequired:!1,showCount:!0,isErrored:!1,inline:!1,spellCheck:!1,autoFocusInput:!0},l=n.forwardRef(((e,r)=>{const o=n.useRef(null);n.useEffect((()=>{e.autoFocusInput&&setTimeout((()=>{o.current?.focus()}),300+e.autoFocusDelay)}),[e.autoFocusInput]);const{inputStyle:s,style:i,className:a,showCount:u,isErrored:c,startLabel:l,isRequired:m,errorText:d,endLabel:p,maxLength:f=256,onChange:y,autoFocusInput:v,...h}=e;return t.createElement("div",{className:"input-container",style:i},e.label&&t.createElement("label",{className:"input-label "+(m?"required":"")},e.label),t.createElement("div",null,l&&t.createElement("div",{className:"start-label"},l),t.createElement("div",{className:`input-basic ${c?"error":""}${a||""}`},t.createElement("input",Object.assign({},h,{type:"text",autoComplete:"off",ref:o,style:s,onChange:e=>{e.target.value?.length>f||y?.(e)}})),u&&f>0&&t.createElement("div",{className:"end-max-length"},`${e.value&&e.value.length||0}/${f}`)),p&&t.createElement("div",{className:"end-label"},p)),c&&d&&t.createElement("span",{className:"input-error"},e.errorText))})),m=n.forwardRef(((e,r)=>{const o=n.useRef(null);n.useEffect((()=>{e.autoFocusInput&&setTimeout((()=>{o.current?.focus()}),300+e.autoFocusDelay)}),[e.autoFocusInput]);const{inputStyle:s,style:i,className:a,showCount:u,maxLength:c=1500,startLabel:l,isRequired:m,autoFocusInput:d,onChange:p,...f}=e;return t.createElement(t.Fragment,null,t.createElement("div",{className:"textarea-container",style:i},e.label&&t.createElement("label",{className:"input-label "+(m?"required":"")},e.label),l&&t.createElement("div",{className:"start-label"},l),t.createElement("div",{className:`input-basic ${a||""}`},t.createElement("textarea",Object.assign({},f,{autoComplete:"off",ref:o,style:s,onChange:e=>{e.target.value?.length>c||p?.(e)}})),u&&c&&c>0&&t.createElement("div",{className:"end-max-length"},`${e.value&&e.value.length||0}/${c}`)),e.endLabel&&t.createElement("div",{className:"end-label"},e.endLabel)))})),d=i(l,c),p=i(m,c);o('.freemium-survey-components .checkbox-group {\n width: 100%;\n display: flex;\n grid-gap: 12px;\n gap: 12px;\n flex-direction: column;\n white-space: nowrap;\n flex-wrap: wrap;\n}\n.freemium-survey-components .icon-container {\n display: inline-block;\n flex: 0 0 12px;\n width: 12px;\n height: 12px;\n min-width: 12px;\n min-height: 12px;\n color: inherit;\n position: absolute;\n left: 1px;\n top: 2px;\n}\n.freemium-survey-components .tick-icon {\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n height: 100%;\n width: 100%;\n color: inherit;\n fill: currentColor;\n}\n.freemium-survey-components input[type=checkbox] {\n position: absolute;\n clip: rect(0px 0px 0px 0px);\n width: 0px;\n height: 0px;\n}\n.freemium-survey-components input[type=checkbox]:focus ~ .checkbox {\n /* box-shadow: ${pseudo.focus} 0px 0px 0px 2px; */\n box-shadow: var(--default-brand-color) 0px 0px 0px 2px;\n box-shadow: var(--brand-color, var(--default-brand-color)) 0px 0px 0px 2px;\n border-color: transparent;\n}\n.freemium-survey-components .checkbox-label {\n display: flex;\n align-items: baseline;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n text-align: left;\n opacity: 1;\n line-height: 1.2;\n cursor: pointer;\n font-size: 1rem;\n padding: 16px 24px;\n min-width: 200px;\n border: 1px solid #ebeff3;\n border-radius: 4px;\n white-space: pre-wrap;\n}\n.freemium-survey-components .checkbox-label:hover .checkbox {\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n box-shadow: var(--default-background-color) 0px 0px 0px 5px;\n box-shadow: var(--background-color, var(--default-background-color)) 0px 0px 0px 5px;\n}\n.freemium-survey-components .checkbox-label.disabled {\n opacity: 0.5;\n cursor: "not-allowed";\n}\n.freemium-survey-components .checkbox {\n transition: background-color ease-in 0.2s;\n min-width: 14px;\n min-height: 14px;\n min-height: 14px;\n max-height: 14px;\n border-radius: 2px;\n position: relative;\n margin-right: 16px;\n background-color: #fff;\n border: 1px solid;\n text-align: left;\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n}\n.freemium-survey-components .checkbox:hover {\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n box-shadow: var(--default-background-color) 0px 0px 0px 5px;\n box-shadow: var(--background-color, var(--default-background-color)) 0px 0px 0px 5px;\n}\n.freemium-survey-components input[type=checkbox]:checked ~ .checkbox {\n background-color: var(--default-brand-color);\n background-color: var(--brand-color, var(--default-brand-color));\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n}\n.freemium-survey-components input[type=checkbox]:checked ~ .checkbox:hover {\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n}\n.freemium-survey-components input[type=checkbox]:disabled ~ .checkbox:hover {\n box-shadow: unset;\n border-color: unset;\n}');const f=()=>t.createElement("svg",{id:"tick",className:"tick-icon",xmlns:"http://www.w3.org/2000/svg","aria-labelledby":"title",viewBox:"0 0 10 10"},t.createElement("path",{d:"M3 5.87c-.18666814.00267463-.36667109-.06932655-.5-.2L.21 3.41c-.1786328-.17863279-.24839684-.43899577-.1830127-.6830127.06538414-.24401694.25598306-.43461586.5-.5C.77100423 2.16160316 1.0313672 2.23136721 1.21 2.41L3 4.18 6.8.33c.27679776-.27455556.72320224-.27455556 1 0 .13696438.13025306.21450026.31098915.21450026.5S7.93696438 1.19974694 7.8 1.33L3.45 5.67c-.12082534.11896945-.28072735.19003701-.45.2Z",fill:"#fff",fillRule:"evenodd"})),y=({values:e=[],othersValue:r="",options:o,name:s,autoFocusGroup:i,autoFocusDelay:a,onChangeHandler:u,saveOthersValue:c,othersOption:l,othersRequired:m})=>{const[p,f]=n.useState(!1),y=n.useRef(null);return n.useEffect((()=>{i&&setTimeout((()=>{y.current?.focus()}),300+a)}),[i]),t.createElement("div",{className:"checkbox-group"},t.createElement("button",{ref:y,className:"autofocus-button","aria-hidden":!0}),o?.map(((n,r)=>t.createElement(v,{key:n.id,checked:e?.includes(n.value),name:n.value,id:n.id,onChange:(t,r)=>{if(r)u([...e||[],n.value]);else{const t=e.indexOf(n.value);t>-1&&e.splice(t,1),u([...e])}}},n.value))),l&&t.createElement(v,{key:"others",checked:p,name:"others",id:"others",onChange:(n,t)=>{if(f(t),t)u([...e,"others"]);else{const n=e.findIndex((e=>"others"===e));e.splice(n,1),u(e)}}},"Others"),p&&t.createElement(t.Fragment,null,t.createElement(d,{placeholder:"Enter your comment",value:r[s],onChange:e=>{c(s,e.target.value)},autoFocusDelay:10,label:""})))},v=i((e=>{const r=n.useRef(null);return n.useEffect((()=>{e.autoFocus&&setTimeout((()=>{r.current?.focus()}),320)}),[]),t.createElement("label",{className:`checkbox-label ${e.disabled&&"disabled"}`},t.createElement("input",{ref:r,id:e.id,type:"checkbox",name:e.name,readOnly:e.readOnly,disabled:e.disabled,"aria-disabled":e.disabled,checked:e.checked,onChange:e.readOnly?()=>{}:n=>e.onChange(n,n.target.checked)}),t.createElement("div",{className:"checkbox"},e.checked&&t.createElement("div",{className:"icon-container"},t.createElement(f,null)," ")),t.createElement("div",null,e.children))}),{checked:!1});o('.freemium-survey-components .radio-group {\n display: flex;\n grid-gap: 12px;\n gap: 12px;\n white-space: nowrap;\n flex-direction: column;\n width: 100%;\n}\n.freemium-survey-components .radio {\n background-color: #fff;\n border: 1px solid;\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n transition: background-color ease-in 0.2s;\n min-width: 18px;\n max-width: 18px;\n min-height: 18px;\n max-height: 18px;\n border-radius: 50%;\n position: relative;\n margin-right: 16px;\n text-align: left;\n}\n.freemium-survey-components .radio:before {\n left: 3px;\n top: 3px;\n content: "";\n position: absolute;\n width: 10px;\n height: 10px;\n border-radius: 50%;\n transition: all ease-in 0.2s;\n background-color: #fff;\n}\n.freemium-survey-components .radio-label {\n display: flex;\n align-items: baseline;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n text-align: left;\n cursor: pointer;\n line-height: 1.2;\n font-size: 1rem;\n font-weight: 400;\n padding: 16px 24px;\n min-width: 200px;\n border: 1px solid #ebeff3;\n border-radius: 4px;\n white-space: pre-wrap;\n}\n.freemium-survey-components input[type=radio] {\n position: absolute;\n clip: rect(0, 0, 0, 0);\n width: 0px;\n height: 0px;\n}\n.freemium-survey-components input[type=radio]:focus ~ .radio {\n /* box-shadow: ${pseudo.focus} 0px 0px 0px 3px; */\n box-shadow: var(--default-brand-color) 0px 0px 0px 3px;\n box-shadow: var(--brand-color, var(--default-brand-color)) 0px 0px 0px 3px;\n border-color: transparent;\n}\n.freemium-survey-components input[type=radio]:checked ~ .radio:before {\n background-color: var(--default-brand-color);\n background-color: var(--brand-color, var(--default-brand-color));\n}\n.freemium-survey-components .radio-label:hover .radio {\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n box-shadow: var(--default-background-color) 0px 0px 0px 5px;\n box-shadow: var(--background-color, var(--default-background-color)) 0px 0px 0px 5px;\n}');const h=({name:e,options:r,value:o,autoFocusGroup:s,autoFocusDelay:i,onChangeHandler:a,saveOthersValue:u,othersOption:c,othersRequired:l,othersValue:m})=>{const[p,f]=n.useState(m??""),[y,v]=n.useState(o),h=n.useRef(null);return n.useEffect((()=>{s&&setTimeout((()=>{h.current?.focus()}),300+i)}),[s]),n.useEffect((()=>{o||(f(""),v(null))}),[o]),n.useEffect((()=>{y&&r.find((e=>e.value===y))&&y!==o&&a(y)}),[y]),t.createElement("div",{className:"radio-group",role:"radiogroup"},t.createElement("button",{ref:h,className:"autofocus-button","aria-hidden":!0,tabIndex:-1}),r?.map(((n,r)=>t.createElement(x,{key:n.value,value:n.value,name:e,onChange:e=>{v(e.currentTarget.value)},checked:y===n.value},n.value))),c&&t.createElement(x,{key:"others",value:"others",name:e,onChange:e=>{v("others")},checked:"others"===y},"Others"),"others"===y&&t.createElement(t.Fragment,null,t.createElement(d,{value:p,onChange:e=>f(e.target.value),placeholder:"Enter your comment",label:"",autoFocusDelay:10}),p!==o&&t.createElement(w,{inline:!0,disabled:l&&0===p.length,onClick:()=>{a("others"),u(e,p)}},"Next")))},x=i((e=>{const r=n.useRef(null);return n.useEffect((()=>{e.autoFocus&&setTimeout((()=>{r.current?.focus()}),320)}),[]),t.createElement("label",{className:"radio-label"},t.createElement("input",{ref:r,type:"radio",name:e.name,value:e.value,checked:e.checked,onChange:e.onChange}),t.createElement("div",{className:"radio"}),t.createElement("div",null,e.children))}),{checked:!1,autoFocus:!1});o(".progressbar-container {\n width: 100%;\n height: 4px;\n position: fixed;\n top: 0;\n left: 0;\n z-index: 1;\n text-align: left;\n}\n\n.progressbar {\n transition: transform 0.3s linear 200ms;\n transform-origin: left;\n height: 100%;\n background-color: var(--default-brand-color);\n background-color: var(--brand-color, var(--default-brand-color));\n}");const g=e=>{const{totalSteps:n,completedSteps:r}=e;return t.createElement("div",{className:"progressbar-container"},t.createElement("div",{className:"progressbar",style:{width:(r>0?100/n:0)+"%",transform:`scaleX(${r})`}}))};o(".freemium-survey-components .action-button {\n width: auto;\n display: block;\n padding: 8px 16px;\n cursor: pointer;\n line-height: 1.5;\n text-align: center;\n font-weight: 600;\n letter-spacing: 0.3px;\n border-radius: 4px;\n white-space: nowrap;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n color: --default-button-text-color;\n color: var(--button-text-color, --default-button-text-color);\n background: var(--default-brand-color);\n background: var(--brand-color, var(--default-brand-color));\n border: 1px solid var(--default-brand-color);\n border: 1px solid var(--brand-color, var(--default-brand-color));\n border-radius: 4px;\n min-width: 200px;\n max-width: -webkit-fit-content;\n max-width: -moz-fit-content;\n max-width: fit-content;\n transform: translateY(0px);\n transition: transform ease 0.2s;\n}\n.freemium-survey-components .action-button:not([disabled]):hover {\n transform: translateY(-4px);\n}\n.freemium-survey-components .action-button[disabled] {\n cursor: not-allowed;\n opacity: 0.6;\n}\n.freemium-survey-components button:focus:not(:active) {\n /* box-shadow: 0 0 0 2px ${pseudo.focus}; */\n}\n\n@media (max-width: 550px) {\n .freemium-survey-components .action-button {\n min-width: 120px;\n }\n}\n.widget-survey-components .action-button {\n min-width: 120px;\n}\n\n.freemium-survey-components.mobile-preview .action-button {\n min-width: 120px;\n}");const b=()=>t.createElement(t.Fragment,null,"..."),w=e=>{const{inline:n=!1,children:r,disabled:o,className:s="",htmlType:i,type:a="primary",onClick:u,size:c,overrideStyleClassName:l="",loading:m=!1,...d}=e;return t.createElement("button",Object.assign({style:n?{display:"inline-block"}:{},disabled:o,className:`action-button ${s} ${l}`,type:i,onClick:u},d),m?t.createElement(b,null):r)},k=()=>t.createElement("svg",{style:{display:"block"},width:"9",height:"14",viewBox:"0 0 10 16",fill:"none",xmlns:"http://www.w3.org/2000/svg"},t.createElement("path",{d:"M7.82585 6.15754C7.98999 6.32147 8.08232 6.54389 8.08252 6.77587L8.08252 7.2192C8.07983 7.45069 7.98788 7.6722 7.82585 7.83754L1.82919 13.8225C1.77496 13.8772 1.71044 13.9206 1.63936 13.9502C1.56827 13.9798 1.49203 13.9951 1.41502 13.9951C1.33801 13.9951 1.26177 13.9798 1.19068 13.9502C1.1196 13.9206 1.05508 13.8772 1.00085 13.8225L0.172521 12.9942C0.118197 12.941 0.0750381 12.8774 0.0455752 12.8073C0.0161124 12.7372 0.000937578 12.6619 0.000937585 12.5859C0.000937592 12.5098 0.0161125 12.4345 0.0455753 12.3644C0.0750381 12.2943 0.118197 12.2308 0.172521 12.1775L5.36419 6.99754L0.172522 1.81754C0.117847 1.76331 0.0744506 1.69879 0.0448352 1.62771C0.0152208 1.55662 -2.75162e-05 1.48038 -2.75094e-05 1.40337C-2.75027e-05 1.32636 0.0152208 1.25012 0.0448353 1.17904C0.0744507 1.10795 0.117847 1.04343 0.172522 0.989205L1.00086 0.172537C1.05508 0.117862 1.1196 0.0744661 1.19069 0.0448507C1.26177 0.0152353 1.33801 -1.20337e-05 1.41502 -1.2027e-05C1.49203 -1.20203e-05 1.56827 0.0152353 1.63936 0.0448507C1.71044 0.0744661 1.77496 0.117862 1.82919 0.172537L7.82585 6.15754Z",fill:"#6B6B6B"})),q=()=>t.createElement("svg",{style:{display:"block"},width:"9",height:"14",viewBox:"0 0 10 16",fill:"none",xmlns:"http://www.w3.org/2000/svg"},t.createElement("path",{d:"M0.256667 7.83755C0.0925257 7.67361 0.000204227 7.4512 0 7.21921V6.77588C0.00268801 6.5444 0.0946357 6.32289 0.256667 6.15755L6.25333 0.172549C6.30756 0.117874 6.37208 0.0744776 6.44316 0.0448625C6.51425 0.0152474 6.59049 0 6.6675 0C6.74451 0 6.82075 0.0152474 6.89184 0.0448625C6.96292 0.0744776 7.02744 0.117874 7.08167 0.172549L7.91 1.00088C7.96432 1.05411 8.00748 1.11764 8.03694 1.18776C8.06641 1.25787 8.08158 1.33316 8.08158 1.40922C8.08158 1.48527 8.06641 1.56056 8.03694 1.63067C8.00748 1.70079 7.96432 1.76432 7.91 1.81755L2.71833 6.99755L7.91 12.1775C7.96467 12.2318 8.00807 12.2963 8.03769 12.3674C8.0673 12.4385 8.08255 12.5147 8.08255 12.5917C8.08255 12.6687 8.0673 12.745 8.03769 12.8161C8.00807 12.8871 7.96467 12.9517 7.91 13.0059L7.08167 13.8225C7.02744 13.8772 6.96292 13.9206 6.89184 13.9502C6.82075 13.9799 6.74451 13.9951 6.6675 13.9951C6.59049 13.9951 6.51425 13.9799 6.44316 13.9502C6.37208 13.9206 6.30756 13.8772 6.25333 13.8225L0.256667 7.83755Z",fill:"#6B6B6B"})),E=({question:e,formValues:n,othersMeta:r,onChangeHandler:o,saveOthersValue:i,autoFocus:a,autoFocusDelay:u})=>{switch(e.type_info.question_type){case"RANGE":return t.createElement(s,{type_info:e.type_info,onChangeHandler:o,npsValue:n[e.name]});case"CHECKBOX":case"MULTI_SELECT":return t.createElement(y,{name:e.name,autoFocusGroup:a,values:n[e.name],othersValue:r[e.name],options:e.type_info.choices,onChangeHandler:o,saveOthersValue:i,othersOption:e.type_info.meta?.othersOption,othersRequired:e.type_info.meta?.othersRequired,autoFocusDelay:u});case"RADIO":case"DROPDOWN":return t.createElement(h,{autoFocusGroup:a,autoFocusDelay:u,name:e.name,onChangeHandler:o,saveOthersValue:i,options:e.type_info.choices,value:n[e.name],othersValue:r[e.name],othersOption:e.type_info.meta?.othersOption,othersRequired:e.type_info.meta?.othersRequired});case"INPUT":case"TEXT":return e.type_info?.meta?.readOnly?t.createElement("div",{className:"message-container"},e.type_info?.meta?.value):t.createElement("div",{className:"responsive-text-field"},t.createElement(d,{autoFocusInput:a,autoFocusDelay:u,label:"",isRequired:e.is_required,value:n[e.name]||"",placeholder:e.type_info?.meta?.placeholder??"",onChange:e=>o(e.target.value)}),t.createElement(p,{autoFocusInput:a,autoFocusDelay:u,label:"",isRequired:e.is_required,placeholder:e.type_info?.meta?.placeholder??"",value:n[e.name]||"",onChange:e=>o(e.target.value)}));case"PARAGRAPH":return t.createElement(p,{autoFocusInput:a,autoFocusDelay:u,label:"",isRequired:e.is_required,placeholder:e.type_info?.meta?.placeholder??"",value:n[e.name]||"",onChange:e=>o(e.target.value)});default:return console.error(`Question type ${e.type_info.question_type} not found`),null}},_=(e,n,t)=>{if(e){let r={"{{nps.rating}}":t};n&&(r={...r,...n});const o=new RegExp(Object.keys(r).join("|"),"gi");e=e.replace(o,(function(e){return r[e.toLowerCase()]}))}return e},C=e=>n.useMemo((()=>{const n=JSON.parse(JSON.stringify(e)),t=[];return(n.question_details?.questions||[]).forEach((e=>{const n=e.type_info?.meta?.block;n&&(n.question_names||(n.question_names=[e.name]),t.push(n))})),{...n,meta:{...n.meta,blocks:t}}}),[e]);o(":root {\n --default-brand-color: #264966;\n --default-question-text-color: #000;\n --default-question-background-color: #fff;\n --default-background-color: #f8f8f8;\n --default-button-text-color: #fff;\n --default-secondary-button-text-color: #000;\n --default-input-placeholder-color: #92a2b1;\n --compact-widget-max-height: 560px;\n --default-widget-max-height: 400px;\n --cozy-widget-max-height: 380px;\n}\n\n.freemium-survey-components.card-survey-style {\n padding: 20px 0;\n}\n.freemium-survey-components.card-survey-style .freemium-survey-step-navigation {\n white-space: nowrap;\n border-radius: 3px;\n border: 1px solid #efefef;\n}\n.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button {\n width: 38px;\n text-align: -webkit-center;\n height: 38px;\n background-color: #fff;\n border: none;\n cursor: pointer;\n border-radius: 0 3px 3px 0;\n}\n.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button svg {\n transform: rotate(90deg);\n}\n.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button:first-of-type {\n border-right: 1px solid #efefef;\n border-radius: 3px 0 0 3px;\n}\n.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button:disabled {\n cursor: not-allowed;\n opacity: 0.5;\n}\n.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button:focus {\n position: relative;\n z-index: 1;\n}\n.freemium-survey-components.card-survey-style .question-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n text-align: center;\n max-width: 700px;\n margin: 0 auto;\n background: var(--default-question-background-color);\n background: var(--question-background-color, var(--default-question-background-color));\n border-radius: 4px;\n transition: transform 500ms ease 0ms, opacity 200ms ease 0ms;\n box-shadow: 0px 12px 15px rgba(18, 52, 77, 0.03);\n padding: 28px;\n grid-gap: 28px;\n gap: 28px;\n position: relative;\n height: -webkit-fit-content;\n height: -moz-fit-content;\n height: fit-content;\n transition: opacity 50ms ease-out;\n overflow: auto;\n}\n.freemium-survey-components.card-survey-style .hide-question-container {\n opacity: 0;\n}\n.freemium-survey-components.card-survey-style .question-text {\n font-size: 1rem;\n font-weight: 600;\n line-height: 1.8;\n width: 100%;\n text-align: left;\n color: var(--default-question-text-color);\n color: var(--question-text-color, var(--default-question-text-color));\n}\n.freemium-survey-components.card-survey-style .autofocus-button {\n border: none;\n width: 0;\n height: 0;\n opacity: 0;\n margin-top: -12px;\n margin-left: -12px;\n position: absolute;\n}\n.freemium-survey-components.card-survey-style .fade-enter .question-container {\n opacity: 0;\n transform: translateY(15px);\n}\n.freemium-survey-components.card-survey-style .fade-enter-active .question-container {\n opacity: 1;\n transform: translateY(0);\n}\n.freemium-survey-components.card-survey-style .fade-exit .question-container {\n opacity: 1;\n transform: translateY(0);\n}\n.freemium-survey-components.card-survey-style .fade-exit-active .question-container {\n opacity: 0.05;\n transform: translateY(-15px);\n}\n.freemium-survey-components.card-survey-style .fade-reverse-enter .question-container {\n opacity: 0;\n transform: translateY(-15px);\n}\n.freemium-survey-components.card-survey-style .fade-reverse-enter-active .question-container {\n opacity: 1;\n transform: translateY(0);\n}\n.freemium-survey-components.card-survey-style .fade-reverse-exit .question-container {\n opacity: 1;\n transform: translateY(0);\n}\n.freemium-survey-components.card-survey-style .fade-reverse-exit-active .question-container {\n opacity: 0.05;\n transform: translateY(15px);\n}\n.freemium-survey-components.card-survey-style .fade-enter-active .question-container,\n.freemium-survey-components.card-survey-style .fade-exit-active .question-container,\n.freemium-survey-components.card-survey-style .fade-reverse-enter-active .question-container,\n.freemium-survey-components.card-survey-style .fade-reverse-exit-active .question-container {\n transition: opacity 300ms, transform 300ms;\n}\n.freemium-survey-components.card-survey-style .question-footer {\n display: flex;\n grid-gap: 40px;\n gap: 40px;\n width: 100%;\n align-items: center;\n}\n.freemium-survey-components.card-survey-style .question-footer:empty {\n display: none;\n}\n.freemium-survey-components.card-survey-style .question-footer:only-child {\n margin-left: auto;\n}\n.freemium-survey-components.card-survey-style .action-buttons {\n display: flex;\n grid-gap: 20px;\n gap: 20px;\n flex-direction: row-reverse;\n width: 100%;\n}\n.freemium-survey-components.card-survey-style .action-buttons:empty {\n display: none;\n}\n.freemium-survey-components.card-survey-style .skip-button {\n font-weight: 500;\n cursor: pointer;\n background: transparent;\n border: none;\n min-width: 40px;\n padding: 8px 16px;\n border-radius: 4px;\n color: var(--default-secondary-button-text-color);\n color: var(--secondary-button-text-color, var(--default-secondary-button-text-color));\n letter-spacing: 0.05rem;\n line-height: 1.5;\n border: 1px solid transparent;\n transform: translateY(0px);\n transition: transform ease 0.2s;\n}\n.freemium-survey-components.card-survey-style .skip-button:hover {\n background-color: #f3f3f3;\n transform: translateY(-4px);\n}\n.freemium-survey-components.card-survey-style .next-button {\n color: var(--default-button-text-color);\n color: var(--button-text-color, var(--default-button-text-color));\n}\n.freemium-survey-components.card-survey-style .submit {\n max-width: 700px;\n text-align: left;\n background: transparent;\n box-shadow: none;\n color: var(--default-button-text-color);\n color: var(--button-text-color, var(--default-button-text-color));\n}\n.freemium-survey-components.card-survey-style .thankyou {\n display: flex;\n align-items: center;\n justify-content: center;\n grid-gap: 20px;\n gap: 20px;\n min-height: 180px;\n}\n.freemium-survey-components.card-survey-style .thankyou .heading {\n font-weight: 600;\n font-size: 28px;\n}\n.freemium-survey-components.card-survey-style .thankyou .text {\n white-space: pre-wrap;\n font-weight: 500;\n font-size: 0.875rem;\n line-height: 1.6;\n color: #12344d;\n width: 75%;\n}\n.freemium-survey-components.card-survey-style .thankyou .redirection-text {\n color: #929292;\n margin-bottom: 12px;\n font-weight: 300;\n}\n.freemium-survey-components.card-survey-style .thankyou .link {\n width: 100%;\n display: inline-block;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n color: #666;\n font-weight: 500;\n text-decoration: underline;\n}\n.freemium-survey-components.card-survey-style .responsive-text-field {\n width: 100%;\n}\n.freemium-survey-components.card-survey-style .responsive-text-field .textarea-container {\n display: none;\n}\n.freemium-survey-components.card-survey-style .message-container:empty {\n display: none;\n}\n\n@media (max-width: 550px) {\n div.freemium-survey-components.card-survey-style .responsive-text-field .input-container {\n display: none;\n }\n div.freemium-survey-components.card-survey-style .responsive-text-field .textarea-container {\n display: flex;\n }\n div.freemium-survey-components.card-survey-style .question-footer {\n flex-direction: column-reverse;\n grid-gap: 20px;\n gap: 20px;\n }\n div.freemium-survey-components.card-survey-style .freemium-survey-step-navigation {\n width: 100%;\n }\n div.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button {\n width: 50%;\n }\n div.freemium-survey-components.card-survey-style .action-buttons {\n flex-direction: column;\n width: 100%;\n }\n div.freemium-survey-components.card-survey-style .action-buttons button {\n max-width: unset;\n }\n div.freemium-survey-components.card-survey-style .action-button {\n max-width: unset;\n width: 100%;\n }\n div.freemium-survey-components.card-survey-style .thankyou .text {\n width: auto;\n }\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .responsive-text-field .input-container {\n display: none;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .responsive-text-field .textarea-container {\n display: flex;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .question-footer {\n flex-direction: column-reverse;\n grid-gap: 20px;\n gap: 20px;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .freemium-survey-step-navigation {\n width: 100%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .freemium-survey-step-navigation .navigation-button {\n width: 50%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .action-buttons {\n flex-direction: column;\n width: 100%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .action-buttons button {\n max-width: unset;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .action-button {\n max-width: unset;\n width: 100%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .thankyou .text {\n width: auto;\n}\n\n.freemium-survey-components.mobile-preview .thankyou .text {\n width: unset;\n}");const S=({thankYouQuestion:e,preview:r,placeholders:o,npsValue:s})=>(n.useEffect((()=>{r||e.type_info.meta?.redirectUrl&&setTimeout((()=>{window.location.href=e.type_info.meta?.redirectUrl}),e.type_info.meta?.redirectDelay??1e4)}),[]),t.createElement("div",{className:"question-container thankyou"},t.createElement("div",{className:"heading"},"Thank you!"),t.createElement("div",{className:"text",dangerouslySetInnerHTML:{__html:_(e.text,o,s)}}),e.type_info.meta?.redirectUrl&&t.createElement("div",{style:{width:"100%"}},t.createElement("div",{className:"redirection-text"},"You will be redirected to the below URL automatically in"," ",e.type_info.meta?.redirectDelay," seconds.",t.createElement("br",null)),t.createElement("a",{className:"link",href:e.type_info.meta?.redirectUrl},e?.type_info.meta?.redirectUrl)))),N=({currentBlockIndex:e,currentBlockIndexOfBlocksWithQns:n,blocksWithQns:r,blocks:o,setHorizontalScrollUnits:s,preventQuestionAnimation:i,tempCurrentBlockIndexOfBlocksWithQns:a,setReverse:u,reverse:c})=>t.createElement("div",{className:"freemium-survey-step-navigation","data-navigation-element":"1"},t.createElement("button",{disabled:0==n.current,className:"navigation-button",onClick:()=>{c?(n.current=Math.max(n.current-1,0),e.current=o.findIndex((e=>e.name===r[n.current].name))):(a.current=Math.max(n.current-1,0),e.current=o.findIndex((e=>e.name===r[a.current].name))),i.current=!1,u(!0),s(n.current)}},t.createElement(q,null)),t.createElement("button",{className:"navigation-button",disabled:n.current>=r.length-1,onClick:()=>{i.current=!1,c?a.current=Math.min(n.current+1,r.length-1):n.current=Math.min(n.current+1,r.length-1),u(!1),s(n.current)}},t.createElement(k,null))),B=({widget:e,surveyStyle:n,formValues:r,blocksWithQns:o,blocks:s,thankYouQuestion:i,currentBlockIndexOfBlocksWithQns:u,currentBlockIndexOfBlocks:c,currentEditingBlock:l,isSubmitting:m,isValuesCommitted:d,isCurrentBlockFinal:p,setHorizontalScrollUnits:f,handleFormValues:y,skipBlock:v,setIsSubmitting:h,onSubmit:x,setIsSurveyCompleted:g,preventQuestionAnimation:b,preview:k,closePreview:q,setReverse:E,tempCurrentBlockIndexOfBlocksWithQns:_,question:C,reverse:S,othersMeta:B,...I})=>{const R=I.blockIndex??u.current,z=()=>!a.includes(C.type_info.question_type)&&!p(),O=()=>"RANGE"!==C.type_info.question_type&&!C.required&&!p(),T=()=>("DROPDOWN"===C.type_info.question_type&&!C.required&&r[C.name],!1),Q=()=>p()&&(e||"standard"!==n),F="MULTI_SELECT"===l.current.question.type_info.question_type&&r[l.current.question.name]?.includes("others")&&(!B[l.current.question.name]||""===B[l.current.question.name]);return t.createElement("div",{className:"question-footer"},!(!e&&"standard"===n||0===R&&void 0===r[C.name]||0===u.current&&!S)&&t.createElement(N,{currentBlockIndex:c,currentBlockIndexOfBlocksWithQns:u,blocksWithQns:o,blocks:s,setHorizontalScrollUnits:f,preventQuestionAnimation:b,setReverse:E,tempCurrentBlockIndexOfBlocksWithQns:_,reverse:S}),(z()||T()||O()||Q())&&t.createElement("div",{className:"action-buttons"},z()&&t.createElement(w,{onClick:()=>{E(!1),y(o[R],null,!0)},disabled:l.current.question.required&&(!r[l.current.question.name]||Array.isArray(r[l.current.question.name])&&0===r[l.current.question.name].length)||l.current.question.type_info.meta?.othersRequired&&F,className:"next-button"},"Next"),O()&&t.createElement("button",{className:"skip-button",onClick:()=>{E(!1),v(C)}},"Skip"),Q()&&t.createElement("div",{className:"submit"},t.createElement(w,{disabled:(l.current.question.required||l.current.question.type_info.pivot_question)&&(null==r[l.current.question.name]||0===r[l.current.question.name]?.length)||l.current.question.type_info.meta?.othersRequired&&F||m,onClick:()=>{h(!0),x({...r,others_meta:B},(()=>{i?.type_info.meta?.skipThankYouPage?k?setTimeout((()=>{q?.()}),300):window.location.href=i?.type_info.meta?.redirectUrl:g(!0)}))}},m?"Submitting":"Submit survey")),T()&&t.createElement("button",{className:"skip-button",onClick:()=>{E(!1),l.current=o[R],c.current=s.findIndex((e=>e.name===o[R].name)),v(C)}},"Clear selection")))},I=({survey:e,surveyStyle:o="standard",placeholders:s,onSubmit:i,widget:u,npsValue:c,preview:l,mobilePreview:m,closePreview:d})=>{const p=e.question_details?.questions||[],f=e.meta?.blocks||[],[y,v]=n.useState(null),[h,x]=n.useState({}),[b,w]=n.useState(!1),[k,q]=n.useState([]),[C,N]=n.useState(0),[I,R]=n.useState(!1),[z,O]=n.useState(null),[T,Q]=n.useState({}),F=n.useRef(null),L=n.useRef(null),V=n.useRef(-1),Y=n.useRef(null),A=n.useRef(0),M=n.useRef(0),U=n.useRef(!1),$=n.useRef([]),D=t.useRef(!!c&&"card"===o),H=n.useRef(null),W=n.useRef(0),[P,j]=n.useState(!1);n.useEffect((()=>{f&&(H.current=f.find((e=>"TY"===e.name)),v(f.filter((e=>"TY"!==e.name))))}),[f]),n.useEffect((()=>{M.current=W.current,N(C+1)}),[P]),n.useEffect((()=>{if(y)if(L.current=p.find((e=>e.type_info?.pivot_question))??p.find((e=>"RANGE"===e.type_info?.question_type))??p[0],null!=c){V.current=c;const e=p.find((e=>e.name===y[0].question_names[0]));F.current={...y[0],question:e},$.current=[...$.current,{...y[0],question:e}],q($.current),x({Q_1:c})}else if(!F.current&&y.length>0)return F.current=y[0],void X(y[0])}),[y,c]),t.useEffect((()=>{k.length&&($.current=k,M.current=k.length-1),N(k.length-1)}),[k]),n.useEffect((()=>{Object.keys(h).length>0&&F.current.question&&(a.includes(F.current.question.type_info.question_type)||U.current)&&!G()&&(c&&1==k.length?setTimeout((()=>{Z()}),1500):Z())}),[h]),n.useEffect((()=>{if(null!=h?.[L.current?.name])if(H.current?.is_based_on_rating){const e=L.current?.type_info?.choices[h?.[L.current?.name]-L.current?.type_info?.validation?.min??0]?.dependent_question_names,n=H.current?.question_names.find((n=>e?.includes(n))),t=p.find((e=>e.name===n));O(t)}else{const e=p.find((e=>e.name==H.current?.question_names[0]));O(e)}}),[h?.[L.current?.name]]);const G=()=>(A.current===y.length-1||"end"===F.current.branchOption)&&M.current===k.length-1,X=e=>{let n={};if(e.is_based_on_rating){const t=L.current?.type_info?.choices[h?.[L.current?.name]-L.current?.type_info?.validation?.min??0]?.dependent_question_names,r=e.question_names.find((e=>t?.includes(e)));n=p.find((e=>e.name===r))}else n=p.find((n=>n.name===e.question_names[0]));F.current.question=n;$.current.find((e=>e.question.name===n.name))?(N(C+1),M.current+=1):q([...$.current,{...e,question:n}])},Z=()=>{if(G())w(!0);else{if(F.current.nextBlock)A.current=y.findIndex((e=>e.name===F.current.nextBlock));else if(F.current.question.type_info?.meta?.branches){const e=F.current.question.type_info?.meta?.branches,n=h[F.current.question.name];let t;if(t="RANGE"===F.current.question.type_info.question_type?e.find((e=>n>=e.min&&n<=e.max)):e.find((e=>n===e.value)),t?.nextBlock){if("TY"===t.nextBlock)return void w(!0);A.current=y.findIndex((e=>e.name===t.nextBlock))}else A.current+=1}else A.current+=1;F.current=y[A.current],X(y[A.current])}},K=(e,n,t)=>{if(D.current=!1,t){if(U.current=!0,null!=h[e.question.name]&&e.name!==k[k.length-1].name){const[t,r]=(e=>{const n=k.findIndex((n=>n.name===e.name)),t=k.slice(0,n+1),r=t.reduce(((e,n)=>(e[n.question.name]=h[n.question.name],e)),{});return A.current=y.findIndex((n=>n.name===e.name)),[t,r]})(e);x({...r,...null!=n&&{[e.question.name]:n}}),$.current=t}else x({...h,...null!=n&&{[e.question.name]:n}});L?.current?.name==e?.question?.name&&(V.current=n)}else x({...h,...null!=n&&{[e.question.name]:n}})};if(!F.current||!F.current.question)return null;const J=k[Math.min(M.current??k.length-1,k.length-1)];return t.createElement("div",{className:`freemium-survey-components ${m?"mobile-preview":""} ${o}-survey-style`,id:"freemium-survey"},t.createElement(g,{totalSteps:y.length,completedSteps:A.current+(b?1:0)}),t.createElement(r.SwitchTransition,{mode:"out-in"},t.createElement(r.CSSTransition,{key:M.current+String(b),addEndListener:(e,n)=>{e.addEventListener("transitionend",n,!1)},classNames:P?"fade-reverse":"fade"},t.createElement("div",{className:"questions"},b?t.createElement(S,{thankYouQuestion:z,preview:l,placeholders:s,npsValue:V.current}):t.createElement("div",{ref:Y,id:`${J.question.name}`,className:`question-container ${u||"card"===o}`,"data-test-question-name":J.question.name},t.createElement("div",{className:"question-text",dangerouslySetInnerHTML:{__html:_(J.question.text,s,V.current)},title:`question-${M.current}`,role:"heading","aria-level":1}),t.createElement("div",{onTransitionEndCapture:e=>e.stopPropagation(),style:{width:"100%"}},t.createElement(E,{question:J.question,formValues:h,othersMeta:T,autoFocus:!0,autoFocusDelay:"standard"===o?350:0,saveOthersValue:(e,n)=>{Q({...T,[e]:n})},onChangeHandler:e=>{U.current=!1,A.current=y.findIndex((e=>e.name===J.name)),F.current=J,j(!1),K(J,e,a.includes(J.question.type_info.question_type)&&!G())}})),t.createElement(B,{question:J.question,widget:u,surveyStyle:o,formValues:h,othersMeta:T,blocksWithQns:k,blocks:y,thankYouQuestion:z,currentBlockIndexOfBlocksWithQns:M,reverse:P,setReverse:j,currentBlockIndexOfBlocks:A,currentEditingBlock:F,isSubmitting:I,isValuesCommitted:U,isCurrentBlockFinal:G,setHorizontalScrollUnits:N,handleFormValues:K,skipBlock:e=>{U.current=!0,delete h[e.name],x({...h})},setIsSubmitting:R,onSubmit:i,setIsSurveyCompleted:w,preventQuestionAnimation:D,preview:l,closePreview:d,tempCurrentBlockIndexOfBlocksWithQns:W}))))))};o(":root {\n --default-brand-color: #264966;\n --default-question-text-color: #000;\n --default-question-background-color: #fff;\n --default-background-color: #f8f8f8;\n --default-button-text-color: #fff;\n --default-secondary-button-text-color: #000;\n --default-input-placeholder-color: #92a2b1;\n}\n\n.freemium-survey-components.widget-survey-components .freemium-survey-step-navigation {\n white-space: nowrap;\n border-radius: 3px;\n border: 1px solid #efefef;\n}\n.freemium-survey-components.widget-survey-components .freemium-survey-step-navigation .navigation-button {\n width: 38px;\n text-align: -webkit-center;\n height: 38px;\n background-color: #fff;\n border: none;\n cursor: pointer;\n border-radius: 0 3px 3px 0;\n}\n.freemium-survey-components.widget-survey-components .freemium-survey-step-navigation .navigation-button:first-of-type {\n border-right: 1px solid #efefef;\n border-radius: 3px 0 0 3px;\n}\n.freemium-survey-components.widget-survey-components .freemium-survey-step-navigation .navigation-button:disabled {\n cursor: not-allowed;\n opacity: 0.5;\n}\n.freemium-survey-components.widget-survey-components .freemium-survey-step-navigation .navigation-button:focus {\n position: relative;\n z-index: 1;\n}\n.freemium-survey-components.widget-survey-components .question-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n text-align: center;\n max-width: 700px;\n margin: 0 auto;\n border-radius: 4px;\n box-shadow: 0px 12px 15px rgba(18, 52, 77, 0.03);\n padding: 28px;\n grid-gap: 28px;\n gap: 28px;\n position: relative;\n overflow: auto;\n}\n.freemium-survey-components.widget-survey-components .hide-question-container {\n opacity: 0;\n}\n.freemium-survey-components.widget-survey-components .question-text {\n font-size: 1rem;\n font-weight: 600;\n line-height: 1.8;\n width: 100%;\n text-align: left;\n color: var(--default-question-text-color);\n color: var(--question-text-color, var(--default-question-text-color));\n}\n.freemium-survey-components.widget-survey-components .autofocus-button {\n border: none;\n width: 0;\n height: 0;\n opacity: 0;\n margin-top: -12px;\n margin-left: -12px;\n position: absolute;\n}\n.freemium-survey-components.widget-survey-components .fade-enter {\n opacity: 1;\n transform: translateX(80px);\n position: absolute;\n}\n.freemium-survey-components.widget-survey-components .fade-enter-active {\n position: absolute;\n opacity: 1;\n transform: translateX(0);\n}\n.freemium-survey-components.widget-survey-components .fade-enter-done {\n position: absolute;\n}\n.freemium-survey-components.widget-survey-components .fade-exit {\n opacity: 0.05;\n pointer-events: none;\n transform: translateX(0);\n}\n.freemium-survey-components.widget-survey-components .fade-exit-active {\n pointer-events: none;\n opacity: 0;\n transform: translateX(-80px);\n}\n.freemium-survey-components.widget-survey-components .fade-reverse-enter {\n opacity: 0;\n position: absolute;\n transform: translateX(-80px);\n}\n.freemium-survey-components.widget-survey-components .fade-reverse-enter-active {\n opacity: 1;\n position: absolute;\n transform: translateX(0);\n}\n.freemium-survey-components.widget-survey-components .fade-reverse-exit {\n opacity: 0.05;\n transform: translateX(0);\n}\n.freemium-survey-components.widget-survey-components .fade-reverse-exit-active {\n opacity: 0;\n transform: translateX(80px);\n}\n.freemium-survey-components.widget-survey-components .fade-enter-active,\n.freemium-survey-components.widget-survey-components .fade-reverse-enter-active {\n transition: opacity 300ms, transform 300ms;\n}\n.freemium-survey-components.widget-survey-components .fade-reverse-exit-active,\n.freemium-survey-components.widget-survey-components .fade-exit-active {\n transition: opacity 200ms, transform 200ms;\n}\n.freemium-survey-components.widget-survey-components .question-footer {\n display: flex;\n grid-gap: 40px;\n gap: 40px;\n width: 100%;\n align-items: center;\n}\n.freemium-survey-components.widget-survey-components .question-footer:empty {\n display: none;\n}\n.freemium-survey-components.widget-survey-components .question-footer:only-child {\n margin-left: auto;\n}\n.freemium-survey-components.widget-survey-components .action-buttons {\n display: flex;\n grid-gap: 20px;\n gap: 20px;\n flex-direction: row-reverse;\n width: 100%;\n}\n.freemium-survey-components.widget-survey-components .action-buttons:empty {\n display: none;\n}\n.freemium-survey-components.widget-survey-components .skip-button {\n font-weight: 500;\n cursor: pointer;\n background: transparent;\n border: none;\n min-width: 40px;\n padding: 8px 16px;\n border-radius: 4px;\n color: var(--default-secondary-button-text-color);\n color: var(--secondary-button-text-color, var(--default-secondary-button-text-color));\n letter-spacing: 0.05rem;\n line-height: 1.5;\n border: 1px solid transparent;\n transform: translateY(0px);\n transition: transform ease 0.2s;\n}\n.freemium-survey-components.widget-survey-components .skip-button:hover {\n background-color: #f3f3f3;\n transform: translateY(-4px);\n}\n.freemium-survey-components.widget-survey-components .next-button {\n color: var(--default-button-text-color);\n color: var(--button-text-color, var(--default-button-text-color));\n}\n.freemium-survey-components.widget-survey-components .submit {\n max-width: 700px;\n text-align: left;\n background: transparent;\n box-shadow: none;\n color: var(--default-button-text-color);\n color: var(--button-text-color, var(--default-button-text-color));\n}\n.freemium-survey-components.widget-survey-components .thankyou {\n display: flex;\n align-items: center;\n justify-content: center;\n grid-gap: 20px;\n gap: 20px;\n min-height: 180px;\n}\n.freemium-survey-components.widget-survey-components .thankyou .heading {\n font-weight: 600;\n font-size: 28px;\n}\n.freemium-survey-components.widget-survey-components .thankyou .text {\n white-space: pre-wrap;\n font-weight: 500;\n font-size: 0.875rem;\n line-height: 1.6;\n color: #12344d;\n width: 75%;\n}\n.freemium-survey-components.widget-survey-components .thankyou .redirection-text {\n color: #929292;\n margin-bottom: 12px;\n font-weight: 300;\n}\n.freemium-survey-components.widget-survey-components .thankyou .link {\n width: 100%;\n display: inline-block;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n color: #666;\n font-weight: 500;\n text-decoration: underline;\n}\n.freemium-survey-components.widget-survey-components .responsive-text-field {\n width: 100%;\n}\n.freemium-survey-components.widget-survey-components .responsive-text-field .textarea-container {\n display: none;\n}\n.freemium-survey-components.widget-survey-components .message-container:empty {\n display: none;\n}\n\n@media (max-width: 550px) {\n div.freemium-survey-components.card-survey-style .responsive-text-field .input-container {\n display: none;\n }\n div.freemium-survey-components.card-survey-style .responsive-text-field .textarea-container {\n display: flex;\n }\n div.freemium-survey-components.card-survey-style .question-footer {\n flex-direction: column-reverse;\n grid-gap: 20px;\n gap: 20px;\n }\n div.freemium-survey-components.card-survey-style .freemium-survey-step-navigation {\n width: 100%;\n }\n div.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button {\n width: 50%;\n }\n div.freemium-survey-components.card-survey-style .action-buttons {\n flex-direction: column;\n width: 100%;\n }\n div.freemium-survey-components.card-survey-style .action-buttons button {\n max-width: unset;\n }\n div.freemium-survey-components.card-survey-style .action-button {\n max-width: unset;\n width: 100%;\n }\n div.freemium-survey-components.card-survey-style .thankyou .text {\n width: auto;\n }\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .responsive-text-field .input-container {\n display: none;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .responsive-text-field .textarea-container {\n display: flex;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .question-footer {\n flex-direction: column-reverse;\n grid-gap: 20px;\n gap: 20px;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .freemium-survey-step-navigation {\n width: 100%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .freemium-survey-step-navigation .navigation-button {\n width: 50%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .action-buttons {\n flex-direction: column;\n width: 100%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .action-buttons button {\n max-width: unset;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .action-button {\n max-width: unset;\n width: 100%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .thankyou .text {\n width: auto;\n}\n\n.widget-survey-components.compact-style .freemium-survey-step-navigation {\n padding: 0 2px;\n margin-left: 4px;\n box-shadow: 0px 0px 6px #eee;\n margin-top: 4px;\n}\n.widget-survey-components.compact-style .nps-container .footer {\n padding-top: 12px;\n}\n.widget-survey-components.compact-style .nps-container .choices {\n grid-gap: 12px;\n gap: 12px;\n}\n\n.widget-survey-components,\n.card-survey-style {\n display: flex;\n flex-direction: column;\n grid-gap: 28px;\n gap: 28px;\n flex-grow: 1;\n font-size: 0.875rem;\n position: relative;\n overflow: hidden;\n}\n.widget-survey-components .questions,\n.card-survey-style .questions {\n min-width: 100%;\n max-width: 100%;\n background: var(--default-question-background-color);\n background: var(--question-background-color, var(--default-question-background-color));\n position: relative;\n display: flex;\n justify-content: row;\n align-items: flex-end;\n height: 100%;\n transition: height 300ms ease;\n}\n.widget-survey-components .question-text,\n.card-survey-style .question-text {\n width: 100%;\n text-align: left;\n}\n.widget-survey-components .focus-lock,\n.card-survey-style .focus-lock {\n width: 100%;\n}\n.widget-survey-components .question-container,\n.card-survey-style .question-container {\n height: -webkit-fit-content;\n height: -moz-fit-content;\n height: fit-content;\n max-height: 100%;\n min-width: 100%;\n max-width: 100%;\n margin-bottom: 0;\n padding: 28px;\n grid-gap: 28px;\n gap: 28px;\n flex-grow: 1;\n align-self: flex-end;\n margin-top: auto;\n position: absolute;\n}\n.widget-survey-components .question-footer,\n.card-survey-style .question-footer {\n margin: 0px auto;\n justify-content: space-between;\n position: -webkit-sticky;\n position: sticky;\n bottom: -28px;\n padding: 20px 0;\n background: var(--default-question-background-color);\n background: var(--question-background-color, var(--default-question-background-color));\n}\n.widget-survey-components .submit,\n.card-survey-style .submit {\n padding-bottom: 0;\n margin: unset;\n}\n.widget-survey-components .nps-container .footer,\n.card-survey-style .nps-container .footer {\n padding-top: 12px;\n}\n.widget-survey-components .nps-container .widget .choices,\n.card-survey-style .nps-container .widget .choices {\n grid-gap: 8px;\n gap: 8px;\n}\n.widget-survey-components .radio-group,\n.card-survey-style .radio-group {\n width: 100%;\n overflow: auto;\n}\n.widget-survey-components .checkbox-group,\n.card-survey-style .checkbox-group {\n width: 100%;\n overflow: auto;\n}\n\ndiv.widget-survey-components .question-container {\n box-shadow: none;\n border-radius: 0;\n}\ndiv.widget-survey-components .question-text {\n font-size: 0.875rem;\n}\ndiv.widget-survey-components .progressbar-container {\n position: absolute;\n}\ndiv.widget-survey-components .progressbar-container .progressbar {\n border-radius: 3px 0 0 0;\n}\ndiv.widget-survey-components .textarea-container .end-max-length {\n padding: 4px;\n}\ndiv.widget-survey-components .responsive-text-field .input-container {\n display: none;\n}\ndiv.widget-survey-components .responsive-text-field .textarea-container {\n display: flex;\n}\ndiv.widget-survey-components div.thankyou {\n min-height: unset;\n}\ndiv.widget-survey-components div.thankyou .text {\n width: 85%;\n}\ndiv.widget-survey-components div.thankyou svg {\n width: 140px;\n height: 120px;\n}\n\ndiv.widget-survey-components.default-style .freemium-survey-step-navigation {\n margin: 0;\n}\ndiv.widget-survey-components.default-style .question-container {\n padding: 28px;\n}\ndiv.widget-survey-components.default-style .question-footer {\n justify-content: space-between;\n}\ndiv.widget-survey-components.default-style .nps-container .footer {\n padding-top: 12px;\n}\ndiv.widget-survey-components.default-style .nps-container .choices {\n flex-wrap: unset;\n grid-gap: 12px;\n gap: 12px;\n}\ndiv.widget-survey-components.default-style .action-button {\n line-height: 1.2;\n}\ndiv.widget-survey-components.default-style .radio-group {\n flex-direction: column;\n flex-wrap: nowrap;\n overflow: auto;\n}\ndiv.widget-survey-components.default-style .radio-group .radio-label {\n padding: 12px 16px;\n min-width: 160px;\n font-size: 0.9rem;\n}\ndiv.widget-survey-components.default-style .checkbox-group {\n flex-direction: row;\n flex-wrap: wrap;\n}\ndiv.widget-survey-components.default-style .checkbox-group .checkbox-label {\n padding: 12px 16px;\n min-width: 160px;\n font-size: 0.9rem;\n}\ndiv.widget-survey-components.default-style textarea {\n min-height: 84px;\n}\ndiv.widget-survey-components.default-style .end-max-length {\n font-size: 0.8rem;\n font-weight: 300;\n padding: 4px;\n}\n\n.widget-survey-components.cozy-style .freemium-survey-step-navigation {\n margin: 0;\n}\n.widget-survey-components.cozy-style .question-text {\n font-size: 1rem;\n}\n.widget-survey-components.cozy-style .question-text.nps {\n text-align: center;\n width: 60%;\n min-width: 600px;\n margin: auto;\n}\n.widget-survey-components.cozy-style .question-container {\n padding: 12px 28px;\n}\n.widget-survey-components.cozy-style .question-footer {\n justify-content: space-between;\n}\n.widget-survey-components.cozy-style .nps-container {\n grid-gap: 44px;\n gap: 44px;\n}\n.widget-survey-components.cozy-style .nps-container .widget {\n display: flex;\n justify-content: center;\n}\n.widget-survey-components.cozy-style .nps-container .button-container {\n width: 60%;\n min-width: 600px;\n margin: 0 auto;\n}\n.widget-survey-components.cozy-style .nps-container .button-container .choices {\n justify-content: space-around;\n}\n.widget-survey-components.cozy-style .nps-container .footer {\n padding-top: 8px;\n}\n.widget-survey-components.cozy-style .action-button {\n line-height: 1.2;\n}\n.widget-survey-components.cozy-style .radio-group {\n flex-direction: row;\n flex-wrap: wrap;\n}\n.widget-survey-components.cozy-style .radio-group .radio-label {\n padding: 12px 16px;\n min-width: 160px;\n font-size: 0.9rem;\n}\n.widget-survey-components.cozy-style .checkbox-group {\n flex-direction: row;\n flex-wrap: wrap;\n}\n.widget-survey-components.cozy-style .checkbox-group .checkbox-label {\n padding: 12px 16px;\n min-width: 160px;\n font-size: 0.9rem;\n}\n.widget-survey-components.cozy-style textarea {\n min-height: 60px;\n}\n.widget-survey-components.cozy-style .end-max-length {\n font-size: 0.8rem;\n font-weight: 300;\n padding: 4px;\n}\n\n.freemium-survey-components.mobile-preview .thankyou .text {\n width: unset;\n}");const R=({thankYouQuestion:e,preview:r,placeholders:o,npsValue:s,setBlockElementRef:i},a)=>(n.useEffect((()=>{r||e.type_info.meta?.redirectUrl&&setTimeout((()=>{window.location.href=e.type_info.meta?.redirectUrl}),e.type_info.meta?.redirectDelay??1e4)}),[]),t.createElement(t.Fragment,null,t.createElement("div",{className:"heading"},"Thank you!"),t.createElement("div",{className:"text",dangerouslySetInnerHTML:{__html:_(e.text,o,s)}}),e.type_info.meta?.redirectUrl&&t.createElement("div",{style:{width:"100%"}},t.createElement("div",{className:"redirection-text"},"You will be redirected to the below URL automatically in"," ",e.type_info.meta?.redirectDelay," seconds.",t.createElement("br",null)),t.createElement("a",{className:"link",href:e.type_info.meta?.redirectUrl},e?.type_info.meta?.redirectUrl)))),z=({currentBlockIndexOfBlocks:e,currentBlockIndexOfBlocksWithQns:n,blocksWithQns:r,blocks:o,setHorizontalScrollUnits:s,preventQuestionAnimation:i,tempCurrentBlockIndexOfBlocksWithQns:a,setReverse:u,reverse:c})=>t.createElement("div",{className:"freemium-survey-step-navigation","data-navigation-element":"1"},t.createElement("button",{disabled:0==n.current,className:"navigation-button",onClick:()=>{c?(n.current=Math.max(n.current-1,0),e.current=o.findIndex((e=>e.name===r[n.current].name))):(a.current=Math.max(n.current-1,0),e.current=o.findIndex((e=>e.name===r[a.current].name))),i.current=!1,u(!0),s(n.current)}},t.createElement(q,null)),t.createElement("button",{className:"navigation-button",disabled:n.current>=r.length-1,onClick:()=>{i.current=!1,c?a.current=Math.min(n.current+1,r.length-1):n.current=Math.min(n.current+1,r.length-1),u(!1),s(n.current)}},t.createElement(k,null))),O=({widget:e,widgetStyle:n,surveyStyle:r,formValues:o,blocksWithQns:s,blocks:i,thankYouQuestion:u,currentBlockIndexOfBlocksWithQns:c,currentBlockIndexOfBlocks:l,currentEditingBlock:m,isSubmitting:d,isValuesCommitted:p,isCurrentBlockFinal:f,setHorizontalScrollUnits:y,handleFormValues:v,skipBlock:h,setIsSubmitting:x,onSubmit:g,setIsSurveyCompleted:b,preventQuestionAnimation:k,preview:q,closePreview:E,setReverse:_,tempCurrentBlockIndexOfBlocksWithQns:C,question:S,reverse:N,othersMeta:B,...I})=>{const R=I.blockIndex??c.current,O=()=>!a.includes(S.type_info.question_type)&&!f(),T=()=>"RANGE"!==S.type_info.question_type&&!S.required&&!f(),Q=()=>("DROPDOWN"===S.type_info.question_type&&!S.required&&o[S.name],!1),F=()=>f()&&(e||"standard"!==r),L="MULTI_SELECT"===m.current.question.type_info.question_type&&o[m.current.question.name]?.includes("others")&&(!B[m.current.question.name]||""===B[m.current.question.name]);return t.createElement("div",{className:"question-footer"},!(!e&&"standard"===r||0===R&&void 0===o[S.name]||"compact"===n||0===c.current&&!N)&&t.createElement(z,{currentBlockIndexOfBlocks:l,currentBlockIndexOfBlocksWithQns:c,blocksWithQns:s,blocks:i,setHorizontalScrollUnits:y,preventQuestionAnimation:k,setReverse:_,tempCurrentBlockIndexOfBlocksWithQns:C,reverse:N}),(O()||Q()||T()||F())&&t.createElement("div",{className:"action-buttons"},O()&&t.createElement(w,{onClick:()=>{_(!1),v(s[R],null,!0)},disabled:m.current.question.required&&(!o[m.current.question.name]||Array.isArray(o[m.current.question.name])&&0===o[m.current.question.name].length)||m.current.question.type_info.meta?.othersRequired&&L,className:"next-button"},"Next"),T()&&t.createElement("button",{className:"skip-button",onClick:()=>{_(!1),h(S)}},"Skip"),F()&&t.createElement("div",{className:"submit"},t.createElement(w,{disabled:(m.current.question.required||m.current.question.type_info.pivot_question)&&(null==o[m.current.question.name]||0===o[m.current.question.name]?.length)||m.current.question.type_info.meta?.othersRequired&&L||d,onClick:()=>{x(!0),g({...o,others_meta:B},(()=>{u?.type_info.meta?.skipThankYouPage?q?setTimeout((()=>{E?.()}),300):window.location.href=u?.type_info.meta?.redirectUrl:b(!0)}))}},d?"Submitting":"Submit survey")),Q()&&t.createElement("button",{className:"skip-button",onClick:()=>{_(!1),m.current=s[R],l.current=i.findIndex((e=>e.name===s[R].name)),h(S)}},"Clear selection")))},T=({survey:e,surveyStyle:o="standard",placeholders:s,onSubmit:i,widget:c,npsValue:l,widgetStyle:m,widgetNavigatorQuerySelector:d,preview:p,mobilePreview:f,closePreview:y})=>{const v=e.question_details?.questions||[],h=e.meta?.blocks||[],[x,b]=n.useState(null),[w,k]=n.useState({}),[q,C]=n.useState(!1),[S,N]=n.useState([]),[B,I]=n.useState(0),[z,T]=n.useState(!1),[Q,F]=n.useState(null),[L,V]=n.useState({}),Y=n.useRef(null),A=n.useRef(null),M=n.useRef(-1),[U,$]=n.useState(null),D=n.useRef(0),H=n.useRef(0),W=n.useRef(!1),P=n.useRef([]),j=n.useRef(!!l&&"card"===o),G=n.useRef(null),X=n.useRef(0),[Z,K]=n.useState(!1),J=n.useRef(0);n.useEffect((()=>{h&&(G.current=h.find((e=>"TY"===e.name)),b(h.filter((e=>"TY"!==e.name))))}),[h]),n.useEffect((()=>{H.current=X.current,I(B+1)}),[Z]),n.useEffect((()=>{if(x)if(A.current=v.find((e=>e.type_info?.pivot_question))??v.find((e=>"RANGE"===e.type_info?.question_type))??v[0],null!=l){M.current=l;const e=v.find((e=>e.name===x[0].question_names[0]));Y.current={...x[0],question:e},P.current=[...P.current,{...x[0],question:e}],N(P.current),k({Q_1:l})}else if(!Y.current&&x.length>0)return Y.current=x[0],void ne(x[0])}),[x,l]),n.useEffect((()=>{S.length&&(P.current=S,H.current=S.length-1,I(S.length-1))}),[S]),n.useEffect((()=>{Object.keys(w).length>0&&Y.current.question&&(a.includes(Y.current.question.type_info.question_type)||W.current)&&!ee()&&(l&&1==S.length?setTimeout((()=>{te()}),1500):te())}),[w]),n.useEffect((()=>{if(null!=w?.[A.current?.name])if(G.current?.is_based_on_rating){const e=A.current?.type_info?.choices[w?.[A.current?.name]-A.current?.type_info?.validation?.min??0]?.dependent_question_names,n=G.current?.question_names.find((n=>e?.includes(n))),t=v.find((e=>e.name===n));F(t)}else{const e=v.find((e=>e.name==G.current?.question_names[0]));F(e)}}),[w?.[A.current?.name]]);n.useMemo((()=>{(()=>{if(U){U.style.minHeight="unset",U.style.height="min-content";const e=Math.min(U?.scrollHeight,u[m]);U.style.height=e+"px",U.style.minHeight=e+"px",J.current=e}})()}),[U]);const ee=()=>(D.current===x.length-1||"end"===Y.current.branchOption)&&H.current===S.length-1,ne=e=>{let n={};if(e.is_based_on_rating){const t=A.current?.type_info?.choices[w?.[A.current?.name]-A.current?.type_info?.validation?.min??0]?.dependent_question_names,r=e.question_names.find((e=>t?.includes(e)));n=v.find((e=>e.name===r))}else n=v.find((n=>n.name===e.question_names[0]));Y.current.question=n;P.current.find((e=>e.question.name===n.name))?(I(B+1),H.current+=1):N([...P.current,{...e,question:n}])},te=()=>{if(ee())C(!0);else{if(Y.current.nextBlock)D.current=x.findIndex((e=>e.name===Y.current.nextBlock));else if(Y.current.question.type_info?.meta?.branches){const e=Y.current.question.type_info?.meta?.branches,n=w[Y.current.question.name];let t;if(t="RANGE"===Y.current.question.type_info.question_type?e.find((e=>n>=e.min&&n<=e.max)):e.find((e=>n===e.value)),t?.nextBlock){if("TY"===t.nextBlock)return void C(!0);D.current=x.findIndex((e=>e.name===t.nextBlock))}else D.current+=1}else D.current+=1;Y.current=x[D.current],ne(x[D.current])}},re=(e,n,t)=>{if(j.current=!1,t){if(W.current=!0,null!=w[e.question.name]&&e.name!==S[S.length-1].name){const[t,r]=(e=>{const n=S.findIndex((n=>n.name===e.name)),t=S.slice(0,n+1),r=t.reduce(((e,n)=>(e[n.question.name]=w[n.question.name],e)),{});return D.current=x.findIndex((n=>n.name===e.name)),[t,r]})(e);k({...r,...null!=n&&{[e.question.name]:n}}),P.current=t}else k({...w,...null!=n&&{[e.question.name]:n}});A?.current?.name==e?.question?.name&&(M.current=n)}else k({...w,...null!=n&&{[e.question.name]:n}})};if(!Y.current||!Y.current.question)return null;const oe=S[Math.min(H.current??S.length-1,S.length-1)];return t.createElement("div",{className:`freemium-survey-components ${c?"widget-survey-components":""} ${m}-style ${f?"mobile-preview":""}`,id:"freemium-survey"},t.createElement(g,{totalSteps:x.length,completedSteps:D.current+(q?1:0)}),t.createElement("div",{className:"questions",style:{height:J.current,...1===S.length?{transition:"none"}:{}}},t.createElement(r.TransitionGroup,{component:null},t.createElement(r.CSSTransition,{key:oe.question.name+String(q),unmountOnExit:!0,addEndListener:(e,n)=>{e.addEventListener("transitionend",n,!1)},classNames:Z?"fade-reverse":"fade"},t.createElement("div",{ref:e=>e?$(e):null,id:`${oe.question.name}`,className:"question-container "+(q?"thankyou":""),"data-test-question-name":oe.question.name},q?t.createElement(R,{thankYouQuestion:Q,preview:p,placeholders:s,npsValue:M.current,setBlockElementRef:$}):t.createElement(t.Fragment,null,t.createElement("div",{className:"question-text",dangerouslySetInnerHTML:{__html:_(oe.question.text,s,M.current)},title:`question-${H.current}`,role:"heading","aria-level":1}),t.createElement("div",{onTransitionEndCapture:e=>e.stopPropagation(),style:{width:"100%",flexGrow:"1"}},t.createElement(E,{question:oe.question,formValues:w,othersMeta:L,autoFocus:!0,autoFocusDelay:"standard"===o?300:0,saveOthersValue:(e,n)=>{V({...L,[e]:n})},onChangeHandler:e=>{W.current=!1,D.current=x.findIndex((e=>e.name===oe.name)),Y.current=oe,K(!1),re(oe,e,a.includes(oe.question.type_info.question_type)&&!ee())}})),t.createElement(O,{question:oe.question,widget:c,widgetStyle:m,surveyStyle:o,formValues:w,othersMeta:L,blocksWithQns:S,blocks:x,thankYouQuestion:Q,currentBlockIndexOfBlocksWithQns:H,reverse:Z,setReverse:K,currentBlockIndexOfBlocks:D,currentEditingBlock:Y,isSubmitting:z,isValuesCommitted:W,isCurrentBlockFinal:ee,setHorizontalScrollUnits:I,handleFormValues:re,skipBlock:e=>{W.current=!0,delete w[e.name],k({...w})},setIsSubmitting:T,onSubmit:i,setIsSurveyCompleted:C,preventQuestionAnimation:j,preview:p,closePreview:y,tempCurrentBlockIndexOfBlocksWithQns:X})))))))};o(":root {\n --default-brand-color: #264966;\n --default-question-text-color: #000;\n --default-question-background-color: #fff;\n --default-background-color: #f8f8f8;\n --default-button-text-color: #fff;\n --default-secondary-button-text-color: #000;\n --default-input-placeholder-color: #92a2b1;\n --compact-widget-max-height: 480px;\n --default-widget-max-height: 460px;\n --cozy-widget-max-height: 380px;\n}\n\n.freemium-survey-step-navigation {\n border-radius: 3px;\n border: 1px solid #efefef;\n white-space: nowrap;\n}\n.freemium-survey-step-navigation .navigation-button {\n width: 38px;\n text-align: -webkit-center;\n height: 38px;\n background-color: #fff;\n border: none;\n cursor: pointer;\n border-radius: 0 3px 3px 0;\n}\n.freemium-survey-step-navigation .navigation-button:first-of-type {\n border-right: 1px solid #efefef;\n border-radius: 3px 0 0 3px;\n}\n.freemium-survey-step-navigation .navigation-button:disabled {\n cursor: not-allowed;\n opacity: 0.5;\n}\n.freemium-survey-step-navigation .navigation-button:focus {\n position: relative;\n z-index: 1;\n}\n\n.freemium-survey-components.standard-survey-style .question-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n text-align: center;\n max-width: 700px;\n margin: 0 auto;\n background: var(--default-question-background-color);\n background: var(--question-background-color, var(--default-question-background-color));\n border-radius: 4px;\n transition: transform 500ms ease 0ms, opacity 800ms ease 0ms;\n box-shadow: 0px 12px 15px rgba(18, 52, 77, 0.03);\n margin-bottom: 28px;\n padding: 28px;\n grid-gap: 28px;\n gap: 28px;\n position: relative;\n height: -webkit-fit-content;\n height: -moz-fit-content;\n height: fit-content;\n overflow: auto;\n opacity: 1;\n}\n.freemium-survey-components.standard-survey-style .hide-question-container {\n pointer-events: none;\n opacity: 0;\n}\n.freemium-survey-components.standard-survey-style .question-text {\n font-size: 1rem;\n font-weight: 600;\n line-height: 1.8;\n width: 100%;\n text-align: left;\n color: var(--default-question-text-color);\n color: var(--question-text-color, var(--default-question-text-color));\n}\n.freemium-survey-components.standard-survey-style .autofocus-button {\n border: none;\n width: 0;\n height: 0;\n opacity: 0;\n margin-top: -12px;\n margin-left: -12px;\n position: absolute;\n}\n.freemium-survey-components.standard-survey-style .question-footer {\n display: flex;\n justify-content: flex-start;\n grid-gap: 40px;\n gap: 40px;\n width: 100%;\n align-items: center;\n}\n.freemium-survey-components.standard-survey-style .question-footer:empty {\n display: none;\n}\n.freemium-survey-components.standard-survey-style .action-buttons {\n display: flex;\n grid-gap: 20px;\n gap: 20px;\n flex-direction: row-reverse;\n}\n.freemium-survey-components.standard-survey-style .action-buttons:empty {\n display: none;\n}\n.freemium-survey-components.standard-survey-style .skip-button {\n font-weight: 500;\n cursor: pointer;\n background: transparent;\n border: none;\n min-width: 40px;\n padding: 8px 16px;\n border-radius: 4px;\n color: var(--default-secondary-button-text-color);\n color: var(--secondary-button-text-color, var(--default-secondary-button-text-color));\n letter-spacing: 0.05rem;\n line-height: 1.5;\n border: 1px solid transparent;\n transform: translateY(0px);\n transition: transform ease 0.2s;\n}\n.freemium-survey-components.standard-survey-style .skip-button:hover {\n background-color: #f3f3f3;\n transform: translateY(-4px);\n}\n.freemium-survey-components.standard-survey-style .next-button {\n color: var(--default-button-text-color);\n color: var(--button-text-color, var(--default-button-text-color));\n}\n.freemium-survey-components.standard-survey-style .submit {\n max-width: 700px;\n margin: 0 auto;\n text-align: left;\n background: transparent;\n box-shadow: none;\n padding-bottom: 40px;\n color: var(--default-button-text-color);\n color: var(--button-text-color, var(--default-button-text-color));\n}\n.freemium-survey-components.standard-survey-style .fade-enter {\n transition: all ease 400ms;\n opacity: 0;\n transform: translateY(40px);\n}\n.freemium-survey-components.standard-survey-style .fade-enter-active {\n transition: all ease 400ms;\n opacity: 1;\n transform: translateY(0);\n}\n.freemium-survey-components.standard-survey-style .fade-exit {\n transition: all ease 400ms;\n opacity: 1;\n transform: translateY(0);\n}\n.freemium-survey-components.standard-survey-style .fade-exit-active {\n transition: all ease 400ms;\n opacity: 0;\n transform: translateY(-40px);\n}\n.freemium-survey-components.standard-survey-style .thankyou {\n display: flex;\n align-items: center;\n justify-content: center;\n grid-gap: 20px;\n gap: 20px;\n min-height: 180px;\n}\n.freemium-survey-components.standard-survey-style .thankyou .heading {\n font-weight: 600;\n font-size: 28px;\n}\n.freemium-survey-components.standard-survey-style .thankyou .text {\n white-space: pre-wrap;\n font-weight: 500;\n font-size: 0.875rem;\n line-height: 1.6;\n color: #12344d;\n width: 75%;\n}\n.freemium-survey-components.standard-survey-style .thankyou .redirection-text {\n color: #929292;\n margin-bottom: 12px;\n font-weight: 300;\n}\n.freemium-survey-components.standard-survey-style .thankyou .link {\n width: 100%;\n display: inline-block;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n color: #666;\n font-weight: 500;\n text-decoration: underline;\n}\n.freemium-survey-components.standard-survey-style .responsive-text-field {\n width: 100%;\n}\n.freemium-survey-components.standard-survey-style .responsive-text-field .textarea-container {\n display: none;\n}\n.freemium-survey-components.standard-survey-style .message-container:empty {\n display: none;\n}\n@media (max-width: 550px) {\n .freemium-survey-components.standard-survey-style .action-buttons {\n flex-direction: column;\n width: 100%;\n }\n .freemium-survey-components.standard-survey-style .action-buttons button {\n max-width: unset;\n }\n .freemium-survey-components.standard-survey-style .action-button {\n max-width: unset;\n width: 100%;\n }\n .freemium-survey-components.standard-survey-style .thankyou .text {\n width: auto;\n }\n}\n\n@media (max-width: 550px) {\n .freemium-survey-component .responsive-text-field .input-container,\n.card-survey-style .responsive-text-field .input-container {\n display: none;\n }\n .freemium-survey-component .responsive-text-field .textarea-container,\n.card-survey-style .responsive-text-field .textarea-container {\n display: flex;\n }\n}\n.freemium-survey-components.mobile-preview .thankyou .text {\n width: unset;\n}");const Q=({thankYouQuestion:e,preview:r,placeholders:o,npsValue:s})=>(n.useEffect((()=>{r||e.type_info.meta?.redirectUrl&&setTimeout((()=>{window.location.href=e.type_info.meta?.redirectUrl}),1e3*(e.type_info.meta?.redirectDelay??1e4))}),[]),t.createElement("div",{className:"question-container thankyou"},t.createElement("div",{className:"heading"},"Thank you!"),t.createElement("div",{className:"text",dangerouslySetInnerHTML:{__html:_(e.text,o,s)}}),e.type_info.meta?.redirectUrl&&t.createElement("div",{style:{width:"100%"}},t.createElement("div",{className:"redirection-text"},"You will be redirected to the below URL automatically in"," ",e.type_info.meta?.redirectDelay," seconds.",t.createElement("br",null)),t.createElement("a",{className:"link",href:e.type_info.meta?.redirectUrl},e?.type_info.meta?.redirectUrl)))),F=({currentBlockIndex:e,currentBlockIndexOfBlocksWithQns:n,blocksWithQns:r,blocks:o,setHorizontalScrollUnits:s,preventQuestionAnimation:i})=>t.createElement("div",{className:"freemium-survey-step-navigation","data-navigation-element":"1"},t.createElement("button",{disabled:0==n.current,className:"navigation-button",onClick:()=>{n.current=Math.max(n.current-1,0),e.current=o.findIndex((e=>e.name===r[n.current].name)),i.current=!1,s(n.current)}},t.createElement(q,null)),t.createElement("button",{className:"navigation-button",disabled:n.current>=r.length-1,onClick:()=>{i.current=!1,n.current=Math.min(n.current+1,r.length-1),e.current=o.findIndex((e=>e.name===r[n.current].name)),s(n.current)}},t.createElement(k,null))),L=({widget:e,surveyStyle:n,formValues:r,othersMeta:o,blocksWithQns:s,blocks:i,thankYouQuestion:u,currentBlockIndexOfBlocksWithQns:c,currentBlockIndexOfBlocks:l,currentEditingBlock:m,isSubmitting:d,isValuesCommitted:p,isCurrentBlockFinal:f,setHorizontalScrollUnits:y,handleFormValues:v,skipBlock:h,setIsSubmitting:x,onSubmit:g,setIsSurveyCompleted:b,preventQuestionAnimation:k,preview:q,closePreview:E,..._})=>{const C=_.blockIndex??c.current,S=_.question??s[C].question,N=()=>S.name===m.current.question.name&&!a.includes(S.type_info.question_type)&&!f(),B=()=>"RANGE"!==S.type_info.question_type&&!S.required&&S.name===m.current.question.name&&!f(),I=()=>("DROPDOWN"===S.type_info.question_type&&S.name!==m.current.question.name&&!S.required&&r[S.name],!1),R=()=>f()&&(e||"standard"!==n)&&S.name===m.current.question.name,z="MULTI_SELECT"===m.current.question.type_info.question_type&&r[m.current.question.name]?.includes("others")&&(!o[m.current.question.name]||""===o[m.current.question.name]);return t.createElement("div",{className:"question-footer"},!(!e&&"standard"===n||0===C&&!r[S.name])&&t.createElement(F,{currentBlockIndex:l,currentBlockIndexOfBlocksWithQns:c,blocksWithQns:s,blocks:i,setHorizontalScrollUnits:y,preventQuestionAnimation:k}),(N()||I()||B()||R())&&t.createElement("div",{className:"action-buttons"},N()&&t.createElement(w,{onClick:()=>{v(s[C],null,!0)},disabled:m.current.question.required&&(!r[m.current.question.name]||Array.isArray(r[m.current.question.name])&&0===r[m.current.question.name].length)||m.current.question.type_info.meta?.othersRequired&&z,className:"next-button"},"Next"),B()&&t.createElement("button",{className:"skip-button",onClick:()=>h(S)},"Skip"),I()&&t.createElement("button",{className:"skip-button",onClick:()=>{m.current=s[C],l.current=i.findIndex((e=>e.name===s[C].name)),h(S)}},"Clear selection"),R()&&t.createElement("div",{className:"submit"},t.createElement(w,{disabled:(m.current.question.required||m.current.question.type_info.pivot_question)&&(null==r[m.current.question.name]||0===r[m.current.question.name]?.length)||m.current.question.type_info.meta?.othersRequired&&z||d,onClick:()=>{x(!0),g({...r,others_meta:o},(()=>{u?.type_info.meta?.skipThankYouPage?q?setTimeout((()=>{E?.()}),300):window.location.href=u?.type_info.meta?.redirectUrl:b(!0)}))}},d?"Submitting":"Submit survey"))))},V=({survey:e,surveyStyle:o="standard",placeholders:s,onSubmit:i,widget:u,npsValue:c,preview:l,mobilePreview:m,closePreview:d})=>{const p=e.question_details?.questions||[],f=e.meta?.blocks||[],[y,v]=n.useState(null),[h,x]=n.useState({}),[b,k]=n.useState(!1),[q,C]=n.useState([]),[S,N]=n.useState(0),[B,I]=n.useState(!1),[R,z]=n.useState(null),[O,T]=n.useState({}),F=n.useRef(null),V=n.useRef(null),Y=n.useRef(-1),A=n.useRef(null),M=n.useRef(0),U=n.useRef(0),$=n.useRef(!1),D=n.useRef([]),H=n.useRef(!!c&&"card"===o),W=n.useRef(null),P=n.useRef([]);n.useEffect((()=>{f&&(W.current=f.find((e=>"TY"===e.name)),v(f.filter((e=>"TY"!==e.name))))}),[f]),n.useEffect((()=>{if(y)if(V.current=p.find((e=>e.type_info?.pivot_question))??p.find((e=>"RANGE"===e.type_info?.question_type))??p[0],null!=c){Y.current=c;const e=p.find((e=>e.name===y[0].question_names[0]));F.current={...y[0],question:e},D.current=[...D.current,{...y[0],question:e}],C(D.current),x({Q_1:c})}else if(!F.current&&y.length>0)return F.current=y[0],void G(y[0])}),[y,c]),n.useEffect((()=>{q.length&&(D.current=q,U.current=q.length-1),u||"standard"!==o?(A.current&&(A.current.style.maxHeight="unset"),P.current[M.current]=A.current?.scrollHeight||P.current[M.current]||0,A.current&&(A.current.style.maxHeight="100%")):A.current?.scrollIntoView({block:"start",behavior:"smooth"}),N(q.length-1)}),[q]),n.useEffect((()=>{Object.keys(h).length>0&&F.current.question&&(a.includes(F.current.question.type_info.question_type)||$.current)&&!j()&&X()}),[h]),n.useEffect((()=>{if(null!=h?.[V.current?.name])if(W.current?.is_based_on_rating){const e=V.current?.type_info?.choices[h?.[V.current?.name]-V.current?.type_info?.validation?.min??0]?.dependent_question_names,n=W.current?.question_names.find((n=>e?.includes(n))),t=p.find((e=>e.name===n));z(t)}else{const e=p.find((e=>e.name==W.current?.question_names[0]));z(e)}}),[h?.[V.current?.name]]);const j=()=>M.current===y.length-1||"end"===F.current.branchOption,G=e=>{let n={};if(e.is_based_on_rating){const t=V.current?.type_info?.choices[h?.[V.current?.name]-V.current?.type_info?.validation?.min??0]?.dependent_question_names,r=e.question_names.find((e=>t?.includes(e)));n=p.find((e=>e.name===r))}else n=p.find((n=>n.name===e.question_names[0]));F.current.question=n;D.current.find((e=>e.question.name===n.name))?(N(S+1),U.current+=1):C([...D.current,{...e,question:n}])},X=()=>{if(j())k(!0);else{if(F.current.nextBlock)M.current=y.findIndex((e=>e.name===F.current.nextBlock));else if(F.current.question.type_info?.meta?.branches){const e=F.current.question.type_info?.meta?.branches,n=h[F.current.question.name];let t;if(t="RANGE"===F.current.question.type_info.question_type?e.find((e=>n>=e.min&&n<=e.max)):e.find((e=>n===e.value)),t?.nextBlock){if("TY"===t.nextBlock)return void k(!0);M.current=y.findIndex((e=>e.name===t.nextBlock))}else M.current+=1}else M.current+=1;F.current=y[M.current],G(y[M.current])}},Z=e=>{$.current=!0,delete h[e.name],x({...h})},K=(e,n,t)=>{if(H.current=!1,t){if($.current=!0,null!=h[e.question.name]&&e.name!==q[q.length-1].name){const[t,r]=(e=>{const n=q.findIndex((n=>n.name===e.name)),t=q.slice(0,n+1),r=t.reduce(((e,n)=>(e[n.question.name]=h[n.question.name],e)),{});return M.current=y.findIndex((n=>n.name===e.name)),[t,r]})(e);x({...r,...null!=n&&{[e.question.name]:n}}),D.current=t}else x({...h,...null!=n&&{[e.question.name]:n}});V?.current?.name==e?.question?.name&&(Y.current=n)}else x({...h,...null!=n&&{[e.question.name]:n}})},J=(e,n)=>{T({...O,[e]:n})};return F.current&&F.current.question?t.createElement("div",{className:`freemium-survey-components ${u?"widget-survey-components":""} ${m?"mobile-preview":""} ${o}-survey-style`,id:"freemium-survey"},b?null:t.createElement(g,{totalSteps:y.length,completedSteps:M.current}),t.createElement(r.SwitchTransition,{mode:"out-in"},t.createElement(r.CSSTransition,{key:String(b),addEndListener:(e,n)=>{e.addEventListener("transitionend",n,!1)},classNames:u?"":"fade"},t.createElement("div",null,b?t.createElement(Q,{thankYouQuestion:R,preview:l,placeholders:s,npsValue:Y.current}):t.createElement(t.Fragment,null,t.createElement("div",{onTransitionEndCapture:e=>e.stopPropagation(),style:u||"card"===o?{transform:`translateX(calc(-${S} * 100%))`,height:`${P.current[M.current]}px`,transition:H.current||q?.length<=1?"none":"all 300ms ease-out 0ms"}:{},className:"questions"},q.map(((e,n)=>t.createElement("div",{key:e.question.name,ref:A,className:"question-container "+(!u&&"card"!==o||U.current===n?"":"hide-question-container")},t.createElement("div",{className:"question-text "+(0===n?"nps":""),dangerouslySetInnerHTML:{__html:_(e.question.text,s,Y.current)},title:`question-${n}`,role:"heading","aria-level":1}),t.createElement("button",{disabled:!u&&"standard"===o,className:"autofocus-button",onKeyDown:e=>{"Tab"===e.key&&(e.stopPropagation(),e.preventDefault())}}),t.createElement(E,{question:e.question,formValues:h,othersMeta:O,autoFocus:U.current===n,autoFocusDelay:"standard"===o?350:20,saveOthersValue:J,onChangeHandler:n=>{$.current=!1,M.current=y.findIndex((n=>n.name===e.name)),F.current=e,K(e,n,a.includes(e.question.type_info.question_type)&&!j())}}),t.createElement("button",{disabled:!u&&"standard"===o,className:"autofocus-button",onKeyDown:e=>{"Tab"===e.key&&(e.stopPropagation(),e.preventDefault())}}),t.createElement(L,{question:e.question,blockIndex:n,widget:u,surveyStyle:o,formValues:h,othersMeta:O,blocksWithQns:q,blocks:y,thankYouQuestion:R,currentBlockIndexOfBlocksWithQns:U,currentBlockIndexOfBlocks:M,currentEditingBlock:F,isSubmitting:B,isValuesCommitted:$,isCurrentBlockFinal:j,setHorizontalScrollUnits:N,handleFormValues:K,skipBlock:Z,setIsSubmitting:I,onSubmit:i,setIsSurveyCompleted:k,preventQuestionAnimation:H,preview:l,closePreview:d})))),!u&&"card"!==o&&j()&&t.createElement("div",{className:"submit"},t.createElement(w,{disabled:(F.current.question.required||F.current.question.type_info.pivot_question)&&(null==h[F.current.question.name]||0===h[F.current.question.name]?.length)||F.current.question.type_info.meta?.othersRequired&&"MULTI_SELECT"===F.current.question.type_info.question_type&&h[F.current.question.name]?.includes("")||B,onClick:()=>{I(!0),i({...h,others_meta:O},(()=>{R?.type_info.meta?.skipThankYouPage?l?setTimeout((()=>{d?.()}),300):window.location.href=R?.type_info.meta?.redirectUrl:k(!0)}))}},B?"Submitting":"Submit survey")))))))):null};exports.BUTTON_SIZE_VARIANTS={LARGE:"large",MINI:"mini",NORMAL:"normal"},exports.Button=w,exports.CheckboxGroup=y,exports.Input=d,exports.NPS=s,exports.ProgressBar=g,exports.Radio=x,exports.RadioGroup=h,exports.Survey=e=>{const n=C(e.survey);return t.createElement(t.Fragment,null,"standard"===e.surveyStyle?t.createElement(V,Object.assign({},e,{survey:n})):t.createElement(I,Object.assign({},e,{survey:n})))},exports.TextArea=p,exports.WebInAppSurvey=e=>{const n=C(e.survey);return t.createElement(T,Object.assign({},e,{survey:n}))};
package/lib/index.esm.js CHANGED
@@ -1 +1 @@
1
- import e,{useRef as n,forwardRef as t,useEffect as r,useState as o,useMemo as s}from"react";import{SwitchTransition as i,CSSTransition as a,TransitionGroup as u}from"react-transition-group";function c(e,n){void 0===n&&(n={});var t=n.insertAt;if(e&&"undefined"!=typeof document){var r=document.head||document.getElementsByTagName("head")[0],o=document.createElement("style");o.type="text/css","top"===t&&r.firstChild?r.insertBefore(o,r.firstChild):r.appendChild(o),o.styleSheet?o.styleSheet.cssText=e:o.appendChild(document.createTextNode(e))}}c(".freemium-survey-components .nps-container {\n margin: 0 auto;\n width: 100%;\n display: flex;\n flex-direction: column;\n grid-gap: 28px;\n gap: 28px;\n}\n.freemium-survey-components .nps-container .footer {\n border-top: 1px solid var(--default-background-color);\n border-top: 1px solid var(--background-color, var(--default-background-color));\n padding-top: 20px;\n display: flex;\n justify-content: center;\n font-size: 0.875rem;\n line-height: 1.5;\n color: #666;\n}\n.freemium-survey-components .nps-container .footer:empty {\n display: none;\n}\n.freemium-survey-components .nps-container .nps-scale {\n position: relative;\n}\n.freemium-survey-components .nps-container .nps-scale .button-container {\n display: flex;\n border-radius: 4px;\n justify-content: space-between;\n background: var(--default-background-color);\n background: var(--background-color, var(--default-background-color));\n position: relative;\n margin-bottom: 40px;\n}\n.freemium-survey-components .nps-container .nps-scale .positive-text {\n position: absolute;\n color: #475867;\n bottom: -40px;\n font-size: 12px;\n right: 0px;\n text-align: right;\n}\n.freemium-survey-components .nps-container .nps-scale .negative-text {\n position: absolute;\n color: #475867;\n bottom: -40px;\n font-size: 12px;\n left: 0;\n text-align: left;\n}\n.freemium-survey-components .nps-container .nps-scale span {\n color: #aaa;\n font-size: 0.75rem;\n}\n.freemium-survey-components .nps-container .nps-scale button {\n display: inline-block;\n font-size: 1rem;\n white-space: nowrap;\n vertical-align: middle;\n background: none;\n border: none;\n box-shadow: none;\n cursor: pointer;\n text-align: center;\n font-weight: 400;\n border-radius: 4px;\n margin: 0;\n outline: none;\n margin-left: -1px;\n width: 40px;\n height: 40px;\n transform: scale(1);\n}\n.freemium-survey-components .nps-container .nps-scale button:hover {\n transition: background 0.2s ease-in, border-color 0.2s ease-in, transform 0.2s cubic-bezier(0.5, 2, 0.5, 0.75);\n}\n.freemium-survey-components .nps-container .nps-scale button:hover, .freemium-survey-components .nps-container .nps-scale button:focus {\n color: white;\n transform: scale(1.2);\n z-index: 2;\n position: relative;\n}\n.freemium-survey-components .nps-container .nps-scale button.active {\n color: white;\n transform: scale(1.2);\n z-index: 2;\n position: relative;\n}\n.freemium-survey-components .nps-container .nps-scale.rounded button {\n border-radius: 50%;\n}\n.freemium-survey-components .nps-container .nps-scale.square button {\n border-radius: 0;\n}\n.freemium-survey-components .nps-container .nps-scale.curved button {\n border-radius: 3px;\n}\n.freemium-survey-components .nps-container .nps-scale.highlighted button:hover, .freemium-survey-components .nps-container .nps-scale.highlighted button:focus, .freemium-survey-components .nps-container .nps-scale.highlighted button.active {\n background: var(--default-brand-color) !important;\n background: var(--brand-color, var(--default-brand-color)) !important;\n}\n.freemium-survey-components .nps-container .nps-scale .choices {\n width: 100%;\n display: flex;\n justify-content: space-between;\n font-weight: 500;\n}\n.freemium-survey-components .nps-container .nps-scale.standard .button-container {\n background-color: transparent;\n}\n.freemium-survey-components .nps-container .nps-scale.standard .choice {\n background: #EBEFF3;\n color: #000;\n}\n.freemium-survey-components .nps-container .nps-scale.standard .choice:focus, .freemium-survey-components .nps-container .nps-scale.standard .choice.active, .freemium-survey-components .nps-container .nps-scale.standard .choice:hover {\n background: #E43E3D;\n}\n.freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(1):focus, .freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(1).active, .freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(1):hover, .freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(2):focus, .freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(2).active, .freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(2):hover {\n background: #00AF50;\n}\n.freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(3):hover, .freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(4):hover {\n background: #F8C43E;\n}\n.freemium-survey-components .nps-container .nps-scale.standard .choice:hover, .freemium-survey-components .nps-container .nps-scale.standard .choice:focus, .freemium-survey-components .nps-container .nps-scale.standard .choice.active {\n color: #fff;\n transform: scale(1.2);\n}\n\n.freemium-survey-components.mobile-preview .nps-container .nps-scale .button-container {\n background: transparent;\n}\n.freemium-survey-components.mobile-preview .nps-container .nps-scale .choices {\n flex-wrap: wrap;\n justify-content: center;\n grid-gap: 16px;\n gap: 16px;\n background: transparent;\n}\n.freemium-survey-components.mobile-preview .nps-container .nps-scale button {\n border-radius: 50%;\n background: #ebeff3;\n}\n\n@media (max-width: 550px) {\n .freemium-survey-components .nps-container .nps-scale .button-container,\n.card-survey-style .nps-container .nps-scale .button-container {\n background: transparent;\n }\n .freemium-survey-components .nps-container .nps-scale .choices,\n.card-survey-style .nps-container .nps-scale .choices {\n flex-wrap: wrap;\n justify-content: center;\n grid-gap: 16px;\n gap: 16px;\n background: transparent;\n }\n .freemium-survey-components .nps-container .nps-scale button,\n.card-survey-style .nps-container .nps-scale button {\n border-radius: 50%;\n background: #ebeff3;\n }\n}\n.widget-survey-components .nps-container .nps-scale .button-container {\n background: transparent;\n}\n.widget-survey-components .nps-container .nps-scale .choices {\n flex-wrap: wrap;\n justify-content: center;\n grid-gap: 16px;\n gap: 16px;\n background: transparent;\n}\n.widget-survey-components .nps-container .nps-scale button {\n border-radius: 50%;\n background: #ebeff3;\n}");const l=t=>{const{type_info:{linear_scale:{button_style:r="highlighted",button_shape:o="rounded"}={},rating_presets:{start:s="Very unlikely",end:i="Very likely"}={},validation:{min:a},footer_text:u}}=t,c=e=>{switch(e){case e<=6:return"detractor";case e<=8:return"passive";default:return"promoter"}},l=n(Array.from({length:10+(0===a?1:0)},((e,n)=>n+a)));return e.createElement("div",{className:"nps-container","data-test-input":"nps"},e.createElement("div",{className:`nps-scale ${o} ${r}`},e.createElement("div",{className:"button-container"},e.createElement("span",{className:"negative-text",role:"note"},`${a} - ${s}`),e.createElement("span",{className:"positive-text",role:"note"},`${l.current[l.current.length-1]} - ${i}`),e.createElement("div",{className:"choices",role:"radiogroup","aria-required":!0},l.current.map((n=>e.createElement("button",{role:"radio","aria-checked":t.npsValue===n,key:n,"data-test-nps-choice":n,onClick:e=>{t.onChangeHandler(n)},className:`choice ${c(n)} ${t.npsValue===n&&"active"}`},n)))))),e.createElement("div",{className:"footer",role:"note"},u))},m=(e,n)=>(e.defaultProps=n,e);c('.freemium-survey-components .input-container,\n.freemium-survey-components .textarea-container {\n display: flex;\n flex-direction: column;\n width: 100%;\n border-radius: 4px;\n position: relative;\n}\n.freemium-survey-components label.input-label {\n display: inline-block;\n padding-bottom: 8px;\n padding-left: 2px;\n font-size: 0.75rem;\n font-weight: 400;\n}\n.freemium-survey-components label.required::after {\n content: "*";\n position: relative;\n top: 2px;\n font-weight: 500;\n font-size: 0.85rem;\n padding-left: 3px;\n color: #d72d30;\n}\n.freemium-survey-components .input-basic {\n width: 100%;\n display: flex;\n align-items: center;\n border-radius: 4px;\n border: 1px solid var(--default-brand-color);\n border: 1px solid var(--brand-color, var(--default-brand-color));\n transition: border-color 0.2s linear;\n background: #fff;\n}\n.freemium-survey-components .textarea-container .input-basic {\n flex-direction: column;\n align-items: unset;\n}\n.freemium-survey-components .input-basic.error {\n border: 1px solid #d72d30;\n}\n.freemium-survey-components .input-basic.error:hover {\n border: 1px solid #d72d30;\n}\n.freemium-survey-components .input-basic.error[focus-within] {\n box-shadow: none;\n}\n.freemium-survey-components .input-basic.error:focus-within {\n box-shadow: none;\n}\n.freemium-survey-components .input-basic:hover {\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n transition: 0.2s linear;\n}\n.freemium-survey-components .input-basic[focus-within] {\n border: 1px solid transparent;\n box-shadow: 0 0 0 2px var(--default-brand-color);\n box-shadow: 0 0 0 2px var(--brand-color, var(--default-brand-color));\n}\n.freemium-survey-components .input-basic:focus-within {\n border: 1px solid transparent;\n box-shadow: 0 0 0 2px var(--default-brand-color);\n box-shadow: 0 0 0 2px var(--brand-color, var(--default-brand-color));\n}\n.freemium-survey-components .input-basic[focus-within] .end-max-length {\n opacity: 1;\n}\n.freemium-survey-components .input-basic:focus-within .end-max-length {\n opacity: 1;\n}\n.freemium-survey-components .end-max-length {\n transition: opacity ease 0.2s;\n opacity: 0;\n padding: 0 8px;\n font-size: 0.75rem;\n color: #264966;\n}\n.freemium-survey-components .textarea-container .end-max-length {\n padding: 8px;\n align-self: flex-end;\n}\n.freemium-survey-components span.input-error {\n display: block;\n padding-left: 2px;\n padding-top: 4px;\n font-size: 0.9rem;\n color: #d72d30;\n}\n.freemium-survey-components input[type=text] {\n padding: 6px 12px;\n flex: 1;\n border: unset;\n height: 32px;\n font-size: 1rem;\n /* line-height: ${typography.input.text.lineHeight}; */\n border-radius: 4px;\n}\n.freemium-survey-components input[type=text],\n.freemium-survey-components textarea {\n outline: none;\n border: none;\n}\n.freemium-survey-components input[type=text]::-moz-placeholder {\n color: #92a2b2;\n font-weight: 400;\n font-size: 0.85rem;\n}\n.freemium-survey-components input[type=text]:-ms-input-placeholder {\n color: #92a2b2;\n font-weight: 400;\n font-size: 0.85rem;\n}\n.freemium-survey-components input[type=text]::placeholder {\n color: #92a2b2;\n font-weight: 400;\n font-size: 0.85rem;\n}\n.freemium-survey-components textarea {\n min-height: 116px;\n padding: 12px;\n flex: 1;\n border: unset;\n resize: none;\n font-size: 1rem;\n /* line-height: ${typography.input.text.lineHeight}; */\n border-radius: 4px;\n}\n.freemium-survey-components textarea::-moz-placeholder {\n color: #92a2b2;\n font-weight: 400;\n font-size: 0.85rem;\n}\n.freemium-survey-components textarea:-ms-input-placeholder {\n color: #92a2b2;\n font-weight: 400;\n font-size: 0.85rem;\n}\n.freemium-survey-components textarea::placeholder {\n color: #92a2b2;\n font-weight: 400;\n font-size: 0.85rem;\n}');const d=["RANGE","NPS","RADIO","DROPDOWN"],p={default:500,compact:500,cozy:400},f={isRequired:!1,showCount:!0,isErrored:!1,inline:!1,spellCheck:!1,autoFocusInput:!0},y=t(((t,o)=>{const s=n(null);r((()=>{t.autoFocusInput&&setTimeout((()=>{s.current?.focus()}),300+t.autoFocusDelay)}),[t.autoFocusInput]);const{inputStyle:i,style:a,className:u,showCount:c,isErrored:l,startLabel:m,isRequired:d,errorText:p,endLabel:f,maxLength:y=300,onChange:v,autoFocusInput:h,...x}=t;return e.createElement("div",{className:"input-container",style:a},t.label&&e.createElement("label",{className:"input-label "+(d?"required":"")},t.label),e.createElement("div",null,m&&e.createElement("div",{className:"start-label"},m),e.createElement("div",{className:`input-basic ${l?"error":""}${u||""}`},e.createElement("input",Object.assign({},x,{type:"text",autoComplete:"off",ref:s,style:i,onChange:e=>{e.target.value?.length>y||v?.(e)}})),c&&y>0&&e.createElement("div",{className:"end-max-length"},`${t.value&&t.value.length||0}/${y}`)),f&&e.createElement("div",{className:"end-label"},f)),l&&p&&e.createElement("span",{className:"input-error"},t.errorText))})),v=t(((t,o)=>{const s=n(null);r((()=>{t.autoFocusInput&&setTimeout((()=>{s.current?.focus()}),300+t.autoFocusDelay)}),[t.autoFocusInput]);const{inputStyle:i,style:a,className:u,showCount:c,maxLength:l=1500,startLabel:m,isRequired:d,autoFocusInput:p,onChange:f,...y}=t;return e.createElement(e.Fragment,null,e.createElement("div",{className:"textarea-container",style:a},t.label&&e.createElement("label",{className:"input-label "+(d?"required":"")},t.label),m&&e.createElement("div",{className:"start-label"},m),e.createElement("div",{className:`input-basic ${u||""}`},e.createElement("textarea",Object.assign({},y,{autoComplete:"off",ref:s,style:i,onChange:e=>{e.target.value?.length>l||f?.(e)}})),c&&l&&l>0&&e.createElement("div",{className:"end-max-length"},`${t.value&&t.value.length||0}/${l}`)),t.endLabel&&e.createElement("div",{className:"end-label"},t.endLabel)))})),h=m(y,f),x=m(v,f);c('.freemium-survey-components .checkbox-group {\n width: 100%;\n display: flex;\n grid-gap: 12px;\n gap: 12px;\n flex-direction: column;\n white-space: nowrap;\n flex-wrap: wrap;\n}\n.freemium-survey-components .icon-container {\n display: inline-block;\n flex: 0 0 12px;\n width: 12px;\n height: 12px;\n min-width: 12px;\n min-height: 12px;\n color: inherit;\n position: absolute;\n left: 1px;\n top: 2px;\n}\n.freemium-survey-components .tick-icon {\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n height: 100%;\n width: 100%;\n color: inherit;\n fill: currentColor;\n}\n.freemium-survey-components input[type=checkbox] {\n position: absolute;\n clip: rect(0px 0px 0px 0px);\n width: 0px;\n height: 0px;\n}\n.freemium-survey-components input[type=checkbox]:focus ~ .checkbox {\n /* box-shadow: ${pseudo.focus} 0px 0px 0px 2px; */\n box-shadow: var(--default-brand-color) 0px 0px 0px 2px;\n box-shadow: var(--brand-color, var(--default-brand-color)) 0px 0px 0px 2px;\n border-color: transparent;\n}\n.freemium-survey-components .checkbox-label {\n display: flex;\n align-items: baseline;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n text-align: left;\n opacity: 1;\n line-height: 1.2;\n cursor: pointer;\n font-size: 1rem;\n padding: 16px 24px;\n min-width: 200px;\n border: 1px solid #ebeff3;\n border-radius: 4px;\n white-space: pre-wrap;\n}\n.freemium-survey-components .checkbox-label:hover .checkbox {\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n box-shadow: var(--default-background-color) 0px 0px 0px 5px;\n box-shadow: var(--background-color, var(--default-background-color)) 0px 0px 0px 5px;\n}\n.freemium-survey-components .checkbox-label.disabled {\n opacity: 0.5;\n cursor: "not-allowed";\n}\n.freemium-survey-components .checkbox {\n transition: background-color ease-in 0.2s;\n min-width: 14px;\n min-height: 14px;\n min-height: 14px;\n max-height: 14px;\n border-radius: 2px;\n position: relative;\n margin-right: 16px;\n background-color: #fff;\n border: 1px solid;\n text-align: left;\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n}\n.freemium-survey-components .checkbox:hover {\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n box-shadow: var(--default-background-color) 0px 0px 0px 5px;\n box-shadow: var(--background-color, var(--default-background-color)) 0px 0px 0px 5px;\n}\n.freemium-survey-components input[type=checkbox]:checked ~ .checkbox {\n background-color: var(--default-brand-color);\n background-color: var(--brand-color, var(--default-brand-color));\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n}\n.freemium-survey-components input[type=checkbox]:checked ~ .checkbox:hover {\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n}\n.freemium-survey-components input[type=checkbox]:disabled ~ .checkbox:hover {\n box-shadow: unset;\n border-color: unset;\n}');const g=()=>e.createElement("svg",{id:"tick",className:"tick-icon",xmlns:"http://www.w3.org/2000/svg","aria-labelledby":"title",viewBox:"0 0 10 10"},e.createElement("path",{d:"M3 5.87c-.18666814.00267463-.36667109-.06932655-.5-.2L.21 3.41c-.1786328-.17863279-.24839684-.43899577-.1830127-.6830127.06538414-.24401694.25598306-.43461586.5-.5C.77100423 2.16160316 1.0313672 2.23136721 1.21 2.41L3 4.18 6.8.33c.27679776-.27455556.72320224-.27455556 1 0 .13696438.13025306.21450026.31098915.21450026.5S7.93696438 1.19974694 7.8 1.33L3.45 5.67c-.12082534.11896945-.28072735.19003701-.45.2Z",fill:"#fff",fillRule:"evenodd"})),b=({values:t=[],othersValue:s="",options:i,name:a,autoFocusGroup:u,autoFocusDelay:c,onChangeHandler:l,saveOthersValue:m,othersOption:d,othersRequired:p})=>{const[f,y]=o(!1),v=n(null);return r((()=>{u&&setTimeout((()=>{v.current?.focus()}),300+c)}),[u]),e.createElement("div",{className:"checkbox-group"},e.createElement("button",{ref:v,className:"autofocus-button","aria-hidden":!0}),i?.map(((n,r)=>e.createElement(w,{key:n.id,checked:t?.includes(n.value),name:n.value,id:n.id,onChange:(e,r)=>{if(r)l([...t||[],n.value]);else{const e=t.indexOf(n.value);e>-1&&t.splice(e,1),l([...t])}}},n.value))),d&&e.createElement(w,{key:"others",checked:f,name:"others",id:"others",onChange:(e,n)=>{if(y(n),n)l([...t,"others"]);else{const e=t.findIndex((e=>"others"===e));t.splice(e,1),l(t)}}},"Others"),f&&e.createElement(e.Fragment,null,e.createElement(h,{placeholder:"Enter your comment",value:s[a],onChange:e=>{m(a,e.target.value)},autoFocusDelay:10,label:""})))},w=m((t=>{const o=n(null);return r((()=>{t.autoFocus&&setTimeout((()=>{o.current?.focus()}),320)}),[]),e.createElement("label",{className:`checkbox-label ${t.disabled&&"disabled"}`},e.createElement("input",{ref:o,id:t.id,type:"checkbox",name:t.name,readOnly:t.readOnly,disabled:t.disabled,"aria-disabled":t.disabled,checked:t.checked,onChange:t.readOnly?()=>{}:e=>t.onChange(e,e.target.checked)}),e.createElement("div",{className:"checkbox"},t.checked&&e.createElement("div",{className:"icon-container"},e.createElement(g,null)," ")),e.createElement("div",null,t.children))}),{checked:!1});c('.freemium-survey-components .radio-group {\n display: flex;\n grid-gap: 12px;\n gap: 12px;\n white-space: nowrap;\n flex-direction: column;\n width: 100%;\n}\n.freemium-survey-components .radio {\n background-color: #fff;\n border: 1px solid;\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n transition: background-color ease-in 0.2s;\n min-width: 18px;\n max-width: 18px;\n min-height: 18px;\n max-height: 18px;\n border-radius: 50%;\n position: relative;\n margin-right: 16px;\n text-align: left;\n}\n.freemium-survey-components .radio:before {\n left: 3px;\n top: 3px;\n content: "";\n position: absolute;\n width: 10px;\n height: 10px;\n border-radius: 50%;\n transition: all ease-in 0.2s;\n background-color: #fff;\n}\n.freemium-survey-components .radio-label {\n display: flex;\n align-items: baseline;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n text-align: left;\n cursor: pointer;\n line-height: 1.2;\n font-size: 1rem;\n font-weight: 400;\n padding: 16px 24px;\n min-width: 200px;\n border: 1px solid #ebeff3;\n border-radius: 4px;\n white-space: pre-wrap;\n}\n.freemium-survey-components input[type=radio] {\n position: absolute;\n clip: rect(0, 0, 0, 0);\n width: 0px;\n height: 0px;\n}\n.freemium-survey-components input[type=radio]:focus ~ .radio {\n /* box-shadow: ${pseudo.focus} 0px 0px 0px 3px; */\n box-shadow: var(--default-brand-color) 0px 0px 0px 3px;\n box-shadow: var(--brand-color, var(--default-brand-color)) 0px 0px 0px 3px;\n border-color: transparent;\n}\n.freemium-survey-components input[type=radio]:checked ~ .radio:before {\n background-color: var(--default-brand-color);\n background-color: var(--brand-color, var(--default-brand-color));\n}\n.freemium-survey-components .radio-label:hover .radio {\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n box-shadow: var(--default-background-color) 0px 0px 0px 5px;\n box-shadow: var(--background-color, var(--default-background-color)) 0px 0px 0px 5px;\n}');const k=({name:t,options:s,value:i,autoFocusGroup:a,autoFocusDelay:u,onChangeHandler:c,saveOthersValue:l,othersOption:m,othersRequired:d,othersValue:p})=>{const[f,y]=o(p??""),[v,x]=o(i),g=n(null);return r((()=>{a&&setTimeout((()=>{g.current?.focus()}),300+u)}),[a]),r((()=>{i||(y(""),x(null))}),[i]),r((()=>{v&&s.find((e=>e.value===v))&&v!==i&&c(v)}),[v]),e.createElement("div",{className:"radio-group",role:"radiogroup"},e.createElement("button",{ref:g,className:"autofocus-button","aria-hidden":!0,tabIndex:-1}),s?.map(((n,r)=>e.createElement(q,{key:n.value,value:n.value,name:t,onChange:e=>{x(e.currentTarget.value)},checked:v===n.value},n.value))),m&&e.createElement(q,{key:"others",value:"others",name:t,onChange:e=>{x("others")},checked:"others"===v},"Others"),"others"===v&&e.createElement(e.Fragment,null,e.createElement(h,{value:f,onChange:e=>y(e.target.value),placeholder:"Enter your comment",label:"",autoFocusDelay:10}),f!==i&&e.createElement(N,{inline:!0,disabled:d&&0===f.length,onClick:()=>{c("others"),l(t,f)}},"Next")))},q=m((t=>{const o=n(null);return r((()=>{t.autoFocus&&setTimeout((()=>{o.current?.focus()}),320)}),[]),e.createElement("label",{className:"radio-label"},e.createElement("input",{ref:o,type:"radio",name:t.name,value:t.value,checked:t.checked,onChange:t.onChange}),e.createElement("div",{className:"radio"}),e.createElement("div",null,t.children))}),{checked:!1,autoFocus:!1});c(".progressbar-container {\n width: 100%;\n height: 4px;\n position: fixed;\n top: 0;\n left: 0;\n z-index: 1;\n text-align: left;\n}\n\n.progressbar {\n transition: transform 0.3s linear 200ms;\n transform-origin: left;\n height: 100%;\n background-color: var(--default-brand-color);\n background-color: var(--brand-color, var(--default-brand-color));\n}");const E=n=>{const{totalSteps:t,completedSteps:r}=n;return e.createElement("div",{className:"progressbar-container"},e.createElement("div",{className:"progressbar",style:{width:(r>0?100/t:0)+"%",transform:`scaleX(${r})`}}))};c(".freemium-survey-components .action-button {\n width: auto;\n display: block;\n padding: 8px 16px;\n cursor: pointer;\n line-height: 1.5;\n text-align: center;\n font-weight: 600;\n letter-spacing: 0.3px;\n border-radius: 4px;\n white-space: nowrap;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n color: --default-button-text-color;\n color: var(--button-text-color, --default-button-text-color);\n background: var(--default-brand-color);\n background: var(--brand-color, var(--default-brand-color));\n border: 1px solid var(--default-brand-color);\n border: 1px solid var(--brand-color, var(--default-brand-color));\n border-radius: 4px;\n min-width: 200px;\n max-width: -webkit-fit-content;\n max-width: -moz-fit-content;\n max-width: fit-content;\n transform: translateY(0px);\n transition: transform ease 0.2s;\n}\n.freemium-survey-components .action-button:not([disabled]):hover {\n transform: translateY(-4px);\n}\n.freemium-survey-components .action-button[disabled] {\n cursor: not-allowed;\n opacity: 0.6;\n}\n.freemium-survey-components button:focus:not(:active) {\n /* box-shadow: 0 0 0 2px ${pseudo.focus}; */\n}\n\n@media (max-width: 550px) {\n .freemium-survey-components .action-button {\n min-width: 120px;\n }\n}\n.widget-survey-components .action-button {\n min-width: 120px;\n}\n\n.freemium-survey-components.mobile-preview .action-button {\n min-width: 120px;\n}");const _=()=>e.createElement(e.Fragment,null,"..."),C={LARGE:"large",MINI:"mini",NORMAL:"normal"},N=n=>{const{inline:t=!1,children:r,disabled:o,className:s="",htmlType:i,type:a="primary",onClick:u,size:c,overrideStyleClassName:l="",loading:m=!1,...d}=n;return e.createElement("button",Object.assign({style:t?{display:"inline-block"}:{},disabled:o,className:`action-button ${s} ${l}`,type:i,onClick:u},d),m?e.createElement(_,null):r)},B=()=>e.createElement("svg",{style:{display:"block"},width:"9",height:"14",viewBox:"0 0 10 16",fill:"none",xmlns:"http://www.w3.org/2000/svg"},e.createElement("path",{d:"M7.82585 6.15754C7.98999 6.32147 8.08232 6.54389 8.08252 6.77587L8.08252 7.2192C8.07983 7.45069 7.98788 7.6722 7.82585 7.83754L1.82919 13.8225C1.77496 13.8772 1.71044 13.9206 1.63936 13.9502C1.56827 13.9798 1.49203 13.9951 1.41502 13.9951C1.33801 13.9951 1.26177 13.9798 1.19068 13.9502C1.1196 13.9206 1.05508 13.8772 1.00085 13.8225L0.172521 12.9942C0.118197 12.941 0.0750381 12.8774 0.0455752 12.8073C0.0161124 12.7372 0.000937578 12.6619 0.000937585 12.5859C0.000937592 12.5098 0.0161125 12.4345 0.0455753 12.3644C0.0750381 12.2943 0.118197 12.2308 0.172521 12.1775L5.36419 6.99754L0.172522 1.81754C0.117847 1.76331 0.0744506 1.69879 0.0448352 1.62771C0.0152208 1.55662 -2.75162e-05 1.48038 -2.75094e-05 1.40337C-2.75027e-05 1.32636 0.0152208 1.25012 0.0448353 1.17904C0.0744507 1.10795 0.117847 1.04343 0.172522 0.989205L1.00086 0.172537C1.05508 0.117862 1.1196 0.0744661 1.19069 0.0448507C1.26177 0.0152353 1.33801 -1.20337e-05 1.41502 -1.2027e-05C1.49203 -1.20203e-05 1.56827 0.0152353 1.63936 0.0448507C1.71044 0.0744661 1.77496 0.117862 1.82919 0.172537L7.82585 6.15754Z",fill:"#6B6B6B"})),I=()=>e.createElement("svg",{style:{display:"block"},width:"9",height:"14",viewBox:"0 0 10 16",fill:"none",xmlns:"http://www.w3.org/2000/svg"},e.createElement("path",{d:"M0.256667 7.83755C0.0925257 7.67361 0.000204227 7.4512 0 7.21921V6.77588C0.00268801 6.5444 0.0946357 6.32289 0.256667 6.15755L6.25333 0.172549C6.30756 0.117874 6.37208 0.0744776 6.44316 0.0448625C6.51425 0.0152474 6.59049 0 6.6675 0C6.74451 0 6.82075 0.0152474 6.89184 0.0448625C6.96292 0.0744776 7.02744 0.117874 7.08167 0.172549L7.91 1.00088C7.96432 1.05411 8.00748 1.11764 8.03694 1.18776C8.06641 1.25787 8.08158 1.33316 8.08158 1.40922C8.08158 1.48527 8.06641 1.56056 8.03694 1.63067C8.00748 1.70079 7.96432 1.76432 7.91 1.81755L2.71833 6.99755L7.91 12.1775C7.96467 12.2318 8.00807 12.2963 8.03769 12.3674C8.0673 12.4385 8.08255 12.5147 8.08255 12.5917C8.08255 12.6687 8.0673 12.745 8.03769 12.8161C8.00807 12.8871 7.96467 12.9517 7.91 13.0059L7.08167 13.8225C7.02744 13.8772 6.96292 13.9206 6.89184 13.9502C6.82075 13.9799 6.74451 13.9951 6.6675 13.9951C6.59049 13.9951 6.51425 13.9799 6.44316 13.9502C6.37208 13.9206 6.30756 13.8772 6.25333 13.8225L0.256667 7.83755Z",fill:"#6B6B6B"})),S=({question:n,formValues:t,othersMeta:r,onChangeHandler:o,saveOthersValue:s,autoFocus:i,autoFocusDelay:a})=>{switch(n.type_info.question_type){case"RANGE":return e.createElement(l,{type_info:n.type_info,onChangeHandler:o,npsValue:t[n.name]});case"CHECKBOX":case"MULTI_SELECT":return e.createElement(b,{name:n.name,autoFocusGroup:i,values:t[n.name],othersValue:r[n.name],options:n.type_info.choices,onChangeHandler:o,saveOthersValue:s,othersOption:n.type_info.meta?.othersOption,othersRequired:n.type_info.meta?.othersRequired,autoFocusDelay:a});case"RADIO":case"DROPDOWN":return e.createElement(k,{autoFocusGroup:i,autoFocusDelay:a,name:n.name,onChangeHandler:o,saveOthersValue:s,options:n.type_info.choices,value:t[n.name],othersValue:r[n.name],othersOption:n.type_info.meta?.othersOption,othersRequired:n.type_info.meta?.othersRequired});case"INPUT":case"TEXT":return n.type_info?.meta?.readOnly?e.createElement("div",{className:"message-container"},n.type_info?.meta?.value):e.createElement("div",{className:"responsive-text-field"},e.createElement(h,{autoFocusInput:i,autoFocusDelay:a,label:"",isRequired:n.is_required,value:t[n.name]||"",placeholder:n.type_info?.meta?.placeholder??"",onChange:e=>o(e.target.value)}),e.createElement(x,{autoFocusInput:i,autoFocusDelay:a,label:"",isRequired:n.is_required,placeholder:n.type_info?.meta?.placeholder??"",value:t[n.name]||"",onChange:e=>o(e.target.value)}));case"PARAGRAPH":return e.createElement(x,{autoFocusInput:i,autoFocusDelay:a,label:"",isRequired:n.is_required,placeholder:n.type_info?.meta?.placeholder??"",value:t[n.name]||"",onChange:e=>o(e.target.value)});default:return console.error(`Question type ${n.type_info.question_type} not found`),null}},z=(e,n,t)=>{if(e){let r={"{{nps.rating}}":t};n&&(r={...r,...n});const o=new RegExp(Object.keys(r).join("|"),"gi");e=e.replace(o,(function(e){return r[e.toLowerCase()]}))}return e},O=e=>s((()=>{const n=JSON.parse(JSON.stringify(e)),t=[];return(n.question_details?.questions||[]).forEach((e=>{const n=e.type_info?.meta?.block;n&&(n.question_names||(n.question_names=[e.name]),t.push(n))})),{...n,meta:{...n.meta,blocks:t}}}),[e]);c(":root {\n --default-brand-color: #264966;\n --default-question-text-color: #000;\n --default-question-background-color: #fff;\n --default-background-color: #f8f8f8;\n --default-button-text-color: #fff;\n --default-secondary-button-text-color: #000;\n --default-input-placeholder-color: #92a2b1;\n --compact-widget-max-height: 560px;\n --default-widget-max-height: 400px;\n --cozy-widget-max-height: 380px;\n}\n\n.freemium-survey-components.card-survey-style {\n padding: 20px 0;\n}\n.freemium-survey-components.card-survey-style .freemium-survey-step-navigation {\n white-space: nowrap;\n border-radius: 3px;\n border: 1px solid #efefef;\n}\n.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button {\n width: 38px;\n text-align: -webkit-center;\n height: 38px;\n background-color: #fff;\n border: none;\n cursor: pointer;\n border-radius: 0 3px 3px 0;\n}\n.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button svg {\n transform: rotate(90deg);\n}\n.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button:first-of-type {\n border-right: 1px solid #efefef;\n border-radius: 3px 0 0 3px;\n}\n.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button:disabled {\n cursor: not-allowed;\n opacity: 0.5;\n}\n.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button:focus {\n position: relative;\n z-index: 1;\n}\n.freemium-survey-components.card-survey-style .question-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n text-align: center;\n max-width: 700px;\n margin: 0 auto;\n background: var(--default-question-background-color);\n background: var(--question-background-color, var(--default-question-background-color));\n border-radius: 4px;\n transition: transform 500ms ease 0ms, opacity 200ms ease 0ms;\n box-shadow: 0px 12px 15px rgba(18, 52, 77, 0.03);\n padding: 28px;\n grid-gap: 28px;\n gap: 28px;\n position: relative;\n height: -webkit-fit-content;\n height: -moz-fit-content;\n height: fit-content;\n transition: opacity 50ms ease-out;\n overflow: auto;\n}\n.freemium-survey-components.card-survey-style .hide-question-container {\n opacity: 0;\n}\n.freemium-survey-components.card-survey-style .question-text {\n font-size: 1rem;\n font-weight: 600;\n line-height: 1.8;\n width: 100%;\n text-align: left;\n color: var(--default-question-text-color);\n color: var(--question-text-color, var(--default-question-text-color));\n}\n.freemium-survey-components.card-survey-style .autofocus-button {\n border: none;\n width: 0;\n height: 0;\n opacity: 0;\n margin-top: -12px;\n margin-left: -12px;\n position: absolute;\n}\n.freemium-survey-components.card-survey-style .fade-enter .question-container {\n opacity: 0;\n transform: translateY(15px);\n}\n.freemium-survey-components.card-survey-style .fade-enter-active .question-container {\n opacity: 1;\n transform: translateY(0);\n}\n.freemium-survey-components.card-survey-style .fade-exit .question-container {\n opacity: 1;\n transform: translateY(0);\n}\n.freemium-survey-components.card-survey-style .fade-exit-active .question-container {\n opacity: 0.05;\n transform: translateY(-15px);\n}\n.freemium-survey-components.card-survey-style .fade-reverse-enter .question-container {\n opacity: 0;\n transform: translateY(-15px);\n}\n.freemium-survey-components.card-survey-style .fade-reverse-enter-active .question-container {\n opacity: 1;\n transform: translateY(0);\n}\n.freemium-survey-components.card-survey-style .fade-reverse-exit .question-container {\n opacity: 1;\n transform: translateY(0);\n}\n.freemium-survey-components.card-survey-style .fade-reverse-exit-active .question-container {\n opacity: 0.05;\n transform: translateY(15px);\n}\n.freemium-survey-components.card-survey-style .fade-enter-active .question-container,\n.freemium-survey-components.card-survey-style .fade-exit-active .question-container,\n.freemium-survey-components.card-survey-style .fade-reverse-enter-active .question-container,\n.freemium-survey-components.card-survey-style .fade-reverse-exit-active .question-container {\n transition: opacity 300ms, transform 300ms;\n}\n.freemium-survey-components.card-survey-style .question-footer {\n display: flex;\n grid-gap: 40px;\n gap: 40px;\n width: 100%;\n align-items: center;\n}\n.freemium-survey-components.card-survey-style .question-footer:empty {\n display: none;\n}\n.freemium-survey-components.card-survey-style .question-footer:only-child {\n margin-left: auto;\n}\n.freemium-survey-components.card-survey-style .action-buttons {\n display: flex;\n grid-gap: 20px;\n gap: 20px;\n flex-direction: row-reverse;\n width: 100%;\n}\n.freemium-survey-components.card-survey-style .action-buttons:empty {\n display: none;\n}\n.freemium-survey-components.card-survey-style .skip-button {\n font-weight: 500;\n cursor: pointer;\n background: transparent;\n border: none;\n min-width: 40px;\n padding: 8px 16px;\n border-radius: 4px;\n color: var(--default-secondary-button-text-color);\n color: var(--secondary-button-text-color, var(--default-secondary-button-text-color));\n letter-spacing: 0.05rem;\n line-height: 1.5;\n border: 1px solid transparent;\n transform: translateY(0px);\n transition: transform ease 0.2s;\n}\n.freemium-survey-components.card-survey-style .skip-button:hover {\n background-color: #f3f3f3;\n transform: translateY(-4px);\n}\n.freemium-survey-components.card-survey-style .next-button {\n color: var(--default-button-text-color);\n color: var(--button-text-color, var(--default-button-text-color));\n}\n.freemium-survey-components.card-survey-style .submit {\n max-width: 700px;\n text-align: left;\n background: transparent;\n box-shadow: none;\n color: var(--default-button-text-color);\n color: var(--button-text-color, var(--default-button-text-color));\n}\n.freemium-survey-components.card-survey-style .thankyou {\n display: flex;\n align-items: center;\n justify-content: center;\n grid-gap: 20px;\n gap: 20px;\n min-height: 180px;\n}\n.freemium-survey-components.card-survey-style .thankyou .heading {\n font-weight: 600;\n font-size: 28px;\n}\n.freemium-survey-components.card-survey-style .thankyou .text {\n white-space: pre-wrap;\n font-weight: 500;\n font-size: 0.875rem;\n line-height: 1.6;\n color: #12344d;\n width: 75%;\n}\n.freemium-survey-components.card-survey-style .thankyou .redirection-text {\n color: #929292;\n margin-bottom: 12px;\n font-weight: 300;\n}\n.freemium-survey-components.card-survey-style .thankyou .link {\n width: 100%;\n display: inline-block;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n color: #666;\n font-weight: 500;\n text-decoration: underline;\n}\n.freemium-survey-components.card-survey-style .responsive-text-field {\n width: 100%;\n}\n.freemium-survey-components.card-survey-style .responsive-text-field .textarea-container {\n display: none;\n}\n.freemium-survey-components.card-survey-style .message-container:empty {\n display: none;\n}\n\n@media (max-width: 550px) {\n div.freemium-survey-components.card-survey-style .responsive-text-field .input-container {\n display: none;\n }\n div.freemium-survey-components.card-survey-style .responsive-text-field .textarea-container {\n display: flex;\n }\n div.freemium-survey-components.card-survey-style .question-footer {\n flex-direction: column-reverse;\n grid-gap: 20px;\n gap: 20px;\n }\n div.freemium-survey-components.card-survey-style .freemium-survey-step-navigation {\n width: 100%;\n }\n div.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button {\n width: 50%;\n }\n div.freemium-survey-components.card-survey-style .action-buttons {\n flex-direction: column;\n width: 100%;\n }\n div.freemium-survey-components.card-survey-style .action-buttons button {\n max-width: unset;\n }\n div.freemium-survey-components.card-survey-style .action-button {\n max-width: unset;\n width: 100%;\n }\n div.freemium-survey-components.card-survey-style .thankyou .text {\n width: auto;\n }\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .responsive-text-field .input-container {\n display: none;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .responsive-text-field .textarea-container {\n display: flex;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .question-footer {\n flex-direction: column-reverse;\n grid-gap: 20px;\n gap: 20px;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .freemium-survey-step-navigation {\n width: 100%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .freemium-survey-step-navigation .navigation-button {\n width: 50%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .action-buttons {\n flex-direction: column;\n width: 100%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .action-buttons button {\n max-width: unset;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .action-button {\n max-width: unset;\n width: 100%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .thankyou .text {\n width: auto;\n}\n\n.freemium-survey-components.mobile-preview .thankyou .text {\n width: unset;\n}");const T=({thankYouQuestion:n,preview:t,placeholders:o,npsValue:s})=>(r((()=>{t||n.type_info.meta?.redirectUrl&&setTimeout((()=>{window.location.href=n.type_info.meta?.redirectUrl}),n.type_info.meta?.redirectDelay??1e4)}),[]),e.createElement("div",{className:"question-container thankyou"},e.createElement("div",{className:"heading"},"Thank you!"),e.createElement("div",{className:"text",dangerouslySetInnerHTML:{__html:z(n.text,o,s)}}),n.type_info.meta?.redirectUrl&&e.createElement("div",{style:{width:"100%"}},e.createElement("div",{className:"redirection-text"},"You will be redirected to the below URL automatically in"," ",n.type_info.meta?.redirectDelay," seconds.",e.createElement("br",null)),e.createElement("a",{className:"link",href:n.type_info.meta?.redirectUrl},n?.type_info.meta?.redirectUrl)))),Q=({currentBlockIndex:n,currentBlockIndexOfBlocksWithQns:t,blocksWithQns:r,blocks:o,setHorizontalScrollUnits:s,preventQuestionAnimation:i,tempCurrentBlockIndexOfBlocksWithQns:a,setReverse:u,reverse:c})=>e.createElement("div",{className:"freemium-survey-step-navigation","data-navigation-element":"1"},e.createElement("button",{disabled:0==t.current,className:"navigation-button",onClick:()=>{c?t.current=Math.max(t.current-1,0):a.current=Math.max(t.current-1,0),i.current=!1,u(!0),s(t.current)}},e.createElement(I,null)),e.createElement("button",{className:"navigation-button",disabled:t.current>=r.length-1,onClick:()=>{i.current=!1,c?a.current=Math.min(t.current+1,r.length-1):t.current=Math.min(t.current+1,r.length-1),u(!1),s(t.current)}},e.createElement(B,null))),F=({widget:n,surveyStyle:t,formValues:r,blocksWithQns:o,blocks:s,thankYouQuestion:i,currentBlockIndexOfBlocksWithQns:a,currentBlockIndexOfBlocks:u,currentEditingBlock:c,isSubmitting:l,isValuesCommitted:m,isCurrentBlockFinal:p,setHorizontalScrollUnits:f,handleFormValues:y,skipBlock:v,setIsSubmitting:h,onSubmit:x,setIsSurveyCompleted:g,preventQuestionAnimation:b,preview:w,closePreview:k,setReverse:q,tempCurrentBlockIndexOfBlocksWithQns:E,question:_,reverse:C,othersMeta:B,...I})=>{const S=I.blockIndex??a.current,z=()=>!d.includes(_.type_info.question_type)&&!p(),O=()=>"RANGE"!==_.type_info.question_type&&!_.required&&!p(),T=()=>("DROPDOWN"===_.type_info.question_type&&!_.required&&r[_.name],!1),F=()=>p()&&(n||"standard"!==t),R="MULTI_SELECT"===c.current.question.type_info.question_type&&r[c.current.question.name]?.includes("others")&&(!B[c.current.question.name]||""===B[c.current.question.name]);return e.createElement("div",{className:"question-footer"},!(!n&&"standard"===t||0===S&&void 0===r[_.name]||0===a.current&&!C)&&e.createElement(Q,{currentBlockIndex:u,currentBlockIndexOfBlocksWithQns:a,blocksWithQns:o,blocks:s,setHorizontalScrollUnits:f,preventQuestionAnimation:b,setReverse:q,tempCurrentBlockIndexOfBlocksWithQns:E,reverse:C}),(z()||T()||O()||F())&&e.createElement("div",{className:"action-buttons"},z()&&e.createElement(N,{onClick:()=>{q(!1),y(o[S],null,!0)},disabled:c.current.question.required&&(!r[c.current.question.name]||Array.isArray(r[c.current.question.name])&&0===r[c.current.question.name].length)||c.current.question.type_info.meta?.othersRequired&&R,className:"next-button"},"Next"),O()&&e.createElement("button",{className:"skip-button",onClick:()=>{q(!1),v(_)}},"Skip"),F()&&e.createElement("div",{className:"submit"},e.createElement(N,{disabled:(c.current.question.required||c.current.question.type_info.pivot_question)&&(null==r[c.current.question.name]||0===r[c.current.question.name]?.length)||c.current.question.type_info.meta?.othersRequired&&R||l,onClick:()=>{h(!0),x({...r,others_meta:B},(()=>{i?.type_info.meta?.skipThankYouPage?w?setTimeout((()=>{k?.()}),300):window.location.href=i?.type_info.meta?.redirectUrl:g(!0)}))}},l?"Submitting":"Submit survey")),T()&&e.createElement("button",{className:"skip-button",onClick:()=>{q(!1),c.current=o[S],u.current=s.findIndex((e=>e.name===o[S].name)),v(_)}},"Clear selection")))},R=({survey:t,surveyStyle:s="standard",placeholders:u,onSubmit:c,widget:l,npsValue:m,preview:p,mobilePreview:f,closePreview:y})=>{const v=t.question_details?.questions||[],h=t.meta?.blocks||[],[x,g]=o(null),[b,w]=o({}),[k,q]=o(!1),[_,C]=o([]),[N,B]=o(0),[I,O]=o(!1),[Q,R]=o(null),[L,V]=o({}),Y=n(null),$=n(null),U=n(-1),A=n(null),D=n(0),H=n(0),M=n(!1),W=n([]),P=e.useRef(!!m&&"card"===s),j=n(null),G=n(0),[X,K]=o(!1);r((()=>{h&&(j.current=h.find((e=>"TY"===e.name)),g(h.filter((e=>"TY"!==e.name))))}),[h]),r((()=>{H.current=G.current,x&&_&&(D.current=x.findIndex((e=>e.name===_[G.current].name))),B(N+1)}),[X]),r((()=>{if(x)if($.current=v.find((e=>e.type_info?.pivot_question))??v.find((e=>"RANGE"===e.type_info?.question_type))??v[0],null!=m){U.current=m;const e=v.find((e=>e.name===x[0].question_names[0]));Y.current={...x[0],question:e},W.current=[...W.current,{...x[0],question:e}],C(W.current),w({Q_1:m})}else if(!Y.current&&x.length>0)return Y.current=x[0],void J(x[0])}),[x,m]),e.useEffect((()=>{_.length&&(W.current=_,H.current=_.length-1),B(_.length-1)}),[_]),r((()=>{Object.keys(b).length>0&&Y.current.question&&(d.includes(Y.current.question.type_info.question_type)||M.current)&&!Z()&&(m&&1==_.length?setTimeout((()=>{ee()}),1500):ee())}),[b]),r((()=>{if(null!=b?.[$.current?.name])if(j.current?.is_based_on_rating){const e=$.current?.type_info?.choices[b?.[$.current?.name]-$.current?.type_info?.validation?.min??0]?.dependent_question_names,n=j.current?.question_names.find((n=>e?.includes(n))),t=v.find((e=>e.name===n));R(t)}else{const e=v.find((e=>e.name==j.current?.question_names[0]));R(e)}}),[b?.[$.current?.name]]);const Z=()=>(D.current===x.length-1||"end"===Y.current.branchOption)&&H.current===_.length-1,J=e=>{let n={};if(e.is_based_on_rating){const t=$.current?.type_info?.choices[b?.[$.current?.name]-$.current?.type_info?.validation?.min??0]?.dependent_question_names,r=e.question_names.find((e=>t?.includes(e)));n=v.find((e=>e.name===r))}else n=v.find((n=>n.name===e.question_names[0]));Y.current.question=n;W.current.find((e=>e.question.name===n.name))?(B(N+1),H.current+=1):C([...W.current,{...e,question:n}])},ee=()=>{if(Z())q(!0);else{if(Y.current.nextBlock)D.current=x.findIndex((e=>e.name===Y.current.nextBlock));else if(Y.current.question.type_info?.meta?.branches){const e=Y.current.question.type_info?.meta?.branches,n=b[Y.current.question.name];let t;if(t="RANGE"===Y.current.question.type_info.question_type?e.find((e=>n>=e.min&&n<=e.max)):e.find((e=>n===e.value)),t?.nextBlock){if("TY"===t.nextBlock)return void q(!0);D.current=x.findIndex((e=>e.name===t.nextBlock))}else D.current+=1}else D.current+=1;Y.current=x[D.current],J(x[D.current])}},ne=(e,n,t)=>{if(P.current=!1,t){if(M.current=!0,null!=b[e.question.name]&&e.name!==_[_.length-1].name){const[t,r]=(e=>{const n=_.findIndex((n=>n.name===e.name)),t=_.slice(0,n+1),r=t.reduce(((e,n)=>(e[n.question.name]=b[n.question.name],e)),{});return D.current=x.findIndex((n=>n.name===e.name)),[t,r]})(e);w({...r,...null!=n&&{[e.question.name]:n}}),W.current=t}else w({...b,...null!=n&&{[e.question.name]:n}});$?.current?.name==e?.question?.name&&(U.current=n)}else w({...b,...null!=n&&{[e.question.name]:n}})};if(!Y.current||!Y.current.question)return null;const te=_[H.current];return e.createElement("div",{className:`freemium-survey-components ${f?"mobile-preview":""} ${s}-survey-style`,id:"freemium-survey"},e.createElement(E,{totalSteps:x.length,completedSteps:D.current+(k?1:0)}),e.createElement(i,{mode:"out-in"},e.createElement(a,{key:H.current+String(k),addEndListener:(e,n)=>{e.addEventListener("transitionend",n,!1)},classNames:X?"fade-reverse":"fade"},e.createElement("div",{className:"questions"},k?e.createElement(T,{thankYouQuestion:Q,preview:p,placeholders:u,npsValue:U.current}):e.createElement("div",{ref:A,id:`${te.question.name}`,className:`question-container ${l||"card"===s}`,"data-test-question-name":te.question.name},e.createElement("div",{className:"question-text",dangerouslySetInnerHTML:{__html:z(te.question.text,u,U.current)},title:`question-${H.current}`,role:"heading","aria-level":1}),e.createElement("div",{onTransitionEndCapture:e=>e.stopPropagation(),style:{width:"100%"}},e.createElement(S,{question:te.question,formValues:b,othersMeta:L,autoFocus:!0,autoFocusDelay:"standard"===s?350:0,saveOthersValue:(e,n)=>{V({...L,[e]:n})},onChangeHandler:e=>{M.current=!1,D.current=x.findIndex((e=>e.name===te.name)),Y.current=te,K(!1),ne(te,e,d.includes(te.question.type_info.question_type)&&!Z())}})),e.createElement(F,{question:te.question,widget:l,surveyStyle:s,formValues:b,othersMeta:L,blocksWithQns:_,blocks:x,thankYouQuestion:Q,currentBlockIndexOfBlocksWithQns:H,reverse:X,setReverse:K,currentBlockIndexOfBlocks:D,currentEditingBlock:Y,isSubmitting:I,isValuesCommitted:M,isCurrentBlockFinal:Z,setHorizontalScrollUnits:B,handleFormValues:ne,skipBlock:e=>{M.current=!0,delete b[e.name],w({...b})},setIsSubmitting:O,onSubmit:c,setIsSurveyCompleted:q,preventQuestionAnimation:P,preview:p,closePreview:y,tempCurrentBlockIndexOfBlocksWithQns:G}))))))};c(":root {\n --default-brand-color: #264966;\n --default-question-text-color: #000;\n --default-question-background-color: #fff;\n --default-background-color: #f8f8f8;\n --default-button-text-color: #fff;\n --default-secondary-button-text-color: #000;\n --default-input-placeholder-color: #92a2b1;\n}\n\n.freemium-survey-components.widget-survey-components .freemium-survey-step-navigation {\n white-space: nowrap;\n border-radius: 3px;\n border: 1px solid #efefef;\n}\n.freemium-survey-components.widget-survey-components .freemium-survey-step-navigation .navigation-button {\n width: 38px;\n text-align: -webkit-center;\n height: 38px;\n background-color: #fff;\n border: none;\n cursor: pointer;\n border-radius: 0 3px 3px 0;\n}\n.freemium-survey-components.widget-survey-components .freemium-survey-step-navigation .navigation-button svg {\n transform: rotate(90deg);\n}\n.freemium-survey-components.widget-survey-components .freemium-survey-step-navigation .navigation-button:first-of-type {\n border-right: 1px solid #efefef;\n border-radius: 3px 0 0 3px;\n}\n.freemium-survey-components.widget-survey-components .freemium-survey-step-navigation .navigation-button:disabled {\n cursor: not-allowed;\n opacity: 0.5;\n}\n.freemium-survey-components.widget-survey-components .freemium-survey-step-navigation .navigation-button:focus {\n position: relative;\n z-index: 1;\n}\n.freemium-survey-components.widget-survey-components .question-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n text-align: center;\n max-width: 700px;\n margin: 0 auto;\n border-radius: 4px;\n box-shadow: 0px 12px 15px rgba(18, 52, 77, 0.03);\n padding: 28px;\n grid-gap: 28px;\n gap: 28px;\n position: relative;\n overflow: auto;\n}\n.freemium-survey-components.widget-survey-components .hide-question-container {\n opacity: 0;\n}\n.freemium-survey-components.widget-survey-components .question-text {\n font-size: 1rem;\n font-weight: 600;\n line-height: 1.8;\n width: 100%;\n text-align: left;\n color: var(--default-question-text-color);\n color: var(--question-text-color, var(--default-question-text-color));\n}\n.freemium-survey-components.widget-survey-components .autofocus-button {\n border: none;\n width: 0;\n height: 0;\n opacity: 0;\n margin-top: -12px;\n margin-left: -12px;\n position: absolute;\n}\n.freemium-survey-components.widget-survey-components .fade-enter {\n opacity: 1;\n transform: translateX(80px);\n position: absolute;\n}\n.freemium-survey-components.widget-survey-components .fade-enter-active {\n position: absolute;\n opacity: 1;\n transform: translateX(0);\n}\n.freemium-survey-components.widget-survey-components .fade-enter-done {\n position: absolute;\n}\n.freemium-survey-components.widget-survey-components .fade-exit {\n opacity: 0.05;\n pointer-events: none;\n transform: translateX(0);\n}\n.freemium-survey-components.widget-survey-components .fade-exit-active {\n pointer-events: none;\n opacity: 0;\n transform: translateX(-80px);\n}\n.freemium-survey-components.widget-survey-components .fade-reverse-enter {\n opacity: 0;\n position: absolute;\n transform: translateX(-80px);\n}\n.freemium-survey-components.widget-survey-components .fade-reverse-enter-active {\n opacity: 1;\n position: absolute;\n transform: translateX(0);\n}\n.freemium-survey-components.widget-survey-components .fade-reverse-exit {\n opacity: 0.05;\n transform: translateX(0);\n}\n.freemium-survey-components.widget-survey-components .fade-reverse-exit-active {\n opacity: 0;\n transform: translateX(80px);\n}\n.freemium-survey-components.widget-survey-components .fade-enter-active,\n.freemium-survey-components.widget-survey-components .fade-reverse-enter-active {\n transition: opacity 400ms, transform 400ms;\n}\n.freemium-survey-components.widget-survey-components .fade-reverse-exit-active,\n.freemium-survey-components.widget-survey-components .fade-exit-active {\n transition: opacity 300ms, transform 300ms;\n}\n.freemium-survey-components.widget-survey-components .question-footer {\n display: flex;\n grid-gap: 40px;\n gap: 40px;\n width: 100%;\n align-items: center;\n}\n.freemium-survey-components.widget-survey-components .question-footer:empty {\n display: none;\n}\n.freemium-survey-components.widget-survey-components .question-footer:only-child {\n margin-left: auto;\n}\n.freemium-survey-components.widget-survey-components .action-buttons {\n display: flex;\n grid-gap: 20px;\n gap: 20px;\n flex-direction: row-reverse;\n width: 100%;\n}\n.freemium-survey-components.widget-survey-components .action-buttons:empty {\n display: none;\n}\n.freemium-survey-components.widget-survey-components .skip-button {\n font-weight: 500;\n cursor: pointer;\n background: transparent;\n border: none;\n min-width: 40px;\n padding: 8px 16px;\n border-radius: 4px;\n color: var(--default-secondary-button-text-color);\n color: var(--secondary-button-text-color, var(--default-secondary-button-text-color));\n letter-spacing: 0.05rem;\n line-height: 1.5;\n border: 1px solid transparent;\n transform: translateY(0px);\n transition: transform ease 0.2s;\n}\n.freemium-survey-components.widget-survey-components .skip-button:hover {\n background-color: #f3f3f3;\n transform: translateY(-4px);\n}\n.freemium-survey-components.widget-survey-components .next-button {\n color: var(--default-button-text-color);\n color: var(--button-text-color, var(--default-button-text-color));\n}\n.freemium-survey-components.widget-survey-components .submit {\n max-width: 700px;\n text-align: left;\n background: transparent;\n box-shadow: none;\n color: var(--default-button-text-color);\n color: var(--button-text-color, var(--default-button-text-color));\n}\n.freemium-survey-components.widget-survey-components .thankyou {\n display: flex;\n align-items: center;\n justify-content: center;\n grid-gap: 20px;\n gap: 20px;\n min-height: 180px;\n}\n.freemium-survey-components.widget-survey-components .thankyou .heading {\n font-weight: 600;\n font-size: 28px;\n}\n.freemium-survey-components.widget-survey-components .thankyou .text {\n white-space: pre-wrap;\n font-weight: 500;\n font-size: 0.875rem;\n line-height: 1.6;\n color: #12344d;\n width: 75%;\n}\n.freemium-survey-components.widget-survey-components .thankyou .redirection-text {\n color: #929292;\n margin-bottom: 12px;\n font-weight: 300;\n}\n.freemium-survey-components.widget-survey-components .thankyou .link {\n width: 100%;\n display: inline-block;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n color: #666;\n font-weight: 500;\n text-decoration: underline;\n}\n.freemium-survey-components.widget-survey-components .responsive-text-field {\n width: 100%;\n}\n.freemium-survey-components.widget-survey-components .responsive-text-field .textarea-container {\n display: none;\n}\n.freemium-survey-components.widget-survey-components .message-container:empty {\n display: none;\n}\n\n@media (max-width: 550px) {\n div.freemium-survey-components.card-survey-style .responsive-text-field .input-container {\n display: none;\n }\n div.freemium-survey-components.card-survey-style .responsive-text-field .textarea-container {\n display: flex;\n }\n div.freemium-survey-components.card-survey-style .question-footer {\n flex-direction: column-reverse;\n grid-gap: 20px;\n gap: 20px;\n }\n div.freemium-survey-components.card-survey-style .freemium-survey-step-navigation {\n width: 100%;\n }\n div.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button {\n width: 50%;\n }\n div.freemium-survey-components.card-survey-style .action-buttons {\n flex-direction: column;\n width: 100%;\n }\n div.freemium-survey-components.card-survey-style .action-buttons button {\n max-width: unset;\n }\n div.freemium-survey-components.card-survey-style .action-button {\n max-width: unset;\n width: 100%;\n }\n div.freemium-survey-components.card-survey-style .thankyou .text {\n width: auto;\n }\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .responsive-text-field .input-container {\n display: none;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .responsive-text-field .textarea-container {\n display: flex;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .question-footer {\n flex-direction: column-reverse;\n grid-gap: 20px;\n gap: 20px;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .freemium-survey-step-navigation {\n width: 100%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .freemium-survey-step-navigation .navigation-button {\n width: 50%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .action-buttons {\n flex-direction: column;\n width: 100%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .action-buttons button {\n max-width: unset;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .action-button {\n max-width: unset;\n width: 100%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .thankyou .text {\n width: auto;\n}\n\n.widget-survey-components.compact-style .freemium-survey-step-navigation {\n padding: 0 2px;\n margin-left: 4px;\n box-shadow: 0px 0px 6px #eee;\n margin-top: 4px;\n}\n.widget-survey-components.compact-style .nps-container .footer {\n padding-top: 12px;\n}\n.widget-survey-components.compact-style .nps-container .choices {\n grid-gap: 12px;\n gap: 12px;\n}\n\n.widget-survey-components,\n.card-survey-style {\n display: flex;\n flex-direction: column;\n grid-gap: 28px;\n gap: 28px;\n flex-grow: 1;\n font-size: 0.875rem;\n position: relative;\n overflow: hidden;\n}\n.widget-survey-components .questions,\n.card-survey-style .questions {\n min-width: 100%;\n max-width: 100%;\n background: var(--default-question-background-color);\n background: var(--question-background-color, var(--default-question-background-color));\n position: relative;\n display: flex;\n justify-content: row;\n align-items: flex-end;\n height: 100%;\n transition: height 400ms ease;\n}\n.widget-survey-components .question-text,\n.card-survey-style .question-text {\n width: 100%;\n text-align: left;\n}\n.widget-survey-components .focus-lock,\n.card-survey-style .focus-lock {\n width: 100%;\n}\n.widget-survey-components .question-container,\n.card-survey-style .question-container {\n height: -webkit-fit-content;\n height: -moz-fit-content;\n height: fit-content;\n max-height: 100%;\n min-width: 100%;\n max-width: 100%;\n margin-bottom: 0;\n padding: 28px;\n grid-gap: 28px;\n gap: 28px;\n flex-grow: 1;\n align-self: flex-end;\n margin-top: auto;\n position: absolute;\n}\n.widget-survey-components .question-footer,\n.card-survey-style .question-footer {\n margin: 0px auto;\n justify-content: space-between;\n position: -webkit-sticky;\n position: sticky;\n bottom: -28px;\n padding: 20px 0;\n background: var(--default-question-background-color);\n background: var(--question-background-color, var(--default-question-background-color));\n}\n.widget-survey-components .submit,\n.card-survey-style .submit {\n padding-bottom: 0;\n margin: unset;\n}\n.widget-survey-components .nps-container .footer,\n.card-survey-style .nps-container .footer {\n padding-top: 12px;\n}\n.widget-survey-components .nps-container .widget .choices,\n.card-survey-style .nps-container .widget .choices {\n grid-gap: 8px;\n gap: 8px;\n}\n.widget-survey-components .radio-group,\n.card-survey-style .radio-group {\n width: 100%;\n overflow: auto;\n}\n.widget-survey-components .checkbox-group,\n.card-survey-style .checkbox-group {\n width: 100%;\n overflow: auto;\n}\n\ndiv.widget-survey-components .question-container {\n box-shadow: none;\n border-radius: 0;\n}\ndiv.widget-survey-components .question-text {\n font-size: 0.875rem;\n}\ndiv.widget-survey-components .progressbar-container {\n position: absolute;\n}\ndiv.widget-survey-components .progressbar-container .progressbar {\n border-radius: 3px 0 0 0;\n}\ndiv.widget-survey-components .textarea-container .end-max-length {\n padding: 4px;\n}\ndiv.widget-survey-components .responsive-text-field .input-container {\n display: none;\n}\ndiv.widget-survey-components .responsive-text-field .textarea-container {\n display: flex;\n}\ndiv.widget-survey-components div.thankyou {\n min-height: unset;\n}\ndiv.widget-survey-components div.thankyou .text {\n width: 85%;\n}\ndiv.widget-survey-components div.thankyou svg {\n width: 140px;\n height: 120px;\n}\n\ndiv.widget-survey-components.default-style .freemium-survey-step-navigation {\n margin: 0;\n}\ndiv.widget-survey-components.default-style .question-container {\n padding: 28px;\n}\ndiv.widget-survey-components.default-style .question-footer {\n justify-content: space-between;\n}\ndiv.widget-survey-components.default-style .nps-container .footer {\n padding-top: 12px;\n}\ndiv.widget-survey-components.default-style .nps-container .choices {\n flex-wrap: unset;\n grid-gap: 12px;\n gap: 12px;\n}\ndiv.widget-survey-components.default-style .action-button {\n line-height: 1.2;\n}\ndiv.widget-survey-components.default-style .radio-group {\n flex-direction: column;\n flex-wrap: nowrap;\n overflow: auto;\n}\ndiv.widget-survey-components.default-style .radio-group .radio-label {\n padding: 12px 16px;\n min-width: 160px;\n font-size: 0.9rem;\n}\ndiv.widget-survey-components.default-style .checkbox-group {\n flex-direction: row;\n flex-wrap: wrap;\n}\ndiv.widget-survey-components.default-style .checkbox-group .checkbox-label {\n padding: 12px 16px;\n min-width: 160px;\n font-size: 0.9rem;\n}\ndiv.widget-survey-components.default-style textarea {\n min-height: 84px;\n}\ndiv.widget-survey-components.default-style .end-max-length {\n font-size: 0.8rem;\n font-weight: 300;\n padding: 4px;\n}\n\n.widget-survey-components.cozy-style .freemium-survey-step-navigation {\n margin: 0;\n}\n.widget-survey-components.cozy-style .question-text {\n font-size: 1rem;\n}\n.widget-survey-components.cozy-style .question-text.nps {\n text-align: center;\n width: 60%;\n min-width: 600px;\n margin: auto;\n}\n.widget-survey-components.cozy-style .question-container {\n padding: 12px 28px;\n}\n.widget-survey-components.cozy-style .question-footer {\n justify-content: space-between;\n}\n.widget-survey-components.cozy-style .nps-container {\n grid-gap: 44px;\n gap: 44px;\n}\n.widget-survey-components.cozy-style .nps-container .widget {\n display: flex;\n justify-content: center;\n}\n.widget-survey-components.cozy-style .nps-container .button-container {\n width: 60%;\n min-width: 600px;\n margin: 0 auto;\n}\n.widget-survey-components.cozy-style .nps-container .button-container .choices {\n justify-content: space-around;\n}\n.widget-survey-components.cozy-style .nps-container .footer {\n padding-top: 8px;\n}\n.widget-survey-components.cozy-style .action-button {\n line-height: 1.2;\n}\n.widget-survey-components.cozy-style .radio-group {\n flex-direction: row;\n flex-wrap: wrap;\n}\n.widget-survey-components.cozy-style .radio-group .radio-label {\n padding: 12px 16px;\n min-width: 160px;\n font-size: 0.9rem;\n}\n.widget-survey-components.cozy-style .checkbox-group {\n flex-direction: row;\n flex-wrap: wrap;\n}\n.widget-survey-components.cozy-style .checkbox-group .checkbox-label {\n padding: 12px 16px;\n min-width: 160px;\n font-size: 0.9rem;\n}\n.widget-survey-components.cozy-style textarea {\n min-height: 60px;\n}\n.widget-survey-components.cozy-style .end-max-length {\n font-size: 0.8rem;\n font-weight: 300;\n padding: 4px;\n}\n\n.freemium-survey-components.mobile-preview .thankyou .text {\n width: unset;\n}");const L=({thankYouQuestion:n,preview:t,placeholders:o,npsValue:s,setBlockElementRef:i},a)=>(r((()=>{t||n.type_info.meta?.redirectUrl&&setTimeout((()=>{window.location.href=n.type_info.meta?.redirectUrl}),n.type_info.meta?.redirectDelay??1e4)}),[]),e.createElement(e.Fragment,null,e.createElement("div",{className:"heading"},"Thank you!"),e.createElement("div",{className:"text",dangerouslySetInnerHTML:{__html:z(n.text,o,s)}}),n.type_info.meta?.redirectUrl&&e.createElement("div",{style:{width:"100%"}},e.createElement("div",{className:"redirection-text"},"You will be redirected to the below URL automatically in"," ",n.type_info.meta?.redirectDelay," seconds.",e.createElement("br",null)),e.createElement("a",{className:"link",href:n.type_info.meta?.redirectUrl},n?.type_info.meta?.redirectUrl)))),V=({currentBlockIndex:n,currentBlockIndexOfBlocksWithQns:t,blocksWithQns:r,blocks:o,setHorizontalScrollUnits:s,preventQuestionAnimation:i,tempCurrentBlockIndexOfBlocksWithQns:a,setReverse:u,reverse:c})=>e.createElement("div",{className:"freemium-survey-step-navigation","data-navigation-element":"1"},e.createElement("button",{disabled:0==t.current,className:"navigation-button",onClick:()=>{c?t.current=Math.max(t.current-1,0):a.current=Math.max(t.current-1,0),i.current=!1,u(!0),s(t.current)}},e.createElement(I,null)),e.createElement("button",{className:"navigation-button",disabled:t.current>=r.length-1,onClick:()=>{i.current=!1,c?a.current=Math.min(t.current+1,r.length-1):t.current=Math.min(t.current+1,r.length-1),u(!1),s(t.current)}},e.createElement(B,null))),Y=({widget:n,widgetStyle:t,surveyStyle:r,formValues:o,blocksWithQns:s,blocks:i,thankYouQuestion:a,currentBlockIndexOfBlocksWithQns:u,currentBlockIndexOfBlocks:c,currentEditingBlock:l,isSubmitting:m,isValuesCommitted:p,isCurrentBlockFinal:f,setHorizontalScrollUnits:y,handleFormValues:v,skipBlock:h,setIsSubmitting:x,onSubmit:g,setIsSurveyCompleted:b,preventQuestionAnimation:w,preview:k,closePreview:q,setReverse:E,tempCurrentBlockIndexOfBlocksWithQns:_,question:C,reverse:B,othersMeta:I,...S})=>{const z=S.blockIndex??u.current,O=()=>!d.includes(C.type_info.question_type)&&!f(),T=()=>"RANGE"!==C.type_info.question_type&&!C.required&&!f(),Q=()=>("DROPDOWN"===C.type_info.question_type&&!C.required&&o[C.name],!1),F=()=>f()&&(n||"standard"!==r),R="MULTI_SELECT"===l.current.question.type_info.question_type&&o[l.current.question.name]?.includes("others")&&(!I[l.current.question.name]||""===I[l.current.question.name]);return e.createElement("div",{className:"question-footer"},!(!n&&"standard"===r||0===z&&void 0===o[C.name]||"compact"===t||0===u.current&&!B)&&e.createElement(V,{currentBlockIndex:c,currentBlockIndexOfBlocksWithQns:u,blocksWithQns:s,blocks:i,setHorizontalScrollUnits:y,preventQuestionAnimation:w,setReverse:E,tempCurrentBlockIndexOfBlocksWithQns:_,reverse:B}),(O()||Q()||T()||F())&&e.createElement("div",{className:"action-buttons"},O()&&e.createElement(N,{onClick:()=>{E(!1),v(s[z],null,!0)},disabled:l.current.question.required&&(!o[l.current.question.name]||Array.isArray(o[l.current.question.name])&&0===o[l.current.question.name].length)||l.current.question.type_info.meta?.othersRequired&&R,className:"next-button"},"Next"),T()&&e.createElement("button",{className:"skip-button",onClick:()=>{E(!1),h(C)}},"Skip"),F()&&e.createElement("div",{className:"submit"},e.createElement(N,{disabled:(l.current.question.required||l.current.question.type_info.pivot_question)&&(null==o[l.current.question.name]||0===o[l.current.question.name]?.length)||l.current.question.type_info.meta?.othersRequired&&R||m,onClick:()=>{x(!0),g({...o,others_meta:I},(()=>{a?.type_info.meta?.skipThankYouPage?k?setTimeout((()=>{q?.()}),300):window.location.href=a?.type_info.meta?.redirectUrl:b(!0)}))}},m?"Submitting":"Submit survey")),Q()&&e.createElement("button",{className:"skip-button",onClick:()=>{E(!1),l.current=s[z],c.current=i.findIndex((e=>e.name===s[z].name)),h(C)}},"Clear selection")))},$=({survey:t,surveyStyle:i="standard",placeholders:c,onSubmit:l,widget:m,npsValue:f,widgetStyle:y,widgetNavigatorQuerySelector:v,preview:h,mobilePreview:x,closePreview:g})=>{const b=t.question_details?.questions||[],w=t.meta?.blocks||[],[k,q]=o(null),[_,C]=o({}),[N,B]=o(!1),[I,O]=o([]),[T,Q]=o(0),[F,R]=o(!1),[V,$]=o(null),[U,A]=o({}),D=n(null),H=n(null),M=n(-1),[W,P]=o(null),j=n(0),G=n(0),X=n(!1),K=n([]),Z=n(!!f&&"card"===i),J=n(null),ee=n(0),[ne,te]=o(!1),re=n(0);r((()=>{w&&(J.current=w.find((e=>"TY"===e.name)),q(w.filter((e=>"TY"!==e.name))))}),[w]),r((()=>{G.current=ee.current,k&&I&&(j.current=k.findIndex((e=>e.name===I[ee.current].name))),Q(T+1)}),[ne]),r((()=>{if(k)if(H.current=b.find((e=>e.type_info?.pivot_question))??b.find((e=>"RANGE"===e.type_info?.question_type))??b[0],null!=f){M.current=f;const e=b.find((e=>e.name===k[0].question_names[0]));D.current={...k[0],question:e},K.current=[...K.current,{...k[0],question:e}],O(K.current),C({Q_1:f})}else if(!D.current&&k.length>0)return D.current=k[0],void se(k[0])}),[k,f]),r((()=>{I.length&&(K.current=I,G.current=I.length-1,Q(I.length-1))}),[I]),r((()=>{Object.keys(_).length>0&&D.current.question&&(d.includes(D.current.question.type_info.question_type)||X.current)&&!oe()&&(f&&1==I.length?setTimeout((()=>{ie()}),1500):ie())}),[_]),r((()=>{if(null!=_?.[H.current?.name])if(J.current?.is_based_on_rating){const e=H.current?.type_info?.choices[_?.[H.current?.name]-H.current?.type_info?.validation?.min??0]?.dependent_question_names,n=J.current?.question_names.find((n=>e?.includes(n))),t=b.find((e=>e.name===n));$(t)}else{const e=b.find((e=>e.name==J.current?.question_names[0]));$(e)}}),[_?.[H.current?.name]]);s((()=>{(()=>{if(W){W.style.minHeight="unset",W.style.height="min-content";const e=Math.min(W?.scrollHeight,p[y]);W.style.height=e+"px",W.style.minHeight=e+"px",re.current=e}})()}),[W]);const oe=()=>(j.current===k.length-1||"end"===D.current.branchOption)&&G.current===I.length-1,se=e=>{let n={};if(e.is_based_on_rating){const t=H.current?.type_info?.choices[_?.[H.current?.name]-H.current?.type_info?.validation?.min??0]?.dependent_question_names,r=e.question_names.find((e=>t?.includes(e)));n=b.find((e=>e.name===r))}else n=b.find((n=>n.name===e.question_names[0]));D.current.question=n;K.current.find((e=>e.question.name===n.name))?(Q(T+1),G.current+=1):O([...K.current,{...e,question:n}])},ie=()=>{if(oe())B(!0);else{if(D.current.nextBlock)j.current=k.findIndex((e=>e.name===D.current.nextBlock));else if(D.current.question.type_info?.meta?.branches){const e=D.current.question.type_info?.meta?.branches,n=_[D.current.question.name];let t;if(t="RANGE"===D.current.question.type_info.question_type?e.find((e=>n>=e.min&&n<=e.max)):e.find((e=>n===e.value)),t?.nextBlock){if("TY"===t.nextBlock)return void B(!0);j.current=k.findIndex((e=>e.name===t.nextBlock))}else j.current+=1}else j.current+=1;D.current=k[j.current],se(k[j.current])}},ae=(e,n,t)=>{if(Z.current=!1,t){if(X.current=!0,null!=_[e.question.name]&&e.name!==I[I.length-1].name){const[t,r]=(e=>{const n=I.findIndex((n=>n.name===e.name)),t=I.slice(0,n+1),r=t.reduce(((e,n)=>(e[n.question.name]=_[n.question.name],e)),{});return j.current=k.findIndex((n=>n.name===e.name)),[t,r]})(e);C({...r,...null!=n&&{[e.question.name]:n}}),K.current=t}else C({..._,...null!=n&&{[e.question.name]:n}});H?.current?.name==e?.question?.name&&(M.current=n)}else C({..._,...null!=n&&{[e.question.name]:n}})},ue=I[G.current];return D.current&&D.current.question?e.createElement("div",{className:`freemium-survey-components ${m?"widget-survey-components":""} ${y}-style ${x?"mobile-preview":""}`,id:"freemium-survey"},e.createElement(E,{totalSteps:k.length,completedSteps:j.current+(N?1:0)}),e.createElement("div",{className:"questions",style:{height:re.current,...1===I.length?{transition:"none"}:{}}},e.createElement(u,{component:null},e.createElement(a,{key:ue.question.name+String(N),unmountOnExit:!0,addEndListener:(e,n)=>{e.addEventListener("transitionend",n,!1)},classNames:ne?"fade-reverse":"fade"},e.createElement("div",{ref:e=>e?P(e):null,id:`${ue.question.name}`,className:"question-container "+(N?"thankyou":""),"data-test-question-name":ue.question.name},N?e.createElement(L,{thankYouQuestion:V,preview:h,placeholders:c,npsValue:M.current,setBlockElementRef:P}):e.createElement(e.Fragment,null,e.createElement("div",{className:"question-text",dangerouslySetInnerHTML:{__html:z(ue.question.text,c,M.current)},title:`question-${G.current}`,role:"heading","aria-level":1}),e.createElement("div",{onTransitionEndCapture:e=>e.stopPropagation(),style:{width:"100%",flexGrow:"1"}},e.createElement(S,{question:ue.question,formValues:_,othersMeta:U,autoFocus:!0,autoFocusDelay:"standard"===i?350:0,saveOthersValue:(e,n)=>{A({...U,[e]:n})},onChangeHandler:e=>{X.current=!1,j.current=k.findIndex((e=>e.name===ue.name)),D.current=ue,te(!1),ae(ue,e,d.includes(ue.question.type_info.question_type)&&!oe())}})),e.createElement(Y,{question:ue.question,widget:m,widgetStyle:y,surveyStyle:i,formValues:_,othersMeta:U,blocksWithQns:I,blocks:k,thankYouQuestion:V,currentBlockIndexOfBlocksWithQns:G,reverse:ne,setReverse:te,currentBlockIndexOfBlocks:j,currentEditingBlock:D,isSubmitting:F,isValuesCommitted:X,isCurrentBlockFinal:oe,setHorizontalScrollUnits:Q,handleFormValues:ae,skipBlock:e=>{X.current=!0,delete _[e.name],C({..._})},setIsSubmitting:R,onSubmit:l,setIsSurveyCompleted:B,preventQuestionAnimation:Z,preview:h,closePreview:g,tempCurrentBlockIndexOfBlocksWithQns:ee}))))))):null};c(":root {\n --default-brand-color: #264966;\n --default-question-text-color: #000;\n --default-question-background-color: #fff;\n --default-background-color: #f8f8f8;\n --default-button-text-color: #fff;\n --default-secondary-button-text-color: #000;\n --default-input-placeholder-color: #92a2b1;\n --compact-widget-max-height: 480px;\n --default-widget-max-height: 460px;\n --cozy-widget-max-height: 380px;\n}\n\n.freemium-survey-step-navigation {\n border-radius: 3px;\n border: 1px solid #efefef;\n white-space: nowrap;\n}\n.freemium-survey-step-navigation .navigation-button {\n width: 38px;\n text-align: -webkit-center;\n height: 38px;\n background-color: #fff;\n border: none;\n cursor: pointer;\n border-radius: 0 3px 3px 0;\n}\n.freemium-survey-step-navigation .navigation-button:first-of-type {\n border-right: 1px solid #efefef;\n border-radius: 3px 0 0 3px;\n}\n.freemium-survey-step-navigation .navigation-button:disabled {\n cursor: not-allowed;\n opacity: 0.5;\n}\n.freemium-survey-step-navigation .navigation-button:focus {\n position: relative;\n z-index: 1;\n}\n\n.freemium-survey-components.standard-survey-style .question-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n text-align: center;\n max-width: 700px;\n margin: 0 auto;\n background: var(--default-question-background-color);\n background: var(--question-background-color, var(--default-question-background-color));\n border-radius: 4px;\n transition: transform 500ms ease 0ms, opacity 800ms ease 0ms;\n box-shadow: 0px 12px 15px rgba(18, 52, 77, 0.03);\n margin-bottom: 28px;\n padding: 28px;\n grid-gap: 28px;\n gap: 28px;\n position: relative;\n height: -webkit-fit-content;\n height: -moz-fit-content;\n height: fit-content;\n overflow: auto;\n opacity: 1;\n}\n.freemium-survey-components.standard-survey-style .hide-question-container {\n pointer-events: none;\n opacity: 0;\n}\n.freemium-survey-components.standard-survey-style .question-text {\n font-size: 1rem;\n font-weight: 600;\n line-height: 1.8;\n width: 100%;\n text-align: left;\n color: var(--default-question-text-color);\n color: var(--question-text-color, var(--default-question-text-color));\n}\n.freemium-survey-components.standard-survey-style .autofocus-button {\n border: none;\n width: 0;\n height: 0;\n opacity: 0;\n margin-top: -12px;\n margin-left: -12px;\n position: absolute;\n}\n.freemium-survey-components.standard-survey-style .question-footer {\n display: flex;\n justify-content: flex-start;\n grid-gap: 40px;\n gap: 40px;\n width: 100%;\n align-items: center;\n}\n.freemium-survey-components.standard-survey-style .question-footer:empty {\n display: none;\n}\n.freemium-survey-components.standard-survey-style .action-buttons {\n display: flex;\n grid-gap: 20px;\n gap: 20px;\n flex-direction: row-reverse;\n}\n.freemium-survey-components.standard-survey-style .action-buttons:empty {\n display: none;\n}\n.freemium-survey-components.standard-survey-style .skip-button {\n font-weight: 500;\n cursor: pointer;\n background: transparent;\n border: none;\n min-width: 40px;\n padding: 8px 16px;\n border-radius: 4px;\n color: var(--default-secondary-button-text-color);\n color: var(--secondary-button-text-color, var(--default-secondary-button-text-color));\n letter-spacing: 0.05rem;\n line-height: 1.5;\n border: 1px solid transparent;\n transform: translateY(0px);\n transition: transform ease 0.2s;\n}\n.freemium-survey-components.standard-survey-style .skip-button:hover {\n background-color: #f3f3f3;\n transform: translateY(-4px);\n}\n.freemium-survey-components.standard-survey-style .next-button {\n color: var(--default-button-text-color);\n color: var(--button-text-color, var(--default-button-text-color));\n}\n.freemium-survey-components.standard-survey-style .submit {\n max-width: 700px;\n margin: 0 auto;\n text-align: left;\n background: transparent;\n box-shadow: none;\n padding-bottom: 40px;\n color: var(--default-button-text-color);\n color: var(--button-text-color, var(--default-button-text-color));\n}\n.freemium-survey-components.standard-survey-style .fade-enter {\n transition: all ease 400ms;\n opacity: 0;\n transform: translateY(40px);\n}\n.freemium-survey-components.standard-survey-style .fade-enter-active {\n transition: all ease 400ms;\n opacity: 1;\n transform: translateY(0);\n}\n.freemium-survey-components.standard-survey-style .fade-exit {\n transition: all ease 400ms;\n opacity: 1;\n transform: translateY(0);\n}\n.freemium-survey-components.standard-survey-style .fade-exit-active {\n transition: all ease 400ms;\n opacity: 0;\n transform: translateY(-40px);\n}\n.freemium-survey-components.standard-survey-style .thankyou {\n display: flex;\n align-items: center;\n justify-content: center;\n grid-gap: 20px;\n gap: 20px;\n min-height: 180px;\n}\n.freemium-survey-components.standard-survey-style .thankyou .heading {\n font-weight: 600;\n font-size: 28px;\n}\n.freemium-survey-components.standard-survey-style .thankyou .text {\n white-space: pre-wrap;\n font-weight: 500;\n font-size: 0.875rem;\n line-height: 1.6;\n color: #12344d;\n width: 75%;\n}\n.freemium-survey-components.standard-survey-style .thankyou .redirection-text {\n color: #929292;\n margin-bottom: 12px;\n font-weight: 300;\n}\n.freemium-survey-components.standard-survey-style .thankyou .link {\n width: 100%;\n display: inline-block;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n color: #666;\n font-weight: 500;\n text-decoration: underline;\n}\n.freemium-survey-components.standard-survey-style .responsive-text-field {\n width: 100%;\n}\n.freemium-survey-components.standard-survey-style .responsive-text-field .textarea-container {\n display: none;\n}\n.freemium-survey-components.standard-survey-style .message-container:empty {\n display: none;\n}\n@media (max-width: 550px) {\n .freemium-survey-components.standard-survey-style .action-buttons {\n flex-direction: column;\n width: 100%;\n }\n .freemium-survey-components.standard-survey-style .action-buttons button {\n max-width: unset;\n }\n .freemium-survey-components.standard-survey-style .action-button {\n max-width: unset;\n width: 100%;\n }\n .freemium-survey-components.standard-survey-style .thankyou .text {\n width: auto;\n }\n}\n\n@media (max-width: 550px) {\n .freemium-survey-component .responsive-text-field .input-container,\n.card-survey-style .responsive-text-field .input-container {\n display: none;\n }\n .freemium-survey-component .responsive-text-field .textarea-container,\n.card-survey-style .responsive-text-field .textarea-container {\n display: flex;\n }\n}\n.freemium-survey-components.mobile-preview .thankyou .text {\n width: unset;\n}");const U=({thankYouQuestion:n,preview:t,placeholders:o,npsValue:s})=>(r((()=>{t||n.type_info.meta?.redirectUrl&&setTimeout((()=>{window.location.href=n.type_info.meta?.redirectUrl}),1e3*(n.type_info.meta?.redirectDelay??1e4))}),[]),e.createElement("div",{className:"question-container thankyou"},e.createElement("div",{className:"heading"},"Thank you!"),e.createElement("div",{className:"text",dangerouslySetInnerHTML:{__html:z(n.text,o,s)}}),n.type_info.meta?.redirectUrl&&e.createElement("div",{style:{width:"100%"}},e.createElement("div",{className:"redirection-text"},"You will be redirected to the below URL automatically in"," ",n.type_info.meta?.redirectDelay," seconds.",e.createElement("br",null)),e.createElement("a",{className:"link",href:n.type_info.meta?.redirectUrl},n?.type_info.meta?.redirectUrl)))),A=({currentBlockIndex:n,currentBlockIndexOfBlocksWithQns:t,blocksWithQns:r,blocks:o,setHorizontalScrollUnits:s,preventQuestionAnimation:i})=>e.createElement("div",{className:"freemium-survey-step-navigation","data-navigation-element":"1"},e.createElement("button",{disabled:0==t.current,className:"navigation-button",onClick:()=>{t.current=Math.max(t.current-1,0),n.current=o.findIndex((e=>e.name===r[t.current].name)),i.current=!1,s(t.current)}},e.createElement(I,null)),e.createElement("button",{className:"navigation-button",disabled:t.current>=r.length-1,onClick:()=>{i.current=!1,t.current=Math.min(t.current+1,r.length-1),n.current=o.findIndex((e=>e.name===r[t.current].name)),s(t.current)}},e.createElement(B,null))),D=({widget:n,surveyStyle:t,formValues:r,othersMeta:o,blocksWithQns:s,blocks:i,thankYouQuestion:a,currentBlockIndexOfBlocksWithQns:u,currentBlockIndexOfBlocks:c,currentEditingBlock:l,isSubmitting:m,isValuesCommitted:p,isCurrentBlockFinal:f,setHorizontalScrollUnits:y,handleFormValues:v,skipBlock:h,setIsSubmitting:x,onSubmit:g,setIsSurveyCompleted:b,preventQuestionAnimation:w,preview:k,closePreview:q,...E})=>{const _=E.blockIndex??u.current,C=E.question??s[_].question,B=()=>C.name===l.current.question.name&&!d.includes(C.type_info.question_type)&&!f(),I=()=>"RANGE"!==C.type_info.question_type&&!C.required&&C.name===l.current.question.name&&!f(),S=()=>("DROPDOWN"===C.type_info.question_type&&C.name!==l.current.question.name&&!C.required&&r[C.name],!1),z=()=>f()&&(n||"standard"!==t)&&C.name===l.current.question.name,O="MULTI_SELECT"===l.current.question.type_info.question_type&&r[l.current.question.name]?.includes("others")&&(!o[l.current.question.name]||""===o[l.current.question.name]);return e.createElement("div",{className:"question-footer"},!(!n&&"standard"===t||0===_&&!r[C.name])&&e.createElement(A,{currentBlockIndex:c,currentBlockIndexOfBlocksWithQns:u,blocksWithQns:s,blocks:i,setHorizontalScrollUnits:y,preventQuestionAnimation:w}),(B()||S()||I()||z())&&e.createElement("div",{className:"action-buttons"},B()&&e.createElement(N,{onClick:()=>{v(s[_],null,!0)},disabled:l.current.question.required&&(!r[l.current.question.name]||Array.isArray(r[l.current.question.name])&&0===r[l.current.question.name].length)||l.current.question.type_info.meta?.othersRequired&&O,className:"next-button"},"Next"),I()&&e.createElement("button",{className:"skip-button",onClick:()=>h(C)},"Skip"),S()&&e.createElement("button",{className:"skip-button",onClick:()=>{l.current=s[_],c.current=i.findIndex((e=>e.name===s[_].name)),h(C)}},"Clear selection"),z()&&e.createElement("div",{className:"submit"},e.createElement(N,{disabled:(l.current.question.required||l.current.question.type_info.pivot_question)&&(null==r[l.current.question.name]||0===r[l.current.question.name]?.length)||l.current.question.type_info.meta?.othersRequired&&O||m,onClick:()=>{x(!0),g({...r,others_meta:o},(()=>{a?.type_info.meta?.skipThankYouPage?k?setTimeout((()=>{q?.()}),300):window.location.href=a?.type_info.meta?.redirectUrl:b(!0)}))}},m?"Submitting":"Submit survey"))))},H=({survey:t,surveyStyle:s="standard",placeholders:u,onSubmit:c,widget:l,npsValue:m,preview:p,mobilePreview:f,closePreview:y})=>{const v=t.question_details?.questions||[],h=t.meta?.blocks||[],[x,g]=o(null),[b,w]=o({}),[k,q]=o(!1),[_,C]=o([]),[B,I]=o(0),[O,T]=o(!1),[Q,F]=o(null),[R,L]=o({}),V=n(null),Y=n(null),$=n(-1),A=n(null),H=n(0),M=n(0),W=n(!1),P=n([]),j=n(!!m&&"card"===s),G=n(null),X=n([]);r((()=>{h&&(G.current=h.find((e=>"TY"===e.name)),g(h.filter((e=>"TY"!==e.name))))}),[h]),r((()=>{if(x)if(Y.current=v.find((e=>e.type_info?.pivot_question))??v.find((e=>"RANGE"===e.type_info?.question_type))??v[0],null!=m){$.current=m;const e=v.find((e=>e.name===x[0].question_names[0]));V.current={...x[0],question:e},P.current=[...P.current,{...x[0],question:e}],C(P.current),w({Q_1:m})}else if(!V.current&&x.length>0)return V.current=x[0],void Z(x[0])}),[x,m]),r((()=>{_.length&&(P.current=_,M.current=_.length-1),l||"standard"!==s?(A.current&&(A.current.style.maxHeight="unset"),X.current[H.current]=A.current?.scrollHeight||X.current[H.current]||0,A.current&&(A.current.style.maxHeight="100%")):A.current?.scrollIntoView({block:"start",behavior:"smooth"}),I(_.length-1)}),[_]),r((()=>{Object.keys(b).length>0&&V.current.question&&(d.includes(V.current.question.type_info.question_type)||W.current)&&!K()&&J()}),[b]),r((()=>{if(null!=b?.[Y.current?.name])if(G.current?.is_based_on_rating){const e=Y.current?.type_info?.choices[b?.[Y.current?.name]-Y.current?.type_info?.validation?.min??0]?.dependent_question_names,n=G.current?.question_names.find((n=>e?.includes(n))),t=v.find((e=>e.name===n));F(t)}else{const e=v.find((e=>e.name==G.current?.question_names[0]));F(e)}}),[b?.[Y.current?.name]]);const K=()=>H.current===x.length-1||"end"===V.current.branchOption,Z=e=>{let n={};if(e.is_based_on_rating){const t=Y.current?.type_info?.choices[b?.[Y.current?.name]-Y.current?.type_info?.validation?.min??0]?.dependent_question_names,r=e.question_names.find((e=>t?.includes(e)));n=v.find((e=>e.name===r))}else n=v.find((n=>n.name===e.question_names[0]));V.current.question=n;P.current.find((e=>e.question.name===n.name))?(I(B+1),M.current+=1):C([...P.current,{...e,question:n}])},J=()=>{if(K())q(!0);else{if(V.current.nextBlock)H.current=x.findIndex((e=>e.name===V.current.nextBlock));else if(V.current.question.type_info?.meta?.branches){const e=V.current.question.type_info?.meta?.branches,n=b[V.current.question.name];let t;if(t="RANGE"===V.current.question.type_info.question_type?e.find((e=>n>=e.min&&n<=e.max)):e.find((e=>n===e.value)),t?.nextBlock){if("TY"===t.nextBlock)return void q(!0);H.current=x.findIndex((e=>e.name===t.nextBlock))}else H.current+=1}else H.current+=1;V.current=x[H.current],Z(x[H.current])}},ee=e=>{W.current=!0,delete b[e.name],w({...b})},ne=(e,n,t)=>{if(j.current=!1,t){if(W.current=!0,null!=b[e.question.name]&&e.name!==_[_.length-1].name){const[t,r]=(e=>{const n=_.findIndex((n=>n.name===e.name)),t=_.slice(0,n+1),r=t.reduce(((e,n)=>(e[n.question.name]=b[n.question.name],e)),{});return H.current=x.findIndex((n=>n.name===e.name)),[t,r]})(e);w({...r,...null!=n&&{[e.question.name]:n}}),P.current=t}else w({...b,...null!=n&&{[e.question.name]:n}});Y?.current?.name==e?.question?.name&&($.current=n)}else w({...b,...null!=n&&{[e.question.name]:n}})},te=(e,n)=>{L({...R,[e]:n})};return V.current&&V.current.question?e.createElement("div",{className:`freemium-survey-components ${l?"widget-survey-components":""} ${f?"mobile-preview":""} ${s}-survey-style`,id:"freemium-survey"},k?null:e.createElement(E,{totalSteps:x.length,completedSteps:H.current}),e.createElement(i,{mode:"out-in"},e.createElement(a,{key:String(k),addEndListener:(e,n)=>{e.addEventListener("transitionend",n,!1)},classNames:l?"":"fade"},e.createElement("div",null,k?e.createElement(U,{thankYouQuestion:Q,preview:p,placeholders:u,npsValue:$.current}):e.createElement(e.Fragment,null,e.createElement("div",{onTransitionEndCapture:e=>e.stopPropagation(),style:l||"card"===s?{transform:`translateX(calc(-${B} * 100%))`,height:`${X.current[H.current]}px`,transition:j.current||_?.length<=1?"none":"all 300ms ease-out 0ms"}:{},className:"questions"},_.map(((n,t)=>e.createElement("div",{key:n.question.name,ref:A,className:"question-container "+(!l&&"card"!==s||M.current===t?"":"hide-question-container")},e.createElement("div",{className:"question-text "+(0===t?"nps":""),dangerouslySetInnerHTML:{__html:z(n.question.text,u,$.current)},title:`question-${t}`,role:"heading","aria-level":1}),e.createElement("button",{disabled:!l&&"standard"===s,className:"autofocus-button",onKeyDown:e=>{"Tab"===e.key&&(e.stopPropagation(),e.preventDefault())}}),e.createElement(S,{question:n.question,formValues:b,othersMeta:R,autoFocus:M.current===t,autoFocusDelay:"standard"===s?350:20,saveOthersValue:te,onChangeHandler:e=>{W.current=!1,H.current=x.findIndex((e=>e.name===n.name)),V.current=n,ne(n,e,d.includes(n.question.type_info.question_type)&&!K())}}),e.createElement("button",{disabled:!l&&"standard"===s,className:"autofocus-button",onKeyDown:e=>{"Tab"===e.key&&(e.stopPropagation(),e.preventDefault())}}),e.createElement(D,{question:n.question,blockIndex:t,widget:l,surveyStyle:s,formValues:b,othersMeta:R,blocksWithQns:_,blocks:x,thankYouQuestion:Q,currentBlockIndexOfBlocksWithQns:M,currentBlockIndexOfBlocks:H,currentEditingBlock:V,isSubmitting:O,isValuesCommitted:W,isCurrentBlockFinal:K,setHorizontalScrollUnits:I,handleFormValues:ne,skipBlock:ee,setIsSubmitting:T,onSubmit:c,setIsSurveyCompleted:q,preventQuestionAnimation:j,preview:p,closePreview:y})))),!l&&"card"!==s&&K()&&e.createElement("div",{className:"submit"},e.createElement(N,{disabled:(V.current.question.required||V.current.question.type_info.pivot_question)&&(null==b[V.current.question.name]||0===b[V.current.question.name]?.length)||V.current.question.type_info.meta?.othersRequired&&"MULTI_SELECT"===V.current.question.type_info.question_type&&b[V.current.question.name]?.includes("")||O,onClick:()=>{T(!0),c({...b,others_meta:R},(()=>{Q?.type_info.meta?.skipThankYouPage?p?setTimeout((()=>{y?.()}),300):window.location.href=Q?.type_info.meta?.redirectUrl:q(!0)}))}},O?"Submitting":"Submit survey")))))))):null},M=n=>{const t=O(n.survey);return e.createElement(e.Fragment,null,"standard"===n.surveyStyle?e.createElement(H,Object.assign({},n,{survey:t})):e.createElement(R,Object.assign({},n,{survey:t})))},W=n=>{const t=O(n.survey);return e.createElement($,Object.assign({},n,{survey:t}))};export{C as BUTTON_SIZE_VARIANTS,N as Button,b as CheckboxGroup,h as Input,l as NPS,E as ProgressBar,q as Radio,k as RadioGroup,M as Survey,x as TextArea,W as WebInAppSurvey};
1
+ import e,{useRef as n,forwardRef as t,useEffect as r,useState as o,useMemo as s}from"react";import{SwitchTransition as i,CSSTransition as a,TransitionGroup as u}from"react-transition-group";function c(e,n){void 0===n&&(n={});var t=n.insertAt;if(e&&"undefined"!=typeof document){var r=document.head||document.getElementsByTagName("head")[0],o=document.createElement("style");o.type="text/css","top"===t&&r.firstChild?r.insertBefore(o,r.firstChild):r.appendChild(o),o.styleSheet?o.styleSheet.cssText=e:o.appendChild(document.createTextNode(e))}}c(".freemium-survey-components .nps-container {\n margin: 0 auto;\n width: 100%;\n display: flex;\n flex-direction: column;\n grid-gap: 28px;\n gap: 28px;\n}\n.freemium-survey-components .nps-container .footer {\n border-top: 1px solid var(--default-background-color);\n border-top: 1px solid var(--background-color, var(--default-background-color));\n padding-top: 20px;\n display: flex;\n justify-content: center;\n font-size: 0.875rem;\n line-height: 1.5;\n color: #666;\n}\n.freemium-survey-components .nps-container .footer:empty {\n display: none;\n}\n.freemium-survey-components .nps-container .nps-scale {\n position: relative;\n}\n.freemium-survey-components .nps-container .nps-scale .button-container {\n display: flex;\n border-radius: 4px;\n justify-content: space-between;\n background: var(--default-background-color);\n background: var(--background-color, var(--default-background-color));\n position: relative;\n margin-bottom: 40px;\n}\n.freemium-survey-components .nps-container .nps-scale .positive-text {\n position: absolute;\n color: #475867;\n bottom: -40px;\n font-size: 12px;\n right: 0px;\n text-align: right;\n}\n.freemium-survey-components .nps-container .nps-scale .negative-text {\n position: absolute;\n color: #475867;\n bottom: -40px;\n font-size: 12px;\n left: 0;\n text-align: left;\n}\n.freemium-survey-components .nps-container .nps-scale span {\n color: #aaa;\n font-size: 0.75rem;\n}\n.freemium-survey-components .nps-container .nps-scale button {\n display: inline-block;\n font-size: 1rem;\n white-space: nowrap;\n vertical-align: middle;\n background: none;\n border: none;\n box-shadow: none;\n cursor: pointer;\n text-align: center;\n font-weight: 400;\n border-radius: 4px;\n margin: 0;\n outline: none;\n margin-left: -1px;\n width: 40px;\n height: 40px;\n transform: scale(1);\n}\n.freemium-survey-components .nps-container .nps-scale button:hover {\n transition: background 0.2s ease-in, border-color 0.2s ease-in, transform 0.2s cubic-bezier(0.5, 2, 0.5, 0.75);\n}\n.freemium-survey-components .nps-container .nps-scale button:hover, .freemium-survey-components .nps-container .nps-scale button:focus {\n color: white;\n transform: scale(1.2);\n z-index: 2;\n position: relative;\n}\n.freemium-survey-components .nps-container .nps-scale button.active {\n color: white;\n transform: scale(1.2);\n z-index: 2;\n position: relative;\n}\n.freemium-survey-components .nps-container .nps-scale.rounded button {\n border-radius: 50%;\n}\n.freemium-survey-components .nps-container .nps-scale.square button {\n border-radius: 0;\n}\n.freemium-survey-components .nps-container .nps-scale.curved button {\n border-radius: 3px;\n}\n.freemium-survey-components .nps-container .nps-scale.highlighted button:hover, .freemium-survey-components .nps-container .nps-scale.highlighted button:focus, .freemium-survey-components .nps-container .nps-scale.highlighted button.active {\n background: var(--default-brand-color) !important;\n background: var(--brand-color, var(--default-brand-color)) !important;\n}\n.freemium-survey-components .nps-container .nps-scale .choices {\n width: 100%;\n display: flex;\n justify-content: space-between;\n font-weight: 500;\n}\n.freemium-survey-components .nps-container .nps-scale.standard .button-container {\n background-color: transparent;\n}\n.freemium-survey-components .nps-container .nps-scale.standard .choice {\n background: #EBEFF3;\n color: #000;\n}\n.freemium-survey-components .nps-container .nps-scale.standard .choice:focus, .freemium-survey-components .nps-container .nps-scale.standard .choice.active, .freemium-survey-components .nps-container .nps-scale.standard .choice:hover {\n background: #E43E3D;\n}\n.freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(1):focus, .freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(1).active, .freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(1):hover, .freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(2):focus, .freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(2).active, .freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(2):hover {\n background: #00AF50;\n}\n.freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(3):hover, .freemium-survey-components .nps-container .nps-scale.standard .choice:nth-last-child(4):hover {\n background: #F8C43E;\n}\n.freemium-survey-components .nps-container .nps-scale.standard .choice:hover, .freemium-survey-components .nps-container .nps-scale.standard .choice:focus, .freemium-survey-components .nps-container .nps-scale.standard .choice.active {\n color: #fff;\n transform: scale(1.2);\n}\n\n.freemium-survey-components.mobile-preview .nps-container .nps-scale .button-container {\n background: transparent;\n}\n.freemium-survey-components.mobile-preview .nps-container .nps-scale .choices {\n flex-wrap: wrap;\n justify-content: center;\n grid-gap: 16px;\n gap: 16px;\n background: transparent;\n}\n.freemium-survey-components.mobile-preview .nps-container .nps-scale button {\n border-radius: 50%;\n background: #ebeff3;\n}\n\n@media (max-width: 550px) {\n .freemium-survey-components .nps-container .nps-scale .button-container,\n.card-survey-style .nps-container .nps-scale .button-container {\n background: transparent;\n }\n .freemium-survey-components .nps-container .nps-scale .choices,\n.card-survey-style .nps-container .nps-scale .choices {\n flex-wrap: wrap;\n justify-content: center;\n grid-gap: 16px;\n gap: 16px;\n background: transparent;\n }\n .freemium-survey-components .nps-container .nps-scale button,\n.card-survey-style .nps-container .nps-scale button {\n border-radius: 50%;\n background: #ebeff3;\n }\n}\n.widget-survey-components .nps-container .nps-scale .button-container {\n background: transparent;\n}\n.widget-survey-components .nps-container .nps-scale .choices {\n flex-wrap: wrap;\n justify-content: center;\n grid-gap: 16px;\n gap: 16px;\n background: transparent;\n}\n.widget-survey-components .nps-container .nps-scale button {\n border-radius: 50%;\n background: #ebeff3;\n}");const l=t=>{const{type_info:{linear_scale:{button_style:r="highlighted",button_shape:o="rounded"}={},rating_presets:{start:s="Very unlikely",end:i="Very likely"}={},validation:{min:a},footer_text:u}}=t,c=e=>{switch(e){case e<=6:return"detractor";case e<=8:return"passive";default:return"promoter"}},l=n(Array.from({length:10+(0===a?1:0)},((e,n)=>n+a)));return e.createElement("div",{className:"nps-container","data-test-input":"nps"},e.createElement("div",{className:`nps-scale ${o} ${r}`},e.createElement("div",{className:"button-container"},e.createElement("span",{className:"negative-text",role:"note"},`${a} - ${s}`),e.createElement("span",{className:"positive-text",role:"note"},`${l.current[l.current.length-1]} - ${i}`),e.createElement("div",{className:"choices",role:"radiogroup","aria-required":!0},l.current.map((n=>e.createElement("button",{role:"radio","aria-checked":t.npsValue===n,key:n,"data-test-nps-choice":n,onClick:e=>{t.onChangeHandler(n)},className:`choice ${c(n)} ${t.npsValue===n&&"active"}`},n)))))),e.createElement("div",{className:"footer",role:"note"},u))},m=(e,n)=>(e.defaultProps=n,e);c('.freemium-survey-components .input-container,\n.freemium-survey-components .textarea-container {\n display: flex;\n flex-direction: column;\n width: 100%;\n border-radius: 4px;\n position: relative;\n}\n.freemium-survey-components label.input-label {\n display: inline-block;\n padding-bottom: 8px;\n padding-left: 2px;\n font-size: 0.75rem;\n font-weight: 400;\n}\n.freemium-survey-components label.required::after {\n content: "*";\n position: relative;\n top: 2px;\n font-weight: 500;\n font-size: 0.85rem;\n padding-left: 3px;\n color: #d72d30;\n}\n.freemium-survey-components .input-basic {\n width: 100%;\n display: flex;\n align-items: center;\n border-radius: 4px;\n border: 1px solid var(--default-brand-color);\n border: 1px solid var(--brand-color, var(--default-brand-color));\n transition: border-color 0.2s linear;\n background: #fff;\n}\n.freemium-survey-components .textarea-container .input-basic {\n flex-direction: column;\n align-items: unset;\n}\n.freemium-survey-components .input-basic.error {\n border: 1px solid #d72d30;\n}\n.freemium-survey-components .input-basic.error:hover {\n border: 1px solid #d72d30;\n}\n.freemium-survey-components .input-basic.error[focus-within] {\n box-shadow: none;\n}\n.freemium-survey-components .input-basic.error:focus-within {\n box-shadow: none;\n}\n.freemium-survey-components .input-basic:hover {\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n transition: 0.2s linear;\n}\n.freemium-survey-components .input-basic[focus-within] {\n border: 1px solid transparent;\n box-shadow: 0 0 0 2px var(--default-brand-color);\n box-shadow: 0 0 0 2px var(--brand-color, var(--default-brand-color));\n}\n.freemium-survey-components .input-basic:focus-within {\n border: 1px solid transparent;\n box-shadow: 0 0 0 2px var(--default-brand-color);\n box-shadow: 0 0 0 2px var(--brand-color, var(--default-brand-color));\n}\n.freemium-survey-components .input-basic[focus-within] .end-max-length {\n opacity: 1;\n}\n.freemium-survey-components .input-basic:focus-within .end-max-length {\n opacity: 1;\n}\n.freemium-survey-components .end-max-length {\n transition: opacity ease 0.2s;\n opacity: 0;\n padding: 0 8px;\n font-size: 0.75rem;\n color: #264966;\n}\n.freemium-survey-components .textarea-container .end-max-length {\n padding: 8px;\n align-self: flex-end;\n}\n.freemium-survey-components span.input-error {\n display: block;\n padding-left: 2px;\n padding-top: 4px;\n font-size: 0.9rem;\n color: #d72d30;\n}\n.freemium-survey-components input[type=text] {\n padding: 6px 12px;\n flex: 1;\n border: unset;\n height: 32px;\n font-size: 1rem;\n /* line-height: ${typography.input.text.lineHeight}; */\n border-radius: 4px;\n}\n.freemium-survey-components input[type=text],\n.freemium-survey-components textarea {\n outline: none;\n border: none;\n}\n.freemium-survey-components input[type=text]::-moz-placeholder {\n color: #92a2b2;\n font-weight: 400;\n font-size: 0.85rem;\n}\n.freemium-survey-components input[type=text]:-ms-input-placeholder {\n color: #92a2b2;\n font-weight: 400;\n font-size: 0.85rem;\n}\n.freemium-survey-components input[type=text]::placeholder {\n color: #92a2b2;\n font-weight: 400;\n font-size: 0.85rem;\n}\n.freemium-survey-components textarea {\n min-height: 116px;\n padding: 12px;\n flex: 1;\n border: unset;\n resize: none;\n font-size: 1rem;\n /* line-height: ${typography.input.text.lineHeight}; */\n border-radius: 4px;\n}\n.freemium-survey-components textarea::-moz-placeholder {\n color: #92a2b2;\n font-weight: 400;\n font-size: 0.85rem;\n}\n.freemium-survey-components textarea:-ms-input-placeholder {\n color: #92a2b2;\n font-weight: 400;\n font-size: 0.85rem;\n}\n.freemium-survey-components textarea::placeholder {\n color: #92a2b2;\n font-weight: 400;\n font-size: 0.85rem;\n}');const d=["RANGE","NPS","RADIO","DROPDOWN"],p={default:500,compact:500,cozy:400},f={isRequired:!1,showCount:!0,isErrored:!1,inline:!1,spellCheck:!1,autoFocusInput:!0},y=t(((t,o)=>{const s=n(null);r((()=>{t.autoFocusInput&&setTimeout((()=>{s.current?.focus()}),300+t.autoFocusDelay)}),[t.autoFocusInput]);const{inputStyle:i,style:a,className:u,showCount:c,isErrored:l,startLabel:m,isRequired:d,errorText:p,endLabel:f,maxLength:y=256,onChange:v,autoFocusInput:h,...x}=t;return e.createElement("div",{className:"input-container",style:a},t.label&&e.createElement("label",{className:"input-label "+(d?"required":"")},t.label),e.createElement("div",null,m&&e.createElement("div",{className:"start-label"},m),e.createElement("div",{className:`input-basic ${l?"error":""}${u||""}`},e.createElement("input",Object.assign({},x,{type:"text",autoComplete:"off",ref:s,style:i,onChange:e=>{e.target.value?.length>y||v?.(e)}})),c&&y>0&&e.createElement("div",{className:"end-max-length"},`${t.value&&t.value.length||0}/${y}`)),f&&e.createElement("div",{className:"end-label"},f)),l&&p&&e.createElement("span",{className:"input-error"},t.errorText))})),v=t(((t,o)=>{const s=n(null);r((()=>{t.autoFocusInput&&setTimeout((()=>{s.current?.focus()}),300+t.autoFocusDelay)}),[t.autoFocusInput]);const{inputStyle:i,style:a,className:u,showCount:c,maxLength:l=1500,startLabel:m,isRequired:d,autoFocusInput:p,onChange:f,...y}=t;return e.createElement(e.Fragment,null,e.createElement("div",{className:"textarea-container",style:a},t.label&&e.createElement("label",{className:"input-label "+(d?"required":"")},t.label),m&&e.createElement("div",{className:"start-label"},m),e.createElement("div",{className:`input-basic ${u||""}`},e.createElement("textarea",Object.assign({},y,{autoComplete:"off",ref:s,style:i,onChange:e=>{e.target.value?.length>l||f?.(e)}})),c&&l&&l>0&&e.createElement("div",{className:"end-max-length"},`${t.value&&t.value.length||0}/${l}`)),t.endLabel&&e.createElement("div",{className:"end-label"},t.endLabel)))})),h=m(y,f),x=m(v,f);c('.freemium-survey-components .checkbox-group {\n width: 100%;\n display: flex;\n grid-gap: 12px;\n gap: 12px;\n flex-direction: column;\n white-space: nowrap;\n flex-wrap: wrap;\n}\n.freemium-survey-components .icon-container {\n display: inline-block;\n flex: 0 0 12px;\n width: 12px;\n height: 12px;\n min-width: 12px;\n min-height: 12px;\n color: inherit;\n position: absolute;\n left: 1px;\n top: 2px;\n}\n.freemium-survey-components .tick-icon {\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n height: 100%;\n width: 100%;\n color: inherit;\n fill: currentColor;\n}\n.freemium-survey-components input[type=checkbox] {\n position: absolute;\n clip: rect(0px 0px 0px 0px);\n width: 0px;\n height: 0px;\n}\n.freemium-survey-components input[type=checkbox]:focus ~ .checkbox {\n /* box-shadow: ${pseudo.focus} 0px 0px 0px 2px; */\n box-shadow: var(--default-brand-color) 0px 0px 0px 2px;\n box-shadow: var(--brand-color, var(--default-brand-color)) 0px 0px 0px 2px;\n border-color: transparent;\n}\n.freemium-survey-components .checkbox-label {\n display: flex;\n align-items: baseline;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n text-align: left;\n opacity: 1;\n line-height: 1.2;\n cursor: pointer;\n font-size: 1rem;\n padding: 16px 24px;\n min-width: 200px;\n border: 1px solid #ebeff3;\n border-radius: 4px;\n white-space: pre-wrap;\n}\n.freemium-survey-components .checkbox-label:hover .checkbox {\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n box-shadow: var(--default-background-color) 0px 0px 0px 5px;\n box-shadow: var(--background-color, var(--default-background-color)) 0px 0px 0px 5px;\n}\n.freemium-survey-components .checkbox-label.disabled {\n opacity: 0.5;\n cursor: "not-allowed";\n}\n.freemium-survey-components .checkbox {\n transition: background-color ease-in 0.2s;\n min-width: 14px;\n min-height: 14px;\n min-height: 14px;\n max-height: 14px;\n border-radius: 2px;\n position: relative;\n margin-right: 16px;\n background-color: #fff;\n border: 1px solid;\n text-align: left;\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n}\n.freemium-survey-components .checkbox:hover {\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n box-shadow: var(--default-background-color) 0px 0px 0px 5px;\n box-shadow: var(--background-color, var(--default-background-color)) 0px 0px 0px 5px;\n}\n.freemium-survey-components input[type=checkbox]:checked ~ .checkbox {\n background-color: var(--default-brand-color);\n background-color: var(--brand-color, var(--default-brand-color));\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n}\n.freemium-survey-components input[type=checkbox]:checked ~ .checkbox:hover {\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n}\n.freemium-survey-components input[type=checkbox]:disabled ~ .checkbox:hover {\n box-shadow: unset;\n border-color: unset;\n}');const g=()=>e.createElement("svg",{id:"tick",className:"tick-icon",xmlns:"http://www.w3.org/2000/svg","aria-labelledby":"title",viewBox:"0 0 10 10"},e.createElement("path",{d:"M3 5.87c-.18666814.00267463-.36667109-.06932655-.5-.2L.21 3.41c-.1786328-.17863279-.24839684-.43899577-.1830127-.6830127.06538414-.24401694.25598306-.43461586.5-.5C.77100423 2.16160316 1.0313672 2.23136721 1.21 2.41L3 4.18 6.8.33c.27679776-.27455556.72320224-.27455556 1 0 .13696438.13025306.21450026.31098915.21450026.5S7.93696438 1.19974694 7.8 1.33L3.45 5.67c-.12082534.11896945-.28072735.19003701-.45.2Z",fill:"#fff",fillRule:"evenodd"})),b=({values:t=[],othersValue:s="",options:i,name:a,autoFocusGroup:u,autoFocusDelay:c,onChangeHandler:l,saveOthersValue:m,othersOption:d,othersRequired:p})=>{const[f,y]=o(!1),v=n(null);return r((()=>{u&&setTimeout((()=>{v.current?.focus()}),300+c)}),[u]),e.createElement("div",{className:"checkbox-group"},e.createElement("button",{ref:v,className:"autofocus-button","aria-hidden":!0}),i?.map(((n,r)=>e.createElement(w,{key:n.id,checked:t?.includes(n.value),name:n.value,id:n.id,onChange:(e,r)=>{if(r)l([...t||[],n.value]);else{const e=t.indexOf(n.value);e>-1&&t.splice(e,1),l([...t])}}},n.value))),d&&e.createElement(w,{key:"others",checked:f,name:"others",id:"others",onChange:(e,n)=>{if(y(n),n)l([...t,"others"]);else{const e=t.findIndex((e=>"others"===e));t.splice(e,1),l(t)}}},"Others"),f&&e.createElement(e.Fragment,null,e.createElement(h,{placeholder:"Enter your comment",value:s[a],onChange:e=>{m(a,e.target.value)},autoFocusDelay:10,label:""})))},w=m((t=>{const o=n(null);return r((()=>{t.autoFocus&&setTimeout((()=>{o.current?.focus()}),320)}),[]),e.createElement("label",{className:`checkbox-label ${t.disabled&&"disabled"}`},e.createElement("input",{ref:o,id:t.id,type:"checkbox",name:t.name,readOnly:t.readOnly,disabled:t.disabled,"aria-disabled":t.disabled,checked:t.checked,onChange:t.readOnly?()=>{}:e=>t.onChange(e,e.target.checked)}),e.createElement("div",{className:"checkbox"},t.checked&&e.createElement("div",{className:"icon-container"},e.createElement(g,null)," ")),e.createElement("div",null,t.children))}),{checked:!1});c('.freemium-survey-components .radio-group {\n display: flex;\n grid-gap: 12px;\n gap: 12px;\n white-space: nowrap;\n flex-direction: column;\n width: 100%;\n}\n.freemium-survey-components .radio {\n background-color: #fff;\n border: 1px solid;\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n transition: background-color ease-in 0.2s;\n min-width: 18px;\n max-width: 18px;\n min-height: 18px;\n max-height: 18px;\n border-radius: 50%;\n position: relative;\n margin-right: 16px;\n text-align: left;\n}\n.freemium-survey-components .radio:before {\n left: 3px;\n top: 3px;\n content: "";\n position: absolute;\n width: 10px;\n height: 10px;\n border-radius: 50%;\n transition: all ease-in 0.2s;\n background-color: #fff;\n}\n.freemium-survey-components .radio-label {\n display: flex;\n align-items: baseline;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n text-align: left;\n cursor: pointer;\n line-height: 1.2;\n font-size: 1rem;\n font-weight: 400;\n padding: 16px 24px;\n min-width: 200px;\n border: 1px solid #ebeff3;\n border-radius: 4px;\n white-space: pre-wrap;\n}\n.freemium-survey-components input[type=radio] {\n position: absolute;\n clip: rect(0, 0, 0, 0);\n width: 0px;\n height: 0px;\n}\n.freemium-survey-components input[type=radio]:focus ~ .radio {\n /* box-shadow: ${pseudo.focus} 0px 0px 0px 3px; */\n box-shadow: var(--default-brand-color) 0px 0px 0px 3px;\n box-shadow: var(--brand-color, var(--default-brand-color)) 0px 0px 0px 3px;\n border-color: transparent;\n}\n.freemium-survey-components input[type=radio]:checked ~ .radio:before {\n background-color: var(--default-brand-color);\n background-color: var(--brand-color, var(--default-brand-color));\n}\n.freemium-survey-components .radio-label:hover .radio {\n border-color: var(--default-brand-color);\n border-color: var(--brand-color, var(--default-brand-color));\n box-shadow: var(--default-background-color) 0px 0px 0px 5px;\n box-shadow: var(--background-color, var(--default-background-color)) 0px 0px 0px 5px;\n}');const k=({name:t,options:s,value:i,autoFocusGroup:a,autoFocusDelay:u,onChangeHandler:c,saveOthersValue:l,othersOption:m,othersRequired:d,othersValue:p})=>{const[f,y]=o(p??""),[v,x]=o(i),g=n(null);return r((()=>{a&&setTimeout((()=>{g.current?.focus()}),300+u)}),[a]),r((()=>{i||(y(""),x(null))}),[i]),r((()=>{v&&s.find((e=>e.value===v))&&v!==i&&c(v)}),[v]),e.createElement("div",{className:"radio-group",role:"radiogroup"},e.createElement("button",{ref:g,className:"autofocus-button","aria-hidden":!0,tabIndex:-1}),s?.map(((n,r)=>e.createElement(q,{key:n.value,value:n.value,name:t,onChange:e=>{x(e.currentTarget.value)},checked:v===n.value},n.value))),m&&e.createElement(q,{key:"others",value:"others",name:t,onChange:e=>{x("others")},checked:"others"===v},"Others"),"others"===v&&e.createElement(e.Fragment,null,e.createElement(h,{value:f,onChange:e=>y(e.target.value),placeholder:"Enter your comment",label:"",autoFocusDelay:10}),f!==i&&e.createElement(N,{inline:!0,disabled:d&&0===f.length,onClick:()=>{c("others"),l(t,f)}},"Next")))},q=m((t=>{const o=n(null);return r((()=>{t.autoFocus&&setTimeout((()=>{o.current?.focus()}),320)}),[]),e.createElement("label",{className:"radio-label"},e.createElement("input",{ref:o,type:"radio",name:t.name,value:t.value,checked:t.checked,onChange:t.onChange}),e.createElement("div",{className:"radio"}),e.createElement("div",null,t.children))}),{checked:!1,autoFocus:!1});c(".progressbar-container {\n width: 100%;\n height: 4px;\n position: fixed;\n top: 0;\n left: 0;\n z-index: 1;\n text-align: left;\n}\n\n.progressbar {\n transition: transform 0.3s linear 200ms;\n transform-origin: left;\n height: 100%;\n background-color: var(--default-brand-color);\n background-color: var(--brand-color, var(--default-brand-color));\n}");const E=n=>{const{totalSteps:t,completedSteps:r}=n;return e.createElement("div",{className:"progressbar-container"},e.createElement("div",{className:"progressbar",style:{width:(r>0?100/t:0)+"%",transform:`scaleX(${r})`}}))};c(".freemium-survey-components .action-button {\n width: auto;\n display: block;\n padding: 8px 16px;\n cursor: pointer;\n line-height: 1.5;\n text-align: center;\n font-weight: 600;\n letter-spacing: 0.3px;\n border-radius: 4px;\n white-space: nowrap;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n color: --default-button-text-color;\n color: var(--button-text-color, --default-button-text-color);\n background: var(--default-brand-color);\n background: var(--brand-color, var(--default-brand-color));\n border: 1px solid var(--default-brand-color);\n border: 1px solid var(--brand-color, var(--default-brand-color));\n border-radius: 4px;\n min-width: 200px;\n max-width: -webkit-fit-content;\n max-width: -moz-fit-content;\n max-width: fit-content;\n transform: translateY(0px);\n transition: transform ease 0.2s;\n}\n.freemium-survey-components .action-button:not([disabled]):hover {\n transform: translateY(-4px);\n}\n.freemium-survey-components .action-button[disabled] {\n cursor: not-allowed;\n opacity: 0.6;\n}\n.freemium-survey-components button:focus:not(:active) {\n /* box-shadow: 0 0 0 2px ${pseudo.focus}; */\n}\n\n@media (max-width: 550px) {\n .freemium-survey-components .action-button {\n min-width: 120px;\n }\n}\n.widget-survey-components .action-button {\n min-width: 120px;\n}\n\n.freemium-survey-components.mobile-preview .action-button {\n min-width: 120px;\n}");const _=()=>e.createElement(e.Fragment,null,"..."),C={LARGE:"large",MINI:"mini",NORMAL:"normal"},N=n=>{const{inline:t=!1,children:r,disabled:o,className:s="",htmlType:i,type:a="primary",onClick:u,size:c,overrideStyleClassName:l="",loading:m=!1,...d}=n;return e.createElement("button",Object.assign({style:t?{display:"inline-block"}:{},disabled:o,className:`action-button ${s} ${l}`,type:i,onClick:u},d),m?e.createElement(_,null):r)},B=()=>e.createElement("svg",{style:{display:"block"},width:"9",height:"14",viewBox:"0 0 10 16",fill:"none",xmlns:"http://www.w3.org/2000/svg"},e.createElement("path",{d:"M7.82585 6.15754C7.98999 6.32147 8.08232 6.54389 8.08252 6.77587L8.08252 7.2192C8.07983 7.45069 7.98788 7.6722 7.82585 7.83754L1.82919 13.8225C1.77496 13.8772 1.71044 13.9206 1.63936 13.9502C1.56827 13.9798 1.49203 13.9951 1.41502 13.9951C1.33801 13.9951 1.26177 13.9798 1.19068 13.9502C1.1196 13.9206 1.05508 13.8772 1.00085 13.8225L0.172521 12.9942C0.118197 12.941 0.0750381 12.8774 0.0455752 12.8073C0.0161124 12.7372 0.000937578 12.6619 0.000937585 12.5859C0.000937592 12.5098 0.0161125 12.4345 0.0455753 12.3644C0.0750381 12.2943 0.118197 12.2308 0.172521 12.1775L5.36419 6.99754L0.172522 1.81754C0.117847 1.76331 0.0744506 1.69879 0.0448352 1.62771C0.0152208 1.55662 -2.75162e-05 1.48038 -2.75094e-05 1.40337C-2.75027e-05 1.32636 0.0152208 1.25012 0.0448353 1.17904C0.0744507 1.10795 0.117847 1.04343 0.172522 0.989205L1.00086 0.172537C1.05508 0.117862 1.1196 0.0744661 1.19069 0.0448507C1.26177 0.0152353 1.33801 -1.20337e-05 1.41502 -1.2027e-05C1.49203 -1.20203e-05 1.56827 0.0152353 1.63936 0.0448507C1.71044 0.0744661 1.77496 0.117862 1.82919 0.172537L7.82585 6.15754Z",fill:"#6B6B6B"})),I=()=>e.createElement("svg",{style:{display:"block"},width:"9",height:"14",viewBox:"0 0 10 16",fill:"none",xmlns:"http://www.w3.org/2000/svg"},e.createElement("path",{d:"M0.256667 7.83755C0.0925257 7.67361 0.000204227 7.4512 0 7.21921V6.77588C0.00268801 6.5444 0.0946357 6.32289 0.256667 6.15755L6.25333 0.172549C6.30756 0.117874 6.37208 0.0744776 6.44316 0.0448625C6.51425 0.0152474 6.59049 0 6.6675 0C6.74451 0 6.82075 0.0152474 6.89184 0.0448625C6.96292 0.0744776 7.02744 0.117874 7.08167 0.172549L7.91 1.00088C7.96432 1.05411 8.00748 1.11764 8.03694 1.18776C8.06641 1.25787 8.08158 1.33316 8.08158 1.40922C8.08158 1.48527 8.06641 1.56056 8.03694 1.63067C8.00748 1.70079 7.96432 1.76432 7.91 1.81755L2.71833 6.99755L7.91 12.1775C7.96467 12.2318 8.00807 12.2963 8.03769 12.3674C8.0673 12.4385 8.08255 12.5147 8.08255 12.5917C8.08255 12.6687 8.0673 12.745 8.03769 12.8161C8.00807 12.8871 7.96467 12.9517 7.91 13.0059L7.08167 13.8225C7.02744 13.8772 6.96292 13.9206 6.89184 13.9502C6.82075 13.9799 6.74451 13.9951 6.6675 13.9951C6.59049 13.9951 6.51425 13.9799 6.44316 13.9502C6.37208 13.9206 6.30756 13.8772 6.25333 13.8225L0.256667 7.83755Z",fill:"#6B6B6B"})),S=({question:n,formValues:t,othersMeta:r,onChangeHandler:o,saveOthersValue:s,autoFocus:i,autoFocusDelay:a})=>{switch(n.type_info.question_type){case"RANGE":return e.createElement(l,{type_info:n.type_info,onChangeHandler:o,npsValue:t[n.name]});case"CHECKBOX":case"MULTI_SELECT":return e.createElement(b,{name:n.name,autoFocusGroup:i,values:t[n.name],othersValue:r[n.name],options:n.type_info.choices,onChangeHandler:o,saveOthersValue:s,othersOption:n.type_info.meta?.othersOption,othersRequired:n.type_info.meta?.othersRequired,autoFocusDelay:a});case"RADIO":case"DROPDOWN":return e.createElement(k,{autoFocusGroup:i,autoFocusDelay:a,name:n.name,onChangeHandler:o,saveOthersValue:s,options:n.type_info.choices,value:t[n.name],othersValue:r[n.name],othersOption:n.type_info.meta?.othersOption,othersRequired:n.type_info.meta?.othersRequired});case"INPUT":case"TEXT":return n.type_info?.meta?.readOnly?e.createElement("div",{className:"message-container"},n.type_info?.meta?.value):e.createElement("div",{className:"responsive-text-field"},e.createElement(h,{autoFocusInput:i,autoFocusDelay:a,label:"",isRequired:n.is_required,value:t[n.name]||"",placeholder:n.type_info?.meta?.placeholder??"",onChange:e=>o(e.target.value)}),e.createElement(x,{autoFocusInput:i,autoFocusDelay:a,label:"",isRequired:n.is_required,placeholder:n.type_info?.meta?.placeholder??"",value:t[n.name]||"",onChange:e=>o(e.target.value)}));case"PARAGRAPH":return e.createElement(x,{autoFocusInput:i,autoFocusDelay:a,label:"",isRequired:n.is_required,placeholder:n.type_info?.meta?.placeholder??"",value:t[n.name]||"",onChange:e=>o(e.target.value)});default:return console.error(`Question type ${n.type_info.question_type} not found`),null}},z=(e,n,t)=>{if(e){let r={"{{nps.rating}}":t};n&&(r={...r,...n});const o=new RegExp(Object.keys(r).join("|"),"gi");e=e.replace(o,(function(e){return r[e.toLowerCase()]}))}return e},O=e=>s((()=>{const n=JSON.parse(JSON.stringify(e)),t=[];return(n.question_details?.questions||[]).forEach((e=>{const n=e.type_info?.meta?.block;n&&(n.question_names||(n.question_names=[e.name]),t.push(n))})),{...n,meta:{...n.meta,blocks:t}}}),[e]);c(":root {\n --default-brand-color: #264966;\n --default-question-text-color: #000;\n --default-question-background-color: #fff;\n --default-background-color: #f8f8f8;\n --default-button-text-color: #fff;\n --default-secondary-button-text-color: #000;\n --default-input-placeholder-color: #92a2b1;\n --compact-widget-max-height: 560px;\n --default-widget-max-height: 400px;\n --cozy-widget-max-height: 380px;\n}\n\n.freemium-survey-components.card-survey-style {\n padding: 20px 0;\n}\n.freemium-survey-components.card-survey-style .freemium-survey-step-navigation {\n white-space: nowrap;\n border-radius: 3px;\n border: 1px solid #efefef;\n}\n.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button {\n width: 38px;\n text-align: -webkit-center;\n height: 38px;\n background-color: #fff;\n border: none;\n cursor: pointer;\n border-radius: 0 3px 3px 0;\n}\n.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button svg {\n transform: rotate(90deg);\n}\n.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button:first-of-type {\n border-right: 1px solid #efefef;\n border-radius: 3px 0 0 3px;\n}\n.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button:disabled {\n cursor: not-allowed;\n opacity: 0.5;\n}\n.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button:focus {\n position: relative;\n z-index: 1;\n}\n.freemium-survey-components.card-survey-style .question-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n text-align: center;\n max-width: 700px;\n margin: 0 auto;\n background: var(--default-question-background-color);\n background: var(--question-background-color, var(--default-question-background-color));\n border-radius: 4px;\n transition: transform 500ms ease 0ms, opacity 200ms ease 0ms;\n box-shadow: 0px 12px 15px rgba(18, 52, 77, 0.03);\n padding: 28px;\n grid-gap: 28px;\n gap: 28px;\n position: relative;\n height: -webkit-fit-content;\n height: -moz-fit-content;\n height: fit-content;\n transition: opacity 50ms ease-out;\n overflow: auto;\n}\n.freemium-survey-components.card-survey-style .hide-question-container {\n opacity: 0;\n}\n.freemium-survey-components.card-survey-style .question-text {\n font-size: 1rem;\n font-weight: 600;\n line-height: 1.8;\n width: 100%;\n text-align: left;\n color: var(--default-question-text-color);\n color: var(--question-text-color, var(--default-question-text-color));\n}\n.freemium-survey-components.card-survey-style .autofocus-button {\n border: none;\n width: 0;\n height: 0;\n opacity: 0;\n margin-top: -12px;\n margin-left: -12px;\n position: absolute;\n}\n.freemium-survey-components.card-survey-style .fade-enter .question-container {\n opacity: 0;\n transform: translateY(15px);\n}\n.freemium-survey-components.card-survey-style .fade-enter-active .question-container {\n opacity: 1;\n transform: translateY(0);\n}\n.freemium-survey-components.card-survey-style .fade-exit .question-container {\n opacity: 1;\n transform: translateY(0);\n}\n.freemium-survey-components.card-survey-style .fade-exit-active .question-container {\n opacity: 0.05;\n transform: translateY(-15px);\n}\n.freemium-survey-components.card-survey-style .fade-reverse-enter .question-container {\n opacity: 0;\n transform: translateY(-15px);\n}\n.freemium-survey-components.card-survey-style .fade-reverse-enter-active .question-container {\n opacity: 1;\n transform: translateY(0);\n}\n.freemium-survey-components.card-survey-style .fade-reverse-exit .question-container {\n opacity: 1;\n transform: translateY(0);\n}\n.freemium-survey-components.card-survey-style .fade-reverse-exit-active .question-container {\n opacity: 0.05;\n transform: translateY(15px);\n}\n.freemium-survey-components.card-survey-style .fade-enter-active .question-container,\n.freemium-survey-components.card-survey-style .fade-exit-active .question-container,\n.freemium-survey-components.card-survey-style .fade-reverse-enter-active .question-container,\n.freemium-survey-components.card-survey-style .fade-reverse-exit-active .question-container {\n transition: opacity 300ms, transform 300ms;\n}\n.freemium-survey-components.card-survey-style .question-footer {\n display: flex;\n grid-gap: 40px;\n gap: 40px;\n width: 100%;\n align-items: center;\n}\n.freemium-survey-components.card-survey-style .question-footer:empty {\n display: none;\n}\n.freemium-survey-components.card-survey-style .question-footer:only-child {\n margin-left: auto;\n}\n.freemium-survey-components.card-survey-style .action-buttons {\n display: flex;\n grid-gap: 20px;\n gap: 20px;\n flex-direction: row-reverse;\n width: 100%;\n}\n.freemium-survey-components.card-survey-style .action-buttons:empty {\n display: none;\n}\n.freemium-survey-components.card-survey-style .skip-button {\n font-weight: 500;\n cursor: pointer;\n background: transparent;\n border: none;\n min-width: 40px;\n padding: 8px 16px;\n border-radius: 4px;\n color: var(--default-secondary-button-text-color);\n color: var(--secondary-button-text-color, var(--default-secondary-button-text-color));\n letter-spacing: 0.05rem;\n line-height: 1.5;\n border: 1px solid transparent;\n transform: translateY(0px);\n transition: transform ease 0.2s;\n}\n.freemium-survey-components.card-survey-style .skip-button:hover {\n background-color: #f3f3f3;\n transform: translateY(-4px);\n}\n.freemium-survey-components.card-survey-style .next-button {\n color: var(--default-button-text-color);\n color: var(--button-text-color, var(--default-button-text-color));\n}\n.freemium-survey-components.card-survey-style .submit {\n max-width: 700px;\n text-align: left;\n background: transparent;\n box-shadow: none;\n color: var(--default-button-text-color);\n color: var(--button-text-color, var(--default-button-text-color));\n}\n.freemium-survey-components.card-survey-style .thankyou {\n display: flex;\n align-items: center;\n justify-content: center;\n grid-gap: 20px;\n gap: 20px;\n min-height: 180px;\n}\n.freemium-survey-components.card-survey-style .thankyou .heading {\n font-weight: 600;\n font-size: 28px;\n}\n.freemium-survey-components.card-survey-style .thankyou .text {\n white-space: pre-wrap;\n font-weight: 500;\n font-size: 0.875rem;\n line-height: 1.6;\n color: #12344d;\n width: 75%;\n}\n.freemium-survey-components.card-survey-style .thankyou .redirection-text {\n color: #929292;\n margin-bottom: 12px;\n font-weight: 300;\n}\n.freemium-survey-components.card-survey-style .thankyou .link {\n width: 100%;\n display: inline-block;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n color: #666;\n font-weight: 500;\n text-decoration: underline;\n}\n.freemium-survey-components.card-survey-style .responsive-text-field {\n width: 100%;\n}\n.freemium-survey-components.card-survey-style .responsive-text-field .textarea-container {\n display: none;\n}\n.freemium-survey-components.card-survey-style .message-container:empty {\n display: none;\n}\n\n@media (max-width: 550px) {\n div.freemium-survey-components.card-survey-style .responsive-text-field .input-container {\n display: none;\n }\n div.freemium-survey-components.card-survey-style .responsive-text-field .textarea-container {\n display: flex;\n }\n div.freemium-survey-components.card-survey-style .question-footer {\n flex-direction: column-reverse;\n grid-gap: 20px;\n gap: 20px;\n }\n div.freemium-survey-components.card-survey-style .freemium-survey-step-navigation {\n width: 100%;\n }\n div.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button {\n width: 50%;\n }\n div.freemium-survey-components.card-survey-style .action-buttons {\n flex-direction: column;\n width: 100%;\n }\n div.freemium-survey-components.card-survey-style .action-buttons button {\n max-width: unset;\n }\n div.freemium-survey-components.card-survey-style .action-button {\n max-width: unset;\n width: 100%;\n }\n div.freemium-survey-components.card-survey-style .thankyou .text {\n width: auto;\n }\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .responsive-text-field .input-container {\n display: none;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .responsive-text-field .textarea-container {\n display: flex;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .question-footer {\n flex-direction: column-reverse;\n grid-gap: 20px;\n gap: 20px;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .freemium-survey-step-navigation {\n width: 100%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .freemium-survey-step-navigation .navigation-button {\n width: 50%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .action-buttons {\n flex-direction: column;\n width: 100%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .action-buttons button {\n max-width: unset;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .action-button {\n max-width: unset;\n width: 100%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .thankyou .text {\n width: auto;\n}\n\n.freemium-survey-components.mobile-preview .thankyou .text {\n width: unset;\n}");const T=({thankYouQuestion:n,preview:t,placeholders:o,npsValue:s})=>(r((()=>{t||n.type_info.meta?.redirectUrl&&setTimeout((()=>{window.location.href=n.type_info.meta?.redirectUrl}),n.type_info.meta?.redirectDelay??1e4)}),[]),e.createElement("div",{className:"question-container thankyou"},e.createElement("div",{className:"heading"},"Thank you!"),e.createElement("div",{className:"text",dangerouslySetInnerHTML:{__html:z(n.text,o,s)}}),n.type_info.meta?.redirectUrl&&e.createElement("div",{style:{width:"100%"}},e.createElement("div",{className:"redirection-text"},"You will be redirected to the below URL automatically in"," ",n.type_info.meta?.redirectDelay," seconds.",e.createElement("br",null)),e.createElement("a",{className:"link",href:n.type_info.meta?.redirectUrl},n?.type_info.meta?.redirectUrl)))),Q=({currentBlockIndex:n,currentBlockIndexOfBlocksWithQns:t,blocksWithQns:r,blocks:o,setHorizontalScrollUnits:s,preventQuestionAnimation:i,tempCurrentBlockIndexOfBlocksWithQns:a,setReverse:u,reverse:c})=>e.createElement("div",{className:"freemium-survey-step-navigation","data-navigation-element":"1"},e.createElement("button",{disabled:0==t.current,className:"navigation-button",onClick:()=>{c?(t.current=Math.max(t.current-1,0),n.current=o.findIndex((e=>e.name===r[t.current].name))):(a.current=Math.max(t.current-1,0),n.current=o.findIndex((e=>e.name===r[a.current].name))),i.current=!1,u(!0),s(t.current)}},e.createElement(I,null)),e.createElement("button",{className:"navigation-button",disabled:t.current>=r.length-1,onClick:()=>{i.current=!1,c?a.current=Math.min(t.current+1,r.length-1):t.current=Math.min(t.current+1,r.length-1),u(!1),s(t.current)}},e.createElement(B,null))),F=({widget:n,surveyStyle:t,formValues:r,blocksWithQns:o,blocks:s,thankYouQuestion:i,currentBlockIndexOfBlocksWithQns:a,currentBlockIndexOfBlocks:u,currentEditingBlock:c,isSubmitting:l,isValuesCommitted:m,isCurrentBlockFinal:p,setHorizontalScrollUnits:f,handleFormValues:y,skipBlock:v,setIsSubmitting:h,onSubmit:x,setIsSurveyCompleted:g,preventQuestionAnimation:b,preview:w,closePreview:k,setReverse:q,tempCurrentBlockIndexOfBlocksWithQns:E,question:_,reverse:C,othersMeta:B,...I})=>{const S=I.blockIndex??a.current,z=()=>!d.includes(_.type_info.question_type)&&!p(),O=()=>"RANGE"!==_.type_info.question_type&&!_.required&&!p(),T=()=>("DROPDOWN"===_.type_info.question_type&&!_.required&&r[_.name],!1),F=()=>p()&&(n||"standard"!==t),R="MULTI_SELECT"===c.current.question.type_info.question_type&&r[c.current.question.name]?.includes("others")&&(!B[c.current.question.name]||""===B[c.current.question.name]);return e.createElement("div",{className:"question-footer"},!(!n&&"standard"===t||0===S&&void 0===r[_.name]||0===a.current&&!C)&&e.createElement(Q,{currentBlockIndex:u,currentBlockIndexOfBlocksWithQns:a,blocksWithQns:o,blocks:s,setHorizontalScrollUnits:f,preventQuestionAnimation:b,setReverse:q,tempCurrentBlockIndexOfBlocksWithQns:E,reverse:C}),(z()||T()||O()||F())&&e.createElement("div",{className:"action-buttons"},z()&&e.createElement(N,{onClick:()=>{q(!1),y(o[S],null,!0)},disabled:c.current.question.required&&(!r[c.current.question.name]||Array.isArray(r[c.current.question.name])&&0===r[c.current.question.name].length)||c.current.question.type_info.meta?.othersRequired&&R,className:"next-button"},"Next"),O()&&e.createElement("button",{className:"skip-button",onClick:()=>{q(!1),v(_)}},"Skip"),F()&&e.createElement("div",{className:"submit"},e.createElement(N,{disabled:(c.current.question.required||c.current.question.type_info.pivot_question)&&(null==r[c.current.question.name]||0===r[c.current.question.name]?.length)||c.current.question.type_info.meta?.othersRequired&&R||l,onClick:()=>{h(!0),x({...r,others_meta:B},(()=>{i?.type_info.meta?.skipThankYouPage?w?setTimeout((()=>{k?.()}),300):window.location.href=i?.type_info.meta?.redirectUrl:g(!0)}))}},l?"Submitting":"Submit survey")),T()&&e.createElement("button",{className:"skip-button",onClick:()=>{q(!1),c.current=o[S],u.current=s.findIndex((e=>e.name===o[S].name)),v(_)}},"Clear selection")))},R=({survey:t,surveyStyle:s="standard",placeholders:u,onSubmit:c,widget:l,npsValue:m,preview:p,mobilePreview:f,closePreview:y})=>{const v=t.question_details?.questions||[],h=t.meta?.blocks||[],[x,g]=o(null),[b,w]=o({}),[k,q]=o(!1),[_,C]=o([]),[N,B]=o(0),[I,O]=o(!1),[Q,R]=o(null),[L,V]=o({}),Y=n(null),$=n(null),U=n(-1),A=n(null),M=n(0),D=n(0),H=n(!1),W=n([]),P=e.useRef(!!m&&"card"===s),j=n(null),G=n(0),[X,K]=o(!1);r((()=>{h&&(j.current=h.find((e=>"TY"===e.name)),g(h.filter((e=>"TY"!==e.name))))}),[h]),r((()=>{D.current=G.current,B(N+1)}),[X]),r((()=>{if(x)if($.current=v.find((e=>e.type_info?.pivot_question))??v.find((e=>"RANGE"===e.type_info?.question_type))??v[0],null!=m){U.current=m;const e=v.find((e=>e.name===x[0].question_names[0]));Y.current={...x[0],question:e},W.current=[...W.current,{...x[0],question:e}],C(W.current),w({Q_1:m})}else if(!Y.current&&x.length>0)return Y.current=x[0],void J(x[0])}),[x,m]),e.useEffect((()=>{_.length&&(W.current=_,D.current=_.length-1),B(_.length-1)}),[_]),r((()=>{Object.keys(b).length>0&&Y.current.question&&(d.includes(Y.current.question.type_info.question_type)||H.current)&&!Z()&&(m&&1==_.length?setTimeout((()=>{ee()}),1500):ee())}),[b]),r((()=>{if(null!=b?.[$.current?.name])if(j.current?.is_based_on_rating){const e=$.current?.type_info?.choices[b?.[$.current?.name]-$.current?.type_info?.validation?.min??0]?.dependent_question_names,n=j.current?.question_names.find((n=>e?.includes(n))),t=v.find((e=>e.name===n));R(t)}else{const e=v.find((e=>e.name==j.current?.question_names[0]));R(e)}}),[b?.[$.current?.name]]);const Z=()=>(M.current===x.length-1||"end"===Y.current.branchOption)&&D.current===_.length-1,J=e=>{let n={};if(e.is_based_on_rating){const t=$.current?.type_info?.choices[b?.[$.current?.name]-$.current?.type_info?.validation?.min??0]?.dependent_question_names,r=e.question_names.find((e=>t?.includes(e)));n=v.find((e=>e.name===r))}else n=v.find((n=>n.name===e.question_names[0]));Y.current.question=n;W.current.find((e=>e.question.name===n.name))?(B(N+1),D.current+=1):C([...W.current,{...e,question:n}])},ee=()=>{if(Z())q(!0);else{if(Y.current.nextBlock)M.current=x.findIndex((e=>e.name===Y.current.nextBlock));else if(Y.current.question.type_info?.meta?.branches){const e=Y.current.question.type_info?.meta?.branches,n=b[Y.current.question.name];let t;if(t="RANGE"===Y.current.question.type_info.question_type?e.find((e=>n>=e.min&&n<=e.max)):e.find((e=>n===e.value)),t?.nextBlock){if("TY"===t.nextBlock)return void q(!0);M.current=x.findIndex((e=>e.name===t.nextBlock))}else M.current+=1}else M.current+=1;Y.current=x[M.current],J(x[M.current])}},ne=(e,n,t)=>{if(P.current=!1,t){if(H.current=!0,null!=b[e.question.name]&&e.name!==_[_.length-1].name){const[t,r]=(e=>{const n=_.findIndex((n=>n.name===e.name)),t=_.slice(0,n+1),r=t.reduce(((e,n)=>(e[n.question.name]=b[n.question.name],e)),{});return M.current=x.findIndex((n=>n.name===e.name)),[t,r]})(e);w({...r,...null!=n&&{[e.question.name]:n}}),W.current=t}else w({...b,...null!=n&&{[e.question.name]:n}});$?.current?.name==e?.question?.name&&(U.current=n)}else w({...b,...null!=n&&{[e.question.name]:n}})};if(!Y.current||!Y.current.question)return null;const te=_[Math.min(D.current??_.length-1,_.length-1)];return e.createElement("div",{className:`freemium-survey-components ${f?"mobile-preview":""} ${s}-survey-style`,id:"freemium-survey"},e.createElement(E,{totalSteps:x.length,completedSteps:M.current+(k?1:0)}),e.createElement(i,{mode:"out-in"},e.createElement(a,{key:D.current+String(k),addEndListener:(e,n)=>{e.addEventListener("transitionend",n,!1)},classNames:X?"fade-reverse":"fade"},e.createElement("div",{className:"questions"},k?e.createElement(T,{thankYouQuestion:Q,preview:p,placeholders:u,npsValue:U.current}):e.createElement("div",{ref:A,id:`${te.question.name}`,className:`question-container ${l||"card"===s}`,"data-test-question-name":te.question.name},e.createElement("div",{className:"question-text",dangerouslySetInnerHTML:{__html:z(te.question.text,u,U.current)},title:`question-${D.current}`,role:"heading","aria-level":1}),e.createElement("div",{onTransitionEndCapture:e=>e.stopPropagation(),style:{width:"100%"}},e.createElement(S,{question:te.question,formValues:b,othersMeta:L,autoFocus:!0,autoFocusDelay:"standard"===s?350:0,saveOthersValue:(e,n)=>{V({...L,[e]:n})},onChangeHandler:e=>{H.current=!1,M.current=x.findIndex((e=>e.name===te.name)),Y.current=te,K(!1),ne(te,e,d.includes(te.question.type_info.question_type)&&!Z())}})),e.createElement(F,{question:te.question,widget:l,surveyStyle:s,formValues:b,othersMeta:L,blocksWithQns:_,blocks:x,thankYouQuestion:Q,currentBlockIndexOfBlocksWithQns:D,reverse:X,setReverse:K,currentBlockIndexOfBlocks:M,currentEditingBlock:Y,isSubmitting:I,isValuesCommitted:H,isCurrentBlockFinal:Z,setHorizontalScrollUnits:B,handleFormValues:ne,skipBlock:e=>{H.current=!0,delete b[e.name],w({...b})},setIsSubmitting:O,onSubmit:c,setIsSurveyCompleted:q,preventQuestionAnimation:P,preview:p,closePreview:y,tempCurrentBlockIndexOfBlocksWithQns:G}))))))};c(":root {\n --default-brand-color: #264966;\n --default-question-text-color: #000;\n --default-question-background-color: #fff;\n --default-background-color: #f8f8f8;\n --default-button-text-color: #fff;\n --default-secondary-button-text-color: #000;\n --default-input-placeholder-color: #92a2b1;\n}\n\n.freemium-survey-components.widget-survey-components .freemium-survey-step-navigation {\n white-space: nowrap;\n border-radius: 3px;\n border: 1px solid #efefef;\n}\n.freemium-survey-components.widget-survey-components .freemium-survey-step-navigation .navigation-button {\n width: 38px;\n text-align: -webkit-center;\n height: 38px;\n background-color: #fff;\n border: none;\n cursor: pointer;\n border-radius: 0 3px 3px 0;\n}\n.freemium-survey-components.widget-survey-components .freemium-survey-step-navigation .navigation-button:first-of-type {\n border-right: 1px solid #efefef;\n border-radius: 3px 0 0 3px;\n}\n.freemium-survey-components.widget-survey-components .freemium-survey-step-navigation .navigation-button:disabled {\n cursor: not-allowed;\n opacity: 0.5;\n}\n.freemium-survey-components.widget-survey-components .freemium-survey-step-navigation .navigation-button:focus {\n position: relative;\n z-index: 1;\n}\n.freemium-survey-components.widget-survey-components .question-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n text-align: center;\n max-width: 700px;\n margin: 0 auto;\n border-radius: 4px;\n box-shadow: 0px 12px 15px rgba(18, 52, 77, 0.03);\n padding: 28px;\n grid-gap: 28px;\n gap: 28px;\n position: relative;\n overflow: auto;\n}\n.freemium-survey-components.widget-survey-components .hide-question-container {\n opacity: 0;\n}\n.freemium-survey-components.widget-survey-components .question-text {\n font-size: 1rem;\n font-weight: 600;\n line-height: 1.8;\n width: 100%;\n text-align: left;\n color: var(--default-question-text-color);\n color: var(--question-text-color, var(--default-question-text-color));\n}\n.freemium-survey-components.widget-survey-components .autofocus-button {\n border: none;\n width: 0;\n height: 0;\n opacity: 0;\n margin-top: -12px;\n margin-left: -12px;\n position: absolute;\n}\n.freemium-survey-components.widget-survey-components .fade-enter {\n opacity: 1;\n transform: translateX(80px);\n position: absolute;\n}\n.freemium-survey-components.widget-survey-components .fade-enter-active {\n position: absolute;\n opacity: 1;\n transform: translateX(0);\n}\n.freemium-survey-components.widget-survey-components .fade-enter-done {\n position: absolute;\n}\n.freemium-survey-components.widget-survey-components .fade-exit {\n opacity: 0.05;\n pointer-events: none;\n transform: translateX(0);\n}\n.freemium-survey-components.widget-survey-components .fade-exit-active {\n pointer-events: none;\n opacity: 0;\n transform: translateX(-80px);\n}\n.freemium-survey-components.widget-survey-components .fade-reverse-enter {\n opacity: 0;\n position: absolute;\n transform: translateX(-80px);\n}\n.freemium-survey-components.widget-survey-components .fade-reverse-enter-active {\n opacity: 1;\n position: absolute;\n transform: translateX(0);\n}\n.freemium-survey-components.widget-survey-components .fade-reverse-exit {\n opacity: 0.05;\n transform: translateX(0);\n}\n.freemium-survey-components.widget-survey-components .fade-reverse-exit-active {\n opacity: 0;\n transform: translateX(80px);\n}\n.freemium-survey-components.widget-survey-components .fade-enter-active,\n.freemium-survey-components.widget-survey-components .fade-reverse-enter-active {\n transition: opacity 300ms, transform 300ms;\n}\n.freemium-survey-components.widget-survey-components .fade-reverse-exit-active,\n.freemium-survey-components.widget-survey-components .fade-exit-active {\n transition: opacity 200ms, transform 200ms;\n}\n.freemium-survey-components.widget-survey-components .question-footer {\n display: flex;\n grid-gap: 40px;\n gap: 40px;\n width: 100%;\n align-items: center;\n}\n.freemium-survey-components.widget-survey-components .question-footer:empty {\n display: none;\n}\n.freemium-survey-components.widget-survey-components .question-footer:only-child {\n margin-left: auto;\n}\n.freemium-survey-components.widget-survey-components .action-buttons {\n display: flex;\n grid-gap: 20px;\n gap: 20px;\n flex-direction: row-reverse;\n width: 100%;\n}\n.freemium-survey-components.widget-survey-components .action-buttons:empty {\n display: none;\n}\n.freemium-survey-components.widget-survey-components .skip-button {\n font-weight: 500;\n cursor: pointer;\n background: transparent;\n border: none;\n min-width: 40px;\n padding: 8px 16px;\n border-radius: 4px;\n color: var(--default-secondary-button-text-color);\n color: var(--secondary-button-text-color, var(--default-secondary-button-text-color));\n letter-spacing: 0.05rem;\n line-height: 1.5;\n border: 1px solid transparent;\n transform: translateY(0px);\n transition: transform ease 0.2s;\n}\n.freemium-survey-components.widget-survey-components .skip-button:hover {\n background-color: #f3f3f3;\n transform: translateY(-4px);\n}\n.freemium-survey-components.widget-survey-components .next-button {\n color: var(--default-button-text-color);\n color: var(--button-text-color, var(--default-button-text-color));\n}\n.freemium-survey-components.widget-survey-components .submit {\n max-width: 700px;\n text-align: left;\n background: transparent;\n box-shadow: none;\n color: var(--default-button-text-color);\n color: var(--button-text-color, var(--default-button-text-color));\n}\n.freemium-survey-components.widget-survey-components .thankyou {\n display: flex;\n align-items: center;\n justify-content: center;\n grid-gap: 20px;\n gap: 20px;\n min-height: 180px;\n}\n.freemium-survey-components.widget-survey-components .thankyou .heading {\n font-weight: 600;\n font-size: 28px;\n}\n.freemium-survey-components.widget-survey-components .thankyou .text {\n white-space: pre-wrap;\n font-weight: 500;\n font-size: 0.875rem;\n line-height: 1.6;\n color: #12344d;\n width: 75%;\n}\n.freemium-survey-components.widget-survey-components .thankyou .redirection-text {\n color: #929292;\n margin-bottom: 12px;\n font-weight: 300;\n}\n.freemium-survey-components.widget-survey-components .thankyou .link {\n width: 100%;\n display: inline-block;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n color: #666;\n font-weight: 500;\n text-decoration: underline;\n}\n.freemium-survey-components.widget-survey-components .responsive-text-field {\n width: 100%;\n}\n.freemium-survey-components.widget-survey-components .responsive-text-field .textarea-container {\n display: none;\n}\n.freemium-survey-components.widget-survey-components .message-container:empty {\n display: none;\n}\n\n@media (max-width: 550px) {\n div.freemium-survey-components.card-survey-style .responsive-text-field .input-container {\n display: none;\n }\n div.freemium-survey-components.card-survey-style .responsive-text-field .textarea-container {\n display: flex;\n }\n div.freemium-survey-components.card-survey-style .question-footer {\n flex-direction: column-reverse;\n grid-gap: 20px;\n gap: 20px;\n }\n div.freemium-survey-components.card-survey-style .freemium-survey-step-navigation {\n width: 100%;\n }\n div.freemium-survey-components.card-survey-style .freemium-survey-step-navigation .navigation-button {\n width: 50%;\n }\n div.freemium-survey-components.card-survey-style .action-buttons {\n flex-direction: column;\n width: 100%;\n }\n div.freemium-survey-components.card-survey-style .action-buttons button {\n max-width: unset;\n }\n div.freemium-survey-components.card-survey-style .action-button {\n max-width: unset;\n width: 100%;\n }\n div.freemium-survey-components.card-survey-style .thankyou .text {\n width: auto;\n }\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .responsive-text-field .input-container {\n display: none;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .responsive-text-field .textarea-container {\n display: flex;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .question-footer {\n flex-direction: column-reverse;\n grid-gap: 20px;\n gap: 20px;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .freemium-survey-step-navigation {\n width: 100%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .freemium-survey-step-navigation .navigation-button {\n width: 50%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .action-buttons {\n flex-direction: column;\n width: 100%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .action-buttons button {\n max-width: unset;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .action-button {\n max-width: unset;\n width: 100%;\n}\ndiv.freemium-survey-components.card-survey-style.mobile-preview .thankyou .text {\n width: auto;\n}\n\n.widget-survey-components.compact-style .freemium-survey-step-navigation {\n padding: 0 2px;\n margin-left: 4px;\n box-shadow: 0px 0px 6px #eee;\n margin-top: 4px;\n}\n.widget-survey-components.compact-style .nps-container .footer {\n padding-top: 12px;\n}\n.widget-survey-components.compact-style .nps-container .choices {\n grid-gap: 12px;\n gap: 12px;\n}\n\n.widget-survey-components,\n.card-survey-style {\n display: flex;\n flex-direction: column;\n grid-gap: 28px;\n gap: 28px;\n flex-grow: 1;\n font-size: 0.875rem;\n position: relative;\n overflow: hidden;\n}\n.widget-survey-components .questions,\n.card-survey-style .questions {\n min-width: 100%;\n max-width: 100%;\n background: var(--default-question-background-color);\n background: var(--question-background-color, var(--default-question-background-color));\n position: relative;\n display: flex;\n justify-content: row;\n align-items: flex-end;\n height: 100%;\n transition: height 300ms ease;\n}\n.widget-survey-components .question-text,\n.card-survey-style .question-text {\n width: 100%;\n text-align: left;\n}\n.widget-survey-components .focus-lock,\n.card-survey-style .focus-lock {\n width: 100%;\n}\n.widget-survey-components .question-container,\n.card-survey-style .question-container {\n height: -webkit-fit-content;\n height: -moz-fit-content;\n height: fit-content;\n max-height: 100%;\n min-width: 100%;\n max-width: 100%;\n margin-bottom: 0;\n padding: 28px;\n grid-gap: 28px;\n gap: 28px;\n flex-grow: 1;\n align-self: flex-end;\n margin-top: auto;\n position: absolute;\n}\n.widget-survey-components .question-footer,\n.card-survey-style .question-footer {\n margin: 0px auto;\n justify-content: space-between;\n position: -webkit-sticky;\n position: sticky;\n bottom: -28px;\n padding: 20px 0;\n background: var(--default-question-background-color);\n background: var(--question-background-color, var(--default-question-background-color));\n}\n.widget-survey-components .submit,\n.card-survey-style .submit {\n padding-bottom: 0;\n margin: unset;\n}\n.widget-survey-components .nps-container .footer,\n.card-survey-style .nps-container .footer {\n padding-top: 12px;\n}\n.widget-survey-components .nps-container .widget .choices,\n.card-survey-style .nps-container .widget .choices {\n grid-gap: 8px;\n gap: 8px;\n}\n.widget-survey-components .radio-group,\n.card-survey-style .radio-group {\n width: 100%;\n overflow: auto;\n}\n.widget-survey-components .checkbox-group,\n.card-survey-style .checkbox-group {\n width: 100%;\n overflow: auto;\n}\n\ndiv.widget-survey-components .question-container {\n box-shadow: none;\n border-radius: 0;\n}\ndiv.widget-survey-components .question-text {\n font-size: 0.875rem;\n}\ndiv.widget-survey-components .progressbar-container {\n position: absolute;\n}\ndiv.widget-survey-components .progressbar-container .progressbar {\n border-radius: 3px 0 0 0;\n}\ndiv.widget-survey-components .textarea-container .end-max-length {\n padding: 4px;\n}\ndiv.widget-survey-components .responsive-text-field .input-container {\n display: none;\n}\ndiv.widget-survey-components .responsive-text-field .textarea-container {\n display: flex;\n}\ndiv.widget-survey-components div.thankyou {\n min-height: unset;\n}\ndiv.widget-survey-components div.thankyou .text {\n width: 85%;\n}\ndiv.widget-survey-components div.thankyou svg {\n width: 140px;\n height: 120px;\n}\n\ndiv.widget-survey-components.default-style .freemium-survey-step-navigation {\n margin: 0;\n}\ndiv.widget-survey-components.default-style .question-container {\n padding: 28px;\n}\ndiv.widget-survey-components.default-style .question-footer {\n justify-content: space-between;\n}\ndiv.widget-survey-components.default-style .nps-container .footer {\n padding-top: 12px;\n}\ndiv.widget-survey-components.default-style .nps-container .choices {\n flex-wrap: unset;\n grid-gap: 12px;\n gap: 12px;\n}\ndiv.widget-survey-components.default-style .action-button {\n line-height: 1.2;\n}\ndiv.widget-survey-components.default-style .radio-group {\n flex-direction: column;\n flex-wrap: nowrap;\n overflow: auto;\n}\ndiv.widget-survey-components.default-style .radio-group .radio-label {\n padding: 12px 16px;\n min-width: 160px;\n font-size: 0.9rem;\n}\ndiv.widget-survey-components.default-style .checkbox-group {\n flex-direction: row;\n flex-wrap: wrap;\n}\ndiv.widget-survey-components.default-style .checkbox-group .checkbox-label {\n padding: 12px 16px;\n min-width: 160px;\n font-size: 0.9rem;\n}\ndiv.widget-survey-components.default-style textarea {\n min-height: 84px;\n}\ndiv.widget-survey-components.default-style .end-max-length {\n font-size: 0.8rem;\n font-weight: 300;\n padding: 4px;\n}\n\n.widget-survey-components.cozy-style .freemium-survey-step-navigation {\n margin: 0;\n}\n.widget-survey-components.cozy-style .question-text {\n font-size: 1rem;\n}\n.widget-survey-components.cozy-style .question-text.nps {\n text-align: center;\n width: 60%;\n min-width: 600px;\n margin: auto;\n}\n.widget-survey-components.cozy-style .question-container {\n padding: 12px 28px;\n}\n.widget-survey-components.cozy-style .question-footer {\n justify-content: space-between;\n}\n.widget-survey-components.cozy-style .nps-container {\n grid-gap: 44px;\n gap: 44px;\n}\n.widget-survey-components.cozy-style .nps-container .widget {\n display: flex;\n justify-content: center;\n}\n.widget-survey-components.cozy-style .nps-container .button-container {\n width: 60%;\n min-width: 600px;\n margin: 0 auto;\n}\n.widget-survey-components.cozy-style .nps-container .button-container .choices {\n justify-content: space-around;\n}\n.widget-survey-components.cozy-style .nps-container .footer {\n padding-top: 8px;\n}\n.widget-survey-components.cozy-style .action-button {\n line-height: 1.2;\n}\n.widget-survey-components.cozy-style .radio-group {\n flex-direction: row;\n flex-wrap: wrap;\n}\n.widget-survey-components.cozy-style .radio-group .radio-label {\n padding: 12px 16px;\n min-width: 160px;\n font-size: 0.9rem;\n}\n.widget-survey-components.cozy-style .checkbox-group {\n flex-direction: row;\n flex-wrap: wrap;\n}\n.widget-survey-components.cozy-style .checkbox-group .checkbox-label {\n padding: 12px 16px;\n min-width: 160px;\n font-size: 0.9rem;\n}\n.widget-survey-components.cozy-style textarea {\n min-height: 60px;\n}\n.widget-survey-components.cozy-style .end-max-length {\n font-size: 0.8rem;\n font-weight: 300;\n padding: 4px;\n}\n\n.freemium-survey-components.mobile-preview .thankyou .text {\n width: unset;\n}");const L=({thankYouQuestion:n,preview:t,placeholders:o,npsValue:s,setBlockElementRef:i},a)=>(r((()=>{t||n.type_info.meta?.redirectUrl&&setTimeout((()=>{window.location.href=n.type_info.meta?.redirectUrl}),n.type_info.meta?.redirectDelay??1e4)}),[]),e.createElement(e.Fragment,null,e.createElement("div",{className:"heading"},"Thank you!"),e.createElement("div",{className:"text",dangerouslySetInnerHTML:{__html:z(n.text,o,s)}}),n.type_info.meta?.redirectUrl&&e.createElement("div",{style:{width:"100%"}},e.createElement("div",{className:"redirection-text"},"You will be redirected to the below URL automatically in"," ",n.type_info.meta?.redirectDelay," seconds.",e.createElement("br",null)),e.createElement("a",{className:"link",href:n.type_info.meta?.redirectUrl},n?.type_info.meta?.redirectUrl)))),V=({currentBlockIndexOfBlocks:n,currentBlockIndexOfBlocksWithQns:t,blocksWithQns:r,blocks:o,setHorizontalScrollUnits:s,preventQuestionAnimation:i,tempCurrentBlockIndexOfBlocksWithQns:a,setReverse:u,reverse:c})=>e.createElement("div",{className:"freemium-survey-step-navigation","data-navigation-element":"1"},e.createElement("button",{disabled:0==t.current,className:"navigation-button",onClick:()=>{c?(t.current=Math.max(t.current-1,0),n.current=o.findIndex((e=>e.name===r[t.current].name))):(a.current=Math.max(t.current-1,0),n.current=o.findIndex((e=>e.name===r[a.current].name))),i.current=!1,u(!0),s(t.current)}},e.createElement(I,null)),e.createElement("button",{className:"navigation-button",disabled:t.current>=r.length-1,onClick:()=>{i.current=!1,c?a.current=Math.min(t.current+1,r.length-1):t.current=Math.min(t.current+1,r.length-1),u(!1),s(t.current)}},e.createElement(B,null))),Y=({widget:n,widgetStyle:t,surveyStyle:r,formValues:o,blocksWithQns:s,blocks:i,thankYouQuestion:a,currentBlockIndexOfBlocksWithQns:u,currentBlockIndexOfBlocks:c,currentEditingBlock:l,isSubmitting:m,isValuesCommitted:p,isCurrentBlockFinal:f,setHorizontalScrollUnits:y,handleFormValues:v,skipBlock:h,setIsSubmitting:x,onSubmit:g,setIsSurveyCompleted:b,preventQuestionAnimation:w,preview:k,closePreview:q,setReverse:E,tempCurrentBlockIndexOfBlocksWithQns:_,question:C,reverse:B,othersMeta:I,...S})=>{const z=S.blockIndex??u.current,O=()=>!d.includes(C.type_info.question_type)&&!f(),T=()=>"RANGE"!==C.type_info.question_type&&!C.required&&!f(),Q=()=>("DROPDOWN"===C.type_info.question_type&&!C.required&&o[C.name],!1),F=()=>f()&&(n||"standard"!==r),R="MULTI_SELECT"===l.current.question.type_info.question_type&&o[l.current.question.name]?.includes("others")&&(!I[l.current.question.name]||""===I[l.current.question.name]);return e.createElement("div",{className:"question-footer"},!(!n&&"standard"===r||0===z&&void 0===o[C.name]||"compact"===t||0===u.current&&!B)&&e.createElement(V,{currentBlockIndexOfBlocks:c,currentBlockIndexOfBlocksWithQns:u,blocksWithQns:s,blocks:i,setHorizontalScrollUnits:y,preventQuestionAnimation:w,setReverse:E,tempCurrentBlockIndexOfBlocksWithQns:_,reverse:B}),(O()||Q()||T()||F())&&e.createElement("div",{className:"action-buttons"},O()&&e.createElement(N,{onClick:()=>{E(!1),v(s[z],null,!0)},disabled:l.current.question.required&&(!o[l.current.question.name]||Array.isArray(o[l.current.question.name])&&0===o[l.current.question.name].length)||l.current.question.type_info.meta?.othersRequired&&R,className:"next-button"},"Next"),T()&&e.createElement("button",{className:"skip-button",onClick:()=>{E(!1),h(C)}},"Skip"),F()&&e.createElement("div",{className:"submit"},e.createElement(N,{disabled:(l.current.question.required||l.current.question.type_info.pivot_question)&&(null==o[l.current.question.name]||0===o[l.current.question.name]?.length)||l.current.question.type_info.meta?.othersRequired&&R||m,onClick:()=>{x(!0),g({...o,others_meta:I},(()=>{a?.type_info.meta?.skipThankYouPage?k?setTimeout((()=>{q?.()}),300):window.location.href=a?.type_info.meta?.redirectUrl:b(!0)}))}},m?"Submitting":"Submit survey")),Q()&&e.createElement("button",{className:"skip-button",onClick:()=>{E(!1),l.current=s[z],c.current=i.findIndex((e=>e.name===s[z].name)),h(C)}},"Clear selection")))},$=({survey:t,surveyStyle:i="standard",placeholders:c,onSubmit:l,widget:m,npsValue:f,widgetStyle:y,widgetNavigatorQuerySelector:v,preview:h,mobilePreview:x,closePreview:g})=>{const b=t.question_details?.questions||[],w=t.meta?.blocks||[],[k,q]=o(null),[_,C]=o({}),[N,B]=o(!1),[I,O]=o([]),[T,Q]=o(0),[F,R]=o(!1),[V,$]=o(null),[U,A]=o({}),M=n(null),D=n(null),H=n(-1),[W,P]=o(null),j=n(0),G=n(0),X=n(!1),K=n([]),Z=n(!!f&&"card"===i),J=n(null),ee=n(0),[ne,te]=o(!1),re=n(0);r((()=>{w&&(J.current=w.find((e=>"TY"===e.name)),q(w.filter((e=>"TY"!==e.name))))}),[w]),r((()=>{G.current=ee.current,Q(T+1)}),[ne]),r((()=>{if(k)if(D.current=b.find((e=>e.type_info?.pivot_question))??b.find((e=>"RANGE"===e.type_info?.question_type))??b[0],null!=f){H.current=f;const e=b.find((e=>e.name===k[0].question_names[0]));M.current={...k[0],question:e},K.current=[...K.current,{...k[0],question:e}],O(K.current),C({Q_1:f})}else if(!M.current&&k.length>0)return M.current=k[0],void se(k[0])}),[k,f]),r((()=>{I.length&&(K.current=I,G.current=I.length-1,Q(I.length-1))}),[I]),r((()=>{Object.keys(_).length>0&&M.current.question&&(d.includes(M.current.question.type_info.question_type)||X.current)&&!oe()&&(f&&1==I.length?setTimeout((()=>{ie()}),1500):ie())}),[_]),r((()=>{if(null!=_?.[D.current?.name])if(J.current?.is_based_on_rating){const e=D.current?.type_info?.choices[_?.[D.current?.name]-D.current?.type_info?.validation?.min??0]?.dependent_question_names,n=J.current?.question_names.find((n=>e?.includes(n))),t=b.find((e=>e.name===n));$(t)}else{const e=b.find((e=>e.name==J.current?.question_names[0]));$(e)}}),[_?.[D.current?.name]]);s((()=>{(()=>{if(W){W.style.minHeight="unset",W.style.height="min-content";const e=Math.min(W?.scrollHeight,p[y]);W.style.height=e+"px",W.style.minHeight=e+"px",re.current=e}})()}),[W]);const oe=()=>(j.current===k.length-1||"end"===M.current.branchOption)&&G.current===I.length-1,se=e=>{let n={};if(e.is_based_on_rating){const t=D.current?.type_info?.choices[_?.[D.current?.name]-D.current?.type_info?.validation?.min??0]?.dependent_question_names,r=e.question_names.find((e=>t?.includes(e)));n=b.find((e=>e.name===r))}else n=b.find((n=>n.name===e.question_names[0]));M.current.question=n;K.current.find((e=>e.question.name===n.name))?(Q(T+1),G.current+=1):O([...K.current,{...e,question:n}])},ie=()=>{if(oe())B(!0);else{if(M.current.nextBlock)j.current=k.findIndex((e=>e.name===M.current.nextBlock));else if(M.current.question.type_info?.meta?.branches){const e=M.current.question.type_info?.meta?.branches,n=_[M.current.question.name];let t;if(t="RANGE"===M.current.question.type_info.question_type?e.find((e=>n>=e.min&&n<=e.max)):e.find((e=>n===e.value)),t?.nextBlock){if("TY"===t.nextBlock)return void B(!0);j.current=k.findIndex((e=>e.name===t.nextBlock))}else j.current+=1}else j.current+=1;M.current=k[j.current],se(k[j.current])}},ae=(e,n,t)=>{if(Z.current=!1,t){if(X.current=!0,null!=_[e.question.name]&&e.name!==I[I.length-1].name){const[t,r]=(e=>{const n=I.findIndex((n=>n.name===e.name)),t=I.slice(0,n+1),r=t.reduce(((e,n)=>(e[n.question.name]=_[n.question.name],e)),{});return j.current=k.findIndex((n=>n.name===e.name)),[t,r]})(e);C({...r,...null!=n&&{[e.question.name]:n}}),K.current=t}else C({..._,...null!=n&&{[e.question.name]:n}});D?.current?.name==e?.question?.name&&(H.current=n)}else C({..._,...null!=n&&{[e.question.name]:n}})};if(!M.current||!M.current.question)return null;const ue=I[Math.min(G.current??I.length-1,I.length-1)];return e.createElement("div",{className:`freemium-survey-components ${m?"widget-survey-components":""} ${y}-style ${x?"mobile-preview":""}`,id:"freemium-survey"},e.createElement(E,{totalSteps:k.length,completedSteps:j.current+(N?1:0)}),e.createElement("div",{className:"questions",style:{height:re.current,...1===I.length?{transition:"none"}:{}}},e.createElement(u,{component:null},e.createElement(a,{key:ue.question.name+String(N),unmountOnExit:!0,addEndListener:(e,n)=>{e.addEventListener("transitionend",n,!1)},classNames:ne?"fade-reverse":"fade"},e.createElement("div",{ref:e=>e?P(e):null,id:`${ue.question.name}`,className:"question-container "+(N?"thankyou":""),"data-test-question-name":ue.question.name},N?e.createElement(L,{thankYouQuestion:V,preview:h,placeholders:c,npsValue:H.current,setBlockElementRef:P}):e.createElement(e.Fragment,null,e.createElement("div",{className:"question-text",dangerouslySetInnerHTML:{__html:z(ue.question.text,c,H.current)},title:`question-${G.current}`,role:"heading","aria-level":1}),e.createElement("div",{onTransitionEndCapture:e=>e.stopPropagation(),style:{width:"100%",flexGrow:"1"}},e.createElement(S,{question:ue.question,formValues:_,othersMeta:U,autoFocus:!0,autoFocusDelay:"standard"===i?300:0,saveOthersValue:(e,n)=>{A({...U,[e]:n})},onChangeHandler:e=>{X.current=!1,j.current=k.findIndex((e=>e.name===ue.name)),M.current=ue,te(!1),ae(ue,e,d.includes(ue.question.type_info.question_type)&&!oe())}})),e.createElement(Y,{question:ue.question,widget:m,widgetStyle:y,surveyStyle:i,formValues:_,othersMeta:U,blocksWithQns:I,blocks:k,thankYouQuestion:V,currentBlockIndexOfBlocksWithQns:G,reverse:ne,setReverse:te,currentBlockIndexOfBlocks:j,currentEditingBlock:M,isSubmitting:F,isValuesCommitted:X,isCurrentBlockFinal:oe,setHorizontalScrollUnits:Q,handleFormValues:ae,skipBlock:e=>{X.current=!0,delete _[e.name],C({..._})},setIsSubmitting:R,onSubmit:l,setIsSurveyCompleted:B,preventQuestionAnimation:Z,preview:h,closePreview:g,tempCurrentBlockIndexOfBlocksWithQns:ee})))))))};c(":root {\n --default-brand-color: #264966;\n --default-question-text-color: #000;\n --default-question-background-color: #fff;\n --default-background-color: #f8f8f8;\n --default-button-text-color: #fff;\n --default-secondary-button-text-color: #000;\n --default-input-placeholder-color: #92a2b1;\n --compact-widget-max-height: 480px;\n --default-widget-max-height: 460px;\n --cozy-widget-max-height: 380px;\n}\n\n.freemium-survey-step-navigation {\n border-radius: 3px;\n border: 1px solid #efefef;\n white-space: nowrap;\n}\n.freemium-survey-step-navigation .navigation-button {\n width: 38px;\n text-align: -webkit-center;\n height: 38px;\n background-color: #fff;\n border: none;\n cursor: pointer;\n border-radius: 0 3px 3px 0;\n}\n.freemium-survey-step-navigation .navigation-button:first-of-type {\n border-right: 1px solid #efefef;\n border-radius: 3px 0 0 3px;\n}\n.freemium-survey-step-navigation .navigation-button:disabled {\n cursor: not-allowed;\n opacity: 0.5;\n}\n.freemium-survey-step-navigation .navigation-button:focus {\n position: relative;\n z-index: 1;\n}\n\n.freemium-survey-components.standard-survey-style .question-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n text-align: center;\n max-width: 700px;\n margin: 0 auto;\n background: var(--default-question-background-color);\n background: var(--question-background-color, var(--default-question-background-color));\n border-radius: 4px;\n transition: transform 500ms ease 0ms, opacity 800ms ease 0ms;\n box-shadow: 0px 12px 15px rgba(18, 52, 77, 0.03);\n margin-bottom: 28px;\n padding: 28px;\n grid-gap: 28px;\n gap: 28px;\n position: relative;\n height: -webkit-fit-content;\n height: -moz-fit-content;\n height: fit-content;\n overflow: auto;\n opacity: 1;\n}\n.freemium-survey-components.standard-survey-style .hide-question-container {\n pointer-events: none;\n opacity: 0;\n}\n.freemium-survey-components.standard-survey-style .question-text {\n font-size: 1rem;\n font-weight: 600;\n line-height: 1.8;\n width: 100%;\n text-align: left;\n color: var(--default-question-text-color);\n color: var(--question-text-color, var(--default-question-text-color));\n}\n.freemium-survey-components.standard-survey-style .autofocus-button {\n border: none;\n width: 0;\n height: 0;\n opacity: 0;\n margin-top: -12px;\n margin-left: -12px;\n position: absolute;\n}\n.freemium-survey-components.standard-survey-style .question-footer {\n display: flex;\n justify-content: flex-start;\n grid-gap: 40px;\n gap: 40px;\n width: 100%;\n align-items: center;\n}\n.freemium-survey-components.standard-survey-style .question-footer:empty {\n display: none;\n}\n.freemium-survey-components.standard-survey-style .action-buttons {\n display: flex;\n grid-gap: 20px;\n gap: 20px;\n flex-direction: row-reverse;\n}\n.freemium-survey-components.standard-survey-style .action-buttons:empty {\n display: none;\n}\n.freemium-survey-components.standard-survey-style .skip-button {\n font-weight: 500;\n cursor: pointer;\n background: transparent;\n border: none;\n min-width: 40px;\n padding: 8px 16px;\n border-radius: 4px;\n color: var(--default-secondary-button-text-color);\n color: var(--secondary-button-text-color, var(--default-secondary-button-text-color));\n letter-spacing: 0.05rem;\n line-height: 1.5;\n border: 1px solid transparent;\n transform: translateY(0px);\n transition: transform ease 0.2s;\n}\n.freemium-survey-components.standard-survey-style .skip-button:hover {\n background-color: #f3f3f3;\n transform: translateY(-4px);\n}\n.freemium-survey-components.standard-survey-style .next-button {\n color: var(--default-button-text-color);\n color: var(--button-text-color, var(--default-button-text-color));\n}\n.freemium-survey-components.standard-survey-style .submit {\n max-width: 700px;\n margin: 0 auto;\n text-align: left;\n background: transparent;\n box-shadow: none;\n padding-bottom: 40px;\n color: var(--default-button-text-color);\n color: var(--button-text-color, var(--default-button-text-color));\n}\n.freemium-survey-components.standard-survey-style .fade-enter {\n transition: all ease 400ms;\n opacity: 0;\n transform: translateY(40px);\n}\n.freemium-survey-components.standard-survey-style .fade-enter-active {\n transition: all ease 400ms;\n opacity: 1;\n transform: translateY(0);\n}\n.freemium-survey-components.standard-survey-style .fade-exit {\n transition: all ease 400ms;\n opacity: 1;\n transform: translateY(0);\n}\n.freemium-survey-components.standard-survey-style .fade-exit-active {\n transition: all ease 400ms;\n opacity: 0;\n transform: translateY(-40px);\n}\n.freemium-survey-components.standard-survey-style .thankyou {\n display: flex;\n align-items: center;\n justify-content: center;\n grid-gap: 20px;\n gap: 20px;\n min-height: 180px;\n}\n.freemium-survey-components.standard-survey-style .thankyou .heading {\n font-weight: 600;\n font-size: 28px;\n}\n.freemium-survey-components.standard-survey-style .thankyou .text {\n white-space: pre-wrap;\n font-weight: 500;\n font-size: 0.875rem;\n line-height: 1.6;\n color: #12344d;\n width: 75%;\n}\n.freemium-survey-components.standard-survey-style .thankyou .redirection-text {\n color: #929292;\n margin-bottom: 12px;\n font-weight: 300;\n}\n.freemium-survey-components.standard-survey-style .thankyou .link {\n width: 100%;\n display: inline-block;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n color: #666;\n font-weight: 500;\n text-decoration: underline;\n}\n.freemium-survey-components.standard-survey-style .responsive-text-field {\n width: 100%;\n}\n.freemium-survey-components.standard-survey-style .responsive-text-field .textarea-container {\n display: none;\n}\n.freemium-survey-components.standard-survey-style .message-container:empty {\n display: none;\n}\n@media (max-width: 550px) {\n .freemium-survey-components.standard-survey-style .action-buttons {\n flex-direction: column;\n width: 100%;\n }\n .freemium-survey-components.standard-survey-style .action-buttons button {\n max-width: unset;\n }\n .freemium-survey-components.standard-survey-style .action-button {\n max-width: unset;\n width: 100%;\n }\n .freemium-survey-components.standard-survey-style .thankyou .text {\n width: auto;\n }\n}\n\n@media (max-width: 550px) {\n .freemium-survey-component .responsive-text-field .input-container,\n.card-survey-style .responsive-text-field .input-container {\n display: none;\n }\n .freemium-survey-component .responsive-text-field .textarea-container,\n.card-survey-style .responsive-text-field .textarea-container {\n display: flex;\n }\n}\n.freemium-survey-components.mobile-preview .thankyou .text {\n width: unset;\n}");const U=({thankYouQuestion:n,preview:t,placeholders:o,npsValue:s})=>(r((()=>{t||n.type_info.meta?.redirectUrl&&setTimeout((()=>{window.location.href=n.type_info.meta?.redirectUrl}),1e3*(n.type_info.meta?.redirectDelay??1e4))}),[]),e.createElement("div",{className:"question-container thankyou"},e.createElement("div",{className:"heading"},"Thank you!"),e.createElement("div",{className:"text",dangerouslySetInnerHTML:{__html:z(n.text,o,s)}}),n.type_info.meta?.redirectUrl&&e.createElement("div",{style:{width:"100%"}},e.createElement("div",{className:"redirection-text"},"You will be redirected to the below URL automatically in"," ",n.type_info.meta?.redirectDelay," seconds.",e.createElement("br",null)),e.createElement("a",{className:"link",href:n.type_info.meta?.redirectUrl},n?.type_info.meta?.redirectUrl)))),A=({currentBlockIndex:n,currentBlockIndexOfBlocksWithQns:t,blocksWithQns:r,blocks:o,setHorizontalScrollUnits:s,preventQuestionAnimation:i})=>e.createElement("div",{className:"freemium-survey-step-navigation","data-navigation-element":"1"},e.createElement("button",{disabled:0==t.current,className:"navigation-button",onClick:()=>{t.current=Math.max(t.current-1,0),n.current=o.findIndex((e=>e.name===r[t.current].name)),i.current=!1,s(t.current)}},e.createElement(I,null)),e.createElement("button",{className:"navigation-button",disabled:t.current>=r.length-1,onClick:()=>{i.current=!1,t.current=Math.min(t.current+1,r.length-1),n.current=o.findIndex((e=>e.name===r[t.current].name)),s(t.current)}},e.createElement(B,null))),M=({widget:n,surveyStyle:t,formValues:r,othersMeta:o,blocksWithQns:s,blocks:i,thankYouQuestion:a,currentBlockIndexOfBlocksWithQns:u,currentBlockIndexOfBlocks:c,currentEditingBlock:l,isSubmitting:m,isValuesCommitted:p,isCurrentBlockFinal:f,setHorizontalScrollUnits:y,handleFormValues:v,skipBlock:h,setIsSubmitting:x,onSubmit:g,setIsSurveyCompleted:b,preventQuestionAnimation:w,preview:k,closePreview:q,...E})=>{const _=E.blockIndex??u.current,C=E.question??s[_].question,B=()=>C.name===l.current.question.name&&!d.includes(C.type_info.question_type)&&!f(),I=()=>"RANGE"!==C.type_info.question_type&&!C.required&&C.name===l.current.question.name&&!f(),S=()=>("DROPDOWN"===C.type_info.question_type&&C.name!==l.current.question.name&&!C.required&&r[C.name],!1),z=()=>f()&&(n||"standard"!==t)&&C.name===l.current.question.name,O="MULTI_SELECT"===l.current.question.type_info.question_type&&r[l.current.question.name]?.includes("others")&&(!o[l.current.question.name]||""===o[l.current.question.name]);return e.createElement("div",{className:"question-footer"},!(!n&&"standard"===t||0===_&&!r[C.name])&&e.createElement(A,{currentBlockIndex:c,currentBlockIndexOfBlocksWithQns:u,blocksWithQns:s,blocks:i,setHorizontalScrollUnits:y,preventQuestionAnimation:w}),(B()||S()||I()||z())&&e.createElement("div",{className:"action-buttons"},B()&&e.createElement(N,{onClick:()=>{v(s[_],null,!0)},disabled:l.current.question.required&&(!r[l.current.question.name]||Array.isArray(r[l.current.question.name])&&0===r[l.current.question.name].length)||l.current.question.type_info.meta?.othersRequired&&O,className:"next-button"},"Next"),I()&&e.createElement("button",{className:"skip-button",onClick:()=>h(C)},"Skip"),S()&&e.createElement("button",{className:"skip-button",onClick:()=>{l.current=s[_],c.current=i.findIndex((e=>e.name===s[_].name)),h(C)}},"Clear selection"),z()&&e.createElement("div",{className:"submit"},e.createElement(N,{disabled:(l.current.question.required||l.current.question.type_info.pivot_question)&&(null==r[l.current.question.name]||0===r[l.current.question.name]?.length)||l.current.question.type_info.meta?.othersRequired&&O||m,onClick:()=>{x(!0),g({...r,others_meta:o},(()=>{a?.type_info.meta?.skipThankYouPage?k?setTimeout((()=>{q?.()}),300):window.location.href=a?.type_info.meta?.redirectUrl:b(!0)}))}},m?"Submitting":"Submit survey"))))},D=({survey:t,surveyStyle:s="standard",placeholders:u,onSubmit:c,widget:l,npsValue:m,preview:p,mobilePreview:f,closePreview:y})=>{const v=t.question_details?.questions||[],h=t.meta?.blocks||[],[x,g]=o(null),[b,w]=o({}),[k,q]=o(!1),[_,C]=o([]),[B,I]=o(0),[O,T]=o(!1),[Q,F]=o(null),[R,L]=o({}),V=n(null),Y=n(null),$=n(-1),A=n(null),D=n(0),H=n(0),W=n(!1),P=n([]),j=n(!!m&&"card"===s),G=n(null),X=n([]);r((()=>{h&&(G.current=h.find((e=>"TY"===e.name)),g(h.filter((e=>"TY"!==e.name))))}),[h]),r((()=>{if(x)if(Y.current=v.find((e=>e.type_info?.pivot_question))??v.find((e=>"RANGE"===e.type_info?.question_type))??v[0],null!=m){$.current=m;const e=v.find((e=>e.name===x[0].question_names[0]));V.current={...x[0],question:e},P.current=[...P.current,{...x[0],question:e}],C(P.current),w({Q_1:m})}else if(!V.current&&x.length>0)return V.current=x[0],void Z(x[0])}),[x,m]),r((()=>{_.length&&(P.current=_,H.current=_.length-1),l||"standard"!==s?(A.current&&(A.current.style.maxHeight="unset"),X.current[D.current]=A.current?.scrollHeight||X.current[D.current]||0,A.current&&(A.current.style.maxHeight="100%")):A.current?.scrollIntoView({block:"start",behavior:"smooth"}),I(_.length-1)}),[_]),r((()=>{Object.keys(b).length>0&&V.current.question&&(d.includes(V.current.question.type_info.question_type)||W.current)&&!K()&&J()}),[b]),r((()=>{if(null!=b?.[Y.current?.name])if(G.current?.is_based_on_rating){const e=Y.current?.type_info?.choices[b?.[Y.current?.name]-Y.current?.type_info?.validation?.min??0]?.dependent_question_names,n=G.current?.question_names.find((n=>e?.includes(n))),t=v.find((e=>e.name===n));F(t)}else{const e=v.find((e=>e.name==G.current?.question_names[0]));F(e)}}),[b?.[Y.current?.name]]);const K=()=>D.current===x.length-1||"end"===V.current.branchOption,Z=e=>{let n={};if(e.is_based_on_rating){const t=Y.current?.type_info?.choices[b?.[Y.current?.name]-Y.current?.type_info?.validation?.min??0]?.dependent_question_names,r=e.question_names.find((e=>t?.includes(e)));n=v.find((e=>e.name===r))}else n=v.find((n=>n.name===e.question_names[0]));V.current.question=n;P.current.find((e=>e.question.name===n.name))?(I(B+1),H.current+=1):C([...P.current,{...e,question:n}])},J=()=>{if(K())q(!0);else{if(V.current.nextBlock)D.current=x.findIndex((e=>e.name===V.current.nextBlock));else if(V.current.question.type_info?.meta?.branches){const e=V.current.question.type_info?.meta?.branches,n=b[V.current.question.name];let t;if(t="RANGE"===V.current.question.type_info.question_type?e.find((e=>n>=e.min&&n<=e.max)):e.find((e=>n===e.value)),t?.nextBlock){if("TY"===t.nextBlock)return void q(!0);D.current=x.findIndex((e=>e.name===t.nextBlock))}else D.current+=1}else D.current+=1;V.current=x[D.current],Z(x[D.current])}},ee=e=>{W.current=!0,delete b[e.name],w({...b})},ne=(e,n,t)=>{if(j.current=!1,t){if(W.current=!0,null!=b[e.question.name]&&e.name!==_[_.length-1].name){const[t,r]=(e=>{const n=_.findIndex((n=>n.name===e.name)),t=_.slice(0,n+1),r=t.reduce(((e,n)=>(e[n.question.name]=b[n.question.name],e)),{});return D.current=x.findIndex((n=>n.name===e.name)),[t,r]})(e);w({...r,...null!=n&&{[e.question.name]:n}}),P.current=t}else w({...b,...null!=n&&{[e.question.name]:n}});Y?.current?.name==e?.question?.name&&($.current=n)}else w({...b,...null!=n&&{[e.question.name]:n}})},te=(e,n)=>{L({...R,[e]:n})};return V.current&&V.current.question?e.createElement("div",{className:`freemium-survey-components ${l?"widget-survey-components":""} ${f?"mobile-preview":""} ${s}-survey-style`,id:"freemium-survey"},k?null:e.createElement(E,{totalSteps:x.length,completedSteps:D.current}),e.createElement(i,{mode:"out-in"},e.createElement(a,{key:String(k),addEndListener:(e,n)=>{e.addEventListener("transitionend",n,!1)},classNames:l?"":"fade"},e.createElement("div",null,k?e.createElement(U,{thankYouQuestion:Q,preview:p,placeholders:u,npsValue:$.current}):e.createElement(e.Fragment,null,e.createElement("div",{onTransitionEndCapture:e=>e.stopPropagation(),style:l||"card"===s?{transform:`translateX(calc(-${B} * 100%))`,height:`${X.current[D.current]}px`,transition:j.current||_?.length<=1?"none":"all 300ms ease-out 0ms"}:{},className:"questions"},_.map(((n,t)=>e.createElement("div",{key:n.question.name,ref:A,className:"question-container "+(!l&&"card"!==s||H.current===t?"":"hide-question-container")},e.createElement("div",{className:"question-text "+(0===t?"nps":""),dangerouslySetInnerHTML:{__html:z(n.question.text,u,$.current)},title:`question-${t}`,role:"heading","aria-level":1}),e.createElement("button",{disabled:!l&&"standard"===s,className:"autofocus-button",onKeyDown:e=>{"Tab"===e.key&&(e.stopPropagation(),e.preventDefault())}}),e.createElement(S,{question:n.question,formValues:b,othersMeta:R,autoFocus:H.current===t,autoFocusDelay:"standard"===s?350:20,saveOthersValue:te,onChangeHandler:e=>{W.current=!1,D.current=x.findIndex((e=>e.name===n.name)),V.current=n,ne(n,e,d.includes(n.question.type_info.question_type)&&!K())}}),e.createElement("button",{disabled:!l&&"standard"===s,className:"autofocus-button",onKeyDown:e=>{"Tab"===e.key&&(e.stopPropagation(),e.preventDefault())}}),e.createElement(M,{question:n.question,blockIndex:t,widget:l,surveyStyle:s,formValues:b,othersMeta:R,blocksWithQns:_,blocks:x,thankYouQuestion:Q,currentBlockIndexOfBlocksWithQns:H,currentBlockIndexOfBlocks:D,currentEditingBlock:V,isSubmitting:O,isValuesCommitted:W,isCurrentBlockFinal:K,setHorizontalScrollUnits:I,handleFormValues:ne,skipBlock:ee,setIsSubmitting:T,onSubmit:c,setIsSurveyCompleted:q,preventQuestionAnimation:j,preview:p,closePreview:y})))),!l&&"card"!==s&&K()&&e.createElement("div",{className:"submit"},e.createElement(N,{disabled:(V.current.question.required||V.current.question.type_info.pivot_question)&&(null==b[V.current.question.name]||0===b[V.current.question.name]?.length)||V.current.question.type_info.meta?.othersRequired&&"MULTI_SELECT"===V.current.question.type_info.question_type&&b[V.current.question.name]?.includes("")||O,onClick:()=>{T(!0),c({...b,others_meta:R},(()=>{Q?.type_info.meta?.skipThankYouPage?p?setTimeout((()=>{y?.()}),300):window.location.href=Q?.type_info.meta?.redirectUrl:q(!0)}))}},O?"Submitting":"Submit survey")))))))):null},H=n=>{const t=O(n.survey);return e.createElement(e.Fragment,null,"standard"===n.surveyStyle?e.createElement(D,Object.assign({},n,{survey:t})):e.createElement(R,Object.assign({},n,{survey:t})))},W=n=>{const t=O(n.survey);return e.createElement($,Object.assign({},n,{survey:t}))};export{C as BUTTON_SIZE_VARIANTS,N as Button,b as CheckboxGroup,h as Input,l as NPS,E as ProgressBar,q as Radio,k as RadioGroup,H as Survey,x as TextArea,W as WebInAppSurvey};
@@ -1,5 +1,5 @@
1
1
  export declare const AUTO_COMMIT_FIELD_TYPES: string[];
2
- export declare const TRANSITION_DURATION: number;
2
+ export declare const TRANSITION_DURATION = 300;
3
3
  export declare const AUTO_REDIRECT_DELAY: number;
4
4
  export declare const ACTIVE_FOCUS_LOCK_GROUP = "active-focus-lock-1";
5
5
  export declare const WIDGET_MAX_HEIGHT: {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "freemium-survey-components",
3
- "version": "0.10.40",
3
+ "version": "0.10.41",
4
4
  "description": "React Survey Ui Components",
5
5
  "main": "lib/index.cjs.js",
6
6
  "module": "lib/index.esm.js",