@cling-se/widget 0.9.5 → 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 (138) hide show
  1. package/dist/{AddClientCallout-e4e9874f.js → AddClientCallout-d8f5bc53.js} +5 -5
  2. package/dist/{AnswerModal-acd3b9c0.js → AnswerModal-5f83562b.js} +3 -3
  3. package/dist/{AttachmentItem-34e91526.js → AttachmentItem-79eb718b.js} +3 -3
  4. package/dist/{BaseDatePicker-581297bc.js → BaseDatePicker-ae7aebf1.js} +1 -1
  5. package/dist/{BaseInput-29d88150.js → BaseInput-2c476604.js} +1 -1
  6. package/dist/{BaseUpload-84d3b68b.js → BaseUpload-9e15729d.js} +2 -2
  7. package/dist/{BlockMedia-319932b8.js → BlockMedia-a3f00a2f.js} +1 -1
  8. package/dist/{CCallout-88ae9c08.js → CCallout-04e2c8c6.js} +2 -2
  9. package/dist/{CDropdownItem-d46bf062.js → CDropdownItem-5532f8af.js} +1 -1
  10. package/dist/{CField-be05883b.js → CField-0bc9de28.js} +1 -1
  11. package/dist/{CSlider.vue_vue_type_style_index_0_lang-df4c839e.js → CSlider.vue_vue_type_style_index_0_lang-d9c2f582.js} +1 -1
  12. package/dist/{ClientAutocomplete-68f76bfc.js → ClientAutocomplete-e13c2753.js} +2 -2
  13. package/dist/{ClientModal-73086005.js → ClientModal-da9fddf9.js} +4 -4
  14. package/dist/{ColorPicker-11ee76f0.js → ColorPicker-06b731b7.js} +1 -1
  15. package/dist/{CompanyModal-0fec4480.js → CompanyModal-b7c42f2a.js} +3 -3
  16. package/dist/{ContentWrapper-fba78b6f.js → ContentWrapper-fe4a67bc.js} +11 -11
  17. package/dist/{CoverBlockSettings-7ffa15b1.js → CoverBlockSettings-2024e993.js} +6 -6
  18. package/dist/DocForm-af03179d.js +7012 -0
  19. package/dist/{DocFormSend-cdc4eaf8.js → DocFormSend-44161541.js} +14 -14
  20. package/dist/{DocModalBase-e473b946.js → DocModalBase-9eb0f26f.js} +1 -1
  21. package/dist/{DocPrint-6d8b1f14.js → DocPrint-92d12950.js} +1 -1
  22. package/dist/{DocReceipt-c8a543f8.js → DocReceipt-4df57e1d.js} +1 -1
  23. package/dist/{DocSendReminder-70effa09.js → DocSendReminder-041af744.js} +1 -1
  24. package/dist/{DocTextEditor-cce51e7c.js → DocTextEditor-b07dd391.js} +7 -7
  25. package/dist/{DocTimeline-c2cbd773.js → DocTimeline-2ae2ca63.js} +5 -5
  26. package/dist/{DocumentClient-611c8c1c.js → DocumentClient-3a1aecf2.js} +5 -5
  27. package/dist/{DocumentLayout-86c367d1.js → DocumentLayout-ae49ac7a.js} +3 -3
  28. package/dist/{DocumentLogotype-441a9fdb.js → DocumentLogotype-91436523.js} +3 -3
  29. package/dist/{EmbedInput-a5938c25.js → EmbedInput-05e22228.js} +2 -2
  30. package/dist/{EmbedSettings-141ab53c.js → EmbedSettings-9dabb6d4.js} +3 -3
  31. package/dist/{ErrorCallout-7dea37df.js → ErrorCallout-c7f69cd9.js} +1 -1
  32. package/dist/{FilePreviewModal-875fd8c9.js → FilePreviewModal-167a40c8.js} +4 -4
  33. package/dist/{HeaderSettings-0364b6df.js → HeaderSettings-e9b177e0.js} +13 -13
  34. package/dist/{ImageSelectModal-2d3a69db.js → ImageSelectModal-8565c461.js} +9 -9
  35. package/dist/{ImageUploadWrapper-7c70045f.js → ImageUploadWrapper-1e61e8da.js} +2 -2
  36. package/dist/{Index-fa01557d.js → Index-0708b238.js} +5 -5
  37. package/dist/{Index-889b6a45.js → Index-0799eaba.js} +2 -2
  38. package/dist/{Index-affdb14c.js → Index-1f3de208.js} +8 -8
  39. package/dist/{Index-28bdb859.js → Index-27a05d76.js} +2 -2
  40. package/dist/{Index-c746dc64.js → Index-43899daf.js} +8 -8
  41. package/dist/{Index-1e0cf88a.js → Index-4446581c.js} +7 -7
  42. package/dist/{Index-b80ab22f.js → Index-49766088.js} +2 -2
  43. package/dist/{Index-beb43a1a.js → Index-630600c9.js} +12 -12
  44. package/dist/{Index-53348c92.js → Index-6b63686e.js} +4 -4
  45. package/dist/{Index-245f88ff.js → Index-716dbe24.js} +5 -5
  46. package/dist/{Index-006a27da.js → Index-72bcad54.js} +4 -4
  47. package/dist/{Index-532b8844.js → Index-84820d3d.js} +2 -2
  48. package/dist/{Index-205dd368.js → Index-85e8119e.js} +6 -6
  49. package/dist/{Index-07ae23ce.js → Index-88e175bf.js} +2 -2
  50. package/dist/{Index-5196628a.js → Index-89addabd.js} +11 -11
  51. package/dist/{Index-5de564da.js → Index-8b29bd10.js} +1 -1
  52. package/dist/{Index-1fc54467.js → Index-8d1c62be.js} +4 -4
  53. package/dist/{Index-3d84a32c.js → Index-96a07794.js} +5 -5
  54. package/dist/{Index-2a0c06b1.js → Index-9bbfa37b.js} +3 -3
  55. package/dist/{Index-0f4c9eb4.js → Index-a7a6f91c.js} +8 -8
  56. package/dist/{Index-7a2f20fd.js → Index-a987a099.js} +6 -6
  57. package/dist/{Index-710d1132.js → Index-b6b60b81.js} +8 -8
  58. package/dist/{Index-ba48e68b.js → Index-ba0c8eaa.js} +2 -2
  59. package/dist/{Index-06bd31c3.js → Index-c038406f.js} +25 -25
  60. package/dist/{Index-875e7805.js → Index-c53330d6.js} +1 -1
  61. package/dist/{Index-54962a1e.js → Index-c58260f8.js} +11 -11
  62. package/dist/{Index-cf54ef50.js → Index-c893d091.js} +2 -2
  63. package/dist/{Index-818ef607.js → Index-ca112d97.js} +4 -4
  64. package/dist/{Index-ff60354c.js → Index-e728d2f7.js} +4 -4
  65. package/dist/{Index-0313a553.js → Index-ecf93915.js} +2 -2
  66. package/dist/{Index-dbf5c34c.js → Index-eda700f4.js} +4 -4
  67. package/dist/{Index-8975cd1e.js → Index-ee75e74a.js} +4 -4
  68. package/dist/{Index-6f957f7e.js → Index-f75b1dd5.js} +4 -4
  69. package/dist/{Index-418c517f.js → Index-fc722547.js} +4 -4
  70. package/dist/{InputToggleRow-c520bed9.js → InputToggleRow-483acc75.js} +1 -1
  71. package/dist/IsPremiumPreStep-aa08f8c8.js +2343 -0
  72. package/dist/{MediaWrapper-722723f7.js → MediaWrapper-ed7db800.js} +3 -3
  73. package/dist/{NotBindingText-613399b6.js → NotBindingText-a99b4f85.js} +2 -2
  74. package/dist/{PackageGroup-1085c76c.js → PackageGroup-8cae78f1.js} +10 -10
  75. package/dist/{PdfTerms-f98a6f75.js → PdfTerms-9c1c806e.js} +4 -4
  76. package/dist/{PdfViewer-096bbf00.js → PdfViewer-1227dda6.js} +2 -2
  77. package/dist/{PlainHtml-752bc8d6.js → PlainHtml-647219e9.js} +1 -1
  78. package/dist/{PriceHeader-e25df5eb.js → PriceHeader-cfb22169.js} +11 -11
  79. package/dist/{SearchApi-20629627.js → SearchApi-c0067742.js} +2 -2
  80. package/dist/{TermsSettings-4cc4a9ee.js → TermsSettings-a0282ad7.js} +6 -6
  81. package/dist/{ThemeColorRow-c292abc6.js → ThemeColorRow-71af67bd.js} +2 -2
  82. package/dist/{ToggleBinding-406175fb.js → ToggleBinding-16c2879e.js} +3 -3
  83. package/dist/{UploadModal-0cbd0c8f.js → UploadModal-084e3c2e.js} +3 -3
  84. package/dist/{VideoPlayerInput-d7b5fe4b.js → VideoPlayerInput-fe87698e.js} +3 -3
  85. package/dist/{VideoPlayerSettings-51c75143.js → VideoPlayerSettings-06cfaccc.js} +4 -4
  86. package/dist/{VideoSelectModal-e34cde4b.js → VideoSelectModal-fa81fb92.js} +7 -7
  87. package/dist/{answerDocumentMixin-574c5304.js → answerDocumentMixin-ef48c7eb.js} +3 -3
  88. package/dist/{cssMode-eda08630.js → cssMode-916ae2c1.js} +15 -19
  89. package/dist/{focusDrawerMixin-72f8dd7a.js → focusDrawerMixin-24942dd1.js} +1 -1
  90. package/dist/{formComponentsInstall-3f1c6477.js → formComponentsInstall-2dfa2def.js} +26 -26
  91. package/dist/{formValidationMixin-d4e84872.js → formValidationMixin-82793652.js} +1 -1
  92. package/dist/{freemarker2-42cdfba5.js → freemarker2-6fd30e77.js} +19 -23
  93. package/dist/{handlebars-b4515777.js → handlebars-ff07e526.js} +11 -15
  94. package/dist/{html-ea5d1845.js → html-5ad143f9.js} +14 -18
  95. package/dist/{htmlMode-1cc3531d.js → htmlMode-adc834ff.js} +19 -23
  96. package/dist/{index-7adda710.js → index-045c9c73.js} +1 -1
  97. package/dist/index-1f068e8e.js +14 -0
  98. package/dist/{index-762349d7.js → index-6eda8be0.js} +4 -4
  99. package/dist/{index-07377b76.js → index-b3fb8f92.js} +7 -7
  100. package/dist/index.es.js +2 -2
  101. package/dist/index.umd.js +539 -539
  102. package/dist/{javascript-185ef2e0.js → javascript-9c241e8d.js} +11 -15
  103. package/dist/{jsonMode-59ea4e99.js → jsonMode-36a8e1fd.js} +19 -23
  104. package/dist/{liquid-517f2a7c.js → liquid-da99d7af.js} +14 -18
  105. package/dist/{main-95207159.js → main-2dc98356.js} +45 -45
  106. package/dist/{mapFormMixin-a245a297.js → mapFormMixin-4ac649c2.js} +1 -1
  107. package/dist/{publicSenderState-bea5980b.js → publicSenderState-1db8a50c.js} +1 -1
  108. package/dist/{python-eb6703d8.js → python-15d86041.js} +11 -15
  109. package/dist/{razor-4c5b7deb.js → razor-19e0207f.js} +18 -22
  110. package/dist/{simplebar.min-97b539d6.js → simplebar.min-9f5e0b8a.js} +1 -1
  111. package/dist/style.css +1 -1
  112. package/dist/template-069f0890.js +526 -0
  113. package/dist/{throttle-a0ce8f66.js → throttle-f8ef830f.js} +2 -2
  114. package/dist/{tinycolor-65e7dc2e.js → tinycolor-78c3e3d5.js} +1 -1
  115. package/dist/{tippy.esm-3c111ba9.js → tippy.esm-d2a6f864.js} +5 -5
  116. package/dist/{tsMode-a4a0e653.js → tsMode-7fcdffc4.js} +15 -19
  117. package/dist/{typescript-aeab7849.js → typescript-f492bdab.js} +11 -15
  118. package/dist/{utils-580c7144.js → utils-aab0bc31.js} +1 -1
  119. package/dist/{vuedraggable.umd-2c22e5f8.js → vuedraggable.umd-eb01eee5.js} +1 -1
  120. package/dist/{xml-098907e6.js → xml-976a8723.js} +14 -18
  121. package/package.json +1 -1
  122. package/stats.html +1 -1
  123. package/dist/DocForm-e56b3a0c.js +0 -7143
  124. package/dist/IsPremiumPreStep-d4739d6a.js +0 -2443
  125. package/dist/assets/article-options-10291.png +0 -0
  126. package/dist/assets/bg-base-13048.png +0 -0
  127. package/dist/assets/bg-pro-81076.png +0 -0
  128. package/dist/assets/bg-start-20630.png +0 -0
  129. package/dist/assets/blank-10674.png +0 -0
  130. package/dist/assets/block-options-17322.png +0 -0
  131. package/dist/assets/columnGallery.image-24825.png +0 -0
  132. package/dist/assets/doc-send-94456.png +0 -0
  133. package/dist/assets/drag-block-17194.png +0 -0
  134. package/dist/assets/headerCircularGradient.image-13878.png +0 -0
  135. package/dist/assets/roiCalculator.image-14704.png +0 -0
  136. package/dist/assets/text-bubble-53861.png +0 -0
  137. package/dist/index-676b9274.js +0 -17
  138. package/dist/template-b3af7583.js +0 -528
@@ -0,0 +1,2343 @@
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 = {
395
+ props: {
396
+ colors: {
397
+ type: Array,
398
+ default: () => ["#FF1461", "#18FF92", "#5A87FF", "#FBF38C"]
399
+ },
400
+ animate: {
401
+ type: Boolean,
402
+ default: !1
403
+ }
404
+ },
405
+ data() {
406
+ return {
407
+ canvasEl: null,
408
+ ctx: null,
409
+ pointerX: 0,
410
+ pointerY: 0,
411
+ numberOfParticles: 30
412
+ };
413
+ },
414
+ mounted() {
415
+ this.canvasEl = document.getElementById("fireworks"), this.ctx = this.canvasEl.getContext("2d"), u({
416
+ duration: 1 / 0,
417
+ update: () => {
418
+ this.ctx.clearRect(0, 0, this.canvasEl.width, this.canvasEl.height);
419
+ }
420
+ }), this.autoClick(), this.setCanvasSize(), window.addEventListener("resize", this.setCanvasSize, !1);
421
+ },
422
+ beforeDestroy() {
423
+ window.removeEventListener("resize", this.setCanvasSize, !1);
424
+ },
425
+ methods: {
426
+ setCanvasSize() {
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);
428
+ },
429
+ updateCoords(r) {
430
+ this.pointerX = r.clientX || r.touches[0].clientX, this.pointerY = r.clientY || r.touches[0].clientY;
431
+ },
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;
434
+ return {
435
+ x: r.x + n * Math.cos(t),
436
+ y: r.y + n * Math.sin(t)
437
+ };
438
+ },
439
+ createParticle(r, t) {
440
+ const e = {};
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 = () => {
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();
443
+ }, e;
444
+ },
445
+ createCircle(r, t) {
446
+ const e = {};
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 = () => {
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;
449
+ }, e;
450
+ },
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;
463
+ },
464
+ y(a) {
465
+ return a.endPos.y;
466
+ },
467
+ radius: 0.1,
468
+ duration: u.random(1200, 1800),
469
+ easing: "easeOutExpo",
470
+ update: this.renderParticle
471
+ }).add({
472
+ targets: e,
473
+ radius: u.random(80, 160),
474
+ lineWidth: 0,
475
+ alpha: {
476
+ value: 0,
477
+ easing: "linear",
478
+ duration: u.random(600, 800)
479
+ },
480
+ duration: u.random(1200, 1800),
481
+ easing: "easeOutExpo",
482
+ update: this.renderParticle,
483
+ offset: 0
484
+ });
485
+ },
486
+ autoClick() {
487
+ const r = window.innerWidth / 2, t = window.innerHeight / 2;
488
+ this.animate && (this.animateParticles(
489
+ u.random(r - 50, r + 50),
490
+ // 50 as constant
491
+ u.random(t - 50, t + 50)
492
+ // 50 as constant
493
+ ), u({ duration: 500 }).finished.then(this.autoClick));
494
+ }
495
+ }
496
+ };
497
+ var ht = function() {
498
+ var t = this;
499
+ return t._self._c, t._m(0);
500
+ }, yt = [function() {
501
+ var r = this, t = r._self._c;
502
+ return t("div", [t("canvas", { attrs: { id: "fireworks" } })]);
503
+ }], Ct = /* @__PURE__ */ d(
504
+ gt,
505
+ ht,
506
+ yt,
507
+ !1,
508
+ null,
509
+ "d4677903",
510
+ null,
511
+ null
512
+ );
513
+ const At = Ct.exports;
514
+ const Pt = {
515
+ name: "PremiumStripeSelect",
516
+ i18nOptions: {
517
+ namespaces: "PremiumStripeSelect",
518
+ messages: {
519
+ en: {
520
+ title: 'Upgrade your plan. <span style="opacity: 0.5;">Get more out of {{brand,capitalize}}.</span>',
521
+ saveYearly: "Save 30%",
522
+ billedYearly: "Billed yearly.",
523
+ continueButton: "Continue to billing",
524
+ currentPlan: "Your current plan"
525
+ },
526
+ sv: {
527
+ title: 'Uppgradera ditt konto. <span style="opacity: 0.5;">Få ut mer av {{brand,capitalize}}.</span>',
528
+ saveYearly: "Spara 30%",
529
+ billedYearly: "Faktureras årsvis.",
530
+ continueButton: "Fortsätt till kassan",
531
+ currentPlan: "Din nuvarande plan"
532
+ }
533
+ }
534
+ },
535
+ props: {
536
+ plans: {
537
+ type: Array,
538
+ required: !0
539
+ },
540
+ interval: {
541
+ type: String,
542
+ required: !0
543
+ },
544
+ plan: {
545
+ type: String,
546
+ required: !0
547
+ }
548
+ },
549
+ computed: {
550
+ ...h({
551
+ currentPlan: "stripe/currentPlan",
552
+ getPrice: "stripe/getPrice"
553
+ }),
554
+ currentAccountType() {
555
+ var r;
556
+ return (r = this.currentPlan) == null ? void 0 : r.accountType;
557
+ },
558
+ currentInterval() {
559
+ var r;
560
+ return (r = this.currentPlan) == null ? void 0 : r.interval;
561
+ }
562
+ },
563
+ created() {
564
+ this.$nextTick(() => {
565
+ u({
566
+ targets: ".anim-block",
567
+ translateY: [50, 0],
568
+ opacity: [0, 1],
569
+ delay: u.stagger(80),
570
+ easing: "spring(1, 70, 20, 9)",
571
+ complete: (r) => {
572
+ r.animatables.forEach(({ target: t }) => {
573
+ t.style.transform = "", this.$el.classList.remove("animating");
574
+ });
575
+ }
576
+ });
577
+ });
578
+ },
579
+ methods: {
580
+ getPriceFormatted(r) {
581
+ const { amount: t, currency: e } = this.getPrice(r.accountType, this.interval) || {};
582
+ if (typeof t > "u" || typeof e > "u")
583
+ return "";
584
+ const n = t / (this.interval === "month" ? 1 : 12);
585
+ return `${y(n, { currency: e })}/${this.$t("_common:month")}`;
586
+ }
587
+ }
588
+ };
589
+ var bt = function() {
590
+ var t = this, e = t._self._c;
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([
592
+ "month",
593
+ "year"
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);
599
+ } } });
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
603
+ }, on: { click: 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) {
606
+ return e("li", { key: i }, [e("span", { domProps: { textContent: t._s(i) } })]);
607
+ }), 0)]);
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) {
609
+ return t.$emit("next");
610
+ } } }, [t._v(t._s(t.$t("continueButton")))])], 1);
611
+ }, kt = [], St = /* @__PURE__ */ d(
612
+ Pt,
613
+ bt,
614
+ kt,
615
+ !1,
616
+ null,
617
+ "59cedf98",
618
+ null,
619
+ null
620
+ );
621
+ const wt = St.exports;
622
+ const xt = {
623
+ props: {
624
+ defaultOpen: {
625
+ type: Boolean,
626
+ default: !0
627
+ },
628
+ value: {
629
+ type: Boolean,
630
+ default: null
631
+ },
632
+ duration: {
633
+ type: Number,
634
+ default: 250
635
+ }
636
+ },
637
+ data() {
638
+ return {
639
+ internalExpanded: !1
640
+ };
641
+ },
642
+ computed: {
643
+ wrapperStyle() {
644
+ return {
645
+ transitionDuration: `${this.duration}ms`
646
+ };
647
+ },
648
+ expanded: {
649
+ get() {
650
+ return this.value === null ? this.internalExpanded : this.value;
651
+ },
652
+ set(r) {
653
+ this.value === null ? this.internalExpanded = r : this.$emit("input", this.value);
654
+ }
655
+ }
656
+ },
657
+ created() {
658
+ this.defaultOpen && (this.expanded = !0);
659
+ },
660
+ mounted() {
661
+ this.expanded && this.setWrapperHeightTo("auto");
662
+ },
663
+ methods: {
664
+ onEnter(r) {
665
+ this.setWrapperHeightTo(this.getContentHeight(), r);
666
+ },
667
+ onAfterEnter(r) {
668
+ this.setWrapperHeightTo("auto", r);
669
+ },
670
+ onBeforeLeave(r) {
671
+ this.setWrapperHeightTo(this.getContentHeight(), r);
672
+ },
673
+ onLeave(r) {
674
+ r.scrollHeight, this.setWrapperHeightTo(0, r);
675
+ },
676
+ getContentHeight() {
677
+ const { inner: r } = this.$refs;
678
+ return r.getBoundingClientRect().height;
679
+ },
680
+ setWrapperHeightTo(r, t = this.$refs.wrapper) {
681
+ t.style.height = typeof r == "number" ? `${r}px` : r;
682
+ }
683
+ }
684
+ };
685
+ var It = function() {
686
+ var t = this, e = t._self._c;
687
+ return e("div", [e("div", { on: { click: function(n) {
688
+ t.expanded = !t.expanded;
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);
690
+ }, Ht = [], Bt = /* @__PURE__ */ d(
691
+ xt,
692
+ It,
693
+ Ht,
694
+ !1,
695
+ null,
696
+ null,
697
+ null,
698
+ null
699
+ );
700
+ const Lt = Bt.exports, Tt = {
701
+ amex: {
702
+ name: "American Express",
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>'
704
+ },
705
+ diners: {
706
+ name: "Diners Club",
707
+ logo: '<path d="M99.285 133.86c36.446.177 69.714-29.66 69.714-65.956C169 28.215 135.731.782 99.285.794H67.92C31.037.781.68 28.221.68 67.903c0 36.305 30.357 66.133 67.24 65.956h31.365" fill="#006095"></path><path d="M81.91 103.247V31.175c14.516 5.557 24.822 19.583 24.847 36.034c-.025 16.453-10.33 30.47-24.848 36.038M29.388 67.209c.032-16.441 10.322-30.459 24.83-36.032v72.055C39.71 97.664 29.42 83.654 29.389 67.21M68.066 6.294c-33.701.01-61.011 27.272-61.02 60.915c.009 33.639 27.319 60.895 61.02 60.905c33.714-.01 61.028-27.266 61.033-60.905c-.005-33.643-27.32-60.904-61.033-60.915" fill="#FFF"></path>'
708
+ },
709
+ discover: {
710
+ name: "Discover",
711
+ logo: '<g><path d="M48 4V28C48 30.2091 46.2091 32 44 32H4C3.53583 32.0035 3.07493 31.9222 2.64 31.76C1.05621 31.1874 0.00071654 29.6841 0 28V4C0 1.79086 1.79086 0 4 0H44C46.2091 0 48 1.79086 48 4Z" fill="#DFE3E8"/><g><path d="M48 16V27.9646C48 30.1932 46.1839 31.9999 43.9436 31.9999H3.37919C2.90847 32.0034 2.44107 31.9214 2 31.7578C5.40741 31.2735 8.69312 30.6682 11.918 29.9822C12.7698 29.8208 13.6014 29.6191 14.433 29.4375C27.8395 26.3908 39.4409 21.9117 45.9718 17.5132C46.7019 17.0088 47.3915 16.5044 48 16Z" fill="#EE7623"/><path fill-rule="evenodd" clip-rule="evenodd" d="M4 10.64H5.82V10.6C7.21326 10.4992 8.51258 11.3083 9.03688 12.6031C9.56117 13.8978 9.19084 15.383 8.12 16.28C7.46653 16.792 6.64875 17.048 5.82 17H4V10.64ZM5.58 16C6.20562 16.0549 6.82663 15.8527 7.3 15.44C7.75024 15.0305 8.00481 14.4486 8 13.84C8.00869 13.2306 7.75346 12.6472 7.3 12.24C6.81872 11.8447 6.19969 11.6575 5.58 11.72H5.26V16H5.58Z" fill="#231F20"/><rect x="9.85001" y="10.63" width="1.25" height="6.42" fill="#231F20"/><path d="M14.17 13.09C13.42 12.82 13.17 12.63 13.17 12.28C13.17 11.93 13.56 11.57 14.1 11.57C14.4939 11.5865 14.8602 11.777 15.1 12.09L15.75 11.24C15.2369 10.771 14.5651 10.5138 13.87 10.52C13.3578 10.4871 12.8545 10.6651 12.4768 11.0126C12.0991 11.3601 11.8799 11.8469 11.87 12.36C11.87 13.25 12.27 13.7 13.44 14.12C13.7408 14.2163 14.032 14.3402 14.31 14.49C14.5457 14.6261 14.6907 14.8778 14.69 15.15C14.6882 15.4068 14.5791 15.6511 14.3892 15.8239C14.1993 15.9968 13.9458 16.0823 13.69 16.06C13.1068 16.0663 12.5743 15.7296 12.33 15.2L11.52 15.98C11.9927 16.7804 12.8719 17.2508 13.8 17.2C14.3772 17.2395 14.9444 17.0344 15.3629 16.6349C15.7814 16.2354 16.0126 15.6784 16 15.1C16 14.08 15.59 13.61 14.17 13.09Z" fill="#231F20"/><path d="M16.41 13.84C16.4017 14.738 16.7575 15.601 17.3962 16.2322C18.035 16.8634 18.9022 17.209 19.8 17.19C20.3453 17.1932 20.8835 17.0664 21.37 16.82V15.35C20.9923 15.7916 20.4411 16.0471 19.86 16.05C19.2722 16.0647 18.7049 15.8335 18.2948 15.4121C17.8847 14.9906 17.6692 14.4172 17.7 13.83C17.6811 13.2582 17.8931 12.7029 18.2881 12.2891C18.6831 11.8753 19.228 11.6378 19.8 11.63C20.4027 11.6324 20.9749 11.8949 21.37 12.35V10.88C20.8987 10.6187 20.3689 10.4811 19.83 10.48C18.9301 10.4693 18.0631 10.818 17.4212 11.4487C16.7792 12.0794 16.4153 12.9401 16.41 13.84Z" fill="#231F20"/><path d="M31.3 14.94L29.58 10.63H28.22L30.94 17.21H31.61L34.39 10.63H33.03L31.3 14.94Z" fill="#231F20"/><path d="M34.95 17.05H38.51V15.96H36.2V14.23H38.42V13.14H36.2V11.72H38.51V10.63H34.95V17.05Z" fill="#231F20"/><path fill-rule="evenodd" clip-rule="evenodd" d="M43.46 12.52C43.5281 13.4204 42.8923 14.2216 42 14.36L44 17H42.48L40.74 14.46H40.6V17H39.34V10.64H41.18C42.64 10.64 43.46 11.32 43.46 12.52ZM40.6 13.58H41C41.74 13.58 42.18 13.32 42.18 12.64C42.18 11.96 41.76 11.64 41 11.64H40.6V13.58Z" fill="#231F20"/><path d="M28.59 13.84C28.59 15.7233 27.0633 17.25 25.18 17.25C23.2967 17.25 21.77 15.7233 21.77 13.84C21.77 11.9567 23.2967 10.43 25.18 10.43C27.061 10.4355 28.5845 11.959 28.59 13.84Z" fill="#EE7623"/><path fill-rule="evenodd" clip-rule="evenodd" d="M44.12 10.76C44.1168 10.8286 44.0674 10.8863 44 10.9L44.18 11.16H44.02L43.84 10.92V11.16H43.7V10.58H43.9C44.04 10.58 44.12 10.64 44.12 10.76ZM43.98 10.76C43.98 10.7 43.94 10.7 43.88 10.7V10.82H43.9C43.9532 10.82 43.9725 10.82 43.9788 10.811C43.9844 10.803 43.98 10.7881 43.98 10.76Z" fill="#231F20"/><path fill-rule="evenodd" clip-rule="evenodd" d="M43.46 10.86C43.4598 10.5915 43.6717 10.3707 43.94 10.36C44.076 10.3546 44.2084 10.4048 44.3065 10.4992C44.4047 10.5936 44.4601 10.7239 44.46 10.86C44.46 11.1361 44.2361 11.36 43.96 11.36C43.6838 11.36 43.46 11.1361 43.46 10.86ZM43.94 11.28C44.0407 11.2832 44.1371 11.2387 44.2 11.16C44.275 11.0778 44.3176 10.9712 44.32 10.86C44.32 10.6501 44.1499 10.48 43.94 10.48C43.7301 10.48 43.56 10.6501 43.56 10.86C43.5517 10.9668 43.5878 11.0723 43.6596 11.1518C43.7315 11.2312 43.8329 11.2776 43.94 11.28Z" fill="#231F20"/></g></g>'
712
+ },
713
+ jcb: {
714
+ name: "JCB",
715
+ logo: '<g><rect width="48" height="32" rx="4" fill="white"/><g><path d="M32.1 18.57H34.41H34.69C35.1671 18.4778 35.5088 18.0559 35.5 17.57C35.483 17.0934 35.1527 16.6856 34.69 16.57C34.5969 16.5593 34.503 16.5593 34.41 16.57H32.1V18.57Z" fill="#40A648"/><path d="M34.14 4C31.9309 4 30.14 5.79086 30.14 8V12.15H35.79C35.9229 12.1344 36.0571 12.1344 36.19 12.15C37.46 12.21 38.41 12.87 38.41 14.01C38.3837 15.0096 37.5796 15.8138 36.58 15.84C37.88 15.93 38.87 16.65 38.87 17.78C38.87 18.91 37.77 19.78 36.32 19.78H30.12V28H36C38.2091 28 40 26.2091 40 24V4H34.14Z" fill="#40A648"/><path d="M35.22 14.31C35.2562 13.8151 34.9016 13.3773 34.41 13.31H34.19H32.1V15.24H34.19C34.2629 15.2513 34.3371 15.2513 34.41 15.24C34.8801 15.1789 35.229 14.774 35.22 14.3V14.31Z" fill="#40A648"/><path d="M12 4C9.79086 4 8 5.79086 8 8V17.87C9.06652 18.4287 10.2465 18.7365 11.45 18.77C12.0104 18.8353 12.5711 18.6509 12.9832 18.2657C13.3954 17.8805 13.6173 17.3335 13.59 16.77V12.13H17V16.77C17 18.57 15.88 20.04 12.08 20.04C10.7048 20.039 9.33477 19.8711 8 19.54V28H13.87C16.0791 28 17.87 26.2091 17.87 24V4H12Z" fill="#0D67B0"/><path d="M23.09 4C20.8809 4 19.09 5.79086 19.09 8V13.23C20.09 12.37 21.86 11.82 24.69 11.96C25.7492 12.0232 26.8003 12.1839 27.83 12.44V14.13C26.9019 13.6317 25.8803 13.332 24.83 13.25C22.68 13.1 21.38 14.15 21.38 16C21.38 17.85 22.68 18.92 24.83 18.75C25.8777 18.6543 26.8967 18.3554 27.83 17.87V19.56C26.8008 19.8182 25.7494 19.9789 24.69 20.04C21.86 20.18 20.1 19.63 19.09 18.77V28H25C27.2092 28 29 26.2091 29 24V4H23.09Z" fill="#BE2034"/></g></g>'
716
+ },
717
+ mastercard: {
718
+ name: "Mastercard",
719
+ logo: '<g><rect width="48" height="32" rx="4" fill="#212B36"/><g><g opacity="0.01"><rect x="4.65" y="3.20001" width="38.71" height="25.6" fill="white"/></g><rect x="18.9" y="7.66" width="10.21" height="16.68" fill="#F26122"/><path d="M20 16C19.9831 12.7535 21.4577 9.67905 24 7.66C19.6503 4.23929 13.402 4.73602 9.6473 8.801C5.89264 12.866 5.89264 19.134 9.6473 23.199C13.402 27.264 19.6503 27.7607 24 24.34C21.4577 22.3209 19.9831 19.2465 20 16Z" fill="#EA1D25"/><path fill-rule="evenodd" clip-rule="evenodd" d="M40.14 22.23V22.57H40.08V22.23H39.94V22.16H40.29V22.23H40.14ZM40.82 22.16V22.57H40.75V22.26L40.64 22.53H40.56L40.44 22.26V22.57H40.37V22.16H40.47L40.6 22.45L40.72 22.16H40.82Z" fill="#F69E1E"/><path d="M41.16 16C41.1574 20.0593 38.8389 23.7614 35.1879 25.5358C31.5369 27.3102 27.1935 26.846 24 24.34C28.6001 20.7179 29.3967 14.0543 25.78 9.44999C25.2616 8.78326 24.6638 8.18216 24 7.65999C27.1935 5.15398 31.5369 4.68973 35.1879 6.46416C38.8389 8.23859 41.1574 11.9406 41.16 16Z" fill="#F69E1E"/></g></g>'
720
+ },
721
+ unionpay: {
722
+ name: "China UnionPay",
723
+ logo: '<path d="M50.042 0h63.778c8.903 0 14.44 7.257 12.364 16.19L96.49 143.675c-2.095 8.902-11.01 16.165-19.918 16.165H12.799c-8.89 0-14.44-7.263-12.363-16.165L30.142 16.19C32.219 7.257 41.128 0 50.042 0" fill="#E21836"></path><path d="M108.513 0h73.344c8.901 0 4.888 7.257 2.794 16.19l-29.69 127.485c-2.082 8.902-1.433 16.165-10.353 16.165H71.265c-8.92 0-14.44-7.263-12.345-16.165L88.607 16.19C90.715 7.257 99.606 0 108.513 0" fill="#00447C"></path><path d="M178.948 0h63.778c8.916 0 14.453 7.257 12.36 16.19l-29.69 127.485c-2.095 8.902-11.015 16.165-19.93 16.165h-63.748c-8.92 0-14.453-7.263-12.363-16.165L159.048 16.19C161.125 7.257 170.028 0 178.948 0" fill="#007B84"></path><path d="M66.698 40.856c-6.558.067-8.495 0-9.114-.146c-.238 1.13-4.664 21.546-4.676 21.563c-.953 4.13-1.646 7.075-4.002 8.976c-1.336 1.105-2.897 1.639-4.707 1.639c-2.908 0-4.603-1.445-4.887-4.184l-.055-.94s.886-5.533.886-5.564c0 0 4.645-18.605 5.477-21.064c.044-.14.056-.213.067-.28c-9.041.08-10.644 0-10.754-.146c-.061.2-.285 1.354-.285 1.354l-4.743 20.97l-.407 1.778l-.788 5.817c0 1.725.339 3.134 1.013 4.325c2.161 3.776 8.325 4.342 11.812 4.342c4.492 0 8.707-.955 11.555-2.698c4.943-2.92 6.237-7.486 7.39-11.544l.535-2.081S65.8 43.65 66.613 41.136c.03-.14.043-.213.085-.28zm16.28 15.588c-1.153 0-3.26.28-5.154 1.208c-.687.353-1.337.76-2.023 1.166l.619-2.234l-.339-.376c-4.015.813-4.914.922-8.623 1.444l-.31.207c-.431 3.57-.814 6.255-2.41 13.274a832.32 832.32 0 0 1-1.872 7.78l.17.327c3.802-.2 4.955-.2 8.259-.146l.267-.29c.42-2.15.474-2.654 1.404-7.009c.437-2.064 1.348-6.6 1.797-8.215c.825-.383 1.64-.759 2.417-.759c1.852 0 1.626 1.615 1.555 2.259c-.08 1.08-.754 4.609-1.446 7.639l-.462 1.955c-.321 1.445-.674 2.848-.996 4.28l.14.286c3.746-.2 4.889-.2 8.088-.146l.376-.29c.579-3.358.748-4.257 1.774-9.146l.516-2.246c1.003-4.397 1.507-6.626.748-8.442c-.802-2.035-2.727-2.526-4.494-2.526zm18.188 4.603c-1.992.383-3.262.637-4.524.802c-1.251.2-2.472.383-4.396.65l-.153.138l-.14.11c-.2 1.434-.34 2.673-.606 4.13c-.225 1.506-.572 3.218-1.136 5.677c-.437 1.882-.662 2.538-.911 3.2c-.243.663-.51 1.307-1.001 3.158l.115.171l.096.157c1.799-.085 2.976-.146 4.185-.157c1.208-.043 2.46 0 4.396.01l.17-.137l.182-.153c.28-1.67.321-2.119.492-2.933c.17-.874.462-2.083 1.179-5.314c.339-1.517.716-3.03 1.068-4.578c.365-1.542.747-3.06 1.111-4.578l-.054-.183l-.073-.17zm.042-6.206c-1.81-1.068-4.985-.729-7.123.746c-2.131 1.446-2.374 3.498-.57 4.58c1.778 1.038 4.966.729 7.085-.759c2.127-1.477 2.393-3.51.608-4.567zm10.943 24.734c3.661 0 7.414-1.01 10.239-4.003c2.173-2.428 3.17-6.041 3.515-7.529c1.123-4.931.248-7.233-.85-8.635c-1.67-2.138-4.621-2.824-7.682-2.824c-1.84 0-6.224.182-9.649 3.34c-2.46 2.277-3.596 5.368-4.281 8.33c-.692 3.02-1.488 8.454 3.51 10.477c1.542.662 3.765.844 5.198.844zm-.286-11.095c.844-3.734 1.841-6.868 4.384-6.868c1.993 0 2.138 2.332 1.252 6.078c-.159.832-.886 3.924-1.87 5.24c-.688.972-1.5 1.561-2.4 1.561c-.267 0-1.857 0-1.882-2.361c-.012-1.166.226-2.357.516-3.65zm23.191 10.615l.286-.291c.406-2.15.473-2.655 1.371-7.008c.45-2.065 1.38-6.6 1.816-8.216c.827-.384 1.628-.76 2.43-.76c1.839 0 1.615 1.615 1.542 2.259c-.067 1.082-.742 4.609-1.446 7.639l-.437 1.955c-.334 1.446-.698 2.848-1.02 4.282l.14.286c3.76-.2 4.858-.2 8.076-.146l.389-.291c.564-3.36.717-4.258 1.774-9.146l.503-2.247c1.008-4.397 1.518-6.624.771-8.44c-.825-2.035-2.762-2.526-4.505-2.526c-1.155 0-3.273.278-5.156 1.208c-.673.352-1.348.758-2.01 1.166l.577-2.234l-.31-.378c-4.014.814-4.93.923-8.635 1.446l-.285.206c-.449 3.571-.814 6.254-2.41 13.275a884.37 884.37 0 0 1-1.871 7.779l.17.328c3.807-.2 4.943-.2 8.24-.146zm27.618.145c.236-1.154 1.64-7.99 1.652-7.99c0 0 1.195-5.017 1.269-5.199c0 0 .376-.522.752-.729h.553c5.222 0 11.119 0 15.74-3.4c3.145-2.332 5.295-5.775 6.254-9.96c.249-1.026.432-2.246.432-3.466c0-1.603-.321-3.189-1.251-4.428c-2.357-3.297-7.05-3.358-12.468-3.383l-2.67.025c-6.935.086-9.716.061-10.859-.079c-.096.505-.278 1.404-.278 1.404s-2.484 11.513-2.484 11.531l-6.225 25.632c6.055-.073 8.538-.073 9.583.042zm4.603-20.452s2.64-11.49 2.628-11.446l.086-.59l.037-.448l1.056.108s5.447.468 5.574.48c2.15.832 3.036 2.976 2.418 5.774c-.565 2.558-2.223 4.708-4.355 5.746c-1.755.88-3.905.953-6.12.953h-1.433l.109-.577zm16.444 9.905c-.698 2.975-1.5 8.41 3.473 10.347c1.586.674 3.007.875 4.45.802c1.526-.082 2.939-.847 4.248-1.948l-.355 1.359l.226.29c3.577-.15 4.687-.15 8.562-.12l.352-.268c.565-3.327 1.099-6.557 2.57-12.922c.716-3.048 1.431-6.067 2.166-9.103l-.115-.334c-4.001.741-5.07.9-8.92 1.445l-.292.238c-.039.31-.08.607-.117.904c-.598-.967-1.466-1.793-2.804-2.307c-1.712-.674-5.732.194-9.187 3.34c-2.429 2.247-3.595 5.325-4.257 8.277zm8.404.182c.857-3.668 1.84-6.77 4.39-6.77c1.612 0 2.461 1.487 2.288 4.024a129.1 129.1 0 0 1-.46 2.054c-.255 1.09-.531 2.17-.8 3.252c-.274.74-.593 1.438-.942 1.903c-.656.93-2.217 1.506-3.116 1.506c-.255 0-1.828 0-1.882-2.32c-.013-1.154.225-2.344.522-3.65zm43.886-12.109l-.31-.353c-3.959.802-4.676.93-8.313 1.421l-.268.267c-.012.044-.023.11-.042.171l-.012-.06c-2.708 6.248-2.629 4.9-4.833 9.818c-.013-.224-.013-.363-.025-.601l-.552-10.663l-.346-.353c-4.148.802-4.246.93-8.076 1.421l-.299.267c-.042.128-.042.268-.067.42l.025.055c.479 2.446.364 1.9.844 5.762c.224 1.895.523 3.801.746 5.673c.378 3.132.59 4.674 1.051 9.455c-2.586 4.268-3.199 5.884-5.69 9.63l.018.037l-1.754 2.774c-.2.292-.382.492-.637.578c-.28.138-.644.163-1.149.163h-.972l-1.444 4.804l4.955.085c2.908-.012 4.736-1.372 5.72-3.2l3.116-5.339h-.05l.328-.376c2.096-4.511 18.036-31.856 18.036-31.856zm-52.29 63.088h-2.102l7.78-25.73h2.58l.82-2.65l.078 2.947c-.096 1.822 1.337 3.437 5.102 3.17h4.355l1.498-4.954h-1.638c-.942 0-1.38-.238-1.325-.748l-.079-2.999h-8.063v.016c-2.607.054-10.393.25-11.969.67c-1.907.49-3.917 1.937-3.917 1.937l.79-2.654h-7.543l-1.572 5.265l-7.883 26.123h-1.53l-1.5 4.919h15.023l-.503 1.64h7.402l.492-1.64h2.076l1.628-5.312zm-6.164-20.502c-1.208.334-3.455 1.348-3.455 1.348l1.999-6.576h5.992l-1.445 4.791s-1.852.11-3.09.437zm.115 9.394s-1.882.237-3.121.516c-1.22.37-3.509 1.536-3.509 1.536l2.065-6.843h6.023l-1.458 4.791zm-3.358 11.168h-6.011l1.743-5.775h5.992l-1.724 5.775zm14.477-15.959h8.665l-1.245 4.033h-8.78l-1.318 4.408h7.683l-5.818 8.191c-.407.602-.772.815-1.178.984c-.407.207-.942.45-1.56.45h-2.132l-1.464 4.828h5.574c2.898 0 4.61-1.318 5.873-3.048l3.99-5.46l.856 5.544c.182 1.038.928 1.646 1.433 1.882c.558.28 1.135.76 1.95.832c.873.037 1.504.067 1.924.067h2.74l1.644-5.404h-1.08c-.62 0-1.689-.104-1.87-.298c-.183-.237-.183-.6-.28-1.154l-.87-5.556h-3.558l1.561-1.858h8.763l1.348-4.408h-8.113l1.263-4.033h8.089l1.5-4.973h-24.114l-1.476 4.973zm-73.185 17.082l2.022-6.728h8.313l1.518-5.004h-8.32l1.27-4.141h8.13l1.507-4.846h-20.343l-1.475 4.846h4.622l-1.233 4.14h-4.634l-1.536 5.09h4.62l-2.696 8.902c-.363 1.178.171 1.627.51 2.175c.347.533.698.886 1.488 1.086c.815.182 1.373.291 2.131.291h9.371l1.67-5.544l-4.154.571c-.802 0-3.024-.096-2.781-.838zm.953-32.208l-2.106 3.807c-.45.831-.857 1.348-1.222 1.585c-.322.2-.96.285-1.883.285h-1.099l-1.469 4.87h3.65c1.756 0 3.103-.643 3.747-.965c.692-.37.874-.159 1.408-.675l1.233-1.068h11.398l1.513-5.07h-8.344l1.457-2.77h-8.283zm16.827 32.306c-.194-.28-.054-.773.243-1.799l3.115-10.311h11.083c1.615-.023 2.78-.042 3.54-.096c.814-.086 1.7-.377 2.665-.899c.997-.547 1.507-1.124 1.937-1.786c.48-.66 1.252-2.107 1.914-4.336l3.916-13.049l-11.5.067s-3.542.522-5.101 1.1c-1.573.643-3.821 2.44-3.821 2.44l1.038-3.577h-7.104l-9.946 32.986c-.353 1.28-.59 2.21-.644 2.769c-.018.601.759 1.197 1.263 1.646c.595.449 1.475.376 2.319.449c.888.067 2.15.109 3.893.109h5.46l1.675-5.659l-4.887.462c-.523 0-.9-.28-1.058-.516zm5.368-19.074h11.64l-.74 2.319c-.103.054-.352-.115-1.537.025h-10.08l.717-2.344zm2.332-7.78h11.739l-.845 2.794s-5.532-.054-6.418.109c-3.9.675-6.177 2.758-6.177 2.758l1.701-5.66zm8.83 17.866c-.097.347-.25.558-.462.717c-.237.152-.62.206-1.19.206h-1.658l.098-2.824h-6.9l-.28 13.809c-.01.996.086 1.573.815 2.035c.73.576 2.976.65 6 .65h4.323l1.56-5.17l-3.763.207l-1.252.073c-.17-.073-.334-.14-.516-.321c-.158-.157-.426-.061-.382-1.057l.03-3.54l3.946-.163c2.132 0 3.043-.694 3.82-1.354c.741-.633.984-1.36 1.264-2.345l.662-3.134h-5.424l-.692 2.21z" fill="#FEFEFE"></path>'
724
+ },
725
+ visa: {
726
+ name: "Visa",
727
+ logo: '<g><rect width="48" height="32" rx="4" fill="#2A2A6C"/><path fill-rule="evenodd" clip-rule="evenodd" d="M30.35 17.67C30.3561 16.1453 29.0986 15.4867 28.1227 14.9756C27.5049 14.6521 27 14.3877 27 14C27 13.67 27.32 13.32 28 13.23C28.8093 13.1499 29.6251 13.2917 30.36 13.64L30.78 11.64C30.0636 11.3714 29.3051 11.2325 28.54 11.23C26.18 11.23 24.54 12.49 24.54 14.29C24.54 15.62 25.73 16.36 26.63 16.8C27.53 17.24 27.88 17.55 27.87 17.95C27.87 18.57 27.13 18.85 26.44 18.86C25.5889 18.871 24.749 18.6644 24 18.26L23.57 20.26C24.4175 20.5908 25.3203 20.7571 26.23 20.75C28.74 20.75 30.39 19.51 30.4 17.59L30.35 17.67ZM23.86 11.39L21.86 20.64H19.46L21.46 11.39H23.86ZM33.92 17.39L35.18 13.92L35.91 17.39H33.92ZM38.81 20.67H36.59L36.3 19.29H33.29L32.8 20.67H30.28L33.87 12.1C34.0355 11.6923 34.43 11.424 34.87 11.42H36.87L38.81 20.67ZM16.61 20.61L20.49 11.36H17.89L15.4 17.65L14.4 12.3C14.3115 11.7563 13.8408 11.3578 13.29 11.36H9.22L9.16 11.63C9.97634 11.7897 10.7693 12.0518 11.52 12.41C11.8398 12.5603 12.0564 12.8683 12.09 13.22L14 20.61H16.61Z" fill="white"/></g>'
728
+ },
729
+ default: {
730
+ name: "Credit Card",
731
+ logo: '<rect width="48" height="32" rx="4" fill="#D9D9DF"/><rect y="7" width="48" height="7" fill="#51516A"/>'
732
+ },
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>`;
735
+ return {
736
+ name: n.name,
737
+ logo: i
738
+ };
739
+ }
740
+ }, Dt = {
741
+ data() {
742
+ return {
743
+ stripeCardElementId: null,
744
+ stripe: window.$stripe,
745
+ // will house instance of Stripe object from Stripe JS API
746
+ elements: "",
747
+ // will house instance of Stripe Elements
748
+ elementsError: "",
749
+ // message for invalid input to Card Element
750
+ card: "",
751
+ // will be the object representation of the Card from Stripe Elements
752
+ cardIsComplete: !1
753
+ // Boolean if cart input is completed
754
+ };
755
+ },
756
+ created() {
757
+ this.$nextTick(() => {
758
+ this.elements = this.stripe.elements(), this.stripeCardElementId && this.configureStripeCard(this.stripeCardElementId);
759
+ });
760
+ },
761
+ beforeDestroy() {
762
+ this.card && (this.card.unmount(), this.card = null);
763
+ },
764
+ methods: {
765
+ mountCardInput() {
766
+ this.stripeCardElementId && this.callCard("mount", this.stripeCardElementId);
767
+ },
768
+ unmountCardInput() {
769
+ this.stripeCardElementId && this.callCard("unmount", this.stripeCardElementId);
770
+ },
771
+ callCard(r, t) {
772
+ this.card && typeof this.card[r] == "function" && this.card[r](t);
773
+ },
774
+ /**
775
+ * Start Stripe card component
776
+ * @param {String} elementId The id to mount card component, example #card-element
777
+ */
778
+ configureStripeCard(r) {
779
+ if (!r)
780
+ throw new Error("Missing required param elementId to install Stripe");
781
+ if (!this.elements)
782
+ throw new Error("Stripe is not yet configured");
783
+ const t = {
784
+ base: {
785
+ color: "#111",
786
+ fontFamily: 'Inter, "Helvetica Neue", Helvetica, sans-serif',
787
+ fontSmoothing: "antialiased",
788
+ fontSize: "18px",
789
+ "::placeholder": { color: "#808080" }
790
+ },
791
+ invalid: {
792
+ color: "#fa755a",
793
+ iconColor: "#fa755a"
794
+ }
795
+ };
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;
799
+ });
800
+ }
801
+ }
802
+ };
803
+ const Vt = {
804
+ i18nOptions: {
805
+ namespaces: "PremiumStripeForm",
806
+ messages: {
807
+ en: {
808
+ cardTitle: "Upgrade to {{plan,capitalize}}",
809
+ oneTimeFee: "One time fee",
810
+ plan: "Plan",
811
+ formSteps: "Step 2 of 2:",
812
+ formTitle: "Please enter your payment information.",
813
+ submitButton: "Upgrade to {{plan,capitalize}}",
814
+ paymentInfoLabel: "Enter payment information",
815
+ existingCustomerTitle: "Customer information",
816
+ existingCard: "Charges will be billed to the card ending in {{last4}}.",
817
+ changeCard: "Change card",
818
+ payYearly: "Pay yearly",
819
+ saveAmount: "Save 30%",
820
+ missingCard: "Please fill in your card details.",
821
+ promotion: {
822
+ add: "Promo code?",
823
+ placeholder: "Promotion code",
824
+ submit: "OK"
825
+ },
826
+ highlights: {
827
+ securePayment: "Secure card payment.",
828
+ satisfiedCustomer: "30 days satisfied customer guarantee."
829
+ },
830
+ quantity: {
831
+ label: "Number of licenses",
832
+ tooltip: "Number of members that can create & send documents.",
833
+ disabled: "Switch to <strong>Base</strong> or <strong>Pro</strong> to add more editors.",
834
+ required: "Enter number of licenses",
835
+ minValue: "Add a positive number"
836
+ },
837
+ name: {
838
+ label: "Company name",
839
+ placeholder: "Company name"
840
+ },
841
+ region: {
842
+ label: "Country",
843
+ placeholder: "Country"
844
+ },
845
+ email: {
846
+ label: "Send email receipts to",
847
+ placeholder: "Billing email",
848
+ email: "Invalid format, need to be: name@example.se"
849
+ },
850
+ faq: {
851
+ title: "FAQ",
852
+ items: [
853
+ {
854
+ title: "Can I try {{ brand }} before I purchase a plan?",
855
+ text: "Sure thing. When you sign up for a new account a free trial is automatically included."
856
+ },
857
+ {
858
+ title: "What does the number of licenses mean?",
859
+ text: "The number of licenses is the number of users inside your organization that will be able to create & send documents. You can always add more or decrease licenses later."
860
+ },
861
+ {
862
+ title: "How much does {{ brand }} cost?",
863
+ text: "{{ brand }} plans start at $15 for our Start plan and moves up for for our more advanced plans. We also provide a free plan which includes 2 documents per month."
864
+ },
865
+ {
866
+ title: "How many documents can I send?",
867
+ text: `
868
+ The number of documents you can send differs depending on your plan type.
869
+ Our Starter plan includes 5 documents every month.
870
+ With the Base & Pro plans we believe that how many documents you send for each month or year fluctuates. Looking at our historical data we know that 300 documents per user per year covers the needs for almost all of our users. Thus, the Pro-plan includes 300 documents per user per year. Monthly plans have a pro-rated monthly allowance. If you exceed your allowance an extra charge will occur.
871
+ `
872
+ },
873
+ {
874
+ title: "How do I cancel or downgrade my plan?",
875
+ text: "You can cancel your subscription at anytime via your account settings or contact us at our support chat."
876
+ },
877
+ {
878
+ title: "Do you offer refunds?",
879
+ text: "We offer a 30 days satisfied customer guarantee. This offer is available for all new customers and can only be used one time per person or entity and is only applicable when purchasing an annual plan. Month-to-month plans are not eligible for this offer."
880
+ }
881
+ ]
882
+ },
883
+ reasonableUse: {
884
+ title: "Reasonable Use Policy",
885
+ text: `
886
+ At {{brand}} we encourage our users to make full use of our functionality to benefit their business. However, we strive to offer a service that is high quality. This in turn comes with certain operating costs. To make {{ brand}} fit all types of customers we've decided to include a quota that covers the needs of almost all of our users. If you however were to exceed this quota, you will be charged accordingly to the following prices:
887
+ `,
888
+ document: "Documents",
889
+ sms: "SMS",
890
+ bankId: "BankId signatures",
891
+ apiDocument: "API-documents",
892
+ quotaIncluded: "Each month includes a quota of {{count}} per license.",
893
+ quotaExtra: "The cost for each additional one above your quota is {{cost}}."
894
+ }
895
+ },
896
+ sv: {
897
+ cardTitle: "Uppgradera till {{plan,capitalize}}",
898
+ oneTimeFee: "Engångskostnad",
899
+ plan: "Plan",
900
+ formSteps: "Steg 2 av 2:",
901
+ formTitle: "Vänligen ange betalningsuppgifter.",
902
+ submitButton: "Uppgradera till {{plan,capitalize}}",
903
+ paymentInfoLabel: "Ange betalningsuppgifter",
904
+ existingCustomerTitle: "Kundinformation",
905
+ existingCard: "Utdraget kommer dras från kortet som slutar med {{last4}}.",
906
+ changeCard: "Byt kort",
907
+ payYearly: "Betala årsvis",
908
+ saveAmount: "Spara 30%",
909
+ missingCard: "Fyll i dina kortuppgifter.",
910
+ promotion: {
911
+ add: "Rabattkod?",
912
+ placeholder: "Ange rabattkod",
913
+ submit: "OK"
914
+ },
915
+ highlights: {
916
+ securePayment: "Säker kortbetalning.",
917
+ satisfiedCustomer: "30 dagar nöjdkund-garanti."
918
+ },
919
+ quantity: {
920
+ label: "Välj antal licenser",
921
+ tooltip: "Antal medlemmar som ska kunna skapa & skicka dokument.",
922
+ disabled: "Byt till <strong>Base</strong> eller <strong>Pro</strong> för att lägga till fler licenser.",
923
+ required: "Ange antal licenser",
924
+ minValue: "Ange ett positivt tal"
925
+ },
926
+ name: {
927
+ label: "Företagsnamn",
928
+ placeholder: "Företagsnamn"
929
+ },
930
+ region: {
931
+ label: "Land",
932
+ placeholder: "Land"
933
+ },
934
+ email: {
935
+ label: "Skicka kvitton till",
936
+ placeholder: "E-post",
937
+ email: "Ogitlitgt format, se ex. namn@exempel.se"
938
+ },
939
+ faq: {
940
+ title: "Vanliga frågor",
941
+ items: [
942
+ {
943
+ title: "Kan jag testa {{ brand }} innan jag köper ett paket?",
944
+ text: "Självklart. När du registerar ett konto så inkluderas en gratis testperiod automatiskt."
945
+ },
946
+ {
947
+ title: "Vad betyder antalet licenser?",
948
+ text: "Antalet licenser är antalet användare i din organisation som kan skapa & skicka dokument. Du kan alltid lägga till fler eller ta bort licenser senare."
949
+ },
950
+ {
951
+ title: "Hur mycket kostar {{ brand }}?",
952
+ text: "Våra priser börjar från 190kr i månaden för vårt Start-paket och ökar i pris när man kommer till våra mer avancerade paket. Vi erbjuder dessutom ett gratis paket som inkluderar 2 st dokument per månad."
953
+ },
954
+ {
955
+ title: "Hur många dokument kan jag skicka?",
956
+ text: `
957
+ Antalet dokument du kan skicka skiljer sig beroende på vilket paket du har.
958
+ Vårt Start-paket innehåller 5 dokument per månad.
959
+ Med Base & Pro så är vi medvetna om att mängden dokument man skickar fluktuerar för varje månad eller år. Med det sagt så har vi historiskt sett från våra användare att 300 st dokument per år täcker nästan alla våra användares behov. Därför så inkluderar Pro-paketet 300 st dokument per användare per år. Månadsabbonemang har en pro-rata vägd begränsning. Om du överstiger din månadskvot kommer en extra avgift att debiteras.
960
+ `
961
+ },
962
+ {
963
+ title: "Hur avslutar jag eller nedgraderar jag mitt konto?",
964
+ text: "Du kan avsluta ditt abonnemang närsomhelst genom att gå till dina kontoinställningar eller kontakta oss på supporten via vår chat."
965
+ },
966
+ {
967
+ title: "Erbjuder ni returer?",
968
+ text: "Vi erbjuder en 30 dagar nöjd kundgaranti. Detta erbjudande är tillgängligt för alla nya kunder och kan endast användas enbart en gång per företagskonto och gäller endast om du köper ett årsabonnemang. Erbjudandet erbjuds inte till månadsabonnemang."
969
+ }
970
+ ]
971
+ },
972
+ reasonableUse: {
973
+ title: "Rimlig användningspolicy",
974
+ text: `
975
+ På {{brand}} så uppmuntrar vi våra kunder att ta del av hela vårt tjänsteutbud för att främja deras företag. Däremot, så har {{brand}} en strävan av att erbjuda en sån hög kvalité som möjligt som i sin tur bär med sig kostnader för drift och underhåll. För att vi ska kunna erbjuda en hög kvalitet på våra tjänster till alla typer av företag; så har vi valt att erbjuda en kvot som ingår i varje paket. Kvoten är satt så att den täcker in nästan alla våra användarens behov. Om du däremot skulle komma över din kvot så kommer du att bli debiterad enligt följande prislista:
976
+ `,
977
+ document: "Dokument",
978
+ sms: "SMS",
979
+ bankId: "BankId-signeringar",
980
+ apiDocument: "API-dokument",
981
+ quotaIncluded: "Varje månad inkluderar en kvot om {{ count }} st per licens.",
982
+ quotaExtra: "Överskrider du din kvot så tillkommer en styckkostnad om {{ cost }}."
983
+ }
984
+ }
985
+ }
986
+ },
987
+ name: "PremiumStripeForm",
988
+ components: {
989
+ CAccordion: Lt
990
+ },
991
+ mixins: [Dt],
992
+ props: {
993
+ formPlan: {
994
+ type: Object,
995
+ required: !0
996
+ },
997
+ uiPlan: {
998
+ type: Object,
999
+ required: !0
1000
+ }
1001
+ },
1002
+ data() {
1003
+ return {
1004
+ regions: A,
1005
+ cardBrands: Tt,
1006
+ stripeCardElementId: "#card-element",
1007
+ promoInputVisible: !1,
1008
+ inputPromotionCode: "",
1009
+ isEditLock: !1,
1010
+ isInvalidPromotionCode: !1,
1011
+ useExistingCard: !1,
1012
+ useExistingCustomer: !1
1013
+ };
1014
+ },
1015
+ validations() {
1016
+ return {
1017
+ formCustomer: {
1018
+ email: {
1019
+ email: P.email
1020
+ }
1021
+ },
1022
+ quantity: {
1023
+ required: P.required,
1024
+ minValue: P.minValue(1),
1025
+ numeric: P.numeric
1026
+ }
1027
+ };
1028
+ },
1029
+ computed: {
1030
+ ...h({
1031
+ companyRegion: "application/companyRegion",
1032
+ companyAccount: "application/companyAccount",
1033
+ formCustomer: "stripe/formCustomer",
1034
+ promotion: "stripe/formPromotion",
1035
+ customer: "stripe/customer",
1036
+ isPosting: "stripe/isPosting",
1037
+ formError: "stripe/formError",
1038
+ getMeteredProduct: "stripe/getMeteredProduct",
1039
+ formPrices: "stripe/formPrices"
1040
+ }),
1041
+ messages() {
1042
+ return {
1043
+ email: {
1044
+ email: this.$t("email.email")
1045
+ },
1046
+ quantity: {
1047
+ required: this.$t("quantity.required"),
1048
+ minValue: this.$t("quantity.minValue")
1049
+ }
1050
+ };
1051
+ },
1052
+ quantity: {
1053
+ get() {
1054
+ return this.formPlan.quantity;
1055
+ },
1056
+ set(r) {
1057
+ this.$emit("input", { key: "plan.quantity", value: r });
1058
+ }
1059
+ },
1060
+ routePromo() {
1061
+ return this.$route.query.promoCode;
1062
+ },
1063
+ // promoCode from url
1064
+ existingCardLast4() {
1065
+ var r;
1066
+ return (r = this.customer) == null ? void 0 : r.paymentMethodLast4;
1067
+ },
1068
+ sortedRegions() {
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));
1070
+ },
1071
+ currency() {
1072
+ return this.formPrices.currency;
1073
+ },
1074
+ promotionDescription() {
1075
+ let r = "- ";
1076
+ const { amountOff: t, percentOff: e } = this.promotion || {};
1077
+ return t ? r += y(t, { currency: this.currency }) : e && (r += `${e}%`), r;
1078
+ },
1079
+ reasonableUseQuotas() {
1080
+ var i;
1081
+ const r = {}, t = (i = this.formPlan) == null ? void 0 : i.StripeProduct;
1082
+ if (!t)
1083
+ return [];
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,
1089
+ cost: null
1090
+ });
1091
+ }), n.forEach((s) => {
1092
+ if (s === "bankId" && E[H.brand].defaultRegion === "US")
1093
+ return;
1094
+ const l = this.getMeteredProduct(s);
1095
+ if (!l)
1096
+ return;
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;
1100
+ });
1101
+ if (!o)
1102
+ return;
1103
+ const c = y(o.amount, {
1104
+ currency: o.currency,
1105
+ decimals: 2,
1106
+ hideZeroDecimals: !0
1107
+ });
1108
+ r[s] || (r[s] = { type: s, count: 0, cost: null }), r[s].cost = c;
1109
+ }), Object.keys(r).map((s) => r[s]);
1110
+ }
1111
+ },
1112
+ watch: {
1113
+ useExistingCard(r) {
1114
+ this.$nextTick(() => {
1115
+ r ? this.unmountCardInput() : this.mountCardInput();
1116
+ });
1117
+ }
1118
+ },
1119
+ async created() {
1120
+ if (this.$nextTick(() => {
1121
+ u({
1122
+ targets: ".anime-payment-modal .anim-block",
1123
+ translateX: [50, 0],
1124
+ opacity: [0, 1],
1125
+ delay: u.stagger(100),
1126
+ easing: "spring(1, 80, 20, 10)"
1127
+ });
1128
+ }), this.customer) {
1129
+ this.useExistingCard = !0, this.useExistingCustomer = !0, ["name", "region", "email"].forEach((t) => {
1130
+ this.customer[t] && this.$emit("input", { key: `customer.${t}`, value: this.customer[t] });
1131
+ });
1132
+ const { data: r } = await _();
1133
+ this.setPromotion({ promotionDetails: r });
1134
+ }
1135
+ this.companyRegion === "SE" && !this.formCustomer.region && this.$emit("input", { key: "customer.region", value: this.companyRegion }), this.routePromo && this.verifyPromotionCode(this.routePromo);
1136
+ },
1137
+ methods: {
1138
+ ...k({
1139
+ usePromotionCode: p.SUBMIT_PROMOTION_CODE,
1140
+ setPromotion: p.SET_FORM_PROMOTION,
1141
+ submitPlan: p.SUBMIT_FORM_PLAN
1142
+ }),
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;
1146
+ },
1147
+ async submit() {
1148
+ if (this.$v.$touch(), this.$v.$invalid)
1149
+ return;
1150
+ if (!this.useExistingCard && !this.cardIsComplete) {
1151
+ this.elementsError = this.$t("missingCard");
1152
+ return;
1153
+ }
1154
+ await this.submitPlan({ ...!this.useExistingCard && { cardElement: this.card } }) && this.$emit("success");
1155
+ },
1156
+ async verifyPromotionCode(r) {
1157
+ if (!r) {
1158
+ this.promoInputVisible = !1;
1159
+ return;
1160
+ }
1161
+ this.isInvalidPromotionCode = !1, await this.usePromotionCode(r) ? (this.promoInputVisible = !1, this.inputPromotionCode = "") : this.isInvalidPromotionCode = !0;
1162
+ }
1163
+ }
1164
+ };
1165
+ var Et = function() {
1166
+ var t = this, e = t._self._c;
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) {
1168
+ return t.$emit("update:interval", t.formPlan.interval === "year" ? "month" : "year");
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 })))])]);
1172
+ })], 2);
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) {
1174
+ return t.$emit("input", { key: "promotion", value: null });
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) {
1176
+ return t.verifyPromotionCode(t.inputPromotionCode);
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) {
1182
+ return t.verifyPromotionCode(t.inputPromotionCode);
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) {
1184
+ t.promoInputVisible = !0;
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) {
1186
+ return t.$modal.show("reasonableUse");
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) {
1188
+ return t.$modal.show("faq");
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: `
1190
+ uiPlan.accountType === 'start'
1191
+ ? { content: $t('quantity.disabled') }
1192
+ : ''
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) {
1196
+ t.quantity--;
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) {
1198
+ t.quantity++;
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) {
1200
+ t.useExistingCustomer = !1;
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) {
1202
+ t.useExistingCard = !1;
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()]);
1217
+ }), 0)])])], 1);
1218
+ }, Ot = [], Qt = /* @__PURE__ */ d(
1219
+ Vt,
1220
+ Et,
1221
+ Ot,
1222
+ !1,
1223
+ null,
1224
+ "b5b143cd",
1225
+ null,
1226
+ null
1227
+ );
1228
+ const qt = Qt.exports, Jt = "", Ut = "", Xt = "", Ft = {
1229
+ name: "PremiumStripe",
1230
+ i18nOptions: {
1231
+ namespaces: "PremiumStripe",
1232
+ messages: {
1233
+ en: {
1234
+ callout: {
1235
+ legacy: {
1236
+ title: "Update your account plan",
1237
+ text: `
1238
+ We've updated our account plans. You'll have to update your old account plan to our new ones.
1239
+ You'll <span style="font-weight: 600;">only</span> have the new subscription active after the switch.
1240
+ Your old subscription will get replaced.
1241
+ `
1242
+ },
1243
+ invoice: {
1244
+ title: "Change to card payment",
1245
+ text: `
1246
+ Replace your current payment method to card.
1247
+ You'll <span style="font-weight: 600;">only</span> have the new subscription active after the switch.
1248
+ Your old subscription will get replaced.
1249
+ `
1250
+ }
1251
+ },
1252
+ features: {
1253
+ start: {
1254
+ singleUser: "Single user only",
1255
+ documents: "Send up to 5 docs / month",
1256
+ templates: "Up to 2 templates",
1257
+ auditTrail: "Real-time audit trail",
1258
+ bankId: "BankId",
1259
+ sms: "SMS"
1260
+ },
1261
+ base: {
1262
+ eSign: "Send documents for eSignature",
1263
+ templates: "Up to 5 templates",
1264
+ zapier: "Zapier integration",
1265
+ members: "Members",
1266
+ reminders: "Reminders",
1267
+ auditTrail: "Real-time audit trail",
1268
+ bankId: "BankId",
1269
+ sms: "SMS"
1270
+ },
1271
+ pro: {
1272
+ allBefore: "Everything in Base",
1273
+ statistics: "Statistics",
1274
+ templates: "Unlimited templates",
1275
+ api: "API",
1276
+ roles: "User roles",
1277
+ signOrder: "Signing order",
1278
+ subdomain: "Custom subdomain",
1279
+ emailDomain: "Custom email address",
1280
+ versions: "Version control",
1281
+ hideLogo: "Hide {{brand,capitalize}}-logo",
1282
+ crms: "CRM integrations"
1283
+ }
1284
+ },
1285
+ success: {
1286
+ title: "Congratulations!",
1287
+ subTitle: "Your account have been upgraded.",
1288
+ subTitleEdit: "Your plan has been updated.",
1289
+ closeButton: "Continue where you were"
1290
+ }
1291
+ },
1292
+ sv: {
1293
+ callout: {
1294
+ legacy: {
1295
+ title: "Uppdatera din kontoplan",
1296
+ text: `
1297
+ Vi har uppdaterat våra kontoplaner. Du behöver uppdatera till våra nya planer.
1298
+ Du kommer <span style="font-weight: 600;">enbart</span> ha det nya abonnemanget aktivt efter bytet.
1299
+ Ditt gamla abonemmang kommer att ersättas.
1300
+ `
1301
+ },
1302
+ invoice: {
1303
+ title: "Byt till kortbetalning",
1304
+ text: `
1305
+ Ersätt din betalmetod till kortbetalning.
1306
+ Du kommer <span style="font-weight: 600;">enbart</span> ha det nya abonnemanget aktivt efter bytet.
1307
+ Ditt gamla abonemmang kommer att ersättas.
1308
+ `
1309
+ }
1310
+ },
1311
+ features: {
1312
+ start: {
1313
+ singleUser: "Endast en användare",
1314
+ documents: "Skicka upp till 5 dokument / månad",
1315
+ templates: "Upp till 2 mallar",
1316
+ auditTrail: "Dokumentspårning i realtid",
1317
+ bankId: "BankId",
1318
+ sms: "SMS"
1319
+ },
1320
+ base: {
1321
+ eSign: "Skicka dokument för e-signering",
1322
+ templates: "Upp till 5 mallar",
1323
+ zapier: "Zapier-integration",
1324
+ members: "Medlemmar",
1325
+ reminders: "Påminnelser",
1326
+ auditTrail: "Dokumentspårning i realtid",
1327
+ bankId: "BankId",
1328
+ sms: "SMS"
1329
+ },
1330
+ pro: {
1331
+ allBefore: "Allt i Base",
1332
+ statistics: "Statistik",
1333
+ templates: "Obegränsat med mallar",
1334
+ api: "API",
1335
+ roles: "Roller för medlemmar",
1336
+ signOrder: "Signeringsordning",
1337
+ subdomain: "Subdomän",
1338
+ emailDomain: "Egen e-postdomän",
1339
+ versions: "Versionshantering",
1340
+ hideLogo: "Göm {{brand,capitalize}}-logo",
1341
+ crms: "CRM-Integrationer"
1342
+ }
1343
+ },
1344
+ success: {
1345
+ title: "Grattis!",
1346
+ subTitle: "Ditt konto har nu uppgraderats.",
1347
+ subTitleEdit: "Din betalningsplan har uppdaterats.",
1348
+ closeButton: "Fortsätt där du var"
1349
+ }
1350
+ }
1351
+ }
1352
+ },
1353
+ components: {
1354
+ Confetti: At,
1355
+ PremiumStripeSelect: wt,
1356
+ PremiumStripeForm: qt
1357
+ },
1358
+ props: {
1359
+ suggestedQuantity: {
1360
+ type: Number,
1361
+ required: !1,
1362
+ default: null
1363
+ },
1364
+ onUpgrade: {
1365
+ type: Function,
1366
+ default: () => null
1367
+ }
1368
+ },
1369
+ data() {
1370
+ return {
1371
+ view: "select",
1372
+ animateConfetti: !0,
1373
+ isEdit: !1
1374
+ };
1375
+ },
1376
+ computed: {
1377
+ ...st({
1378
+ forceShowBase: (r) => r.route.query.base,
1379
+ routeDeal: (r) => r.route.query.deal
1380
+ }),
1381
+ ...h({
1382
+ accountType: "application/companyAccountType",
1383
+ subscription: "application/subscription",
1384
+ formPlan: "stripe/formPlan",
1385
+ formProducts: "stripe/formProducts",
1386
+ currentPlan: "stripe/currentPlan",
1387
+ subscriptions: "stripe/subscriptions",
1388
+ subscriptionItems: "stripe/subscriptionItems",
1389
+ getProductByPriceId: "stripe/getProductByPriceId",
1390
+ stripeCustomDealToken: "settings/stripeCustomDealToken"
1391
+ }),
1392
+ quantity: {
1393
+ get() {
1394
+ var r;
1395
+ return (r = this.formPlan) == null ? void 0 : r.quantity;
1396
+ },
1397
+ set(r) {
1398
+ this.setFormValue({ key: "plan.quantity", value: r });
1399
+ }
1400
+ },
1401
+ plan: {
1402
+ get() {
1403
+ var r;
1404
+ return (r = this.formPlan) == null ? void 0 : r.accountType;
1405
+ },
1406
+ set(r) {
1407
+ this.setFormValue({ key: "plan.accountType", value: r });
1408
+ }
1409
+ },
1410
+ interval: {
1411
+ get() {
1412
+ var r;
1413
+ return (r = this.formPlan) == null ? void 0 : r.interval;
1414
+ },
1415
+ set(r) {
1416
+ this.setFormValue({ key: "plan.interval", value: r });
1417
+ }
1418
+ },
1419
+ dealSource: {
1420
+ get() {
1421
+ return this.formDealSource;
1422
+ },
1423
+ set(r) {
1424
+ this.setFormValue({ key: "dealSource", value: r });
1425
+ }
1426
+ },
1427
+ prettyPlans() {
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;
1431
+ };
1432
+ return t && r.push({
1433
+ name: "Start",
1434
+ accountType: "start",
1435
+ img: Xt,
1436
+ features: [
1437
+ this.$t("features.start.singleUser"),
1438
+ this.$t("features.start.documents"),
1439
+ this.$t("features.start.templates"),
1440
+ this.$t("features.start.auditTrail"),
1441
+ ...O.checkFeature("bankId") ? [this.$t("features.start.bankId")] : [],
1442
+ this.$t("features.start.sms")
1443
+ ]
1444
+ }), e() && r.push({
1445
+ name: "Base",
1446
+ accountType: "base",
1447
+ img: Ut,
1448
+ features: [
1449
+ this.$t("features.base.eSign"),
1450
+ this.$t("features.base.templates"),
1451
+ this.$t("features.base.zapier"),
1452
+ this.$t("features.base.members"),
1453
+ this.$t("features.base.reminders"),
1454
+ this.$t("features.base.auditTrail"),
1455
+ ...O.checkFeature("bankId") ? [this.$t("features.base.bankId")] : [],
1456
+ this.$t("features.base.sms")
1457
+ ]
1458
+ }), r.push({
1459
+ name: "Pro",
1460
+ accountType: "pro",
1461
+ img: Jt,
1462
+ features: [
1463
+ this.$t("features.pro.allBefore"),
1464
+ this.$t("features.pro.statistics"),
1465
+ this.$t("features.pro.templates"),
1466
+ this.$t("features.pro.api"),
1467
+ this.$t("features.pro.roles"),
1468
+ this.$t("features.pro.signOrder"),
1469
+ this.$t("features.pro.subdomain"),
1470
+ this.$t("features.pro.emailDomain"),
1471
+ this.$t("features.pro.versions"),
1472
+ this.$t("features.pro.hideLogo", { brand: this.$t("_common:brand.name") }),
1473
+ this.$t("features.pro.crms")
1474
+ ]
1475
+ }), r;
1476
+ },
1477
+ calloutMode() {
1478
+ return this.subscription.showCalloutConvertStripe ? "invoice" : this.subscription.isStripeLegacy ? "legacy" : null;
1479
+ }
1480
+ },
1481
+ beforeCreate() {
1482
+ this.$store.state.stripe || this.$store.registerModule("stripe", j);
1483
+ },
1484
+ async created() {
1485
+ this.resetStripeForm(), await this.loadPrices(), await this.suggestQuantity(), await this.handlePossibleDeal(), this.isEdit = !!this.subscriptions.length;
1486
+ },
1487
+ methods: {
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
1493
+ }),
1494
+ // Suggest quantity of licenses based on property or from account
1495
+ async suggestQuantity() {
1496
+ if (this.plan === "start")
1497
+ return;
1498
+ if (this.suggestedQuantity && typeof this.suggestedQuantity == "number") {
1499
+ this.quantity = this.suggestedQuantity;
1500
+ return;
1501
+ }
1502
+ const { data: r } = await $();
1503
+ this.quantity = r;
1504
+ },
1505
+ onReset() {
1506
+ this.view = "select", this.resetStripeForm();
1507
+ },
1508
+ goToSuccess() {
1509
+ this.view = "success", this.$nextTick(() => {
1510
+ u({
1511
+ targets: ".anime-payment-modal .success-block",
1512
+ translateY: [50, 0],
1513
+ opacity: [0, 1],
1514
+ delay: u.stagger(100, { start: 500 }),
1515
+ easing: "spring(1, 80, 15, 0)"
1516
+ });
1517
+ }), this.removePossibleDealToken(), setTimeout(() => {
1518
+ this.animateConfetti = !1;
1519
+ }, 3e3);
1520
+ },
1521
+ closeAndContinue() {
1522
+ this.$emit("close"), typeof this.onUpgrade == "function" && this.onUpgrade();
1523
+ },
1524
+ handlePossibleDeal() {
1525
+ this.routeDeal ? this.setFromDealToken(this.routeDeal) : this.stripeCustomDealToken && this.setFromDealToken(this.stripeCustomDealToken);
1526
+ },
1527
+ removePossibleDealToken() {
1528
+ if (this.routeDeal) {
1529
+ const r = { ...this.$route.query };
1530
+ delete r.deal, this.$router.replace({ ...this.$route, query: r });
1531
+ } else
1532
+ this.stripeCustomDealToken && this.updateSettings({
1533
+ key: "company",
1534
+ settings: { stripeCustomDealToken: null }
1535
+ });
1536
+ },
1537
+ setFromDealToken(r) {
1538
+ if (r)
1539
+ try {
1540
+ const t = tt(r);
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) {
1542
+ const e = [];
1543
+ Object.keys(t.items).forEach((n) => {
1544
+ const a = this.getProductByPriceId(n);
1545
+ a && e.push({ ...a, quantity: t.items[n] });
1546
+ }), e.length && this.setFormValue({
1547
+ key: "products",
1548
+ value: [
1549
+ // ...this.formProducts,
1550
+ ...e
1551
+ ]
1552
+ });
1553
+ }
1554
+ this.view = "form";
1555
+ } catch (t) {
1556
+ console.error(t);
1557
+ }
1558
+ }
1559
+ }
1560
+ };
1561
+ var Mt = function() {
1562
+ var t = this, e = t._self._c;
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) {
1564
+ return t.$emit("close");
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) {
1570
+ t.view = "form";
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) {
1574
+ return t.closeAndContinue();
1575
+ } } }, [t._v(t._s(t.$t("success.closeButton")))])], 1) : t._e()], 1)]);
1576
+ }, Rt = [], jt = /* @__PURE__ */ d(
1577
+ Ft,
1578
+ Mt,
1579
+ Rt,
1580
+ !1,
1581
+ null,
1582
+ null,
1583
+ null,
1584
+ null
1585
+ );
1586
+ const zt = jt.exports, Nt = {
1587
+ name: "IsPremium",
1588
+ computed: {
1589
+ ...h({
1590
+ subscription: "application/subscription",
1591
+ companyAccount: "application/companyAccount",
1592
+ stripeCustomDealToken: "settings/stripeCustomDealToken"
1593
+ }),
1594
+ isPremium() {
1595
+ return Q.includes(this.subscription.type);
1596
+ },
1597
+ isPremiumLike() {
1598
+ return ["trial", ...Q].includes(this.subscription.type);
1599
+ },
1600
+ isProLike() {
1601
+ return ["pro", "trial"].includes(this.subscription.type);
1602
+ },
1603
+ allowPremiumFeatures() {
1604
+ return !0;
1605
+ },
1606
+ canCreateDocument() {
1607
+ return this.subscription.freeDocumentsLeft > 0 || v(this.companyAccount, "documentQuota.priceExtra.value") !== null;
1608
+ },
1609
+ openSubscription() {
1610
+ return "openSubscription" in this.$route.query;
1611
+ }
1612
+ // Route query if subscription modal should be opened (the query just have to be specified, value does not matter)
1613
+ },
1614
+ created() {
1615
+ if (this.openSubscription) {
1616
+ const r = { ...this.$route.query };
1617
+ delete r.openSubscription, this.$router.replace({ ...this.$route, query: r }), this.openUpgradeModal();
1618
+ } else
1619
+ this.stripeCustomDealToken && this.openUpgradeModal();
1620
+ },
1621
+ methods: {
1622
+ /**
1623
+ * Open upgrade to premium modal
1624
+ * @param {Object} obj Optional
1625
+ * @param {Number} obj.suggestedQuantity Optional license quantity to suggest
1626
+ * @param {Function} obj.callback Optional callback to run after upgrade
1627
+ * @param {Function} obj.onClosed Optional callback to run after Stripe modal is closed
1628
+ */
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,
1633
+ {
1634
+ suggestedQuantity: r,
1635
+ onUpgrade: n
1636
+ },
1637
+ {
1638
+ adaptive: !0,
1639
+ // maxWidth: 500,
1640
+ // height: 'auto',
1641
+ width: "100%",
1642
+ height: "100%",
1643
+ // scrollable: true,
1644
+ classes: "overflow-visible primary"
1645
+ },
1646
+ {
1647
+ closed: () => {
1648
+ typeof a == "function" && a();
1649
+ }
1650
+ }
1651
+ );
1652
+ }
1653
+ },
1654
+ render() {
1655
+ return this.$scopedSlots.default ? this.$scopedSlots.default({
1656
+ isPremium: this.isPremium,
1657
+ isPremiumLike: this.isPremiumLike,
1658
+ isProLike: this.isProLike,
1659
+ isLegacy: this.subscription.isStripeLegacy,
1660
+ showCalloutConvertStripe: this.subscription.showCalloutConvertStripe,
1661
+ allowPremiumFeatures: this.allowPremiumFeatures,
1662
+ openUpgradeModal: this.openUpgradeModal,
1663
+ accountType: this.subscription.type,
1664
+ freeDocumentsLeft: this.subscription.freeDocumentsLeft,
1665
+ trialDaysLeft: this.subscription.trialDaysLeft,
1666
+ maxProjectManagers: this.subscription.maxProjectManagers,
1667
+ canCreateDocument: this.canCreateDocument
1668
+ }) : {};
1669
+ }
1670
+ }, Gt = null, Wt = null;
1671
+ var Kt = /* @__PURE__ */ d(
1672
+ Nt,
1673
+ Gt,
1674
+ Wt,
1675
+ !1,
1676
+ null,
1677
+ null,
1678
+ null,
1679
+ null
1680
+ );
1681
+ const Zt = Kt.exports, Yt = {
1682
+ name: "CalloutLegacy",
1683
+ i18nOptions: {
1684
+ namespaces: "components",
1685
+ messages: {
1686
+ sv: {
1687
+ legacy: {
1688
+ title: "Du har en gammal kontoplan",
1689
+ text: `
1690
+ Den här funktionen är enbart tillgänglig på våra uppdaterade kontoplaner.
1691
+ För att gå vidare måste du först byta till de uppdaterade kontoplanerna.
1692
+ `,
1693
+ action: "Gå till inställningar"
1694
+ },
1695
+ invoice: {
1696
+ title: "Byt till kortbetalning",
1697
+ text: `
1698
+ För att gå vidare måste du byta till att använda kortbetalning.
1699
+ Din betalningsmetod är just nu faktura.
1700
+ `,
1701
+ action: "Gå till inställningar"
1702
+ }
1703
+ },
1704
+ en: {
1705
+ legacy: {
1706
+ title: "Your account plan is outdated",
1707
+ text: `
1708
+ This feature is now only available on our updated account plans.
1709
+ To continue you must first convert your account to the updated account plans.
1710
+ `,
1711
+ action: "Go to settings"
1712
+ },
1713
+ invoice: {
1714
+ title: "Change to card",
1715
+ text: `
1716
+ To continue you must change your payment method to card. You're currently using invoice as a payment method.
1717
+ `,
1718
+ action: "Go to settings"
1719
+ }
1720
+ }
1721
+ }
1722
+ },
1723
+ props: {
1724
+ mode: {
1725
+ type: String,
1726
+ default: "legacy",
1727
+ validator: (r) => ["legacy", "invoice"].includes(r)
1728
+ }
1729
+ }
1730
+ };
1731
+ var _t = function() {
1732
+ var t = this, e = t._self._c;
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,
1738
+ !1,
1739
+ null,
1740
+ null,
1741
+ null,
1742
+ null
1743
+ );
1744
+ const ee = te.exports;
1745
+ const re = {
1746
+ i18nOptions: {
1747
+ namespaces: "components",
1748
+ messages: {
1749
+ sv: {
1750
+ badge: {
1751
+ premium: "Base & Pro",
1752
+ pro: "Pro only"
1753
+ },
1754
+ upgradeButton: "Uppgradera nu",
1755
+ cancelButton: "Nej, tack"
1756
+ },
1757
+ en: {
1758
+ badge: {
1759
+ premium: "Base & Pro",
1760
+ pro: "Pro only"
1761
+ },
1762
+ upgradeButton: "Upgrade now",
1763
+ cancelButton: "No thanks"
1764
+ }
1765
+ }
1766
+ },
1767
+ name: "PremiumRestrictedBase",
1768
+ components: {
1769
+ IsPremium: Zt,
1770
+ CalloutLegacy: ee
1771
+ },
1772
+ props: {
1773
+ plan: {
1774
+ type: String,
1775
+ default: "pro",
1776
+ validator: (r) => ["pro", "premium"].includes(r)
1777
+ },
1778
+ title: {
1779
+ type: String,
1780
+ default: ""
1781
+ },
1782
+ subTitle: {
1783
+ type: String,
1784
+ default: ""
1785
+ },
1786
+ badgeText: {
1787
+ type: String,
1788
+ default: ""
1789
+ },
1790
+ onUpgrade: {
1791
+ type: Function,
1792
+ default: null
1793
+ },
1794
+ actionFunction: {
1795
+ type: Function,
1796
+ default: null
1797
+ }
1798
+ },
1799
+ data() {
1800
+ return {
1801
+ isLoading: !1
1802
+ };
1803
+ },
1804
+ methods: {
1805
+ async onActionClick(r) {
1806
+ try {
1807
+ this.isLoading = !0, await r({ callback: this.onUpgrade }), this.$parent.$emit("close");
1808
+ } catch (t) {
1809
+ throw t;
1810
+ } finally {
1811
+ this.isLoading = !1;
1812
+ }
1813
+ }
1814
+ }
1815
+ };
1816
+ var ne = function() {
1817
+ var t = this, e = t._self._c;
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() {
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))])];
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);
1823
+ } } }, [t._t("actionText", function() {
1824
+ return [t._v(t._s(t.$t("upgradeButton")))];
1825
+ })], 2)], 1)];
1826
+ } }], null, !0) }), e("div", { staticStyle: { "margin-top": "5px" } }, [e("CButton", { attrs: { type: "none", pattern: "tertiary", wide: "" }, on: { click: function(n) {
1827
+ return t.$parent.$emit("close");
1828
+ } } }, [t._v(" " + t._s(t.$t("cancelButton")) + " ")])], 1)], 1)])]);
1829
+ }, ae = [], se = /* @__PURE__ */ d(
1830
+ re,
1831
+ ne,
1832
+ ae,
1833
+ !1,
1834
+ null,
1835
+ "993cb5cc",
1836
+ null,
1837
+ null
1838
+ );
1839
+ const g = se.exports, ie = {
1840
+ i18nOptions: {
1841
+ namespaces: "winProfile",
1842
+ keyPrefix: "account.subscription.winProfile",
1843
+ messages: {
1844
+ sv: {
1845
+ // TODO REMOVE ?
1846
+ title: "Designa din profil",
1847
+ subTitle: "Anpassa ditt utseende så att det matchar dig & ditt företag"
1848
+ },
1849
+ en: {
1850
+ // TODO REMOVE ?
1851
+ title: "Design your profile",
1852
+ subTitle: "Adjust profile to match your branding"
1853
+ }
1854
+ }
1855
+ },
1856
+ name: "PremiumRestrictedWinProfile",
1857
+ components: {
1858
+ PremiumRestrictedBase: g
1859
+ },
1860
+ props: {
1861
+ onUpgrade: {
1862
+ type: Function,
1863
+ default: null
1864
+ }
1865
+ }
1866
+ };
1867
+ var oe = function() {
1868
+ var t = this, e = t._self._c;
1869
+ return e("PremiumRestrictedBase", { attrs: { title: t.$t("title"), "sub-title": t.$t("subTitle"), "on-upgrade": t.onUpgrade } });
1870
+ }, le = [], ce = /* @__PURE__ */ d(
1871
+ ie,
1872
+ oe,
1873
+ le,
1874
+ !1,
1875
+ null,
1876
+ null,
1877
+ null,
1878
+ null
1879
+ );
1880
+ const ue = ce.exports, de = {
1881
+ i18nOptions: {
1882
+ namespaces: "subTemplates",
1883
+ messages: {
1884
+ en: {
1885
+ title: "Become even more effective",
1886
+ subTitle: "Create reusable text so you can create proposal with a few click"
1887
+ },
1888
+ sv: {
1889
+ title: "Bli ännu mer effektiv",
1890
+ subTitle: "Skapa återanvändbara texter så kan du med ett par klick få en komplett offert."
1891
+ }
1892
+ }
1893
+ },
1894
+ name: "PremiumRestrictedTemplates",
1895
+ components: {
1896
+ PremiumRestrictedBase: g
1897
+ },
1898
+ props: {
1899
+ onUpgrade: {
1900
+ type: Function,
1901
+ default: null
1902
+ }
1903
+ }
1904
+ };
1905
+ var pe = function() {
1906
+ var t = this, e = t._self._c;
1907
+ return e("PremiumRestrictedBase", { attrs: { title: t.$t("title"), "sub-title": t.$t("subTitle"), "on-upgrade": t.onUpgrade } });
1908
+ }, me = [], fe = /* @__PURE__ */ d(
1909
+ de,
1910
+ pe,
1911
+ me,
1912
+ !1,
1913
+ null,
1914
+ null,
1915
+ null,
1916
+ null
1917
+ );
1918
+ const ve = fe.exports, ge = {
1919
+ i18nOptions: {
1920
+ namespaces: "PremiumRestrictedDocuments",
1921
+ messages: {
1922
+ en: {
1923
+ title: "Send unlimited amount of documents",
1924
+ subTitle: "You have reached your limit of new documents for this month.",
1925
+ voucherTitle: "A special gift from us",
1926
+ voucherText: "Here is {{ count }} extra documents you can use.",
1927
+ voucherButton: "Give me {{count}} extra documents",
1928
+ voucherSuccessMessage: "{{ count }} extra documents are now available"
1929
+ },
1930
+ sv: {
1931
+ title: "Skicka obegränsat med dokument",
1932
+ subTitle: "Du har nått din gräns av nya dokument för den här månaden.",
1933
+ voucherTitle: "En present från oss",
1934
+ voucherText: "Här får du {{ count }} st dokument till att använda.",
1935
+ voucherButton: "Ge mig {{count}} extra dokument",
1936
+ voucherSuccessMessage: "Ditt konto har nu {{ count }} extra dokument"
1937
+ }
1938
+ }
1939
+ },
1940
+ name: "PremiumRestrictedDocuments",
1941
+ components: {
1942
+ PremiumRestrictedBase: g
1943
+ },
1944
+ props: {
1945
+ onUpgrade: {
1946
+ type: Function,
1947
+ default: null
1948
+ }
1949
+ },
1950
+ data() {
1951
+ return {
1952
+ canUseFreeDocVoucher: !1,
1953
+ voucherDocCount: 3,
1954
+ // This should be updated if we change the voucher value
1955
+ isLoading: !1
1956
+ };
1957
+ },
1958
+ computed: {
1959
+ ...h({
1960
+ getCompanyUserSetting: "settings/getCompanyUserSetting",
1961
+ user: "application/user",
1962
+ account: "application/companyAccount"
1963
+ })
1964
+ },
1965
+ created() {
1966
+ try {
1967
+ et("/documentLimitReached", {});
1968
+ } catch (r) {
1969
+ L(r, { showMessage: !1 });
1970
+ }
1971
+ },
1972
+ async mounted() {
1973
+ this.checkFreeDocVoucher();
1974
+ },
1975
+ methods: {
1976
+ ...k({
1977
+ loadCurrentCompany: p.DO_LOAD_CURRENT_COMPANY
1978
+ }),
1979
+ async checkFreeDocVoucher() {
1980
+ var t, e;
1981
+ if (this.canUseFreeDocVoucher = !1, ((t = this.account) == null ? void 0 : t.accountType) !== "free")
1982
+ return;
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());
1985
+ },
1986
+ async canUseVoucher() {
1987
+ try {
1988
+ return await q.canUse("freeUserDocs"), !0;
1989
+ } catch {
1990
+ return x.setItem("voucher-freeUserDocs-company-id", this.account.CompanyId), !1;
1991
+ }
1992
+ },
1993
+ async useFreeDocsVoucher() {
1994
+ this.isLoading = !0;
1995
+ try {
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);
1999
+ } finally {
2000
+ this.isLoading = !1;
2001
+ }
2002
+ }
2003
+ }
2004
+ };
2005
+ var he = function() {
2006
+ var t = this, e = t._self._c;
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,
2012
+ !1,
2013
+ null,
2014
+ null,
2015
+ null,
2016
+ null
2017
+ );
2018
+ const Ae = Ce.exports, Pe = {
2019
+ i18nOptions: {
2020
+ namespaces: "personalMessage",
2021
+ messages: {
2022
+ en: {
2023
+ title: "Make an impression",
2024
+ subTitle: "Upgrade to premium to add a personal message"
2025
+ },
2026
+ sv: {
2027
+ title: "Gör ett gott intryck",
2028
+ subTitle: "Uppgradera till Premium för att kunna lägga till en personlig hälsning."
2029
+ }
2030
+ }
2031
+ },
2032
+ name: "PremiumRestrictedWinProfile",
2033
+ components: {
2034
+ PremiumRestrictedBase: g
2035
+ },
2036
+ props: {
2037
+ onUpgrade: {
2038
+ type: Function,
2039
+ default: null
2040
+ }
2041
+ }
2042
+ };
2043
+ var be = function() {
2044
+ var t = this, e = t._self._c;
2045
+ return e("PremiumRestrictedBase", { attrs: { title: t.$t("title"), "sub-title": t.$t("subTitle"), "on-upgrade": t.onUpgrade } });
2046
+ }, ke = [], Se = /* @__PURE__ */ d(
2047
+ Pe,
2048
+ be,
2049
+ ke,
2050
+ !1,
2051
+ null,
2052
+ null,
2053
+ null,
2054
+ null
2055
+ );
2056
+ const we = Se.exports;
2057
+ const xe = {
2058
+ i18nOptions: {
2059
+ namespaces: "licenses",
2060
+ messages: {
2061
+ sv: {
2062
+ title: "Lägg till projektskapare",
2063
+ subTitle: "För att bjuda in din kollega behöver du ha en till licens.",
2064
+ actionText: "Lägg till licens",
2065
+ chatMessageStarter: "Hej! Jag är på starter men skulle vilja köpa till fler licenser",
2066
+ productTitle: "Extra licens",
2067
+ productCost: "Kostnad"
2068
+ },
2069
+ en: {
2070
+ title: "Add creator",
2071
+ subTitle: "To add teammates you need to add a license",
2072
+ actionText: "Add licens",
2073
+ chatMessageStarter: "Hi! I am om the starter package and would like to add licenses",
2074
+ productTitle: "Extra license",
2075
+ productCost: "Cost"
2076
+ }
2077
+ }
2078
+ },
2079
+ name: "PremiumRestrictedLicenses",
2080
+ components: {
2081
+ PremiumRestrictedBase: g
2082
+ },
2083
+ props: {
2084
+ onUpgrade: {
2085
+ type: Function,
2086
+ default: null
2087
+ }
2088
+ },
2089
+ computed: {
2090
+ ...h({
2091
+ subscription: "application/subscription",
2092
+ currentPlan: "stripe/currentPlan",
2093
+ formPlan: "stripe/formPlan"
2094
+ }),
2095
+ extraPrice() {
2096
+ return this.subscription.paymentMethod === "stripe" && this.formPlan ? this.formPlan : null;
2097
+ }
2098
+ },
2099
+ beforeCreate() {
2100
+ this.$store.state.stripe || this.$store.registerModule("stripe", j);
2101
+ },
2102
+ created() {
2103
+ this.initLicense();
2104
+ },
2105
+ methods: {
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
2112
+ }),
2113
+ priceFormat: y,
2114
+ async initLicense() {
2115
+ this.subscription.paymentMethod === "stripe" && (await this.loadPrices(), await this.resetStripeForm(), this.updateFormValue({ key: "plan", value: this.currentPlan }));
2116
+ },
2117
+ supportChatMessage() {
2118
+ this.$supportChat.showNewMessage(this.$t("chatMessageStarter")), this.$emit("close");
2119
+ },
2120
+ async doUpgrade({ callback: r }) {
2121
+ let t = !1;
2122
+ try {
2123
+ if (this.subscription.paymentMethod === "stripe")
2124
+ t = await this.addStripeLicense();
2125
+ else if (this.subscription.paymentMethod === "invoice")
2126
+ await this.addInvoiceLicense(), t = !0;
2127
+ else
2128
+ throw new Error("Cannot upgrade license as current paymentMethod is not valid");
2129
+ } catch (e) {
2130
+ L(e);
2131
+ }
2132
+ t && await r();
2133
+ },
2134
+ async addStripeLicense() {
2135
+ this.updateFormValue({ key: "plan.quantity", value: this.currentPlan.quantity + 1 });
2136
+ const r = await this.submitPlan({});
2137
+ return await this.loadCurrentCompany(), r;
2138
+ },
2139
+ async addInvoiceLicense() {
2140
+ await nt(), await this.loadCurrentCompany();
2141
+ }
2142
+ }
2143
+ };
2144
+ var Ie = function() {
2145
+ var t = this, e = t._self._c;
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,
2151
+ !1,
2152
+ null,
2153
+ null,
2154
+ null,
2155
+ null
2156
+ );
2157
+ const Le = Be.exports;
2158
+ const Te = {
2159
+ i18nOptions: {
2160
+ namespaces: "licenses",
2161
+ messages: {
2162
+ sv: {
2163
+ title: "Lägg till skapare",
2164
+ subTitle: "För att bjuda in en dokumentskapare behöver du uppgradera till vår Base- eller Pro-plan.",
2165
+ actionText: "Uppgradera konto"
2166
+ },
2167
+ en: {
2168
+ title: "Add creators",
2169
+ subTitle: "To invite creators you need to upgrade your account to the Base or Pro plan.",
2170
+ actionText: "Upgrade my plan"
2171
+ }
2172
+ }
2173
+ },
2174
+ name: "PremiumRestrictedLicenses",
2175
+ components: {
2176
+ PremiumRestrictedBase: g
2177
+ },
2178
+ props: {
2179
+ onUpgrade: {
2180
+ type: Function,
2181
+ default: null
2182
+ }
2183
+ }
2184
+ };
2185
+ var De = function() {
2186
+ var t = this, e = t._self._c;
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);
2188
+ }, Ve = [], Ee = /* @__PURE__ */ d(
2189
+ Te,
2190
+ De,
2191
+ Ve,
2192
+ !1,
2193
+ null,
2194
+ null,
2195
+ null,
2196
+ null
2197
+ );
2198
+ const Oe = Ee.exports, Qe = {
2199
+ i18nOptions: {
2200
+ namespaces: "stats",
2201
+ messages: {
2202
+ sv: {
2203
+ title: "Statistik",
2204
+ subTitle: "För att se statistik över alla dina dokument behöver du uppgradera ditt konto till Pro.",
2205
+ actionText: "Uppgradera konto"
2206
+ },
2207
+ en: {
2208
+ title: "Statistics",
2209
+ subTitle: "To view statistics about all your documents you need to upgrade your account to Pro.",
2210
+ actionText: "Upgrade my plan"
2211
+ }
2212
+ }
2213
+ },
2214
+ name: "PremiumRestrictedStats",
2215
+ components: {
2216
+ PremiumRestrictedBase: g
2217
+ },
2218
+ props: {
2219
+ onUpgrade: {
2220
+ type: Function,
2221
+ default: null
2222
+ }
2223
+ }
2224
+ };
2225
+ var qe = function() {
2226
+ var t = this, e = t._self._c;
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);
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,
2272
+ !1,
2273
+ null,
2274
+ null,
2275
+ null,
2276
+ null
2277
+ );
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 = {
2288
+ name: "IsPremiumPreStep",
2289
+ props: {
2290
+ feature: {
2291
+ type: String,
2292
+ required: !0,
2293
+ validator: (r) => Object.keys(I).includes(r)
2294
+ }
2295
+ },
2296
+ computed: {
2297
+ modalName() {
2298
+ return I[this.feature] ? I[this.feature] : (at.error("Missing IsPremiumPreStep component name"), null);
2299
+ }
2300
+ },
2301
+ methods: {
2302
+ onClick({ callback: r = null } = {}) {
2303
+ this.$modal.show(
2304
+ this.modalName,
2305
+ {
2306
+ ...r && { onUpgrade: r }
2307
+ },
2308
+ {
2309
+ adaptive: !0,
2310
+ maxWidth: 390,
2311
+ width: "90%",
2312
+ height: "auto",
2313
+ scrollable: !0,
2314
+ classes: "overflow-visible primary"
2315
+ }
2316
+ );
2317
+ }
2318
+ },
2319
+ render() {
2320
+ return this.$scopedSlots.default ? this.$scopedSlots.default({
2321
+ onClick: this.onClick
2322
+ }) : {};
2323
+ }
2324
+ }, Ge = null, We = null;
2325
+ var Ke = /* @__PURE__ */ d(
2326
+ Ne,
2327
+ Ge,
2328
+ We,
2329
+ !1,
2330
+ null,
2331
+ null,
2332
+ null,
2333
+ null
2334
+ );
2335
+ const nr = Ke.exports;
2336
+ export {
2337
+ ee as C,
2338
+ nr as I,
2339
+ zt as P,
2340
+ Zt as a,
2341
+ Lt as b,
2342
+ Dt as s
2343
+ };