userflow.js-self-hosted 0.0.2000001

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.
Files changed (51) hide show
  1. package/BubbleToolbar.js +1 -0
  2. package/BuilderBar.js +1 -0
  3. package/ChecklistApp.js +1 -0
  4. package/ChecklistUI.js +1 -0
  5. package/DynamicIcon.js +1 -0
  6. package/ElementSelectionApp.js +1 -0
  7. package/FlowApp.js +1 -0
  8. package/FlowChrome.js +1 -0
  9. package/Icons.js +1 -0
  10. package/LauncherApp.js +1 -0
  11. package/NotificationsApp.js +1 -0
  12. package/ResourceCenterApp.js +1 -0
  13. package/TrackerTestingApp.js +1 -0
  14. package/Trigger.js +1 -0
  15. package/avatar-frame.css +18 -0
  16. package/bubble-frame.css +1775 -0
  17. package/builder-ui-frame.css +786 -0
  18. package/builder-ui-host.css +45 -0
  19. package/checklist-launcher-frame.css +64 -0
  20. package/client-context.js +1 -0
  21. package/flow-condition-types.js +1 -0
  22. package/flow-host.css +677 -0
  23. package/iframe-reset.css +145 -0
  24. package/logomark.d9cf252a.svg +4 -0
  25. package/logomark.js +1 -0
  26. package/notifications-host.css +51 -0
  27. package/package.json +6 -0
  28. package/resource-center-logomark.05363402.svg +4 -0
  29. package/stylesheets.js +1 -0
  30. package/ui.js +1 -0
  31. package/userflow.js +1 -0
  32. package/vendor.babel.runtime.js +1 -0
  33. package/vendor.date-fns.js +1 -0
  34. package/vendor.fortawesome.fontawesome-svg-core.js +5 -0
  35. package/vendor.fortawesome.pro-light-svg-icons.js +5 -0
  36. package/vendor.fortawesome.pro-regular-svg-icons.js +5 -0
  37. package/vendor.fortawesome.pro-solid-svg-icons.js +5 -0
  38. package/vendor.fortawesome.react-fontawesome.js +1 -0
  39. package/vendor.html-parse-stringify2.js +1 -0
  40. package/vendor.i18next.js +1 -0
  41. package/vendor.is-hotkey.js +1 -0
  42. package/vendor.obj-str.js +1 -0
  43. package/vendor.object-assign.js +6 -0
  44. package/vendor.phoenix.js +1 -0
  45. package/vendor.prop-types.js +1 -0
  46. package/vendor.react-dom.js +9 -0
  47. package/vendor.react-i18next.js +1 -0
  48. package/vendor.react.js +9 -0
  49. package/vendor.scheduler.js +9 -0
  50. package/vendor.uuid.js +1 -0
  51. package/vendor.void-elements.js +1 -0
@@ -0,0 +1 @@
1
+ import{r as e}from"./vendor.react.js";import{c as t,a as n,i as r}from"./flow-condition-types.js";import{b as l}from"./stylesheets.js";import{o}from"./vendor.obj-str.js";import{l as a,n as i,S as s,E as u,c,s as d,U as m,p as b,d as f}from"./userflow.js";import{S as h,a as p,V as w,b as g,c as v,T as E}from"./Icons.js";import{F as y}from"./vendor.fortawesome.react-fontawesome.js";import{f as k}from"./vendor.fortawesome.pro-solid-svg-icons.js";import{u as _}from"./vendor.react-i18next.js";import{u as x}from"./client-context.js";const j=e.createContext(null);function q(){const t=e.useContext(j);if(!t)throw new Error("useSession: Session was not set");return t}function N(n){const r=q(),[o,a]=e.useState(!1),i=l(r.data),s=function(t){const n=e.useRef(t),r=e.useRef(t);return t!==r.current&&JSON.stringify(t)!==JSON.stringify(r.current)&&(n.current=t),r.current=t,n.current}(n);return e.useLayoutEffect((()=>{if(s){return t[s.type].track({sessionData:i,condition:s,callback:e=>{a(e)}})}}),[i,s]),null!=s&&o}const S=({appearance:t,hidden:n,disabled:r,onMouseDown:l,onClick:a,text:i,active:s,children:u})=>e.createElement("button",{className:o({[ue(t)]:!0,"userflowjs-bubble-button--hidden":!!n,"userflowjs-bubble-button--active":!!s}),onMouseDown:l,onClick:a,disabled:r},u||e.createElement("div",{className:"userflowjs-bubble-button-text",role:"presentation"},i));async function C(e,t,l){const{steps:o}=t.version;switch(l.type){case a.CLOSE_FLOW:switch(t.kind){case"launcher":await e.dismissLauncher(t,{endReason:u.ACTION});break;case"flow":case"checklist":await e.endFlow(t,{endReason:u.ACTION})}return;case a.EVAL_JS:try{const e=r(l.code||"",t.data);new Function('"use strict";\n'+e)()}catch(b){console.error(`Userflow.js: Evaluate JavaScript action failed.\n\nError:\n${b.stack||b.message||b}\n\nCode:\n${l.code}`)}return;case a.GO_TO_STEP:{if("flow"!==t.kind)return;const n=o.find((({crossVersionId:e})=>e===l.stepCvid));if(!n)throw new m("Action points to unknown step: "+l.stepCvid);return void(await e.goToStep(t,n))}case a.NAVIGATE:{if(!l.url)return void console.warn("Userflow.js: NAVIGATE action is missing url property");const e=F(l.url,{lookupAttribute:n(t.data)});return void(l.navigateTarget===i.NEW_TAB?window.open(e):c.customNavigate?c.customNavigate(e):window.setTimeout((()=>{d(e)}),0))}case a.SNOOZE:return void("flow"===t.kind&&l.timeValue&&l.timeUnit&&(e.endFlow(t,{endReason:u.SNOOZED,batch:!0}),t.draftMode?window.alert(`In preview mode, flows can't be snoozed.\n\nBut if this flow was running in published mode, the flow would now be snoozed for ${l.timeValue} ${l.timeUnit.toLowerCase()+(1===l.timeValue?"":"s")}.`):e.send({kind:"Snooze",flowId:t.flow.id,timeValue:l.timeValue,timeUnit:l.timeUnit},{batch:!0})));case a.START_FLOW:return"launcher"===t.kind&&e.deactivateLauncher(t),void(l.otherFlow?await e.startFlow({flowId:l.otherFlow.id,stepCvid:l.otherFlowStepCvid,startReason:t.draftMode?s.DRAFT:s.ACTION,replaceCurrent:!0}):console.warn("Userflow.js: START_FLOW action is missing other flow"))}}async function T(e,t,n){const r=[],l=[],o=[];for(const s of n)s.type===a.NAVIGATE?s.navigateTarget===i.NEW_TAB?r.push(s):o.push(s):l.push(s);for(const a of r)C(e,t,a);await Promise.all(l.map((n=>C(e,t,n))));for(const a of o)C(e,t,a)}const P=({button:t})=>{const n=x(),l=q(),o=N(t.disabledCondition),a=N(t.hiddenCondition);return e.createElement(S,{appearance:t.appearance,hidden:a,disabled:o,onClick:()=>T(n,l,t.actions),text:r(t.text,l.data)})},I=({type:t,required:n,buttonText:r,options:l,otherOption:a,multipleSelection:i,labelLeft:s,labelCenter:u,labelRight:c,minValue:d,maxValue:m,onSubmit:f,inert:w})=>{const{t:g}=_(),v=e.useRef(null),[E,x]=e.useState(""),[j,q]=e.useState(new Set),[N,S]=e.useState(),[C,T]=e.useState(),[P,I]=e.useState(!1),[A,$]=e.useState(!1),[M,R]=e.useState(null),F=e=>{if(!w&&f){if(n&&""===E&&[b.MULTILINE_TEXT,b.TEXT].includes(t))return R(g("question.requiredError")),void O();$(!0),R(null),f({...e,onCancel:()=>{$(!1)},onError:e=>{$(!1),R(e||"Sorry, something went wrong saving your answer. Please try again.")}})}},O=e.useCallback((()=>{!w&&v.current&&v.current.focus()}),[w]),[U,W]=e.useState(!1);e.useEffect((()=>{U&&(O(),W(!1))}),[O,U]);const B=e.createElement("div",{className:"userflowjs-bubble-question__button-row userflowjs-bubble-question__button-row--end"},e.createElement("button",{className:"userflowjs-bubble-button userflowjs-bubble-button--primary",onClick:()=>F({answer:{kind:"text",value:E}}),tabIndex:w?-1:void 0,disabled:A},e.createElement("div",{className:"userflowjs-bubble-button-text",role:"presentation"},r||g("question.submit"))));let V=null,D=0;if(t===b.NPS)s=s||g("question.npsLabelLeft"),c=c||g("question.npsLabelRight"),V=[0,1,2,3,4,5,6,7,8,9,10],D=V.length;else if([b.SCALE,b.STARS].includes(t)){m=null!=m?m:5,V=[];for(let e=d=null!=d?d:1;e<=m;e++)V.push(e);D=V.length}else t===b.MULTIPLE_CHOICE&&(D=(l?l.length:0)+(a&&!P?1:0));const[z,K]=e.useState(-1),J=-1===z?-1:Math.min(z,D-1),H=e=>{if(!e.target.closest('[role="radio"], [role="checkbox"], [role="radiogroup"], [role="group"]'))return;let t=null;if("ArrowRight"===e.key||"ArrowDown"===e.key?t=1:"ArrowLeft"!==e.key&&"ArrowUp"!==e.key||(t=-1),null!=t){e.preventDefault();const n=e.currentTarget.querySelectorAll('[role="radio"], [role="checkbox"]');let r=J+t;r<0?r=n.length-1:r>n.length-1&&(r=0),K(r),n[r].focus()}};let G,X=null,Q=null;if(V&&(s||u||c)){const t=[];s&&t.push(V[0],s),c&&t.push(V[V.length-1],c),X=e.createElement("div",{id:"a11y-scale-labels",className:"userflowjs-a11y-only"},t.join(", ")),Q=e.createElement("div",{id:"userflowjs-bubble-question-labels",className:"userflowjs-bubble-question__scale-labels","aria-hidden":"true"},e.createElement("div",{className:"userflowjs-bubble-question__scale-label"},s),u&&e.createElement("div",{className:"userflowjs-bubble-question__scale-label userflowjs-bubble-question__scale-label--center"},u),e.createElement("div",{className:"userflowjs-bubble-question__scale-label userflowjs-bubble-question__scale-label--right"},c))}switch(t){case b.MULTILINE_TEXT:G=e.createElement(e.Fragment,null,e.createElement("textarea",{ref:v,className:"userflowjs-textarea userflowjs-bubble-question__textarea",value:E,onChange:e=>x(e.target.value),onKeyDown:e=>{(e.ctrlKey||e.metaKey)&&"Enter"===e.key&&F({answer:{kind:"text",value:E}})},placeholder:g("question.placeholder"),readOnly:w||A,tabIndex:w?-1:void 0,rows:3,"aria-required":n?"true":void 0,"aria-invalid":null!=M?"true":void 0}),B);break;case b.MULTIPLE_CHOICE:{const t=()=>{E&&F({answer:{kind:"text",value:E},animationPromise:L()})},n=(l?.length||0)+(a?1:0),s=Math.max(0,Math.min(n,null==d?1:d)),u=Math.max(0,Math.min(n,null==m?n:m)),c=()=>{const e=(l||[]).filter(((e,t)=>j.has(t))).map((e=>e.value));a&&P&&""!==E&&e.push(E),s!==u||e.length===s?e.length<s?R(g("question.multiple_selection_too_few",{count:s})):e.length>u?R(g("question.multiple_selection_too_many",{count:u})):F({answer:{kind:"list",values:e}}):R(g("question.multiple_selection_wrong",{count:s}))};G=e.createElement(e.Fragment,null,i&&e.createElement("div",{className:o({"userflowjs-bubble-question__multiple-choice-hint":!0,"userflowjs-bubble-question__multiple-choice-hint--error":!!M})},g("question.multiple_selection_hint",{replace:{selected:j.size+(a&&P&&""!==E?1:0),range:s===u?s:`${s}-${u}`}}),M&&e.createElement(e.Fragment,null,". ",e.createElement("span",{role:"alert"},M))),e.createElement("div",{className:o({"userflowjs-bubble-question__multiple-choice":!0,"userflowjs-bubble-question__multiple-choice--single-selection":!i,"userflowjs-bubble-question__multiple-choice--multiple-selection":!!i,"userflowjs-bubble-question__multiple-choice--other-option-active":!!a&&P}),role:i?"group":"radiogroup",tabIndex:w||-1!==J?-1:0,onKeyDown:H},l?.map((({value:t,label:n},r)=>e.createElement("button",{key:r,className:o({"userflowjs-bubble-question__multiple-choice-option":!0,"userflowjs-bubble-question__multiple-choice-option--selected":i?j.has(r):A&&!P&&E==t}),onClick:A?void 0:()=>{if(i){R(null);const e=new Set(j);j.has(r)?e.delete(r):e.add(r),q(e)}else I(!1),x(t),F({answer:{kind:"text",value:t},animationPromise:L()})},disabled:A,tabIndex:w||r!==J?-1:0,role:i?"checkbox":"radio","aria-label":n||t,"aria-checked":!P&&E==t},i?e.createElement("div",{className:"userflowjs-bubble-question__multiple-choice-checkbox"},e.createElement("div",{className:"userflowjs-bubble-question__multiple-choice-checkbox-inner"},e.createElement(y,{icon:k}))):e.createElement("div",{className:"userflowjs-bubble-question__multiple-choice-radio"},e.createElement("div",{className:"userflowjs-bubble-question__multiple-choice-radio-inner"})),e.createElement("div",{className:"userflowjs-bubble-question__multiple-choice-option-text","aria-hidden":"true"},n||t)))),a&&(P?e.createElement("div",{className:o({"userflowjs-bubble-question__multiple-choice-option":!0,"userflowjs-bubble-question__multiple-choice-option--other":!0,"userflowjs-bubble-question__multiple-choice-option--selected":i?""!=E:A})},i?e.createElement("div",{className:"userflowjs-bubble-question__multiple-choice-checkbox",onClick:()=>{x(""),I(!1)}},e.createElement("div",{className:"userflowjs-bubble-question__multiple-choice-checkbox-inner"},e.createElement(y,{icon:k}))):e.createElement("div",{className:"userflowjs-bubble-question__multiple-choice-radio"},e.createElement("div",{className:"userflowjs-bubble-question__multiple-choice-radio-inner"})),e.createElement("input",{ref:v,className:"userflowjs-bubble-question__multiple-choice-option-input",value:E,onChange:e=>x(e.target.value),onKeyDown:e=>{e.shiftKey||"Enter"!==e.key?"Escape"===e.key&&(e.stopPropagation(),x(""),I(!1)):i?c():t()},onBlur:()=>{""===E&&I(!1)},placeholder:g("question.placeholder"),readOnly:w||A,tabIndex:w?-1:void 0}),!i&&e.createElement("button",{"data-testid":"multiple-choice-other-submit",className:"userflowjs-bubble-question__multiple-choice-option-submit",onClick:()=>t(),disabled:A,"aria-label":g("question.submit")},e.createElement(p,null))):e.createElement("button",{className:"userflowjs-bubble-question__multiple-choice-option",onClick:A?void 0:()=>{R(null),I(!0),W(!0)},disabled:A,tabIndex:w||l?.length!==J?-1:0,role:"radio","aria-label":g("question.other"),"aria-checked":"false"},i?e.createElement("div",{className:"userflowjs-bubble-question__multiple-choice-checkbox"},e.createElement("div",{className:"userflowjs-bubble-question__multiple-choice-checkbox-inner"},e.createElement(y,{icon:k}))):e.createElement("div",{className:"userflowjs-bubble-question__multiple-choice-radio"},e.createElement("div",{className:"userflowjs-bubble-question__multiple-choice-radio-inner"})),e.createElement("div",{className:"userflowjs-bubble-question__multiple-choice-option-text","aria-hidden":"true"},g("question.other"))))),i&&e.createElement("div",{className:"userflowjs-bubble-question__button-row"},e.createElement("button",{className:"userflowjs-bubble-button userflowjs-bubble-button--primary",onClick:c,tabIndex:w?-1:void 0,disabled:A},e.createElement("div",{className:"userflowjs-bubble-button-text",role:"presentation"},r||g("question.submit")))));break}case b.NPS:case b.SCALE:G=e.createElement(e.Fragment,null,X,e.createElement("div",{className:"userflowjs-bubble-question__scale-options",role:"radiogroup",tabIndex:w||-1!==J?-1:0,onKeyDown:H},V?.map(((t,n)=>e.createElement("button",{className:o({"userflowjs-bubble-question__scale-option":!0,"userflowjs-bubble-question__scale-option--selected":A&&N==t}),key:t,tabIndex:w||n!==J?-1:0,onClick:()=>{S(t),F({answer:{kind:"number",value:t},animationPromise:L()})},disabled:A,role:"radio","aria-checked":N==t},t)))),Q);break;case b.STARS:G=e.createElement("div",{className:"userflowjs-bubble-question__stars-wrapper"},X,e.createElement("div",{className:"userflowjs-bubble-question__stars",role:"radiogroup",tabIndex:w||-1!==J?-1:0,onKeyDown:H},V?.map(((t,n)=>e.createElement("button",{className:o({"userflowjs-bubble-question__star":!0,"userflowjs-bubble-question__star--hovered":!A&&null!=C&&C>=t,"userflowjs-bubble-question__star--selected":A&&null!=N&&N>=t,"userflowjs-bubble-question__star--not-selected":A&&null!=N&&N<t}),key:t,tabIndex:w||n!==J?-1:0,onClick:()=>{S(t),F({answer:{kind:"number",value:t},animationPromise:L()})},onMouseOver:()=>T(t),onMouseLeave:()=>T(null),disabled:A,role:"radio","aria-checked":N==t,"aria-label":String(t)},e.createElement("div",{className:"userflowjs-bubble-question__star-icon","aria-hidden":"true"},e.createElement(h,null)),e.createElement("div",{className:"userflowjs-bubble-question__star-value","aria-hidden":"true"},t))))),Q);break;case b.TEXT:G=e.createElement(e.Fragment,null,e.createElement("input",{ref:v,className:"userflowjs-text-input userflowjs-bubble-question__text-input",value:E,onChange:e=>x(e.target.value),onKeyDown:e=>{e.shiftKey||"Enter"!==e.key||F({answer:{kind:"text",value:E}})},placeholder:g("question.placeholder"),readOnly:w||A,tabIndex:w?-1:void 0,"aria-required":n?"true":void 0,"aria-invalid":null!=M?"true":void 0}),B)}return e.createElement("div",{className:"userflowjs-bubble-question",style:{pointerEvents:w?"none":void 0}},M&&!(t===b.MULTIPLE_CHOICE&&i)&&e.createElement("div",{className:"userflowjs-bubble-question__error",role:"alert"},M),G)};function L(){return new Promise((e=>window.setTimeout(e,250)))}const A=({question:t})=>{const n=x(),r=function(){const e=q();if("flow"!==e.kind)throw new Error("useFlowSession: Wrong session kind");return e}();return e.createElement(I,{type:t.type,required:!!t.required,buttonText:t.buttonText||"",options:t.options,otherOption:t.otherOption,multipleSelection:t.multipleSelection,labelLeft:t.labelLeft||"",labelCenter:t.labelCenter||"",labelRight:t.labelRight||"",minValue:t.minValue,maxValue:t.maxValue,onSubmit:async e=>{f("answerQuestion",r.id,t.cvid,e);const{answer:l}=e;try{await Promise.all([await n.send({kind:"AnswerQuestion",sessionId:r.id,questionName:t.name,questionCvid:t.cvid,textAnswer:"text"==l.kind?l.value:null,numberAnswer:"number"==l.kind?String(l.value):null,listAnswer:"list"==l.kind?l.values:null}),e.animationPromise])}catch(a){return console.log("Userflow.js: Error when answering question:",a),void e.onError()}const{bindAttributeFqn:o}=t;if(o&&n.flowSession?.id===r.id){let e;switch(l.kind){case"text":e={name:o,value:l.value};break;case"number":e={name:o,value:String(l.value)};break;case"list":e={name:o,value:l.values}}n.optimisticClockUIUpdate((()=>{n.setFlowSession({...r,data:[...r.data.filter((e=>e.name!==o)),e]})}))}T(n,r,t.actions)}})},$=({text:t})=>{if(!t)return null;const n=t.split(/\n/);return 1===n.length?e.createElement(e.Fragment,null,n[0]):e.createElement(e.Fragment,null,n.map(((t,n)=>e.createElement(e.Fragment,{key:n},n>0&&e.createElement("br",null),t))))};function M(e=""){return{type:"paragraph",children:[{text:e}]}}function R(e){if(e){let n;try{n=JSON.parse(e)}catch(t){throw new Error("Could not JSON.parse rich content doc: "+e)}if("rich2"===n.type)return n;throw new Error("Could not recognize rich content doc: "+e)}return function(e=""){return{type:"rich2",children:[M(e)]}}()}function F(e,{lookupAttribute:t}){if(!e)return"";"string"==typeof e&&(e=function(e){if(e){let n;try{n=JSON.parse(e)}catch(t){throw new Error("Could not JSON.parse plaintext doc: "+e)}if("plaintext2"===n.type)return n;throw new Error("Could not recognize plaintext doc: "+e)}return function(e=""){return{type:"plaintext2",children:[{type:"plaintext",children:[{text:e}]}]}}()}(e));const n=[];function r(e){e&&e.forEach((e=>e&&function(e){if(oe(e))e.text&&n.push(e.text);else switch(e.type){case"attribute":{const r=ne(e,t);r&&n.push(r);break}default:r(e.children)}}(e)))}return r(e.children),n.join("")}function O(e){let t=!0;if(!e)return!0;"string"==typeof e&&(e=R(e));const n=new Set(["attribute","button","image","question","video"]);return ae(e,(e=>{oe(e)?""!==e.text&&(t=!1):"type"in e&&n.has(e.type)&&(t=!1)})),t}const U=e.memo((({doc:t,...n})=>t?("string"==typeof t&&(t=R(t)),e.createElement(W,{parent:t,...n})):null)),W=({parent:t,...n})=>e.createElement(e.Fragment,null,t.children.map(((r,l)=>oe(r)?e.createElement(B,{key:l,node:r}):e.createElement(D,{key:l,node:r,parent:t,...n})))),B=({node:t})=>t.text?e.createElement(V,{node:t},e.createElement($,{text:t.text})):null,V=({node:t,children:n})=>(t.color&&"string"==typeof t.color&&(n=e.createElement("span",{style:{color:t.color}},n)),t.bold&&(n=e.createElement("b",null,n)),t.italic&&(n=e.createElement("i",null,n)),t.underline&&(n=e.createElement("u",null,n)),t.strikeThrough&&(n=e.createElement("s",null,n)),t.code&&(n=e.createElement("code",null,n)),t.sup&&(n=e.createElement("sup",null,n)),n),D=({node:t,parent:n,...r})=>{const{lookupAttribute:l}=r,o=e.createElement(W,{parent:t,...r});switch(t.type){case"attribute":return e.createElement(z,{node:t,...r});case"button":return e.createElement(K,{node:t,...r});case"button-group":return e.createElement("div",{className:"userflowjs-bubble-buttons"},o);case"column":return e.createElement("div",{style:ee(t,n)},o);case"column-group":return e.createElement("div",{className:"p-like",style:Y(t)},o);case"container":return e.createElement("div",{className:"p-like"+(t.className?` ${t.className}`:""),style:te(t)},o);case"image":return e.createElement(H,{node:t,...r});case"link":return e.createElement("a",{href:F(t.href,{lookupAttribute:l}),target:"_blank",rel:"noopener noreferrer"},o);case"paragraph":return e.createElement("p",{className:Q(t)},o);case"heading1":return e.createElement("h1",{className:Q(t)},o);case"heading2":return e.createElement("h2",{className:Q(t)},o);case"question":return e.createElement(J,{node:t,...r});case"quote":return e.createElement("blockquote",null,o);case"code-block":return e.createElement("pre",null,e.createElement("code",null,o));case"ordered-list":return e.createElement("ol",null,o);case"unordered-list":return e.createElement("ul",null,o);case"list-item":return e.createElement("li",null,o);case"video":return e.createElement(G,{node:t,...r});default:return e.createElement("div",null,o)}},z=({node:t,lookupAttribute:n})=>{let r=ne(t,n);return e.createElement(V,{node:t},r)},K=({node:t,buttons:n})=>{const r=n?.find((e=>e.cvid===t.cvid));return r?e.createElement(P,{key:r.id,button:r}):null},J=({node:t,questions:n})=>{const r=n?.find((e=>e.cvid===t.cvid));return r?e.createElement(A,{key:r.id,question:r}):null},H=({node:t,lookupAttribute:n})=>{const{src:r,widthMode:l,displayWidth:o,width:a,height:i,marginTop:s,marginRight:u,marginBottom:c,marginLeft:d,align:m,hasLink:b,href:f}=t;if("string"!=typeof r||!r)return null;const{wrapperStyle:h,blockStyle:p}=Z({widthMode:l,displayWidth:o,width:a,height:i,marginTop:s,marginRight:u,marginBottom:c,marginLeft:d,align:m});let w=e.createElement("img",{src:r,style:{...p,objectFit:"contain"}});return b&&f&&(w=e.createElement("a",{href:F(f,{lookupAttribute:n}),target:"_blank",rel:"noopener noreferrer",style:p},w)),e.createElement("div",{className:"p-like"},e.createElement("div",{style:h},w))},G=({node:t})=>{const{url:n,widthMode:r,displayWidth:l,width:o,height:a,marginTop:i,marginRight:s,marginBottom:u,marginLeft:c,align:d}=t;if("string"!=typeof n||!n)return null;const{wrapperStyle:m,blockStyle:b}=Z({widthMode:r,displayWidth:l,width:o,height:a,marginTop:i,marginRight:s,marginBottom:u,marginLeft:c,align:d});return e.createElement("div",{className:"p-like"},e.createElement("div",{style:m},e.createElement("div",{style:b},e.createElement(X,{element:t,noFocus:!0}))))},X=({element:{embedType:t,url:n,src:r,autoPlay:l,controls:o,muted:a},noFocus:i,forceMuted:s})=>{if(!n)return null;const u={width:"100%",height:"100%",frameBorder:"0",allow:"accelerometer; autoplay; fullscreen; encrypted-media; gyroscope; picture-in-picture",allowFullScreen:!0,allowtransparency:"true",mozallowfullscreen:"true",webkitallowfullscreen:"true",oallowfullscreen:"true",msallowfullscreen:"true",style:{display:"block"},tabIndex:i?-1:void 0};if("video"===t)return e.createElement("video",{key:n+";"+String(l)+";"+String(o)+";"+String(a),src:n,style:{width:"100%",height:"100%",display:"block"},autoPlay:!!l,controls:!1!==o,muted:s||a});if(r){let t;try{t=new URL(r)}catch(f){return null}return s&&(t.searchParams.has("autoplay")||t.searchParams.has("autoPlay"))&&(t.searchParams.set("mute","1"),t.searchParams.set("muted","1"),t.searchParams.set("volume","0")),e.createElement("iframe",{src:t.toString(),...u})}let c=function(e,{iframeFallback:t}={}){let n;try{n=new URL(e)}catch(f){return{kind:"invalid"}}const{hostname:r,pathname:l,searchParams:o}=n;if(r.match(/^(www\.)?(use)?loom\.com$/)){const e=l.match(/^\/share\/([a-z0-9]+)$/i);if(e){const[,t]=e;return{kind:"ok",videoProvider:"loom",videoId:t,searchParams:o}}}if(e.startsWith("raw:")){return{kind:"ok",videoProvider:"raw",videoId:e.replace(/^raw:/,""),searchParams:o}}if(e.startsWith("iframe:")){return{kind:"ok",videoProvider:"iframe",videoId:e.replace(/^iframe:/,""),searchParams:o}}if(["youtube.com","www.youtube.com"].includes(r)){const e=o.get("v");if(e)return o.delete("v"),{kind:"ok",videoProvider:"youtube",videoId:e,searchParams:o}}if("youtu.be"===r){const e=l.match(/^\/([^/]+)$/);if(e){const[,t]=e;return{kind:"ok",videoProvider:"youtube",videoId:t,searchParams:o}}}if("vimeo.com"===r){const e=l.match(/^\/(\d+)$/);if(e){const[,t]=e;return{kind:"ok",videoProvider:"vimeo",videoId:t,searchParams:o}}}if("player.vimeo.com"===r){const e=l.match(/^\/video\/([^/]+)$/);if(e){const[,t]=e;return{kind:"ok",videoProvider:"vimeo",videoId:t,searchParams:o}}}if(r.match(/^[^.]+\.wistia.com$/)){const e=l.match(/^\/medias\/([^/]+)$/);if(e){const[,t]=e;return{kind:"ok",videoProvider:"wistia",videoId:t,searchParams:o}}}return t?{kind:"ok",videoProvider:"iframe",videoId:e,searchParams:o}:{kind:"invalid"}}(n,{iframeFallback:!0});if("invalid"===c.kind)return null;const{videoProvider:d,videoId:m,searchParams:b}=c;switch(l=l||b.has("autoplay")||b.has("autoPlay"),d){case"iframe":return e.createElement("iframe",{src:m,scrolling:b.get("scrolling")||void 0,...u});case"loom":return e.createElement("iframe",{src:`https://www.loom.com/embed/${m}?${b.toString()}`,...u});case"raw":return e.createElement("video",{src:m,controls:!0,style:{width:"100%",height:"100%",display:"block"},autoPlay:b.has("autoplay"),muted:s||b.has("muted")});case"youtube":return s&&l&&b.set("mute","1"),e.createElement("iframe",{src:`https://www.youtube.com/embed/${m}?${b.toString()}`,...u});case"vimeo":return s&&l&&b.set("muted","1"),e.createElement("iframe",{src:`https://player.vimeo.com/video/${m}?${b.toString()}`,...u});case"wistia":return b.set("videoFoam","true"),s&&l&&b.set("volume","0"),e.createElement(e.Fragment,null,e.createElement("iframe",{src:`https://fast.wistia.net/embed/iframe/${m}?${b.toString()}`,...u}))}};function Q(e){return"right"===e.align?"userflowjs-text-align-end":"center"===e.align?"userflowjs-text-align-center":""}function Z({widthMode:e,displayWidth:t,width:n,height:r,marginTop:l,marginRight:o,marginBottom:a,marginLeft:i,align:s}){const u={position:"relative"};"number"!=typeof t&&(t=100,e="percent"),"center"===s?(u.marginLeft="auto",u.marginRight="auto"):"right"===s&&(u.marginLeft="auto");let c=0;if(null!=l&&"number"==typeof l&&(u.marginTop=`${l}px`),null!=o&&"number"==typeof o&&(u.marginRight=`${o}px`,c+=o),null!=a&&"number"==typeof a&&(u.marginBottom=`${a}px`),null!=i&&"number"==typeof i&&(u.marginLeft=`${i}px`,c+=i),"number"!=typeof t||"number"!=typeof n||"number"!=typeof r)u.width="100px",u.height="100px";else if("px"===e){const e=10,l=Math.max(e,t);u.width=`${l}px`,u.height=l/(n/r)+"px"}else{const e=Math.max(0,Math.min(100,t));u.width=`calc(${e}% - ${c}px)`,u.height="0",u.paddingBottom=`calc((${e}% - ${c}px) / (${n} / ${r})`}return{wrapperStyle:u,blockStyle:{position:"absolute",top:"0",left:"0",display:"block",width:"100%",height:"100%"}}}function Y(e){return{display:"flex",alignItems:"stretch",marginRight:`-${null==e.spacing?16:e.spacing}px`}}function ee(e,t){const n="fill"===e.widthMode||null==e.displayWidth;return{display:"flex",flexDirection:"column",justifyContent:e.justifyContent,width:n?void 0:"px"===e.widthMode?`${e.displayWidth||50}px`:"percent"===e.widthMode?`${e.displayWidth||50}%`:void 0,flex:n?"1 0 0":void 0,marginRight:`${null==t.spacing?16:t.spacing}px`,marginBottom:"0"}}function te(e){return{display:"flex",flexDirection:"column",justifyContent:e.justifyContent,width:"px"===e.widthMode&&null!=e.displayWidth?`${e.displayWidth}px`:"percent"===e.widthMode&&null!=e.displayWidth?`${e.displayWidth}%`:void 0,minHeight:"px"===e.heightMode?`${e.displayHeight||50}px`:void 0,flex:"fill"===e.heightMode?"1 0 0":void 0,marginTop:null!=e.marginTop?`${e.marginTop}px`:void 0,marginRight:null!=e.marginRight?`${e.marginRight}px`:"fill"!==e.widthMode&&"center"===e.align?"auto":void 0,marginBottom:null!=e.marginBottom?`${e.marginBottom}px`:void 0,marginLeft:null!=e.marginLeft?`${e.marginLeft}px`:"fill"===e.widthMode||"center"!==e.align&&"right"!==e.align?void 0:"auto"}}function ne(e,t){const n=e.attributeName;if("string"==typeof n){const r=t(n)||e.fallback;if("string"==typeof r)return r}return null}function re(e){return Array.isArray(e.children)&&void 0===e.addMark}function le(e,t,n="type"){return re(e)&&e[n]===t}function oe(e){return"string"==typeof e.text}function ae(e,t){function n(e){e&&e.forEach(((e,r)=>e&&function(e,r){t(e,r),re(e)&&n(e.children)}(e,r)))}n(Array.isArray(e)?e:e.children)}const ie=e.memo((({doc:t,lookupAttribute:n})=>t?e.createElement(e.Fragment,null,F(t,{lookupAttribute:n})):null));function se(e,{buttons:t,questions:n}){const r=new Set,l=new Set;if(ae(e,(e=>{le(e,"button")&&r.add(e.cvid),le(e,"question")&&l.add(e.cvid)})),n){const t=n.filter((e=>!l.has(e.cvid)));t.length>0&&(e={...e,children:[...e.children,...t.map((e=>({type:"question",cvid:e.cvid,children:[{text:""}]})))]})}if(t){const n=t.filter((e=>!r.has(e.cvid)));n.length>0&&(e={...e,children:[...e.children,{type:"button-group",children:n.map((e=>({type:"button",cvid:e.cvid,children:[{text:""}]})))}]})}return e}function ue(e){return"userflowjs-bubble-button "+("primary"===(e=e||"default")||"PRIMARY"===e?"userflowjs-bubble-button--primary":"default"===e||"DEFAULT"===e?"userflowjs-bubble-button--default":e)}var ce=new URL("flow-host.css",import.meta.url).href,de=new URL("bubble-frame.css",import.meta.url).href;const me=({draftMode:t,muted:n,toggleMuted:r,close:l,minimize:o})=>{const{t:a}=_();return e.createElement("div",{className:"userflowjs-bubble-toolbar"},t&&e.createElement("div",{className:"userflowjs-bubble-draft"},"string"==typeof t?t:"Preview"),r&&e.createElement("button",{className:"userflowjs-bubble-toolbar-button",onClick:r,"aria-label":n?"Unmute":"Mute"},n?e.createElement(w,null):e.createElement(g,null)),o&&e.createElement("button",{"data-testid":"minimize-button",className:"userflowjs-bubble-toolbar-button",onClick:o,"aria-label":"Minimize checklist"},e.createElement(v,null)),l&&e.createElement("button",{"data-testid":"close-button",className:"userflowjs-bubble-toolbar-button",onClick:l,"aria-label":a("menu.close")},e.createElement(E,null)))};export{me as B,U as R,j as S,ie as a,de as b,S as c,R as d,q as e,ce as f,ne as g,T as h,oe as i,se as m,O as r,F as s,N as u};
package/BuilderBar.js ADDED
@@ -0,0 +1 @@
1
+ import{r as e}from"./vendor.react.js";import{u as t,F as r,S as s}from"./logomark.js";import{o}from"./vendor.obj-str.js";import{f as a,a as n}from"./vendor.fortawesome.pro-light-svg-icons.js";import{v as l}from"./userflow.js";import{a as m}from"./stylesheets.js";import{D as i}from"./DynamicIcon.js";var u=new URL("builder-ui-host.css",import.meta.url).href,c=new URL("builder-ui-frame.css",import.meta.url).href;const f=e.forwardRef((({onReadyChange:f,children:d,buttons:p},b)=>{const{loaded:v}=m(window,u),[h,E]=e.useState(!1),g=v&&h,y=e.useRef(!1);e.useEffect((()=>{g&&!y.current&&f&&(y.current=!0,f(!0))}),[g,f]);const j=e.useRef(null),[w,R]=e.useState(null),[k,N]=e.useState((()=>"top"===l.getItem("builderBarPos")?"top":"bottom")),S=e.useCallback((e=>{N(e),l.setItem("builderBarPos",e)}),[]),C=e.useRef(0),I=e.useCallback((()=>{const e=j.current;if(!e||!w||!g)return;const t=w.clientHeight;t!==C.current&&(C.current=t,e.style.setProperty("height",t+"px","important"))}),[g,w]);return e.useLayoutEffect((()=>{I()})),t(I),e.useImperativeHandle(b,(()=>({getFrame:()=>j.current,getRootEl:()=>w})),[w]),e.createElement(e.Fragment,null,e.createElement(r,{className:o({"userflowjs-builder-bar":!0,"userflowjs-builder-bar--top":"top"===k}),style:{visibility:g?void 0:"hidden",animation:g?void 0:"none"},elRef:j,stylesheetUrl:c,onStylesheetsLoad:E},g&&e.createElement("div",{className:"root",ref:R},e.createElement("div",{className:"logomark"},e.createElement(s,null)),e.createElement("div",{className:"main"},d),e.createElement("div",{className:"buttons"},p,e.createElement("button",{key:k,className:"btn btn--square btn--plain-on-dark",onClick:()=>S("top"===k?"bottom":"top")},e.createElement(i,{icon:"top"===k?a:n,size:20}))))))}));export{f as B};
@@ -0,0 +1 @@
1
+ import{r as e}from"./vendor.react.js";import{y as t,A as s,x as o,i as n}from"./userflow.js";import{F as r}from"./FlowChrome.js";import{i,u as c}from"./client-context.js";import{w as a,C as l,a as u,g as m}from"./Icons.js";import{f as d,B as h}from"./BubbleToolbar.js";import{a as p,u as f}from"./stylesheets.js";import{F as k}from"./logomark.js";import{o as v}from"./vendor.obj-str.js";import{z as b}from"./flow-condition-types.js";import{u as j}from"./vendor.react-i18next.js";import{C as E}from"./ChecklistUI.js";import"./vendor.object-assign.js";import"./vendor.phoenix.js";import"./vendor.uuid.js";import"./vendor.i18next.js";import"./vendor.fortawesome.react-fontawesome.js";import"./vendor.fortawesome.fontawesome-svg-core.js";import"./vendor.prop-types.js";import"./vendor.fortawesome.pro-solid-svg-icons.js";import"./vendor.react-dom.js";import"./vendor.scheduler.js";import"./vendor.date-fns.js";import"./vendor.babel.runtime.js";var x=new URL("checklist-launcher-frame.css",import.meta.url).href;const w=({position:s,theme:o,onClick:n,onVisibleChange:r,buttonRef:i,text:c,uncompletedCount:m})=>{const h=s||"absolute",{i18n:f}=j(),E=f.dir(),{loaded:w}=p(window,d,o),[g,y]=e.useState(!1),L=w&&g;e.useEffect((()=>{r&&r(L)}),[r,L]);const F=e.useRef(null),I=e.useRef(0),[C,A]=e.useState(null);e.useLayoutEffect((()=>{const e=F.current;if(!e||!C)return;const t=C.clientWidth;t!==I.current&&(I.current=t,e.style.setProperty("width",b(t)+"px","important"),e.style.setProperty("height",o.checklistLauncherHeight+"px","important"))}));const T=o.checklistLauncherPlacement,R=T===t.TOP_LEFT||T===t.TOP_RIGHT,N=T===t.TOP_LEFT||T===t.BOTTOM_LEFT,P={zIndex:"fixed"===h?null!=o.checklistZIndex?o.checklistZIndex:a(l):1,top:R?o.checklistLauncherY+"px":void 0,bottom:R?void 0:o.checklistLauncherY+"px",["ltr"===E?"left":"right"]:N?o.checklistLauncherX+"px":void 0,["ltr"===E?"right":"left"]:N?void 0:o.checklistLauncherX+"px",height:o.checklistLauncherHeight+"px",borderRadius:o.checklistLauncherBorderRadius+"px",position:L?void 0:"absolute",visibility:L?void 0:"hidden",animation:L?void 0:"none"};return e.createElement(k,{elRef:F,testId:"checklist-launcher-app",className:v({"userflowjs-checklist-launcher":!0,[`userflowjs-checklist-launcher--position-${h}`]:!0}),style:P,stylesheetUrl:x,theme:o,onStylesheetsLoad:y},e.createElement("button",{ref:i,className:"userflowjs-checklist-launcher-frame-root",onClick:n},e.createElement("div",{ref:A,className:"userflowjs-checklist-launcher-content"},e.createElement("div",{className:"userflowjs-checklist-launcher-text"},c||"Get Started"),e.createElement("div",{"data-testid":"checklist-launcher-uncompleted-count",className:"userflowjs-checklist-launcher-uncompleted-count"},0===m?e.createElement(u,null):m,e.createElement("div",{className:"userflowjs-a11y-only"},"uncompleted tasks")))))},g=({session:t,checklistExpanded:s})=>{const{version:o}=t,n=o.checklist,r=t.locale?t.locale.standardLocaleId:t.version.theme.languageId;e.useEffect((()=>{i.changeLanguage(r)}),[r]);const[c,a]=e.useState(!1);return s?e.createElement(y,{session:t,initialAutoFocus:c,setInitialAutoFocus:a}):n.launcherEnabled?e.createElement(L,{session:t,initialAutoFocus:c,setInitialAutoFocus:a}):null},y=({session:t,initialAutoFocus:n,setInitialAutoFocus:i})=>{const a=c(),[l,u]=e.useState(null),{version:d}=t,p=d.checklist,k=f(d.theme),v=e.useMemo((()=>({...k,avatarType:s.NONE,bubblePlacement:k.checklistPlacement,bubbleX:k.checklistX,bubbleY:k.checklistY,bubbleWidth:k.checklistWidth})),[k]);return e.useEffect((()=>{const e=l?.ownerDocument.defaultView;if(!e)return;const t=e=>{"Escape"===e.key&&(i(!0),a.hideChecklist())};return e.addEventListener("keydown",t),()=>e.removeEventListener("keydown",t)}),[l,i,a]),e.createElement(m,null,e.createElement(r,{company:t.flow.company,theme:v,position:"fixed",stepAppearance:o.BUBBLE,zIndex:k.checklistZIndex,autoHide3pEnabled:!0,backgroundImageUrl:p.backgroundAsset&&p.backgroundAsset.assetUrl,bubbleFrameRootRef:u},e.createElement("div",{role:"dialog","aria-label":"Checklist"},e.createElement(E,{session:t,initialAutoFocus:n}),e.createElement(h,{draftMode:t.draftMode,minimize:e=>{i(0===e.detail),a.hideChecklist()}}))))},L=({session:t,initialAutoFocus:s,setInitialAutoFocus:o})=>{const r=c(),[i,a]=e.useState(!1),[l,u]=e.useState(null),{version:m}=t,d=m.checklist,h=f(m.theme);return e.useEffect((()=>{i&&l&&s&&l.focus()}),[r,l,i,s]),e.createElement(w,{position:"fixed",theme:h,onClick:e=>{o(0===e.detail),r.showChecklist()},onVisibleChange:a,buttonRef:u,text:d.launcherText,uncompletedCount:n(t)})};export default g;export{g as ChecklistApp};
package/ChecklistUI.js ADDED
@@ -0,0 +1 @@
1
+ import{r as e}from"./vendor.react.js";import{E as t,v as s}from"./userflow.js";import{u as l}from"./client-context.js";import{u as o}from"./vendor.react-i18next.js";import{o as n}from"./vendor.obj-str.js";import{a as c,A as a,L as r,d as u}from"./Icons.js";import{h as i,a as b,r as m,R as d}from"./BubbleToolbar.js";import{a as k}from"./flow-condition-types.js";const f=e.forwardRef((({elProps:t,onClick:s,onCheckmarkClick:l,completed:o,disabled:r,name:u,text:i,active:b,htmlAttributes:m,children:d},k)=>{const f=e.useRef(o);return e.createElement("button",{...t,ref:k,"data-testid":"bubble-task",tabIndex:s?0:-1,className:n({"userflowjs-bubble-task":!0,"userflowjs-bubble-task--completed":!!o,"userflowjs-bubble-task--just-completed":!f.current&&!!o,"userflowjs-bubble-task--disabled":!o&&!!r,"userflowjs-bubble-task--clickable":!!s,"userflowjs-bubble-task--active":!!b}),onClick:s,...m},e.createElement("div",{className:"userflowjs-bubble-task__checkmark",onClick:l},o&&e.createElement(c,null)),e.createElement("div",{className:"userflowjs-bubble-task__content"},e.createElement("div",{className:"userflowjs-bubble-task__name"},u),e.createElement("div",{className:"userflowjs-bubble-task__text"},i)),e.createElement("div",{className:"userflowjs-bubble-task__arrow"},!o&&e.createElement("div",{className:"userflowjs-rtl-mirrored"},e.createElement(a,null))),d)})),E=({task:t,previousTasksCompleted:s})=>{const o=l(),{session:n}=R(),c=n.version.checklist,[a,r]=e.useState((()=>o.taskIsUnacked(t.cvid)));e.useEffect((()=>{if(!a)return;const e=window.setTimeout((()=>r(!1)),500);return()=>window.clearTimeout(e)}),[a]);const u=n.taskCompletions.some((({taskCvid:e})=>e===t.cvid)),m=!a&&u;e.useEffect((()=>{m&&o.ackCompletedTask(t.cvid)}),[o,m,t.cvid]);const d=c.completeInOrder&&!s,E=d||0===t.actions.length&&m?void 0:()=>{o.send({kind:"ClickChecklistTask",sessionId:n.id,taskCvid:t.cvid},{batch:!0}),t.actions.length>0&&(m||!t.completesOnClick)&&o.hideChecklist(),i(o,n,t.actions)};return e.createElement(f,{onClick:E,name:e.createElement(b,{doc:t.name,lookupAttribute:k(n.data)}),text:e.createElement(b,{doc:t.text,lookupAttribute:k(n.data)}),completed:m,disabled:d})},p=({completedCount:t,taskCount:s})=>{const l=0===s?0:Math.min(100,Math.round(t/s*100));return e.createElement("div",{className:"userflowjs-bubble-checklist-progress"},e.createElement("div",{className:"userflowjs-bubble-checklist-progress-bg"},e.createElement("div",{className:"userflowjs-bubble-checklist-progress-text"},l,"%")),e.createElement("div",{className:"userflowjs-bubble-checklist-progress-fill",style:{width:`${l}%`}},e.createElement("div",{className:"userflowjs-bubble-checklist-progress-text"},l,"%")))},w=()=>{const{t:c}=o(),a=l(),i=R(),{session:b}=i,{version:f}=b,w=f.checklist,{dispatch:v}=F(),j=b.taskCompletions.length,C=w.tasks.length,h=j===C;let N=!0,x=w.tasks,S=[],g=i.currentSectionName,y=!1;if(w.sectionsEnabled){let e=null;const t=Array.from(w.tasks).sort(((e,t)=>e.sectionName.localeCompare(t.sectionName)));for(const s of t)s.sectionName!==e&&(S.push(s.sectionName),e=s.sectionName);g&&S.includes(g)||(g=S[0]),x=t.filter((e=>e.sectionName===g)),y=x.some((e=>{const t=b.taskCompletions.some((({taskCvid:t})=>t===e.cvid));return e.blocksNextSection&&!t}))}const _=null==g?-1:S.indexOf(g),T=e=>{const t=_+e;if(t>=0&&t<=S.length-1){const e=S[t];s.setItem("currentChecklistSectionName:"+b.id,e),v({kind:"setCurrentSection",sectionName:e})}};return e.createElement(e.Fragment,null,!m(w.content)&&e.createElement("div",{className:"userflowjs-bubble-content"},e.createElement(d,{doc:w.content,lookupAttribute:k(b.data)})),e.createElement(p,{completedCount:j,taskCount:C}),w.sectionsEnabled&&e.createElement("div",{className:"userflowjs-bubble-section-name"},g||"First section"),e.createElement("div",{className:"userflowjs-bubble-tasks"},x.map((t=>{const s=N;return b.taskCompletions.some((({taskCvid:e})=>e===t.cvid))||(N=!1),e.createElement(E,{key:t.id,task:t,previousTasksCompleted:s})}))),w.sectionsEnabled&&e.createElement("div",{className:"userflowjs-bubble-section-buttons"},e.createElement("button",{className:"userflowjs-bubble-section-button",onClick:()=>T(-1),disabled:_<=0},e.createElement(r,null),e.createElement("span",null,c("checklist.previousSection"))),e.createElement("button",{className:"userflowjs-bubble-section-button",onClick:()=>T(1),disabled:_>=S.length-1||y},e.createElement("span",null,c("checklist.nextSection")),e.createElement(u,null))),!f.closeDisabled&&e.createElement("div",{className:"userflowjs-bubble-dismiss-row"},e.createElement("button",{className:n({"userflowjs-bubble-dismiss-button":!0,"userflowjs-bubble-dismiss-button--completed":h}),onClick:()=>h?a.endFlow(b,{endReason:t.USER_CLOSED}):v({kind:"showClose"})},c("checklistDismiss.button"))))},v=()=>{const{t:s}=o(),n=l(),{dispatch:c}=F(),{session:a}=R();return e.createElement("div",{role:"alert"},e.createElement("div",{className:"userflowjs-bubble-content"},e.createElement("p",null,e.createElement("b",null,s("checklistDismiss.title")),e.createElement("br",null),s("checklistDismiss.text"))),e.createElement("div",{className:"userflowjs-bubble-buttons"},e.createElement("button",{className:"userflowjs-bubble-button userflowjs-bubble-button--primary",onClick:()=>n.endFlow(a,{endReason:t.USER_CLOSED})},e.createElement("div",{className:"userflowjs-bubble-button-text",role:"presentation"},s("checklistDismiss.yes"))),e.createElement("button",{className:"userflowjs-bubble-button userflowjs-bubble-button--default",onClick:()=>c({kind:"showFlow"})},e.createElement("div",{className:"userflowjs-bubble-button-text",role:"presentation"},s("checklistDismiss.cancel")))))};function j(e){const t=e?.querySelector(".userflowjs-bubble-task--clickable:not(.userflowjs-bubble-task--completed)")||e?.querySelector(".userflowjs-bubble-task--clickable")||e?.querySelector('button:not([tabIndex="-1"])');t&&"function"==typeof t.focus&&t.focus()}const C=({session:t,initialAutoFocus:o})=>{const n=l(),c=e.useRef(null),[a,r]=e.useReducer(N,void 0,(()=>({...h,session:t,currentSectionName:s.getItem("currentChecklistSectionName:"+t.id),autoFocusRequested:!!o}))),{session:u,contentType:i}=a;e.useEffect((()=>{u!==t&&r({kind:"updateSession",session:t})}),[u,t]);const b=e.useMemo((()=>({dispatch:r})),[r]);return e.useEffect((()=>{if(!a.autoFocusRequested)return;const e=c.current;e&&j(e),r({kind:"autoFocused"})}),[n,a.autoFocusRequested]),e.createElement(x.Provider,{value:b},e.createElement(S.Provider,{value:a},e.createElement("div",{ref:c},"close"===i?e.createElement(v,null):e.createElement(w,null))))},h={contentType:"flow"};function N(e,t){switch(t.kind){case"updateSession":return{...e,session:t.session};case"showFlow":return{...e,contentType:"flow",autoFocusRequested:!0};case"showClose":return{...e,contentType:"close",autoFocusRequested:!0};case"setCurrentSection":return{...e,currentSectionName:t.sectionName};case"autoFocused":return{...e,autoFocusRequested:!1}}}const x=e.createContext(null),S=e.createContext(null);function F(){return e.useContext(x)}function R(){return e.useContext(S)}export{C,j as f};
package/DynamicIcon.js ADDED
@@ -0,0 +1 @@
1
+ import{r}from"./vendor.react.js";import{j as e,k as a,i as s,g as i,l,e as o,m as t,n,o as c,p as g,q as u,h as d,r as m,s as p,t as h,u as f,v,w}from"./vendor.fortawesome.pro-regular-svg-icons.js";import{a as y,b as j,c as x,d as b,e as k,g as q,h as E,i as $,j as z,k as B}from"./vendor.fortawesome.pro-solid-svg-icons.js";const C=({icon:e,size:a})=>{a=a||16;const s="string"==typeof e&&D[e]?D[e]:e;if("string"==typeof s)return r.createElement("img",{"aria-hidden":"true",src:s,width:a,height:a,style:{objectFit:"contain"}});{const e=s.icon[0],i=s.icon[1],l=s.icon[4];return r.createElement("svg",{"aria-hidden":"true",role:"img",xmlns:"http://www.w3.org/2000/svg",width:a,height:a,viewBox:`0 0 ${e} ${i}`},r.createElement("path",{fill:"currentColor",d:String(l)}))}},D={"regular/calendar-day":e,"regular/comment-alt":a,"regular/comments-alt":s,"regular/envelope":i,"regular/exclamation-triangle":l,"regular/external-link":o,"regular/file-alt":t,"regular/graduation-cap":n,"regular/info-circle":c,"regular/lightbulb":g,"regular/pencil":u,"regular/phone":d,"regular/play-circle":m,"regular/question-circle":p,"regular/shoe-prints":h,"solid/shoe-prints":y,"solid/file-invoice":j,"solid/receipt":x,"solid/university":b,"solid/users":k,"solid/stars":q,"regular/tasks":f,"regular/user":v,"regular/users":w,"solid/exclamation-triangle":E,"solid/info-circle":$,"solid/play-circle":z,"solid/question-circle":B};export{C as D};
@@ -0,0 +1 @@
1
+ import{r as e}from"./vendor.react.js";import{i as t}from"./vendor.is-hotkey.js";import{o as n}from"./vendor.obj-str.js";import{r as o,b as s,g as a,d as r,o as l,e as i,f as m,h as c,j as d,k as u,l as p}from"./flow-condition-types.js";import{a as v}from"./userflow.js";import{u as f}from"./client-context.js";import{u as g}from"./logomark.js";import{B as h}from"./BuilderBar.js";import"./vendor.object-assign.js";import"./vendor.date-fns.js";import"./vendor.phoenix.js";import"./vendor.uuid.js";import"./vendor.i18next.js";import"./vendor.react-i18next.js";import"./vendor.babel.runtime.js";import"./vendor.react-dom.js";import"./vendor.scheduler.js";import"./stylesheets.js";import"./vendor.fortawesome.pro-light-svg-icons.js";import"./DynamicIcon.js";import"./vendor.fortawesome.pro-regular-svg-icons.js";import"./vendor.fortawesome.pro-solid-svg-icons.js";const w=t("alt+s"),b=t("escape"),y=t("u"),E=({state:t})=>{const{mode:c,elementType:d}=t,E=f(),L=e.useRef(null),[S,N]=e.useState(!1),M=e.useRef(null),[k,R]=e.useState(null),[D,F]=e.useState((()=>x())),T=e.useCallback((async(e,t)=>{if(e&&t){const n=L.current?.getFrame();n&&M.current&&(M.current.classList.add("userflowjs-element-selection-box--no-transition"),n.style.display="none",n.offsetWidth),m(),E.setSessionStorageState((e=>({...e,elementSelection:{...e.elementSelection,mode:"done"}})));const l=o(e),i=0,c=0,d=Math.round(s()),u=Math.round(a()),p=await E.getTargetEnv().captureScreenshot(i,c,d,u),v=e=>Math.round(e/r(1));t={...t,screenshotDataUrl:p,targetX1:v(l.left),targetY1:v(l.top-c),targetX2:v(l.right),targetY2:v(l.bottom-c),screenshotWidth:d,screenshotHeight:u}}E.setSessionStorageState((e=>({...e,activeApp:null,elementSelection:null}))),E.getTargetEnv().postBuilderMessage({kind:"userflow:selectElementResult",selectorData:t})}),[E]),A=e.useCallback((e=>E.setSessionStorageState((t=>({...t,elementSelection:{...t.elementSelection,mode:e}})))),[E]);return e.useEffect((()=>{if(!S||!L.current)return;const e=L.current.getFrame(),t=L.current.getRootEl();let n=t&&t.ownerDocument&&t.ownerDocument.defaultView;n===window&&(n=null);let f=null,g=null,h=null,E=null;const x=document.getElementById("userflow-ui"),N={capture:!0},k=()=>{window.cancelAnimationFrame(F);let e=null,t=null,n=null;if(g&&!x.contains(g)){let o=null,s=g;for(;s;){{const e=s.getBoundingClientRect();if(0===e.width&&0===e.height){s=j(s);continue}}if(o=u(s,{elementType:d}),o)break;s=j(s)}o?(t=o.el,e=o.selector):n=d===v.INPUT?"No text input found here":"Sorry, we can't select that element (yet!)"}h=t,f=e,R(n),C()};let F;const B=()=>{window.cancelAnimationFrame(F),F=window.requestAnimationFrame(k)},C=()=>{window.cancelAnimationFrame($);const e=M.current;if(!e)return;m();const t=r(s()),n=r(a());let l=n/2,i=t/2,c=n/2,d=t/2;let u=2,v=2,f=2,g=2;if(h){const e=o(h),s=window.getComputedStyle(h);l=Math.max(0,e.top),i=Math.max(0,t-e.right),c=Math.max(0,n-e.bottom),d=Math.max(0,e.left),u=Math.max(2,p(s.borderTopLeftRadius)),v=Math.max(2,p(s.borderTopRightRadius)),f=Math.max(2,p(s.borderBottomLeftRadius)),g=Math.max(2,p(s.borderBottomRightRadius)),E=h}else if(E){const e=o(E);l=Math.max(0,e.top+e.height/2),i=Math.max(0,t-e.right+e.width/2),c=Math.max(0,n-e.bottom+e.height/2),d=Math.max(0,e.left+e.width/2)}e.style.top=`${l}px`,e.style.right=`${i}px`,e.style.bottom=`${c}px`,e.style.left=`${d}px`,e.style.borderTopLeftRadius=`${u}px`,e.style.borderTopRightRadius=`${v}px`,e.style.borderBottomLeftRadius=`${f}px`,e.style.borderBottomRightRadius=`${g}px`,h?document.body.classList.remove("userflowjs-body-with-element-selection--none"):document.body.classList.add("userflowjs-body-with-element-selection--none")};let $;const P=()=>{window.cancelAnimationFrame($),$=window.requestAnimationFrame(C)},I=e=>{if(w(e))return e.preventDefault(),void("select"===c?A("navigate"):"navigate"===c&&A("select"));if(b(e)&&"select"===c)return e.preventDefault(),void T(null,null);if(y(e)&&h){const t=j(h);if(t)return e.preventDefault(),g=t,void k()}},U=e=>{const t=e.composedPath()[0];t&&t!==h&&"BODY"!==t.tagName&&"HTML"!==t.tagName&&(g=t,B())},Y=()=>{g=null,B()};e&&e.addEventListener("mouseenter",Y);const V=e=>{e.preventDefault(),e.stopPropagation()},q=e=>{V(e)},H=e=>{V(e)},O=e=>{if(V(e),D){const t=e.target;if(!h||!h.contains(t))return void U(e)}f&&(T(h,f),X())};n&&n.addEventListener("keydown",I),"select"===c&&(document.body.addEventListener("mouseleave",Y),document.body.classList.add("userflowjs-body-with-element-selection"));const W=l((e=>{const t=e.ownerDocument.defaultView;t&&(t.addEventListener("keydown",I,N),"select"===c&&(t.addEventListener("scroll",P,N),e.addEventListener("mousemove",U,N),e.addEventListener("mousedown",q,N),e.addEventListener("focus",H,N),e.addEventListener("click",O,N)))}),(e=>{const t=e.ownerDocument.defaultView;t&&(t.removeEventListener("keydown",I,N),"select"===c&&(t.removeEventListener("scroll",P,N),i(e)||e.removeEventListener("mousemove",U,N),e.removeEventListener("mousedown",q,N),e.removeEventListener("focus",H,N),e.removeEventListener("click",O,N)))})),X=()=>{window.cancelAnimationFrame(F),window.cancelAnimationFrame($),document.body.removeEventListener("mouseleave",Y),n&&n.removeEventListener("keydown",I),e&&e.removeEventListener("mouseenter",Y),document.body.classList.remove("userflowjs-body-with-element-selection"),document.body.classList.remove("userflowjs-body-with-element-selection--none"),W()};return X}),[D,E,c,S,d,T,A]),g((()=>F(x()))),e.createElement(e.Fragment,null,e.createElement(h,{ref:L,onReadyChange:N,buttons:e.createElement(e.Fragment,null,"navigate"===c?e.createElement("button",{key:"select",className:"btn btn--default",onMouseDown:e=>{e.preventDefault(),e.stopPropagation(),A("select")}},e.createElement("span",{className:"hidden-lg-up"},"Select here"),e.createElement("span",{className:"hidden-md-down"},"Select element here (Alt + S)")):"select"===c?e.createElement("button",{key:"navigate",className:"btn btn--default",onMouseDown:e=>{e.preventDefault(),e.stopPropagation(),A("navigate")}},e.createElement("span",{className:"hidden-lg-up"},"Navigate"),e.createElement("span",{className:"hidden-md-down"},"Navigate to another page (Alt + S)")):null,("select"===c||"navigate"===c)&&e.createElement("button",{className:"btn btn--secondary-on-dark",onClick:()=>T(null,null)},"Cancel"))},"navigate"===c?e.createElement("div",{className:"status"},"Navigate to the page the element appears on"):k?e.createElement("div",{className:"error"},k):e.createElement("div",{className:"status"},D?e.createElement(e.Fragment,null,"Tap"," ",d===v.INPUT?"a text input":"an element"," ","to focus. Tap again to select."):e.createElement(e.Fragment,null,"Click"," ",d===v.INPUT?"a text input":"an element"," ","to select it"))),S&&("select"===c||"done"===c)&&e.createElement("div",{className:n({"userflowjs-element-selection-box":!0}),ref:M}))};function j(e){const t=e.parentNode;if(!t)return null;if(i(t))return t.host;if(!c(t))return null;if("BODY"===t.tagName){const e=d(t);return e||null}return t}function x(){return window.navigator.userAgent.includes("Mobile")}export default E;export{E as ElementSelectionApp};
package/FlowApp.js ADDED
@@ -0,0 +1 @@
1
+ import{r as e}from"./vendor.react.js";import{E as t,V as o,w as n,b as s,T as r,v as l,x as a,p as i,A as c,M as u,U as d}from"./userflow.js";import{m as p,d as m,R as f,B as b,i as h,g as w,u as g,c as E,h as v,S as k}from"./BubbleToolbar.js";import{a as y,z as j,g as T,m as R,r as S}from"./flow-condition-types.js";import{u as L,i as M}from"./client-context.js";import{u as x,r as F,F as C}from"./FlowChrome.js";import{e as N,f as I,g as B}from"./Icons.js";import{T as D}from"./Trigger.js";import{u as P}from"./vendor.react-i18next.js";import{u as q}from"./stylesheets.js";import"./vendor.object-assign.js";import"./vendor.phoenix.js";import"./vendor.uuid.js";import"./vendor.obj-str.js";import"./vendor.fortawesome.react-fontawesome.js";import"./vendor.fortawesome.fontawesome-svg-core.js";import"./vendor.prop-types.js";import"./vendor.fortawesome.pro-solid-svg-icons.js";import"./vendor.date-fns.js";import"./vendor.i18next.js";import"./logomark.js";import"./vendor.react-dom.js";import"./vendor.scheduler.js";import"./vendor.babel.runtime.js";const A=()=>{const{t:o}=P(),n=L(),{dispatch:s,restart:r}=re(),{session:l,step:a}=le(),i="userflowjs-bubble-button userflowjs-bubble-button--default userflowjs-bubble-menu__item";return e.createElement("div",{role:"dialog","aria-modal":oe(a)?"true":void 0,"aria-label":"Guide menu"},e.createElement("div",{className:"userflowjs-bubble-menu__title"},o("menu.title")),e.createElement("button",{className:i,onClick:()=>n.endFlow(l,{endReason:t.USER_CLOSED})},o("menu.close")),l.version.restartEnabled&&e.createElement("button",{className:i,onClick:r},o("menu.restart")),e.createElement("button",{className:i,onClick:()=>s({kind:"showFlow"})},o("menu.back")))},_=({progress:t})=>{const o={width:100*parseFloat(t||"0")+"%"};return e.createElement("div",{className:"userflowjs-bubble-progress"},e.createElement("div",{className:"userflowjs-bubble-progress__fill",style:o}))},O=()=>{const s=L(),{session:r,step:l,muted:a,shouldLabelDialog:i}=le(),{version:c}=r,u=l.theme||r.version.theme,{dispatch:d}=re(),h=c.steps[0],w=h&&h.id===l.id,g=w&&"1"===l.progress,E=e.useMemo((()=>l.content&&p(m(l.content),{buttons:l.buttons,questions:l.questions})),[l.content,l.buttons,l.questions]);return e.createElement("div",{key:l.id,role:"alertdialog","aria-modal":oe(l)?"true":void 0,"aria-label":i?"Guide":void 0},!g&&e.createElement(_,{progress:l.progress}),e.createElement("div",{id:"userflowjs-bubble-content",className:"userflowjs-bubble-content"},e.createElement(f,{doc:E,lookupAttribute:y(r.data),buttons:l.buttons,questions:l.questions})),e.createElement(b,{draftMode:r.draftMode,muted:a,toggleMuted:u.voiceType!==o.NONE?()=>d({kind:"toggleMuted"}):void 0,close:c.closeDisabled?void 0:()=>u.flowXButtonBehavior===n.DISMISS||w?s.endFlow(r,{endReason:t.USER_CLOSED}):d({kind:"showMenu"})}))};function U(e,t){if(!e)return"";"string"==typeof e&&(e=m(e));const o=[],n=/[.!?;,]$/;function s(){const e=(o[o.length-1]||"").trim();e&&!e.match(n)&&o.push(".")}function r(e){e.forEach((e=>function(e){if(h(e)){if(e.text&&!e.silent){const t=e.text.split("\n");t.forEach(((e,n)=>{o.push(e),n<t.length-1&&(s(),o.push("\n"))}))}}else switch(e.type){case"attribute":{const n=w(e,t);n&&o.push(n);break}default:r(e.children),["link"].includes(e.type)||(s(),o.push("\n\n"))}}(e)))}return r(e.children),o.join("").trim().replace(new RegExp(String.fromCharCode(160),"g")," ").replace(new RegExp(String.fromCharCode(8),"g"),"")}const V=({bubbleFrame:t,theme:n})=>{const s=L(),{dispatch:r}=re(),{muted:l,session:a,step:i}=le(),c=s.getAudio();e.useEffect((()=>{const e=()=>{r({kind:"speechPlaying"})},t=()=>{r({kind:"speechStopped"})};return c.addEventListener("playing",e),c.addEventListener("ended",t),c.addEventListener("pause",t),()=>{c.removeEventListener("playing",e),c.removeEventListener("ended",t),c.removeEventListener("pause",t),c.pause(),c.src="",r({kind:"speechStopped"})}}),[r,c]),e.useEffect((()=>{if(s.audioReady)return;const e=t&&"IFRAME"===t.tagName?t.contentWindow:null;const o=()=>{window.removeEventListener("mousedown",n),e&&e.removeEventListener("mousedown",n)},n=()=>{o(),s.playAudio(null)};return window.addEventListener("mousedown",n),e&&e.addEventListener("mousedown",n),o}),[t,s]);const u=e.useRef(a),d=e.useRef(n),p=e.useRef(i);return e.useEffect((()=>{u.current=a,d.current=n,p.current=i}),[a,n,i]),e.useEffect((()=>{if(!s.audioReady||l)return void s.pauseAudio();let e=!1;return async function(e,t,n,s){if(n.voiceType===o.SYNTHETIC&&"string"==typeof n.syntheticVoice&&s.content){e.ensureIdentified();const o=y(t.data),r=U(s.content,o);return e.getStepSpeech(n.syntheticVoice,r)}if(n.voiceType===o.MANUAL&&s.speechAsset)return s.speechAsset.assetUrl;return null}(s,u.current,d.current,p.current).then((t=>{t&&!e&&s.playAudio(t)})),()=>{e=!0}}),[l,s,i.id]),null};const Y=e.forwardRef(((t,o)=>{const n=N();return e.createElement("div",{ref:o,className:"userflowjs-out-of-viewport-pointer",style:{zIndex:n+2}},e.createElement(I,null))}));function z(e,t){const o=e.current;o&&(o.classList.toggle("userflowjs-out-of-viewport-pointer--visible",null!=t),t&&(o.style.left=t.left+"px",o.style.top=t.top+"px",o.classList.toggle("userflowjs-out-of-viewport-pointer--visible-up","up"===t.direction),o.classList.toggle("userflowjs-out-of-viewport-pointer--visible-down","down"===t.direction)))}const G=()=>{const{step:t}=le();return e.createElement(e.Fragment,null,t.beacons.map((t=>e.createElement(X,{key:t.id,beacon:t}))))},X=({beacon:t})=>{const{session:o}=le(),n=N(),s=e.useRef(null),r=e.useRef(null),l=g(t.hiddenCondition),a=e.useMemo((()=>R(t.selector,o.data)),[t.selector,o.data]),i=e.useCallback((({targetRect:e,clipEl:o,viewportClipRect:n})=>{const l=function({beacon:e,beaconRef:t,clipEl:o,viewportClipRect:n,targetRect:s}){if(!t.current)return null;if(0===s.width||0===s.height)return null;const r=16,l=16,a=S(o);let i=0,c=0;switch(e.placement){case"top-left":case"left":case"bottom-left":i=s.left;break;case"top":case"center":case"bottom":i=s.left+s.width/2;break;default:i=s.left+s.width}switch(e.placement){case"left":case"center":case"right":c=s.top+s.height/2;break;case"bottom-left":case"bottom":case"bottom-right":c=s.top+s.height;break;default:c=s.top}i-=r/2,c-=l/2,i+=e.offsetX,c+=e.offsetY,i=Math.max(i,a.left-(o===document.documentElement?0:o.scrollLeft)),c=Math.max(c,a.top-(o===document.documentElement?0:o.scrollTop));const u=i+r,d=c+l,p=Math.min(32,.5*l);let m;m=d<n.top+p?"up":c>n.bottom-p?"down":null;return{top:c,right:u,bottom:d,left:i,width:r,height:l,pointerSubjectPosition:{direction:m,left:i,width:r},visible:null==m}}({beacon:t,beaconRef:s,clipEl:o,viewportClipRect:n,targetRect:e}),a=l&&function({subjectPosition:e,pointerRef:t,viewportClipRect:o}){const n=t.current;if(!n)return null;const s=n.getBoundingClientRect(),r=j(T());let l,a,i=e.direction;return null==i?null:("down"===i&&o.bottom<s.height/2?i="up":"up"===i&&o.top>r&&(i="down"),l=e.left+e.width/2-s.width/2,a="down"===i?o.bottom-s.height:o.top,{direction:i,left:l,top:a})}({subjectPosition:l.pointerSubjectPosition,pointerRef:r,viewportClipRect:n});F((()=>{H(s,l),z(r,a)}))}),[t]),c=e.useCallback((()=>{H(s,null),z(r,null)}),[]);return x({selector:l?null:a,targetMoved:i,targetLost:c}),e.createElement(e.Fragment,null,e.createElement("div",{ref:s,className:"userflowjs-beacon userflowjs-beacon--pulse userflowjs-beacon--for-flow userflowjs-fixed-widget",style:{zIndex:n+2}},e.createElement("div",{className:"userflowjs-beacon__ring"}),e.createElement("div",{className:"userflowjs-beacon__ring"})),e.createElement(Y,{ref:r}))};function H(e,t){const o=e.current;o&&(o.classList.toggle("userflowjs-fixed-widget--visible",null!=t),t&&(o.style.transform=`translate3d(${t.left}px, ${t.top}px, 0)`,o.style.visibility=t.visible?"visible":"hidden"))}const W=()=>{const{t:o}=P(),n=L(),{restart:l}=re(),{session:a,step:i}=le(),c=i.theme||a.version.theme,u=i.selector,d=!u||u.type===s.AUTO&&!u.autoData,p=()=>n.endFlow(a,{endReason:t.USER_CLOSED});return e.createElement(e.Fragment,null,e.createElement(b,{draftMode:a.draftMode,close:p}),a.draftMode&&d?e.createElement("div",{className:"userflowjs-bubble-content"},e.createElement("div",{className:"userflowjs-bubble-alert p-like"},e.createElement("span",{className:"userflowjs-bubble-alert__label"},"Preview-only tip"),"No tooltip target selected yet. Please go back to the Builder and select a tooltip target in ",e.createElement("b",null,"Step ",i.idx+1)," of"," ",e.createElement("b",null,a.flow.name),".")):a.draftMode&&c.tooltipMissingBehavior===r.END?e.createElement("div",{className:"userflowjs-bubble-content"},e.createElement("div",{className:"userflowjs-bubble-alert p-like"},e.createElement("p",null,e.createElement("span",{className:"userflowjs-bubble-alert__label"},"Preview-only tip"),"The tooltip target element in ",e.createElement("b",null,"Step ",i.idx+1)," of"," ",e.createElement("b",null,a.flow.name)," was not found within"," ",c.tooltipMissingToleranceSeconds," ",1===parseFloat(c.tooltipMissingToleranceSeconds)?"second":"seconds","."),e.createElement("p",null,"For regular users, the flow will auto-dismiss when this happens."),e.createElement("p",null,"If you are on the right page, then try reselecting the element in the Builder."),e.createElement("p",null,"Read more in our"," ",e.createElement("a",{href:"https://userflow.com/docs/trouble/element-not-found",target:"_blank",rel:"noopener noreferrer"},"Element not found guide"),"."))):e.createElement(e.Fragment,null,e.createElement("div",{className:"userflowjs-bubble-content"},a.draftMode&&e.createElement("div",{className:"userflowjs-bubble-alert p-like"},e.createElement("span",{className:"userflowjs-bubble-alert__label"},"Preview-only tip"),"The tooltip target element in ",e.createElement("b",null,"Step ",i.idx+1)," of"," ",e.createElement("b",null,a.flow.name)," was not found on the page. If you are on the right page, then try reselecting the element in the Builder."),e.createElement("p",null,e.createElement("b",null,o("tooltipTargetMissing.line1"))),e.createElement("p",null,o("tooltipTargetMissing.line2"))),e.createElement("div",{className:"userflowjs-bubble-buttons"},e.createElement(E,{appearance:"primary",onClick:l,text:o("menu.restart")}),e.createElement(E,{appearance:"default",onClick:p,text:o("menu.close")}))))},$=({session:o,checklistSession:n,resourceCenterEmbedsChecklist:s})=>{const d=L(),[p,m]=e.useState(!1),[f,b]=e.useState(null),[h,w]=e.useReducer(Q,void 0,(()=>{const e=o,t=Z(e);return{...J,session:e,step:t,muted:!!l.getItem("flowsMuted"),autoFocusRequested:te(t)}})),{session:g,step:E,speechPlaying:y,contentType:j}=h,{version:T}=g,S=oe(E);let x=0;E.questions.some((e=>e.type===i.NPS))&&(x=420);const F=q(E.theme||T.theme),N=e.useMemo((()=>{let e=F.bubbleY;const t=n?.version.theme;return!s&&n&&t&&n.version.checklist?.launcherEnabled&&E.appearance===a.BUBBLE&&t.checklistLauncherPlacement===F.bubblePlacement&&(F.avatarType===c.NONE||t.checklistLauncherX<F.bubbleX+F.avatarSize)&&(e=Math.max(F.bubbleY,t.checklistLauncherY+t.checklistLauncherHeight+F.bubbleY)),{...F,bubbleWidth:Math.max(F.bubbleWidth,x),bubbleY:e}}),[s,n,E.appearance,F,x]);e.useEffect((()=>{g!==o&&w({kind:"updateSession",session:o});const e=e=>{e.session.id===g.id&&w({kind:"goToStep",stepId:e.step.id})};return d.on("gotostep",e),()=>{d.off("gotostep",e)}}),[d,g,o]);const I=e.useMemo((()=>({dispatch:w,restart:()=>{d.goToStep(g,ee(g)),w({kind:"showFlow"})}})),[d,w,g]),D=e.useMemo((()=>E.selector&&R(E.selector,g.data)),[E.selector,g.data]),P=e.useCallback((()=>{v(d,g,E.actions)}),[d,g,E.actions]);e.useEffect((()=>{h.muted?l.setItem("flowsMuted","true"):l.removeItem("flowsMuted")}),[h.muted]);const _=g.locale?g.locale.standardLocaleId:N.languageId;e.useEffect((()=>{M.changeLanguage(_)}),[_]);const[U,V]=e.useState(!1),Y=e.useCallback((e=>{V(e),e&&N.tooltipMissingBehavior===r.END&&!g.draftMode&&d.endFlow(g,{endReason:t.TOOLTIP_TARGET_MISSING})}),[d,g,N.tooltipMissingBehavior]);return e.useEffect((()=>{if(!p||!h.autoFocusRequested)return;d.originalActiveElement||d.originalActiveElement===f?.ownerDocument.defaultView?.frameElement||(d.originalActiveElement=document.activeElement);let e=f?.querySelector('button:not([tabindex="-1"]):not(.userflowjs-bubble-toolbar-button), [tabindex]:not([tabindex="-1"]):not(.userflowjs-bubble-toolbar-button), input, textarea');if(e&&e.matches(".userflowjs-bubble-buttons button:not(.userflowjs-bubble-button--primary)")){const t=f?.querySelector(".userflowjs-bubble-buttons .userflowjs-bubble-button--primary");t&&(e=t)}e&&"function"==typeof e.focus&&e.focus({preventScroll:!0}),w({kind:"autoFocused"})}),[d,f,p,h.autoFocusRequested]),e.useEffect((()=>{const e=f?.ownerDocument.defaultView;if(!e)return;const t=()=>{w({kind:"focusOut"}),delete d.originalActiveElement},o=()=>{w({kind:"focusIn"})};return window.addEventListener("focusin",t),e.addEventListener("focusin",o),()=>{window.removeEventListener("focusin",t),e.removeEventListener("focusin",o)}}),[f,d]),e.useEffect((()=>{if(!S||!f)return;const e=f.ownerDocument.defaultView,o=e?e.document:document,n=e=>{if("Escape"!==e.key||T.closeDisabled){if("Tab"===e.key){const t=f.querySelectorAll('button:not([tabindex="-1"]), [tabindex]:not([tabindex="-1"]), input, textarea'),n=t[0],s=t[t.length-1],r=o.activeElement;e.shiftKey?r===n&&(e.preventDefault(),s.focus()):r===s&&(e.preventDefault(),n.focus())}}else d.endFlow(g,{endReason:t.USER_CLOSED})};return window.addEventListener("keydown",n),e?.addEventListener("keydown",n),()=>{window.removeEventListener("keydown",n),e?.removeEventListener("keydown",n)}}),[S,d,g,f,T.closeDisabled]),e.useEffect((()=>{if(h.scrollToTopRequested){if(f?.ownerDocument.defaultView?.frameElement){const e=f?.ownerDocument.body;e&&(e.scrollTop=0)}w({kind:"scrolledToTop"})}}),[h.scrollToTopRequested,f]),e.createElement(ne.Provider,{value:I},e.createElement(se.Provider,{value:h},e.createElement(k.Provider,{value:g},e.createElement(B,null,e.createElement(C,{company:g.flow.company,theme:N,position:"fixed",stepKey:E.crossVersionId,stepAppearance:E.appearance,width:E.width,backgroundImageUrl:"flow"===j&&!U&&E.backgroundAsset?E.backgroundAsset.assetUrl:null,tooltipSelector:D,tooltipPlacement:E.tooltipPlacement,backdrop:E.backdrop,tooltipTargetBlocked:E.tooltipTargetBlocked,backdropPadding:E.backdropPadding,onTooltipTargetClick:P,onTooltipTargetMissingChange:Y,onModalBackdropClick:E.appearance!==a.MODAL||N.modalBackdropOnclick!==u.DISMISS||T.closeDisabled?void 0:()=>d.endFlow(g,{endReason:t.USER_CLOSED}),speaking:y,minimizeOnAvatarClick:!0,autoHide3pEnabled:!0,onVisibleChange:m,bubbleFrameRootRef:b,rootChildren:t=>e.createElement(K,{...t,theme:N})},"menu"===j?e.createElement(A,null):U&&N.tooltipMissingBehavior!==r.BUBBLE?e.createElement(W,null):e.createElement(O,null))))))},K=({visible:t,bubbleFrame:o,theme:n})=>{const s=le(),{step:r}=s,l=s.session.currentStep&&s.session.currentStep.id,[a,i]=e.useState(!1),c=e.useRef(l);return e.useEffect((()=>{t?i(!0):c.current!==l&&i(!1),c.current=l}),[l,t]),e.createElement(e.Fragment,null,(t||a)&&"flow"===s.contentType&&e.createElement(e.Fragment,null,e.createElement(V,{bubbleFrame:o,theme:n}),e.createElement(G,null)),r.triggers.map((t=>e.createElement(D,{key:t.id,trigger:t}))))},J={muted:!1,speechPlaying:!1,contentType:"flow",autoFocusRequested:!1,hasFocus:!1,scrollToTopRequested:!1,shouldLabelDialog:!0};function Q(e,t){switch(t.kind){case"updateSession":{let o;return o=t.session.id===e.session.id&&t.session.version.steps.find((({crossVersionId:t})=>t===e.step.crossVersionId))||Z(t.session),{...e,session:t.session,step:o}}case"goToStep":{const o=e.session.version.steps.find((e=>e.id===t.stepId));return o?{...e,step:o,contentType:"flow",autoFocusRequested:e.hasFocus||te(o),scrollToTopRequested:!0,shouldLabelDialog:!e.hasFocus}:e}case"toggleMuted":return{...e,muted:!e.muted};case"speechPlaying":return{...e,speechPlaying:!0};case"speechStopped":return{...e,speechPlaying:!1};case"showFlow":return{...e,contentType:"flow",autoFocusRequested:!0,scrollToTopRequested:!0};case"showMenu":return{...e,contentType:"menu",autoFocusRequested:!0,scrollToTopRequested:!0};case"autoFocused":return{...e,autoFocusRequested:!1};case"focusIn":return{...e,hasFocus:!0};case"focusOut":return{...e,hasFocus:!1};case"scrolledToTop":return{...e,scrollToTopRequested:!1}}}function Z(e){const{currentStep:t}=e,{steps:o}=e.version;if(t){const e=o.find((({crossVersionId:e})=>e===t.crossVersionId));if(!e)throw new d("Session points to an unknown step: "+t.crossVersionId);return e}return ee(e)}function ee(e){const t=e.version.steps[0];if(!t)throw new d("Session has no current step and its version has no start step");return t}function te(e){return oe(e)}function oe(e){return e.appearance===a.MODAL||e.appearance===a.BUBBLE&&e.backdrop||e.appearance===a.TOOLTIP&&e.tooltipTargetBlocked}const ne=e.createContext(null),se=e.createContext(null);function re(){return e.useContext(ne)}function le(){return e.useContext(se)}export default $;export{$ as FlowApp,se as FlowStateContext,J as initialFlowState,oe as isStepModal,re as useFlowDispatch,le as useFlowState};
package/FlowChrome.js ADDED
@@ -0,0 +1 @@
1
+ import{r as t}from"./vendor.react.js";import{u as e,F as o,S as a}from"./logomark.js";import{c as l,x as r,A as i,b as n,y as s,B as c,z as u}from"./userflow.js";import{f as d,b as p}from"./BubbleToolbar.js";import{o as m}from"./vendor.obj-str.js";import{n as f,h as b,p as h,q as g,r as w,f as T,d as E,g as v,b as M,s as L,M as y,l as k}from"./flow-condition-types.js";import{a as R,g as j}from"./stylesheets.js";import{e as B}from"./Icons.js";import{u as O}from"./vendor.react-i18next.js";var P=new URL("avatar-frame.css",import.meta.url).href;let x=!1;const I=[];let N,_=[];function H(t){_.push(t)}function C(){I.forEach((t=>t())),_.length>0&&(_.forEach((t=>t())),_=[]),S()}function S(){x&&(N=window.requestAnimationFrame(C))}function D(){}function U({selector:e,targetMoved:o,targetLost:a,onTargetClick:l,onTargetMouseEnter:r,onTargetMouseLeave:i}){const n=t.useRef(o),s=t.useRef(a),c=t.useRef(l),u=t.useRef(r),d=t.useRef(i);t.useLayoutEffect((()=>{n.current=o,s.current=a,c.current=l,u.current=r,d.current=i})),t.useLayoutEffect((()=>{let t=null,o=null,a=null,l=!1;const r=()=>{t=null,o=null,a=null,s.current()};if(!e)return void r();const i=()=>{if(!a||!t)return;const e=w(t);var l,i;o&&(i=e,(l=o).left===i.left&&l.top===i.top&&l.width===i.width&&l.height===i.height)||(o=e,0===e.width&&0===e.height?r():n.current({targetEl:t,targetRect:o,clipEl:a,viewportClipRect:F(a)}))};let p=!1;const m=()=>{var t;p||(p=!0,t=i,I.push(t),1===I.length&&(x=!0,S(),window.addEventListener("scroll",D)))},T=()=>{p&&(p=!1,function(t){const e=I.indexOf(t);e>=0&&(I.splice(e,1),0===I.length&&(x=!1,window.cancelAnimationFrame(N),window.removeEventListener("scroll",D)))}(i))},E=()=>{c.current&&c.current()},v=()=>{u.current&&u.current()},M=()=>{d.current&&d.current()},L=()=>{const o=t;t=b(e)?e:h(e),l&&t===o||(o&&(o.removeEventListener("click",E),o.removeEventListener("mouseenter",v),o.removeEventListener("mouseleave",M)),t?(m(),t.addEventListener("click",E),t.addEventListener("mouseenter",v),t.addEventListener("mouseleave",M),a=g(t)):(T(),r())),l=!0};L();const y=f(L);return()=>{y.disconnect(),T(),t&&(t.removeEventListener("click",E),t.removeEventListener("mouseenter",v),t.removeEventListener("mouseleave",M))}}),[e])}function F(t){T();const e=E(v()),o=E(M());if(t&&t!==document.documentElement){const a=w(t);return{top:Math.max(0,a.top),right:Math.min(o,a.right),bottom:Math.min(e,a.bottom),left:Math.max(0,a.left)}}return{top:0,right:o,bottom:e,left:0}}const A=({company:f,theme:h,position:w,absoluteWidth:x,absoluteHeight:I,stepKey:N,stepAppearance:_,width:H,backgroundImageUrl:C,tooltipSelector:S,allowMissingTooltipTarget:D,tooltipPlacement:F,backdrop:A,tooltipTargetBlocked:K,backdropPadding:q,zIndex:Y,onTooltipTargetClick:X,onTooltipTargetMissingChange:J,onModalBackdropClick:Q,onVisibleChange:Z,speaking:tt,noIframe:et,MadeWithUserflow:ot,minimizeOnAvatarClick:at,autoHide3pEnabled:lt,bubbleFrameRootRef:rt,frameWrapperHtmlAttributes:it,rootChildren:nt,children:st})=>{const ct=w||"absolute",ut=F||null,dt=q||"0",pt=ot||z,mt=B(),ft="fixed"===ct?null!=Y?Y:mt+1:1,bt=ft-1,{i18n:ht}=O(),gt=ht.dir(),wt=t.useRef(null),Tt=t.useRef(null),Et=t.useRef(null),[vt,Mt]=t.useState(null),Lt=t.useRef(null),yt=t.useRef(null),kt=t.useRef(null),Rt=t.useRef(null),jt=t.useRef(null),Bt=t.useRef(null),Ot=t.useRef(null),Pt=t.useRef(null),xt=t.useRef(null);t.useLayoutEffect((()=>{const t=wt.current.style;t.animation="none",t.visibility="hidden",t.position="absolute",t.top="-99999px",t.left="-99999px"}),[]);const{loaded:It}=R(window,d,h),[Nt,_t]=t.useState(!1),[Ht,Ct]=t.useState(!1),St=It&&Nt&&Ht;let[Dt,Ut]=t.useState(!1);_!==r.BUBBLE&&(at=!1,Dt=!1),t.useEffect((()=>{Ut(!1)}),[N]);const Ft=t.useRef({appearance:null,width:null,theme:h,bubbleFrameHeight:0,backdrop:!1,backdropPadding:"0",prevTooltipTargetParams:null,tooltipTargetParams:null,desiredTooltipPlacement:null,tooltipPlacement:null,lastReportedTooltipTargetMissing:!1,tooltipTargetMissing:!1,tooltipTargetMissingTimeout:void 0,stepKeyScrolledIntoView:void 0,targetScrolledIntoView:null}),[At,Wt]=t.useState(null),zt=null!=At&&St;t.useEffect((()=>{Z&&Z(zt)}),[Z,zt]);const Vt=t.useCallback((t=>{Ft.current.lastReportedTooltipTargetMissing!==t&&(Ft.current.lastReportedTooltipTargetMissing=t,J&&J(t))}),[J]),Gt=t.useCallback((({forceAppearanceLayout:t,forceUpdatePosition:e}={})=>{const o=wt.current,a=Tt.current,n=Et.current,d=yt.current,p=Lt.current,m=kt.current,f=Rt.current,b=jt.current,w=Bt.current,y=Ot.current,R=Pt.current,j=xt.current;if(!(o&&a&&n&&vt&&d&&p&&m&&f&&b&&w&&y&&R&&j))return;if(!St)return;const B=Ft.current,{tooltipTargetParams:O}=B;T();let P=_,C=!1;P!==r.TOOLTIP||D||O||(B.tooltipTargetMissing?(P=r.BUBBLE,C=!0):P=null);const S=P!==B.appearance,U=H!==B.width;if((t||S||U||h!==B.theme||A!=B.backdrop||dt!=B.backdropPadding||ut!==B.desiredTooltipPlacement)&&(B.appearance=P,B.width=H,B.theme=h,B.backdrop=A,B.backdropPadding=dt,B.desiredTooltipPlacement=ut,e=!0,function({layoutState:{appearance:t,theme:e,backdrop:o,tooltipTargetMissing:a},width:l,position:n,absoluteWidth:c,root:u,bubble:d,bubbleFrameRoot:p,avatar:m,avatarNotch:f,modalBackdrop:b,dir:h}){const g="absolute"===n?c||1024:E(M()),{avatarSize:w,bubblePlacement:T}=e;let v=e.bubbleWidth,L=null,y=null,k="userflowjs-bubble-frame-root",R="hidden",j=null,B=null,O=null,P=null,x="userflowjs-bubble__avatar-notch",I="hidden",N=null,_=null,H=null,C=null,S="userflowjs-modal-backdrop";(t===r.MODAL||!a&&t===r.BUBBLE&&o)&&(S+=" userflowjs-modal-backdrop--visible");switch(t){case r.BUBBLE:if(e.avatarType!==i.NONE){R="",I="",T===s.TOP_LEFT||T===s.TOP_CENTER||T===s.TOP_RIGHT?(L=w+20,j=0,N=-40,x+=" userflowjs-bubble__avatar-notch--top"):(y=w+20,O=0,H=-40,x+=" userflowjs-bubble__avatar-notch--bottom");const t=T===s.TOP_LEFT||T===s.TOP_CENTER||T===s.BOTTOM_LEFT||T===s.BOTTOM_CENTER||T===s.CENTER;"ltr"===h&&t||"rtl"===h&&!t?(P=0,C=w,x+=" userflowjs-bubble__avatar-notch--left"):(B=0,_=w,x+=" userflowjs-bubble__avatar-notch--right")}break;case r.MODAL:v=e.modalWidth,k+=" userflowjs-bubble-frame-root--appearance-modal",e.avatarType!==i.NONE&&(R="",P=`calc(50% - ${w/2}px)`,j=-w/2);break;case r.TOOLTIP:v=e.tooltipWidth}null!=l&&(v=l);v=Math.min(v,g),u.classList.toggle("userflowjs-flow-chrome--position-absolute","absolute"===n),u.classList.toggle("userflowjs-flow-chrome--position-relative","relative"===n),u.classList.toggle("userflowjs-flow-chrome--position-fixed","fixed"===n),u.classList.toggle("userflowjs-flow-chrome--appearance-modal",t===r.MODAL);const D=null!=t&&t!==r.HIDDEN;u.style.position="",u.style.top="",u.style.left="",u.style.visibility=D?"":"hidden",u.style.animation=D?"":"none",V(d,"width",E(v)),V(d,"padding-top",L),V(d,"padding-bottom",y),p.className=k,V(m,"width",E(e.avatarSize)),V(m,"height",E(e.avatarSize)),m.style.visibility=R,V(m,"top",j),V(m,"right",B),V(m,"bottom",O),V(m,"left",P),f.className=x,f.style.visibility=I,V(f,"top",N),V(f,"right",_),V(f,"bottom",H),V(f,"left",C),b.className=S}({layoutState:B,width:H,position:ct,absoluteWidth:x,root:o,bubble:a,bubbleFrameRoot:vt,avatar:d,avatarNotch:p,modalBackdrop:j,dir:gt})),!et){const t=vt.offsetHeight,o=v()-2*(M()<800?0:16)-(P===r.BUBBLE&&h.avatarType!==i.NONE?20+h.avatarSize:0),a=Math.min(t,o);if(P&&a!==B.bubbleFrameHeight){if(B.bubbleFrameHeight=a,V(n,"height",E(a)),L(n)&&n.contentDocument){n.contentDocument.documentElement.style.overflowY=t<=o?"hidden":"scroll"}e=!0}}if(e&&P){let t=S;if(P===r.TOOLTIP){(B.tooltipTargetParams&&B.tooltipTargetParams.targetEl)!==(B.prevTooltipTargetParams&&B.prevTooltipTargetParams.targetEl)&&(t=!0)}B.prevTooltipTargetParams=B.tooltipTargetParams,function({layoutState:t,animateIn:e,position:o,absoluteWidth:a,absoluteHeight:l,desiredTooltipPlacement:i,root:n,bubble:d,tooltipNotch:p,tooltipBackdrop:m,tooltipBlockTop:f,tooltipBlockRight:b,tooltipBlockBottom:h,tooltipBlockLeft:g,dir:w}){const{appearance:T,theme:L,tooltipTargetParams:y,backdrop:R,backdropPadding:j}=t,{bubblePlacement:B}=L,O=16,P=L.tooltipNotchSize,x=10,{width:I,height:N}=d.getBoundingClientRect(),_="absolute"===o?a||1024:E(M()),H="absolute"===o?l||768:E(v());let C=0,S=0,D="userflowjs-bubble__tooltip-notch",U="hidden",F=null,A=null,W=null,z=null,K="userflowjs-tooltip-backdrop",q=null,Y=null,X=null,J=null,Q=null,Z=null,tt=null,et=null,ot="userflowjs-tooltip-block userflowjs-tooltip-block--top",at=null,lt=null,rt="userflowjs-tooltip-block userflowjs-tooltip-block--right",it=null,nt=null,st="userflowjs-tooltip-block userflowjs-tooltip-block--bottom",ct=null,ut=null,dt="userflowjs-tooltip-block userflowjs-tooltip-block--left",pt=null,mt=null;switch(T){case r.BUBBLE:C=B===s.TOP_LEFT||B===s.BOTTOM_LEFT?L.bubbleX:B===s.TOP_CENTER||B===s.CENTER||B===s.BOTTOM_CENTER?(_-I)/2:_-I-L.bubbleX,S=B===s.TOP_LEFT||B===s.TOP_CENTER||B===s.TOP_RIGHT?L.bubbleY:B===s.CENTER?(H-N)/2:H-N-L.bubbleY,"rtl"===w&&(C=_-C-I),C=Math.max(0,Math.min(_-I,C)),S=Math.max(0,Math.min(H-N,S));break;case r.MODAL:C=O+(_-2*O-I)/2,S=O+(H-2*O-N)/2;break;case r.TOOLTIP:{let e;if(y){let{targetRect:a,viewportClipRect:l}=y;if("absolute"===o){const t=n.offsetParent.getBoundingClientRect();l={top:0,right:_,bottom:H,left:0},a={top:a.top-t.top,right:a.right-t.left,bottom:a.bottom-t.top,left:a.left-t.left,width:a.width,height:a.height}}let r=0;if(R){const{paddingTop:t,paddingRight:e,paddingBottom:o,paddingLeft:l}=function(t){if(!t||"0"===t)return{paddingTop:0,paddingRight:0,paddingBottom:0,paddingLeft:0};const e=t.trim().split(" ");if(1===e.length){const t=$(e[0]);return{paddingTop:t,paddingRight:t,paddingBottom:t,paddingLeft:t}}if(2===e.length){const t=$(e[0]),o=$(e[1]);return{paddingTop:t,paddingRight:o,paddingBottom:t,paddingLeft:o}}return{paddingTop:$(e[0]),paddingRight:$(e[1]),paddingBottom:$(e[2]),paddingLeft:$(e[3])}}(j);a={top:a.top-t,right:a.right+e,bottom:a.bottom+o,left:a.left-l,width:a.width+l+e,height:a.height+t+o},r=Math.min(t,e,o,l)}const s=a,d=L.backdropHighlightType==c.OUTSIDE?L.backdropHighlightSpread:0;if(R&&d&&(a={top:a.top-d,right:a.right+d,bottom:a.bottom+d,left:a.left-d,width:a.width+2*d,height:a.height+2*d}),e=function({targetRect:t,bubbleWidth:e,bubbleHeight:o,containerWidth:a,containerHeight:l,viewportClipRect:r,tooltipNotchSize:i,currentTooltipPlacement:n,desiredTooltipPlacement:s}){if(t.bottom<=r.top)return o+i<=l-r.top?u.BELOW:u.ABOVE;if(t.top>=r.bottom)return o+i<=r.bottom?u.ABOVE:u.BELOW;if(t.right<=r.left)return e+i<=a-r.left?u.RIGHT:u.LEFT;if(t.left>=r.right)return e+i<=r.right?u.LEFT:u.RIGHT;const c=n=>{const s=t.left+t.width/2,c=s>=r.left&&s<=r.right,d=t.top+t.height/2,p=d>=r.top&&d<=r.bottom;switch(n){case u.BELOW:return l-t.bottom>o+i&&c;case u.ABOVE:return t.top>o+i&&c;case u.RIGHT:return a-t.right>e+i&&p;case u.LEFT:return t.left>e+i&&p}};if(s&&c(s))return s;if(n&&c(n))return n;const d=[{placement:u.BELOW,dist:t.top},{placement:u.ABOVE,dist:l-t.bottom},{placement:u.RIGHT,dist:t.left},{placement:u.LEFT,dist:a-t.right}];d.sort(((t,e)=>t.dist-e.dist));for(const{placement:u}of d)if(c(u))return u;return u.BELOW}({targetRect:a,bubbleWidth:I,bubbleHeight:N,containerWidth:_,containerHeight:H,viewportClipRect:l,tooltipNotchSize:P,currentTooltipPlacement:t.tooltipPlacement,desiredTooltipPlacement:i}),e===u.BELOW||e===u.ABOVE?(C=a.left+a.width/2-I/2,C=Math.max(O,Math.min(_-I-O,C)),z=Math.max(x,Math.min(I-x-2*P,a.left+a.width/2-P-C)),e===u.BELOW?F=2*-P:W=2*-P):e===u.RIGHT?(C=a.right+P,C=Math.max(C,l.left+P),C=Math.min(C,l.right+P),C=Math.max(C,P),C=Math.min(C,_-I)):(C=a.left-P-I,C=Math.max(C,l.left-I-P),C=Math.min(C,l.right-I-P),C=Math.max(C,0),C=Math.min(C,_-I-P)),e===u.LEFT||e===u.RIGHT?(S=a.top+a.height/2-N/2,S=Math.max(O,Math.min(H-N-O,S)),F=Math.max(x,Math.min(N-x-2*P,a.top+a.height/2-P-S)),e===u.LEFT?A=2*-P:z=2*-P):e===u.BELOW?(S=a.bottom+P,S=Math.max(S,l.top+P),S=Math.min(S,l.bottom+P),S=Math.max(S,P),S=Math.min(S,H-N)):(S=a.top-P-N,S=Math.max(S,l.top-N-P),S=Math.min(S,l.bottom-N-P),S=Math.max(S,0),S=Math.min(S,H-N-P)),R){const t=window.getComputedStyle(y.targetEl);q=Math.max(0,s.top),Y=Math.max(0,_-s.right),X=Math.max(0,H-s.bottom),J=Math.max(0,s.left),Q=Math.max(0,k(t.borderTopLeftRadius)+r),Z=Math.max(0,k(t.borderTopRightRadius)+r),tt=Math.max(0,k(t.borderBottomRightRadius)+r),et=Math.max(0,k(t.borderBottomLeftRadius)+r),at=Math.max(0,s.right),lt=Math.max(0,s.top),it=Math.max(0,s.right),nt=Math.max(0,s.bottom),ct=Math.max(0,s.left),ut=Math.max(0,s.bottom),pt=Math.max(0,s.left),mt=Math.max(0,s.top)}}else e=i||u.BELOW,e!==u.BELOW&&e!==u.ABOVE||(z=I/2-P,e===u.BELOW?F=2*-P:W=2*-P),e!==u.LEFT&&e!==u.RIGHT||(F=N/2-P,e===u.LEFT?A=2*-P:z=2*-P);t.tooltipPlacement=e,D+=` userflowjs-bubble__tooltip-notch--${e.toLowerCase()}`,U="",R&&(K+=" userflowjs-tooltip-backdrop--visible",ot+=" userflowjs-tooltip-block--visible",rt+=" userflowjs-tooltip-block--visible",st+=" userflowjs-tooltip-block--visible",dt+=" userflowjs-tooltip-block--visible");break}}d.style.transition="";let ft=C,bt=S;if(e&&(d.style.opacity="0",T===r.TOOLTIP)){const e=24;switch(t.tooltipPlacement){case u.BELOW:S+=e;break;case u.ABOVE:S-=e;break;case u.RIGHT:C+=e;break;case u.LEFT:C-=e}}"relative"!==o&&G(d,C,S);if(p.className=D,p.style.visibility=U,V(p,"top",F),V(p,"right",A),V(p,"bottom",W),V(p,"left",z),m.className=K,V(m,"top",q),V(m,"right",Y),V(m,"bottom",X),V(m,"left",J),V(m,"border-top-left-radius",Q),V(m,"border-top-right-radius",Z),V(m,"border-bottom-right-radius",tt),V(m,"border-bottom-left-radius",et),f.className=ot,V(f,"width",at),V(f,"height",lt),b.className=rt,V(b,"left",it),V(b,"height",nt),h.className=st,V(h,"left",ct),V(h,"top",ut),g.className=dt,V(g,"width",pt),V(g,"top",mt),e){d.offsetWidth;const t="opacity 250ms linear";T===r.TOOLTIP?d.style.transition=`${t}, transform 500ms cubic-bezier(0.25, 0.8, 0.5, 1)`:d.style.transition=t,d.style.opacity="1","relative"!==o&&G(d,ft,bt)}}({layoutState:B,animateIn:t,position:ct,absoluteWidth:x,absoluteHeight:I,desiredTooltipPlacement:ut,root:o,bubble:a,tooltipNotch:m,tooltipBackdrop:f,tooltipBlockTop:b,tooltipBlockRight:w,tooltipBlockBottom:y,tooltipBlockLeft:R,dir:gt})}if(P===r.TOOLTIP){const t=O&&O.targetEl;t&&B.stepKeyScrolledIntoView!==N&&B.targetScrolledIntoView!==t&&(B.stepKeyScrolledIntoView=N,B.targetScrolledIntoView=t,function(t){if(l.customScrollIntoView)return void l.customScrollIntoView(t);const{scrollPadding:e}=l;if(e&&g(t)===document.scrollingElement){const o=e.top||0,a=e.right||0,l=e.bottom||0,r=e.left||0;let i=0,n=0;const s=t.getBoundingClientRect(),c=M(),u=v();if(s.top<o?i=s.top-o:s.bottom>u-l&&(i=s.bottom-u+l),s.left<r?n=s.left-r:s.right>c-a&&(n=s.right-c+a),0!=i||0!=n)return void window.scrollBy({top:i,left:n,behavior:"smooth"})}try{t.scrollIntoView({behavior:"smooth",block:"nearest"})}catch(o){console.warn("Userflow.js: scrollIntoView error (falling back to no options).",o),t.scrollIntoView()}}(t))}else B.stepKeyScrolledIntoView=void 0,B.targetScrolledIntoView=null;Vt(C),Wt(P)}),[St,vt,N,_,H,h,ct,x,I,D,ut,A,dt,et,Vt,gt]),$t=t.useRef(Gt);$t.current=Gt;const Kt=t.useRef(!1);t.useEffect((()=>{const t=()=>{Kt.current=!0};return window.addEventListener("beforeunload",t),()=>window.removeEventListener("beforeunload",t)}),[]);const qt=()=>{window.clearTimeout(Ft.current.tooltipTargetMissingTimeout),Ft.current.tooltipTargetMissingTimeout=void 0};t.useEffect((()=>qt),[]);const Yt=t.useCallback((()=>{const t=Ft.current;if(t.tooltipTargetParams=null,D||(t.tooltipPlacement=null),_!==r.TOOLTIP)return qt(),void(t.tooltipTargetMissing=!1);if(!D&&!t.tooltipTargetMissingTimeout){t.tooltipTargetMissing=!1;const e=!S||b(S)||S.type!==n.AUTO||S.autoData?1e3*parseFloat(h.tooltipMissingToleranceSeconds):1;t.tooltipTargetMissingTimeout=window.setTimeout((()=>{if(!Kt.current){if(S&&!b(S)){let t=S.autoData;if(S.autoData)try{t=JSON.parse(S.autoData)}catch(e){}console.warn("Userflow.js: Tooltip target not found on page.\n",{type:S.type,autoData:t,excludeText:S.excludeText,precision:S.precision,text:S.text,css:S.css})}qt(),t.tooltipTargetMissing=!0,$t.current()}}),e)}$t.current()}),[_,D,S,h.tooltipMissingToleranceSeconds]),Xt=t.useCallback((t=>{const e=Ft.current;qt(),e.tooltipTargetParams&&e.tooltipTargetParams.targetEl!==t.targetEl&&(e.tooltipPlacement=null),e.tooltipTargetParams=t,Gt({forceUpdatePosition:!0})}),[Gt]);U({selector:_===r.TOOLTIP&&S||null,targetMoved:Xt,targetLost:Yt,onTargetClick:X});const Jt=t.useCallback((()=>Gt({forceAppearanceLayout:!0})),[Gt]);e(Jt),t.useEffect((()=>{if(!vt||et||"function"!=typeof y)return;let t;const e=new y((()=>{t||(t=window.requestAnimationFrame((()=>{t=void 0,$t.current()})))}));return e.observe(vt,{childList:!0,attributes:!0,subtree:!0}),()=>{e.disconnect(),t&&window.cancelAnimationFrame(t)}}),[vt,et]),t.useLayoutEffect((()=>{$t.current()})),t.useLayoutEffect((()=>{"absolute"===ct&&Gt({forceAppearanceLayout:!0})}),[ct,x,I]);const Qt=t=>{t.preventDefault(),t.stopPropagation()};return function(e,o){const a=window.Intercom;t.useEffect((()=>{if(o&&e.autoHideIntercom&&"function"==typeof a&&!l.autoHide3pDisabled){try{a("update",{hide_default_launcher:!0})}catch(t){console.warn("Userflow.js: Error when hiding Intercom launcher",t)}return()=>{if(!l.autoHide3pDisabled)try{a("update",{hide_default_launcher:!1})}catch(t){console.warn("Userflow.js: Error when unhiding Intercom launcher",t)}}}}),[a,e.autoHideIntercom,o]);const r=window.$crisp;t.useEffect((()=>{if(o&&e.autoHideCrisp&&r&&!l.autoHide3pDisabled){try{r.push(["do","chat:hide"])}catch(t){console.warn("Userflow.js: Error when hiding Crisp Chat",t)}return()=>{if(!l.autoHide3pDisabled)try{r.push(["do","chat:show"])}catch(t){console.warn("Userflow.js: Error when unhiding Crisp Chat",t)}}}}),[r,e.autoHideCrisp,o]);const i=window.HubSpotConversations;t.useEffect((()=>{if(o&&e.autoHideHubspot&&i&&!l.autoHide3pDisabled){try{i.widget.remove()}catch(t){console.warn("Userflow.js: Error when hiding HubSpot Chat",t)}return()=>{if(!l.autoHide3pDisabled)try{i.widget.load()}catch(t){console.warn("Userflow.js: Error when unhiding HubSpot Chat",t)}}}}),[i,e.autoHideHubspot,o]);const n=window.drift;t.useEffect((()=>{if(o&&e.autoHideDrift&&n&&!l.autoHide3pDisabled){try{n.api.widget.hide()}catch(t){console.warn("Userflow.js: Error when hiding Drift Chat",t)}return()=>{if(!l.autoHide3pDisabled)try{n.api.widget.show()}catch(t){console.warn("Userflow.js: Error when unhiding Drift Chat",t)}}}}),[n,e.autoHideDrift,o])}(h,!!lt&&At===r.BUBBLE),t.createElement("div",{ref:wt,"data-testid":"flow-chrome",className:"userflowjs-flow-chrome userflowjs-theme-root",style:j(h),dir:gt},t.createElement("div",{className:"userflowjs-bubble",ref:Tt,style:{zIndex:ft}},t.createElement("div",{className:m({"userflowjs-bubble-outline":!0,[`userflowjs-bubble-outline--bubble-placement-${(h.bubblePlacement||"").toLowerCase().replace(/_/,"-")}`]:!0,"userflowjs-bubble-outline--minimizable":!!at,"userflowjs-bubble-outline--minimized":Dt})},t.createElement("div",{className:"userflowjs-bubble__frame-wrapper",...it},t.createElement(o,{className:"userflowjs-bubble__frame",elRef:Et,stylesheetUrl:p,theme:h,onStylesheetsLoad:_t,noIframe:et},t.createElement("div",{className:"userflowjs-bubble-frame-root",dir:gt,ref:t=>{rt&&rt(t),Mt(t)},style:C?{backgroundImage:`url("${encodeURI(C)}")`}:void 0},st,f.flowBranding&&t.createElement("div",{className:"userflowjs-bubble-made-with-userflow"},t.createElement("div",{className:"userflowjs-bubble-made-with-userflow__absolute"},t.createElement(pt,{company:f},t.createElement(a,null),t.createElement("div",null,"Made with Userflow"))))))),t.createElement("div",{ref:Lt,className:"userflowjs-bubble__avatar-notch"})),t.createElement(o,{className:m({"userflowjs-bubble__avatar":!0,"userflowjs-bubble__avatar--minimizable":!!at,"userflowjs-bubble__avatar--speaking":!!tt}),elRef:yt,stylesheetUrl:P,theme:h,onStylesheetsLoad:Ct,noIframe:et,ariaHidden:!0},t.createElement("div",{className:m({"userflowjs-avatar-frame-root":!0,"userflowjs-avatar-frame-root--minimizable":!!at}),onClick:at?()=>Ut((t=>!t)):void 0},t.createElement(W,{theme:h}))),t.createElement("div",{ref:kt,className:"userflowjs-bubble__tooltip-notch"})),t.createElement("div",{ref:Rt,className:"userflowjs-tooltip-backdrop",onMouseDown:Qt,style:{zIndex:bt,pointerEvents:K?void 0:"none"}}),t.createElement("div",{ref:jt,className:"userflowjs-tooltip-block",onMouseDown:Qt,style:{zIndex:bt}}),t.createElement("div",{ref:Bt,className:"userflowjs-tooltip-block",onMouseDown:Qt,style:{zIndex:bt}}),t.createElement("div",{ref:Ot,className:"userflowjs-tooltip-block",onMouseDown:Qt,style:{zIndex:bt}}),t.createElement("div",{ref:Pt,className:"userflowjs-tooltip-block",onMouseDown:Qt,style:{zIndex:bt}}),t.createElement("div",{ref:xt,className:"userflowjs-modal-backdrop",onMouseDown:Qt,onClick:Q,style:{zIndex:bt}}),nt&&nt({visible:zt,bubbleFrame:Et.current}))},W=({theme:e})=>{const o="https://js.userflow.com/cartoon-avatars-no-bg/";let a;return a=e.avatarType===i.ASSET&&e.avatarAsset?e.avatarAsset.assetUrl:e.avatarType===i.CARTOON&&e.avatarName?o+e.avatarName+".svg?3":e.avatarType===i.URL&&e.avatarUrl?e.avatarUrl:o+"none.svg",t.createElement("img",{src:a,alt:""})},z=({company:e,children:o})=>t.createElement("a",{href:"https://userflow.com/?utm_source=made-with-userflow&utm_medium=link&utm_campaign=made-with-userflow-"+e.slug,target:"_blank",rel:"noopener noreferrer"},o);function V(t,e,o){null==o?t.style.removeProperty(e):t.style.setProperty(e,"number"==typeof o?o+"px":o,"important")}function G(t,e,o){e=Math.round(e),o=Math.round(o),t.style.transform=`translate3d(${e}px, ${o}px, 0px)`}function $(t){const e=parseInt(t,10);return isNaN(e)?0:e}export{A as F,H as r,U as u};
package/Icons.js ADDED
@@ -0,0 +1 @@
1
+ import{r as e}from"./vendor.react.js";const t=0,c=10,r=2e3;function l(e){return 1234500+e}const n=[];function a(){const e={zIndex:0===n.length?l(100):n[n.length-1].zIndex+10};return n.push(e),e}function o(e){const t=n.indexOf(e);-1!==t&&n.splice(t,1)}function s(){const[t,c]=e.useState(a);e.useEffect((()=>()=>o(t)),[t]);const r=e.useCallback((()=>{o(t),c(a())}),[t]);return{zIndex:t.zIndex,bringToFront:r}}const i=({children:t})=>{const{zIndex:c}=s();return e.createElement(w.Provider,{value:c},t)},w=e.createContext(void 0);function v(){return e.useContext(w)||l(100)}const g=()=>e.createElement("svg",{"aria-hidden":"true",role:"img",xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 448 512"},e.createElement("path",{fill:"currentColor",d:"M0 304v-96c0-13.3 10.7-24 24-24h200V80.2c0-21.4 25.8-32.1 41-17L441 239c9.4 9.4 9.4 24.6 0 34L265 448.7c-15.1 15.1-41 4.4-41-17V328H24c-13.3 0-24-10.7-24-24z"})),m=()=>e.createElement("svg",{"aria-hidden":"true",role:"img",xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 448 512"},e.createElement("path",{fill:"currentColor",d:"M272 480h-96c-13.3 0-24-10.7-24-24V256H48.2c-21.4 0-32.1-25.8-17-41L207 39c9.4-9.4 24.6-9.4 34 0l175.8 176c15.1 15.1 4.4 41-17 41H296v200c0 13.3-10.7 24-24 24z"})),h=()=>e.createElement("svg",{"aria-hidden":"true",role:"img",xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 512 512"},e.createElement("path",{fill:"currentColor",d:"M435.848 83.466L172.804 346.51l-96.652-96.652c-4.686-4.686-12.284-4.686-16.971 0l-28.284 28.284c-4.686 4.686-4.686 12.284 0 16.971l133.421 133.421c4.686 4.686 12.284 4.686 16.971 0l299.813-299.813c4.686-4.686 4.686-12.284 0-16.971l-28.284-28.284c-4.686-4.686-12.284-4.686-16.97 0z"})),d=()=>e.createElement("svg",{"aria-hidden":"true",role:"img",xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 448 512"},e.createElement("path",{fill:"currentColor",d:"M441.9 167.3l-19.8-19.8c-4.7-4.7-12.3-4.7-17 0L224 328.2 42.9 147.5c-4.7-4.7-12.3-4.7-17 0L6.1 167.3c-4.7 4.7-4.7 12.3 0 17l209.4 209.4c4.7 4.7 12.3 4.7 17 0l209.4-209.4c4.7-4.7 4.7-12.3 0-17z"})),u=()=>e.createElement("svg",{"aria-hidden":"true",role:"img",xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 448 512"},e.createElement("path",{fill:"currentColor",d:"M107.515 150.971L8.485 250c-4.686 4.686-4.686 12.284 0 16.971L107.515 366c7.56 7.56 20.485 2.206 20.485-8.485v-71.03h308c6.627 0 12-5.373 12-12v-32c0-6.627-5.373-12-12-12H128v-71.03c0-10.69-12.926-16.044-20.485-8.484z"})),x=()=>e.createElement("svg",{"aria-hidden":"true",role:"img",xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 448 512"},e.createElement("path",{fill:"currentColor",d:"M340.485 366l99.03-99.029c4.686-4.686 4.686-12.284 0-16.971l-99.03-99.029c-7.56-7.56-20.485-2.206-20.485 8.485v71.03H12c-6.627 0-12 5.373-12 12v32c0 6.627 5.373 12 12 12h308v71.03c0 10.689 12.926 16.043 20.485 8.484z"})),L=()=>e.createElement("svg",{viewBox:"0 0 32 32",xmlns:"http://www.w3.org/2000/svg"},e.createElement("polygon",{className:"userflowjs-star-shape",fill:"#fff",points:"16 22.7785728 7.18322122 29.1352549 10.5042507 18.7856772 1.73415226 12.3647451 12.6034401 12.3250364 16 2 19.3965599 12.3250364 30.2658477 12.3647451 21.4957493 18.7856772 24.8167788 29.1352549"})),p=()=>e.createElement("svg",{"aria-hidden":"true",role:"img",xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 320 512"},e.createElement("path",{fill:"currentColor",d:"M207.6 256l107.72-107.72c6.23-6.23 6.23-16.34 0-22.58l-25.03-25.03c-6.23-6.23-16.34-6.23-22.58 0L160 208.4 52.28 100.68c-6.23-6.23-16.34-6.23-22.58 0L4.68 125.7c-6.23 6.23-6.23 16.34 0 22.58L112.4 256 4.68 363.72c-6.23 6.23-6.23 16.34 0 22.58l25.03 25.03c6.23 6.23 16.34 6.23 22.58 0L160 303.6l107.72 107.72c6.23 6.23 16.34 6.23 22.58 0l25.03-25.03c6.23-6.23 6.23-16.34 0-22.58L207.6 256z"})),f=()=>e.createElement("svg",{"aria-hidden":"true",role:"img",xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 480 512"},e.createElement("path",{fill:"currentColor",d:"M394.23 100.85c-11.19-7.09-26.03-3.8-33.12 7.41s-3.78 26.03 7.41 33.12C408.27 166.6 432 209.44 432 256s-23.73 89.41-63.48 114.62c-11.19 7.09-14.5 21.92-7.41 33.12 6.51 10.28 21.12 15.03 33.12 7.41C447.94 377.09 480 319.09 480 256s-32.06-121.09-85.77-155.15zm-56 78.28c-11.58-6.33-26.19-2.16-32.61 9.45-6.39 11.61-2.16 26.2 9.45 32.61C327.98 228.28 336 241.63 336 256c0 14.37-8.02 27.72-20.92 34.81-11.61 6.41-15.84 21-9.45 32.61 6.43 11.66 21.05 15.8 32.61 9.45 28.23-15.55 45.77-45 45.77-76.87s-17.54-61.33-45.78-76.87zM231.81 64c-5.91 0-11.92 2.18-16.78 7.05L126.06 160H24c-13.26 0-24 10.74-24 24v144c0 13.25 10.74 24 24 24h102.06l88.97 88.95c4.87 4.87 10.88 7.05 16.78 7.05 12.33 0 24.19-9.52 24.19-24.02V88.02C256 73.51 244.13 64 231.81 64zM208 366.05L145.94 304H48v-96h97.94L208 145.95v220.1z"})),E=()=>e.createElement("svg",{"aria-hidden":"true",role:"img",xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 512 512"},e.createElement("path",{fill:"currentColor",d:"M231.81 64c-5.91 0-11.92 2.18-16.78 7.05L126.06 160H24c-13.26 0-24 10.74-24 24v144c0 13.25 10.74 24 24 24h102.06l88.97 88.95c4.87 4.87 10.88 7.05 16.78 7.05 12.33 0 24.19-9.52 24.19-24.02V88.02C256 73.51 244.13 64 231.81 64zM208 366.05l-48-47.99L145.94 304H48v-96h97.94L160 193.94l48-47.99v220.1zM465.94 256l41.37-41.37c6.25-6.25 6.25-16.38 0-22.63L496 180.69c-6.25-6.25-16.38-6.25-22.63 0L432 222.06l-41.37-41.37c-6.25-6.25-16.38-6.25-22.63 0L356.69 192c-6.25 6.25-6.25 16.38 0 22.63L398.06 256l-41.37 41.37c-6.25 6.25-6.25 16.38 0 22.63L368 331.32c6.25 6.25 16.38 6.25 22.63 0L432 289.94l41.37 41.37c6.25 6.25 16.38 6.25 22.63 0L507.31 320c6.25-6.25 6.25-16.38 0-22.63L465.94 256z"}));export{g as A,c as C,u as L,r as N,L as S,p as T,E as V,h as a,f as b,d as c,x as d,v as e,m as f,i as g,t as h,s as u,l as w};
package/LauncherApp.js ADDED
@@ -0,0 +1 @@
1
+ import{r as e}from"./vendor.react.js";import{L as t,D as r,G as o,x as s,H as n,I as a,J as c,z as i}from"./userflow.js";import{u as l,F as u,r as E}from"./FlowChrome.js";import{f as d,m as p,d as m,S as T,B as f,R as h,h as w}from"./BubbleToolbar.js";import{u as g,i as v}from"./client-context.js";import{o as C}from"./vendor.obj-str.js";import{a as R,c as b,g as L,u as j}from"./stylesheets.js";import{D as A}from"./DynamicIcon.js";import{w as O,h as N,g as I}from"./Icons.js";import{a as _,r as k}from"./flow-condition-types.js";import{T as H}from"./Trigger.js";import"./vendor.object-assign.js";import"./vendor.phoenix.js";import"./vendor.uuid.js";import"./logomark.js";import"./vendor.react-dom.js";import"./vendor.scheduler.js";import"./vendor.react-i18next.js";import"./vendor.babel.runtime.js";import"./vendor.fortawesome.react-fontawesome.js";import"./vendor.fortawesome.fontawesome-svg-core.js";import"./vendor.prop-types.js";import"./vendor.fortawesome.pro-solid-svg-icons.js";import"./vendor.i18next.js";import"./vendor.fortawesome.pro-regular-svg-icons.js";import"./vendor.date-fns.js";const x=e.forwardRef((({appearance:r,icon:o,buttonText:s,theme:n,noAnimation:a,noFixed:c,onClick:i,onMouseEnter:l,onMouseLeave:u,noPointerEvents:E,zIndex:p},m)=>{const{loaded:T}=R(window,d,n),f=n&&r===t.BUTTON?n:null,{loaded:h}=b(window,f),w={"userflowjs-launcher":!0,"userflowjs-launcher--activate-on-click":!!i,"userflowjs-fixed-widget":!c},g={ref:m,style:{...L(n),zIndex:p||O(N),pointerEvents:E?"none":void 0},onClick:i,onMouseEnter:l,onMouseLeave:u};if(!T||!h)return null;switch(r){case t.BEACON:return e.createElement("div",{className:C({...w,"userflowjs-beacon":!0,"userflowjs-beacon--pulse":!a,"userflowjs-beacon--pulse-still":!!a}),...g},e.createElement("div",{className:"userflowjs-beacon__ring"}),e.createElement("div",{className:"userflowjs-beacon__ring"}));case t.BUTTON:return e.createElement("div",{className:C({...w,"userflowjs-launcher--button":!0}),...g},s);case t.HIDDEN:return null;case t.ICON:return e.createElement("div",{className:C({...w,"userflowjs-launcher--icon":!0}),...g},e.createElement(A,{icon:o||"solid/info-circle",size:n.launcherIconSize}))}})),M=({session:d,active:C})=>{const R=g(),{version:b}=d,L=d.id,A=d.flow.id,O=d.version.launcher,[N,M]=e.useState(null),G=j(b.theme),U=d.locale?d.locale.standardLocaleId:G.languageId;e.useEffect((()=>{v.changeLanguage(U)}),[U]);const{activateOn:P}=O,y=O.activeWhileTooltipHover||O.buttons.length>0,B=O.hiddenWhileActive&&P!==r.LAUNCHER_HOVER,K=!C||!B,D=P===r.LAUNCHER_CLICK||P===r.TARGET_CLICK||P===r.LAUNCHER_TARGET_CLICK||y,F=e.useRef({}),S=e.useCallback((()=>{const e=N;if(!e)return;const{targetEl:r,clipEl:s,viewportClipRect:n}=F.current;let i=null;r&&s&&n&&(i=function({targetEl:e,subjectEl:t,clipEl:r,viewportClipRect:s,position:n,subjectAnchor:i}){const l=k(e);if(0===l.width||0===l.height)return null;const u=t.getBoundingClientRect();let E=0,d=0,{side:p,align:m}=n;p===o.AUTO&&(p=o.TOP,m=a.END);switch(p){case o.TOP:d=l.top;break;case o.BOTTOM:d=l.bottom;break;case o.LEFT:E=l.left;break;case o.RIGHT:E=l.right}switch(p){case o.TOP:case o.BOTTOM:switch(m){case a.START:E=l.left;break;case a.CENTER:E=l.left+l.width/2;break;case a.END:E=l.right}break;case o.LEFT:case o.RIGHT:switch(m){case a.START:d=l.top;break;case a.CENTER:d=l.top+l.height/2;break;case a.END:d=l.bottom}}n.xUnit===c.PERCENT?E+=n.xOffset/100*l.width:E+=n.xOffset;n.yUnit===c.PERCENT?d+=n.yOffset/100*l.height:d+=n.yOffset;switch(i){case"center":E-=u.width/2,d-=u.height/2;break;case"side":switch(p){case o.TOP:d-=u.height;break;case o.LEFT:E-=u.width}switch(p){case o.TOP:case o.BOTTOM:switch(m){case a.CENTER:E-=u.width/2;break;case a.END:E-=u.width}break;case o.LEFT:case o.RIGHT:switch(m){case a.CENTER:d-=u.height/2;break;case a.END:d-=u.height}}}if(E+u.width<s.left||E>s.right)return null;if(d+u.height<s.top||d>s.bottom)return null;const T=k(r);return E=Math.max(E,T.left-r.scrollLeft),d=Math.max(d,T.top-r.scrollTop),E=Math.round(E),d=Math.round(d),{left:E,top:d}}({targetEl:r,subjectEl:e,clipEl:s,viewportClipRect:n,position:O.targetPosition,subjectAnchor:O.appearance===t.BEACON?"center":"side"})),E((()=>{!function(e,t){e.classList.toggle("userflowjs-fixed-widget--visible",null!=t),t&&(e.style.transform=`translate3d(${t.left}px, ${t.top}px, 0)`)}(e,i)})),!i||F.current.seenTriggered||L||(F.current.seenTriggered=!0,R.launcherSeen(A))}),[N,O,R,L,A]);e.useLayoutEffect((()=>{S()}),[S]);const z=e.useRef(!1),V=e.useRef(!1),W=e.useRef(!1),$=e.useRef(),J=()=>{q();$.current=window.setTimeout((()=>X.current()),250)},q=e.useCallback((()=>{window.clearTimeout($.current)}),[]),Q=()=>{if(P===r.LAUNCHER_CLICK||P===r.TARGET_CLICK||P===r.LAUNCHER_TARGET_CLICK)return;const e=P===r.LAUNCHER_HOVER||P===r.LAUNCHER_TARGET_HOVER,t=P===r.TARGET_HOVER||P===r.LAUNCHER_TARGET_HOVER;z.current&&(!B||!C)&&e||V.current&&t||W.current&&y?Y():Z()},X=e.useRef(Q);X.current=Q;const Y=()=>{C||(q(),w(R,d,O.actions),O.tooltipEnabled?R.activateLauncher(d):(R.activateLauncher(d),R.deactivateLauncher(d)))},Z=e.useCallback((()=>{C&&(q(),R.deactivateLauncher(d))}),[C,R,d,q]),ee=()=>{C?Z():Y()},te=e.useCallback((({targetEl:e,clipEl:t,viewportClipRect:r})=>{F.current.targetEl=e,F.current.clipEl=t,F.current.viewportClipRect=r,S()}),[S]),re=e.useCallback((()=>{F.current.targetEl=void 0,F.current.clipEl=void 0,S(),Z()}),[S,Z]);l({selector:O.targetSelector,targetMoved:te,targetLost:re,onTargetMouseEnter:()=>{V.current=!0,J()},onTargetMouseLeave:()=>{V.current=!1,J()},onTargetClick:P===r.TARGET_CLICK||P===r.LAUNCHER_TARGET_CLICK?ee:void 0}),e.useEffect((()=>{if(!C)return;const e=e=>{const t=e.target;N&&N.contains(t)||(P===r.TARGET_CLICK||P===r.LAUNCHER_TARGET_CLICK)&&F.current.targetEl&&F.current.targetEl.contains(t)||Z()};return window.addEventListener("click",e,{capture:!0}),()=>window.removeEventListener("click",e,{capture:!0})}),[C,P,N,Z]);const oe=function(e){switch(e.side){case o.AUTO:return null;case o.TOP:return i.ABOVE;case o.BOTTOM:return i.BELOW;case o.LEFT:return i.LEFT;case o.RIGHT:return i.RIGHT}}(O.tooltipPosition.side===o.AUTO?O.targetPosition:O.tooltipPosition),se=e.useMemo((()=>O.content&&p(m(O.content),{buttons:O.buttons})),[O.content,O.buttons]);return e.createElement(T.Provider,{value:d},K&&e.createElement(x,{ref:M,appearance:O.appearance,icon:O.icon,buttonText:O.buttonText,theme:G,onClick:P===r.LAUNCHER_CLICK||P===r.LAUNCHER_TARGET_CLICK?ee:void 0,onMouseEnter:()=>{z.current=!0,J()},onMouseLeave:()=>{z.current=!1,J()},noPointerEvents:P===r.TARGET_HOVER,zIndex:O.zIndex}),C&&e.createElement(I,null,e.createElement(u,{company:d.flow.company,theme:G,position:"fixed",stepAppearance:s.TOOLTIP,width:O.tooltipWidth,tooltipSelector:O.tooltipAnchor===n.TARGET?F.current.targetEl:N,tooltipPlacement:oe,frameWrapperHtmlAttributes:{onMouseEnter:()=>{W.current=!0,J()},onMouseLeave:()=>{W.current=!1,J()}},rootChildren:()=>e.createElement(e.Fragment,null,O.triggers.map((t=>e.createElement(H,{key:t.id,trigger:t}))))},e.createElement(f,{draftMode:d.draftMode,close:D?Z:void 0}),e.createElement("div",{className:"userflowjs-bubble-content"},e.createElement(h,{doc:se,lookupAttribute:_(d.data),buttons:O.buttons})))))};export default M;export{M as LauncherApp};
@@ -0,0 +1 @@
1
+ import{r as t}from"./vendor.react.js";import{u as e}from"./client-context.js";import{w as s,N as o,T as i}from"./Icons.js";import{a as n}from"./stylesheets.js";import"./vendor.object-assign.js";import"./vendor.i18next.js";import"./vendor.react-i18next.js";import"./vendor.babel.runtime.js";import"./userflow.js";import"./vendor.phoenix.js";import"./vendor.uuid.js";import"./flow-condition-types.js";import"./vendor.date-fns.js";var a=new URL("notifications-host.css",import.meta.url).href;const r=({notifications:e})=>{const{loaded:i}=n(window,a);return i?t.createElement("div",{className:"userflowjs-notifications",style:{zIndex:s(o)}},e.map((e=>t.createElement(m,{key:e.id,notification:e})))):null},m=({notification:s})=>{const o=e();return t.createElement("div",{className:"userflowjs-notifications__toast"},t.createElement("div",{className:"userflowjs-notifications__toast-content"},t.createElement("span",{className:"userflowjs-notifications__toast-label"},s.label),s.message),t.createElement("div",{className:"userflowjs-notifications__toast-dismiss",onClick:()=>o.dismissNotification(s.id)},t.createElement(i,null)))};export default r;export{r as NotificationsApp};
@@ -0,0 +1 @@
1
+ import{r as e}from"./vendor.react.js";import{h as t,C as r,i as s,c as o,j as n,k as c,E as l,l as a,m as i,S as u}from"./userflow.js";import{u as d,i as m}from"./client-context.js";import{u as f,w,C as h}from"./Icons.js";import{b as E,h as b,B as p,R as k,a as v,s as g,f as j}from"./BubbleToolbar.js";import{M as C,g as S,a as y}from"./flow-condition-types.js";import{u as N,a as _,g as x}from"./stylesheets.js";import{u as I,F as T,S as R}from"./logomark.js";import{o as L}from"./vendor.obj-str.js";import{D as B}from"./DynamicIcon.js";import{f as H,C as M}from"./ChecklistUI.js";import{f as W,a as F,b as P,c as $,d as A,e as z,g as O,h as U,i as q}from"./vendor.fortawesome.pro-regular-svg-icons.js";import{u as D}from"./vendor.react-i18next.js";import"./vendor.object-assign.js";import"./vendor.phoenix.js";import"./vendor.uuid.js";import"./vendor.i18next.js";import"./vendor.fortawesome.react-fontawesome.js";import"./vendor.fortawesome.fontawesome-svg-core.js";import"./vendor.prop-types.js";import"./vendor.fortawesome.pro-solid-svg-icons.js";import"./vendor.date-fns.js";import"./vendor.react-dom.js";import"./vendor.scheduler.js";import"./vendor.babel.runtime.js";function K(e){return e!==t.ACTION&&e!==t.CONTACT&&e!==t.FLOWS&&e!==t.KNOWLEDGE_BASE&&e!==t.SUBPAGE}const Q=window,V={[r.CRISP]:{configure:({onShow:e,onHide:t})=>{Q.$crisp||(Q.$crisp=[]),Q.$crisp.push(["do","chat:hide"]);let r=!1,s=!1;const o=()=>{r||s?(Q.$crisp.push(["do","chat:show"]),e()):(Q.$crisp.push(["do","chat:hide"]),t())},n=()=>{r=!0,o()};Q.$crisp.push(["on","chat:opened",n]);const c=()=>{r=!1,o()};Q.$crisp.push(["on","chat:closed",c]);const l=()=>{s=!0,o()};Q.$crisp.push(["on","message:received",l]);const a=window.setInterval((()=>{const e=(()=>{const e=document.getElementById("crisp-chatbox");if(!e||"block"!==window.getComputedStyle(e).display)return!1;const t=e.querySelector('[data-id="new_messages"]');return!(!t||"block"!==window.getComputedStyle(t).display)})();e!==s&&(s=e,o())}),200);return()=>{Q.$crisp.push(["off","chat:opened",n]),Q.$crisp.push(["off","chat:closed",c]),Q.$crisp.push(["off","message:received",l]),window.clearInterval(a)}},show:()=>{Q.$crisp.push(["do","chat:show"]),Q.$crisp.push(["do","chat:open"])},hide:()=>{Q.$crisp.push(["do","chat:hide"]),Q.$crisp.push(["do","chat:close"])}},[r.CUSTOM]:{configure:()=>()=>{},show:({block:e})=>{try{new Function('"use strict";\n'+e.chatCode)()}catch(t){console.error(`Userflow.js: Showing custom chat provider failed. Code: ${e.chatCode}`,t)}},hide:()=>{}},[r.FRESHCHAT]:{configure:({onShow:e,onHide:t})=>{if(!Q.fcWidget)throw new Error("Freshchat is not installed");let r=!1,s=!1;const o=()=>{r||s?e():t()},n=()=>{r=!0,o()};Q.fcWidget.on("widget:opened",n);const c=()=>{r=!1,o()};Q.fcWidget.on("widget:closed",c);const l=()=>{const e=!!document.querySelector("#fc_frame.h-open-notify");e!==s&&(s=e,o())},a=window.setInterval(l,200);return Q.fcWidget.on("unreadCount:notify",l),()=>{Q.fcWidget.off("widget:opened",n),Q.fcWidget.off("widget:closed",c),Q.fcWidget.off("unreadCount:notify",l),window.clearInterval(a)}},show:()=>{Q.fcWidget.open()},hide:()=>{Q.fcWidget.close()}},[r.HELPSCOUT]:{configure:({onShow:e,onHide:t})=>{if(!Q.Beacon)throw new Error("Help Scout is not installed");Z();let r=!1,s=!1;const o=()=>{r||s?(G(),e()):(Z(),t())},n=()=>{r=!0,o()};Q.Beacon("on","open",n),Q.Beacon("info")?.status.isOpened&&n();const c=()=>{r=!1,o()};Q.Beacon("on","close",c);const l=window.setInterval((()=>{const e=!!document.querySelector(".BeaconNotificationsFrame");e!==s&&(s=e,o())}),200);return()=>{Q.Beacon("off","open",n),Q.Beacon("off","close",c),window.clearInterval(l)}},show:()=>{G(),Q.Beacon("open")},hide:()=>{Z(),Q.Beacon("close")}},[r.HUBSPOT]:{configure:({onShow:e,onHide:t})=>{const r=()=>{const r=document.getElementById("hubspot-messages-iframe-container");if(!Q.HubSpotConversations||!r)return;window.clearInterval(o),Y?J():X();let n=!1,c=!1;const l=()=>{n||c?(J(),e()):(X(),t())},a=()=>{const e=!!document.querySelector("#hubspot-messages-iframe-container .shadow-container.active");e!==n&&(n=e,l())},i=new C(a);i.observe(r,{attributes:!0,subtree:!0,attributeFilter:["class"]}),a();const u=({unreadCount:e})=>{const t=e>0;t!==c&&(c=t,l())};Q.HubSpotConversations.on("unreadConversationCountChanged",u),s=()=>{i.disconnect(),Q.HubSpotConversations.off("unreadConversationCountChanged",u)}};let s=()=>{window.clearInterval(o)};const o=window.setInterval(r,100);return r(),()=>{s()}},show:()=>{J(),Q.HubSpotConversations.widget.open()},hide:()=>{X(),Q.HubSpotConversations.widget.close()}},[r.INTERCOM]:{configure:({onShow:e,onHide:t})=>{if(!Q.Intercom)throw new Error("Intercom is not installed");return oe(),function(){if(ee)return;ee=!0;let e=!1,t=!1;const r=()=>{se();for(const e of te)e()},s=()=>{oe();for(const e of re)e()},o=()=>{e||t?r():s()};Q.Intercom("onShow",(()=>{e=!0,o()})),Q.Intercom("onHide",(()=>{e=!1,o()}));const n=()=>{const e=!!document.querySelector('iframe[name="intercom-borderless-frame"], iframe[name="intercom-notifications-frame"]');t!==e&&(t=e,o())};Q.Intercom("onUnreadCountChange",(()=>{n()})),window.setInterval(n,200)}(),te.add(e),re.add(t),()=>{te.delete(e),re.delete(t)}},show:()=>{se(),Q.Intercom("show")},hide:()=>{oe(),Q.Intercom("hide")}},[r.ZENDESK]:{configure:({onShow:e,onHide:t})=>{if(!Q.zE)throw new Error("Zendesk is not installed");!function(){if(ne)return;ne=!0,Q.zE("webWidget:on","open",(()=>{for(const e of ce)e()})),Q.zE("webWidget:on","close",(()=>{for(const e of le)e()})),Q.zE("webWidget:on","chat:unreadMessages",(e=>{for(const t of ae)t(e)}))}(),Q.zE("webWidget","hide"),Q.zE("webWidget","close");let r=!1,s=!1;const o=()=>{r||s?(Q.zE("webWidget","show"),e()):(Q.zE("webWidget","hide"),t())},n=()=>{r=!0,s=!1,o()};ce.add(n);const c=()=>{r=!1,s=!1,o()};le.add(c);const l=e=>{const t=e>0;t!==s&&(s=t,o())};return ae.add(l),()=>{ce.delete(n),le.delete(c),ae.delete(l)}},show:()=>{Q.zE("webWidget","show"),Q.zE("webWidget","open")},hide:()=>{Q.zE("webWidget","hide"),Q.zE("webWidget","close")}},[r.ZENDESK_MESSENGER]:{configure:({onShow:e,onHide:t})=>{if(!Q.zE)throw new Error("Zendesk is not installed");let r=!1;const s=window.setInterval((()=>{const s=(()=>{const e=document.querySelector('iframe[title="Messaging window"]');return!!e?.parentElement&&"0px"!==window.getComputedStyle(e.parentElement).height})();s!==r&&(r=s,r?e():t())}),200);return()=>{window.clearInterval(s)}},show:()=>{Q.zE("messenger","open")},hide:()=>{Q.zE("messenger","close")}}};function G(){Q.Beacon("config",{display:{style:"icon"}})}function Z(){Q.Beacon("config",{display:{style:"manual"}})}let Y=!1;function J(){Y=!0;document.getElementById("hubspot-messages-iframe-container")?.style.setProperty("visibility","visible","important")}function X(){Y=!1;document.getElementById("hubspot-messages-iframe-container")?.style.setProperty("visibility","hidden","important")}let ee=!1,te=new Set,re=new Set;function se(){Q.Intercom("update",{hide_default_launcher:!1,vertical_padding:20})}function oe(){Q.Intercom("update",{hide_default_launcher:!0,vertical_padding:100})}let ne=!1,ce=new Set,le=new Set,ae=new Set;function ie(){return e.createElement("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 100 100"},e.createElement("path",{fill:"currentColor",d:"M24.049 79.74h36.003c8.185 0 15.985-6.621 17.43-14.814l6.091-34.556h3.997c8.149 0 13.645 6.63 12.2 14.815l-7.051 40C91.274 93.363 83.474 100 75.288 100h-40c-8.185 0-13.645-6.667-12.2-14.815l.96-5.444z"}),e.createElement("path",{fill:"currentColor",fillRule:"evenodd",d:"M12.437 69.63h40c8.148 0 15.978-6.637 17.422-14.815l7.052-40C78.355 6.63 72.896 0 64.711 0h-40C16.533 0 8.726 6.63 7.281 14.815l-7.052 40C-1.215 62.963 4.252 69.63 12.437 69.63zm33.628-33.798c3.756-2.064 8.725-4.795 9.907-11.844C57.385 15.458 50.065 8.983 42.168 9c-7.452 0-12.771 3.195-17.508 8.892-.858 1.034-.884 2.45-.053 3.212l3.472 3.196c.847.767 2.25.589 3.176-.406 2.842-3.068 4.869-4.83 8.51-4.83 2.864 0 6.077 1.934 5.59 4.847-.37 2.223-2.292 3.334-5.4 5.001l-.28.151c-3.582 1.92-8.134 4.362-9.124 10.247l-.16.956c-.055.28-.05.571.014.85.065.278.188.538.362.76.173.222.391.4.639.522.247.121.518.183.79.18h6.744a2.709 2.709 0 001.712-.688c.481-.426.81-1.01.934-1.657l.095-.556c.266-1.582 2.101-2.59 4.384-3.845zM32.837 59c3.552 0 6.955-3.034 7.58-6.769.63-3.729-1.742-6.763-5.293-6.763-3.552 0-6.934 3.028-7.58 6.763C26.9 55.966 29.286 59 32.837 59z"}))}const ue=()=>{const t=12;return e.createElement("div",{className:"userflowjs-spinner"},e.createElement("svg",{viewBox:"0 0 24 24",version:"1.1",xmlns:"http://www.w3.org/2000/svg"},e.createElement("circle",{className:"userflowjs-spinner__bg",fill:"none",cx:t,cy:t,r:10,style:{strokeWidth:"4px"}}),e.createElement("circle",{className:"userflowjs-spinner__fill",fill:"none",cx:t,cy:t,r:10,transform:"translate(12, 12) rotate(-90) translate(-12, -12)",style:{strokeWidth:"4px",strokeDasharray:20*Math.PI*.25+"px, 1000"}})))};function de(t){const r=d(),[s,o]=e.useState(!0),[n,c]=e.useState(!1),[l,a]=e.useState(null),[i,u]=e.useState(null),[m,f]=e.useState(null),w=e.useRef(0),h=e.useRef(null),E=e.useRef((()=>{}));return e.useEffect((()=>{const e=JSON.stringify(t);if(e===h.current)return;h.current=e;const s=++w.current;let n,l;let i=!1;E.current=async(e,t)=>{if(!i){i=!0,c(!0);try{const o=e(n,l);l=o;const u=await r.send(o,{handlesRejection:!0});if(s!==w.current)return;n=t(n,u),a(n),f(null)}catch(o){if(s!==w.current)return;f(o)}finally{i=!1,c(!1)}}},(async()=>{o(!0);try{l=t;const e=await r.send(t,{handlesRejection:!0});if(s!==w.current)return;n=e,a(n),u(t),f(null)}catch(e){if(s!==w.current)return;f(e)}finally{o(!1)}})()}),[r,t]),{loading:s,loadingMore:n,data:l,messageForData:i,error:m,loadMore:E.current}}function me(t,r){const[s,o]=e.useState(t),n=e.useRef(void 0),c=e.useCallback((e=>{window.clearTimeout(n.current),o(e),r(e)}),[r]),l=e.useCallback((e=>{window.clearTimeout(n.current),o(e),n.current=window.setTimeout((()=>{r(e)}),200)}),[r]);return e.useEffect((()=>()=>{window.clearTimeout(n.current)}),[]),[s,l,c]}const fe=({session:a,isOpen:i,flowSession:u,checklistSession:b})=>{const p=d(),{t:k}=D(),{company:v}=a.flow,{version:g}=a,y=g.resourceCenter,M=N(g.theme),A=a.locale?a.locale.standardLocaleId:a.version.theme.languageId;e.useEffect((()=>{m.changeLanguage(A)}),[A]);const{loaded:z}=_(window,j,M),[O,U]=e.useState(!1),q=z&&O,[Q,G]=e.useState(S()),Z=e.useCallback((()=>{G(S())}),[]);I(Z);const{zIndex:Y,bringToFront:J}=f(),X=e.useRef(null),[ee,te]=e.useState(null),[re,se]=e.useState(null),[oe,ne]=e.useState(null),ce=e.useRef(null),[le,ae]=e.useState(null),[ue,de]=e.useState(null),[me,fe]=e.useState(null),[Ee,be]=e.useState(0),[je,Ce]=e.useState(0),ye=e.useCallback((()=>{re&&be(re.offsetWidth),Ce((oe?.offsetHeight||0)+(le?.offsetHeight||0)+(ue?.offsetHeight||0)+(me?.offsetHeight||0))}),[re,oe,le,ue,me]);e.useLayoutEffect((()=>{if(!ee||"function"!=typeof C)return;const e=new C((()=>{ye()}));return e.observe(ee,{childList:!0,attributes:!0,subtree:!0}),()=>{e.disconnect()}}),[ee,ye]),e.useLayoutEffect((()=>{ye()}));const[xe,Ie]=e.useState(!1),Te=e.useRef(),Re=e.useCallback((()=>{Ie(!0),window.clearTimeout(Te.current),Te.current=window.setTimeout((()=>{Ie(!1)}),M.resourceCenterTransitionDuration)}),[M.resourceCenterTransitionDuration]);e.useEffect((()=>()=>{window.clearTimeout(Te.current)}),[]);const Le=e.useCallback((()=>{J(),Re(),p.openResourceCenter()}),[J,p,Re]),Be=e.useCallback((()=>{Re(),p.closeResourceCenter()}),[p,Re]),[He,Me]=e.useState(!1);e.useEffect((()=>{if(He){if(i){const e='button:not([tabindex="-1"]), [tabindex]:not([tabindex="-1"]), input, textarea';let t=le?.querySelector(e)||oe?.querySelector(e);if(t){const e=t.closest&&t.closest(".userflowjs-resource-center-checklist")||null;e?H(e):t.focus({preventScroll:!0})}}else re?.focus({preventScroll:!0});Me(!1)}}),[He,i,le,oe,re]),e.useEffect((()=>{const e=ee?.ownerDocument.defaultView;if(!i||!e)return;const t=e=>{"Escape"===e.key&&(Be(),Me(!0))};return e.addEventListener("keydown",t),()=>e.removeEventListener("keydown",t)}),[i,ee,Me,Be]);const[We,Fe]=e.useState(null),Pe=e.useCallback(((e,t)=>{Fe(e),0===t?.detail&&Me(!0)}),[]);e.useEffect((()=>{i||Pe(null)}),[i,Pe]);const $e=e.useMemo((()=>y.blocks.filter((e=>!(e.type===t.CHECKLIST&&!b)&&(!e.hiddenWhenFlowsActive||!e.hiddenWhenFlowsActive.some((e=>e===u?.flow.id||e===b?.flow.id)))))),[y,u,b]),Ae=e.useMemo((()=>we($e)),[$e]),ze=e.useMemo((()=>b&&y.blocks.some((e=>e.type===t.CHECKLIST))?s(b):0),[y,b]),Oe=e.useMemo((()=>y.blocks.find((e=>e.type===t.CONTACT&&e.chatEnabled&&e.chatProvider))),[y]),[Ue,qe]=e.useState(!1),De=e.useCallback((()=>{p.closeResourceCenter(),Oe&&Oe.chatProvider!==r.CUSTOM&&qe(!0)}),[p,Oe]),Ke=e.useCallback((()=>{qe(!1)}),[]),Qe=e.useCallback((()=>{if(Oe)try{V[Oe.chatProvider].hide({block:Oe}),Ke()}catch(e){console.error(`Userflow.js: Error when hiding ${Oe.chatProvider}:`,e)}}),[Oe,Ke]);e.useEffect((()=>{if(!Oe)return;o.autoHide3pDisabled=!0;const e=V[Oe.chatProvider];try{const t=e.configure({block:Oe,onShow:De,onHide:Ke});return()=>{t()}}catch(t){return void console.error(`Userflow.js: Error when configuring ${Oe.chatProvider}:`,t)}}),[Oe,De,Ke]),e.useEffect((()=>{i&&Qe()}),[Qe,i]);const Ve=!!We&&("search"===We.kind||"flows"===We.kind||"knowledgeBase"===We.kind),Ge={zIndex:null!=M.resourceCenterZIndex?M.resourceCenterZIndex:i?Y:w(h),width:i?void 0:Ee+"px",height:i?Math.min(Ve?540:je,Q-2*M.resourceCenterPaddingY)+"px":void 0,position:q?void 0:"absolute",visibility:q&&!Ue?void 0:"hidden"},Ze=M.resourceCenterDisplayChecklistProgress&&b&&ze>0?e.createElement("div",{"data-testid":"resource-center-launcher-badge",className:"userflowjs-resource-center-launcher-badge"},ze,e.createElement("div",{className:"userflowjs-a11y-only"},"uncompleted tasks")):null;let Ye="",Je="";return M.resourceCenterLauncherTextMode===n.CHECKLIST_OVERRIDE&&b&&ze>0?Ye=b.version.checklist?.launcherText||"Get Started":M.resourceCenterLauncherTextMode!==n.NONE&&(Je=y.buttonText),e.createElement("div",{"data-testid":"resource-center-app",className:"userflowjs-resource-center userflowjs-theme-root",style:x(M),dir:m.dir()},e.createElement(T,{elRef:X,className:L({"userflowjs-resource-center-frame":!0,"userflowjs-resource-center-frame--fixed":!0,[`userflowjs-resource-center-frame--placement-${M.resourceCenterPlacement.toLowerCase().replace(/_/g,"-")}`]:!0,"userflowjs-resource-center-frame--animating":xe,"userflowjs-resource-center-frame--open":i,"userflowjs-resource-center-frame--closed":!i}),style:{...Ge},stylesheetUrl:E,theme:M,onStylesheetsLoad:U},q&&e.createElement(e.Fragment,null,e.createElement("div",{ref:te,className:L({"userflowjs-resource-center-frame-root":!0,[`userflowjs-resource-center-frame-root--placement-${M.resourceCenterPlacement.toLowerCase().replace(/_/g,"-")}`]:!0,"userflowjs-resource-center-frame-root--animating":xe,"userflowjs-resource-center-frame-root--open":i,"userflowjs-resource-center-frame-root--closed":!i}),dir:m.dir(),role:i?"dialog":void 0,"aria-label":i?y.headerText:void 0},e.createElement("div",{className:"userflowjs-resource-center-launcher-container"},e.createElement("button",{ref:se,className:"userflowjs-resource-center-launcher-button",onClick:e=>{Le(),0===e.detail&&Me(!0)},"aria-label":`Open ${y.headerText}`},Ze,Ye&&e.createElement("div",{"data-testid":"resource-center-launcher-text",className:"userflowjs-resource-center-launcher-text"},Ye),(Ze||Ye)&&e.createElement("div",{className:"userflowjs-resource-center-launcher-divider"}),Je&&e.createElement("div",{"data-testid":"resource-center-launcher-text",className:"userflowjs-resource-center-launcher-text"},Je),e.createElement("div",{className:"userflowjs-resource-center-launcher-icon"},M.resourceCenterLauncherIconType===c.PLAINTEXT?"?":e.createElement(ie,null)))),e.createElement("div",{ref:ce,className:"userflowjs-resource-center-body"},e.createElement("div",{ref:ae,className:L({"userflowjs-resource-center-body-content":!0,"userflowjs-resource-center-body-content--same-background":M.sameBackground,"userflowjs-resource-center-body-content--with-made-with-userflow":v.resourceCenterBranding})},i&&e.createElement(e.Fragment,null,We?"search"===We.kind?e.createElement(pe,{session:a,navigate:Pe}):"email"===We.kind?e.createElement(ke,{block:We.block,session:a}):"phone"===We.kind?e.createElement(ve,{block:We.block,session:a}):"flows"===We.kind?e.createElement(ge,{block:We.block,initialQ:We.initialQ,session:a,navigate:Pe}):"knowledgeBase"===We.kind?e.createElement(Se,{block:We.block,initialQ:We.initialQ,session:a,bodyRef:ce}):"subpage"===We.kind?e.createElement(Ne,{block:We.block,session:a}):null:e.createElement(e.Fragment,null,$e.map(((t,r)=>{const s=he[t.type],o=$e[r+1];return s?e.createElement(e.Fragment,{key:t.id},e.createElement(s.View,{session:a,flowSession:u,checklistSession:b,block:t,navigate:Pe,onChatShow:De}),o&&(n=t.type,c=o.type,K(n)||K(c))&&e.createElement("div",{className:"userflowjs-resource-center-divider"})):null;var n,c})))))),v.resourceCenterBranding&&e.createElement("div",{className:"userflowjs-resource-center-made-with-userflow"},e.createElement("div",{className:"userflowjs-resource-center-made-with-userflow-content",ref:de},e.createElement("a",{href:"https://userflow.com/?utm_source=made-with-userflow&utm_medium=link&utm_campaign=made-with-userflow-"+v.slug+"&utm_content=resource-center",target:"_blank",rel:"noopener noreferrer"},e.createElement(R,null),e.createElement("div",null,"Made with Userflow")))),a.draftMode&&e.createElement("div",{className:"userflowjs-resource-center-preview"},e.createElement("div",{ref:fe,className:"userflowjs-resource-center-preview-content"},e.createElement("div",{className:"userflowjs-resource-center-preview-text"},"Preview"),e.createElement("button",{className:"userflowjs-resource-center-preview-button",onClick:()=>{p.endFlow(a,{endReason:l.USER_CLOSED})}},e.createElement(B,{icon:W})))),e.createElement("div",{className:"userflowjs-resource-center-header"},e.createElement("div",{ref:ne,className:"userflowjs-resource-center-header-content"},null==We?e.createElement("div",{className:"userflowjs-resource-center-header-text"},y.headerText):e.createElement("button",{className:"userflowjs-resource-center-icon-button",onClick:e=>Pe(null,e)},e.createElement("div",{className:"userflowjs-rtl-mirrored"},e.createElement(B,{icon:F})),e.createElement("div",{className:"userflowjs-resource-center-icon-button__text"},k("resource_center.back"))),e.createElement("div",{className:"flex-1"}),Ae.length>0&&e.createElement("button",{className:"userflowjs-resource-center-icon-button",onClick:()=>{let e={kind:"search"};if(1===Ae.length){const t=Ae[0],r=he[t.type];r.routeTo&&(e=r.routeTo({block:t}))}"search"===We?.kind?Pe(null):(_e(p,a,null,"Search icon"),Pe(e))},"aria-label":"Search"},e.createElement(B,{icon:P})),e.createElement("button",{className:"userflowjs-resource-center-icon-button userflowjs-resource-center-close-button",onClick:e=>{Be(),0===e.detail&&Me(!0)},"aria-label":`Close ${y.headerText}`},e.createElement(B,{icon:$}))))))))};function we(e){return e.filter((e=>{const t=he[e.type];return t.isSearchable?t.isSearchable(e):!!t.search}))}const he={[t.ACTION]:{View:t=>{const{block:r,session:s,flowSession:o,checklistSession:n}=t,c=d(),[l,i]=e.useState(!1),u=o?.id,m=n?.id;return e.useEffect((()=>{i(!1)}),[u,m]),e.createElement("button",{className:"userflowjs-resource-center-block userflowjs-resource-center-block--clickable",onClick:l?void 0:()=>{_e(c,s,r);const e=r.actions.find((e=>e.type===a.START_FLOW));if(e){e.otherFlow?.id!==n?.flow.id&&i(!0)}else c.closeResourceCenter();b(c,s,r.actions)},disabled:l},e.createElement(Ee,{...t}),e.createElement(be,{...t}),l&&e.createElement(ue,null))}},[t.CHECKLIST]:{View:({checklistSession:t})=>e.createElement("div",{"data-testid":"resource-center-checklist",className:"userflowjs-resource-center-checklist"},e.createElement(M,{session:t}),e.createElement(p,{draftMode:!!t.draftMode&&"CHECKLIST PREVIEW"}))},[t.CONTACT]:{View:t=>{const{block:r,session:s,navigate:o,onChatShow:n}=t,c=d(),l=[];return r.emailEnabled&&l.push({icon:O,label:"Email",isRoute:!0,onClick:e=>{_e(c,s,r,"Email"),o({kind:"email",block:r},e)}}),r.phoneEnabled&&l.push({icon:U,label:"Phone",isRoute:!0,onClick:e=>{_e(c,s,r,"Phone"),o({kind:"phone",block:r},e)}}),r.chatEnabled&&l.push({icon:q,label:"Live-chat",isRoute:!1,onClick:()=>{if(_e(c,s,r,"Chat"),r.chatProvider){const t=V[r.chatProvider];try{t.show({block:r})}catch(e){console.error(`Userflow.js: Error when showing ${r.chatProvider}:`,e)}n()}else s.draftMode&&window.alert("You have not selected a chat provider. Go to the resource center builder in Userflow. Click the Contact block. Pick a chat provider in the side panel.")}}),e.createElement("div",{className:L({"userflowjs-resource-center-block":!0,"userflowjs-resource-center-block--clickable":1===l.length}),onClick:1===l.length?l[0].onClick:void 0},1===l.length&&e.createElement("div",{className:"userflowjs-resource-center-block-icon"},e.createElement(B,{icon:l[0].icon})),e.createElement(be,{...t}),l.length>1&&l.map((({icon:t,label:r,onClick:s},o)=>e.createElement("button",{key:o,className:"userflowjs-resource-center-icon-button",onClick:s,"aria-label":r},e.createElement(B,{icon:t})))),1===l.length&&l[0].isRoute&&e.createElement("div",{className:"userflowjs-resource-center-block-nav-icon"},e.createElement(B,{icon:A})))}},[t.FLOWS]:{View:t=>{const{block:r,session:s,navigate:o}=t,n=d();return e.createElement("button",{className:"userflowjs-resource-center-block userflowjs-resource-center-block--clickable",onClick:e=>{_e(n,s,r),o({kind:"flows",block:r},e)}},e.createElement(Ee,{...t}),e.createElement(be,{...t}),e.createElement("div",{className:"userflowjs-resource-center-block-nav-icon"},e.createElement(B,{icon:A})))},routeTo:({block:e,initialQ:t})=>({kind:"flows",block:e,initialQ:t}),isSearchable:e=>!!e.searchEnabled,search:async({client:e,session:t,block:r,q:s})=>{const{flows:o}=await e.send({kind:"ListResourceCenterBlockFlows",sessionId:t.id,blockCvid:r.cvid},{handlesRejection:!0}),n=je(o,s),c=n.slice(0,5);return{block:r,truncated:c.length===n.length,results:c.map((e=>({kind:"flow",flow:e})))}}},[t.KNOWLEDGE_BASE]:{View:t=>{const{block:r,session:s,navigate:o}=t,n=d();return e.createElement("button",{className:"userflowjs-resource-center-block userflowjs-resource-center-block--clickable",onClick:e=>{_e(n,s,r),o({kind:"knowledgeBase",block:r},e)}},e.createElement(Ee,{...t}),e.createElement(be,{...t}),e.createElement("div",{className:"userflowjs-resource-center-block-nav-icon"},e.createElement(B,{icon:A})))},routeTo:({block:e,initialQ:t})=>({kind:"knowledgeBase",block:e,initialQ:t}),search:async({client:e,session:t,block:r,q:s})=>{const{truncated:o,articles:n}=await e.send({kind:"SearchKnowledgeBase",sessionId:t.id,blockCvid:r.cvid,q:s,offset:0,limit:5},{handlesRejection:!0});return{block:r,truncated:o,results:n.map((e=>({kind:"article",article:e})))}}},[t.MESSAGE]:{View:({block:t,session:r})=>e.createElement("div",{className:"userflowjs-resource-center-block"},e.createElement("div",{className:"userflowjs-resource-center-block-text userflowjs-bubble-content"},e.createElement(k,{doc:t.content,lookupAttribute:y(r.data)})))},[t.SUBPAGE]:{View:t=>{const{block:r,session:s,navigate:o}=t,n=d();return e.createElement("button",{className:"userflowjs-resource-center-block userflowjs-resource-center-block--clickable",onClick:e=>{_e(n,s,r),o({kind:"subpage",block:r},e)}},e.createElement(Ee,{...t}),e.createElement(be,{...t}),e.createElement("div",{className:"userflowjs-resource-center-block-nav-icon"},e.createElement(B,{icon:A})))}}},Ee=({block:t})=>t.icon?e.createElement("div",{className:"userflowjs-resource-center-block-icon"},e.createElement(B,{icon:t.icon,size:16})):null,be=({block:t,session:r})=>e.createElement("div",{className:"userflowjs-resource-center-block-text"},e.createElement(v,{doc:t.name,lookupAttribute:y(r.data)})),pe=({session:t,navigate:r})=>{const s=d(),o=t.version.resourceCenter.blocks,n=we(o),{t:c}=D(),l=e.useRef(null),[a,i]=e.useState(""),[u,m]=me(a,i),[f,w]=e.useState(null);return e.useEffect((()=>{if(""===a.trim())return void w(null);let e=!1;return(async()=>{w(null);const r=await Promise.all(o.map((async e=>{const{search:r}=he[e.type];if(!r)return null;try{return await r({client:s,session:t,block:e,q:a})}catch(o){return console.error(`Userflow.js: Global search failed for ${e.type} block=`,e,"error=",o),null}})));e||w(r.filter((e=>null!=e&&e.results.length>0)))})(),()=>{e=!0}}),[s,t,o,a]),e.useEffect((()=>{l.current?.focus({preventScroll:!0})}),[]),e.createElement(e.Fragment,null,e.createElement("div",{className:"userflowjs-resource-center-list-route-search"},e.createElement("input",{ref:l,className:"userflowjs-text-input",type:"text",value:u,onChange:e=>m(e.target.value),placeholder:c("resource_center.search_placeholder")})),""===a.trim()?e.createElement("div",{"data-testid":"resource-center-empty-query",className:"userflowjs-resource-center-list-route-error"},c("resource_center.search_in")," ",n.map(((r,s)=>e.createElement(e.Fragment,{key:r.cvid},s>0&&(s===n.length-1?` ${c("and")} `:", "),e.createElement("b",null,e.createElement(v,{doc:r.name,lookupAttribute:y(t.data)}))))),"."):f?0===f.length?e.createElement("div",{className:"userflowjs-resource-center-list-route-error"},c("resource_center.no_results_found")):f.map((({block:o,truncated:n,results:l},i)=>{const u=he[o.type],d=u.routeTo&&u.routeTo({block:o,initialQ:a});return e.createElement(e.Fragment,{key:o.cvid},i>0&&e.createElement("div",{className:"userflowjs-resource-center-divider"}),e.createElement("div",{className:"userflowjs-resource-center-label"},e.createElement(v,{doc:o.name,lookupAttribute:y(t.data)})),l.map(((s,n)=>"flow"===s.kind?e.createElement(Ce,{key:s.flow.id,block:o,session:t,flow:s.flow,navigate:r}):"article"===s.kind?e.createElement(ye,{key:n,block:o,session:t,article:s.article}):null)),!n&&d&&e.createElement("button",{className:"userflowjs-resource-center-block userflowjs-resource-center-block--clickable",onClick:e=>{_e(s,t,o),r(d,e)}},e.createElement("div",{className:"userflowjs-resource-center-block-text"},c("more"),":"," ",e.createElement(v,{doc:o.name,lookupAttribute:y(t.data)})),e.createElement("div",{className:"userflowjs-resource-center-block-nav-icon"},e.createElement(B,{icon:A}))))})):e.createElement("div",{className:"userflowjs-resource-center-list-route-spinner"},e.createElement(ue,null)))},ke=({block:t,session:r})=>e.createElement("div",{className:"userflowjs-resource-center-content-route userflowjs-bubble-content"},e.createElement(k,{doc:t.emailContent,lookupAttribute:y(r.data)})),ve=({block:t,session:r})=>e.createElement("div",{className:"userflowjs-resource-center-content-route userflowjs-bubble-content"},e.createElement(k,{doc:t.phoneContent,lookupAttribute:y(r.data)})),ge=({block:t,initialQ:r,session:s,navigate:o})=>{const{t:n}=D(),c=e.useRef(null),[l,a]=e.useState(r||""),[i,u]=me(l,a),{data:d,error:m}=de({kind:"ListResourceCenterBlockFlows",sessionId:s.id,blockCvid:t.cvid}),f=d?.flows,w=e.useMemo((()=>f?je(f,l):null),[f,l]);return e.useEffect((()=>{c.current?.focus({preventScroll:!0})}),[]),e.createElement(e.Fragment,null,e.createElement("div",{className:"userflowjs-resource-center-list-route-header"},e.createElement("div",{className:"userflowjs-resource-center-list-route-title"},e.createElement(v,{doc:t.name,lookupAttribute:y(s.data)}))),t.searchEnabled&&e.createElement("div",{className:"userflowjs-resource-center-list-route-search"},e.createElement("input",{ref:c,className:"userflowjs-text-input",type:"text",value:i,onChange:e=>u(e.target.value),placeholder:n("resource_center.search_placeholder")})),m?e.createElement("div",{className:"userflowjs-resource-center-list-route-error"},n("resource_center.generic_error")):w?0===w.length?e.createElement("div",{className:"userflowjs-resource-center-list-route-error"},n("resource_center.no_results_found")):w.map((r=>e.createElement(Ce,{key:r.id,block:t,session:s,flow:r,navigate:o}))):e.createElement("div",{className:"userflowjs-resource-center-list-route-spinner"},e.createElement(ue,null)))};function je(e,t){const r=t.toLowerCase().trim();return""===r?e:e.filter((e=>e.name.toLowerCase().includes(r)))}const Ce=({block:t,session:r,flow:s,navigate:o})=>{const n=d(),[c,l]=e.useState(!1);return e.useEffect((()=>{if(!c||s.type!==i.CHECKLIST)return;const e=()=>{n.checklistSession?.flow.id===s.id&&(t(),o(null))},t=()=>{n.off("checklistChanged",e)};return n.on("checklistChanged",e),t}),[n,c,s.type,s.id,o]),e.createElement("button",{className:"userflowjs-resource-center-block userflowjs-resource-center-block--clickable",onClick:()=>{_e(n,r,t,s.name),n.startFlow({flowId:s.id,startReason:u.RESOURCE_CENTER,replaceCurrent:!0}),l(!0)},disabled:c},e.createElement("div",{className:"userflowjs-resource-center-block-icon"},e.createElement(B,{icon:s.type===i.CHECKLIST?"regular/tasks":"regular/shoe-prints",size:16})),e.createElement("div",{className:"userflowjs-resource-center-block-text"},s.name),c&&e.createElement(ue,null))},Se=({block:t,initialQ:r,session:s,bodyRef:o})=>{const{t:n}=D(),c=e.useRef(null),[l,a]=e.useState(r||""),[i,u]=me(l,a),{loading:d,loadingMore:m,data:f,messageForData:w,error:h,loadMore:E}=de({kind:"SearchKnowledgeBase",sessionId:s.id,blockCvid:t.cvid,q:l,offset:0}),b=f?.truncated,p=e.useCallback((()=>{E(((e,t)=>({...t,offset:e.articles.length})),((e,t)=>({...t,articles:[...e.articles,...t.articles]})))}),[E]);e.useEffect((()=>{const e=o.current;if(!e||d||m||b)return;const t=()=>{e.scrollHeight-e.clientHeight-e.scrollTop>400||p()};return e.addEventListener("scroll",t),()=>{e.removeEventListener("scroll",t)}}),[o,d,m,b,p]),e.useEffect((()=>{c.current?.focus({preventScroll:!0})}),[]);let k=t.knowledgeBaseUrl||"";return k.match(/^https?:\/\//)||(k=`http://${k}`),e.createElement(e.Fragment,null,e.createElement("div",{className:"userflowjs-resource-center-list-route-header"},e.createElement("div",{className:"userflowjs-resource-center-list-route-title"},e.createElement(v,{doc:t.name,lookupAttribute:y(s.data)})),e.createElement("a",{className:"userflowjs-resource-center-icon-button",href:k,target:"_blank",rel:"noopener noreferrer"},e.createElement(B,{icon:z}))),e.createElement("div",{className:"userflowjs-resource-center-list-route-search"},e.createElement("input",{ref:c,className:"userflowjs-text-input",type:"text",value:i,onChange:e=>u(e.target.value),placeholder:n("resource_center.search_placeholder")})),h?e.createElement("div",{className:"userflowjs-resource-center-list-route-error"},"quota_exceeded"===h.code?"Sorry, this company has reached its max number of searches. Consider asking Userflow to be moved to a dedicated search engine for a higher quota.":n("resource_center.generic_error")):d||!f?e.createElement("div",{className:"userflowjs-resource-center-list-route-spinner"},e.createElement(ue,null)):0===f.articles.length?""===w?.q?null:e.createElement("div",{className:"userflowjs-resource-center-list-route-error"},n("resource_center.no_results_found")):e.createElement(e.Fragment,null,""===w?.q&&e.createElement("div",{className:"userflowjs-resource-center-label"},n("resource_center.suggested_articles")),f.articles.map(((r,o)=>e.createElement(ye,{key:o,block:t,session:s,article:r}))),m&&e.createElement("div",{className:"userflowjs-resource-center-list-route-spinner"},e.createElement(ue,null))))},ye=({block:t,article:r,session:s})=>{const o=d();return e.createElement("a",{className:"userflowjs-resource-center-block userflowjs-resource-center-block--clickable",onClick:()=>{_e(o,s,t,r.title)},href:r.url,target:"_blank",rel:"noopener noreferrer"},e.createElement("div",{className:"userflowjs-resource-center-block-icon"},e.createElement(B,{icon:"regular/file-alt",size:16})),e.createElement("div",{className:"userflowjs-resource-center-block-text"},e.createElement("span",{dangerouslySetInnerHTML:{__html:r.htmlTitle}}),e.createElement("div",{className:"userflowjs-resource-center-block-subtext",dangerouslySetInnerHTML:{__html:r.htmlSnippet}})))},Ne=({block:t,session:r})=>e.createElement("div",{className:"userflowjs-resource-center-content-route userflowjs-bubble-content"},e.createElement(k,{doc:t.content,lookupAttribute:y(r.data)}));function _e(e,t,r,s){e.send({kind:"ClickResourceCenter",sessionId:t.id,description:r?g(r.name,{lookupAttribute:y(t.data)})+(s?` - ${s}`:""):s},{batch:!0})}export default fe;export{fe as ResourceCenterApp};
@@ -0,0 +1 @@
1
+ import{r as e}from"./vendor.react.js";import{u as t}from"./client-context.js";import{B as r}from"./BuilderBar.js";import{c as o}from"./flow-condition-types.js";import{q as s}from"./userflow.js";import"./vendor.object-assign.js";import"./vendor.i18next.js";import"./vendor.react-i18next.js";import"./vendor.babel.runtime.js";import"./logomark.js";import"./vendor.react-dom.js";import"./vendor.scheduler.js";import"./stylesheets.js";import"./vendor.obj-str.js";import"./vendor.fortawesome.pro-light-svg-icons.js";import"./DynamicIcon.js";import"./vendor.fortawesome.pro-regular-svg-icons.js";import"./vendor.fortawesome.pro-solid-svg-icons.js";import"./vendor.date-fns.js";import"./vendor.phoenix.js";import"./vendor.uuid.js";const n=({state:n})=>{const i=t(),[a,c]=e.useState("notIdentified");e.useEffect((()=>{let e,t,r=!1;const a=async()=>{c("trackerLoading");const{tracker:e}=await i.send({kind:"GetTrackerForTesting",token:n.token});if(r)return;const{condition:a}=e,d=o[a.type];let l=!1;t=d.track({sessionData:new s(e.data),condition:a,flipBackEvents:!0,callback:e=>{const t=l;l=e,!t&&e&&i.setSessionStorageState((e=>({...e,trackerTesting:{...e.trackerTesting,events:e.trackerTesting.events+1}})))}}),c("trackerLoaded")};return e=()=>{i.off("private:identified",e),a()},i.isIdentified()?e():i.on("private:identified",e),()=>{r=!0,e&&i.off("private:identified",e),t&&t()}}),[i,n.token]);const d=e.useCallback((async()=>{i.setSessionStorageState((e=>({...e,activeApp:null,trackerTesting:null}))),i.getTargetEnv().postBuilderMessage({kind:"userflow:testTrackerClosed"})}),[i]);return e.createElement(r,{buttons:e.createElement("button",{className:"btn btn--default",onClick:()=>d()},"Back to Builder")},e.createElement("div",null,e.createElement("div",{className:"label"},"Testing tracker: ",n.trackerName),"notIdentified"===a?e.createElement("div",null,"Waiting for your app to identify user..."):"trackerLoading"===a?e.createElement("div",null,"Loading tracker..."):0===n.events?e.createElement("div",{className:"error"},"Not tracked yet"):e.createElement("div",{className:"success"},"Tracked ",n.events," time",1===n.events?"":"s")))};export default n;export{n as TrackerTestingApp};
package/Trigger.js ADDED
@@ -0,0 +1 @@
1
+ import{r}from"./vendor.react.js";import{e as t,u as o,h as e}from"./BubbleToolbar.js";import{u as s}from"./client-context.js";const n=({trigger:n})=>{const a=s(),c=t(),u=r.useRef(!1),i=o(n.condition);return r.useLayoutEffect((()=>{i&&!u.current&&(u.current=!0,e(a,c,n.actions))}),[i,u,a,c,n.actions]),null};export{n as T};
@@ -0,0 +1,18 @@
1
+ .userflowjs-avatar-frame-root {
2
+ width: 100%;
3
+ height: 100%;
4
+ overflow: hidden;
5
+ background-color: var(--userflow-main-background-color, #fff);
6
+ border-radius: 100%;
7
+ border-width: var(--userflow-bubble-border-width);
8
+ border-style: solid;
9
+ border-color: var(--userflow-bubble-border-color);
10
+ }
11
+ .userflowjs-avatar-frame-root img {
12
+ width: 100%;
13
+ height: 100%;
14
+ object-fit: cover;
15
+ }
16
+ .userflowjs-avatar-frame-root--minimizable {
17
+ cursor: pointer;
18
+ }