@cling-se/widget 0.9.4 → 0.9.6

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 (131) hide show
  1. package/dist/{AddClientCallout-d472aa84.js → AddClientCallout-d8f5bc53.js} +5 -5
  2. package/dist/{AnswerModal-06487437.js → AnswerModal-5f83562b.js} +248 -248
  3. package/dist/{AttachmentItem-d98488ee.js → AttachmentItem-79eb718b.js} +8 -8
  4. package/dist/{BaseDatePicker-8c098701.js → BaseDatePicker-ae7aebf1.js} +43 -43
  5. package/dist/{BaseInput-2723d613.js → BaseInput-2c476604.js} +1 -1
  6. package/dist/{BaseUpload-996d74b3.js → BaseUpload-9e15729d.js} +3 -3
  7. package/dist/{BlockMedia-00907fb6.js → BlockMedia-a3f00a2f.js} +1 -1
  8. package/dist/{CCallout-ffa95028.js → CCallout-04e2c8c6.js} +6 -6
  9. package/dist/{CDropdownItem-74672842.js → CDropdownItem-5532f8af.js} +76 -75
  10. package/dist/{CField-06dd50f1.js → CField-0bc9de28.js} +1 -1
  11. package/dist/{CSlider.vue_vue_type_style_index_0_lang-f49d85e0.js → CSlider.vue_vue_type_style_index_0_lang-d9c2f582.js} +1 -1
  12. package/dist/{ClientAutocomplete-f65643dd.js → ClientAutocomplete-e13c2753.js} +4 -4
  13. package/dist/{ClientModal-d276aabd.js → ClientModal-da9fddf9.js} +16 -16
  14. package/dist/{ColorPicker-4f6b70af.js → ColorPicker-06b731b7.js} +2 -2
  15. package/dist/{CompanyModal-30c54ce3.js → CompanyModal-b7c42f2a.js} +8 -8
  16. package/dist/{ContentWrapper-d5653fef.js → ContentWrapper-fe4a67bc.js} +19 -19
  17. package/dist/{CoverBlockSettings-2335f3a8.js → CoverBlockSettings-2024e993.js} +19 -19
  18. package/dist/DocForm-af03179d.js +7012 -0
  19. package/dist/{DocFormSend-d0c6fa1d.js → DocFormSend-44161541.js} +14 -14
  20. package/dist/{DocModalBase-f4915a62.js → DocModalBase-9eb0f26f.js} +4 -4
  21. package/dist/DocPrint-92d12950.js +222 -0
  22. package/dist/{DocReceipt-d192000e.js → DocReceipt-4df57e1d.js} +1 -1
  23. package/dist/{DocSendReminder-06d5b34c.js → DocSendReminder-041af744.js} +1 -1
  24. package/dist/{DocTextEditor-c6d1df3c.js → DocTextEditor-b07dd391.js} +19 -19
  25. package/dist/{DocTimeline-b4c20f93.js → DocTimeline-2ae2ca63.js} +7 -7
  26. package/dist/{DocumentClient-c2319f00.js → DocumentClient-3a1aecf2.js} +8 -6
  27. package/dist/{formValidationMixin-4920ab53.js → DocumentLayout-ae49ac7a.js} +1617 -1709
  28. package/dist/{DocumentLogotype-1efd1ce9.js → DocumentLogotype-91436523.js} +3 -3
  29. package/dist/{EmbedInput-654c0477.js → EmbedInput-05e22228.js} +2 -2
  30. package/dist/{EmbedSettings-b81ec734.js → EmbedSettings-9dabb6d4.js} +10 -10
  31. package/dist/ErrorCallout-c7f69cd9.js +30 -0
  32. package/dist/{FilePreviewModal-895bd1bd.js → FilePreviewModal-167a40c8.js} +8 -7
  33. package/dist/{HeaderSettings-c6dac755.js → HeaderSettings-e9b177e0.js} +29 -29
  34. package/dist/{ImageSelectModal-7cece54e.js → ImageSelectModal-8565c461.js} +11 -11
  35. package/dist/{ImageUploadWrapper-53afd31d.js → ImageUploadWrapper-1e61e8da.js} +3 -3
  36. package/dist/{Index-5cc51230.js → Index-0708b238.js} +12 -12
  37. package/dist/{Index-82574a41.js → Index-0799eaba.js} +18 -19
  38. package/dist/{Index-1a7e98d7.js → Index-1f3de208.js} +11 -10
  39. package/dist/{Index-d8879ca9.js → Index-27a05d76.js} +2 -2
  40. package/dist/{Index-b15cfd62.js → Index-43899daf.js} +13 -13
  41. package/dist/{Index-c4de05aa.js → Index-4446581c.js} +10 -9
  42. package/dist/{Index-01c63c88.js → Index-49766088.js} +2 -2
  43. package/dist/{Index-caf5cf44.js → Index-630600c9.js} +94 -94
  44. package/dist/{Index-b14d0f03.js → Index-6b63686e.js} +4 -4
  45. package/dist/{Index-34c84bab.js → Index-716dbe24.js} +10 -10
  46. package/dist/{Index-f935c492.js → Index-72bcad54.js} +10 -10
  47. package/dist/{Index-61f7dc92.js → Index-84820d3d.js} +2 -2
  48. package/dist/{Index-e749f6f1.js → Index-85e8119e.js} +14 -14
  49. package/dist/Index-88e175bf.js +54 -0
  50. package/dist/{Index-e45a0c32.js → Index-89addabd.js} +27 -27
  51. package/dist/{Index-701f0d05.js → Index-8b29bd10.js} +2 -2
  52. package/dist/{Index-d45a1eff.js → Index-8d1c62be.js} +4 -4
  53. package/dist/{Index-63805642.js → Index-96a07794.js} +9 -9
  54. package/dist/{Index-60fc8a6e.js → Index-9bbfa37b.js} +3 -3
  55. package/dist/{Index-7443e91c.js → Index-a7a6f91c.js} +31 -31
  56. package/dist/{Index-8bca2d87.js → Index-a987a099.js} +9 -9
  57. package/dist/{Index-98e8bb86.js → Index-b6b60b81.js} +8 -8
  58. package/dist/{Index-5e35f4a2.js → Index-ba0c8eaa.js} +8 -8
  59. package/dist/{Index-9aaf8b90.js → Index-c038406f.js} +26 -26
  60. package/dist/Index-c53330d6.js +79 -0
  61. package/dist/{Index-9233cc83.js → Index-c58260f8.js} +15 -15
  62. package/dist/{Index-2535f58f.js → Index-c893d091.js} +2 -2
  63. package/dist/{Index-1d361d01.js → Index-ca112d97.js} +4 -4
  64. package/dist/{Index-cd76b120.js → Index-e728d2f7.js} +7 -7
  65. package/dist/{Index-6ef78b7a.js → Index-ecf93915.js} +2 -2
  66. package/dist/{Index-c7e68382.js → Index-eda700f4.js} +4 -4
  67. package/dist/{Index-82b5de12.js → Index-ee75e74a.js} +4 -4
  68. package/dist/{Index-c67218ce.js → Index-f75b1dd5.js} +15 -15
  69. package/dist/{Index-66c8cbfa.js → Index-fc722547.js} +4 -4
  70. package/dist/{InputToggleRow-9d8a7da4.js → InputToggleRow-483acc75.js} +5 -5
  71. package/dist/{IsPremiumPreStep-3a087524.js → IsPremiumPreStep-aa08f8c8.js} +856 -432
  72. package/dist/{MediaWrapper-d4a4b66f.js → MediaWrapper-ed7db800.js} +3 -3
  73. package/dist/{NotBindingText-b199006c.js → NotBindingText-a99b4f85.js} +2 -2
  74. package/dist/{PackageGroup-37ac99b1.js → PackageGroup-8cae78f1.js} +56 -56
  75. package/dist/{PdfTerms-8b52bb6e.js → PdfTerms-9c1c806e.js} +8 -7
  76. package/dist/{PdfViewer-38bd8439.js → PdfViewer-1227dda6.js} +5 -4
  77. package/dist/{PlainHtml-9174cbf6.js → PlainHtml-647219e9.js} +1 -1
  78. package/dist/PriceHeader-cfb22169.js +337 -0
  79. package/dist/{SearchApi-2e286be6.js → SearchApi-c0067742.js} +2 -2
  80. package/dist/{TermsSettings-c74eec79.js → TermsSettings-a0282ad7.js} +11 -11
  81. package/dist/{ThemeColorRow-3558367b.js → ThemeColorRow-71af67bd.js} +3 -3
  82. package/dist/{ToggleBinding-6c9c1ac3.js → ToggleBinding-16c2879e.js} +3 -3
  83. package/dist/{UploadModal-6d0abd77.js → UploadModal-084e3c2e.js} +16 -16
  84. package/dist/{VideoPlayerInput-77cd86aa.js → VideoPlayerInput-fe87698e.js} +3 -3
  85. package/dist/{VideoPlayerSettings-b7eb781c.js → VideoPlayerSettings-06cfaccc.js} +12 -12
  86. package/dist/VideoSelectModal-fa81fb92.js +111 -0
  87. package/dist/{answerDocumentMixin-66023e62.js → answerDocumentMixin-ef48c7eb.js} +3 -3
  88. package/dist/{cssMode-8552fc56.js → cssMode-916ae2c1.js} +7 -7
  89. package/dist/dom-068d1a7b.js +59 -0
  90. package/dist/{focusDrawerMixin-67462262.js → focusDrawerMixin-24942dd1.js} +1 -1
  91. package/dist/{formComponentsInstall-ad9c2a83.js → formComponentsInstall-2dfa2def.js} +25 -25
  92. package/dist/formValidationMixin-82793652.js +49 -0
  93. package/dist/{freemarker2-7e10a65d.js → freemarker2-6fd30e77.js} +7 -7
  94. package/dist/{handlebars-8045bfa8.js → handlebars-ff07e526.js} +7 -7
  95. package/dist/{html-8afcb633.js → html-5ad143f9.js} +7 -7
  96. package/dist/{htmlMode-1a2d1b48.js → htmlMode-adc834ff.js} +7 -7
  97. package/dist/{index-3d6d7a03.js → index-045c9c73.js} +31 -31
  98. package/dist/{index-c48c5eb4.js → index-1f068e8e.js} +3 -3
  99. package/dist/{index-bf93d7c2.js → index-6eda8be0.js} +7 -7
  100. package/dist/{index-f805bfce.js → index-b3fb8f92.js} +45 -45
  101. package/dist/index.es.js +8 -8
  102. package/dist/index.umd.js +565 -561
  103. package/dist/{javascript-dad5561e.js → javascript-9c241e8d.js} +8 -8
  104. package/dist/{jsonMode-ce09245f.js → jsonMode-36a8e1fd.js} +7 -7
  105. package/dist/{liquid-05247459.js → liquid-da99d7af.js} +7 -7
  106. package/dist/{main-04025a56.js → main-2dc98356.js} +15380 -12891
  107. package/dist/{mapFormMixin-8d073f99.js → mapFormMixin-4ac649c2.js} +1 -1
  108. package/dist/{publicSenderState-97108de1.js → publicSenderState-1db8a50c.js} +1 -1
  109. package/dist/{python-3f3513c5.js → python-15d86041.js} +7 -7
  110. package/dist/{razor-1f3e9c4e.js → razor-19e0207f.js} +7 -7
  111. package/dist/simplebar.min-9f5e0b8a.js +71 -0
  112. package/dist/style.css +2 -2
  113. package/dist/{template-42a1d852.js → template-069f0890.js} +1 -1
  114. package/dist/{throttle-a2c1f34d.js → throttle-f8ef830f.js} +2 -2
  115. package/dist/{tinycolor-88fa380f.js → tinycolor-78c3e3d5.js} +1 -1
  116. package/dist/{FormInputRow-9819eb71.js → tippy.esm-d2a6f864.js} +285 -285
  117. package/dist/{tsMode-4c026047.js → tsMode-7fcdffc4.js} +7 -7
  118. package/dist/{typescript-baf56f67.js → typescript-f492bdab.js} +7 -7
  119. package/dist/{utils-6670dea6.js → utils-aab0bc31.js} +1 -1
  120. package/dist/{vuedraggable.umd-d7138234.js → vuedraggable.umd-eb01eee5.js} +41 -41
  121. package/dist/{xml-ffc6146a.js → xml-976a8723.js} +7 -7
  122. package/package.json +3 -2
  123. package/stats.html +1 -1
  124. package/vite-plugin-library-asset-external/index.js +134 -0
  125. package/dist/DocForm-9ca24de4.js +0 -6772
  126. package/dist/ErrorCallout-60d0b3ab.js +0 -30
  127. package/dist/Index-b020a80c.js +0 -47
  128. package/dist/Index-e80f5f9c.js +0 -79
  129. package/dist/PriceHeader-e357afe9.js +0 -336
  130. package/dist/VideoSelectModal-d2299552.js +0 -111
  131. package/dist/simplebar.min-3af55aab.js +0 -2429
@@ -1,10 +1,397 @@
1
- import { n as o, o as p, a7 as b, ah as w, g as l, ai as P, aj as H, ak as I, al as k, b as L, p as B, x as C, I as y, am as x, X as D, an as V, ae as T } from "./main-04025a56.js";
2
- import { m as u, a as v, b as O } from "./vuex.esm-4a0fff7c.js";
3
- import { a as r } from "./anime.es-e284c852.js";
4
- import "./index-3d6d7a03.js";
5
- import { r as f } from "./regions-29ee6964.js";
6
- import { v as g } from "./index-805c56e4.js";
7
- const E = {
1
+ import { k as H, a2 as B, as as D, b as v, at as w, au as N, av as G, aw as W, ax as K, V, ay as Z, az as Y, n as d, q as y, ac as E, aA as _, g as p, aB as O, aC as $, aD as tt, aE as Q, p as et, h as L, I as x, aF as q, a1 as rt, aG as nt, ai as at } from "./main-2dc98356.js";
2
+ import { m as h, a as k, b as st } from "./vuex.esm-4a0fff7c.js";
3
+ import { a as u } from "./anime.es-e284c852.js";
4
+ import "./index-045c9c73.js";
5
+ import { r as A } from "./regions-29ee6964.js";
6
+ import { v as P } from "./index-805c56e4.js";
7
+ const it = (r) => {
8
+ if (document.getElementById("stripe-js"))
9
+ return r();
10
+ const t = "js.stripe.com/v3/", e = document.createElement("script"), n = document.getElementsByTagName("script")[0];
11
+ return e.src = `https://${t}`, e.id = "stripe-js", r && e.addEventListener("load", (a) => r(null, a), !1), n.parentNode.insertBefore(e, n), !0;
12
+ }, ot = () => it(() => {
13
+ window.$stripe = Stripe(H.stripe.publishableKey, { locale: B.lang || "en" });
14
+ });
15
+ ot();
16
+ const lt = (r) => B.te(`errors:${r}`) && B.t(`errors:${r}`), ct = "stripe", {
17
+ LOAD_PRICES: J,
18
+ RESET_STRIPE_FORM: ut,
19
+ SET_STRIPE_FORM_VALUE: dt,
20
+ SET_FORM_PROMOTION: U,
21
+ SUBMIT_PROMOTION_CODE: pt,
22
+ SUBMIT_PAYMENT_METHOD: X,
23
+ SUBMIT_FORM_PLAN: mt,
24
+ REMOVE_SUBSCRIPTION_ITEM: ft,
25
+ CONFIRM_PAYMENT: F,
26
+ SUBMIT_FORM_PAYMENT: b,
27
+ SUBMIT_FORM_PRODUCTS: vt
28
+ } = Y, M = {
29
+ // The term "plan" refers to a _price_ connected to a _product_ with metadata.accountType
30
+ plan: { accountType: "pro", interval: "month", quantity: 1 },
31
+ customer: { name: "", email: "", region: null },
32
+ promotion: null,
33
+ error: null,
34
+ // This array is meant for extra stripe products such as Fortnox API other then the license / metered quotas
35
+ products: [],
36
+ // Array of obj on format { quantity, stripePriceStripeId, stripeProductStripeId }
37
+ dealSource: null
38
+ // If the payment should be associated with a specific dealSource
39
+ }, R = {
40
+ SE: 0.25
41
+ }, j = {
42
+ namespaced: !0,
43
+ state: {
44
+ isFetching: !1,
45
+ isPosting: !1,
46
+ isPostingPaymentMethod: !1,
47
+ priceIds: [],
48
+ prices: {},
49
+ activePriceMap: {
50
+ start: { month: null, year: null },
51
+ base: { month: null, year: null },
52
+ pro: { month: null, year: null }
53
+ },
54
+ form: D(M)
55
+ },
56
+ getters: {
57
+ isPosting: ({ isPosting: r }) => r,
58
+ subscriptions: (r, t, e, n) => v(n["application/companyAccount"], "StripeSubscriptions") || [],
59
+ subscriptionItems: (r, { subscriptions: t }) => {
60
+ const e = [];
61
+ return t.forEach(({ stripeItems: n = [] }) => {
62
+ Array.isArray(n) && n.forEach((a) => {
63
+ e.push({
64
+ quantity: a.quantity,
65
+ stripePriceStripeId: a.stripePriceStripeId,
66
+ stripeProductStripeId: a.stripeProductStripeId
67
+ });
68
+ });
69
+ }), e;
70
+ },
71
+ customer: (r, t, e, n) => v(n["application/companyAccount"], "StripeCustomer") || null,
72
+ products: ({ prices: r }) => {
73
+ const t = {};
74
+ return Object.keys(r).forEach((e) => {
75
+ const n = r[e];
76
+ t[n.stripeProductId] || (t[n.stripeProductId] = { ...n.StripeProduct, prices: [] }), t[n.stripeProductId].prices.push(n);
77
+ }), t;
78
+ },
79
+ getProduct: (r, t) => (e) => {
80
+ const n = {
81
+ fortnox: "Fortnox API"
82
+ // apiDocuments,
83
+ // sms,
84
+ // bankId,
85
+ };
86
+ if (!n[e])
87
+ throw new Error(`Invalid product: ${e}`);
88
+ return Object.values(t.products).find((a) => a.name === n[e]);
89
+ },
90
+ getProductByPriceId: (r, t) => (e) => {
91
+ if (!e)
92
+ throw new Error("Missing parameter stripeId");
93
+ const n = t.priceById(e);
94
+ return n ? {
95
+ stripePriceStripeId: n.stripeId,
96
+ stripeProductStripeId: n.stripeProductId,
97
+ quantity: 1
98
+ } : null;
99
+ },
100
+ getMeteredProduct: (r, t) => (e) => {
101
+ if (!e)
102
+ throw new Error("Missing parameter meteredType");
103
+ const n = t.products, a = Object.keys(n).find((i) => v(n[i], "metadata.meteredType") === e);
104
+ return n[a];
105
+ },
106
+ formPromotion: (r) => r.form.promotion,
107
+ formCustomer: (r) => r.form.customer,
108
+ formDealSource: (r) => r.form.dealSource,
109
+ formError: (r) => r.form.error,
110
+ formPlan: (r, t) => {
111
+ const { accountType: e, interval: n, quantity: a } = r.form.plan;
112
+ if (!e || !n)
113
+ return null;
114
+ const i = t.getPrice(e, n);
115
+ return {
116
+ quantity: a,
117
+ accountType: e,
118
+ interval: n,
119
+ ...i
120
+ };
121
+ },
122
+ currentPlan: (r, t) => {
123
+ const { subscriptionItems: e } = t;
124
+ if (!e || !e.length)
125
+ return null;
126
+ const n = e.find((i) => v(r.prices[i.stripePriceStripeId], "StripeProduct.metadata.accountType"));
127
+ if (!n)
128
+ return null;
129
+ const a = r.prices[n.stripePriceStripeId];
130
+ return {
131
+ ...a,
132
+ quantity: n.quantity,
133
+ accountType: a.StripeProduct.metadata.accountType
134
+ };
135
+ },
136
+ priceById: (r) => (t) => r.prices[t],
137
+ getPrice: (r, t) => (e, n) => {
138
+ const { currentPlan: a } = t;
139
+ return a && a.accountType === e && a.interval === n && a.active ? a : r.prices[r.activePriceMap[e][n]] || null;
140
+ },
141
+ formProducts: (r) => r.form.products,
142
+ /**
143
+ * Get price summaries for the current form configuration
144
+ * @returns {Object} Price obj on format { intervals: {}, currency }
145
+ */
146
+ formPrices: (r, t) => {
147
+ function e(i, s, l) {
148
+ const o = i;
149
+ return (!o.intervals[s] || !Object.keys(o.intervals[s]).length) && (o.intervals[s] = {
150
+ subTotalBeforeDiscount: 0,
151
+ vatAmount: 0,
152
+ subTotal: 0,
153
+ totalAmount: 0,
154
+ items: []
155
+ }), Object.keys(l).forEach((c) => {
156
+ Array.isArray(l[c]) ? o.intervals[s][c] = o.intervals[s][c].concat(l[c]) : o.intervals[s][c] += l[c];
157
+ }), o;
158
+ }
159
+ let n = {
160
+ intervals: {},
161
+ currency: t.formPlan.currency
162
+ };
163
+ function a() {
164
+ const i = (t.formPlan.amount || 0) * t.formPlan.quantity;
165
+ let s = i;
166
+ t.formPromotion && (t.formPromotion.amountOff ? s -= t.formPromotion.amountOff : t.formPromotion.percentOff && (s *= 1 - t.formPromotion.percentOff / 100));
167
+ const l = s * (R[t.formCustomer.region] || 0), o = s + l;
168
+ n = e(n, t.formPlan.interval, {
169
+ subTotalBeforeDiscount: i,
170
+ subTotal: s,
171
+ vatAmount: l,
172
+ totalAmount: o,
173
+ items: [{
174
+ name: t.formPlan.accountType,
175
+ amount: i,
176
+ quantity: t.formPlan.quantity
177
+ }]
178
+ });
179
+ }
180
+ return a(), t.formProducts.forEach((i) => {
181
+ const s = t.priceById(i.stripePriceStripeId);
182
+ if (s) {
183
+ let l = s.interval;
184
+ s.usageType === "one_time" && (l = "oneOff");
185
+ const o = s.amount * i.quantity;
186
+ let c = o;
187
+ t.formPromotion && (t.formPromotion.amountOff ? c -= t.formPromotion.amountOff : t.formPromotion.percentOff && (c *= 1 - t.formPromotion.percentOff / 100));
188
+ const m = c * (R[t.formCustomer.region] || 0), f = c + m;
189
+ n = e(n, l, {
190
+ subTotalBeforeDiscount: o,
191
+ subTotal: c,
192
+ vatAmount: m,
193
+ totalAmount: f,
194
+ items: [{
195
+ name: s.StripeProduct.name,
196
+ amount: o,
197
+ quantity: i.quantity
198
+ }]
199
+ });
200
+ }
201
+ }), n;
202
+ }
203
+ },
204
+ actions: {
205
+ async [J]({ commit: r }) {
206
+ try {
207
+ r("setFetching", !0);
208
+ const { data: t } = await w.getPrices();
209
+ r("setPrices", { data: t }), r("setActivePriceMap");
210
+ } catch (t) {
211
+ this.handleError(t, {
212
+ action: `${ct}/${J}`,
213
+ actionPayload: null
214
+ });
215
+ } finally {
216
+ r("setFetching", !1);
217
+ }
218
+ },
219
+ async [ut]({ commit: r }) {
220
+ r("setForm", D(M));
221
+ },
222
+ async [dt]({ commit: r }, { key: t, value: e }) {
223
+ r("setFormValue", { key: t, value: e });
224
+ },
225
+ [U]({ commit: r, getters: t }, { promotionDetails: e, code: n = null } = {}) {
226
+ if (!e)
227
+ return !1;
228
+ const { appliesToStripeProductIds: a } = e, { stripeProductId: i } = t.formPlan || {};
229
+ return Array.isArray(a) && !a.includes(i) ? !1 : (r("setFormValue", { key: "promotion", value: { ...e, code: n } }), !0);
230
+ },
231
+ async [pt]({ commit: r, getters: t, dispatch: e }, n) {
232
+ try {
233
+ if (t.isPosting || !n)
234
+ return !1;
235
+ r("setPosting", !0);
236
+ const { data: a } = await N(n);
237
+ return e(U, { promotionDetails: a, code: n });
238
+ } catch {
239
+ return !1;
240
+ } finally {
241
+ r("setPosting", !1);
242
+ }
243
+ },
244
+ // Submit payment method to Stripe
245
+ async [X]({ commit: r }, { cardElement: t }) {
246
+ const e = window.$stripe;
247
+ try {
248
+ if (!t)
249
+ throw new Error("Missing parameter cardElement");
250
+ if (!e)
251
+ throw new Error("Stripe is not installed on the window");
252
+ r("setPostingPaymentMethod", !0);
253
+ const { paymentMethod: n = {}, error: a } = await e.createPaymentMethod("card", t);
254
+ if (a)
255
+ throw new Error(a.message || "Card Error");
256
+ const { id: i } = n, { last4: s, brand: l } = n.card || {};
257
+ return { id: i, last4: s, brand: l };
258
+ } catch (n) {
259
+ return this.handleError(n), null;
260
+ } finally {
261
+ r("setPostingPaymentMethod", !1);
262
+ }
263
+ },
264
+ /**
265
+ * Submit products to API to confirm changes
266
+ * @param {Object} Vuex
267
+ * @param {Object} obj
268
+ * @param {Object} obj.form Obj with form data to submit
269
+ * @param {Boolean} obj.removeUnusedItems Optional if items not specified should be removed, defaults true
270
+ * @returns {Promise<Boolean>} Resolves with true if successful, otherwise false
271
+ */
272
+ async [b]({ commit: r, getters: t, dispatch: e }, { form: n, stripe: { cardElement: a } = {}, removeUnusedItems: i = !0 } = {}) {
273
+ try {
274
+ r("setPosting", !0), r("setFormValue", { key: "error", value: null });
275
+ const { items: s } = n, { formCustomer: l, formPromotion: o, customer: c, formDealSource: m } = t;
276
+ let f;
277
+ a && (f = await e(X, { cardElement: a }));
278
+ const C = { ...l, items: s };
279
+ f && (C.paymentMethod = f), o && o.code && (C.promotionCode = o.code), m && (C.dealSource = m);
280
+ const { data: z = {} } = await w.product(C, { removeUnusedItems: i }), { clientSecrets: S } = z, T = f && f.id ? f.id : c && c.paymentMethodId;
281
+ return S && S.length && T ? await e(F, { clientSecrets: S, paymentMethodId: T }) : !0;
282
+ } catch (s) {
283
+ this.handleError(s);
284
+ const l = (s.errorCode ? lt(s.errorCode) : "") || s.message;
285
+ return r("setFormValue", { key: "error", value: l || "Submit Form Payment Error" }), !1;
286
+ } finally {
287
+ r("setPosting", !1);
288
+ }
289
+ },
290
+ async [mt]({ commit: r, dispatch: t, getters: e }, { cardElement: n } = {}) {
291
+ try {
292
+ const { formPlan: a, formProducts: i, products: s, subscriptionItems: l } = e;
293
+ if (!a)
294
+ return !1;
295
+ const o = [...l], c = o.findIndex((m) => v(s[m.stripeProductStripeId], "metadata.accountType"));
296
+ return c !== -1 && o.splice(c, 1), o.push({
297
+ stripePriceStripeId: a.stripeId,
298
+ stripeProductStripeId: a.stripeProductId,
299
+ quantity: a.quantity
300
+ }), o.push(...i), await t(b, { form: { items: o }, stripe: { cardElement: n } });
301
+ } catch (a) {
302
+ return this.handleError(a), r("setFormValue", { key: "error", value: a.message || "Submit Plan Error" }), !1;
303
+ }
304
+ },
305
+ async [vt]({ commit: r, dispatch: t, getters: e }, { cardElement: n, removeUnusedItems: a = !0 } = {}) {
306
+ try {
307
+ const { formProducts: i } = e, s = [...i];
308
+ return s.length ? await t(b, { form: { items: s }, stripe: { cardElement: n }, removeUnusedItems: a }) : !1;
309
+ } catch (i) {
310
+ return this.handleError(i), r("setFormValue", { key: "error", value: i.message || "Submit Products Error" }), !1;
311
+ }
312
+ },
313
+ /**
314
+ * Confirm a Stripe payment with secret(s) and paymentMethodId
315
+ * Some cards required confirmation on first and/or each payment.
316
+ * @param {Object} Vuex
317
+ * @param {Object} obj
318
+ * @param {Object[]} obj.clientSecrets Array of Stripe clientSecrets objects
319
+ * @param {String} obj.paymentMethodId The stripe payment method id to use
320
+ * @returns {Promise<Boolean>} Resolves with true if successful, otherwise false
321
+ */
322
+ async [F]({ commit: r }, { clientSecrets: t = [], paymentMethodId: e }) {
323
+ const n = window.$stripe;
324
+ try {
325
+ if (!e)
326
+ throw new Error("Missing parameter paymentMethodId");
327
+ if (!n)
328
+ throw new Error("Stripe is not installed on the window");
329
+ if (!Array.isArray(t))
330
+ throw new Error("Param clientSecrets needs to be an array");
331
+ return await t.reduce(async (i, s) => {
332
+ await i;
333
+ const { paymentIntent: l, error: o } = await n.confirmCardPayment(s, { payment_method: e });
334
+ return o ? (o.message && r("setFormValue", { key: "error", value: o.message }), await w.cancelAll({ immediately: !0, status: "incomplete" }), !1) : l && l.status === "succeeded";
335
+ }, Promise.resolve());
336
+ } catch (a) {
337
+ return this.handleError(a), !1;
338
+ }
339
+ },
340
+ /**
341
+ * Remove a specific item by priceId
342
+ * Action to remove a specific stripePriceStripeId from active items.
343
+ * @param {Object} Vuex
344
+ * @param {Object} obj
345
+ * @param {String} obj.stripePriceStripeId priceId to remove
346
+ * @returns {Promise<Boolean>} Resolves with true if successful, otherwise false
347
+ */
348
+ async [ft]({ commit: r, dispatch: t, getters: e }, { stripePriceStripeId: n }) {
349
+ try {
350
+ if (!n)
351
+ throw new Error("Missing parameter stripePriceStripeId");
352
+ r("setPosting", !0);
353
+ const { subscriptionItems: a } = e;
354
+ let i = [...a];
355
+ return i = i.filter((s) => s.stripePriceStripeId !== n), await t(b, { form: { items: i } });
356
+ } catch (a) {
357
+ return this.handleError(a), !1;
358
+ } finally {
359
+ r("setPosting", !1);
360
+ }
361
+ }
362
+ },
363
+ mutations: {
364
+ setFetching: (r, t) => {
365
+ r.isFetching = t;
366
+ },
367
+ setPosting: (r, t) => {
368
+ r.isPosting = t;
369
+ },
370
+ setPostingPaymentMethod: (r, t) => {
371
+ r.isPostingPaymentMethod = t;
372
+ },
373
+ // --- Prices ---
374
+ setPrices: (r, { data: t = [] }) => {
375
+ if (typeof t != "object")
376
+ throw Error("Data must be a priceItem or array of priceItems!");
377
+ const e = Array.isArray(t) ? t : [t], { ids: n, values: a } = G(e, { keyId: "stripeId" });
378
+ W(r.prices, a), r.priceIds = K([...n, ...r.priceIds]);
379
+ },
380
+ setActivePriceMap: ({ prices: r, activePriceMap: t }) => Object.keys(r).forEach((e) => {
381
+ const n = r[e], a = v(n, "StripeProduct.metadata.accountType");
382
+ a && n.active && v(n, "metadata.visible") === !0 && (t[a][n.interval] = e);
383
+ }),
384
+ // --- Form ---
385
+ setForm: (r, t) => {
386
+ V.set(r, "form", t);
387
+ },
388
+ setFormValue: (r, { key: t, value: e }) => {
389
+ const { root: n, prop: a } = Z(r, `form.${t}`);
390
+ V.set(n, a, e);
391
+ }
392
+ }
393
+ };
394
+ const gt = {
8
395
  props: {
9
396
  colors: {
10
397
  type: Array,
@@ -25,7 +412,7 @@ const E = {
25
412
  };
26
413
  },
27
414
  mounted() {
28
- this.canvasEl = document.getElementById("fireworks"), this.ctx = this.canvasEl.getContext("2d"), r({
415
+ this.canvasEl = document.getElementById("fireworks"), this.ctx = this.canvasEl.getContext("2d"), u({
29
416
  duration: 1 / 0,
30
417
  update: () => {
31
418
  this.ctx.clearRect(0, 0, this.canvasEl.width, this.canvasEl.height);
@@ -39,92 +426,92 @@ const E = {
39
426
  setCanvasSize() {
40
427
  this.canvasEl.width = window.innerWidth * 2, this.canvasEl.height = window.innerHeight * 2, this.canvasEl.style.width = `${window.innerWidth}px`, this.canvasEl.style.height = `${window.innerHeight}px`, this.canvasEl.getContext("2d").scale(2, 2);
41
428
  },
42
- updateCoords(n) {
43
- this.pointerX = n.clientX || n.touches[0].clientX, this.pointerY = n.clientY || n.touches[0].clientY;
429
+ updateCoords(r) {
430
+ this.pointerX = r.clientX || r.touches[0].clientX, this.pointerY = r.clientY || r.touches[0].clientY;
44
431
  },
45
- setParticleDirection(n) {
46
- const t = r.random(0, 360) * Math.PI / 180, e = r.random(100, 300), a = [-1, 1][r.random(0, 1)] * e;
432
+ setParticleDirection(r) {
433
+ const t = u.random(0, 360) * Math.PI / 180, e = u.random(100, 300), n = [-1, 1][u.random(0, 1)] * e;
47
434
  return {
48
- x: n.x + a * Math.cos(t),
49
- y: n.y + a * Math.sin(t)
435
+ x: r.x + n * Math.cos(t),
436
+ y: r.y + n * Math.sin(t)
50
437
  };
51
438
  },
52
- createParticle(n, t) {
439
+ createParticle(r, t) {
53
440
  const e = {};
54
- return e.x = n, e.y = t, e.color = this.colors[r.random(0, this.colors.length - 1)], e.radius = r.random(24, 50), e.endPos = this.setParticleDirection(e), e.draw = () => {
441
+ return e.x = r, e.y = t, e.color = this.colors[u.random(0, this.colors.length - 1)], e.radius = u.random(24, 50), e.endPos = this.setParticleDirection(e), e.draw = () => {
55
442
  this.ctx.beginPath(), this.ctx.arc(e.x, e.y, e.radius, 0, 2 * Math.PI, !0), this.ctx.fillStyle = e.color, this.ctx.fill();
56
443
  }, e;
57
444
  },
58
- createCircle(n, t) {
445
+ createCircle(r, t) {
59
446
  const e = {};
60
- return e.x = n, e.y = t, e.color = "hsl(205, 100%, 50%)", e.radius = 0.1, e.alpha = 0.5, e.lineWidth = 6, e.draw = () => {
447
+ return e.x = r, e.y = t, e.color = "hsl(205, 100%, 50%)", e.radius = 0.1, e.alpha = 0.5, e.lineWidth = 6, e.draw = () => {
61
448
  this.ctx.globalAlpha = e.alpha, this.ctx.beginPath(), this.ctx.arc(e.x, e.y, e.radius, 0, 2 * Math.PI, !0), this.ctx.lineWidth = e.lineWidth, this.ctx.strokeStyle = e.color, this.ctx.stroke(), this.ctx.globalAlpha = 1;
62
449
  }, e;
63
450
  },
64
- renderParticle(n) {
65
- for (let t = 0; t < n.animatables.length; t++)
66
- n.animatables[t].target.draw();
67
- },
68
- animateParticles(n, t) {
69
- const e = this.createCircle(n, t), a = [];
70
- for (let s = 0; s < this.numberOfParticles; s++)
71
- a.push(this.createParticle(n, t));
72
- r.timeline().add({
73
- targets: a,
74
- x(s) {
75
- return s.endPos.x;
451
+ renderParticle(r) {
452
+ for (let t = 0; t < r.animatables.length; t++)
453
+ r.animatables[t].target.draw();
454
+ },
455
+ animateParticles(r, t) {
456
+ const e = this.createCircle(r, t), n = [];
457
+ for (let a = 0; a < this.numberOfParticles; a++)
458
+ n.push(this.createParticle(r, t));
459
+ u.timeline().add({
460
+ targets: n,
461
+ x(a) {
462
+ return a.endPos.x;
76
463
  },
77
- y(s) {
78
- return s.endPos.y;
464
+ y(a) {
465
+ return a.endPos.y;
79
466
  },
80
467
  radius: 0.1,
81
- duration: r.random(1200, 1800),
468
+ duration: u.random(1200, 1800),
82
469
  easing: "easeOutExpo",
83
470
  update: this.renderParticle
84
471
  }).add({
85
472
  targets: e,
86
- radius: r.random(80, 160),
473
+ radius: u.random(80, 160),
87
474
  lineWidth: 0,
88
475
  alpha: {
89
476
  value: 0,
90
477
  easing: "linear",
91
- duration: r.random(600, 800)
478
+ duration: u.random(600, 800)
92
479
  },
93
- duration: r.random(1200, 1800),
480
+ duration: u.random(1200, 1800),
94
481
  easing: "easeOutExpo",
95
482
  update: this.renderParticle,
96
483
  offset: 0
97
484
  });
98
485
  },
99
486
  autoClick() {
100
- const n = window.innerWidth / 2, t = window.innerHeight / 2;
487
+ const r = window.innerWidth / 2, t = window.innerHeight / 2;
101
488
  this.animate && (this.animateParticles(
102
- r.random(n - 50, n + 50),
489
+ u.random(r - 50, r + 50),
103
490
  // 50 as constant
104
- r.random(t - 50, t + 50)
491
+ u.random(t - 50, t + 50)
105
492
  // 50 as constant
106
- ), r({ duration: 500 }).finished.then(this.autoClick));
493
+ ), u({ duration: 500 }).finished.then(this.autoClick));
107
494
  }
108
495
  }
109
496
  };
110
- var Q = function() {
497
+ var ht = function() {
111
498
  var t = this;
112
499
  return t._self._c, t._m(0);
113
- }, J = [function() {
114
- var n = this, t = n._self._c;
500
+ }, yt = [function() {
501
+ var r = this, t = r._self._c;
115
502
  return t("div", [t("canvas", { attrs: { id: "fireworks" } })]);
116
- }], X = /* @__PURE__ */ o(
117
- E,
118
- Q,
119
- J,
503
+ }], Ct = /* @__PURE__ */ d(
504
+ gt,
505
+ ht,
506
+ yt,
120
507
  !1,
121
508
  null,
122
509
  "d4677903",
123
510
  null,
124
511
  null
125
512
  );
126
- const q = X.exports;
127
- const U = {
513
+ const At = Ct.exports;
514
+ const Pt = {
128
515
  name: "PremiumStripeSelect",
129
516
  i18nOptions: {
130
517
  namespaces: "PremiumStripeSelect",
@@ -160,29 +547,29 @@ const U = {
160
547
  }
161
548
  },
162
549
  computed: {
163
- ...u({
550
+ ...h({
164
551
  currentPlan: "stripe/currentPlan",
165
552
  getPrice: "stripe/getPrice"
166
553
  }),
167
554
  currentAccountType() {
168
- var n;
169
- return (n = this.currentPlan) == null ? void 0 : n.accountType;
555
+ var r;
556
+ return (r = this.currentPlan) == null ? void 0 : r.accountType;
170
557
  },
171
558
  currentInterval() {
172
- var n;
173
- return (n = this.currentPlan) == null ? void 0 : n.interval;
559
+ var r;
560
+ return (r = this.currentPlan) == null ? void 0 : r.interval;
174
561
  }
175
562
  },
176
563
  created() {
177
564
  this.$nextTick(() => {
178
- r({
565
+ u({
179
566
  targets: ".anim-block",
180
567
  translateY: [50, 0],
181
568
  opacity: [0, 1],
182
- delay: r.stagger(80),
569
+ delay: u.stagger(80),
183
570
  easing: "spring(1, 70, 20, 9)",
184
- complete: (n) => {
185
- n.animatables.forEach(({ target: t }) => {
571
+ complete: (r) => {
572
+ r.animatables.forEach(({ target: t }) => {
186
573
  t.style.transform = "", this.$el.classList.remove("animating");
187
574
  });
188
575
  }
@@ -190,49 +577,49 @@ const U = {
190
577
  });
191
578
  },
192
579
  methods: {
193
- getPriceFormatted(n) {
194
- const { amount: t, currency: e } = this.getPrice(n.accountType, this.interval) || {};
580
+ getPriceFormatted(r) {
581
+ const { amount: t, currency: e } = this.getPrice(r.accountType, this.interval) || {};
195
582
  if (typeof t > "u" || typeof e > "u")
196
583
  return "";
197
- const a = t / (this.interval === "month" ? 1 : 12);
198
- return `${p(a, { currency: e })}/${this.$t("_common:month")}`;
584
+ const n = t / (this.interval === "month" ? 1 : 12);
585
+ return `${y(n, { currency: e })}/${this.$t("_common:month")}`;
199
586
  }
200
587
  }
201
588
  };
202
- var z = function() {
589
+ var bt = function() {
203
590
  var t = this, e = t._self._c;
204
591
  return e("div", { staticClass: "flex flex-col items-center w-full animating", staticStyle: { "padding-top": "30px" } }, [e("div", { staticClass: "flex flex-col items-center w-full text-center anim-block", staticStyle: { "margin-bottom": "50px" } }, [e("div", { staticStyle: { "font-size": "22px", "font-weight": "600", "margin-bottom": "20px", "max-width": "20ch" }, domProps: { innerHTML: t._s(t.$t("title", { brand: t.$t("_common:brand.name") })) } }), e("div", { staticStyle: { position: "relative" } }, [e("div", { staticClass: "tgl-btn-group" }, t._l([
205
592
  "month",
206
593
  "year"
207
- ], function(a) {
208
- return e("div", { key: a, staticClass: "tgl-btn", class: {
209
- selected: t.interval === a
210
- }, domProps: { textContent: t._s(t.$t(`_common:paymentInterval.${a}`).capitalize()) }, on: { click: function(s) {
211
- return t.$emit("update:interval", a);
594
+ ], function(n) {
595
+ return e("div", { key: n, staticClass: "tgl-btn", class: {
596
+ selected: t.interval === n
597
+ }, domProps: { textContent: t._s(t.$t(`_common:paymentInterval.${n}`).capitalize()) }, on: { click: function(a) {
598
+ return t.$emit("update:interval", n);
212
599
  } } });
213
- }), 0), e("div", { staticStyle: { position: "absolute", left: "88%", "font-size": "13px", "white-space": "nowrap", top: "112%", color: "hsl(205, 100%, 45%)" } }, [e("svg", { attrs: { width: "14", height: "14", viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg" } }, [e("path", { attrs: { d: "M1.73255 11.5162L3.78467 5.87805L9.42282 7.93017", stroke: "currentColor", "stroke-width": "2", "stroke-linecap": "round", "stroke-linejoin": "round" } }), e("path", { attrs: { d: "M3.78467 5.87805C4.42683 7.25608 8.24738 13.7995 10.2964 15.6909C13.8158 18.9395 19.2241 17.4113 22.0419 16.6886", stroke: "currentColor", "stroke-width": "2", "stroke-linecap": "round", "stroke-linejoin": "round" } })]), e("span", { staticStyle: { "padding-left": "0.25em" }, domProps: { textContent: t._s(t.$t("saveYearly")) } })])])]), e("div", { staticClass: "PriceGrid" }, t._l(t.plans, function(a, s) {
214
- return e("div", { key: s, staticClass: "PriceItem anim-block", class: {
215
- selected: t.plan === a.accountType
600
+ }), 0), e("div", { staticClass: "text-primary-600 absolute whitespace-nowrap text-[13px] left-[88%] top-[112%]" }, [e("svg", { attrs: { width: "14", height: "14", viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg" } }, [e("path", { attrs: { d: "M1.73255 11.5162L3.78467 5.87805L9.42282 7.93017", stroke: "currentColor", "stroke-width": "2", "stroke-linecap": "round", "stroke-linejoin": "round" } }), e("path", { attrs: { d: "M3.78467 5.87805C4.42683 7.25608 8.24738 13.7995 10.2964 15.6909C13.8158 18.9395 19.2241 17.4113 22.0419 16.6886", stroke: "currentColor", "stroke-width": "2", "stroke-linecap": "round", "stroke-linejoin": "round" } })]), e("span", { staticStyle: { "padding-left": "0.25em" }, domProps: { textContent: t._s(t.$t("saveYearly")) } })])])]), e("div", { staticClass: "PriceGrid" }, t._l(t.plans, function(n, a) {
601
+ return e("div", { key: a, staticClass: "PriceItem anim-block", class: {
602
+ selected: t.plan === n.accountType
216
603
  }, on: { click: function(i) {
217
- return t.$emit("update:plan", a.accountType);
218
- } } }, [e("div", [e("img", { staticStyle: { "box-shadow": "0 4px 6px rgba(240, 147, 234, 0.34)", "border-radius": "50%" }, attrs: { src: a.img, alt: a.name, width: "50", height: "50" } })]), e("div", { staticClass: "PriceItem__title" }, [e("span", { domProps: { textContent: t._s(a.name) } }), t._v("   ")]), t.currentAccountType === a.accountType ? e("svg", { directives: [{ name: "tooltip", rawName: "v-tooltip", value: t.$t("currentPlan"), expression: "$t('currentPlan')" }], staticClass: "PriceItem__current_badge", attrs: { width: "50", height: "50", viewBox: "0 0 70 70", fill: "none", xmlns: "http://www.w3.org/2000/svg" } }, [e("path", { attrs: { d: "M0 0H70V70L0 0Z", fill: "hsl(240, 7%, 83%)" } }), e("path", { attrs: { d: "M39.4203 23.5667L45 29.1464L57.0732 17.0732", stroke: "white", "stroke-width": "4" } })]) : t._e(), e("div", { staticClass: "PriceItem__cost" }, [e("span", { staticStyle: { display: "inline-block" }, domProps: { textContent: t._s(t.getPriceFormatted(a)) } }), t._v("   ")]), e("div", { staticStyle: { "font-size": "14px", "margin-bottom": "20px", color: "hsl(240, 8%, 45%)", "min-height": "2em" } }, [e("transition", { attrs: { name: "vertical-fader" } }, [t.interval === "year" ? e("span", { staticStyle: { display: "inline-block" }, domProps: { textContent: t._s(t.$t("billedYearly")) } }) : t._e()])], 1), e("ul", { staticClass: "PriceItem__text" }, t._l(a.features, function(i) {
604
+ return t.$emit("update:plan", n.accountType);
605
+ } } }, [e("div", [e("img", { staticStyle: { "box-shadow": "0 4px 6px rgba(240, 147, 234, 0.34)", "border-radius": "50%" }, attrs: { src: n.img, alt: n.name, width: "50", height: "50" } })]), e("div", { staticClass: "PriceItem__title" }, [e("span", { domProps: { textContent: t._s(n.name) } }), t._v("   ")]), t.currentAccountType === n.accountType ? e("svg", { directives: [{ name: "tooltip", rawName: "v-tooltip", value: t.$t("currentPlan"), expression: "$t('currentPlan')" }], staticClass: "PriceItem__current_badge", attrs: { width: "50", height: "50", viewBox: "0 0 70 70", fill: "none", xmlns: "http://www.w3.org/2000/svg" } }, [e("path", { attrs: { d: "M0 0H70V70L0 0Z", fill: "hsl(240, 7%, 83%)" } }), e("path", { attrs: { d: "M39.4203 23.5667L45 29.1464L57.0732 17.0732", stroke: "white", "stroke-width": "4" } })]) : t._e(), e("div", { staticClass: "PriceItem__cost" }, [e("span", { staticStyle: { display: "inline-block" }, domProps: { textContent: t._s(t.getPriceFormatted(n)) } }), t._v("   ")]), e("div", { staticStyle: { "font-size": "14px", "margin-bottom": "20px", color: "hsl(240, 8%, 45%)", "min-height": "2em" } }, [e("transition", { attrs: { name: "vertical-fader" } }, [t.interval === "year" ? e("span", { staticStyle: { display: "inline-block" }, domProps: { textContent: t._s(t.$t("billedYearly")) } }) : t._e()])], 1), e("ul", { staticClass: "PriceItem__text" }, t._l(n.features, function(i) {
219
606
  return e("li", { key: i }, [e("span", { domProps: { textContent: t._s(i) } })]);
220
607
  }), 0)]);
221
- }), 0), e("CButton", { staticClass: "anim-block sticky-btn", attrs: { disabled: t.currentAccountType === t.plan && t.currentInterval === t.interval, type: "secondary", "icon-right": "arrow-right" }, on: { click: function(a) {
608
+ }), 0), e("CButton", { staticClass: "anim-block sticky-btn", attrs: { disabled: t.currentAccountType === t.plan && t.currentInterval === t.interval, type: "secondary", "icon-right": "arrow-right" }, on: { click: function(n) {
222
609
  return t.$emit("next");
223
610
  } } }, [t._v(t._s(t.$t("continueButton")))])], 1);
224
- }, F = [], R = /* @__PURE__ */ o(
225
- U,
226
- z,
227
- F,
611
+ }, kt = [], St = /* @__PURE__ */ d(
612
+ Pt,
613
+ bt,
614
+ kt,
228
615
  !1,
229
616
  null,
230
- "d75cd7fd",
617
+ "59cedf98",
231
618
  null,
232
619
  null
233
620
  );
234
- const j = R.exports;
235
- const M = {
621
+ const wt = St.exports;
622
+ const xt = {
236
623
  props: {
237
624
  defaultOpen: {
238
625
  type: Boolean,
@@ -262,8 +649,8 @@ const M = {
262
649
  get() {
263
650
  return this.value === null ? this.internalExpanded : this.value;
264
651
  },
265
- set(n) {
266
- this.value === null ? this.internalExpanded = n : this.$emit("input", this.value);
652
+ set(r) {
653
+ this.value === null ? this.internalExpanded = r : this.$emit("input", this.value);
267
654
  }
268
655
  }
269
656
  },
@@ -274,43 +661,43 @@ const M = {
274
661
  this.expanded && this.setWrapperHeightTo("auto");
275
662
  },
276
663
  methods: {
277
- onEnter(n) {
278
- this.setWrapperHeightTo(this.getContentHeight(), n);
664
+ onEnter(r) {
665
+ this.setWrapperHeightTo(this.getContentHeight(), r);
279
666
  },
280
- onAfterEnter(n) {
281
- this.setWrapperHeightTo("auto", n);
667
+ onAfterEnter(r) {
668
+ this.setWrapperHeightTo("auto", r);
282
669
  },
283
- onBeforeLeave(n) {
284
- this.setWrapperHeightTo(this.getContentHeight(), n);
670
+ onBeforeLeave(r) {
671
+ this.setWrapperHeightTo(this.getContentHeight(), r);
285
672
  },
286
- onLeave(n) {
287
- n.scrollHeight, this.setWrapperHeightTo(0, n);
673
+ onLeave(r) {
674
+ r.scrollHeight, this.setWrapperHeightTo(0, r);
288
675
  },
289
676
  getContentHeight() {
290
- const { inner: n } = this.$refs;
291
- return n.getBoundingClientRect().height;
677
+ const { inner: r } = this.$refs;
678
+ return r.getBoundingClientRect().height;
292
679
  },
293
- setWrapperHeightTo(n, t = this.$refs.wrapper) {
294
- t.style.height = typeof n == "number" ? `${n}px` : n;
680
+ setWrapperHeightTo(r, t = this.$refs.wrapper) {
681
+ t.style.height = typeof r == "number" ? `${r}px` : r;
295
682
  }
296
683
  }
297
684
  };
298
- var N = function() {
685
+ var It = function() {
299
686
  var t = this, e = t._self._c;
300
- return e("div", [e("div", { on: { click: function(a) {
687
+ return e("div", [e("div", { on: { click: function(n) {
301
688
  t.expanded = !t.expanded;
302
689
  } } }, [t._t("trigger", null, { expanded: t.expanded })], 2), e("transition", { on: { enter: t.onEnter, "after-enter": t.onAfterEnter, "before-leave": t.onBeforeLeave, leave: t.onLeave } }, [t.expanded ? e("div", { ref: "wrapper", staticClass: "c-accordion", style: t.wrapperStyle }, [e("div", { ref: "inner", staticClass: "c-accordion__inner" }, [t._t("default")], 2)]) : t._e()])], 1);
303
- }, G = [], W = /* @__PURE__ */ o(
304
- M,
305
- N,
306
- G,
690
+ }, Ht = [], Bt = /* @__PURE__ */ d(
691
+ xt,
692
+ It,
693
+ Ht,
307
694
  !1,
308
695
  null,
309
696
  null,
310
697
  null,
311
698
  null
312
699
  );
313
- const K = W.exports, Z = {
700
+ const Lt = Bt.exports, Tt = {
314
701
  amex: {
315
702
  name: "American Express",
316
703
  logo: '<g><rect width="48" height="32" rx="4" fill="white"/><g><path d="M8.88 17.9V26.06H17.14L18 24.84L18.84 26.06H23.89V24.22H24.45C24.9584 24.2244 25.4643 24.1502 25.95 24V26.06H29.38V24.6L30.54 26.06H46.16C46.802 26.0712 47.4338 25.8977 47.98 25.56V29C47.5224 30.7722 45.9203 32.0078 44.09 32H4C1.79086 32 0 30.2091 0 28V15.4H2.28L2.75 14.18H3.87L4.33 15.4H22.67V13.94L23.83 15.4H28.64V14.66C29.3453 15.1621 30.1945 15.4217 31.06 15.4H33.93L34.39 14.18H35.51L36 15.4H40.9V13.82L41.9 15.4H45.28V7.24H41.69V8.9L40.62 7.24H37.48V9.34L36.48 7.24H31.14C30.2366 7.21382 29.3524 7.50384 28.64 8.06V7.24H11L10.4 9L9.8 7.2H5.8V9.3L4.86 7.2H1.6L0 11V4C0 1.79086 1.79086 1.31011e-07 4 1.31011e-07H44.09C45.9278 -0.0169872 47.5406 1.2205 48 3V17.9H18.86L18 19.1L17.16 17.9H8.88Z" fill="#296DB6"/><path fill-rule="evenodd" clip-rule="evenodd" d="M21.32 19.2H24.43V19.16C24.9479 19.1165 25.4595 19.2976 25.8345 19.6574C26.2096 20.0171 26.4119 20.5208 26.39 21.04C26.4028 21.5655 26.1927 22.0718 25.8116 22.4338C25.4306 22.7958 24.9141 22.9797 24.39 22.94H22.69V24.8H21.32V19.2ZM14.71 20.36V19.16H10.18V24.8H14.71V23.6H11.54V22.6H14.65V21.38H11.54V20.38L14.71 20.36ZM18.8 22L21.06 19.2H19.4L18 20.94L16.61 19.16H14.91L17.2 22L15 24.8H16.64L18 23L19.36 24.82H21.08L18.8 22ZM24.31 21.78H22.69V20.36H24.31C24.6911 20.36 25 20.6689 25 21.05C25 21.4311 24.6911 21.74 24.31 21.74V21.78ZM32.17 20.79C32.286 21.7731 31.5831 22.664 30.6 22.78L32.49 24.8H30.78L29.1 22.8H28.48V24.8H27.12V19.22H30.18C31.1631 19.104 32.054 19.8069 32.17 20.79ZM30.06 21.66H28.48V20.36H30.06C30.2378 20.3369 30.4169 20.3918 30.5511 20.5107C30.6853 20.6296 30.7615 20.8007 30.76 20.98C30.7649 21.1604 30.6898 21.3337 30.5547 21.4533C30.4196 21.573 30.2385 21.6267 30.06 21.6V21.66ZM37.36 19.22V20.42L34.19 20.38V21.38H37.28V22.6H34.19V23.6H37.36V24.8H32.81V19.22H37.36ZM41.13 21.42H39.82C39.6175 21.4607 39.4105 21.3753 39.2956 21.2036C39.1808 21.032 39.1808 20.808 39.2956 20.6364C39.4105 20.4647 39.6175 20.3793 39.82 20.42H42.25L42.79 19.22H39.86C39.3615 19.1622 38.8623 19.3225 38.4906 19.6597C38.1189 19.9969 37.9109 20.4782 37.92 20.98C37.8896 21.4469 38.0691 21.903 38.4094 22.2241C38.7498 22.5451 39.2157 22.6976 39.68 22.64H41C41.2025 22.5993 41.4095 22.6847 41.5244 22.8564C41.6392 23.028 41.6392 23.252 41.5244 23.4236C41.4095 23.5953 41.2025 23.6807 41 23.64H38.08V24.84H41C41.5039 24.8812 42.0011 24.7024 42.3634 24.3497C42.7257 23.997 42.9177 23.5049 42.89 23C42.9153 22.5378 42.7326 22.0885 42.392 21.775C42.0514 21.4615 41.5885 21.3166 41.13 21.38V21.42ZM47.46 20.42H45.03L45 20.38C44.7975 20.3393 44.5905 20.4247 44.4756 20.5964C44.3608 20.768 44.3608 20.992 44.4756 21.1636C44.5905 21.3353 44.7975 21.4207 45 21.38H46.36C47.0518 21.3089 47.7118 21.6871 48 22.32V23.66C47.7246 24.4224 46.9666 24.9003 46.16 24.82H43.29V23.62H46.18C46.3825 23.6607 46.5895 23.5753 46.7044 23.4036C46.8192 23.232 46.8192 23.008 46.7044 22.8364C46.5895 22.6647 46.3825 22.5793 46.18 22.62H44.89C44.4257 22.6776 43.9598 22.5251 43.6194 22.2041C43.2791 21.883 43.0996 21.4269 43.13 20.96C43.1209 20.4582 43.3289 19.9769 43.7006 19.6397C44.0723 19.3025 44.5715 19.1422 45.07 19.2H48L47.46 20.42Z" fill="#296DB6"/><path fill-rule="evenodd" clip-rule="evenodd" d="M25.45 10.28C25.4719 11.1815 24.8053 11.9521 23.91 12.06L25.79 14.14H24.09L22.41 12.14H21.79V14.14H20.4V8.5H23.45C23.9596 8.43317 24.473 8.59111 24.8569 8.93278C25.2408 9.27446 25.4573 9.76612 25.45 10.28ZM4.23 8.5H2.45L0 14.14H1.48L2 13H4.63L5.11 14.18H6.65L4.23 8.5ZM2.38 11.86L2.93 10.54L3.29 9.66L3.65 10.54L4.19 11.86H2.38ZM10.6 11.76L11.7 8.5H13.89V14.14H12.57V10.44V9.58L12.31 10.44L11 14.14H9.8L8.52 10.44L8.24 9.58V10.44V14.14H6.91V8.5H9.12L10.24 11.76L10.42 12.38L10.6 11.76ZM19.5 9.7V8.5H15V14.14H19.5V12.94H16.33V11.94H19.42V10.72H16.33V9.72L19.5 9.7ZM23.37 10.94H21.79V9.7H23.37C23.5471 9.68019 23.7243 9.73632 23.8577 9.85449C23.9912 9.97265 24.0683 10.1418 24.07 10.32C24.0749 10.5004 23.9998 10.6737 23.8647 10.7933C23.7296 10.913 23.5485 10.9667 23.37 10.94ZM26.11 14.14V8.5H27.48V14.14H26.11ZM31.11 9.72H32.58V8.5H31C30.2562 8.45299 29.5291 8.7337 29.0099 9.26831C28.4907 9.80292 28.2313 10.5379 28.3 11.28V11.36C28.2164 12.0915 28.4596 12.8226 28.9645 13.3583C29.4694 13.8941 30.1849 14.1801 30.92 14.14H31L31.55 12.94H31.1C30.685 12.9613 30.2819 12.7972 29.9999 12.492C29.7179 12.1868 29.586 11.772 29.64 11.36V11.28C29.5925 10.8712 29.7272 10.4621 30.0085 10.1616C30.2897 9.86113 30.6889 9.69961 31.1 9.72H31.11ZM34.09 8.5H35.89L38.3 14.18H36.76L36.28 13H33.61L33.13 14.14H31.67L34.09 8.5ZM34.05 11.86L34.57 10.54L34.93 9.66L35.27 10.54L35.81 11.86H34.05ZM42.61 11.5V8.5H44V14.14H42.35L40.26 10.96L39.9 10.34V11V14.18H38.56V8.54H40.23L42.23 11.54L42.61 12.18V11.5Z" fill="#296DB6"/></g></g>'
@@ -343,14 +730,14 @@ const K = W.exports, Z = {
343
730
  name: "Credit Card",
344
731
  logo: '<rect width="48" height="32" rx="4" fill="#D9D9DF"/><rect y="7" width="48" height="7" fill="#51516A"/>'
345
732
  },
346
- get(n, { width: t = 48, height: e = 32 } = {}) {
347
- const a = this[n] ? this[n] : this.default, s = a.logo, i = `<svg width="${t}" height="${e}" viewBox="0 0 48 32" fill="none" xmlns="http://www.w3.org/2000/svg">${s}</svg>`;
733
+ get(r, { width: t = 48, height: e = 32 } = {}) {
734
+ const n = this[r] ? this[r] : this.default, a = n.logo, i = `<svg width="${t}" height="${e}" viewBox="0 0 48 32" fill="none" xmlns="http://www.w3.org/2000/svg">${a}</svg>`;
348
735
  return {
349
- name: a.name,
736
+ name: n.name,
350
737
  logo: i
351
738
  };
352
739
  }
353
- }, Y = {
740
+ }, Dt = {
354
741
  data() {
355
742
  return {
356
743
  stripeCardElementId: null,
@@ -381,15 +768,15 @@ const K = W.exports, Z = {
381
768
  unmountCardInput() {
382
769
  this.stripeCardElementId && this.callCard("unmount", this.stripeCardElementId);
383
770
  },
384
- callCard(n, t) {
385
- this.card && typeof this.card[n] == "function" && this.card[n](t);
771
+ callCard(r, t) {
772
+ this.card && typeof this.card[r] == "function" && this.card[r](t);
386
773
  },
387
774
  /**
388
775
  * Start Stripe card component
389
776
  * @param {String} elementId The id to mount card component, example #card-element
390
777
  */
391
- configureStripeCard(n) {
392
- if (!n)
778
+ configureStripeCard(r) {
779
+ if (!r)
393
780
  throw new Error("Missing required param elementId to install Stripe");
394
781
  if (!this.elements)
395
782
  throw new Error("Stripe is not yet configured");
@@ -406,14 +793,14 @@ const K = W.exports, Z = {
406
793
  iconColor: "#fa755a"
407
794
  }
408
795
  };
409
- this.card = this.elements.create("card", { style: t }), document.querySelector(n) && this.mountCardInput(), this.card.addEventListener("change", (e) => {
410
- const { error: a, complete: s } = e;
411
- a ? this.elementsError = a.message : this.elementsError = "", this.cardIsComplete = s;
796
+ this.card = this.elements.create("card", { style: t }), document.querySelector(r) && this.mountCardInput(), this.card.addEventListener("change", (e) => {
797
+ const { error: n, complete: a } = e;
798
+ n ? this.elementsError = n.message : this.elementsError = "", this.cardIsComplete = a;
412
799
  });
413
800
  }
414
801
  }
415
802
  };
416
- const _ = {
803
+ const Vt = {
417
804
  i18nOptions: {
418
805
  namespaces: "PremiumStripeForm",
419
806
  messages: {
@@ -599,9 +986,9 @@ const _ = {
599
986
  },
600
987
  name: "PremiumStripeForm",
601
988
  components: {
602
- CAccordion: K
989
+ CAccordion: Lt
603
990
  },
604
- mixins: [Y],
991
+ mixins: [Dt],
605
992
  props: {
606
993
  formPlan: {
607
994
  type: Object,
@@ -614,8 +1001,8 @@ const _ = {
614
1001
  },
615
1002
  data() {
616
1003
  return {
617
- regions: f,
618
- cardBrands: Z,
1004
+ regions: A,
1005
+ cardBrands: Tt,
619
1006
  stripeCardElementId: "#card-element",
620
1007
  promoInputVisible: !1,
621
1008
  inputPromotionCode: "",
@@ -629,19 +1016,20 @@ const _ = {
629
1016
  return {
630
1017
  formCustomer: {
631
1018
  email: {
632
- email: g.email
1019
+ email: P.email
633
1020
  }
634
1021
  },
635
1022
  quantity: {
636
- required: g.required,
637
- minValue: g.minValue(1),
638
- numeric: g.numeric
1023
+ required: P.required,
1024
+ minValue: P.minValue(1),
1025
+ numeric: P.numeric
639
1026
  }
640
1027
  };
641
1028
  },
642
1029
  computed: {
643
- ...u({
1030
+ ...h({
644
1031
  companyRegion: "application/companyRegion",
1032
+ companyAccount: "application/companyAccount",
645
1033
  formCustomer: "stripe/formCustomer",
646
1034
  promotion: "stripe/formPromotion",
647
1035
  customer: "stripe/customer",
@@ -665,8 +1053,8 @@ const _ = {
665
1053
  get() {
666
1054
  return this.formPlan.quantity;
667
1055
  },
668
- set(n) {
669
- this.$emit("input", { key: "plan.quantity", value: n });
1056
+ set(r) {
1057
+ this.$emit("input", { key: "plan.quantity", value: r });
670
1058
  }
671
1059
  },
672
1060
  routePromo() {
@@ -674,87 +1062,87 @@ const _ = {
674
1062
  },
675
1063
  // promoCode from url
676
1064
  existingCardLast4() {
677
- var n;
678
- return (n = this.customer) == null ? void 0 : n.paymentMethodLast4;
1065
+ var r;
1066
+ return (r = this.customer) == null ? void 0 : r.paymentMethodLast4;
679
1067
  },
680
1068
  sortedRegions() {
681
- return (Object.keys(f) || []).map((n) => ({ key: n, title: `${f[n].name} (${n})`, callingCode: f[n].callingCode })).sort((n, t) => n.title.localeCompare(t.title));
1069
+ return (Object.keys(A) || []).map((r) => ({ key: r, title: `${A[r].name} (${r})`, callingCode: A[r].callingCode })).sort((r, t) => r.title.localeCompare(t.title));
682
1070
  },
683
1071
  currency() {
684
1072
  return this.formPrices.currency;
685
1073
  },
686
1074
  promotionDescription() {
687
- let n = "- ";
1075
+ let r = "- ";
688
1076
  const { amountOff: t, percentOff: e } = this.promotion || {};
689
- return t ? n += p(t, { currency: this.currency }) : e && (n += `${e}%`), n;
1077
+ return t ? r += y(t, { currency: this.currency }) : e && (r += `${e}%`), r;
690
1078
  },
691
1079
  reasonableUseQuotas() {
692
- var s;
693
- const n = {}, t = (s = this.formPlan) == null ? void 0 : s.StripeProduct;
1080
+ var i;
1081
+ const r = {}, t = (i = this.formPlan) == null ? void 0 : i.StripeProduct;
694
1082
  if (!t)
695
1083
  return [];
696
- const { quotas: e, autoAddMeteredTypes: a } = t.metadata;
697
- return Object.keys(e).forEach((i) => {
698
- i === "bankId" && b[this.$brand].defaultRegion === "US" || (n[i] = {
699
- type: i,
700
- count: e[i] || 0,
1084
+ const { quotas: e, autoAddMeteredTypes: n } = t.metadata, a = e[this.companyAccount.accountConfigurationKeyName] || {};
1085
+ return Object.keys(a).forEach((s) => {
1086
+ s === "bankId" && E[H.brand].defaultRegion === "US" || (r[s] = {
1087
+ type: s,
1088
+ count: a[s] || 0,
701
1089
  cost: null
702
1090
  });
703
- }), a.forEach((i) => {
704
- if (i === "bankId" && b[this.$brand].defaultRegion === "US")
1091
+ }), n.forEach((s) => {
1092
+ if (s === "bankId" && E[H.brand].defaultRegion === "US")
705
1093
  return;
706
- const d = this.getMeteredProduct(i);
707
- if (!d)
1094
+ const l = this.getMeteredProduct(s);
1095
+ if (!l)
708
1096
  return;
709
- const h = d.prices.find((m) => {
710
- var A;
711
- return m.active && ((A = m == null ? void 0 : m.metadata) == null ? void 0 : A.visible) === "true";
1097
+ const o = l.prices.find((m) => {
1098
+ var f;
1099
+ return m.active && ((f = m == null ? void 0 : m.metadata) == null ? void 0 : f.visible) === !0;
712
1100
  });
713
- if (!h)
1101
+ if (!o)
714
1102
  return;
715
- const S = p(h.amount, {
716
- currency: h.currency,
1103
+ const c = y(o.amount, {
1104
+ currency: o.currency,
717
1105
  decimals: 2,
718
1106
  hideZeroDecimals: !0
719
1107
  });
720
- n[i] || (n[i] = { type: i, count: 0, cost: null }), n[i].cost = S;
721
- }), Object.keys(n).map((i) => n[i]);
1108
+ r[s] || (r[s] = { type: s, count: 0, cost: null }), r[s].cost = c;
1109
+ }), Object.keys(r).map((s) => r[s]);
722
1110
  }
723
1111
  },
724
1112
  watch: {
725
- useExistingCard(n) {
1113
+ useExistingCard(r) {
726
1114
  this.$nextTick(() => {
727
- n ? this.unmountCardInput() : this.mountCardInput();
1115
+ r ? this.unmountCardInput() : this.mountCardInput();
728
1116
  });
729
1117
  }
730
1118
  },
731
1119
  async created() {
732
1120
  if (this.$nextTick(() => {
733
- r({
1121
+ u({
734
1122
  targets: ".anime-payment-modal .anim-block",
735
1123
  translateX: [50, 0],
736
1124
  opacity: [0, 1],
737
- delay: r.stagger(100),
1125
+ delay: u.stagger(100),
738
1126
  easing: "spring(1, 80, 20, 10)"
739
1127
  });
740
1128
  }), this.customer) {
741
1129
  this.useExistingCard = !0, this.useExistingCustomer = !0, ["name", "region", "email"].forEach((t) => {
742
1130
  this.customer[t] && this.$emit("input", { key: `customer.${t}`, value: this.customer[t] });
743
1131
  });
744
- const { data: n } = await w();
745
- this.setPromotion({ promotionDetails: n });
1132
+ const { data: r } = await _();
1133
+ this.setPromotion({ promotionDetails: r });
746
1134
  }
747
1135
  this.companyRegion === "SE" && !this.formCustomer.region && this.$emit("input", { key: "customer.region", value: this.companyRegion }), this.routePromo && this.verifyPromotionCode(this.routePromo);
748
1136
  },
749
1137
  methods: {
750
- ...v({
751
- usePromotionCode: l.SUBMIT_PROMOTION_CODE,
752
- setPromotion: l.SET_FORM_PROMOTION,
753
- submitPlan: l.SUBMIT_FORM_PLAN
1138
+ ...k({
1139
+ usePromotionCode: p.SUBMIT_PROMOTION_CODE,
1140
+ setPromotion: p.SET_FORM_PROMOTION,
1141
+ submitPlan: p.SUBMIT_FORM_PLAN
754
1142
  }),
755
- priceFormat: p,
756
- getIntervalTitle(n) {
757
- return n === "month" ? this.$t("_common:monthly").capitalize() : n === "year" ? this.$t("_common:yearly").capitalize() : n === "oneOff" ? this.$t("oneTimeFee").capitalize() : null;
1143
+ priceFormat: y,
1144
+ getIntervalTitle(r) {
1145
+ return r === "month" ? this.$t("_common:monthly").capitalize() : r === "year" ? this.$t("_common:yearly").capitalize() : r === "oneOff" ? this.$t("oneTimeFee").capitalize() : null;
758
1146
  },
759
1147
  async submit() {
760
1148
  if (this.$v.$touch(), this.$v.$invalid)
@@ -765,80 +1153,79 @@ const _ = {
765
1153
  }
766
1154
  await this.submitPlan({ ...!this.useExistingCard && { cardElement: this.card } }) && this.$emit("success");
767
1155
  },
768
- async verifyPromotionCode(n) {
769
- if (!n) {
1156
+ async verifyPromotionCode(r) {
1157
+ if (!r) {
770
1158
  this.promoInputVisible = !1;
771
1159
  return;
772
1160
  }
773
- this.isInvalidPromotionCode = !1, await this.usePromotionCode(n) ? (this.promoInputVisible = !1, this.inputPromotionCode = "") : this.isInvalidPromotionCode = !0;
1161
+ this.isInvalidPromotionCode = !1, await this.usePromotionCode(r) ? (this.promoInputVisible = !1, this.inputPromotionCode = "") : this.isInvalidPromotionCode = !0;
774
1162
  }
775
1163
  }
776
1164
  };
777
- var $ = function() {
1165
+ var Et = function() {
778
1166
  var t = this, e = t._self._c;
779
- return e("div", { staticClass: "root font-inter anime-payment-modal" }, [e("div", { staticClass: "flex w-full", staticStyle: { overflow: "hidden" } }, [e("div", { staticClass: "anim-block p-aside" }, [e("div", { staticClass: "p-callout", class: t.uiPlan.accountType }, [e("div", { staticStyle: { "font-size": "11px", position: "absolute", right: "0.5rem", top: "1.5rem", display: "flex", "line-height": "1.2" } }, [e("div", { staticStyle: { "text-align": "right", "padding-right": "0.5em" } }, [e("div", { staticStyle: { opacity: "0.7" }, domProps: { textContent: t._s(t.$t("payYearly")) } }), e("div", { staticStyle: { "font-weight": "500", color: "hsl(205, 100%, 50%)" }, domProps: { textContent: t._s(t.$t("saveAmount")) } })]), e("CSwitch", { attrs: { value: t.formPlan.interval === "year", size: "small", type: "secondary" }, on: { input: function(a) {
1167
+ return e("div", { staticClass: "root font-inter anime-payment-modal" }, [e("div", { staticClass: "flex w-full", staticStyle: { overflow: "hidden" } }, [e("div", { staticClass: "anim-block p-aside" }, [e("div", { staticClass: "p-callout", class: t.uiPlan.accountType }, [e("div", { staticStyle: { "font-size": "11px", position: "absolute", right: "calc(0.5 * var(--rem))", top: "calc(1.5 * var(--rem))", display: "flex", "line-height": "1.2" } }, [e("div", { staticStyle: { "text-align": "right", "padding-right": "0.5em" } }, [e("div", { staticStyle: { opacity: "0.7" }, domProps: { textContent: t._s(t.$t("payYearly")) } }), e("div", { staticClass: "font-medium text-primary-500", domProps: { textContent: t._s(t.$t("saveAmount")) } })]), e("CSwitch", { attrs: { value: t.formPlan.interval === "year", size: "small", type: "secondary" }, on: { input: function(n) {
780
1168
  return t.$emit("update:interval", t.formPlan.interval === "year" ? "month" : "year");
781
- } } })], 1), e("div", [e("img", { staticStyle: { "box-shadow": "0 4px 6px rgba(240, 147, 234, 0.34)", "border-radius": "50%", "margin-bottom": "1rem" }, attrs: { src: t.uiPlan.img, alt: t.uiPlan.name, width: "50", height: "50" } })]), e("div", { staticStyle: { "font-weight": "600", "font-size": "21px" } }, [t._v(" " + t._s(t.$t("cardTitle", { plan: t.uiPlan.name })) + " ")]), e("div", { staticClass: "text-[15px] py-4" }, [t._l(t.formPrices.intervals, function(a, s) {
782
- return e("div", { key: `interval-${s}`, staticStyle: { "border-bottom": "1px solid hsl(0, 0%, 88%)", "margin-bottom": "1em", "padding-bottom": "0.5em" } }, [e("div", { staticClass: "flex justify-between w-full" }, [e("div", { staticClass: "font-medium" }, [t._v(t._s(t.getIntervalTitle(s)))]), e("div", { staticClass: "text-right" }, [e("div", { staticClass: "font-semibold leading-none text-[17px]" }, [t._v(" " + t._s(t.priceFormat(a.subTotal, { currency: t.currency })) + " ")]), e("div", { staticClass: "opacity-70 text-[13px]" }, [t._v(" " + t._s(a.vatAmount ? t.$t("_common:vat.exVat", { thing: t.$t("_common:vat.vat") }) : t.$t("_common:total").capitalize()) + " "), s !== "oneOff" ? [t._v("/ " + t._s(t.$t(`_common:${s}`)) + " ")] : t._e()], 2)])]), t._l(a.items, function(i, d) {
783
- return e("div", { key: d, staticClass: "flex justify-between w-full pb-1 mt-2" }, [e("div", { staticClass: "font-medium opacity-70" }, [t._v(" " + t._s(i.quantity) + " x " + t._s(i.name.capitalize()) + " ")]), e("div", { staticClass: "text-right opacity-70" }, [t._v(t._s(t.priceFormat(i.amount, { currency: t.currency })))])]);
1169
+ } } })], 1), e("div", [e("img", { staticStyle: { "box-shadow": "0 4px 6px rgba(240, 147, 234, 0.34)", "border-radius": "50%", "margin-bottom": "calc(1 * var(--rem))" }, attrs: { src: t.uiPlan.img, alt: t.uiPlan.name, width: "50", height: "50" } })]), e("div", { staticStyle: { "font-weight": "600", "font-size": "21px" } }, [t._v(" " + t._s(t.$t("cardTitle", { plan: t.uiPlan.name })) + " ")]), e("div", { staticClass: "text-[15px] py-4" }, [t._l(t.formPrices.intervals, function(n, a) {
1170
+ return e("div", { key: `interval-${a}`, staticClass: "pb-2 mb-4 border-b border-gray-200" }, [e("div", { staticClass: "flex justify-between w-full" }, [e("div", { staticClass: "font-medium" }, [t._v(t._s(t.getIntervalTitle(a)))]), e("div", { staticClass: "text-right" }, [e("div", { staticClass: "font-semibold leading-none text-[17px]" }, [t._v(" " + t._s(t.priceFormat(n.subTotal, { currency: t.currency })) + " ")]), e("div", { staticClass: "opacity-70 text-[13px]" }, [t._v(" " + t._s(n.vatAmount ? t.$t("_common:vat.exVat", { thing: t.$t("_common:vat.vat") }) : t.$t("_common:total").capitalize()) + " "), a !== "oneOff" ? [t._v("/ " + t._s(t.$t(`_common:${a}`)) + " ")] : t._e()], 2)])]), t._l(n.items, function(i, s) {
1171
+ return e("div", { key: s, staticClass: "flex justify-between w-full pb-1 mt-2" }, [e("div", { staticClass: "font-medium opacity-70" }, [t._v(" " + t._s(i.quantity) + " x " + t._s(i.name.capitalize()) + " ")]), e("div", { staticClass: "text-right opacity-70" }, [t._v(t._s(t.priceFormat(i.amount, { currency: t.currency })))])]);
784
1172
  })], 2);
785
- }), t.promotion ? e("div", { staticClass: "flex justify-between w-full", staticStyle: { "padding-bottom": "4px" } }, [e("div", { staticStyle: { "font-weight": "500", opacity: "0.7" } }, [t._v(t._s(t.promotion.code || t.promotion.name) + " ")]), e("div", { staticClass: "text-right has-text-danger", staticStyle: { display: "inline-flex", "justify-content": "flex-end", "align-items": "center" } }, [e("CButton", { staticStyle: { height: "inherit", "margin-right": "3px" }, attrs: { disabled: t.isEditLock, "icon-props": { size: 15 }, size: "small", type: "none", pattern: "tertiary", icon: "trash" }, on: { click: function(a) {
1173
+ }), t.promotion ? e("div", { staticClass: "flex justify-between w-full", staticStyle: { "padding-bottom": "4px" } }, [e("div", { staticStyle: { "font-weight": "500", opacity: "0.7" } }, [t._v(t._s(t.promotion.code || t.promotion.name) + " ")]), e("div", { staticClass: "text-right has-text-danger", staticStyle: { display: "inline-flex", "justify-content": "flex-end", "align-items": "center" } }, [e("CButton", { staticStyle: { height: "inherit", "margin-right": "3px" }, attrs: { disabled: t.isEditLock, "icon-props": { size: 15 }, size: "small", type: "none", pattern: "tertiary", icon: "trash" }, on: { click: function(n) {
786
1174
  return t.$emit("input", { key: "promotion", value: null });
787
- } } }), e("div", { domProps: { textContent: t._s(t.promotionDescription) } })], 1)]) : t._e(), t.formPrices.vatAmount ? [e("div", { staticClass: "flex justify-between w-full", staticStyle: { "padding-bottom": "4px" } }, [e("div", { staticStyle: { "font-weight": "500", opacity: "0.7" } }, [t._v(t._s(t.$t("_common:vat.vat").capitalize()))]), e("div", { staticClass: "text-right", staticStyle: { opacity: "0.7" } }, [t._v(t._s(t.priceFormat(t.formPrices.vatAmount, { currency: t.currency })))])]), e("div", { staticClass: "flex justify-between w-full", staticStyle: { "padding-bottom": "4px" } }, [e("div", { staticStyle: { "font-weight": "500", opacity: "0.7" } }, [t._v(t._s(t.$t("_common:vat.incVat", { thing: t.$t("_common:vat.vat") }).capitalize()))]), e("div", { staticClass: "text-right", staticStyle: { opacity: "0.7" } }, [t._v(" " + t._s(t.priceFormat(t.formPrices.totalAmount, { currency: t.currency })) + " ")])])] : t._e(), e("div", { directives: [{ name: "show", rawName: "v-show", value: !t.promotion, expression: "!promotion" }], staticClass: "flex justify-end w-full" }, [t.promoInputVisible ? e("CField", { staticStyle: { "padding-top": "1em", width: "100%" }, attrs: { expanded: "" } }, [e("CInput", { attrs: { placeholder: t.$t("promotion.placeholder"), "custom-class": t.isInvalidPromotionCode ? "is-danger shake" : "", autofocus: "", size: "small" }, on: { blur: function(a) {
1175
+ } } }), e("div", { domProps: { textContent: t._s(t.promotionDescription) } })], 1)]) : t._e(), t.formPrices.vatAmount ? [e("div", { staticClass: "flex justify-between w-full", staticStyle: { "padding-bottom": "4px" } }, [e("div", { staticStyle: { "font-weight": "500", opacity: "0.7" } }, [t._v(t._s(t.$t("_common:vat.vat").capitalize()))]), e("div", { staticClass: "text-right", staticStyle: { opacity: "0.7" } }, [t._v(t._s(t.priceFormat(t.formPrices.vatAmount, { currency: t.currency })))])]), e("div", { staticClass: "flex justify-between w-full", staticStyle: { "padding-bottom": "4px" } }, [e("div", { staticStyle: { "font-weight": "500", opacity: "0.7" } }, [t._v(t._s(t.$t("_common:vat.incVat", { thing: t.$t("_common:vat.vat") }).capitalize()))]), e("div", { staticClass: "text-right", staticStyle: { opacity: "0.7" } }, [t._v(" " + t._s(t.priceFormat(t.formPrices.totalAmount, { currency: t.currency })) + " ")])])] : t._e(), e("div", { directives: [{ name: "show", rawName: "v-show", value: !t.promotion, expression: "!promotion" }], staticClass: "flex justify-end w-full" }, [t.promoInputVisible ? e("CField", { staticStyle: { "padding-top": "1em", width: "100%" }, attrs: { expanded: "" } }, [e("CInput", { attrs: { placeholder: t.$t("promotion.placeholder"), "custom-class": t.isInvalidPromotionCode ? "is-danger shake" : "", autofocus: "", size: "small" }, on: { blur: function(n) {
788
1176
  return t.verifyPromotionCode(t.inputPromotionCode);
789
- } }, nativeOn: { keyup: function(a) {
790
- return !a.type.indexOf("key") && t._k(a.keyCode, "enter", 13, a.key, "Enter") ? null : t.verifyPromotionCode(t.inputPromotionCode);
791
- } }, model: { value: t.inputPromotionCode, callback: function(a) {
792
- t.inputPromotionCode = typeof a == "string" ? a.trim() : a;
793
- }, expression: "inputPromotionCode" } }, [e("template", { slot: "suffix" }, [e("CButton", { attrs: { loading: t.isPosting, type: "secondary", size: "small" }, on: { click: function(a) {
1177
+ } }, nativeOn: { keyup: function(n) {
1178
+ return !n.type.indexOf("key") && t._k(n.keyCode, "enter", 13, n.key, "Enter") ? null : t.verifyPromotionCode(t.inputPromotionCode);
1179
+ } }, model: { value: t.inputPromotionCode, callback: function(n) {
1180
+ t.inputPromotionCode = typeof n == "string" ? n.trim() : n;
1181
+ }, expression: "inputPromotionCode" } }, [e("template", { slot: "suffix" }, [e("CButton", { attrs: { loading: t.isPosting, type: "secondary", size: "small" }, on: { click: function(n) {
794
1182
  return t.verifyPromotionCode(t.inputPromotionCode);
795
- } } }, [t._v(" " + t._s(t.$t("promotion.submit")) + " ")])], 1)], 2)], 1) : e("CButton", { staticStyle: { "text-decoration": "underline", "margin-right": "-1em" }, attrs: { disabled: t.isEditLock, type: "secondary", pattern: "tertiary", size: "small" }, on: { click: function(a) {
1183
+ } } }, [t._v(" " + t._s(t.$t("promotion.submit")) + " ")])], 1)], 2)], 1) : e("CButton", { staticStyle: { "text-decoration": "underline", "margin-right": "-1em" }, attrs: { disabled: t.isEditLock, type: "secondary", pattern: "tertiary", size: "small" }, on: { click: function(n) {
796
1184
  t.promoInputVisible = !0;
797
- } } }, [t._v(" " + t._s(t.$t("promotion.add")) + " ")])], 1)], 2)]), e("div", { staticClass: "flex items-center w-full p-badge" }, [e("svg", { staticClass: "has-text-success", staticStyle: { "margin-right": "0.5em" }, attrs: { width: "17", height: "15", xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 448 512" } }, [e("path", { attrs: { fill: "currentColor", d: "M400 224h-24v-72C376 68.2 307.8 0 224 0S72 68.2 72 152v72H48c-26.5 0-48 21.5-48 48v192c0 26.5 21.5 48 48 48h352c26.5 0 48-21.5 48-48V272c0-26.5-21.5-48-48-48zm-104 0H152v-72c0-39.7 32.3-72 72-72s72 32.3 72 72v72z" } })]), t._v(" " + t._s(t.$t("highlights.securePayment")) + " ")]), e("div", { staticClass: "flex items-center w-full p-badge" }, [e("svg", { staticClass: "has-text-success", staticStyle: { "margin-right": "0.5em" }, attrs: { width: "17", height: "20", xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 512 512" } }, [e("path", { attrs: { fill: "currentColor", d: "M512 256c0-37.7-23.7-69.9-57.1-82.4 14.7-32.4 8.8-71.9-17.9-98.6-26.7-26.7-66.2-32.6-98.6-17.9C325.9 23.7 293.7 0 256 0s-69.9 23.7-82.4 57.1c-32.4-14.7-72-8.8-98.6 17.9-26.7 26.7-32.6 66.2-17.9 98.6C23.7 186.1 0 218.3 0 256s23.7 69.9 57.1 82.4c-14.7 32.4-8.8 72 17.9 98.6 26.6 26.6 66.1 32.7 98.6 17.9 12.5 33.3 44.7 57.1 82.4 57.1s69.9-23.7 82.4-57.1c32.6 14.8 72 8.7 98.6-17.9 26.7-26.7 32.6-66.2 17.9-98.6 33.4-12.5 57.1-44.7 57.1-82.4zm-144.8-44.25L236.16 341.74c-4.31 4.28-11.28 4.25-15.55-.06l-75.72-76.33c-4.28-4.31-4.25-11.28.06-15.56l26.03-25.82c4.31-4.28 11.28-4.25 15.56.06l42.15 42.49 97.2-96.42c4.31-4.28 11.28-4.25 15.55.06l25.82 26.03c4.28 4.32 4.26 11.29-.06 15.56z" } })]), t._v(" " + t._s(t.$t("highlights.satisfiedCustomer")) + " ")]), e("div", { staticClass: "flex items-center w-full p-badge" }, [e("BaseIcon", { staticStyle: { opacity: "0.65", "margin-right": "0.5em" }, attrs: { size: 17, "stroke-width": "2", type: "question" } }), e("span", { staticStyle: { "text-decoration": "underline", opacity: "0.85", cursor: "pointer" }, domProps: { textContent: t._s(t.$t("reasonableUse.title")) }, on: { click: function(a) {
1185
+ } } }, [t._v(" " + t._s(t.$t("promotion.add")) + " ")])], 1)], 2)]), e("div", { staticClass: "flex items-center w-full p-badge" }, [e("svg", { staticClass: "has-text-success", staticStyle: { "margin-right": "0.5em" }, attrs: { width: "17", height: "15", xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 448 512" } }, [e("path", { attrs: { fill: "currentColor", d: "M400 224h-24v-72C376 68.2 307.8 0 224 0S72 68.2 72 152v72H48c-26.5 0-48 21.5-48 48v192c0 26.5 21.5 48 48 48h352c26.5 0 48-21.5 48-48V272c0-26.5-21.5-48-48-48zm-104 0H152v-72c0-39.7 32.3-72 72-72s72 32.3 72 72v72z" } })]), t._v(" " + t._s(t.$t("highlights.securePayment")) + " ")]), e("div", { staticClass: "flex items-center w-full p-badge" }, [e("svg", { staticClass: "has-text-success", staticStyle: { "margin-right": "0.5em" }, attrs: { width: "17", height: "20", xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 512 512" } }, [e("path", { attrs: { fill: "currentColor", d: "M512 256c0-37.7-23.7-69.9-57.1-82.4 14.7-32.4 8.8-71.9-17.9-98.6-26.7-26.7-66.2-32.6-98.6-17.9C325.9 23.7 293.7 0 256 0s-69.9 23.7-82.4 57.1c-32.4-14.7-72-8.8-98.6 17.9-26.7 26.7-32.6 66.2-17.9 98.6C23.7 186.1 0 218.3 0 256s23.7 69.9 57.1 82.4c-14.7 32.4-8.8 72 17.9 98.6 26.6 26.6 66.1 32.7 98.6 17.9 12.5 33.3 44.7 57.1 82.4 57.1s69.9-23.7 82.4-57.1c32.6 14.8 72 8.7 98.6-17.9 26.7-26.7 32.6-66.2 17.9-98.6 33.4-12.5 57.1-44.7 57.1-82.4zm-144.8-44.25L236.16 341.74c-4.31 4.28-11.28 4.25-15.55-.06l-75.72-76.33c-4.28-4.31-4.25-11.28.06-15.56l26.03-25.82c4.31-4.28 11.28-4.25 15.56.06l42.15 42.49 97.2-96.42c4.31-4.28 11.28-4.25 15.55.06l25.82 26.03c4.28 4.32 4.26 11.29-.06 15.56z" } })]), t._v(" " + t._s(t.$t("highlights.satisfiedCustomer")) + " ")]), e("div", { staticClass: "flex items-center w-full p-badge" }, [e("BaseIcon", { staticStyle: { opacity: "0.65", "margin-right": "0.5em" }, attrs: { size: 17, "stroke-width": "2", type: "question" } }), e("span", { staticStyle: { "text-decoration": "underline", opacity: "0.85", cursor: "pointer" }, domProps: { textContent: t._s(t.$t("reasonableUse.title")) }, on: { click: function(n) {
798
1186
  return t.$modal.show("reasonableUse");
799
- } } })], 1), e("div", { staticClass: "flex items-center w-full p-badge" }, [e("BaseIcon", { staticStyle: { opacity: "0.65", "margin-right": "0.5em" }, attrs: { size: 17, "stroke-width": "2", type: "question" } }), e("span", { staticStyle: { "text-decoration": "underline", opacity: "0.85", cursor: "pointer" }, domProps: { textContent: t._s(t.$t("faq.title")) }, on: { click: function(a) {
1187
+ } } })], 1), e("div", { staticClass: "flex items-center w-full p-badge" }, [e("BaseIcon", { staticStyle: { opacity: "0.65", "margin-right": "0.5em" }, attrs: { size: 17, "stroke-width": "2", type: "question" } }), e("span", { staticStyle: { "text-decoration": "underline", opacity: "0.85", cursor: "pointer" }, domProps: { textContent: t._s(t.$t("faq.title")) }, on: { click: function(n) {
800
1188
  return t.$modal.show("faq");
801
- } } })], 1)]), e("div", [e("div", { staticClass: "anim-block p-block", staticStyle: { "padding-bottom": "2em" } }, [e("div", { staticStyle: { "font-size": "18px", "font-weight": "600", "line-height": "1.5" } }, [e("span", { staticStyle: { opacity: "0.5" } }, [t._v(t._s(t.$t("formSteps")))]), e("br"), t._v(" " + t._s(t.$t("formTitle")) + " ")])]), e("div", { staticClass: "anim-block", staticStyle: { "font-size": "14px" } }, [e("div", { staticClass: "p-block" }, [e("div", { staticClass: "flex items-center w-full p-block-title" }, [e("div", [t._v(" " + t._s(t.$t("quantity.label")) + " "), e("BaseIcon", { directives: [{ name: "tooltip", rawName: "v-tooltip", value: t.$t("quantity.tooltip"), expression: "$t('quantity.tooltip')" }], staticClass: "has-text-grey", attrs: { type: "info", size: "16" } })], 1)]), e("div", { staticClass: "flex w-full" }, [e("div", { staticClass: "p-option-list", staticStyle: { flex: "1 1 auto" } }, [e("CField", { attrs: { validator: t.$v.quantity, messages: t.messages.quantity, expanded: "" } }, [e("CInput", { directives: [{ name: "tooltip", rawName: "v-tooltip", value: t.uiPlan.accountType === "start" ? { content: t.$t("quantity.disabled") } : "", expression: `
1189
+ } } })], 1)]), e("div", [e("div", { staticClass: "anim-block p-block", staticStyle: { "padding-bottom": "2em" } }, [e("div", { staticStyle: { "font-size": "18px", "font-weight": "600", "line-height": "1.5" } }, [e("span", { staticStyle: { opacity: "0.5" } }, [t._v(t._s(t.$t("formSteps")))]), e("br"), t._v(" " + t._s(t.$t("formTitle")) + " ")])]), e("div", { staticClass: "anim-block", staticStyle: { "font-size": "14px" } }, [e("div", { staticClass: "p-block" }, [e("div", { staticClass: "flex items-center w-full p-block-title" }, [e("div", [t._v(" " + t._s(t.$t("quantity.label")) + " "), e("BaseIcon", { directives: [{ name: "tooltip", rawName: "v-tooltip", value: t.$t("quantity.tooltip"), expression: "$t('quantity.tooltip')" }], staticClass: "text-gray-400", attrs: { type: "info", size: "16" } })], 1)]), e("div", { staticClass: "flex w-full" }, [e("div", { staticClass: "p-option-list", staticStyle: { flex: "1 1 auto" } }, [e("CField", { attrs: { validator: t.$v.quantity, messages: t.messages.quantity, expanded: "" } }, [e("CInput", { directives: [{ name: "tooltip", rawName: "v-tooltip", value: t.uiPlan.accountType === "start" ? { content: t.$t("quantity.disabled") } : "", expression: `
802
1190
  uiPlan.accountType === 'start'
803
1191
  ? { content: $t('quantity.disabled') }
804
1192
  : ''
805
- ` }], attrs: { disabled: t.uiPlan.accountType === "start" || t.isEditLock, size: "medium", min: "1", filled: "", type: "number" }, model: { value: t.quantity, callback: function(a) {
806
- t.quantity = t._n(a);
807
- }, expression: "quantity" } })], 1)], 1), e("div", { staticClass: "flex items-center justify-center w-full p-option-list", staticStyle: { "margin-left": "1rem", flex: "0 0" } }, [e("CButton", { staticStyle: { width: "3.5rem" }, attrs: { disabled: 2 > t.quantity || t.uiPlan.accountType === "start" || t.isEditLock, type: "none", pattern: "tertiary", icon: "minus" }, on: { click: function(a) {
1193
+ ` }], attrs: { disabled: t.uiPlan.accountType === "start" || t.isEditLock, size: "medium", min: "1", filled: "", type: "number" }, model: { value: t.quantity, callback: function(n) {
1194
+ t.quantity = t._n(n);
1195
+ }, expression: "quantity" } })], 1)], 1), e("div", { staticClass: "flex items-center justify-center w-full p-option-list", staticStyle: { "margin-left": "calc(1 * var(--rem))", flex: "0 0" } }, [e("CButton", { staticStyle: { width: "calc(3.5 * var(--rem))" }, attrs: { disabled: 2 > t.quantity || t.uiPlan.accountType === "start" || t.isEditLock, type: "none", pattern: "tertiary", icon: "minus" }, on: { click: function(n) {
808
1196
  t.quantity--;
809
- } } })], 1), e("div", { staticClass: "flex items-center justify-center w-full p-option-list", staticStyle: { "margin-left": "3px", flex: "0 0" } }, [e("CButton", { staticStyle: { width: "3.5rem" }, attrs: { disabled: t.uiPlan.accountType === "start" || t.isEditLock, type: "none", pattern: "tertiary", icon: "plus" }, on: { click: function(a) {
1197
+ } } })], 1), e("div", { staticClass: "flex items-center justify-center w-full p-option-list", staticStyle: { "margin-left": "3px", flex: "0 0" } }, [e("CButton", { staticStyle: { width: "calc(3.5 * var(--rem))" }, attrs: { disabled: t.uiPlan.accountType === "start" || t.isEditLock, type: "none", pattern: "tertiary", icon: "plus" }, on: { click: function(n) {
810
1198
  t.quantity++;
811
- } } })], 1)])]), t.useExistingCustomer ? e("div", { staticClass: "p-callout", staticStyle: { position: "relative", padding: "1rem", "border-radius": "8px" } }, [e("CButton", { staticStyle: { position: "absolute", top: "1rem", right: "1rem" }, attrs: { size: "small", rounded: "" }, on: { click: function(a) {
1199
+ } } })], 1)])]), t.useExistingCustomer ? e("div", { staticClass: "p-callout", staticStyle: { position: "relative", padding: "calc(1 * var(--rem))", "border-radius": "8px" } }, [e("CButton", { staticStyle: { position: "absolute", top: "calc(1 * var(--rem))", right: "calc(1 * var(--rem))" }, attrs: { size: "small", rounded: "" }, on: { click: function(n) {
812
1200
  t.useExistingCustomer = !1;
813
- } } }, [t._v(" " + t._s(t.$t("_common:change")) + " ")]), e("div", { staticClass: "flex items-center w-full" }, [e("div", { domProps: { innerHTML: t._s(t.cardBrands.get(t.customer.paymentMethodBrand, { width: 36 }).logo) } }), e("div", { staticStyle: { "margin-left": "0.5rem" } }, [e("span", { staticStyle: { "margin-right": "5px" } }, [t._v(t._s(t.cardBrands.get(t.customer.paymentMethodBrand).name))]), t._v(" •••• " + t._s(t.customer.paymentMethodLast4 || "") + " ")])]), e("div", [t._v(t._s(t.customer.name))]), e("div", [t._v(t._s(t.customer.email))]), t.regions[t.customer.region] ? e("div", [t._v(t._s(t.regions[t.customer.region].name))]) : t._e()], 1) : [e("div", { staticClass: "p-block" }, [t.useExistingCard ? t._e() : e("div", { staticClass: "flex items-center w-full p-block-title" }, [e("div", [t._v(t._s(t.$t("paymentInfoLabel")))])]), e("div", [t.useExistingCard && t.existingCardLast4 ? e("div", { staticClass: "p-block" }, [t._v(" " + t._s(t.$t("paymentInfoLabel")) + " "), e("CField", { attrs: { messages: t.messages.email, expanded: "" } }, [e("CInput", { attrs: { value: `•••• •••• •••• ${t.existingCardLast4}`, size: "medium", disabled: "", filled: "" } }, [e("CButton", { attrs: { slot: "suffix", type: "secondary", size: "small" }, on: { click: function(a) {
1201
+ } } }, [t._v(" " + t._s(t.$t("_common:change")) + " ")]), e("div", { staticClass: "flex items-center w-full" }, [e("div", { domProps: { innerHTML: t._s(t.cardBrands.get(t.customer.paymentMethodBrand, { width: 36 }).logo) } }), e("div", { staticStyle: { "margin-left": "calc(0.5 * var(--rem))" } }, [e("span", { staticStyle: { "margin-right": "5px" } }, [t._v(t._s(t.cardBrands.get(t.customer.paymentMethodBrand).name))]), t._v(" •••• " + t._s(t.customer.paymentMethodLast4 || "") + " ")])]), e("div", [t._v(t._s(t.customer.name))]), e("div", [t._v(t._s(t.customer.email))]), t.regions[t.customer.region] ? e("div", [t._v(t._s(t.regions[t.customer.region].name))]) : t._e()], 1) : [e("div", { staticClass: "p-block" }, [t.useExistingCard ? t._e() : e("div", { staticClass: "flex items-center w-full p-block-title" }, [e("div", [t._v(t._s(t.$t("paymentInfoLabel")))])]), e("div", [t.useExistingCard && t.existingCardLast4 ? e("div", { staticClass: "p-block" }, [t._v(" " + t._s(t.$t("paymentInfoLabel")) + " "), e("CField", { attrs: { messages: t.messages.email, expanded: "" } }, [e("CInput", { attrs: { value: `•••• •••• •••• ${t.existingCardLast4}`, size: "medium", disabled: "", filled: "" } }, [e("CButton", { attrs: { slot: "suffix", type: "secondary", size: "small" }, on: { click: function(n) {
814
1202
  t.useExistingCard = !1;
815
- } }, slot: "suffix" }, [t._v(" " + t._s(t.$t("_common:change")) + " ")])], 1)], 1)], 1) : t._e(), e("div", { directives: [{ name: "show", rawName: "v-show", value: !t.useExistingCard, expression: "!useExistingCard" }], staticStyle: { width: "400px", background: "hsl(0, 0%, 95%)", padding: "1em 1em", "border-radius": "0.5em", "min-height": "54px" }, attrs: { id: "card-element" } }), e("div", { directives: [{ name: "show", rawName: "v-show", value: t.elementsError && !t.useExistingCard, expression: "elementsError && !useExistingCard" }], staticStyle: { color: "hsl(0, 100%, 60%)", "padding-top": "0.5em" }, domProps: { textContent: t._s(t.elementsError) } })])]), e("div", { staticClass: "p-block" }, [t._v(" " + t._s(t.$t("name.label")) + " "), e("CInput", { attrs: { value: t.formCustomer.name, placeholder: t.$t("name.placeholder"), size: "medium", filled: "" }, on: { input: function(a) {
816
- return t.$emit("input", { key: "customer.name", value: a });
817
- } } })], 1), e("div", { staticClass: "p-block" }, [t._v(" " + t._s(t.$t("region.label")) + " "), e("CSelect", { attrs: { value: t.formCustomer.region, "select-class": "input is-filled", placeholder: t.$t("region.placeholder") }, on: { input: function(a) {
818
- return t.$emit("input", { key: "customer.region", value: a });
819
- } } }, t._l(t.sortedRegions, function({ key: a, title: s }) {
820
- return e("option", { key: a, domProps: { value: a } }, [t._v(" " + t._s(s) + " ")]);
821
- }), 0)], 1), e("div", { staticClass: "p-block" }, [t._v(" " + t._s(t.$t("email.label")) + " "), e("CField", { attrs: { validator: t.$v.formCustomer.email, messages: t.messages.email, expanded: "" } }, [e("CInput", { attrs: { value: t.formCustomer.email, placeholder: t.$t("email.placeholder"), size: "medium", filled: "" }, on: { input: function(a) {
822
- return t.$emit("input", { key: "customer.email", value: a });
823
- } } })], 1)], 1)]], 2), e("div", { staticClass: "anim-block p-block" }, [e("CButton", { staticStyle: { "margin-top": "1rem" }, attrs: { loading: t.isPosting, type: "secondary", wide: "", size: "medium", "icon-right": "arrow-right" }, on: { click: t.submit } }, [t._v(" " + t._s(t.$t("submitButton", { plan: t.uiPlan.name })) + " ")])], 1)])]), e("modal", { staticClass: "overflow-visible primary", attrs: { adaptive: !0, scrollable: !0, "max-width": 400, height: "auto", width: "90%", classes: "primary overflow-visible", name: "faq" } }, [e("div", { staticStyle: { "background-color": "white", "border-radius": "0.5rem", padding: "1rem" } }, [e("div", { staticStyle: { "font-size": "2rem", "font-weight": "600", "margin-bottom": ".5em", padding: "1rem" }, domProps: { textContent: t._s(t.$t("faq.title")) } }), t._l(6, function(a) {
824
- return e("CAccordion", { key: a, attrs: { "default-open": null }, scopedSlots: t._u([{ key: "trigger", fn: function({ expanded: s }) {
825
- return e("div", { staticClass: "list-button" }, [e("span", { domProps: { textContent: t._s(t.$t(`faq.items.${a - 1}.title`, { brand: t.$t("_common:brand.name") })) } }), e("BaseIcon", { staticStyle: { transition: "200ms" }, style: { transform: `rotate(${s ? "0deg" : "180deg"})` }, attrs: { type: "chevron-down", size: "15" } })], 1);
826
- } }], null, !0) }, [e("div", { staticStyle: { "font-size": "14px", opacity: "0.65", padding: "0 .5rem 2rem .5rem" }, domProps: { textContent: t._s(t.$t(`faq.items.${a - 1}.text`, { brand: t.$t("_common:brand.name") })) } })]);
827
- })], 2)]), e("modal", { staticClass: "overflow-visible primary", attrs: { adaptive: !0, scrollable: !0, "max-width": 400, height: "auto", width: "90%", classes: "primary overflow-visible", name: "reasonableUse" } }, [e("div", { staticStyle: { "background-color": "white", "border-radius": "0.5rem", padding: "1rem" } }, [e("div", { staticStyle: { "font-size": "1.5rem", "font-weight": "600", padding: "1rem" }, domProps: { textContent: t._s(t.$t("reasonableUse.title")) } }), e("div", { staticStyle: { "font-size": "15px", opacity: "0.75", padding: "0 1rem 2rem" }, domProps: { textContent: t._s(t.$t("reasonableUse.text", { brand: t.$t("_common:brand.name") })) } }), e("div", { staticStyle: { padding: "0 1rem" } }, t._l(t.reasonableUseQuotas, function(a, s) {
828
- return e("div", { key: s, staticStyle: { "font-size": "14px", "margin-bottom": "1rem" } }, [e("span", { staticStyle: { "font-weight": "500", "padding-right": "0.5ch" }, domProps: { textContent: t._s(t.$t(`reasonableUse.${a.type}`) + ":") } }), e("span", { staticStyle: { opacity: "0.75", "padding-right": "0.5ch" }, domProps: { textContent: t._s(t.$t("reasonableUse.quotaIncluded", { count: a.count })) } }), a.cost ? e("span", { staticStyle: { opacity: "0.75" }, domProps: { textContent: t._s(t.$t("reasonableUse.quotaExtra", { cost: a.cost })) } }) : t._e()]);
1203
+ } }, slot: "suffix" }, [t._v(" " + t._s(t.$t("_common:change")) + " ")])], 1)], 1)], 1) : t._e(), e("div", { directives: [{ name: "show", rawName: "v-show", value: !t.useExistingCard, expression: "!useExistingCard" }], staticClass: "bg-gray-100", staticStyle: { width: "400px", padding: "1em 1em", "border-radius": "0.5em", "min-height": "54px" }, attrs: { id: "card-element" } }), e("div", { directives: [{ name: "show", rawName: "v-show", value: t.elementsError && !t.useExistingCard, expression: "elementsError && !useExistingCard" }], staticClass: "pt-2 text-red-500", domProps: { textContent: t._s(t.elementsError) } })])]), e("div", { staticClass: "p-block" }, [t._v(" " + t._s(t.$t("name.label")) + " "), e("CInput", { attrs: { value: t.formCustomer.name, placeholder: t.$t("name.placeholder"), size: "medium", filled: "" }, on: { input: function(n) {
1204
+ return t.$emit("input", { key: "customer.name", value: n });
1205
+ } } })], 1), e("div", { staticClass: "p-block" }, [t._v(" " + t._s(t.$t("region.label")) + " "), e("CSelect", { attrs: { value: t.formCustomer.region, "select-class": "input is-filled", placeholder: t.$t("region.placeholder") }, on: { input: function(n) {
1206
+ return t.$emit("input", { key: "customer.region", value: n });
1207
+ } } }, t._l(t.sortedRegions, function({ key: n, title: a }) {
1208
+ return e("option", { key: n, domProps: { value: n } }, [t._v(" " + t._s(a) + " ")]);
1209
+ }), 0)], 1), e("div", { staticClass: "p-block" }, [t._v(" " + t._s(t.$t("email.label")) + " "), e("CField", { attrs: { validator: t.$v.formCustomer.email, messages: t.messages.email, expanded: "" } }, [e("CInput", { attrs: { value: t.formCustomer.email, placeholder: t.$t("email.placeholder"), size: "medium", filled: "" }, on: { input: function(n) {
1210
+ return t.$emit("input", { key: "customer.email", value: n });
1211
+ } } })], 1)], 1)]], 2), e("div", { staticClass: "anim-block p-block" }, [e("CButton", { staticStyle: { "margin-top": "calc(1 * var(--rem))" }, attrs: { loading: t.isPosting, type: "secondary", wide: "", size: "medium", "icon-right": "arrow-right" }, on: { click: t.submit } }, [t._v(" " + t._s(t.$t("submitButton", { plan: t.uiPlan.name })) + " ")])], 1)])]), e("modal", { staticClass: "overflow-visible primary", attrs: { adaptive: !0, scrollable: !0, "max-width": 400, height: "auto", width: "90%", classes: "primary overflow-visible", name: "faq" } }, [e("div", { staticStyle: { "background-color": "white", "border-radius": "calc(0.5 * var(--rem))", padding: "calc(1 * var(--rem))" } }, [e("div", { staticStyle: { "font-size": "calc(2 * var(--rem))", "font-weight": "600", "margin-bottom": ".5em", padding: "calc(1 * var(--rem))" }, domProps: { textContent: t._s(t.$t("faq.title")) } }), t._l(6, function(n) {
1212
+ return e("CAccordion", { key: n, attrs: { "default-open": null }, scopedSlots: t._u([{ key: "trigger", fn: function({ expanded: a }) {
1213
+ return e("div", { staticClass: "list-button" }, [e("span", { domProps: { textContent: t._s(t.$t(`faq.items.${n - 1}.title`, { brand: t.$t("_common:brand.name") })) } }), e("BaseIcon", { staticStyle: { transition: "200ms" }, style: { transform: `rotate(${a ? "0deg" : "180deg"})` }, attrs: { type: "chevron-down", size: "15" } })], 1);
1214
+ } }], null, !0) }, [e("div", { staticStyle: { "font-size": "14px", opacity: "0.65", padding: "0 calc(.5 * var(--rem)) calc(2 * var(--rem)) calc(.5 * var(--rem))" }, domProps: { textContent: t._s(t.$t(`faq.items.${n - 1}.text`, { brand: t.$t("_common:brand.name") })) } })]);
1215
+ })], 2)]), e("modal", { staticClass: "overflow-visible primary", attrs: { adaptive: !0, scrollable: !0, "max-width": 400, height: "auto", width: "90%", classes: "primary overflow-visible", name: "reasonableUse" } }, [e("div", { staticStyle: { "background-color": "white", "border-radius": "calc(0.5 * var(--rem))", padding: "calc(1 * var(--rem))" } }, [e("div", { staticStyle: { "font-size": "calc(1.5 * var(--rem))", "font-weight": "600", padding: "calc(1 * var(--rem))" }, domProps: { textContent: t._s(t.$t("reasonableUse.title")) } }), e("div", { staticStyle: { "font-size": "15px", opacity: "0.75", padding: "0 calc(1 * var(--rem)) calc(2 * var(--rem))" }, domProps: { textContent: t._s(t.$t("reasonableUse.text", { brand: t.$t("_common:brand.name") })) } }), e("div", { staticStyle: { padding: "0 calc(1 * var(--rem))" } }, t._l(t.reasonableUseQuotas, function(n, a) {
1216
+ return e("div", { key: a, staticStyle: { "font-size": "14px", "margin-bottom": "calc(1 * var(--rem))" } }, [e("span", { staticStyle: { "font-weight": "500", "padding-right": "0.5ch" }, domProps: { textContent: t._s(t.$t(`reasonableUse.${n.type}`) + ":") } }), e("span", { staticStyle: { opacity: "0.75", "padding-right": "0.5ch" }, domProps: { textContent: t._s(t.$t("reasonableUse.quotaIncluded", { count: n.count })) } }), n.cost ? e("span", { staticStyle: { opacity: "0.75" }, domProps: { textContent: t._s(t.$t("reasonableUse.quotaExtra", { cost: n.cost })) } }) : t._e()]);
829
1217
  }), 0)])])], 1);
830
- }, tt = [], et = /* @__PURE__ */ o(
831
- _,
832
- $,
833
- tt,
1218
+ }, Ot = [], Qt = /* @__PURE__ */ d(
1219
+ Vt,
1220
+ Et,
1221
+ Ot,
834
1222
  !1,
835
1223
  null,
836
- "7bb5eaf1",
1224
+ "b5b143cd",
837
1225
  null,
838
1226
  null
839
1227
  );
840
- const nt = et.exports, at = "", st = "", it = "";
841
- const rt = {
1228
+ const qt = Qt.exports, Jt = "", Ut = "", Xt = "", Ft = {
842
1229
  name: "PremiumStripe",
843
1230
  i18nOptions: {
844
1231
  namespaces: "PremiumStripe",
@@ -964,9 +1351,9 @@ const rt = {
964
1351
  }
965
1352
  },
966
1353
  components: {
967
- Confetti: q,
968
- PremiumStripeSelect: j,
969
- PremiumStripeForm: nt
1354
+ Confetti: At,
1355
+ PremiumStripeSelect: wt,
1356
+ PremiumStripeForm: qt
970
1357
  },
971
1358
  props: {
972
1359
  suggestedQuantity: {
@@ -987,11 +1374,11 @@ const rt = {
987
1374
  };
988
1375
  },
989
1376
  computed: {
990
- ...O({
991
- forceShowBase: (n) => n.route.query.base,
992
- routeDeal: (n) => n.route.query.deal
1377
+ ...st({
1378
+ forceShowBase: (r) => r.route.query.base,
1379
+ routeDeal: (r) => r.route.query.deal
993
1380
  }),
994
- ...u({
1381
+ ...h({
995
1382
  accountType: "application/companyAccountType",
996
1383
  subscription: "application/subscription",
997
1384
  formPlan: "stripe/formPlan",
@@ -1004,60 +1391,60 @@ const rt = {
1004
1391
  }),
1005
1392
  quantity: {
1006
1393
  get() {
1007
- var n;
1008
- return (n = this.formPlan) == null ? void 0 : n.quantity;
1394
+ var r;
1395
+ return (r = this.formPlan) == null ? void 0 : r.quantity;
1009
1396
  },
1010
- set(n) {
1011
- this.setFormValue({ key: "plan.quantity", value: n });
1397
+ set(r) {
1398
+ this.setFormValue({ key: "plan.quantity", value: r });
1012
1399
  }
1013
1400
  },
1014
1401
  plan: {
1015
1402
  get() {
1016
- var n;
1017
- return (n = this.formPlan) == null ? void 0 : n.accountType;
1403
+ var r;
1404
+ return (r = this.formPlan) == null ? void 0 : r.accountType;
1018
1405
  },
1019
- set(n) {
1020
- this.setFormValue({ key: "plan.accountType", value: n });
1406
+ set(r) {
1407
+ this.setFormValue({ key: "plan.accountType", value: r });
1021
1408
  }
1022
1409
  },
1023
1410
  interval: {
1024
1411
  get() {
1025
- var n;
1026
- return (n = this.formPlan) == null ? void 0 : n.interval;
1412
+ var r;
1413
+ return (r = this.formPlan) == null ? void 0 : r.interval;
1027
1414
  },
1028
- set(n) {
1029
- this.setFormValue({ key: "plan.interval", value: n });
1415
+ set(r) {
1416
+ this.setFormValue({ key: "plan.interval", value: r });
1030
1417
  }
1031
1418
  },
1032
1419
  dealSource: {
1033
1420
  get() {
1034
1421
  return this.formDealSource;
1035
1422
  },
1036
- set(n) {
1037
- this.setFormValue({ key: "dealSource", value: n });
1423
+ set(r) {
1424
+ this.setFormValue({ key: "dealSource", value: r });
1038
1425
  }
1039
1426
  },
1040
1427
  prettyPlans() {
1041
- const n = [], t = this.subscription.maxProjectManagers === 1 && this.subscription.mrr < 4e4 || !["base", "pro"].includes(this.accountType), e = () => {
1042
- const a = this.subscription.isStripeLegacy || this.subscription.paymentMethod === "invoice", s = this.subscription.billingCycleInterval === "month" && this.subscription.mrr < 45e3 || this.subscription.billingCycleInterval === "year" && this.subscription.mrr < 38e3;
1043
- return a && !this.forceShowBase ? s : !0;
1428
+ const r = [], t = this.subscription.maxProjectManagers === 1 && this.subscription.mrr < 4e4 || !["base", "pro"].includes(this.accountType), e = () => {
1429
+ const n = this.subscription.isStripeLegacy || this.subscription.paymentMethod === "invoice", a = this.subscription.billingCycleInterval === "month" && this.subscription.mrr < 45e3 || this.subscription.billingCycleInterval === "year" && this.subscription.mrr < 38e3;
1430
+ return n && !this.forceShowBase ? a : !0;
1044
1431
  };
1045
- return t && n.push({
1432
+ return t && r.push({
1046
1433
  name: "Start",
1047
1434
  accountType: "start",
1048
- img: it,
1435
+ img: Xt,
1049
1436
  features: [
1050
1437
  this.$t("features.start.singleUser"),
1051
1438
  this.$t("features.start.documents"),
1052
1439
  this.$t("features.start.templates"),
1053
1440
  this.$t("features.start.auditTrail"),
1054
- ...P.checkFeature("bankId") ? [this.$t("features.start.bankId")] : [],
1441
+ ...O.checkFeature("bankId") ? [this.$t("features.start.bankId")] : [],
1055
1442
  this.$t("features.start.sms")
1056
1443
  ]
1057
- }), e() && n.push({
1444
+ }), e() && r.push({
1058
1445
  name: "Base",
1059
1446
  accountType: "base",
1060
- img: st,
1447
+ img: Ut,
1061
1448
  features: [
1062
1449
  this.$t("features.base.eSign"),
1063
1450
  this.$t("features.base.templates"),
@@ -1065,13 +1452,13 @@ const rt = {
1065
1452
  this.$t("features.base.members"),
1066
1453
  this.$t("features.base.reminders"),
1067
1454
  this.$t("features.base.auditTrail"),
1068
- ...P.checkFeature("bankId") ? [this.$t("features.base.bankId")] : [],
1455
+ ...O.checkFeature("bankId") ? [this.$t("features.base.bankId")] : [],
1069
1456
  this.$t("features.base.sms")
1070
1457
  ]
1071
- }), n.push({
1458
+ }), r.push({
1072
1459
  name: "Pro",
1073
1460
  accountType: "pro",
1074
- img: at,
1461
+ img: Jt,
1075
1462
  features: [
1076
1463
  this.$t("features.pro.allBefore"),
1077
1464
  this.$t("features.pro.statistics"),
@@ -1085,21 +1472,24 @@ const rt = {
1085
1472
  this.$t("features.pro.hideLogo", { brand: this.$t("_common:brand.name") }),
1086
1473
  this.$t("features.pro.crms")
1087
1474
  ]
1088
- }), n;
1475
+ }), r;
1089
1476
  },
1090
1477
  calloutMode() {
1091
1478
  return this.subscription.showCalloutConvertStripe ? "invoice" : this.subscription.isStripeLegacy ? "legacy" : null;
1092
1479
  }
1093
1480
  },
1481
+ beforeCreate() {
1482
+ this.$store.state.stripe || this.$store.registerModule("stripe", j);
1483
+ },
1094
1484
  async created() {
1095
1485
  this.resetStripeForm(), await this.loadPrices(), await this.suggestQuantity(), await this.handlePossibleDeal(), this.isEdit = !!this.subscriptions.length;
1096
1486
  },
1097
1487
  methods: {
1098
- ...v({
1099
- loadPrices: l.LOAD_PRICES,
1100
- resetStripeForm: l.RESET_STRIPE_FORM,
1101
- setFormValue: l.SET_STRIPE_FORM_VALUE,
1102
- updateSettings: l.UPDATE_SETTINGS
1488
+ ...k({
1489
+ loadPrices: p.LOAD_PRICES,
1490
+ resetStripeForm: p.RESET_STRIPE_FORM,
1491
+ setFormValue: p.SET_STRIPE_FORM_VALUE,
1492
+ updateSettings: p.UPDATE_SETTINGS
1103
1493
  }),
1104
1494
  // Suggest quantity of licenses based on property or from account
1105
1495
  async suggestQuantity() {
@@ -1109,19 +1499,19 @@ const rt = {
1109
1499
  this.quantity = this.suggestedQuantity;
1110
1500
  return;
1111
1501
  }
1112
- const { data: n } = await H();
1113
- this.quantity = n;
1502
+ const { data: r } = await $();
1503
+ this.quantity = r;
1114
1504
  },
1115
1505
  onReset() {
1116
1506
  this.view = "select", this.resetStripeForm();
1117
1507
  },
1118
1508
  goToSuccess() {
1119
1509
  this.view = "success", this.$nextTick(() => {
1120
- r({
1510
+ u({
1121
1511
  targets: ".anime-payment-modal .success-block",
1122
1512
  translateY: [50, 0],
1123
1513
  opacity: [0, 1],
1124
- delay: r.stagger(100, { start: 500 }),
1514
+ delay: u.stagger(100, { start: 500 }),
1125
1515
  easing: "spring(1, 80, 15, 0)"
1126
1516
  });
1127
1517
  }), this.removePossibleDealToken(), setTimeout(() => {
@@ -1136,23 +1526,23 @@ const rt = {
1136
1526
  },
1137
1527
  removePossibleDealToken() {
1138
1528
  if (this.routeDeal) {
1139
- const n = { ...this.$route.query };
1140
- delete n.deal, this.$router.replace({ ...this.$route, query: n });
1529
+ const r = { ...this.$route.query };
1530
+ delete r.deal, this.$router.replace({ ...this.$route, query: r });
1141
1531
  } else
1142
1532
  this.stripeCustomDealToken && this.updateSettings({
1143
1533
  key: "company",
1144
1534
  settings: { stripeCustomDealToken: null }
1145
1535
  });
1146
1536
  },
1147
- setFromDealToken(n) {
1148
- if (n)
1537
+ setFromDealToken(r) {
1538
+ if (r)
1149
1539
  try {
1150
- const t = I(n);
1540
+ const t = tt(r);
1151
1541
  if (t.accountType && (this.plan = t.accountType), t.accountTypeInterval && (this.interval = t.accountTypeInterval), t.accountQuantity && (this.quantity = t.accountQuantity), t.dealSource && (this.dealSource = t.dealSource), t.items) {
1152
1542
  const e = [];
1153
- Object.keys(t.items).forEach((a) => {
1154
- const s = this.getProductByPriceId(a);
1155
- s && e.push({ ...s, quantity: t.items[a] });
1543
+ Object.keys(t.items).forEach((n) => {
1544
+ const a = this.getProductByPriceId(n);
1545
+ a && e.push({ ...a, quantity: t.items[n] });
1156
1546
  }), e.length && this.setFormValue({
1157
1547
  key: "products",
1158
1548
  value: [
@@ -1168,44 +1558,44 @@ const rt = {
1168
1558
  }
1169
1559
  }
1170
1560
  };
1171
- var ot = function() {
1561
+ var Mt = function() {
1172
1562
  var t = this, e = t._self._c;
1173
- return e("div", { staticClass: "root font-inter anime-payment-modal", staticStyle: { display: "grid", "place-items": "center" } }, [e("div", { staticStyle: { position: "absolute", left: "1em", top: "0.5em", display: "inline-flex", "z-index": "10" } }, [e("CButton", { attrs: { "icon-props": { size: 20 }, pattern: "tertiary", type: "none", circle: "", icon: "x" }, on: { click: function(a) {
1563
+ return e("div", { staticClass: "relative grid h-full px-12 py-8 overflow-auto bg-white font-inter anime-payment-modal font-base place-items-center" }, [e("div", { staticStyle: { position: "absolute", left: "1em", top: "0.5em", display: "inline-flex", "z-index": "10" } }, [e("CButton", { attrs: { "icon-props": { size: 20 }, pattern: "tertiary", type: "none", circle: "", icon: "x" }, on: { click: function(n) {
1174
1564
  return t.$emit("close");
1175
- } } }), t.view === "form" ? e("CButton", { staticStyle: { "margin-left": "2px" }, attrs: { "icon-props": { size: 20 }, pattern: "tertiary", type: "none", circle: "", icon: "arrow-left" }, on: { click: t.onReset } }) : t._e()], 1), t.calloutMode ? e("div", { staticStyle: { "background-color": "hsl(205,100%,93%)", border: "2px solid hsl(205, 100%, 75%)", display: "inline-block", padding: "1rem 1rem 1rem 3rem", position: "relative", "max-width": "55rem", "border-radius": "8px" } }, [e("BaseIcon", { staticStyle: { position: "absolute", left: "1rem", top: "1.25rem", color: "hsl(205, 100%, 35%)" }, attrs: { type: "info", size: "20" } }), e("div", { staticStyle: { "font-weight": "600", color: "hsl(205, 100%, 35%)" }, domProps: { textContent: t._s(t.$t(`callout.${t.calloutMode}.title`)) } }), e("div", { staticStyle: { "font-size": "14px", opacity: "0.7" }, domProps: { innerHTML: t._s(t.$t(`callout.${t.calloutMode}.text`)) } })], 1) : t._e(), e("div", [t.view === "select" ? e("PremiumStripeSelect", { attrs: { plan: t.plan, interval: t.interval, plans: t.prettyPlans }, on: { "update:plan": function(a) {
1176
- t.plan = a;
1177
- }, "update:interval": function(a) {
1178
- t.interval = a;
1179
- }, next: function(a) {
1565
+ } } }), t.view === "form" ? e("CButton", { staticStyle: { "margin-left": "2px" }, attrs: { "icon-props": { size: 20 }, pattern: "tertiary", type: "none", circle: "", icon: "arrow-left" }, on: { click: t.onReset } }) : t._e()], 1), t.calloutMode ? e("div", { staticClass: "relative inline-block py-4 pl-12 pr-4 border-2 rounded-lg bg-primary-100 border-primary-300", staticStyle: { "max-width": "calc(55 * var(--rem))" } }, [e("BaseIcon", { staticClass: "absolute left-4 top-5 text-primary-800", attrs: { type: "info", size: "20" } }), e("div", { staticClass: "font-semibold text-primary-800", domProps: { textContent: t._s(t.$t(`callout.${t.calloutMode}.title`)) } }), e("div", { staticClass: "text-sm opacity-70", domProps: { innerHTML: t._s(t.$t(`callout.${t.calloutMode}.text`)) } })], 1) : t._e(), e("div", [t.view === "select" ? e("PremiumStripeSelect", { attrs: { plan: t.plan, interval: t.interval, plans: t.prettyPlans }, on: { "update:plan": function(n) {
1566
+ t.plan = n;
1567
+ }, "update:interval": function(n) {
1568
+ t.interval = n;
1569
+ }, next: function(n) {
1180
1570
  t.view = "form";
1181
- } } }) : t.view === "form" ? e("PremiumStripeForm", { attrs: { "ui-plan": t.prettyPlans.find((a) => a.accountType === t.plan), "form-plan": t.formPlan }, on: { "update:interval": function(a) {
1182
- t.interval = a;
1183
- }, input: t.setFormValue, success: t.goToSuccess } }) : t.view === "success" ? e("div", { staticClass: "flex flex-col items-center justify-center w-full text-center", staticStyle: { height: "100%", width: "100%" } }, [e("Confetti", { attrs: { animate: t.animateConfetti } }), t.isEdit ? t._e() : e("div", { staticClass: "success-block", staticStyle: { "font-size": "calc(18px + 2vw)", "font-weight": "800" } }, [t._v(" " + t._s(t.$t("success.title")) + " ")]), e("div", { staticClass: "success-block", staticStyle: { "font-size": "20px", opacity: "0.7" } }, [t._v(" " + t._s(t.isEdit ? t.$t("success.subTitleEdit") : t.$t("success.subTitle")) + " ")]), e("CButton", { staticClass: "success-block", staticStyle: { "margin-top": "3em" }, attrs: { type: "secondary", size: "medium", rounded: "" }, on: { click: function(a) {
1571
+ } } }) : t.view === "form" ? e("PremiumStripeForm", { attrs: { "ui-plan": t.prettyPlans.find((n) => n.accountType === t.plan), "form-plan": t.formPlan }, on: { "update:interval": function(n) {
1572
+ t.interval = n;
1573
+ }, input: t.setFormValue, success: t.goToSuccess } }) : t.view === "success" ? e("div", { staticClass: "flex flex-col items-center justify-center w-full h-full text-center" }, [e("Confetti", { attrs: { animate: t.animateConfetti } }), t.isEdit ? t._e() : e("div", { staticClass: "success-block", staticStyle: { "font-size": "calc(18px + 2vw)", "font-weight": "800" } }, [t._v(" " + t._s(t.$t("success.title")) + " ")]), e("div", { staticClass: "success-block", staticStyle: { "font-size": "20px", opacity: "0.7" } }, [t._v(" " + t._s(t.isEdit ? t.$t("success.subTitleEdit") : t.$t("success.subTitle")) + " ")]), e("CButton", { staticClass: "success-block", staticStyle: { "margin-top": "3em" }, attrs: { type: "secondary", size: "medium", rounded: "" }, on: { click: function(n) {
1184
1574
  return t.closeAndContinue();
1185
1575
  } } }, [t._v(t._s(t.$t("success.closeButton")))])], 1) : t._e()], 1)]);
1186
- }, lt = [], ct = /* @__PURE__ */ o(
1187
- rt,
1188
- ot,
1189
- lt,
1576
+ }, Rt = [], jt = /* @__PURE__ */ d(
1577
+ Ft,
1578
+ Mt,
1579
+ Rt,
1190
1580
  !1,
1191
1581
  null,
1192
- "b3540e16",
1582
+ null,
1193
1583
  null,
1194
1584
  null
1195
1585
  );
1196
- const ut = ct.exports, dt = {
1586
+ const zt = jt.exports, Nt = {
1197
1587
  name: "IsPremium",
1198
1588
  computed: {
1199
- ...u({
1589
+ ...h({
1200
1590
  subscription: "application/subscription",
1201
1591
  companyAccount: "application/companyAccount",
1202
1592
  stripeCustomDealToken: "settings/stripeCustomDealToken"
1203
1593
  }),
1204
1594
  isPremium() {
1205
- return k.includes(this.subscription.type);
1595
+ return Q.includes(this.subscription.type);
1206
1596
  },
1207
1597
  isPremiumLike() {
1208
- return ["trial", ...k].includes(this.subscription.type);
1598
+ return ["trial", ...Q].includes(this.subscription.type);
1209
1599
  },
1210
1600
  isProLike() {
1211
1601
  return ["pro", "trial"].includes(this.subscription.type);
@@ -1214,7 +1604,7 @@ const ut = ct.exports, dt = {
1214
1604
  return !0;
1215
1605
  },
1216
1606
  canCreateDocument() {
1217
- return this.subscription.freeDocumentsLeft > 0 || L(this.companyAccount, "documentQuota.priceExtra.value") !== null;
1607
+ return this.subscription.freeDocumentsLeft > 0 || v(this.companyAccount, "documentQuota.priceExtra.value") !== null;
1218
1608
  },
1219
1609
  openSubscription() {
1220
1610
  return "openSubscription" in this.$route.query;
@@ -1223,8 +1613,8 @@ const ut = ct.exports, dt = {
1223
1613
  },
1224
1614
  created() {
1225
1615
  if (this.openSubscription) {
1226
- const n = { ...this.$route.query };
1227
- delete n.openSubscription, this.$router.replace({ ...this.$route, query: n }), this.openUpgradeModal();
1616
+ const r = { ...this.$route.query };
1617
+ delete r.openSubscription, this.$router.replace({ ...this.$route, query: r }), this.openUpgradeModal();
1228
1618
  } else
1229
1619
  this.stripeCustomDealToken && this.openUpgradeModal();
1230
1620
  },
@@ -1236,13 +1626,13 @@ const ut = ct.exports, dt = {
1236
1626
  * @param {Function} obj.callback Optional callback to run after upgrade
1237
1627
  * @param {Function} obj.onClosed Optional callback to run after Stripe modal is closed
1238
1628
  */
1239
- openUpgradeModal({ suggestedQuantity: n = null, callback: t = null, onClosed: e = null } = {}) {
1240
- let a = () => null, s = () => null;
1241
- typeof t == "function" && (a = t), typeof e == "function" && (s = e), this.$modal.show(
1242
- ut,
1629
+ openUpgradeModal({ suggestedQuantity: r = null, callback: t = null, onClosed: e = null } = {}) {
1630
+ let n = () => null, a = () => null;
1631
+ typeof t == "function" && (n = t), typeof e == "function" && (a = e), this.$modal.show(
1632
+ zt,
1243
1633
  {
1244
- suggestedQuantity: n,
1245
- onUpgrade: a
1634
+ suggestedQuantity: r,
1635
+ onUpgrade: n
1246
1636
  },
1247
1637
  {
1248
1638
  adaptive: !0,
@@ -1255,7 +1645,7 @@ const ut = ct.exports, dt = {
1255
1645
  },
1256
1646
  {
1257
1647
  closed: () => {
1258
- typeof s == "function" && s();
1648
+ typeof a == "function" && a();
1259
1649
  }
1260
1650
  }
1261
1651
  );
@@ -1277,18 +1667,18 @@ const ut = ct.exports, dt = {
1277
1667
  canCreateDocument: this.canCreateDocument
1278
1668
  }) : {};
1279
1669
  }
1280
- }, pt = null, mt = null;
1281
- var ft = /* @__PURE__ */ o(
1282
- dt,
1283
- pt,
1284
- mt,
1670
+ }, Gt = null, Wt = null;
1671
+ var Kt = /* @__PURE__ */ d(
1672
+ Nt,
1673
+ Gt,
1674
+ Wt,
1285
1675
  !1,
1286
1676
  null,
1287
1677
  null,
1288
1678
  null,
1289
1679
  null
1290
1680
  );
1291
- const gt = ft.exports, vt = {
1681
+ const Zt = Kt.exports, Yt = {
1292
1682
  name: "CalloutLegacy",
1293
1683
  i18nOptions: {
1294
1684
  namespaces: "components",
@@ -1334,25 +1724,25 @@ const gt = ft.exports, vt = {
1334
1724
  mode: {
1335
1725
  type: String,
1336
1726
  default: "legacy",
1337
- validator: (n) => ["legacy", "invoice"].includes(n)
1727
+ validator: (r) => ["legacy", "invoice"].includes(r)
1338
1728
  }
1339
1729
  }
1340
1730
  };
1341
- var ht = function() {
1731
+ var _t = function() {
1342
1732
  var t = this, e = t._self._c;
1343
- return e("div", { staticStyle: { border: "2px solid hsla(35, 100%, 50%, 0.2)", "background-color": "hsl(35, 100%, 91%)", padding: "1.5em", "border-radius": "8px", margin: "2rem 0 3rem 0" } }, [e("div", { staticStyle: { "font-weight": "600" }, domProps: { textContent: t._s(t.$t(`${t.mode}.title`)) } }), e("div", { staticStyle: { "font-size": "14px", opacity: "0.7", "margin-bottom": "2em" }, domProps: { textContent: t._s(t.$t(`${t.mode}.text`)) } }), e("CButton", { attrs: { to: { name: "settingsBilling", query: { highlight: t.mode } }, target: "_blank", type: "secondary", wide: "", "icon-right": "new-window" } }, [t._v(" " + t._s(t.$t(`${t.mode}.action`)) + " ")])], 1);
1344
- }, yt = [], Ct = /* @__PURE__ */ o(
1345
- vt,
1346
- ht,
1347
- yt,
1733
+ return e("div", { staticStyle: { border: "2px solid hsla(35, 100%, 50%, 0.2)", "background-color": "hsl(35, 100%, 91%)", padding: "1.5em", "border-radius": "8px", margin: "calc(2 * var(--rem)) 0 calc(3 * var(--rem)) 0" } }, [e("div", { staticStyle: { "font-weight": "600" }, domProps: { textContent: t._s(t.$t(`${t.mode}.title`)) } }), e("div", { staticStyle: { "font-size": "14px", opacity: "0.7", "margin-bottom": "2em" }, domProps: { textContent: t._s(t.$t(`${t.mode}.text`)) } }), e("CButton", { attrs: { to: { name: "settingsBilling", query: { highlight: t.mode } }, target: "_blank", type: "secondary", wide: "", "icon-right": "new-window" } }, [t._v(" " + t._s(t.$t(`${t.mode}.action`)) + " ")])], 1);
1734
+ }, $t = [], te = /* @__PURE__ */ d(
1735
+ Yt,
1736
+ _t,
1737
+ $t,
1348
1738
  !1,
1349
1739
  null,
1350
1740
  null,
1351
1741
  null,
1352
1742
  null
1353
1743
  );
1354
- const At = Ct.exports;
1355
- const bt = {
1744
+ const ee = te.exports;
1745
+ const re = {
1356
1746
  i18nOptions: {
1357
1747
  namespaces: "components",
1358
1748
  messages: {
@@ -1376,14 +1766,14 @@ const bt = {
1376
1766
  },
1377
1767
  name: "PremiumRestrictedBase",
1378
1768
  components: {
1379
- IsPremium: gt,
1380
- CalloutLegacy: At
1769
+ IsPremium: Zt,
1770
+ CalloutLegacy: ee
1381
1771
  },
1382
1772
  props: {
1383
1773
  plan: {
1384
1774
  type: String,
1385
1775
  default: "pro",
1386
- validator: (n) => ["pro", "premium"].includes(n)
1776
+ validator: (r) => ["pro", "premium"].includes(r)
1387
1777
  },
1388
1778
  title: {
1389
1779
  type: String,
@@ -1412,9 +1802,9 @@ const bt = {
1412
1802
  };
1413
1803
  },
1414
1804
  methods: {
1415
- async onActionClick(n) {
1805
+ async onActionClick(r) {
1416
1806
  try {
1417
- this.isLoading = !0, await n({ callback: this.onUpgrade }), this.$parent.$emit("close");
1807
+ this.isLoading = !0, await r({ callback: this.onUpgrade }), this.$parent.$emit("close");
1418
1808
  } catch (t) {
1419
1809
  throw t;
1420
1810
  } finally {
@@ -1423,30 +1813,30 @@ const bt = {
1423
1813
  }
1424
1814
  }
1425
1815
  };
1426
- var Pt = function() {
1816
+ var ne = function() {
1427
1817
  var t = this, e = t._self._c;
1428
1818
  return e("div", { staticClass: "root font-inter" }, [e("div", { staticClass: "lock-wrapper has-text-white" }, [e("BaseIcon", { attrs: { type: "lock", size: "24" } })], 1), e("div", { staticStyle: { width: "100%" } }, [e("div", { staticClass: "flex items-center justify-center" }, [e("div", { staticClass: "badge-premium" }, [t._v(t._s(t.$t(`badge.${t.plan}`)))])]), e("div", { staticStyle: { "text-align": "center" } }, [t._t("default", function() {
1429
1819
  return [t._t("image"), e("div", { staticClass: "title" }, [t._v(t._s(t.title))]), e("div", { staticClass: "sub-title" }, [t._v(t._s(t.subTitle))])];
1430
- }), t.$slots.content ? e("div", { staticStyle: { "margin-top": "2rem" } }, [t._t("content")], 2) : t._e()], 2), e("div", { staticStyle: { "margin-top": "2rem" } }, [e("IsPremium", { scopedSlots: t._u([{ key: "default", fn: function({ openUpgradeModal: a, isLegacy: s, showCalloutConvertStripe: i }) {
1431
- return [e("div", [s || i ? e("CalloutLegacy", { attrs: { mode: s ? "legacy" : "invoice" } }) : t._e(), e("CButton", { attrs: { loading: t.isLoading, disabled: s || i, type: "secondary", wide: "" }, on: { click: function(d) {
1432
- return t.onActionClick(t.actionFunction || a);
1820
+ }), t.$slots.content ? e("div", { staticStyle: { "margin-top": "calc(2 * var(--rem))" } }, [t._t("content")], 2) : t._e()], 2), e("div", { staticStyle: { "margin-top": "calc(2 * var(--rem))" } }, [e("IsPremium", { scopedSlots: t._u([{ key: "default", fn: function({ openUpgradeModal: n, isLegacy: a, showCalloutConvertStripe: i }) {
1821
+ return [e("div", [a || i ? e("CalloutLegacy", { attrs: { mode: a ? "legacy" : "invoice" } }) : t._e(), e("CButton", { attrs: { loading: t.isLoading, disabled: a || i, type: "secondary", wide: "" }, on: { click: function(s) {
1822
+ return t.onActionClick(t.actionFunction || n);
1433
1823
  } } }, [t._t("actionText", function() {
1434
1824
  return [t._v(t._s(t.$t("upgradeButton")))];
1435
1825
  })], 2)], 1)];
1436
- } }], null, !0) }), e("div", { staticStyle: { "margin-top": "5px" } }, [e("CButton", { attrs: { type: "none", pattern: "tertiary", wide: "" }, on: { click: function(a) {
1826
+ } }], null, !0) }), e("div", { staticStyle: { "margin-top": "5px" } }, [e("CButton", { attrs: { type: "none", pattern: "tertiary", wide: "" }, on: { click: function(n) {
1437
1827
  return t.$parent.$emit("close");
1438
1828
  } } }, [t._v(" " + t._s(t.$t("cancelButton")) + " ")])], 1)], 1)])]);
1439
- }, kt = [], xt = /* @__PURE__ */ o(
1440
- bt,
1441
- Pt,
1442
- kt,
1829
+ }, ae = [], se = /* @__PURE__ */ d(
1830
+ re,
1831
+ ne,
1832
+ ae,
1443
1833
  !1,
1444
1834
  null,
1445
- "96d63adb",
1835
+ "993cb5cc",
1446
1836
  null,
1447
1837
  null
1448
1838
  );
1449
- const c = xt.exports, St = {
1839
+ const g = se.exports, ie = {
1450
1840
  i18nOptions: {
1451
1841
  namespaces: "winProfile",
1452
1842
  keyPrefix: "account.subscription.winProfile",
@@ -1465,7 +1855,7 @@ const c = xt.exports, St = {
1465
1855
  },
1466
1856
  name: "PremiumRestrictedWinProfile",
1467
1857
  components: {
1468
- PremiumRestrictedBase: c
1858
+ PremiumRestrictedBase: g
1469
1859
  },
1470
1860
  props: {
1471
1861
  onUpgrade: {
@@ -1474,20 +1864,20 @@ const c = xt.exports, St = {
1474
1864
  }
1475
1865
  }
1476
1866
  };
1477
- var wt = function() {
1867
+ var oe = function() {
1478
1868
  var t = this, e = t._self._c;
1479
1869
  return e("PremiumRestrictedBase", { attrs: { title: t.$t("title"), "sub-title": t.$t("subTitle"), "on-upgrade": t.onUpgrade } });
1480
- }, Ht = [], It = /* @__PURE__ */ o(
1481
- St,
1482
- wt,
1483
- Ht,
1870
+ }, le = [], ce = /* @__PURE__ */ d(
1871
+ ie,
1872
+ oe,
1873
+ le,
1484
1874
  !1,
1485
1875
  null,
1486
1876
  null,
1487
1877
  null,
1488
1878
  null
1489
1879
  );
1490
- const Lt = It.exports, Bt = {
1880
+ const ue = ce.exports, de = {
1491
1881
  i18nOptions: {
1492
1882
  namespaces: "subTemplates",
1493
1883
  messages: {
@@ -1503,7 +1893,7 @@ const Lt = It.exports, Bt = {
1503
1893
  },
1504
1894
  name: "PremiumRestrictedTemplates",
1505
1895
  components: {
1506
- PremiumRestrictedBase: c
1896
+ PremiumRestrictedBase: g
1507
1897
  },
1508
1898
  props: {
1509
1899
  onUpgrade: {
@@ -1512,20 +1902,20 @@ const Lt = It.exports, Bt = {
1512
1902
  }
1513
1903
  }
1514
1904
  };
1515
- var Dt = function() {
1905
+ var pe = function() {
1516
1906
  var t = this, e = t._self._c;
1517
1907
  return e("PremiumRestrictedBase", { attrs: { title: t.$t("title"), "sub-title": t.$t("subTitle"), "on-upgrade": t.onUpgrade } });
1518
- }, Vt = [], Tt = /* @__PURE__ */ o(
1519
- Bt,
1520
- Dt,
1521
- Vt,
1908
+ }, me = [], fe = /* @__PURE__ */ d(
1909
+ de,
1910
+ pe,
1911
+ me,
1522
1912
  !1,
1523
1913
  null,
1524
1914
  null,
1525
1915
  null,
1526
1916
  null
1527
1917
  );
1528
- const Ot = Tt.exports, Et = {
1918
+ const ve = fe.exports, ge = {
1529
1919
  i18nOptions: {
1530
1920
  namespaces: "PremiumRestrictedDocuments",
1531
1921
  messages: {
@@ -1549,7 +1939,7 @@ const Ot = Tt.exports, Et = {
1549
1939
  },
1550
1940
  name: "PremiumRestrictedDocuments",
1551
1941
  components: {
1552
- PremiumRestrictedBase: c
1942
+ PremiumRestrictedBase: g
1553
1943
  },
1554
1944
  props: {
1555
1945
  onUpgrade: {
@@ -1566,7 +1956,7 @@ const Ot = Tt.exports, Et = {
1566
1956
  };
1567
1957
  },
1568
1958
  computed: {
1569
- ...u({
1959
+ ...h({
1570
1960
  getCompanyUserSetting: "settings/getCompanyUserSetting",
1571
1961
  user: "application/user",
1572
1962
  account: "application/companyAccount"
@@ -1574,58 +1964,58 @@ const Ot = Tt.exports, Et = {
1574
1964
  },
1575
1965
  created() {
1576
1966
  try {
1577
- B("/documentLimitReached", {});
1578
- } catch (n) {
1579
- C(n, { showMessage: !1 });
1967
+ et("/documentLimitReached", {});
1968
+ } catch (r) {
1969
+ L(r, { showMessage: !1 });
1580
1970
  }
1581
1971
  },
1582
1972
  async mounted() {
1583
1973
  this.checkFreeDocVoucher();
1584
1974
  },
1585
1975
  methods: {
1586
- ...v({
1587
- loadCurrentCompany: l.DO_LOAD_CURRENT_COMPANY
1976
+ ...k({
1977
+ loadCurrentCompany: p.DO_LOAD_CURRENT_COMPANY
1588
1978
  }),
1589
1979
  async checkFreeDocVoucher() {
1590
1980
  var t, e;
1591
1981
  if (this.canUseFreeDocVoucher = !1, ((t = this.account) == null ? void 0 : t.accountType) !== "free")
1592
1982
  return;
1593
- const n = JSON.parse(y.getItem("voucher-freeUserDocs-company-id"));
1594
- ((e = this.account) == null ? void 0 : e.CompanyId) !== n && (this.canUseFreeDocVoucher = await this.canUseVoucher());
1983
+ const r = JSON.parse(x.getItem("voucher-freeUserDocs-company-id"));
1984
+ ((e = this.account) == null ? void 0 : e.CompanyId) !== r && (this.canUseFreeDocVoucher = await this.canUseVoucher());
1595
1985
  },
1596
1986
  async canUseVoucher() {
1597
1987
  try {
1598
- return await x.canUse("freeUserDocs"), !0;
1988
+ return await q.canUse("freeUserDocs"), !0;
1599
1989
  } catch {
1600
- return y.setItem("voucher-freeUserDocs-company-id", this.account.CompanyId), !1;
1990
+ return x.setItem("voucher-freeUserDocs-company-id", this.account.CompanyId), !1;
1601
1991
  }
1602
1992
  },
1603
1993
  async useFreeDocsVoucher() {
1604
1994
  this.isLoading = !0;
1605
1995
  try {
1606
- await x.post({ code: "freeUserDocs" }), y.setItem("voucher-freeUserDocs-company-id", this.account.CompanyId), await this.loadCurrentCompany(), D("success", this.$t("voucherSuccessMessage", { count: this.voucherDocCount })), this.onUpgrade && typeof this.onUpgrade == "function" && this.onUpgrade();
1607
- } catch (n) {
1608
- C(n);
1996
+ await q.post({ code: "freeUserDocs" }), x.setItem("voucher-freeUserDocs-company-id", this.account.CompanyId), await this.loadCurrentCompany(), rt("success", this.$t("voucherSuccessMessage", { count: this.voucherDocCount })), this.onUpgrade && typeof this.onUpgrade == "function" && this.onUpgrade();
1997
+ } catch (r) {
1998
+ L(r);
1609
1999
  } finally {
1610
2000
  this.isLoading = !1;
1611
2001
  }
1612
2002
  }
1613
2003
  }
1614
2004
  };
1615
- var Qt = function() {
2005
+ var he = function() {
1616
2006
  var t = this, e = t._self._c;
1617
- return e("PremiumRestrictedBase", { attrs: { title: t.$t("title"), "sub-title": t.$t("subTitle"), "on-upgrade": t.onUpgrade } }, [t.canUseFreeDocVoucher ? e("div", { staticStyle: { background: "hsl(33, 100%, 84%)", padding: "1em", "font-size": "15px", "border-radius": "0.5em" }, attrs: { slot: "content" }, slot: "content" }, [e("div", { staticStyle: { "font-size": "16px", "font-weight": "500" } }, [e("span", { staticStyle: { "margin-right": "4px" } }, [t._v("🎁")]), t._v(" " + t._s(t.$t("voucherTitle")) + " ")]), e("div", { staticStyle: { opacity: "0.75" }, domProps: { textContent: t._s(t.$t("voucherText", { count: t.voucherDocCount })) } }), e("div", { staticClass: "flex justify-center w-full", staticStyle: { "margin-top": "1rem" } }, [e("CButton", { staticStyle: { border: "none", background: "hsl(33, 100%, 95%)", color: "hsl(33, 88%, 36%)", "box-shadow": "0 3px 6px -2px rgb(0, 0, 0, 0.3)" }, attrs: { loading: t.isLoading, transparent: "", "icon-left": "heart" }, on: { click: t.useFreeDocsVoucher } }, [t._v(" " + t._s(t.$t("voucherButton", { count: t.voucherDocCount })) + " ")])], 1)]) : t._e()]);
1618
- }, Jt = [], Xt = /* @__PURE__ */ o(
1619
- Et,
1620
- Qt,
1621
- Jt,
2007
+ return e("PremiumRestrictedBase", { attrs: { title: t.$t("title"), "sub-title": t.$t("subTitle"), "on-upgrade": t.onUpgrade } }, [t.canUseFreeDocVoucher ? e("div", { staticStyle: { background: "hsl(33, 100%, 84%)", padding: "1em", "font-size": "15px", "border-radius": "0.5em" }, attrs: { slot: "content" }, slot: "content" }, [e("div", { staticStyle: { "font-size": "16px", "font-weight": "500" } }, [e("span", { staticStyle: { "margin-right": "4px" } }, [t._v("🎁")]), t._v(" " + t._s(t.$t("voucherTitle")) + " ")]), e("div", { staticStyle: { opacity: "0.75" }, domProps: { textContent: t._s(t.$t("voucherText", { count: t.voucherDocCount })) } }), e("div", { staticClass: "flex justify-center w-full", staticStyle: { "margin-top": "calc(1 * var(--rem))" } }, [e("CButton", { staticStyle: { border: "none", background: "hsl(33, 100%, 95%)", color: "hsl(33, 88%, 36%)", "box-shadow": "0 3px 6px -2px rgb(0, 0, 0, 0.3)" }, attrs: { loading: t.isLoading, transparent: "", "icon-left": "heart" }, on: { click: t.useFreeDocsVoucher } }, [t._v(" " + t._s(t.$t("voucherButton", { count: t.voucherDocCount })) + " ")])], 1)]) : t._e()]);
2008
+ }, ye = [], Ce = /* @__PURE__ */ d(
2009
+ ge,
2010
+ he,
2011
+ ye,
1622
2012
  !1,
1623
2013
  null,
1624
2014
  null,
1625
2015
  null,
1626
2016
  null
1627
2017
  );
1628
- const qt = Xt.exports, Ut = {
2018
+ const Ae = Ce.exports, Pe = {
1629
2019
  i18nOptions: {
1630
2020
  namespaces: "personalMessage",
1631
2021
  messages: {
@@ -1641,7 +2031,7 @@ const qt = Xt.exports, Ut = {
1641
2031
  },
1642
2032
  name: "PremiumRestrictedWinProfile",
1643
2033
  components: {
1644
- PremiumRestrictedBase: c
2034
+ PremiumRestrictedBase: g
1645
2035
  },
1646
2036
  props: {
1647
2037
  onUpgrade: {
@@ -1650,21 +2040,21 @@ const qt = Xt.exports, Ut = {
1650
2040
  }
1651
2041
  }
1652
2042
  };
1653
- var zt = function() {
2043
+ var be = function() {
1654
2044
  var t = this, e = t._self._c;
1655
2045
  return e("PremiumRestrictedBase", { attrs: { title: t.$t("title"), "sub-title": t.$t("subTitle"), "on-upgrade": t.onUpgrade } });
1656
- }, Ft = [], Rt = /* @__PURE__ */ o(
1657
- Ut,
1658
- zt,
1659
- Ft,
2046
+ }, ke = [], Se = /* @__PURE__ */ d(
2047
+ Pe,
2048
+ be,
2049
+ ke,
1660
2050
  !1,
1661
2051
  null,
1662
2052
  null,
1663
2053
  null,
1664
2054
  null
1665
2055
  );
1666
- const jt = Rt.exports;
1667
- const Mt = {
2056
+ const we = Se.exports;
2057
+ const xe = {
1668
2058
  i18nOptions: {
1669
2059
  namespaces: "licenses",
1670
2060
  messages: {
@@ -1688,7 +2078,7 @@ const Mt = {
1688
2078
  },
1689
2079
  name: "PremiumRestrictedLicenses",
1690
2080
  components: {
1691
- PremiumRestrictedBase: c
2081
+ PremiumRestrictedBase: g
1692
2082
  },
1693
2083
  props: {
1694
2084
  onUpgrade: {
@@ -1697,7 +2087,7 @@ const Mt = {
1697
2087
  }
1698
2088
  },
1699
2089
  computed: {
1700
- ...u({
2090
+ ...h({
1701
2091
  subscription: "application/subscription",
1702
2092
  currentPlan: "stripe/currentPlan",
1703
2093
  formPlan: "stripe/formPlan"
@@ -1706,25 +2096,28 @@ const Mt = {
1706
2096
  return this.subscription.paymentMethod === "stripe" && this.formPlan ? this.formPlan : null;
1707
2097
  }
1708
2098
  },
2099
+ beforeCreate() {
2100
+ this.$store.state.stripe || this.$store.registerModule("stripe", j);
2101
+ },
1709
2102
  created() {
1710
2103
  this.initLicense();
1711
2104
  },
1712
2105
  methods: {
1713
- ...v({
1714
- loadCurrentCompany: l.DO_LOAD_CURRENT_COMPANY,
1715
- loadPrices: l.LOAD_PRICES,
1716
- resetStripeForm: l.RESET_STRIPE_FORM,
1717
- updateFormValue: l.SET_STRIPE_FORM_VALUE,
1718
- submitPlan: l.SUBMIT_FORM_PLAN
2106
+ ...k({
2107
+ loadCurrentCompany: p.DO_LOAD_CURRENT_COMPANY,
2108
+ loadPrices: p.LOAD_PRICES,
2109
+ resetStripeForm: p.RESET_STRIPE_FORM,
2110
+ updateFormValue: p.SET_STRIPE_FORM_VALUE,
2111
+ submitPlan: p.SUBMIT_FORM_PLAN
1719
2112
  }),
1720
- priceFormat: p,
2113
+ priceFormat: y,
1721
2114
  async initLicense() {
1722
2115
  this.subscription.paymentMethod === "stripe" && (await this.loadPrices(), await this.resetStripeForm(), this.updateFormValue({ key: "plan", value: this.currentPlan }));
1723
2116
  },
1724
2117
  supportChatMessage() {
1725
2118
  this.$supportChat.showNewMessage(this.$t("chatMessageStarter")), this.$emit("close");
1726
2119
  },
1727
- async doUpgrade({ callback: n }) {
2120
+ async doUpgrade({ callback: r }) {
1728
2121
  let t = !1;
1729
2122
  try {
1730
2123
  if (this.subscription.paymentMethod === "stripe")
@@ -1734,35 +2127,35 @@ const Mt = {
1734
2127
  else
1735
2128
  throw new Error("Cannot upgrade license as current paymentMethod is not valid");
1736
2129
  } catch (e) {
1737
- C(e);
2130
+ L(e);
1738
2131
  }
1739
- t && await n();
2132
+ t && await r();
1740
2133
  },
1741
2134
  async addStripeLicense() {
1742
2135
  this.updateFormValue({ key: "plan.quantity", value: this.currentPlan.quantity + 1 });
1743
- const n = await this.submitPlan({});
1744
- return await this.loadCurrentCompany(), n;
2136
+ const r = await this.submitPlan({});
2137
+ return await this.loadCurrentCompany(), r;
1745
2138
  },
1746
2139
  async addInvoiceLicense() {
1747
- await V(), await this.loadCurrentCompany();
2140
+ await nt(), await this.loadCurrentCompany();
1748
2141
  }
1749
2142
  }
1750
2143
  };
1751
- var Nt = function() {
2144
+ var Ie = function() {
1752
2145
  var t = this, e = t._self._c;
1753
- return e("PremiumRestrictedBase", { attrs: { title: t.$t("title"), "sub-title": t.$t("subTitle"), "on-upgrade": t.onUpgrade, "action-function": t.doUpgrade } }, [e("template", { slot: "actionText" }, [t._v(" " + t._s(t.$t("actionText")) + " ")]), t.extraPrice && t.extraPrice.amount && t.extraPrice.currency && t.extraPrice.interval ? e("div", { staticClass: "flex justify-between w-full", staticStyle: { "background-color": "hsl(0, 0%, 95%)", padding: "0.5em 1em", "border-radius": "0.5em" }, attrs: { slot: "content" }, slot: "content" }, [e("div", { staticStyle: { "text-align": "left" } }, [e("div", { staticStyle: { "font-weight": "500" }, domProps: { textContent: t._s(t.$t("productTitle")) } }), e("div", { staticStyle: { opacity: "0.75", "font-size": "13px" }, domProps: { textContent: t._s(t.$t("productCost")) } })]), e("div", { staticStyle: { "text-align": "right" } }, [e("div", [t._v(" +" + t._s(t.priceFormat(t.extraPrice.amount, { currency: t.extraPrice.currency })) + " ")]), e("div", { staticStyle: { "font-size": "13px", opacity: "0.7" } }, [t._v(" per " + t._s(t.$t(`_common:${t.extraPrice.interval}`)) + " ")])])]) : t._e()], 2);
1754
- }, Gt = [], Wt = /* @__PURE__ */ o(
1755
- Mt,
1756
- Nt,
1757
- Gt,
2146
+ return e("PremiumRestrictedBase", { attrs: { title: t.$t("title"), "sub-title": t.$t("subTitle"), "on-upgrade": t.onUpgrade, "action-function": t.doUpgrade } }, [e("template", { slot: "actionText" }, [t._v(" " + t._s(t.$t("actionText")) + " ")]), t.extraPrice && t.extraPrice.amount && t.extraPrice.currency && t.extraPrice.interval ? e("div", { staticClass: "flex justify-between w-full", staticStyle: { "background-color": "hsl(var(--gray-color-100) / 1)", padding: "0.5em 1em", "border-radius": "0.5em" }, attrs: { slot: "content" }, slot: "content" }, [e("div", { staticStyle: { "text-align": "left" } }, [e("div", { staticStyle: { "font-weight": "500" }, domProps: { textContent: t._s(t.$t("productTitle")) } }), e("div", { staticStyle: { opacity: "0.75", "font-size": "13px" }, domProps: { textContent: t._s(t.$t("productCost")) } })]), e("div", { staticStyle: { "text-align": "right" } }, [e("div", [t._v(" +" + t._s(t.priceFormat(t.extraPrice.amount, { currency: t.extraPrice.currency })) + " ")]), e("div", { staticStyle: { "font-size": "13px", opacity: "0.7" } }, [t._v(" per " + t._s(t.$t(`_common:${t.extraPrice.interval}`)) + " ")])])]) : t._e()], 2);
2147
+ }, He = [], Be = /* @__PURE__ */ d(
2148
+ xe,
2149
+ Ie,
2150
+ He,
1758
2151
  !1,
1759
2152
  null,
1760
2153
  null,
1761
2154
  null,
1762
2155
  null
1763
2156
  );
1764
- const Kt = Wt.exports;
1765
- const Zt = {
2157
+ const Le = Be.exports;
2158
+ const Te = {
1766
2159
  i18nOptions: {
1767
2160
  namespaces: "licenses",
1768
2161
  messages: {
@@ -1780,7 +2173,7 @@ const Zt = {
1780
2173
  },
1781
2174
  name: "PremiumRestrictedLicenses",
1782
2175
  components: {
1783
- PremiumRestrictedBase: c
2176
+ PremiumRestrictedBase: g
1784
2177
  },
1785
2178
  props: {
1786
2179
  onUpgrade: {
@@ -1789,20 +2182,20 @@ const Zt = {
1789
2182
  }
1790
2183
  }
1791
2184
  };
1792
- var Yt = function() {
2185
+ var De = function() {
1793
2186
  var t = this, e = t._self._c;
1794
2187
  return e("PremiumRestrictedBase", { attrs: { title: t.$t("title"), "sub-title": t.$t("subTitle"), "action-function": t.onUpgrade, plan: "premium" } }, [e("template", { slot: "actionText" }, [t._v(" " + t._s(t.$t("actionText")) + " ")])], 2);
1795
- }, _t = [], $t = /* @__PURE__ */ o(
1796
- Zt,
1797
- Yt,
1798
- _t,
2188
+ }, Ve = [], Ee = /* @__PURE__ */ d(
2189
+ Te,
2190
+ De,
2191
+ Ve,
1799
2192
  !1,
1800
2193
  null,
1801
2194
  null,
1802
2195
  null,
1803
2196
  null
1804
2197
  );
1805
- const te = $t.exports, ee = {
2198
+ const Oe = Ee.exports, Qe = {
1806
2199
  i18nOptions: {
1807
2200
  namespaces: "stats",
1808
2201
  messages: {
@@ -1820,7 +2213,7 @@ const te = $t.exports, ee = {
1820
2213
  },
1821
2214
  name: "PremiumRestrictedStats",
1822
2215
  components: {
1823
- PremiumRestrictedBase: c
2216
+ PremiumRestrictedBase: g
1824
2217
  },
1825
2218
  props: {
1826
2219
  onUpgrade: {
@@ -1829,57 +2222,88 @@ const te = $t.exports, ee = {
1829
2222
  }
1830
2223
  }
1831
2224
  };
1832
- var ne = function() {
2225
+ var qe = function() {
1833
2226
  var t = this, e = t._self._c;
1834
2227
  return e("PremiumRestrictedBase", { attrs: { title: t.$t("title"), "sub-title": t.$t("subTitle"), "on-upgrade": t.onUpgrade, plan: "pro" } }, [e("template", { slot: "actionText" }, [t._v(" " + t._s(t.$t("actionText")) + " ")])], 2);
1835
- }, ae = [], se = /* @__PURE__ */ o(
1836
- ee,
1837
- ne,
1838
- ae,
2228
+ }, Je = [], Ue = /* @__PURE__ */ d(
2229
+ Qe,
2230
+ qe,
2231
+ Je,
2232
+ !1,
2233
+ null,
2234
+ null,
2235
+ null,
2236
+ null
2237
+ );
2238
+ const Xe = Ue.exports, Fe = {
2239
+ i18nOptions: {
2240
+ namespaces: "stats",
2241
+ messages: {
2242
+ sv: {
2243
+ title: "Premium block",
2244
+ subTitle: "För att använda premium block behöver du uppgradera ditt konto till Pro.",
2245
+ actionText: "Uppgradera konto"
2246
+ },
2247
+ en: {
2248
+ title: "Premium block",
2249
+ subTitle: "To use premium blocks, you need to upgrade your account to Pro.",
2250
+ actionText: "Upgrade my plan"
2251
+ }
2252
+ }
2253
+ },
2254
+ name: "PremiumRestrictedStats",
2255
+ components: {
2256
+ PremiumRestrictedBase: g
2257
+ },
2258
+ props: {
2259
+ onUpgrade: {
2260
+ type: Function,
2261
+ default: null
2262
+ }
2263
+ }
2264
+ };
2265
+ var Me = function() {
2266
+ var t = this, e = t._self._c;
2267
+ return e("PremiumRestrictedBase", { attrs: { title: t.$t("title"), "sub-title": t.$t("subTitle"), "on-upgrade": t.onUpgrade, plan: "pro" } }, [e("template", { slot: "actionText" }, [t._v(" " + t._s(t.$t("actionText")) + " ")])], 2);
2268
+ }, Re = [], je = /* @__PURE__ */ d(
2269
+ Fe,
2270
+ Me,
2271
+ Re,
1839
2272
  !1,
1840
2273
  null,
1841
2274
  null,
1842
2275
  null,
1843
2276
  null
1844
2277
  );
1845
- const ie = se.exports, re = {
2278
+ const ze = je.exports, I = {
2279
+ winProfile: ue,
2280
+ templates: ve,
2281
+ documents: Ae,
2282
+ personalMessage: we,
2283
+ licenses: Le,
2284
+ inviteCreators: Oe,
2285
+ stats: Xe,
2286
+ documentBlocks: ze
2287
+ }, Ne = {
1846
2288
  name: "IsPremiumPreStep",
1847
2289
  props: {
1848
2290
  feature: {
1849
2291
  type: String,
1850
2292
  required: !0,
1851
- validator: (n) => ["winProfile", "documents", "templates", "personalMessage", "licenses", "inviteCreators", "stats"].includes(n)
2293
+ validator: (r) => Object.keys(I).includes(r)
1852
2294
  }
1853
2295
  },
1854
2296
  computed: {
1855
2297
  modalName() {
1856
- switch (this.feature) {
1857
- case "winProfile":
1858
- return Lt;
1859
- case "templates":
1860
- return Ot;
1861
- case "documents":
1862
- return qt;
1863
- case "personalMessage":
1864
- return jt;
1865
- case "licenses":
1866
- return Kt;
1867
- case "inviteCreators":
1868
- return te;
1869
- case "stats":
1870
- return ie;
1871
- default:
1872
- T.error("Missing IsPremiumPreStep component name");
1873
- }
1874
- return null;
2298
+ return I[this.feature] ? I[this.feature] : (at.error("Missing IsPremiumPreStep component name"), null);
1875
2299
  }
1876
2300
  },
1877
2301
  methods: {
1878
- onClick({ callback: n = null } = {}) {
2302
+ onClick({ callback: r = null } = {}) {
1879
2303
  this.$modal.show(
1880
2304
  this.modalName,
1881
2305
  {
1882
- ...n && { onUpgrade: n }
2306
+ ...r && { onUpgrade: r }
1883
2307
  },
1884
2308
  {
1885
2309
  adaptive: !0,
@@ -1897,23 +2321,23 @@ const ie = se.exports, re = {
1897
2321
  onClick: this.onClick
1898
2322
  }) : {};
1899
2323
  }
1900
- }, oe = null, le = null;
1901
- var ce = /* @__PURE__ */ o(
1902
- re,
1903
- oe,
1904
- le,
2324
+ }, Ge = null, We = null;
2325
+ var Ke = /* @__PURE__ */ d(
2326
+ Ne,
2327
+ Ge,
2328
+ We,
1905
2329
  !1,
1906
2330
  null,
1907
2331
  null,
1908
2332
  null,
1909
2333
  null
1910
2334
  );
1911
- const ve = ce.exports;
2335
+ const nr = Ke.exports;
1912
2336
  export {
1913
- At as C,
1914
- ve as I,
1915
- ut as P,
1916
- gt as a,
1917
- K as b,
1918
- Y as s
2337
+ ee as C,
2338
+ nr as I,
2339
+ zt as P,
2340
+ Zt as a,
2341
+ Lt as b,
2342
+ Dt as s
1919
2343
  };