@cling-se/widget 1.0.0-beta.1 → 1.0.0-beta.3

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 (241) hide show
  1. package/CHANGELOG.md +25 -0
  2. package/README.internal.md +82 -0
  3. package/README.md +14 -40
  4. package/README.public.md +14 -0
  5. package/dist/AddClientCallout-DRcy9Dqb.js +101 -0
  6. package/dist/AnswerModal-Dc3cgkap.js +3291 -0
  7. package/dist/AttachmentItem-Bef5zdHr.js +171 -0
  8. package/dist/BaseUpload--paElAyr.js +2472 -0
  9. package/dist/BlockMedia-DbVE3vsb.js +103 -0
  10. package/dist/CCallout-81NkOge7.js +104 -0
  11. package/dist/{CCurrencyDropdown-qH-3m2eP.js → CCurrencyDropdown-M3hi1VVi.js} +91 -49
  12. package/dist/CDropdownItem-DvaU14-V.js +749 -0
  13. package/dist/CFormField.vue_vue_type_script_setup_true_lang-B4s_Zfsp.js +292 -0
  14. package/dist/{CPhoneFormat-CfQayFxw.js → CPhoneFormat-BBQ_UIc_.js} +13 -21
  15. package/dist/CPhoneInput-Dw_LJDgc.js +207 -0
  16. package/dist/CPriceInput-BfWZZv0f.js +140 -0
  17. package/dist/CSelect-B1AAIFbK.js +98 -0
  18. package/dist/CSkeleton.vue_vue_type_script_setup_true_lang-D56L_PYT.js +51 -0
  19. package/dist/ClientAutocomplete-D5veIKyZ.js +532 -0
  20. package/dist/ClientModal-D8_TPzkv.js +1181 -0
  21. package/dist/ColorPicker-C0OahiVg.js +1408 -0
  22. package/dist/CompanyModal-CjzwQU4B.js +250 -0
  23. package/dist/ContentWrapper-DrmiaFOz.js +265 -0
  24. package/dist/CoverBlockSettings-C9DWvA-C.js +861 -0
  25. package/dist/DocAnswer-BEsvAMEp.js +33 -0
  26. package/dist/DocDetails--LO0-S5d.js +448 -0
  27. package/dist/DocForm-D6_tGw06.js +6748 -0
  28. package/dist/DocFormSend-CdFL6rOD.js +171 -0
  29. package/dist/DocLinks-CIQFUh7c.js +36 -0
  30. package/dist/DocModalBase-DtPJK9sp.js +29 -0
  31. package/dist/DocPrint-qX88Ue2I.js +399 -0
  32. package/dist/DocReceipt-BbXoCmpz.js +341 -0
  33. package/dist/DocSendReminder-DZqOkd63.js +181 -0
  34. package/dist/DocTextEditor-Cw-Skmd4.js +19413 -0
  35. package/dist/DocTimeline-CdbSOVD1.js +537 -0
  36. package/dist/DocumentClient-DtTv7gkF.js +90 -0
  37. package/dist/DocumentLayout-BRfEjoYq.js +1368 -0
  38. package/dist/DocumentLogotype-CUNzyewq.js +162 -0
  39. package/dist/DocumentVoided-CgDt-JFI.js +33 -0
  40. package/dist/EmbedInput-rPvTnpXn.js +157 -0
  41. package/dist/EmbedSettings-BtmFxYGB.js +103 -0
  42. package/dist/ErrorCallout-B6YrdUsG.js +34 -0
  43. package/dist/FilePreviewModal-BfIqIIbb.js +202 -0
  44. package/dist/Flag-CE3K7-8a.js +41 -0
  45. package/dist/HeaderSettings-5QR7MmVf.js +720 -0
  46. package/dist/ImageSelectModal-E3hGi8ty.js +119 -0
  47. package/dist/ImageUploadWrapper-BaexFAAh.js +1585 -0
  48. package/dist/Index--gv5fH24.js +201 -0
  49. package/dist/{Index-D4XgxmbD.js → Index-B3ycPjAI.js} +10 -18
  50. package/dist/Index-B7ECpXAa.js +28 -0
  51. package/dist/Index-BIXfUsHH.js +52 -0
  52. package/dist/Index-BM658CCq.js +93 -0
  53. package/dist/{Index--qPMWUMT.js → Index-B_DCM_bL.js} +48 -61
  54. package/dist/Index-BcMATT2_.js +47 -0
  55. package/dist/Index-BpWFU3Td.js +68 -0
  56. package/dist/Index-BulSI5iO.js +38 -0
  57. package/dist/Index-CHInIRw5.js +228 -0
  58. package/dist/Index-COYqsxs9.js +25 -0
  59. package/dist/Index-CSGk060H.js +1098 -0
  60. package/dist/Index-CV2O2fWT.js +21 -0
  61. package/dist/{Index-Bu0MGrj6.js → Index-CXqdBSZ3.js} +313 -206
  62. package/dist/Index-CavttI66.js +126 -0
  63. package/dist/Index-CbZ65-O3.js +629 -0
  64. package/dist/Index-CqrTij2j.js +70 -0
  65. package/dist/Index-CrsGxDWC.js +16 -0
  66. package/dist/Index-CxY5Ii6K.js +49 -0
  67. package/dist/Index-D7Z2w9cd.js +163 -0
  68. package/dist/Index-D7ixmzBH.js +76 -0
  69. package/dist/Index-D7pzv-AR.js +74 -0
  70. package/dist/Index-D9keESQi.js +159 -0
  71. package/dist/Index-Dd6ueeUc.js +136 -0
  72. package/dist/{Index-DIOiMm9f.js → Index-DexIUz3R.js} +10 -18
  73. package/dist/Index-Dnmt6W0u.js +140 -0
  74. package/dist/Index-DtcV6rl1.js +4 -0
  75. package/dist/Index-DuDVafLn.js +3452 -0
  76. package/dist/Index-L913X8Ly.js +102 -0
  77. package/dist/Index-Mdn0niR_.js +28 -0
  78. package/dist/Index-_ellB2fs.js +363 -0
  79. package/dist/{Index-DcQbh-z2.js → Index-baSB5tPv.js} +9 -17
  80. package/dist/Index-bgKndj-l.js +39 -0
  81. package/dist/Index-lNYXAFUH.js +87 -0
  82. package/dist/Index.vue_vue_type_script_lang-DLogex2i.js +671 -0
  83. package/dist/InputToggleRow-BCvMVbW-.js +99 -0
  84. package/dist/ManualPopover-BzBvSl_x.js +57 -0
  85. package/dist/MediaWrapper-_LPau2Ks.js +18 -0
  86. package/dist/{NotBindingText-CNV2Wmdx.js → NotBindingText-DgcOjUmQ.js} +13 -17
  87. package/dist/PackageGroup-1X3jUipj.js +1058 -0
  88. package/dist/PdfTerms-Bf4TlzP5.js +34 -0
  89. package/dist/PdfViewer-BdhwFfc6.js +392 -0
  90. package/dist/PlainHtml.vue_vue_type_script_setup_true_lang-BgsfquR_.js +17 -0
  91. package/dist/PriceHeader-DyC8xssf.js +488 -0
  92. package/dist/SearchApi-C__orGkO.js +137 -0
  93. package/dist/SendForm-Be8uiuaJ.js +7031 -0
  94. package/dist/Setup-DbXs2Zar.js +47 -0
  95. package/dist/{SmartList-Qgu0rMrI.js → SmartList-BmmtZoZ0.js} +16 -24
  96. package/dist/Sortable.vue_vue_type_script_setup_true_lang-D0mloJIN.js +1303 -0
  97. package/dist/{TermsSettings-CE3h_xkm.js → TermsSettings-DsN6v5yj.js} +169 -49
  98. package/dist/ThemeColorRow-BL6p09pN.js +108 -0
  99. package/dist/ToggleBinding-B-tVioQ9.js +44 -0
  100. package/dist/UploadModal-BnA1xLMy.js +134 -0
  101. package/dist/VideoPlayerInput-D38S1IDH.js +135 -0
  102. package/dist/VideoPlayerSettings-B5iXoj5E.js +78 -0
  103. package/dist/VideoSelectModal-BNCoMFKU.js +217 -0
  104. package/dist/{anime.es-BrPTThYb.js → anime.es-gdcpA-eY.js} +1 -2
  105. package/dist/{color-TdtKxwVa.js → color-HetJPhlA.js} +1 -2
  106. package/dist/{debounce-C1AuSpOZ.js → debounce-CBRJalZI.js} +7 -7
  107. package/dist/dom-CkTGWrfu.js +69 -0
  108. package/dist/{focusDrawerMixin-Be6BAK8-.js → focusDrawerMixin-T94b2Y6F.js} +1 -1
  109. package/dist/{formDrawerState-DRbg5rVI.js → formDrawerState-jssoGOce.js} +2 -2
  110. package/dist/helpers-Vo_6Zz3M.js +44 -0
  111. package/dist/index-8g2jwLJx.js +513 -0
  112. package/dist/index-B0udVHyo.js +125 -0
  113. package/dist/index-D63IJVsJ.js +3525 -0
  114. package/dist/index-DCYCN_FR.js +508 -0
  115. package/dist/index-FRHGChx1.js +149 -0
  116. package/dist/index-HXiq8Yxs.js +270 -0
  117. package/dist/index-jOufDnZ8.js +188 -0
  118. package/dist/index.es.js +2 -5
  119. package/dist/index.umd.js +306 -1505
  120. package/dist/{main-WKzC-Dnu.js → main-C4OdoeS2.js} +36750 -37369
  121. package/dist/mapFormMixin-v-nbaWcx.js +1544 -0
  122. package/dist/omit-GuxX6Zt-.js +31 -0
  123. package/dist/{publicSenderState-BujjYsZZ.js → publicSenderState-C-7OMKKW.js} +4 -4
  124. package/dist/regions-BdZt9Srn.js +1250 -0
  125. package/dist/splitpanes-DChJiJ8d.js +342 -0
  126. package/dist/style.css +1 -4
  127. package/dist/template-m1V22cUt.js +1493 -0
  128. package/dist/{throttle-CWPJmFid.js → throttle-WWMDZKby.js} +2 -2
  129. package/dist/tippy.esm-Dz-faEsS.js +1994 -0
  130. package/dist/useTermsModal-C_eLdGLi.js +87 -0
  131. package/dist/{utils-CA_Zy6u1.js → utils-vnvZGRwQ.js} +8 -11
  132. package/dist/validation-C-dQpENM.js +40 -0
  133. package/package.json +25 -31
  134. package/.eslintrc.cjs +0 -4
  135. package/dist/AddClientCallout-BWnvyBcK.js +0 -46
  136. package/dist/AnswerModal-CLGRdSnK.js +0 -3874
  137. package/dist/AttachmentItem-BPS0-wyc.js +0 -78
  138. package/dist/BaseDatePicker-BbmV_GdD.js +0 -3183
  139. package/dist/BaseUpload-9gPgI7r6.js +0 -1977
  140. package/dist/BlockMedia-DkPFWiYL.js +0 -76
  141. package/dist/CCallout-T26jwUby.js +0 -59
  142. package/dist/CDropdownItem-BE8BAMD1.js +0 -636
  143. package/dist/CField.vue_vue_type_style_index_0_lang-l0sNRNKZ.js +0 -1
  144. package/dist/CFormField-DECEfoVq.js +0 -241
  145. package/dist/CPriceInput-C4SOB-P5.js +0 -112
  146. package/dist/CTabs.vue_vue_type_style_index_0_scoped_e02a6440_lang-l0sNRNKZ.js +0 -1
  147. package/dist/ClientAutocomplete-DSebA1Mx.js +0 -78
  148. package/dist/ClientModal-BXFYvYCF.js +0 -625
  149. package/dist/ColorPicker-CZ_bJabP.js +0 -2879
  150. package/dist/CompanyModal-CDr3t28n.js +0 -141
  151. package/dist/ContentWrapper-BwmMoe4W.js +0 -183
  152. package/dist/CoverBlockSettings-_F11-DGc.js +0 -275
  153. package/dist/DocAnswer-BR59xzkT.js +0 -36
  154. package/dist/DocDetails-D1qbCbps.js +0 -259
  155. package/dist/DocForm-DBc2a7z5.js +0 -7272
  156. package/dist/DocFormSend-Casix-yG.js +0 -144
  157. package/dist/DocLinks-DGTaewyX.js +0 -38
  158. package/dist/DocModalBase-BbS_qvSv.js +0 -28
  159. package/dist/DocPrint-0PqX3mbJ.js +0 -240
  160. package/dist/DocReceipt-CU3VD5pt.js +0 -210
  161. package/dist/DocSendReminder-CuycBspr.js +0 -137
  162. package/dist/DocTextEditor-CntS2Bd-.js +0 -17180
  163. package/dist/DocTimeline-DJuv3yBe.js +0 -481
  164. package/dist/DocumentClient-C25XXzz6.js +0 -136
  165. package/dist/DocumentLayout-B7afHRMr.js +0 -4909
  166. package/dist/DocumentLogotype-sqI51wvM.js +0 -87
  167. package/dist/DocumentVoided-TahdTSMn.js +0 -25
  168. package/dist/EmbedInput-BY-wHSfc.js +0 -113
  169. package/dist/EmbedSettings-8pfjk4NP.js +0 -72
  170. package/dist/ErrorCallout-Dsr8PNsU.js +0 -28
  171. package/dist/FilePreviewModal-CcEinEFg.js +0 -81
  172. package/dist/Flag-PJKrghi9.js +0 -114
  173. package/dist/HeaderSettings-BqczIOsG.js +0 -392
  174. package/dist/ImageSelectModal-Cd-HhKnH.js +0 -84
  175. package/dist/ImageUploadWrapper-Dv43rGdb.js +0 -1604
  176. package/dist/Index-6b5VBKE-.js +0 -107
  177. package/dist/Index-B4pRJnbw.js +0 -84
  178. package/dist/Index-B69f8qgZ.js +0 -62
  179. package/dist/Index-B79YN9RO.js +0 -25
  180. package/dist/Index-BBrlPoe8.js +0 -58
  181. package/dist/Index-BXfWJCuq.js +0 -52
  182. package/dist/Index-Bd76vb37.js +0 -55
  183. package/dist/Index-BmbtQO5F.js +0 -150
  184. package/dist/Index-ByV_kJaH.js +0 -77
  185. package/dist/Index-CDV5rhWS.js +0 -49
  186. package/dist/Index-CIx4OOK-.js +0 -144
  187. package/dist/Index-CL1OWLt6.js +0 -223
  188. package/dist/Index-Caow0eZu.js +0 -31
  189. package/dist/Index-Cd3-3PEK.js +0 -2402
  190. package/dist/Index-CdpZBEKU.js +0 -98
  191. package/dist/Index-CmU3Sys-.js +0 -754
  192. package/dist/Index-CtRtgnpm.js +0 -32
  193. package/dist/Index-Cukkr33D.js +0 -140
  194. package/dist/Index-Cuqw0ios.js +0 -57
  195. package/dist/Index-Czm_WdqC.js +0 -25
  196. package/dist/Index-DNdYXHgr.js +0 -33
  197. package/dist/Index-DcuBxutp.js +0 -642
  198. package/dist/Index-DpWNWiyY.js +0 -291
  199. package/dist/Index-DzS1rZdF.js +0 -24
  200. package/dist/Index-N6s5pZxv.js +0 -26
  201. package/dist/Index-g_DNu4mt.js +0 -69
  202. package/dist/Index-mJ8F41GY.js +0 -154
  203. package/dist/Index-q7W9KA8m.js +0 -21
  204. package/dist/Index-rtzblZp4.js +0 -70
  205. package/dist/InputToggleRow-CZjxsDOQ.js +0 -57
  206. package/dist/ManualPopover-CZrWiT-P.js +0 -58
  207. package/dist/MediaWrapper-D37qK4KR.js +0 -23
  208. package/dist/PackageGroup-Heo_s8ct.js +0 -699
  209. package/dist/PdfTerms-AB9tXAtU.js +0 -36
  210. package/dist/PdfViewer-CIVkvOBr.js +0 -373
  211. package/dist/PlainHtml-CPmIebjY.js +0 -20
  212. package/dist/PriceHeader-DhDAruwX.js +0 -339
  213. package/dist/SearchApi-BMgdaI4s.js +0 -161
  214. package/dist/Setup-VIaIV9uT.js +0 -50
  215. package/dist/ThemeColorRow-DYJNgk6S.js +0 -67
  216. package/dist/ToggleBinding-CuwCeYpO.js +0 -38
  217. package/dist/UploadModal-BITcxG-J.js +0 -95
  218. package/dist/VideoPlayerInput-8szEX_8L.js +0 -93
  219. package/dist/VideoPlayerSettings-BIPytm6w.js +0 -61
  220. package/dist/VideoSelectModal-B-Pe34nb.js +0 -100
  221. package/dist/answerDocumentMixin-W7vE1Gp4.js +0 -51
  222. package/dist/formComponentsInstall-Bm3VMOh6.js +0 -2507
  223. package/dist/formValidationMixin-COkY8COk.js +0 -49
  224. package/dist/index-BFvjENMH.js +0 -81
  225. package/dist/index-BV2nGWay.js +0 -492
  226. package/dist/index-BgJ05dYc.js +0 -165
  227. package/dist/index-CMPAXxzs.js +0 -347
  228. package/dist/index-DNDjI5uI.js +0 -3916
  229. package/dist/index-aoff9oUi.js +0 -102
  230. package/dist/mapFormMixin-QbevCwJK.js +0 -72
  231. package/dist/omit-CTp9CXoU.js +0 -31
  232. package/dist/splitpanes-BHUVsCZF.js +0 -382
  233. package/dist/tinycolor-kTl0yxzz.js +0 -633
  234. package/dist/tippy.esm-sS5koDSU.js +0 -1799
  235. package/dist/vuedraggable.umd-BA3ZDRAp.js +0 -3161
  236. package/dist/vuex.esm-DKGl8mcw.js +0 -467
  237. package/public/favicon.ico +0 -0
  238. package/tsconfig.json +0 -26
  239. package/tsconfig.node.json +0 -10
  240. package/tsconfig.paths.json +0 -17
  241. package/vite.config.ts +0 -60
@@ -1,7 +1,9 @@
1
- import { i as m, F as o, n as v } from "./main-WKzC-Dnu.js";
2
- import { m as c } from "./mapFormMixin-QbevCwJK.js";
3
- import g from "./Index-mJ8F41GY.js";
4
- const p = {
1
+ import { _ as C, V as T, a7 as _, b as u, a3 as B, o as s, d as h, s as n, B as v, v as i, E as x, e as k, w as l, F as S, k as F, c as g, f } from "./main-C4OdoeS2.js";
2
+ import { m as U } from "./mapFormMixin-v-nbaWcx.js";
3
+ import { C as j } from "./CCallout-81NkOge7.js";
4
+ import { C as D, a as I } from "./CDropdownItem-DvaU14-V.js";
5
+ import { u as N } from "./useTermsModal-C_eLdGLi.js";
6
+ const A = {
5
7
  i18nOptions: {
6
8
  namespaces: "terms",
7
9
  messages: {
@@ -29,74 +31,192 @@ const p = {
29
31
  },
30
32
  name: "TermsSettings",
31
33
  components: {
32
- TermsDisclaimer: g
34
+ CCallout: j,
35
+ CDropdown: D,
36
+ CDropdownItem: I
33
37
  },
34
- mixins: [c(["term"])],
38
+ mixins: [U(["term"])],
35
39
  data() {
36
40
  return {
37
41
  terms: {
38
42
  data: {},
39
43
  ids: []
40
- },
41
- termsIdList: []
44
+ }
45
+ };
46
+ },
47
+ setup() {
48
+ const { showTermsModal: t } = N();
49
+ return {
50
+ showTermsModal: t
42
51
  };
43
52
  },
44
53
  async created() {
45
54
  await this.getTerms();
46
55
  },
47
56
  methods: {
57
+ showTerms() {
58
+ this.showTermsModal({
59
+ text: this.term.text,
60
+ _document: this._document,
61
+ termType: this.term.type,
62
+ file: this.term.file,
63
+ href: this.term.href
64
+ });
65
+ },
48
66
  async getTerms() {
49
- let r = [];
50
- this.viewSettings.isPublicForm ? r = this.getPublicTerms() : { data: r } = await m("documentTerm"), r.forEach(({ name: t, type: e, text: a, href: n, version: i, File: l, id: d }) => {
51
- const s = {
52
- name: t,
53
- type: e === "pdf" ? "file" : e,
54
- text: a || "",
55
- href: n || "",
56
- version: i,
57
- termId: d,
58
- file: l ? {
59
- name: l.displayName,
60
- url: l.url,
61
- mime: l.mime,
62
- fileId: l.id
67
+ let t = [];
68
+ this.viewSettings.isPublicForm ? t = this.getPublicTerms() : { data: t } = await T("documentTerm"), t.forEach(({ name: e, type: c, text: b, href: a, version: p, File: r, id: o }) => {
69
+ const d = {
70
+ name: e,
71
+ type: c === "pdf" ? "file" : c,
72
+ text: b || "",
73
+ href: a || "",
74
+ version: p,
75
+ termId: o,
76
+ file: r ? {
77
+ name: r.displayName,
78
+ url: r.url,
79
+ mime: r.mime,
80
+ fileId: r.id
63
81
  } : null
64
82
  };
65
- this.terms.data[s.termId] = s, this.terms.ids.push(s.termId);
83
+ this.terms.data[d.termId] = d, this.terms.ids.push(d.termId);
66
84
  }), this.term && !this.terms.ids.includes(this.term.termId) && (this.terms.data[this.term.termId] = this.term, this.terms.ids.push(this.term.termId));
67
85
  },
68
86
  getPublicTerms() {
69
- const { language: r } = this._document, t = [];
70
- return r === "sv" && t.push({
87
+ const { language: t } = this._document, e = [];
88
+ return t === "sv" && e.push({
71
89
  id: 1,
72
90
  name: "Standardvillkor Konsultkontrakt",
73
91
  type: "text",
74
92
  text: '<div class="term-chapter"> <div class="term-title">Tillämplighet</div><div class="term-text"> Dessa allmänna villkor gäller vid utförande av avtalade tjänster mellan Beställare och Utställare. När Beställare anlitar Utställare ansas beställare ha acceptera dessa villkor. Avvikelser från villkoren ska vara skriftliga för att vara gällande. </div></div><div class="term-chapter"> <div class="term-title">Uppdragets omfattning</div><div class="term-text"> Utställare åtar sig att utföra tjänsten fackmässigt och ska med tillbörlig omsorg ta till vara på Beställarens intressen och samråda med denne i den utsträckning som behövs och är möjligt. Omfattningen av uppdraget kan komma att ändras under uppdragets gång utställare ska inhämta beställarens godkännande avseende åtgärder som ligger utanför ramen för uppdraget. </div></div><div class="term-chapter"> <div class="term-title">Uppdragets genomförande</div><div class="term-text"> Baserat på vad som är tillämpligt från fall till fall ska Beställarens lämna Utställare, erforderlig tillgång till lokaler, information eller liknande som krävs för att genomföra uppdraget. Utställare ska utföra alla delar av avtalat åtagande i enlighet med bestämmelserna i leveransavtalet och dessa allmänna villkor och med den skicklighet, snabbhet och omsorg som Beställaren har anledning att förvänta sig av ett välrenommerat företag i branschen. </div></div><div class="term-chapter"> <div class="term-title">Sekretess</div><div class="term-text"> Beställare och Utövare förbinder sig att behandla all information som erhålls från, eller som uppkommer i samband med uppdraget med den andre parten strikt konfidentiellt och inte avslöja sådan information eller använda informationen för egen eller annans räkning, om inte den andre parten har givit skriftligt samtycke för sådan användning. Åtagandet enligt denna bestämmelse skall gälla även efter att parternas samarbete har upphört, och intill dess sådan information som avses härunder får anses ha kommit till allmän kännedom på annat sätt än genom brott mot detta avtal. Sekretesskyldigheten gäller inte när part är skyldig enligt lag, eller myndighetsbeslut att lämna ut uppgifter. Är part skyldig enligt lag att lämna ut uppgifter skall, innan sådant utlämnande sker, andra parten informeras därom. Om inte annat avtalats har Utställare rätt att använda beställarens namn och logo i referenslista samt annat material att användas i marknadsföringsändamål. </div></div><div class="term-chapter"> <div class="term-title">Ansvar</div><div class="term-text"> Utövare är skyldig att teckna lagstadgad ansvars och arbetsskadeförsäkring för sig själv och sina anställda. Om beställaren drabbas av förlust, som direkt följd av att beställaren misslyckats med att fullfölja åtaganden enligt detta kontrakt eller visat grov oaktsamhet i samband med utförandet av projektet, ansvarar utövaren för förlusten. Utställare ansvarar inte för någon följdförlust, badwill eller annan indirekt skada som Beställare lidit pga. eller i samband med resultatet av uppdraget. </div></div><div class="term-chapter"> <div class="term-title">Rättigheter</div><div class="term-text"> Beställaren erhåller ägande, upphovsrätt och andra rättigheter till program, analyser, rapporter, dokument och liknande som utställare producerar som en del av detta uppdrag. </div></div><div class="term-chapter"> <div class="term-title">Förseningar</div><div class="term-text"> Utställare ansvarar inte för förseningar på grund av leveransförseningar från andra leverantörer som utställare inte har ingått i avtal med. Utställare är inte ansvarig för eventuella förseningar på grund av kundrelationer. Om avtalet har blivit föremål för leverans vid angivna tider har Utställare rätt att skjuta upp leveransdatumet om kunden ändrar uppdraget / innehållet i uppdraget eller inte tillhandahåller aktuell information, ritningar, dokument, data eller liknande som är en förutsättning för uppdragets utförande. </div></div><div class="term-chapter"> <div class="term-title">Force majeure</div><div class="term-text"> Yttre händelser utanför parternas kontroll (t ex myndighetsåtgärder, krig, mobilisering, arbetsmarknadskonflikt, naturkatastrof etc.) och som inte endast är av tillfällig natur och som förhindrar genomförande av uppdraget berättigar vardera parten att helt inställa uppdraget utan rätt till skadestånd för den andra parten. </div></div><div class="term-chapter"> <div class="term-title">Tvist</div><div class="term-text"> Om en av parterna inte fullgör sina skyldigheter enligt avtalet och de villkor som är knutna till den, har den andra parten rätt att säga upp avtalet. Svensk lag ska tillämpas på detta Avtal och på varje annat avtal mellan parterna. Tvist som uppstår i anledning av Avtalet ska avgöras i allmän domstol. </div></div>'
75
- }), t;
93
+ }), e;
76
94
  },
77
- truncate: o
95
+ truncate: _
78
96
  }
79
- };
80
- var u = function() {
81
- var t = this, e = t._self._c;
82
- return e("div", { staticClass: "d-root" }, [e("div", { staticClass: "d-option-title" }, [t._v(" " + t._s(t.$t("title")) + " "), e("svg", { directives: [{ name: "tooltip", rawName: "v-tooltip", value: t.$t("tooltip"), expression: "$t('tooltip')" }], attrs: { xmlns: "http://www.w3.org/2000/svg", width: "16", height: "16", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", "stroke-width": "2.5", "stroke-linecap": "square", "stroke-linejoin": "bevel" } }, [e("circle", { attrs: { cx: "12", cy: "12", r: "10" } }), e("line", { attrs: { x1: "12", y1: "16", x2: "12", y2: "12" } }), e("line", { attrs: { x1: "12", y1: "8", x2: "12", y2: "8" } })])]), e("CDropdown", { attrs: { value: t.term ? t.term.id : null, expanded: "" } }, [e("CButton", { staticClass: "is-left", staticStyle: { width: "100%" }, attrs: { slot: "trigger", "dropdown-icon": !0 }, slot: "trigger" }, [e("div", { staticClass: "truncate-text" }, [t._v(" " + t._s(t.truncate(t.term && t.terms.ids.length && t.terms.data[t.term.termId].name || t.$t("noneSelected"), 20)) + " ")])]), t._l(t.terms.ids, function(a) {
83
- return e("CDropdownItem", { key: a, staticStyle: { "padding-right": "calc(1 * var(--rem))" }, attrs: { value: a }, on: { click: function(n) {
84
- t.term = t.terms.data[a];
85
- } } }, [e("div", { staticClass: "truncate-text" }, [t._v(" " + t._s(t.terms.data[a].name) + " ")])]);
86
- }), e("CDropdownItem", { attrs: { value: null }, on: { click: function(a) {
87
- t.term = null;
88
- } } }, [t._v(t._s(t.$t("notSet")))]), t.terms.ids.length ? t._e() : e("CDropdownItem", { attrs: { disabled: "" } }, [t._v(t._s(t.$t("noResults")))])], 2), t.viewSettings.isPublicForm ? e("CCallout", { staticStyle: { margin: "1em 0" }, attrs: { title: t.$t("publicFormCalloutTitle"), size: "small" } }, [t._v(" " + t._s(t.$t("publicFormCallout")) + " ")]) : t._e(), t.term ? e("TermsDisclaimer", { attrs: { _document: t._document, "term-type": t.term.type, href: t.term.href, text: t.term.text, file: t.term.file }, scopedSlots: t._u([{ key: "default", fn: function({ openTerms: a }) {
89
- return [e("CButton", { staticStyle: { "margin-top": "5px" }, attrs: { type: "none", pattern: "secondary", size: "small", "icon-left": "eye" }, on: { click: a } }, [t._v(" " + t._s(t.$t("show")) + " ")])];
90
- } }], null, !1, 1475186016) }) : t._e()], 1);
91
- }, h = [], f = /* @__PURE__ */ v(
92
- p,
93
- u,
94
- h,
95
- !1,
96
- null,
97
- "f7bd188e"
98
- );
99
- const y = f.exports;
97
+ }, O = { class: "d-root" }, V = {
98
+ class: "d-option",
99
+ style: { "border-bottom": "none" }
100
+ }, $ = { class: "d-option-title" }, M = {
101
+ xmlns: "http://www.w3.org/2000/svg",
102
+ width: "16",
103
+ height: "16",
104
+ viewBox: "0 0 24 24",
105
+ fill: "none",
106
+ stroke: "currentColor",
107
+ "stroke-width": "2.5",
108
+ "stroke-linecap": "square",
109
+ "stroke-linejoin": "bevel"
110
+ }, P = { class: "truncate-text" }, R = { class: "truncate-text" };
111
+ function E(t, e, c, b, a, p) {
112
+ const r = u("CButton"), o = u("CDropdownItem"), d = u("CDropdown"), y = u("CCallout"), w = B("tooltip");
113
+ return s(), h("div", O, [
114
+ n("div", V, [
115
+ n("div", $, [
116
+ v(i(t.$t("title")) + " ", 1),
117
+ x((s(), h("svg", M, e[1] || (e[1] = [
118
+ n("circle", {
119
+ cx: "12",
120
+ cy: "12",
121
+ r: "10"
122
+ }, null, -1),
123
+ n("line", {
124
+ x1: "12",
125
+ y1: "16",
126
+ x2: "12",
127
+ y2: "12"
128
+ }, null, -1),
129
+ n("line", {
130
+ x1: "12",
131
+ y1: "8",
132
+ x2: "12",
133
+ y2: "8"
134
+ }, null, -1)
135
+ ]))), [
136
+ [w, t.$t("tooltip")]
137
+ ])
138
+ ])
139
+ ]),
140
+ k(d, {
141
+ "model-value": t.term ? t.term.id : null,
142
+ expanded: ""
143
+ }, {
144
+ trigger: l(() => [
145
+ k(r, {
146
+ "dropdown-icon": !0,
147
+ class: "is-left",
148
+ style: { width: "100%" }
149
+ }, {
150
+ default: l(() => [
151
+ n("div", P, i(p.truncate(
152
+ t.term && a.terms.ids.length && a.terms.data[t.term.termId].name || t.$t("noneSelected"),
153
+ 20
154
+ )), 1)
155
+ ]),
156
+ _: 1
157
+ })
158
+ ]),
159
+ default: l(() => [
160
+ (s(!0), h(S, null, F(a.terms.ids, (m) => (s(), g(o, {
161
+ key: m,
162
+ value: m,
163
+ style: { "padding-right": "calc(1 * var(--rem))" },
164
+ onClick: (z) => t.term = a.terms.data[m]
165
+ }, {
166
+ default: l(() => [
167
+ n("div", R, i(a.terms.data[m].name), 1)
168
+ ]),
169
+ _: 2
170
+ }, 1032, ["value", "onClick"]))), 128)),
171
+ k(o, {
172
+ value: null,
173
+ onClick: e[0] || (e[0] = (m) => t.term = null)
174
+ }, {
175
+ default: l(() => [
176
+ v(i(t.$t("notSet")), 1)
177
+ ]),
178
+ _: 1
179
+ }),
180
+ a.terms.ids.length ? f("", !0) : (s(), g(o, {
181
+ key: 0,
182
+ disabled: ""
183
+ }, {
184
+ default: l(() => [
185
+ v(i(t.$t("noResults")), 1)
186
+ ]),
187
+ _: 1
188
+ }))
189
+ ]),
190
+ _: 1
191
+ }, 8, ["model-value"]),
192
+ t.viewSettings.isPublicForm ? (s(), g(y, {
193
+ key: 0,
194
+ title: t.$t("publicFormCalloutTitle"),
195
+ size: "small",
196
+ style: { margin: "1em 0" }
197
+ }, {
198
+ default: l(() => [
199
+ v(i(t.$t("publicFormCallout")), 1)
200
+ ]),
201
+ _: 1
202
+ }, 8, ["title"])) : f("", !0),
203
+ t.term ? (s(), g(r, {
204
+ key: 1,
205
+ type: "none",
206
+ pattern: "secondary",
207
+ size: "small",
208
+ "icon-left": "eye",
209
+ style: { "margin-top": "5px" },
210
+ onClick: p.showTerms
211
+ }, {
212
+ default: l(() => [
213
+ v(i(t.$t("show")), 1)
214
+ ]),
215
+ _: 1
216
+ }, 8, ["onClick"])) : f("", !0)
217
+ ]);
218
+ }
219
+ const H = /* @__PURE__ */ C(A, [["render", E]]);
100
220
  export {
101
- y as default
221
+ H as default
102
222
  };
@@ -0,0 +1,108 @@
1
+ import { C as h } from "./ColorPicker-C0OahiVg.js";
2
+ import { _ as k } from "./ManualPopover-BzBvSl_x.js";
3
+ import { h as w } from "./color-HetJPhlA.js";
4
+ import { _ as C, b as l, a3 as _, o as a, d as i, s as o, S as d, E as g, f as V, e as p, w as u, ao as c, Z as b, l as y } from "./main-C4OdoeS2.js";
5
+ const P = {
6
+ name: "ThemeColorRow",
7
+ components: {
8
+ ColorPicker: h,
9
+ ManualPopover: k
10
+ },
11
+ emits: ["change"],
12
+ props: {
13
+ value: {
14
+ type: String,
15
+ default: ""
16
+ },
17
+ pickerOptions: {
18
+ type: Object,
19
+ default: () => ({})
20
+ },
21
+ showReset: {
22
+ type: Boolean,
23
+ default: !1
24
+ },
25
+ placement: {
26
+ type: String,
27
+ default: "bottom-end"
28
+ }
29
+ },
30
+ computed: {
31
+ internalValue: {
32
+ get() {
33
+ return this.value;
34
+ },
35
+ set(t) {
36
+ this.$emit("change", w(t.hsl));
37
+ }
38
+ }
39
+ },
40
+ methods: {
41
+ reset() {
42
+ this.$emit("change", null);
43
+ }
44
+ }
45
+ }, M = {
46
+ ref: "themeContainer",
47
+ class: "theme-row"
48
+ }, S = { style: { flex: "1 1 auto" } }, B = { ref: "button" };
49
+ function x(t, e, n, O, R, r) {
50
+ const m = l("ColorPicker"), f = l("ManualPopover"), v = _("tooltip");
51
+ return a(), i("div", M, [
52
+ o("div", S, [
53
+ d(t.$slots, "default", {}, void 0, !0)
54
+ ]),
55
+ n.showReset ? g((a(), i("div", {
56
+ key: 0,
57
+ class: "reset-button",
58
+ onClick: e[0] || (e[0] = (...s) => r.reset && r.reset(...s))
59
+ }, e[4] || (e[4] = [
60
+ o("svg", {
61
+ xmlns: "http://www.w3.org/2000/svg",
62
+ width: "16",
63
+ height: "16",
64
+ viewBox: "0 0 24 24",
65
+ fill: "none",
66
+ stroke: "currentColor",
67
+ "stroke-width": "2",
68
+ "stroke-linecap": "round",
69
+ "stroke-linejoin": "round"
70
+ }, [
71
+ o("path", { d: "M2.5 2v6h6M2.66 15.57a10 10 0 1 0 .57-8.38" })
72
+ ], -1)
73
+ ]))), [
74
+ [v, t.$t("reset")]
75
+ ]) : V("", !0),
76
+ p(f, { "popper-class": "popover-color-picker" }, {
77
+ popper: u(() => [
78
+ o("div", {
79
+ onMousedown: e[2] || (e[2] = c(() => {
80
+ }, ["stop"])),
81
+ onClick: e[3] || (e[3] = c(() => {
82
+ }, ["stop"]))
83
+ }, [
84
+ p(m, b(n.pickerOptions, {
85
+ ref: "colorPicker",
86
+ modelValue: r.internalValue,
87
+ "onUpdate:modelValue": e[1] || (e[1] = (s) => r.internalValue = s)
88
+ }), null, 16, ["modelValue"])
89
+ ], 32)
90
+ ]),
91
+ default: u(() => [
92
+ o("div", B, [
93
+ d(t.$slots, "button", {}, () => [
94
+ o("div", {
95
+ style: y({ backgroundColor: r.internalValue }),
96
+ class: "current-color-icon"
97
+ }, null, 4)
98
+ ], !0)
99
+ ], 512)
100
+ ]),
101
+ _: 3
102
+ })
103
+ ], 512);
104
+ }
105
+ const D = /* @__PURE__ */ C(P, [["render", x], ["__scopeId", "data-v-cdf22c3c"]]);
106
+ export {
107
+ D as T
108
+ };
@@ -0,0 +1,44 @@
1
+ import { m as s } from "./mapFormMixin-v-nbaWcx.js";
2
+ import { I as m } from "./InputToggleRow-BCvMVbW-.js";
3
+ import { b as p } from "./CDropdownItem-DvaU14-V.js";
4
+ import { _ as d, b as e, o as g, d as r, e as i, w as c } from "./main-C4OdoeS2.js";
5
+ const u = {
6
+ name: "ToggleBinding",
7
+ i18nOptions: {
8
+ namespaces: "ToggleBinding",
9
+ messages: {
10
+ en: {
11
+ label: "Answer not binding"
12
+ },
13
+ sv: {
14
+ label: "Ej bindande svar"
15
+ }
16
+ }
17
+ },
18
+ components: {
19
+ InputToggleRow: m,
20
+ CSwitch: p
21
+ },
22
+ mixins: [s(["notBinding"])]
23
+ };
24
+ function b(n, o, f, w, B, _) {
25
+ const t = e("CSwitch"), l = e("InputToggleRow");
26
+ return g(), r("div", null, [
27
+ i(l, {
28
+ "display-value": n.notBinding,
29
+ label: n.$t("label")
30
+ }, {
31
+ toggle: c(() => [
32
+ i(t, {
33
+ modelValue: n.notBinding,
34
+ "onUpdate:modelValue": o[0] || (o[0] = (a) => n.notBinding = a)
35
+ }, null, 8, ["modelValue"])
36
+ ]),
37
+ _: 1
38
+ }, 8, ["display-value", "label"])
39
+ ]);
40
+ }
41
+ const I = /* @__PURE__ */ d(u, [["render", b]]);
42
+ export {
43
+ I as default
44
+ };
@@ -0,0 +1,134 @@
1
+ import { _ as y, m as x, V as v, y as w, au as b, b as p, o as r, d as i, s, B as k, v as l, F as u, k as _, e as c, w as C, f as $ } from "./main-C4OdoeS2.js";
2
+ import { _ as U } from "./Index.vue_vue_type_script_lang-DLogex2i.js";
3
+ const F = {
4
+ i18nOptions: {
5
+ namespaces: "uploadModal",
6
+ messages: {
7
+ sv: {
8
+ upPlaceholder: "Dra & släpp filer hit eller",
9
+ recentlyUsed: "Senast använda"
10
+ },
11
+ en: {
12
+ upPlaceholder: "Drag & drop files here or",
13
+ recentlyUsed: "Recently used"
14
+ }
15
+ }
16
+ },
17
+ name: "UploadModal",
18
+ components: {
19
+ FileIcon: U
20
+ },
21
+ emits: ["open-picker", "select"],
22
+ data() {
23
+ return {
24
+ recentFiles: [],
25
+ isLoading: !0
26
+ };
27
+ },
28
+ computed: {
29
+ ...x({
30
+ user: "application/user"
31
+ })
32
+ },
33
+ mounted() {
34
+ this.loadFiles();
35
+ },
36
+ methods: {
37
+ async loadFiles() {
38
+ var e;
39
+ this.isLoading = !0;
40
+ try {
41
+ const { data: o } = await v("/file", {
42
+ params: {
43
+ CompanyUserId: (e = this.user) == null ? void 0 : e.id,
44
+ _sort: "lastUsedAt",
45
+ _order: "DESC",
46
+ _start: 0,
47
+ _end: 20
48
+ }
49
+ });
50
+ this.recentFiles = (o || []).map(
51
+ ({ displayName: d, mime: h, id: n, createdAt: m, url: a }) => ({
52
+ name: d,
53
+ // TODO, could refactor to only 'displayName'
54
+ displayName: d,
55
+ // file-uploader-component uses displayName, therefore needed for select
56
+ mime: h,
57
+ id: n,
58
+ createdAt: m,
59
+ url: a
60
+ })
61
+ );
62
+ } catch (o) {
63
+ w(o);
64
+ } finally {
65
+ this.isLoading = !1;
66
+ }
67
+ },
68
+ onSelect(e) {
69
+ b(`/file/${e.id}/updateLastUsedAt`), this.$emit("select", e);
70
+ }
71
+ }
72
+ }, L = { class: "max-h-[90%] w-[460px] max-w-full rounded-xl bg-white text-base" }, P = { class: "p-6" }, D = { class: "text-primary-500 underline" }, I = {
73
+ key: 0,
74
+ class: "h-[400px] max-h-[50vh] overflow-auto border-t border-gray-200 pb-4 text-left"
75
+ }, S = { style: { "font-size": "15px", padding: "1em", margin: "0px 1em", color: "hsl(0, 0%, 30%)" } }, V = { class: "flex-grow" }, B = ["onClick"], z = { class: "truncate-text" }, A = {
76
+ class: "truncate-text",
77
+ style: { "font-weight": "500" }
78
+ }, E = { class: "up-recent-item-hint" };
79
+ function M(e, o, d, h, n, m) {
80
+ const a = p("ContentPlaceholdersText"), g = p("ContentPlaceholders"), f = p("FileIcon");
81
+ return r(), i("div", L, [
82
+ s("div", P, [
83
+ s("div", {
84
+ class: "hover:border-primary-500/20 cursor-pointer rounded-lg border border-gray-200 bg-gray-50 p-8 text-center text-gray-700 hover:bg-gray-100 active:bg-gray-200",
85
+ onClick: o[0] || (o[0] = (t) => e.$emit("open-picker"))
86
+ }, [
87
+ k(l(e.$t("upPlaceholder")) + " ", 1),
88
+ s("span", D, l(e.$t("_common:browse")), 1)
89
+ ])
90
+ ]),
91
+ n.isLoading || n.recentFiles.length ? (r(), i("div", I, [
92
+ s("div", S, l(e.$t("recentlyUsed")), 1),
93
+ n.isLoading ? (r(), i(u, { key: 0 }, _(6, (t) => c(g, {
94
+ key: t,
95
+ animated: !1,
96
+ class: "up-recent-item flex w-full items-center"
97
+ }, {
98
+ default: C(() => [
99
+ c(a, {
100
+ lines: 1,
101
+ style: { width: "37px", height: "38px", "font-size": "24px", "margin-right": "4px" }
102
+ }),
103
+ s("div", V, [
104
+ c(a, { lines: 1 }),
105
+ c(a, {
106
+ lines: 1,
107
+ class: "up-recent-item-hint",
108
+ style: { "max-width": "50%" }
109
+ })
110
+ ])
111
+ ]),
112
+ _: 2
113
+ }, 1024)), 64)) : (r(!0), i(u, { key: 1 }, _(n.recentFiles, (t) => (r(), i("div", {
114
+ key: t.id,
115
+ class: "up-recent-item flex w-full items-center",
116
+ onClick: (N) => m.onSelect(t)
117
+ }, [
118
+ c(f, {
119
+ mime: t.mime,
120
+ size: 30,
121
+ style: { "margin-right": "1em" }
122
+ }, null, 8, ["mime"]),
123
+ s("div", z, [
124
+ s("div", A, l(t.name), 1),
125
+ s("div", E, l(e.$formatDate(t.createdAt)), 1)
126
+ ])
127
+ ], 8, B))), 128))
128
+ ])) : $("", !0)
129
+ ]);
130
+ }
131
+ const O = /* @__PURE__ */ y(F, [["render", M], ["__scopeId", "data-v-d88c1700"]]);
132
+ export {
133
+ O as default
134
+ };
@@ -0,0 +1,135 @@
1
+ import { _ as p } from "./CFormField.vue_vue_type_script_setup_true_lang-B4s_Zfsp.js";
2
+ import { u as c } from "./index-8g2jwLJx.js";
3
+ import { d as V } from "./debounce-CBRJalZI.js";
4
+ import { v as h } from "./utils-vnvZGRwQ.js";
5
+ import { _ as v, b as i, o as y, c as _, w as o, e as d, S as g, B as w, v as C, l as x } from "./main-C4OdoeS2.js";
6
+ const D = {
7
+ name: "VideoPlayerInput",
8
+ i18nOptions: {
9
+ namespaces: "components",
10
+ keyPrefix: "document.videoPlayer"
11
+ },
12
+ components: {
13
+ CField: p
14
+ },
15
+ props: {
16
+ modelValue: {
17
+ type: Object,
18
+ default: () => ({})
19
+ },
20
+ isDrawerMode: {
21
+ type: Boolean,
22
+ default: !1
23
+ },
24
+ videoOptions: {
25
+ type: Object,
26
+ default: () => ({ background: !1 })
27
+ },
28
+ filled: {
29
+ type: Boolean,
30
+ default: !1
31
+ }
32
+ },
33
+ emits: ["update:modelValue"],
34
+ setup() {
35
+ return {
36
+ v$: c()
37
+ };
38
+ },
39
+ data() {
40
+ return {
41
+ isLoading: !1,
42
+ isValid: !1,
43
+ url: ""
44
+ };
45
+ },
46
+ validations() {
47
+ return {
48
+ url: {
49
+ isValid: () => this.isValid
50
+ }
51
+ };
52
+ },
53
+ computed: {
54
+ messages() {
55
+ return {
56
+ url: {
57
+ isValid: this.$t("validations.url.isValid")
58
+ }
59
+ };
60
+ }
61
+ },
62
+ created() {
63
+ this.modelValue && this.modelValue.url && (this.url = this.modelValue.url);
64
+ },
65
+ methods: {
66
+ onInput: V(function(e) {
67
+ this.v$.$reset(), this.isValid = !1, e && this.validateUrl(e);
68
+ }, 500),
69
+ async validateUrl(l) {
70
+ const e = l;
71
+ this.isLoading = !0;
72
+ const t = await h(e, this.videoOptions);
73
+ t && (this.isValid = !0, this.$emit("update:modelValue", t)), this.isLoading = !1, this.v$.$touch();
74
+ },
75
+ focus() {
76
+ this.$refs.input && this.$refs.input.focus();
77
+ }
78
+ }
79
+ };
80
+ function B(l, e, t, u, s, a) {
81
+ const m = i("CInput"), n = i("CField"), f = i("CButton");
82
+ return y(), _(n, {
83
+ grouped: !t.isDrawerMode,
84
+ style: x(
85
+ t.isDrawerMode && {
86
+ display: "flex",
87
+ flexDirection: "column",
88
+ alignItems: "flex-start"
89
+ }
90
+ )
91
+ }, {
92
+ default: o(() => [
93
+ d(n, {
94
+ validator: u.v$.url,
95
+ messages: a.messages.url,
96
+ expanded: "",
97
+ style: { width: "100%" }
98
+ }, {
99
+ default: o(() => [
100
+ d(m, {
101
+ ref: "input",
102
+ modelValue: s.url,
103
+ "onUpdate:modelValue": [
104
+ e[0] || (e[0] = (r) => s.url = r),
105
+ a.onInput
106
+ ],
107
+ placeholder: "https://www...",
108
+ size: t.isDrawerMode ? "small" : void 0,
109
+ loading: s.isLoading,
110
+ filled: t.filled || t.isDrawerMode,
111
+ expanded: ""
112
+ }, null, 8, ["modelValue", "size", "loading", "filled", "onUpdate:modelValue"])
113
+ ]),
114
+ _: 1
115
+ }, 8, ["validator", "messages"]),
116
+ g(l.$slots, "default", {}, () => [
117
+ d(f, {
118
+ size: t.isDrawerMode ? "small" : void 0,
119
+ type: "secondary",
120
+ onClick: e[1] || (e[1] = (r) => a.validateUrl(s.url))
121
+ }, {
122
+ default: o(() => [
123
+ w(C(l.$t("_common:add")), 1)
124
+ ]),
125
+ _: 1
126
+ }, 8, ["size"])
127
+ ])
128
+ ]),
129
+ _: 3
130
+ }, 8, ["grouped", "style"]);
131
+ }
132
+ const k = /* @__PURE__ */ v(D, [["render", B]]);
133
+ export {
134
+ k as default
135
+ };