@halo-lab/vue-form-hubspot
Version:
Vue custom form integration with the Hubspot service
802 lines (801 loc) • 22.5 kB
JavaScript
import { onBeforeMount as Y, computed as F, reactive as Z, provide as j, openBlock as m, createElementBlock as f, normalizeClass as c, withModifiers as W, renderSlot as q, toDisplayString as I, ref as T, resolveComponent as p, Fragment as B, createCommentVNode as O, createVNode as S, inject as M, withDirectives as k, createElementVNode as y, vModelDynamic as K, vModelText as H, createTextVNode as J, renderList as V, vModelRadio as X, vModelCheckbox as $ } from "vue";
const ee = (a, t) => a ? "" : `It seems like you didn’t fill in the field. Please, write your ${t} to continue`, te = (a, t) => /^\w+([.-]?\w+)*@\w+([.-]?\w+)*(\.\w{2,3})+$/.test(a) ? "" : `It seems like your ${t} is not valid. Please, enter valid ${t} to continue`, le = (a, t) => /^[0-9]+$/.test(a) ? "" : `It seems like your ${t} is not valid. Your ${t} must contain only numbers`, ae = (a, t) => /^([a-zA-Z]*)$/.test(a) ? "" : `It seems like your ${t} is not valid. Please, enter ${t} with only alphabetical characters to continue`, ne = (a, t, e) => !isNaN(a) && +a > +e ? `It seems like your ${t} is not valid. Your ${t} must be less than ${e}` : "", se = (a, t, e) => !isNaN(a) && +a < +e ? `It seems like your ${t} is not valid. Your ${t} must be at least ${e}` : "", re = (a, t, e) => e && a.length < e ? `It seems like your ${t} is not valid. Your ${t} must contain at least ${e} charackters` : "", ie = (a, t, e) => e && a.length > e ? `It seems like your ${t} is not valid. Your ${t} must contain less charackters than ${e}` : "", oe = (a, t, e) => e.test(a) ? "" : `It seems like you fill in the ${t} field incorrectly. Please, check it to continue`, G = {
required: ee,
email: te,
number: le,
letters: ae,
min: se,
max: ne,
minLength: re,
maxLength: ie,
regexp: oe
}, ue = (a, t, e, l) => a === "func" ? l(e) : G[a] ? G[a](e, t, l) : "", de = (a, t, e, l, s) => {
Y(() => {
e(a, t), s[a] = t ?? void 0;
});
const r = F({
get: () => l(a) ?? t,
set: (d) => {
e(a, d);
}
});
return {
value: r,
validate: (d, C) => {
if (d)
for (const N of d) {
const { name: h, message: _, value: o } = N;
let b = ue(h, a, r.value, o);
if (b)
return h === "func" && (b = _), C(a, b), b;
}
},
fileValidate: (d, C, N) => {
if (!d)
return;
const h = d.name.toLowerCase().split(".").slice(-1)[0], _ = C.map((o) => o.toLowerCase()).includes(h) ? "" : "This document is not supported, please delete and upload another file.";
return _ && N(a, _), _;
},
resetError: (d) => {
d(a, "");
}
};
}, ce = (a, t) => {
const e = Z({}), l = {}, s = Z({}), r = {}, u = (o) => e[o], i = (o, b) => {
e[o] = b;
}, n = (o) => s[o], d = (o, b) => {
s[o] = b;
}, C = () => Object.values(s).some((o) => !!o), N = (o, b, x) => {
const {
value: A,
validate: D,
resetError: E,
fileValidate: U
} = de(
o,
b,
i,
u,
l
), g = () => D(x, d), L = () => E(d), P = (Q, R) => U(Q, R, d);
return r[o] = o.includes("[]") ? P : g, {
value: A,
validate: g,
resetError: L,
fileFieldValidate: P
};
}, h = () => {
Object.keys(e).forEach(
(o) => i(o, l[o])
), Object.keys(s).forEach((o) => s[o] = void 0);
};
return {
registerField: N,
getFieldError: n,
onSubmit: async (o) => {
for (const D in r)
if (r[D]())
return;
if (o)
return o({ ...e });
if (!t)
throw new Error(
'You did not provided "portalId" and "formId" or submit callback function. Please, provide either'
);
const b = `https://api.hsforms.com/submissions/v3/integration/submit/${a}/${t}`, x = [];
for (let [D, E] of Object.entries(e))
Array.isArray(E) && (E = E.join("; ")), x.push({ name: D, value: E });
const A = JSON.stringify({ fields: x });
try {
await fetch(b, {
method: "POST",
body: A,
headers: {
Accept: "application/json",
"Content-Type": "application/json"
}
});
} catch (D) {
console.log(D);
} finally {
h();
}
},
hasFormErrors: C,
setFieldError: d
};
};
const v = (a, t) => {
const e = a.__vccOpts || a;
for (const [l, s] of t)
e[l] = s;
return e;
}, me = {
props: {
hubspotPortalId: {
type: String,
default: ""
},
hubspotFormId: {
type: String,
default: ""
},
className: {
type: String,
default: ""
},
submitHandler: {
type: Function,
default: null
}
},
setup(a) {
const { hubspotPortalId: t, hubspotFormId: e } = a, {
registerField: l,
onSubmit: s,
hasFormErrors: r,
getFieldError: u,
setFieldError: i
} = ce(t, e);
return j("registerField", l), j("getFieldError", u), j("hasFormErrors", r), j("setFieldError", i), { onSubmit: s };
}
};
function fe(a, t, e, l, s, r) {
return m(), f("form", {
class: c(["form", { [e.className]: e.className }]),
onSubmit: t[0] || (t[0] = W(() => l.onSubmit(e.submitHandler), ["prevent"])),
novalidate: ""
}, [
q(a.$slots, "default")
], 34);
}
const Re = /* @__PURE__ */ v(me, [["render", fe]]), be = {
props: {
label: {
type: String
},
isDisabled: {
type: Boolean,
default: !1
},
className: {
type: String,
default: ""
}
}
};
function ye(a, t, e, l, s, r) {
return m(), f("label", {
class: c({
label: !0,
[e.className]: e.className,
"label-disabled": e.isDisabled
})
}, I(e.label), 3);
}
const w = /* @__PURE__ */ v(be, [["render", ye]]), ge = {
props: {
type: {
type: String,
default: "info"
},
text: {
type: String,
default: "",
required: !0
},
isVisible: {
type: Boolean,
default: !1
}
}
};
function Ne(a, t, e, l, s, r) {
return m(), f("div", {
class: c([
"tooltip",
{
[`tooltip-${e.type}`]: !0,
[`tooltip-${e.isVisible ? "visible" : "hidden"}`]: !0
}
])
}, I(e.text), 3);
}
const ve = /* @__PURE__ */ v(ge, [["render", Ne]]), Ce = "", he = {
components: { ToolTip: ve },
props: {
error: {
type: String,
default: ""
}
},
setup() {
return { tooltipShow: T(!1), imageUrl: Ce };
}
}, pe = ["src"];
function Se(a, t, e, l, s, r) {
const u = p("ToolTip");
return m(), f(B, null, [
e.error ? (m(), f("img", {
key: 0,
src: l.imageUrl,
alt: "Error icon",
class: "error-icon",
onMouseenter: t[0] || (t[0] = (i) => l.tooltipShow = !0),
onMouseleave: t[1] || (t[1] = (i) => l.tooltipShow = !1)
}, null, 40, pe)) : O("", !0),
S(u, {
type: "error",
text: e.error,
isVisible: l.tooltipShow
}, null, 8, ["text", "isVisible"])
], 64);
}
const z = /* @__PURE__ */ v(he, [["render", Se]]), Me = {
components: { Label: w, Error: z },
props: {
label: {
type: String,
default: ""
},
validator: {
type: Array,
default: null
},
placeholder: {
type: String
},
type: {
type: String,
default: "text"
},
isDisabled: {
type: Boolean
},
name: {
type: String,
requiered: !0
},
inputClassName: {
type: String,
default: ""
},
labelClassName: {
type: String,
default: ""
},
errorClassName: {
type: String,
default: ""
},
fieldClassName: {
type: String,
default: ""
},
defaultValue: {
type: String,
default: ""
}
},
setup(a) {
const { name: t, defaultValue: e, validator: l } = a, s = M("registerField"), r = M("getFieldError"), u = F(() => r(t)), { value: i, validate: n, resetError: d } = s(t, e, l);
return { value: i, error: u, onBlur: () => n(), onFocus: () => d(t) };
}
}, _e = ["placeholder", "type", "disabled", "name"];
function De(a, t, e, l, s, r) {
const u = p("Label"), i = p("Error");
return m(), f("div", {
class: c(["input-container", { [e.fieldClassName]: e.fieldClassName }])
}, [
S(u, {
label: e.label,
for: e.name,
className: e.labelClassName
}, null, 8, ["label", "for", "className"]),
k(y("input", {
class: c({
input: !0,
"input-error": l.error,
[e.inputClassName]: e.inputClassName,
[e.errorClassName]: l.error && e.errorClassName
}),
placeholder: e.placeholder,
type: e.type,
disabled: e.isDisabled,
name: e.name,
"onUpdate:modelValue": t[0] || (t[0] = (n) => l.value = n),
onBlur: t[1] || (t[1] = (...n) => l.onBlur && l.onBlur(...n)),
onFocus: t[2] || (t[2] = (...n) => l.onFocus && l.onFocus(...n))
}, null, 42, _e), [
[
K,
l.value,
void 0,
{ trim: !0 }
]
]),
S(i, { error: l.error }, null, 8, ["error"])
], 2);
}
const Ye = /* @__PURE__ */ v(Me, [["render", De]]), xe = {
components: { Label: w, Error: z },
props: {
label: {
type: String,
default: ""
},
validator: {
type: Array,
default: null
},
placeholder: {
type: String
},
isDisabled: {
type: Boolean
},
name: {
type: String,
requiered: !0
},
inputClassName: {
type: String,
default: ""
},
labelClassName: {
type: String,
default: ""
},
errorClassName: {
type: String,
default: ""
},
fieldClassName: {
type: String,
default: ""
},
defaultValue: {
type: String,
default: ""
}
},
setup(a) {
const { name: t, defaultValue: e, validator: l } = a, s = M("registerField"), r = M("getFieldError"), u = F(() => r(t)), { value: i, validate: n, resetError: d } = s(t, e, l);
return { value: i, error: u, onBlur: () => n(), onFocus: () => d(t) };
}
}, Ee = ["placeholder", "disabled", "name"];
function Fe(a, t, e, l, s, r) {
const u = p("Label"), i = p("Error");
return m(), f("div", {
class: c(["input-container", { [e.fieldClassName]: e.fieldClassName }])
}, [
S(u, {
label: e.label,
for: e.name,
className: e.labelClassName
}, null, 8, ["label", "for", "className"]),
k(y("textarea", {
class: c({
"input input-textarea": !0,
"input-error": l.error,
[e.inputClassName]: e.inputClassName,
[e.errorClassName]: l.error && e.errorClassName
}),
"onUpdate:modelValue": t[0] || (t[0] = (n) => l.value = n),
placeholder: e.placeholder,
disabled: e.isDisabled,
onBlur: t[1] || (t[1] = (...n) => l.onBlur && l.onBlur(...n)),
onFocus: t[2] || (t[2] = (...n) => l.onFocus && l.onFocus(...n)),
name: e.name
}, null, 42, Ee), [
[
H,
l.value,
void 0,
{ trim: !0 }
]
]),
S(i, { error: l.error }, null, 8, ["error"])
], 2);
}
const We = /* @__PURE__ */ v(xe, [["render", Fe]]), Ie = {
props: {
isStroke: {
type: Boolean,
default: !1
},
label: {
type: String
},
type: {
type: String,
default: "button"
},
isDisabled: {
type: Boolean,
default: !1
},
isArrow: {
type: Boolean,
default: !1
},
isIcon: {
type: Boolean,
default: !1
},
className: {
type: String,
default: ""
}
},
setup(a) {
const { isDisabled: t, type: e } = a, l = M("hasFormErrors");
return { disabled: F(() => l() && e === "submit" || t || t) };
}
}, Le = ["type", "disabled"];
function ke(a, t, e, l, s, r) {
return m(), f("button", {
type: e.type,
class: c([
"button",
{
"button-arrow": e.isArrow,
"button-stroked": e.isStroke,
"button-filled": !e.isIcon && !e.isStroke,
"button-icon": e.isIcon,
[e.className]: e.className
}
]),
disabled: l.disabled
}, [
J(I(e.label) + " ", 1),
q(a.$slots, "default")
], 10, Le);
}
const Ke = /* @__PURE__ */ v(Ie, [["render", ke]]), we = {
components: { Label: w, Error: z },
props: {
label: {
type: String,
default: ""
},
name: {
type: String,
requiered: !0
},
options: {
type: Array,
requiered: !0
},
defaultValue: {
type: String
},
search: {
type: Boolean,
default: !1
},
validator: {
type: Array
},
inputClassName: {
type: String,
default: ""
},
labelClassName: {
type: String,
default: ""
},
errorClassName: {
type: String,
default: ""
},
fieldClassName: {
type: String,
default: ""
},
isDisabled: {
type: Boolean,
default: !1
}
},
setup(a) {
const { name: t, defaultValue: e, validator: l, options: s } = a, r = T(""), u = M("registerField"), i = M("getFieldError"), n = F(() => i(t)), d = F(
() => s.filter((g) => g.label.toLowerCase().includes(r.value.toLowerCase()))
), C = s.map((g) => g.value).includes(e), { value: N, validate: h, resetError: _ } = u(t, C ? e : void 0, l), o = F(
() => {
var g;
return ((g = s.find((L) => L.value === N.value)) == null ? void 0 : g.label) ?? s[0].label;
}
), b = T(!1), x = T();
return {
value: N,
error: n,
currentOptions: d,
onBlur: (g) => {
var L;
if (((L = g.relatedTarget) == null ? void 0 : L.name) === "selectSearch") {
g.preventDefault();
return;
}
h(), r.value = "", b.value = !1;
},
onFocus: () => _(t),
currentLabel: o,
isOpened: b,
onChange: (g) => {
N.value = g, r.value = "", b.value = !1, x.value.blur(), h();
},
selectRef: x,
resetOpened: () => {
b.value = !b.value;
},
searchValue: r
};
}
}, Ae = /* @__PURE__ */ y("svg", {
class: "icon-arrow",
width: "12",
height: "6",
viewBox: "0 0 12 6",
fill: "none",
xmlns: "http://www.w3.org/2000/svg"
}, [
/* @__PURE__ */ y("path", {
d: "M1 1L6 5L11 0.999999",
stroke: "#060811",
"stroke-width": "1.5",
"stroke-linecap": "round",
"stroke-linejoin": "round"
})
], -1), je = {
key: 0,
class: "input-select-list"
}, Te = {
key: 0,
class: /* @__PURE__ */ c(["input-select-item input-select-item-search"])
}, Be = /* @__PURE__ */ y("svg", {
class: "search-icon",
width: "16",
height: "16",
viewBox: "0 0 16 16",
fill: "none",
xmlns: "http://www.w3.org/2000/svg"
}, [
/* @__PURE__ */ y("path", {
d: "M7.27268 0C11.2726 0 14.5454 3.27278 14.5454 7.27305C14.5454 9.01854 13.9273 10.6185 12.909 11.8549L15.7818 14.7278C16.0727 15.0186 16.0727 15.455 15.7818 15.746C15.6363 15.9277 15.4546 16.0005 15.2727 16.0005C15.0909 16.0005 14.909 15.9278 14.7636 15.7823L11.8908 12.9095C10.6181 13.9277 9.0181 14.5459 7.27274 14.5459C3.27278 14.5459 6.88781e-08 11.2731 6.88781e-08 7.27312C-0.00012171 3.27285 3.27278 6.54553e-05 7.27274 6.54553e-05L7.27268 0ZM7.27268 13.0911C10.4728 13.0911 13.0911 10.4729 13.0911 7.27274C13.0909 4.0729 10.4727 1.45467 7.27268 1.45467C4.07252 1.45467 1.4543 4.0729 1.4543 7.27305C1.4543 10.4729 4.07252 13.0911 7.27268 13.0911Z",
fill: "#9B9CA0"
})
], -1), Oe = ["onMousedown"];
function Ve(a, t, e, l, s, r) {
const u = p("Label"), i = p("Error");
return m(), f("div", {
class: c(["input-container", { [e.fieldClassName]: e.fieldClassName }])
}, [
S(u, {
label: e.label,
className: e.labelClassName,
isDisabled: e.isDisabled
}, null, 8, ["label", "className", "isDisabled"]),
y("div", {
onFocusin: t[2] || (t[2] = (...n) => l.onFocus && l.onFocus(...n)),
onFocusout: t[3] || (t[3] = (...n) => l.onBlur && l.onBlur(...n)),
tabindex: 0,
ref: "selectRef",
class: c({
"input input-select": !0,
"input-error": l.error,
[e.inputClassName]: e.inputClassName,
[e.errorClassName]: l.error && e.errorClassName,
disabled: e.isDisabled
})
}, [
y("div", {
class: "input-select-current",
onClick: t[0] || (t[0] = (...n) => l.resetOpened && l.resetOpened(...n))
}, [
J(I(l.currentLabel) + " ", 1),
Ae
]),
l.isOpened ? (m(), f("ul", je, [
e.search ? (m(), f("li", Te, [
k(y("input", {
class: "input input-search",
type: "text",
placeholder: "Type in something",
"onUpdate:modelValue": t[1] || (t[1] = (n) => l.searchValue = n),
name: "selectSearch"
}, null, 512), [
[H, l.searchValue]
]),
Be
])) : O("", !0),
(m(!0), f(B, null, V(l.currentOptions, (n) => (m(), f("li", {
class: c([
"input-select-item",
{ active: n.value === l.value }
]),
key: n.value,
onMousedown: () => l.onChange(n.value)
}, I(n.label), 43, Oe))), 128))
])) : O("", !0)
], 34),
S(i, { error: l.error }, null, 8, ["error"])
], 2);
}
const Xe = /* @__PURE__ */ v(we, [["render", Ve]]), ze = {
components: { Label: w },
props: {
label: {
type: String,
requiered: !0
},
isDisabled: {
type: Boolean
},
name: {
type: String,
requiered: !0
},
fields: {
type: Array,
requiered: !0
},
fieldClassName: {
type: String,
default: ""
},
labelClassName: {
type: String,
default: ""
},
inputClassName: {
type: String,
default: ""
},
inputLabelClassName: {
type: String,
default: ""
}
},
setup(a) {
var u;
const { name: t, fields: e } = a, l = M("registerField"), s = ((u = e.find((i) => i.checked)) == null ? void 0 : u.value) ?? e[0].value, { value: r } = l(t, s);
return { value: r };
}
}, Ue = { class: "box-field" }, Pe = ["disabled", "name", "value"];
function Ze(a, t, e, l, s, r) {
const u = p("Label");
return m(), f("div", {
class: c(["input-container", { [e.fieldClassName]: e.fieldClassName }])
}, [
S(u, {
label: e.label,
className: e.labelClassName,
isDisabled: e.isDisabled
}, null, 8, ["label", "className", "isDisabled"]),
y("div", {
class: c(["box-container", { disabled: e.isDisabled }])
}, [
(m(!0), f(B, null, V(e.fields, (i) => (m(), f("label", Ue, [
k(y("input", {
class: "hidden",
type: "radio",
disabled: e.isDisabled,
name: e.name,
"onUpdate:modelValue": t[0] || (t[0] = (n) => l.value = n),
value: i.value
}, null, 8, Pe), [
[X, l.value]
]),
y("span", {
class: c({
"input input-box input-radio": !0,
"input-radio-checked": l.value === i.value,
[e.inputClassName]: e.inputClassName
})
}, null, 2),
y("span", {
class: c(
{
"box-label": !0,
[e.inputLabelClassName]: e.inputLabelClassName
}
)
}, I(i.label), 3)
]))), 256))
], 2)
], 2);
}
const $e = /* @__PURE__ */ v(ze, [["render", Ze]]), Ge = {
components: { Label: w },
props: {
label: {
type: String,
requiered: !0
},
isDisabled: {
type: Boolean
},
name: {
type: String,
requiered: !0
},
fields: {
type: Array,
requiered: !0
},
fieldClassName: {
type: String,
default: ""
},
labelClassName: {
type: String,
default: ""
},
inputClassName: {
type: String,
default: ""
},
inputLabelClassName: {
type: String,
default: ""
}
},
setup(a) {
const { name: t } = a, e = M("registerField"), { value: l } = e(t, []);
return { value: l };
}
}, qe = { class: "box-field" }, He = ["disabled", "name", "value"];
function Je(a, t, e, l, s, r) {
const u = p("Label");
return m(), f("div", {
class: c(["input-container", { [e.fieldClassName]: e.fieldClassName }])
}, [
S(u, {
label: e.label,
className: e.labelClassName,
isDisabled: e.isDisabled
}, null, 8, ["label", "className", "isDisabled"]),
y("div", {
class: c(["box-container", { disabled: e.isDisabled }])
}, [
(m(!0), f(B, null, V(e.fields, (i) => (m(), f("label", qe, [
k(y("input", {
class: "hidden",
type: "checkbox",
disabled: e.isDisabled,
name: e.name,
"onUpdate:modelValue": t[0] || (t[0] = (n) => l.value = n),
value: i.value
}, null, 8, He), [
[$, l.value]
]),
y("span", {
class: c({
"input input-box input-checkbox": !0,
"input-checkbox-checked": l.value.includes(i.value),
[e.inputClassName]: e.inputClassName
})
}, null, 2),
y("span", {
class: c(
{
"box-label": !0,
[e.inputLabelClassName]: e.inputLabelClassName
}
)
}, I(i.label), 3)
]))), 256))
], 2)
], 2);
}
const et = /* @__PURE__ */ v(Ge, [["render", Je]]);
export {
Ke as Button,
et as CheckBoxGroup,
Re as Form,
Ye as Input,
$e as RadioGroup,
Xe as Select,
We as TextArea
};