@verdocs/web-sdk 5.0.44 → 5.0.45

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 (427) hide show
  1. package/dist/cjs/en-9bc0a0b3.js +35 -0
  2. package/dist/cjs/en-9bc0a0b3.js.map +1 -0
  3. package/dist/cjs/index-01ae8e85.js +4 -0
  4. package/dist/cjs/loader.cjs.js +1 -1
  5. package/dist/cjs/verdocs-button_2.cjs.entry.js +1 -1
  6. package/dist/cjs/verdocs-checkbox_6.cjs.entry.js +6 -6
  7. package/dist/cjs/verdocs-date-input.cjs.entry.js +85 -0
  8. package/dist/cjs/verdocs-date-input.cjs.entry.js.map +1 -0
  9. package/dist/cjs/verdocs-dialog.cjs.entry.js +1 -1
  10. package/dist/cjs/verdocs-envelope-document-page.cjs.entry.js +1 -1
  11. package/dist/cjs/verdocs-envelopes-list.cjs.entry.js +6 -6
  12. package/dist/cjs/verdocs-field-attachment_13.cjs.entry.js +8 -34
  13. package/dist/cjs/verdocs-field-attachment_13.cjs.entry.js.map +1 -1
  14. package/dist/cjs/verdocs-file-chooser_2.cjs.entry.js +2 -2
  15. package/dist/cjs/verdocs-kba-dialog_2.cjs.entry.js +25 -4
  16. package/dist/cjs/verdocs-kba-dialog_2.cjs.entry.js.map +1 -1
  17. package/dist/cjs/verdocs-menu-panel_2.cjs.entry.js +8 -8
  18. package/dist/cjs/verdocs-ok-dialog.cjs.entry.js +1 -1
  19. package/dist/cjs/verdocs-organization-card_2.cjs.entry.js +2 -2
  20. package/dist/cjs/verdocs-pagination_2.cjs.entry.js +1 -1
  21. package/dist/cjs/verdocs-quick-functions.cjs.entry.js +1 -1
  22. package/dist/cjs/verdocs-radio-button.cjs.entry.js +1 -1
  23. package/dist/cjs/verdocs-search-tabs.cjs.entry.js +1 -1
  24. package/dist/cjs/verdocs-sign.cjs.entry.js +1 -2
  25. package/dist/cjs/verdocs-sign.cjs.entry.js.map +1 -1
  26. package/dist/cjs/verdocs-spinner.cjs.entry.js +1 -1
  27. package/dist/cjs/verdocs-status-indicator.cjs.entry.js +2 -2
  28. package/dist/cjs/verdocs-switch.cjs.entry.js +2 -2
  29. package/dist/cjs/verdocs-template-card.cjs.entry.js +1 -1
  30. package/dist/cjs/verdocs-template-document-page_2.cjs.entry.js +1 -1
  31. package/dist/cjs/verdocs-template-star.cjs.entry.js +1 -1
  32. package/dist/cjs/verdocs-template-tags.cjs.entry.js +1 -1
  33. package/dist/cjs/verdocs-toggle-button.cjs.entry.js +1 -1
  34. package/dist/cjs/verdocs-web-sdk.cjs.js +1 -1
  35. package/dist/collection/collection-manifest.json +1 -0
  36. package/dist/collection/components/controls/verdocs-date-input/verdocs-date-input.css +98 -0
  37. package/dist/collection/components/controls/verdocs-date-input/verdocs-date-input.js +242 -0
  38. package/dist/collection/components/controls/verdocs-date-input/verdocs-date-input.js.map +1 -0
  39. package/dist/collection/components/controls/verdocs-file-chooser/verdocs-file-chooser.js +1 -1
  40. package/dist/collection/components/controls/verdocs-help-icon/verdocs-help-icon.js +1 -1
  41. package/dist/collection/components/controls/verdocs-loader/verdocs-loader.js +1 -1
  42. package/dist/collection/components/controls/verdocs-menu-panel/verdocs-menu-panel.js +1 -1
  43. package/dist/collection/components/controls/verdocs-organization-card/verdocs-organization-card.js +1 -1
  44. package/dist/collection/components/controls/verdocs-pagination/verdocs-pagination.js +1 -1
  45. package/dist/collection/components/controls/verdocs-portal/verdocs-portal.js +1 -1
  46. package/dist/collection/components/controls/verdocs-progress-bar/verdocs-progress-bar.js +1 -1
  47. package/dist/collection/components/controls/verdocs-radio-button/verdocs-radio-button.js +1 -1
  48. package/dist/collection/components/controls/verdocs-select-input/verdocs-select-input.js +1 -1
  49. package/dist/collection/components/controls/verdocs-spinner/verdocs-spinner.js +1 -1
  50. package/dist/collection/components/controls/verdocs-switch/verdocs-switch.js +2 -2
  51. package/dist/collection/components/controls/verdocs-text-input/verdocs-text-input.js +4 -4
  52. package/dist/collection/components/controls/verdocs-toggle-button/verdocs-toggle-button.js +1 -1
  53. package/dist/collection/components/controls/verdocs-toolbar-icon/verdocs-toolbar-icon.js +1 -1
  54. package/dist/collection/components/dialogs/verdocs-dialog/verdocs-dialog.js +1 -1
  55. package/dist/collection/components/dialogs/verdocs-initial-dialog/verdocs-initial-dialog.js +1 -1
  56. package/dist/collection/components/dialogs/verdocs-kba-dialog/verdocs-kba-dialog.css +8 -0
  57. package/dist/collection/components/dialogs/verdocs-kba-dialog/verdocs-kba-dialog.js +26 -4
  58. package/dist/collection/components/dialogs/verdocs-kba-dialog/verdocs-kba-dialog.js.map +1 -1
  59. package/dist/collection/components/dialogs/verdocs-ok-dialog/verdocs-ok-dialog.js +1 -1
  60. package/dist/collection/components/dialogs/verdocs-signature-dialog/verdocs-signature-dialog.js +1 -1
  61. package/dist/collection/components/dialogs/verdocs-upload-dialog/verdocs-upload-dialog.js +1 -1
  62. package/dist/collection/components/elements/verdocs-quick-functions/verdocs-quick-functions.js +1 -1
  63. package/dist/collection/components/elements/verdocs-search-tabs/verdocs-search-tabs.js +1 -1
  64. package/dist/collection/components/embeds/verdocs-sign/verdocs-sign.js +1 -2
  65. package/dist/collection/components/embeds/verdocs-sign/verdocs-sign.js.map +1 -1
  66. package/dist/collection/components/envelopes/verdocs-envelope-document-page/verdocs-envelope-document-page.js +1 -1
  67. package/dist/collection/components/envelopes/verdocs-envelopes-list/verdocs-envelopes-list.js +6 -6
  68. package/dist/collection/components/envelopes/verdocs-status-indicator/verdocs-status-indicator.js +2 -2
  69. package/dist/collection/components/fields/verdocs-field-date/verdocs-field-date.js +1 -0
  70. package/dist/collection/components/fields/verdocs-field-date/verdocs-field-date.js.map +1 -1
  71. package/dist/collection/components/templates/verdocs-template-card/verdocs-template-card.js +1 -1
  72. package/dist/collection/components/templates/verdocs-template-role-properties/verdocs-template-role-properties.js +7 -7
  73. package/dist/collection/components/templates/verdocs-template-star/verdocs-template-star.js +1 -1
  74. package/dist/collection/components/templates/verdocs-template-tags/verdocs-template-tags.js +1 -1
  75. package/dist/components/index.js +2 -0
  76. package/dist/components/index.js.map +1 -1
  77. package/dist/components/{p-444a3bdf.js → p-008472ce.js} +11 -11
  78. package/dist/components/{p-444a3bdf.js.map → p-008472ce.js.map} +1 -1
  79. package/dist/components/{p-bebd9b19.js → p-02f67734.js} +2 -2
  80. package/dist/components/{p-bebd9b19.js.map → p-02f67734.js.map} +1 -1
  81. package/dist/components/{p-81979fe6.js → p-06bacd3b.js} +2 -2
  82. package/dist/components/{p-81979fe6.js.map → p-06bacd3b.js.map} +1 -1
  83. package/dist/components/{p-4a04090c.js → p-0a14020a.js} +22 -22
  84. package/dist/components/{p-4a04090c.js.map → p-0a14020a.js.map} +1 -1
  85. package/dist/components/{p-d20bbc7d.js → p-0d7860de.js} +4 -4
  86. package/dist/components/{p-d20bbc7d.js.map → p-0d7860de.js.map} +1 -1
  87. package/dist/components/{p-d990000f.js → p-1354c984.js} +2 -2
  88. package/dist/components/{p-d990000f.js.map → p-1354c984.js.map} +1 -1
  89. package/dist/components/{p-710ca15d.js → p-18086502.js} +2 -2
  90. package/dist/components/{p-710ca15d.js.map → p-18086502.js.map} +1 -1
  91. package/dist/components/{p-44e14cb9.js → p-2985ae11.js} +2 -2
  92. package/dist/components/{p-44e14cb9.js.map → p-2985ae11.js.map} +1 -1
  93. package/dist/components/{p-51c8b927.js → p-2b0d2fbd.js} +4 -4
  94. package/dist/components/{p-51c8b927.js.map → p-2b0d2fbd.js.map} +1 -1
  95. package/dist/components/{p-6a8c32a6.js → p-3077aff3.js} +8 -8
  96. package/dist/components/{p-6a8c32a6.js.map → p-3077aff3.js.map} +1 -1
  97. package/dist/components/{p-92cce3dc.js → p-3ceeb122.js} +2 -210
  98. package/dist/components/p-3ceeb122.js.map +1 -0
  99. package/dist/components/{p-8af753b4.js → p-497ceba2.js} +2 -2
  100. package/dist/components/{p-8af753b4.js.map → p-497ceba2.js.map} +1 -1
  101. package/dist/components/{p-df227cfc.js → p-4a4de8d8.js} +7 -7
  102. package/dist/components/{p-df227cfc.js.map → p-4a4de8d8.js.map} +1 -1
  103. package/dist/components/{p-5faeacf0.js → p-4bcb364c.js} +2 -2
  104. package/dist/components/{p-5faeacf0.js.map → p-4bcb364c.js.map} +1 -1
  105. package/dist/components/{p-e85acbfb.js → p-4fff9f15.js} +7 -7
  106. package/dist/components/{p-e85acbfb.js.map → p-4fff9f15.js.map} +1 -1
  107. package/dist/components/{p-5d578b83.js → p-515f8afb.js} +7 -7
  108. package/dist/components/{p-5d578b83.js.map → p-515f8afb.js.map} +1 -1
  109. package/dist/components/{p-43b8738f.js → p-6507fba9.js} +5 -5
  110. package/dist/components/{p-43b8738f.js.map → p-6507fba9.js.map} +1 -1
  111. package/dist/components/{p-eb4bd2d6.js → p-71b30a91.js} +9 -9
  112. package/dist/components/{p-eb4bd2d6.js.map → p-71b30a91.js.map} +1 -1
  113. package/dist/components/{p-d89157e9.js → p-728ec158.js} +2 -2
  114. package/dist/components/{p-d89157e9.js.map → p-728ec158.js.map} +1 -1
  115. package/dist/components/{p-641e2cc0.js → p-73629a90.js} +3 -3
  116. package/dist/components/{p-641e2cc0.js.map → p-73629a90.js.map} +1 -1
  117. package/dist/components/{p-f7dc9e74.js → p-7f6c97d5.js} +2 -2
  118. package/dist/components/{p-f7dc9e74.js.map → p-7f6c97d5.js.map} +1 -1
  119. package/dist/components/{p-9a24561a.js → p-81e52989.js} +7 -7
  120. package/dist/components/{p-9a24561a.js.map → p-81e52989.js.map} +1 -1
  121. package/dist/components/{p-0a102a9c.js → p-83ecee53.js} +2 -2
  122. package/dist/components/{p-0a102a9c.js.map → p-83ecee53.js.map} +1 -1
  123. package/dist/components/{p-f776eeae.js → p-8e44cb14.js} +3 -3
  124. package/dist/components/{p-f776eeae.js.map → p-8e44cb14.js.map} +1 -1
  125. package/dist/components/{p-4ab3413a.js → p-9c650a78.js} +7 -7
  126. package/dist/components/{p-4ab3413a.js.map → p-9c650a78.js.map} +1 -1
  127. package/dist/components/{p-08ddf0b4.js → p-a5c69199.js} +6 -6
  128. package/dist/components/{p-08ddf0b4.js.map → p-a5c69199.js.map} +1 -1
  129. package/dist/components/{p-4a4bf38c.js → p-a808fcb1.js} +6 -6
  130. package/dist/components/{p-4a4bf38c.js.map → p-a808fcb1.js.map} +1 -1
  131. package/dist/components/{p-1a83e46c.js → p-a8f59e9d.js} +7 -7
  132. package/dist/components/{p-1a83e46c.js.map → p-a8f59e9d.js.map} +1 -1
  133. package/dist/components/{p-ca16a8ac.js → p-acb41a2e.js} +2 -2
  134. package/dist/components/{p-ca16a8ac.js.map → p-acb41a2e.js.map} +1 -1
  135. package/dist/components/{p-321e2d4e.js → p-b4eee1ed.js} +28 -6
  136. package/dist/components/p-b4eee1ed.js.map +1 -0
  137. package/dist/components/{p-91eae04c.js → p-b9ec1278.js} +23 -23
  138. package/dist/components/{p-91eae04c.js.map → p-b9ec1278.js.map} +1 -1
  139. package/dist/components/{p-f66d6a07.js → p-bcbe0f6b.js} +8 -8
  140. package/dist/components/{p-f66d6a07.js.map → p-bcbe0f6b.js.map} +1 -1
  141. package/dist/components/{p-b474c324.js → p-bfa07825.js} +21 -21
  142. package/dist/components/{p-b474c324.js.map → p-bfa07825.js.map} +1 -1
  143. package/dist/components/{p-4dbb9783.js → p-c696e5d7.js} +5 -5
  144. package/dist/components/{p-4dbb9783.js.map → p-c696e5d7.js.map} +1 -1
  145. package/dist/components/{p-61a2c23a.js → p-cb2e0f23.js} +2 -2
  146. package/dist/components/{p-61a2c23a.js.map → p-cb2e0f23.js.map} +1 -1
  147. package/dist/components/{p-73a39d5a.js → p-ccbd93c3.js} +3 -3
  148. package/dist/components/{p-73a39d5a.js.map → p-ccbd93c3.js.map} +1 -1
  149. package/dist/components/{p-0e454650.js → p-cf95858b.js} +7 -7
  150. package/dist/components/{p-0e454650.js.map → p-cf95858b.js.map} +1 -1
  151. package/dist/components/p-d47ac4f2.js +214 -0
  152. package/dist/components/p-d47ac4f2.js.map +1 -0
  153. package/dist/components/{p-54e4bcee.js → p-d5eae4db.js} +2 -2
  154. package/dist/components/{p-54e4bcee.js.map → p-d5eae4db.js.map} +1 -1
  155. package/dist/components/{p-581128fe.js → p-e098ba1d.js} +6 -6
  156. package/dist/components/{p-581128fe.js.map → p-e098ba1d.js.map} +1 -1
  157. package/dist/components/{p-57db7635.js → p-ec06fbd7.js} +2 -2
  158. package/dist/components/{p-57db7635.js.map → p-ec06fbd7.js.map} +1 -1
  159. package/dist/components/{p-081465e0.js → p-ed777fb7.js} +2 -2
  160. package/dist/components/{p-081465e0.js.map → p-ed777fb7.js.map} +1 -1
  161. package/dist/components/{p-e1b7ca10.js → p-ef2df3fa.js} +3 -3
  162. package/dist/components/{p-e1b7ca10.js.map → p-ef2df3fa.js.map} +1 -1
  163. package/dist/components/{p-a50f7982.js → p-f303f8bf.js} +2 -2
  164. package/dist/components/{p-a50f7982.js.map → p-f303f8bf.js.map} +1 -1
  165. package/dist/components/{p-55edf913.js → p-fcfbb327.js} +6 -6
  166. package/dist/components/{p-55edf913.js.map → p-fcfbb327.js.map} +1 -1
  167. package/dist/components/verdocs-auth.js +2 -2
  168. package/dist/components/verdocs-build.js +37 -37
  169. package/dist/components/verdocs-contact-picker.js +1 -1
  170. package/dist/components/verdocs-date-input.d.ts +11 -0
  171. package/dist/components/verdocs-date-input.js +114 -0
  172. package/dist/components/verdocs-date-input.js.map +1 -0
  173. package/dist/components/verdocs-dialog.js +1 -1
  174. package/dist/components/verdocs-dropdown.js +1 -1
  175. package/dist/components/verdocs-envelope-document-page.js +1 -1
  176. package/dist/components/verdocs-envelope-sidebar.js +6 -6
  177. package/dist/components/verdocs-envelopes-list.js +13 -13
  178. package/dist/components/verdocs-field-attachment.js +1 -1
  179. package/dist/components/verdocs-field-checkbox.js +1 -1
  180. package/dist/components/verdocs-field-date.js +1 -1
  181. package/dist/components/verdocs-field-dropdown.js +1 -1
  182. package/dist/components/verdocs-field-initial.js +1 -1
  183. package/dist/components/verdocs-field-payment.js +6 -6
  184. package/dist/components/verdocs-field-radio.js +1 -1
  185. package/dist/components/verdocs-field-signature.js +1 -1
  186. package/dist/components/verdocs-field-textarea.js +1 -1
  187. package/dist/components/verdocs-field-textbox.js +1 -1
  188. package/dist/components/verdocs-field-timestamp.js +1 -1
  189. package/dist/components/verdocs-file-chooser.js +1 -1
  190. package/dist/components/verdocs-help-icon.js +1 -1
  191. package/dist/components/verdocs-initial-dialog.js +1 -1
  192. package/dist/components/verdocs-kba-dialog.js +1 -1
  193. package/dist/components/verdocs-loader.js +1 -1
  194. package/dist/components/verdocs-menu-panel.js +1 -1
  195. package/dist/components/verdocs-multiselect.js +1 -1
  196. package/dist/components/verdocs-ok-dialog.js +1 -1
  197. package/dist/components/verdocs-organization-card.js +2 -2
  198. package/dist/components/verdocs-pagination.js +1 -1
  199. package/dist/components/verdocs-portal.js +1 -1
  200. package/dist/components/verdocs-preview.js +1 -1
  201. package/dist/components/verdocs-progress-bar.js +1 -1
  202. package/dist/components/verdocs-quick-functions.js +1 -1
  203. package/dist/components/verdocs-radio-button.js +1 -1
  204. package/dist/components/verdocs-search-tabs.js +1 -1
  205. package/dist/components/verdocs-select-input.js +1 -1
  206. package/dist/components/verdocs-send.js +1 -1
  207. package/dist/components/verdocs-sign.js +9 -10
  208. package/dist/components/verdocs-sign.js.map +1 -1
  209. package/dist/components/verdocs-signature-dialog.js +1 -1
  210. package/dist/components/verdocs-spinner.js +1 -1
  211. package/dist/components/verdocs-status-indicator.js +1 -1
  212. package/dist/components/verdocs-switch.js +1 -1
  213. package/dist/components/verdocs-template-attachments.js +1 -1
  214. package/dist/components/verdocs-template-build-tabs.js +1 -1
  215. package/dist/components/verdocs-template-card.js +1 -1
  216. package/dist/components/verdocs-template-create.js +2 -2
  217. package/dist/components/verdocs-template-document-page.js +1 -1
  218. package/dist/components/verdocs-template-field-properties.js +1 -1
  219. package/dist/components/verdocs-template-fields.js +1 -1
  220. package/dist/components/verdocs-template-role-properties.js +1 -1
  221. package/dist/components/verdocs-template-roles.js +1 -1
  222. package/dist/components/verdocs-template-settings.js +1 -1
  223. package/dist/components/verdocs-template-star.js +1 -1
  224. package/dist/components/verdocs-template-tags.js +1 -1
  225. package/dist/components/verdocs-templates-list.js +8 -8
  226. package/dist/components/verdocs-text-input.js +1 -1
  227. package/dist/components/verdocs-toggle-button.js +1 -1
  228. package/dist/components/verdocs-toolbar-icon.js +1 -1
  229. package/dist/components/verdocs-upload-dialog.js +1 -1
  230. package/dist/components/verdocs-view.js +1 -1
  231. package/dist/custom-elements.json +2231 -0
  232. package/dist/esm/en-03eb67b8.js +33 -0
  233. package/dist/esm/en-03eb67b8.js.map +1 -0
  234. package/dist/esm/index-2cd5f887.js +4 -0
  235. package/dist/esm/loader.js +1 -1
  236. package/dist/esm/verdocs-button_2.entry.js +1 -1
  237. package/dist/esm/verdocs-checkbox_6.entry.js +6 -6
  238. package/dist/esm/verdocs-date-input.entry.js +81 -0
  239. package/dist/esm/verdocs-date-input.entry.js.map +1 -0
  240. package/dist/esm/verdocs-dialog.entry.js +1 -1
  241. package/dist/esm/verdocs-envelope-document-page.entry.js +1 -1
  242. package/dist/esm/verdocs-envelopes-list.entry.js +6 -6
  243. package/dist/esm/verdocs-field-attachment_13.entry.js +6 -32
  244. package/dist/esm/verdocs-field-attachment_13.entry.js.map +1 -1
  245. package/dist/esm/verdocs-file-chooser_2.entry.js +2 -2
  246. package/dist/esm/verdocs-kba-dialog_2.entry.js +25 -4
  247. package/dist/esm/verdocs-kba-dialog_2.entry.js.map +1 -1
  248. package/dist/esm/verdocs-menu-panel_2.entry.js +8 -8
  249. package/dist/esm/verdocs-ok-dialog.entry.js +1 -1
  250. package/dist/esm/verdocs-organization-card_2.entry.js +2 -2
  251. package/dist/esm/verdocs-pagination_2.entry.js +1 -1
  252. package/dist/esm/verdocs-quick-functions.entry.js +1 -1
  253. package/dist/esm/verdocs-radio-button.entry.js +1 -1
  254. package/dist/esm/verdocs-search-tabs.entry.js +1 -1
  255. package/dist/esm/verdocs-sign.entry.js +1 -2
  256. package/dist/esm/verdocs-sign.entry.js.map +1 -1
  257. package/dist/esm/verdocs-spinner.entry.js +1 -1
  258. package/dist/esm/verdocs-status-indicator.entry.js +2 -2
  259. package/dist/esm/verdocs-switch.entry.js +2 -2
  260. package/dist/esm/verdocs-template-card.entry.js +1 -1
  261. package/dist/esm/verdocs-template-document-page_2.entry.js +1 -1
  262. package/dist/esm/verdocs-template-star.entry.js +1 -1
  263. package/dist/esm/verdocs-template-tags.entry.js +1 -1
  264. package/dist/esm/verdocs-toggle-button.entry.js +1 -1
  265. package/dist/esm/verdocs-web-sdk.js +1 -1
  266. package/dist/esm-es5/en-03eb67b8.js +2 -0
  267. package/dist/esm-es5/en-03eb67b8.js.map +1 -0
  268. package/dist/esm-es5/index-2cd5f887.js +1 -1
  269. package/dist/esm-es5/index-2cd5f887.js.map +1 -1
  270. package/dist/esm-es5/loader.js +1 -1
  271. package/dist/esm-es5/loader.js.map +1 -1
  272. package/dist/esm-es5/verdocs-button_2.entry.js +1 -1
  273. package/dist/esm-es5/verdocs-checkbox_6.entry.js +1 -1
  274. package/dist/esm-es5/verdocs-date-input.entry.js +2 -0
  275. package/dist/esm-es5/verdocs-date-input.entry.js.map +1 -0
  276. package/dist/esm-es5/verdocs-dialog.entry.js +1 -1
  277. package/dist/esm-es5/verdocs-envelope-document-page.entry.js +1 -1
  278. package/dist/esm-es5/verdocs-envelopes-list.entry.js +1 -1
  279. package/dist/esm-es5/verdocs-field-attachment_13.entry.js +1 -1
  280. package/dist/esm-es5/verdocs-field-attachment_13.entry.js.map +1 -1
  281. package/dist/esm-es5/verdocs-file-chooser_2.entry.js +1 -1
  282. package/dist/esm-es5/verdocs-kba-dialog_2.entry.js +1 -1
  283. package/dist/esm-es5/verdocs-kba-dialog_2.entry.js.map +1 -1
  284. package/dist/esm-es5/verdocs-menu-panel_2.entry.js +1 -1
  285. package/dist/esm-es5/verdocs-ok-dialog.entry.js +1 -1
  286. package/dist/esm-es5/verdocs-organization-card_2.entry.js +1 -1
  287. package/dist/esm-es5/verdocs-pagination_2.entry.js +1 -1
  288. package/dist/esm-es5/verdocs-quick-functions.entry.js +1 -1
  289. package/dist/esm-es5/verdocs-radio-button.entry.js +1 -1
  290. package/dist/esm-es5/verdocs-search-tabs.entry.js +1 -1
  291. package/dist/esm-es5/verdocs-sign.entry.js +1 -1
  292. package/dist/esm-es5/verdocs-sign.entry.js.map +1 -1
  293. package/dist/esm-es5/verdocs-spinner.entry.js +1 -1
  294. package/dist/esm-es5/verdocs-status-indicator.entry.js +1 -1
  295. package/dist/esm-es5/verdocs-switch.entry.js +1 -1
  296. package/dist/esm-es5/verdocs-template-card.entry.js +1 -1
  297. package/dist/esm-es5/verdocs-template-document-page_2.entry.js +1 -1
  298. package/dist/esm-es5/verdocs-template-star.entry.js +1 -1
  299. package/dist/esm-es5/verdocs-template-tags.entry.js +1 -1
  300. package/dist/esm-es5/verdocs-toggle-button.entry.js +1 -1
  301. package/dist/esm-es5/verdocs-web-sdk.js +1 -1
  302. package/dist/esm-es5/verdocs-web-sdk.js.map +1 -1
  303. package/dist/types/components/controls/verdocs-date-input/verdocs-date-input.d.ts +43 -0
  304. package/dist/types/components/dialogs/verdocs-kba-dialog/verdocs-kba-dialog.d.ts +3 -1
  305. package/dist/types/components.d.ts +86 -0
  306. package/dist/verdocs-web-sdk/p-0758647e.system.js +2 -0
  307. package/dist/verdocs-web-sdk/p-0758647e.system.js.map +1 -0
  308. package/dist/verdocs-web-sdk/{p-0e485d1a.system.entry.js → p-0974b1cf.system.entry.js} +2 -2
  309. package/dist/verdocs-web-sdk/p-0c1898f6.system.js +1 -1
  310. package/dist/verdocs-web-sdk/p-0c1898f6.system.js.map +1 -1
  311. package/dist/verdocs-web-sdk/{p-96ca1ce2.entry.js → p-11a30de3.entry.js} +2 -2
  312. package/dist/verdocs-web-sdk/p-158808e1.entry.js +2 -0
  313. package/dist/verdocs-web-sdk/{p-b0606620.entry.js.map → p-158808e1.entry.js.map} +1 -1
  314. package/dist/verdocs-web-sdk/{p-644444fe.system.entry.js → p-19ee9379.system.entry.js} +2 -2
  315. package/dist/verdocs-web-sdk/p-1f8bd27c.system.entry.js +2 -0
  316. package/dist/verdocs-web-sdk/p-1f8bd27c.system.entry.js.map +1 -0
  317. package/dist/verdocs-web-sdk/{p-5a639d78.system.entry.js → p-248ffe5c.system.entry.js} +2 -2
  318. package/dist/verdocs-web-sdk/{p-e5719bcf.system.entry.js → p-2d0e964b.system.entry.js} +2 -2
  319. package/dist/verdocs-web-sdk/{p-a508388a.system.entry.js → p-2d2c8ad7.system.entry.js} +2 -2
  320. package/dist/verdocs-web-sdk/{p-06394c15.system.entry.js → p-2d35f678.system.entry.js} +2 -2
  321. package/dist/verdocs-web-sdk/{p-923cc826.entry.js → p-2edf05fe.entry.js} +2 -2
  322. package/dist/verdocs-web-sdk/{p-d8e59850.entry.js → p-344ff0ba.entry.js} +2 -2
  323. package/dist/verdocs-web-sdk/{p-af9cc642.entry.js → p-35fc5f53.entry.js} +2 -2
  324. package/dist/verdocs-web-sdk/{p-1f42a7c2.entry.js → p-3a2bd43c.entry.js} +2 -2
  325. package/dist/verdocs-web-sdk/{p-82c88c0f.entry.js → p-3cc309a8.entry.js} +2 -2
  326. package/dist/verdocs-web-sdk/p-3ceeb122.js +2 -0
  327. package/dist/verdocs-web-sdk/p-3ceeb122.js.map +1 -0
  328. package/dist/verdocs-web-sdk/p-3fc80e05.entry.js +2 -0
  329. package/dist/verdocs-web-sdk/p-3fc80e05.entry.js.map +1 -0
  330. package/dist/verdocs-web-sdk/{p-ba7f0fce.system.entry.js → p-45dd5527.system.entry.js} +2 -2
  331. package/dist/verdocs-web-sdk/{p-f9aaeb81.system.entry.js → p-50e49464.system.entry.js} +2 -2
  332. package/dist/verdocs-web-sdk/p-66ca774d.entry.js +2 -0
  333. package/dist/verdocs-web-sdk/p-66ca774d.entry.js.map +1 -0
  334. package/dist/verdocs-web-sdk/{p-00b95f75.system.entry.js → p-6ddcf3fe.system.entry.js} +2 -2
  335. package/dist/verdocs-web-sdk/{p-517a9262.entry.js → p-7b0281af.entry.js} +2 -2
  336. package/dist/verdocs-web-sdk/{p-df70c2ea.entry.js → p-7e0fa3ae.entry.js} +2 -2
  337. package/dist/verdocs-web-sdk/{p-ab23e446.entry.js → p-7f1edca3.entry.js} +2 -2
  338. package/dist/verdocs-web-sdk/{p-9f2cb0de.entry.js → p-840b6fbe.entry.js} +2 -2
  339. package/dist/verdocs-web-sdk/p-88f4ee7b.system.entry.js +2 -0
  340. package/dist/verdocs-web-sdk/p-88f4ee7b.system.entry.js.map +1 -0
  341. package/dist/verdocs-web-sdk/{p-2df97f4e.entry.js → p-8ec57eff.entry.js} +2 -2
  342. package/dist/verdocs-web-sdk/{p-fb577d62.system.entry.js → p-9363cc19.system.entry.js} +2 -2
  343. package/dist/verdocs-web-sdk/{p-f9d56a3c.entry.js → p-9a19e851.entry.js} +2 -2
  344. package/dist/verdocs-web-sdk/{p-36a10b78.system.entry.js → p-9ccbbb22.system.entry.js} +2 -2
  345. package/dist/verdocs-web-sdk/p-9f684d65.entry.js +2 -0
  346. package/dist/verdocs-web-sdk/p-9f684d65.entry.js.map +1 -0
  347. package/dist/verdocs-web-sdk/{p-a1f9578c.system.entry.js → p-a75f7e9e.system.entry.js} +2 -2
  348. package/dist/verdocs-web-sdk/{p-d2a9d5cf.system.entry.js → p-ad9dd116.system.entry.js} +2 -2
  349. package/dist/verdocs-web-sdk/{p-ac10a0b5.system.entry.js → p-b0220f11.system.entry.js} +2 -2
  350. package/dist/verdocs-web-sdk/{p-9a955b58.system.entry.js → p-b43ede8b.system.entry.js} +2 -2
  351. package/dist/verdocs-web-sdk/{p-ad04e403.system.entry.js → p-bd7b3d7b.system.entry.js} +2 -2
  352. package/dist/verdocs-web-sdk/{p-330c1f00.entry.js → p-c3e2d722.entry.js} +2 -2
  353. package/dist/verdocs-web-sdk/{p-2ce5fef0.system.entry.js → p-c7f2bac2.system.entry.js} +2 -2
  354. package/dist/verdocs-web-sdk/p-c7f2bac2.system.entry.js.map +1 -0
  355. package/dist/verdocs-web-sdk/{p-c397c96b.system.entry.js → p-c9ec99df.system.entry.js} +2 -2
  356. package/dist/verdocs-web-sdk/{p-79a1bf39.entry.js → p-cb0b6e3e.entry.js} +2 -2
  357. package/dist/verdocs-web-sdk/p-cb0b6e3e.entry.js.map +1 -0
  358. package/dist/verdocs-web-sdk/{p-b32c8a43.entry.js → p-cf413e96.entry.js} +2 -2
  359. package/dist/verdocs-web-sdk/{p-5fd67b04.system.entry.js → p-d67c3a58.system.entry.js} +2 -2
  360. package/dist/verdocs-web-sdk/{p-2c9254a9.entry.js → p-d7cafbfe.entry.js} +2 -2
  361. package/dist/verdocs-web-sdk/{p-2415315d.entry.js → p-dea4b888.entry.js} +2 -2
  362. package/dist/verdocs-web-sdk/{p-866d2139.entry.js → p-e388f2eb.entry.js} +2 -2
  363. package/dist/verdocs-web-sdk/{p-195cd4f4.system.entry.js → p-e8184f76.system.entry.js} +2 -2
  364. package/dist/verdocs-web-sdk/{p-ca45c312.entry.js → p-e8c4cb36.entry.js} +2 -2
  365. package/dist/verdocs-web-sdk/{p-66438012.system.entry.js → p-ebec3bc1.system.entry.js} +2 -2
  366. package/dist/verdocs-web-sdk/{p-af41b404.entry.js → p-ed106cc9.entry.js} +2 -2
  367. package/dist/verdocs-web-sdk/{p-dac155a6.system.entry.js → p-f3d09408.system.entry.js} +2 -2
  368. package/dist/verdocs-web-sdk/p-f6bf7e6a.system.entry.js +2 -0
  369. package/dist/verdocs-web-sdk/p-f6bf7e6a.system.entry.js.map +1 -0
  370. package/dist/verdocs-web-sdk/{p-e43a184d.entry.js → p-fc79bf91.entry.js} +2 -2
  371. package/dist/verdocs-web-sdk/verdocs-web-sdk.esm.js +1 -1
  372. package/dist/verdocs-web-sdk/verdocs-web-sdk.esm.js.map +1 -1
  373. package/package.json +1 -1
  374. package/dist/components/p-321e2d4e.js.map +0 -1
  375. package/dist/components/p-92cce3dc.js.map +0 -1
  376. package/dist/verdocs-web-sdk/p-2ce5fef0.system.entry.js.map +0 -1
  377. package/dist/verdocs-web-sdk/p-6cfb51e3.system.entry.js +0 -2
  378. package/dist/verdocs-web-sdk/p-6cfb51e3.system.entry.js.map +0 -1
  379. package/dist/verdocs-web-sdk/p-78d9fa52.system.entry.js +0 -2
  380. package/dist/verdocs-web-sdk/p-78d9fa52.system.entry.js.map +0 -1
  381. package/dist/verdocs-web-sdk/p-79a1bf39.entry.js.map +0 -1
  382. package/dist/verdocs-web-sdk/p-b0606620.entry.js +0 -2
  383. package/dist/verdocs-web-sdk/p-dac04f8e.entry.js +0 -2
  384. package/dist/verdocs-web-sdk/p-dac04f8e.entry.js.map +0 -1
  385. package/dist/verdocs-web-sdk/p-e7ca4f15.entry.js +0 -2
  386. package/dist/verdocs-web-sdk/p-e7ca4f15.entry.js.map +0 -1
  387. /package/dist/verdocs-web-sdk/{p-0e485d1a.system.entry.js.map → p-0974b1cf.system.entry.js.map} +0 -0
  388. /package/dist/verdocs-web-sdk/{p-96ca1ce2.entry.js.map → p-11a30de3.entry.js.map} +0 -0
  389. /package/dist/verdocs-web-sdk/{p-644444fe.system.entry.js.map → p-19ee9379.system.entry.js.map} +0 -0
  390. /package/dist/verdocs-web-sdk/{p-5a639d78.system.entry.js.map → p-248ffe5c.system.entry.js.map} +0 -0
  391. /package/dist/verdocs-web-sdk/{p-e5719bcf.system.entry.js.map → p-2d0e964b.system.entry.js.map} +0 -0
  392. /package/dist/verdocs-web-sdk/{p-a508388a.system.entry.js.map → p-2d2c8ad7.system.entry.js.map} +0 -0
  393. /package/dist/verdocs-web-sdk/{p-06394c15.system.entry.js.map → p-2d35f678.system.entry.js.map} +0 -0
  394. /package/dist/verdocs-web-sdk/{p-923cc826.entry.js.map → p-2edf05fe.entry.js.map} +0 -0
  395. /package/dist/verdocs-web-sdk/{p-d8e59850.entry.js.map → p-344ff0ba.entry.js.map} +0 -0
  396. /package/dist/verdocs-web-sdk/{p-af9cc642.entry.js.map → p-35fc5f53.entry.js.map} +0 -0
  397. /package/dist/verdocs-web-sdk/{p-1f42a7c2.entry.js.map → p-3a2bd43c.entry.js.map} +0 -0
  398. /package/dist/verdocs-web-sdk/{p-82c88c0f.entry.js.map → p-3cc309a8.entry.js.map} +0 -0
  399. /package/dist/verdocs-web-sdk/{p-ba7f0fce.system.entry.js.map → p-45dd5527.system.entry.js.map} +0 -0
  400. /package/dist/verdocs-web-sdk/{p-f9aaeb81.system.entry.js.map → p-50e49464.system.entry.js.map} +0 -0
  401. /package/dist/verdocs-web-sdk/{p-00b95f75.system.entry.js.map → p-6ddcf3fe.system.entry.js.map} +0 -0
  402. /package/dist/verdocs-web-sdk/{p-517a9262.entry.js.map → p-7b0281af.entry.js.map} +0 -0
  403. /package/dist/verdocs-web-sdk/{p-df70c2ea.entry.js.map → p-7e0fa3ae.entry.js.map} +0 -0
  404. /package/dist/verdocs-web-sdk/{p-ab23e446.entry.js.map → p-7f1edca3.entry.js.map} +0 -0
  405. /package/dist/verdocs-web-sdk/{p-9f2cb0de.entry.js.map → p-840b6fbe.entry.js.map} +0 -0
  406. /package/dist/verdocs-web-sdk/{p-2df97f4e.entry.js.map → p-8ec57eff.entry.js.map} +0 -0
  407. /package/dist/verdocs-web-sdk/{p-fb577d62.system.entry.js.map → p-9363cc19.system.entry.js.map} +0 -0
  408. /package/dist/verdocs-web-sdk/{p-f9d56a3c.entry.js.map → p-9a19e851.entry.js.map} +0 -0
  409. /package/dist/verdocs-web-sdk/{p-36a10b78.system.entry.js.map → p-9ccbbb22.system.entry.js.map} +0 -0
  410. /package/dist/verdocs-web-sdk/{p-a1f9578c.system.entry.js.map → p-a75f7e9e.system.entry.js.map} +0 -0
  411. /package/dist/verdocs-web-sdk/{p-d2a9d5cf.system.entry.js.map → p-ad9dd116.system.entry.js.map} +0 -0
  412. /package/dist/verdocs-web-sdk/{p-ac10a0b5.system.entry.js.map → p-b0220f11.system.entry.js.map} +0 -0
  413. /package/dist/verdocs-web-sdk/{p-9a955b58.system.entry.js.map → p-b43ede8b.system.entry.js.map} +0 -0
  414. /package/dist/verdocs-web-sdk/{p-ad04e403.system.entry.js.map → p-bd7b3d7b.system.entry.js.map} +0 -0
  415. /package/dist/verdocs-web-sdk/{p-330c1f00.entry.js.map → p-c3e2d722.entry.js.map} +0 -0
  416. /package/dist/verdocs-web-sdk/{p-c397c96b.system.entry.js.map → p-c9ec99df.system.entry.js.map} +0 -0
  417. /package/dist/verdocs-web-sdk/{p-b32c8a43.entry.js.map → p-cf413e96.entry.js.map} +0 -0
  418. /package/dist/verdocs-web-sdk/{p-5fd67b04.system.entry.js.map → p-d67c3a58.system.entry.js.map} +0 -0
  419. /package/dist/verdocs-web-sdk/{p-2c9254a9.entry.js.map → p-d7cafbfe.entry.js.map} +0 -0
  420. /package/dist/verdocs-web-sdk/{p-2415315d.entry.js.map → p-dea4b888.entry.js.map} +0 -0
  421. /package/dist/verdocs-web-sdk/{p-866d2139.entry.js.map → p-e388f2eb.entry.js.map} +0 -0
  422. /package/dist/verdocs-web-sdk/{p-195cd4f4.system.entry.js.map → p-e8184f76.system.entry.js.map} +0 -0
  423. /package/dist/verdocs-web-sdk/{p-ca45c312.entry.js.map → p-e8c4cb36.entry.js.map} +0 -0
  424. /package/dist/verdocs-web-sdk/{p-66438012.system.entry.js.map → p-ebec3bc1.system.entry.js.map} +0 -0
  425. /package/dist/verdocs-web-sdk/{p-af41b404.entry.js.map → p-ed106cc9.entry.js.map} +0 -0
  426. /package/dist/verdocs-web-sdk/{p-dac155a6.system.entry.js.map → p-f3d09408.system.entry.js.map} +0 -0
  427. /package/dist/verdocs-web-sdk/{p-e43a184d.entry.js.map → p-fc79bf91.entry.js.map} +0 -0
@@ -1 +1 @@
1
- {"version":3,"names":["verdocsFieldAttachmentCss","VerdocsFieldAttachmentStyle0","PaperclipIcon","AttachedIcon","VerdocsFieldAttachment","class_1","hostRef","_this","this","endpoint","VerdocsEndpoint","getDefault","source","sourceid","fieldname","field","disabled","editable","moveable","done","xscale","yscale","pagenumber","showingProperties","dialogOpen","selectedFile","focused","handleUploadNext","e","console","log","detail","_a","attached","emit","handleUploadRemove","preventDefault","stopPropagation","deleted","fieldName","prototype","focusField","setTimeout","showSettingsPanel","settingsPanel","document","getElementById","concat","showPanel","hideSettingsPanel","hidePanel","handleShow","render","_b","_c","_d","_e","_f","_g","_h","Store","getField","index","_j","_k","required","_l","value","_m","label","_o","settings","backgroundColor","getRGBA","hasFile","h","Host","class","innerHTML","style","onClick","Fragment","id","transform","Math","floor","SettingsIcon","anchor","onClickAway","templateId","onClose","onDelete","onSettingsChanged","settingsChanged","helpText","existingFile","onNext","onRemove","onExit","verdocsFieldCheckboxCss","VerdocsFieldCheckboxStyle0","VerdocsFieldCheckbox","class_2","checked","htmlFor","name","type","t","module","exports","d","i","s","o","Object","defineProperty","enumerable","get","hasOwnProperty","call","default","R","days","months","years","day","month","year","eventChangeViewDate","eventChangeCurrentView","eventChangeFocusDate","eventChangeSelectedDate","eventChangeTime","eventChangeLastSelectedDate","actionSelectDate","actionUnselectDate","cssClassWeekend","classes","inline","locale","daysShort","daysMin","monthsShort","today","clear","dateFormat","timeFormat","firstDay","startDate","Date","weekends","altField","altFieldDateFormat","toggleSelected","keyboardNav","selectedDates","container","isMobile","visible","position","offset","view","minView","showOtherMonths","selectOtherMonths","moveToOtherMonthsOnSelect","showOtherYears","selectOtherYears","moveToOtherYearsOnSelect","minDate","maxDate","disableNavWhenOutOfRange","multipleDates","multipleDatesSeparator","range","dynamicRange","buttons","monthsField","showEvent","autoClose","fixedHeight","prevHtml","nextHtml","navTitles","timepicker","onlyTimepicker","dateTimeSeparator","minHours","maxHours","minMinutes","maxMinutes","hoursStep","minutesStep","onSelect","onChangeViewDate","onChangeView","onRenderCell","onShow","onHide","onClickDayName","a","arguments","length","querySelector","n","tagName","className","innerHtml","attrs","createElement","classList","add","apply","split","r","_i","entries","i_1","s_1","setAttribute","getFullYear","getMonth","getDate","getHours","l","hours","dayPeriod","fullMonth","date","fullDate","getDay","fullHours","hours12","fullHours12","minutes","getMinutes","fullMinutes","c","u","Array","forEach","i_2","push","join","p","m","g","getTime","v","setHours","D","addEventListener","y","DocumentFragment","matches","parentNode","f","w","filter","i_3","s_2","toString","t_1","a_1","n_1","isArray","b","test","isNaN","k","RegExp","$","Symbol","toPrimitive","TypeError","String","configurable","writable","C","dp","opts","body","$cell","remove","selected","isDisabled","_handleSelectedStatus","_handleRangeStatus","removeFocus","focus","_getHtml","_handleClasses","singleType","slice","customData","init","cellType","datepicker","_createElement","_bindDatepickerEvents","disableDate","on","onChangeSelectedDate","onChangeFocusDate","unbindDatepickerEvents","off","__assign","adpCell","_getClassName","isDateDisabled","_isOutOfMinMaxRange","isWeekend","isOtherMonth","isOtherDecade","html","destroy","focusDate","rangeDateTo","rangeDateFrom","i_4","_checkIfDateIsSelected","select","removeSelect","_handleInitialFocusStatus","hasSelectedDates","_","M","S","T","target","closest","isMinViewReached","down","_handleAlreadySelectedDates","selectDate","getAttribute","dayIndex","Number","hide","show","setFocusDate","handleClick","handleDayNameClick","pressed","rangeFromFocused","rangeToFocused","e_1","t_2","setMinutes","replaceDate","e_2","t_3","isVisible","currentView","destroyCells","_generateCells","cells","$cells","appendChild","$el","_buildBaseHtml","renderDayNames","_bindEvents","onMouseOverCell","onMouseOutCell","onClickBody","onMouseDown","onMouseMove","window","onMouseUp","onChangeCurrentView","$names","_getDayNamesHtml","e_3","_generateCell","getDatesFunction","getDaysDates","viewDate","e_4","getMonthsDates","parsedViewDate","e_5","getYearsDates","e_6","F","V","dataset","action","_resetNavStatus","handleNavStatus","isFinalView","up","$prev","$next","$title","_getTitle","i_5","_defineDOM","onClickNav","onClickNavTitle","isNavIsFunction","renderDelay","formatDate","_disableNav","e_7","querySelectorAll","keys","find","x","content","setViewDate","H","removeChild","clearHtml","generateButtons","createButton","attachEventToButton","E","L","timepickerIsActive","updateTime","setMinMaxTime","setCurrentTime","addTimeToDate","setTime","updateText","trigger","$minutesText","$hoursText","toggle","toggleTimepickerIsActive","match","ampm","lastSelectedDate","buildHtml","defineDOM","bindDatepickerEvents","bindDOMEvents","onChangeLastSelectedDate","navigator","userAgent","$ranges","onChangeInputRange","onMouseEnterLeave","onFocus","onBlur","displayHours","$hours","$minutes","$ampm","setMinMaxTimeFromOptions","t_4","i_6","setMinTimeFromMinDate","setMaxTimeFromMaxDate","updateSliders","min","max","_hours","O","A","Set","Map","hotKeys","getInitialFocusDate","getClampedDate","viewDateTransition","pressedKeys","size","has","_loop_1","s_3","every","key","which","registerKey","isHotKeyPressed","handleHotKey","isArrow","focusNextCell","e_8","removeKey","bindKeyboardEvents","onKeyDown","onKeyUp","removeEventListener","delete","N","__events","removeAllEvents","I","P","j","B","hideAnimation","_destroyComponents","$container","$datepicker","customHide","$target","$pointer","isViewChange","_finishHide","getBoundingClientRect","offsetParent","scrollY","scrollX","cssText","top","offsetTop","left","offsetLeft","width","height","offsetHeight","e_9","$altField","_getInputValue","map","some","_cancelScheduledCall","_onTransitionEnd","once","e_10","t_5","decade","curDecade","viewIndexes","includes","elIsInput","setPosition","views","t_6","shouldUpdateDOM","$content","silent","isDestroyed","_onFocus","_onBlur","_onResize","_removeMobileAttributes","nav","$customContainer","treatAsInline","_createMinMaxDates","_limitViewDateByMaxMinDates","_handleLocale","setCurrentView","_setInputValue","$timepicker","_addTimepicker","_addButtons","$buttons","_createMobileOverlay","_addMobileAttributes","_showMobileOverlay","update","disabledDates","getCell","currentViewSingular","_triggerOnSelect","isOtherYear","inFocus","nodeName","inited","initialReadonly","buildGlobalContainer","contains","defaultGlobalContainerId","_bindSubEvents","_createComponents","_setPositionClasses","$nav","e_11","_onClickOverlay","removeAttribute","_onChangeSelectedDate","_onChangeFocusedDate","_onChangeTime","insertBefore","nextSibling","JSON","parse","stringify","e_12","_onMouseDown","_onMouseUp","replacer","mm","hh","HH","aa","AA","toUpperCase","EEEE","dd","MM","MMM","MMMM","yy","yyyy","yyyy1","yyyy2","e_13","t_7","_handleUpDownActions","onBeforeSelect","Promise","resolve","_updateLastSelectedDate","unselectDate","splice","indexOf","_scheduleCallAfterTransition","_hasTransition","blur","formattedDate","Boolean","viewIndex","getComputedStyle","getPropertyValue","reduce","parseFloat","replace","K","assign","en","default_1","_default","verdocsFieldDateCss","VerdocsFieldDateStyle0","VerdocsFieldDate","class_3","containerId","random","substring","picker","componentDidLoad","AirDatepicker","localeEn","event","CustomEvent","hostEl","dispatchEvent","placeholder","formattedValue","format","FORMAT_DATE","verdocsFieldDropdownCss","VerdocsFieldDropdownStyle0","VerdocsFieldDropdown","class_4","selectEl","showPicker","handleChange","fieldChange","options","onChange","ref","el","option","verdocsFieldInitialCss","VerdocsFieldInitialStyle0","VerdocsFieldInitial","class_5","initials","tempInitials","hideDialog","dialog","handleAdopt","append","base64","src","alt","verdocsFieldRadioCss","VerdocsFieldRadioStyle0","RadioIconUnselected","RadioIconSelected","VerdocsFieldRadio","class_6","group","maxWidth","verdocsFieldSignatureCss","VerdocsFieldSignatureStyle0","VerdocsFieldSignature","class_7","tempSignature","verdocsFieldTextareaCss","VerdocsFieldTextareaStyle0","VerdocsFieldTextarea","class_8","inputEl","componentDidRender","interact","dynamicDrop","resizable","edges","bottom","right","listeners","start","handleResizeStart","bind","move","handleResize","end","handleResizeEnd","rect","deltaRect","translateX","translateY","round","updateField","then","catch","verdocsFieldTextboxCss","VerdocsFieldTextboxStyle0","VerdocsFieldTextbox","class_9","multiline","modifiers","restrictSize","dX","dY","currentLeft","currentBottom","updatedField","__awaiter","getTemplate","template","sent","newTemplate","fieldIndex","fields","findIndex","updateTemplate","_p","_q","maxlength","verdocsFieldTimestampCss","VerdocsFieldTimestampStyle0","VerdocsFieldTimestamp","class_10","formatted","toISOString","FORMAT_TIMESTAMP","verdocsInitialDialogCss","VerdocsInitialDialogStyle0","VerdocsInitialDialog","fontLoaded","enteredInitials","mode","componentWillLoad","ds","FontFace","load","font","fonts","redrawSignature","componentDidUpdate","canvasElement","canvasWidth","context","getContext","clearRect","fontSize","measureText","textAlign","textBaseline","fillText","handleNameChange","handleCancel","exit","data","toDataURL","next","onInput","display","variant","verdocsSignatureDialogCss","VerdocsSignatureDialogStyle0","VerdocsSignatureDialog","enteredName","verdocsUploadDialogCss","VerdocsUploadDialogStyle0","TrashIcon","VerdocsUploadDialog","class_11","maxSize","draggingOver","confirmDelete","selectedFiles","errorMessage","handleDismiss","handleDone","handleDragOver","handleDragLeave","handleDrop","handleSetSelected","from","dataTransfer","files","handleRemoveAttachment","newFiles","__spreadArray","totalSize","acc","file","handleDeleteAttachment","handleSelectFile","fileInput","click","handleFileChange","marginTop","onDragOver","onDragLeave","onDrop","accept","heading","message","showCancel"],"sources":["src/components/fields/verdocs-field-attachment/verdocs-field-attachment.scss?tag=verdocs-field-attachment","src/components/fields/verdocs-field-attachment/verdocs-field-attachment.tsx","src/components/fields/verdocs-field-checkbox/verdocs-field-checkbox.scss?tag=verdocs-field-checkbox","src/components/fields/verdocs-field-checkbox/verdocs-field-checkbox.tsx","node_modules/air-datepicker/air-datepicker.js","node_modules/air-datepicker/locale/en.js","src/components/fields/verdocs-field-date/verdocs-field-date.scss?tag=verdocs-field-date","src/components/fields/verdocs-field-date/verdocs-field-date.tsx","src/components/fields/verdocs-field-dropdown/verdocs-field-dropdown.scss?tag=verdocs-field-dropdown","src/components/fields/verdocs-field-dropdown/verdocs-field-dropdown.tsx","src/components/fields/verdocs-field-initial/verdocs-field-initial.scss?tag=verdocs-field-initial","src/components/fields/verdocs-field-initial/verdocs-field-initial.tsx","src/components/fields/verdocs-field-radio/verdocs-field-radio.scss?tag=verdocs-field-radio","src/components/fields/verdocs-field-radio/verdocs-field-radio.tsx","src/components/fields/verdocs-field-signature/verdocs-field-signature.scss?tag=verdocs-field-signature","src/components/fields/verdocs-field-signature/verdocs-field-signature.tsx","src/components/fields/verdocs-field-textarea/verdocs-field-textarea.scss?tag=verdocs-field-textarea","src/components/fields/verdocs-field-textarea/verdocs-field-textarea.tsx","src/components/fields/verdocs-field-textbox/verdocs-field-textbox.scss?tag=verdocs-field-textbox","src/components/fields/verdocs-field-textbox/verdocs-field-textbox.tsx","src/components/fields/verdocs-field-timestamp/verdocs-field-timestamp.scss?tag=verdocs-field-timestamp","src/components/fields/verdocs-field-timestamp/verdocs-field-timestamp.tsx","src/components/dialogs/verdocs-initial-dialog/verdocs-initial-dialog.scss?tag=verdocs-initial-dialog","src/components/dialogs/verdocs-initial-dialog/verdocs-initial-dialog.tsx","src/components/dialogs/verdocs-signature-dialog/verdocs-signature-dialog.scss?tag=verdocs-signature-dialog","src/components/dialogs/verdocs-signature-dialog/verdocs-signature-dialog.tsx","src/components/dialogs/verdocs-upload-dialog/verdocs-upload-dialog.scss?tag=verdocs-upload-dialog","src/components/dialogs/verdocs-upload-dialog/verdocs-upload-dialog.tsx"],"sourcesContent":["@import '../../../theme.scss';\n\nverdocs-field-attachment {\n font-family: $verdocs-primary-font;\n box-sizing: border-box;\n width: 24px;\n height: 24px;\n display: block;\n font-size: 11px;\n position: relative;\n scroll-margin: 20px 0;\n background-color: transparent;\n transform-origin: bottom left;\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n label {\n top: -14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n svg {\n width: 16px;\n height: 16px;\n }\n\n &.disabled svg {\n opacity: 0.5;\n\n span {\n cursor: inherit;\n }\n }\n\n .attach {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n width: 24px;\n height: 24px;\n display: flex;\n align-items: center;\n justify-content: center;\n }\n\n &.required {\n .attach {\n border: 1px solid $verdocs-red-1;\n }\n }\n\n verdocs-button-panel {\n top: 1px;\n left: -19px;\n opacity: 0.5;\n z-index: 1000;\n cursor: pointer;\n position: absolute;\n transform: scale(0.6);\n\n &[data-active],\n &:hover {\n opacity: 1;\n }\n\n .icon {\n svg {\n fill: #333333;\n }\n\n &:hover {\n svg {\n fill: #000000;\n }\n }\n }\n }\n\n .settings-icon {\n position: absolute;\n top: -3px;\n left: -20px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import {ITemplateField, getRGBA, VerdocsEndpoint, IEnvelopeField} from '@verdocs/js-sdk';\nimport {Component, h, Host, Prop, Method, Event, EventEmitter, State, Fragment, Element} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\nexport interface ISelectedFile {\n lastModified: number;\n size: number;\n type: string;\n name: string;\n data: string;\n}\n\nconst PaperclipIcon = `<svg xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\"><path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M15.172 7l-6.586 6.586a2 2 0 102.828 2.828l6.414-6.586a4 4 0 00-5.656-5.656l-6.415 6.585a6 6 0 108.486 8.486L20.5 13\" /></svg>`;\n\nconst AttachedIcon = `<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"#339933\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" class=\"lucide lucide-file-check\"><path d=\"M15 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V7Z\"/><path d=\"M14 2v4a2 2 0 0 0 2 2h4\"/><path d=\"m9 15 2 2 4-4\"/></svg>`;\n\n/**\n * Displays an attachment field.\n */\n@Component({\n tag: 'verdocs-field-attachment',\n styleUrl: 'verdocs-field-attachment.scss',\n shadow: false,\n})\nexport class VerdocsFieldAttachment {\n @Element() el: HTMLElement;\n\n /**\n * The endpoint to use to communicate with Verdocs. If not set, the default endpoint will be used.\n * This component self-manages its resize (width) behavior when in edit-template mode, and uses\n * this endpoint to save changes.\n */\n @Prop() endpoint: VerdocsEndpoint = VerdocsEndpoint.getDefault();\n\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when a file is attached by the signer.\n */\n @Event({composed: true}) attached: EventEmitter<ISelectedFile>;\n\n /**\n * Event fired when the field is deleted. Note that this is for the FIELD (e.g. in\n * Build) not for any attachments (during signing).\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() showingProperties?: boolean = false;\n @State() dialogOpen?: boolean = false;\n @State() selectedFile?: ISelectedFile | null = null;\n @State() focused = false;\n\n @Method()\n async focusField() {\n // Our input field is fake, so we fake the flash too\n this.focused = true;\n this.dialogOpen = true;\n setTimeout(() => {\n this.focused = false;\n }, 500);\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n }\n\n handleShow() {\n this.dialogOpen = true;\n }\n\n handleUploadNext = (e: any) => {\n console.log('Upload next', e);\n this.dialogOpen = false;\n this.selectedFile = e.detail[0];\n this.attached?.emit(e.detail[0]);\n };\n\n handleUploadRemove = (e: any) => {\n e.preventDefault();\n e.stopPropagation();\n this.dialogOpen = false;\n this.selectedFile = null;\n this.deleted?.emit({fieldName: this.fieldname});\n };\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n const {required = false, value = '', label = '', settings = {}} = field || {};\n const backgroundColor = getRGBA(index);\n\n const hasFile = value || !!this.selectedFile;\n\n if (done) {\n return (\n <Host class={{done}}>\n <div class=\"attach\" innerHTML={hasFile ? AttachedIcon : PaperclipIcon} />\n </Host>\n );\n }\n\n return (\n <Host class={{required, disabled, done, focused}} style={{backgroundColor}}>\n {label && <label>{label}</label>}\n\n <div class=\"attach\" innerHTML={hasFile ? AttachedIcon : PaperclipIcon} onClick={() => !disabled && this.handleShow()} />\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${fieldname}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => (this.showingProperties = false)}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={'Attachments allow the user to attach their own documents (e.g. resumes or disclosures) to a signing flow.'}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n\n {this.dialogOpen && (\n <verdocs-portal>\n <verdocs-upload-dialog\n existingFile={settings}\n onNext={e => this.handleUploadNext(e)}\n onRemove={e => this.handleUploadRemove(e)}\n onExit={() => (this.dialogOpen = false)}\n />\n </verdocs-portal>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\n// See https://www.kallmanation.com/styling-a-checkbox-with-only-css\nverdocs-field-checkbox {\n padding: 0;\n width: 16px;\n height: 16px;\n display: block;\n scroll-margin: 20px 0;\n box-sizing: border-box;\n transform-origin: bottom left;\n font-family: $verdocs-primary-font;\n\n // To avoid conflicting with the use of a label for the checkbox itself\n div.label {\n top: -14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n label {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n width: 14px;\n height: 14px;\n display: block;\n box-sizing: border-box;\n }\n\n &.disabled label {\n opacity: 0.5;\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n label > input[type='checkbox'] {\n display: none;\n }\n\n label > input[type='checkbox'] + *::before {\n margin: 0;\n content: '';\n width: 12px;\n height: 12px;\n display: block;\n line-height: 12px;\n border-radius: 2px;\n box-sizing: border-box;\n border: 1px solid $verdocs-grey-2;\n }\n\n label > input[type='checkbox']:checked + * {\n color: $verdocs-green;\n }\n\n label > input[type='checkbox']:checked + *::before {\n content: '✓';\n color: white;\n font-size: 12px;\n text-align: center;\n background: $verdocs-green;\n border-color: $verdocs-green;\n }\n\n &.required {\n border: 1px solid $verdocs-red-1;\n }\n\n &.hide {\n display: none;\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n verdocs-button-panel {\n display: block;\n margin-left: -20px;\n margin-top: -17px;\n transform: scale(0.7);\n }\n\n .settings-icon {\n position: absolute;\n top: -5px;\n left: -20px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import {ITemplateField, getRGBA, IEnvelopeField} from '@verdocs/js-sdk';\nimport {Component, Event, EventEmitter, Fragment, h, Host, Method, Prop, State} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\n/**\n * Displays a checkbox.\n */\n@Component({\n tag: 'verdocs-field-checkbox',\n styleUrl: 'verdocs-field-checkbox.scss',\n shadow: false,\n})\nexport class VerdocsFieldCheckbox {\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() showingProperties?: boolean = false;\n @State() focused?: boolean = false;\n\n @Method()\n async focusField() {\n // We don't have a visible input that we can actually focus on, so we fake it\n this.focused = true;\n setTimeout(() => {\n this.focused = false;\n }, 500);\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n }\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n const {required = false, label = '', value = false} = field || {};\n const backgroundColor = getRGBA(index);\n\n const checked = value === 'true';\n\n if (done) {\n return <Host class={{done}}>{checked ? '✓' : '☐'}</Host>;\n }\n\n return (\n <Host class={{required, disabled, done, focused}} style={{backgroundColor}}>\n {label && <div class=\"label\">{label}</div>}\n\n <label htmlFor={fieldname}>\n <input id={fieldname} name={fieldname} type=\"checkbox\" checked={checked} disabled={disabled} required={required} />\n <span />\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${field.name}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={field.name}\n onClose={() => (this.showingProperties = false)}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={'Check boxes allow the user to select one or more (non-exclusive) options.'}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </label>\n </Host>\n );\n }\n}\n","!function(e,t){\"object\"==typeof exports&&\"object\"==typeof module?module.exports=t():\"function\"==typeof define&&define.amd?define([],t):\"object\"==typeof exports?exports.AirDatepicker=t():e.AirDatepicker=t()}(this,(function(){return function(){\"use strict\";var e={d:function(t,i){for(var s in i)e.o(i,s)&&!e.o(t,s)&&Object.defineProperty(t,s,{enumerable:!0,get:i[s]})},o:function(e,t){return Object.prototype.hasOwnProperty.call(e,t)}},t={};e.d(t,{default:function(){return R}});var i={days:\"days\",months:\"months\",years:\"years\",day:\"day\",month:\"month\",year:\"year\",eventChangeViewDate:\"changeViewDate\",eventChangeCurrentView:\"changeCurrentView\",eventChangeFocusDate:\"changeFocusDate\",eventChangeSelectedDate:\"changeSelectedDate\",eventChangeTime:\"changeTime\",eventChangeLastSelectedDate:\"changeLastSelectedDate\",actionSelectDate:\"selectDate\",actionUnselectDate:\"unselectDate\",cssClassWeekend:\"-weekend-\"},s={classes:\"\",inline:!1,locale:{days:[\"Воскресенье\",\"Понедельник\",\"Вторник\",\"Среда\",\"Четверг\",\"Пятница\",\"Суббота\"],daysShort:[\"Вос\",\"Пон\",\"Вто\",\"Сре\",\"Чет\",\"Пят\",\"Суб\"],daysMin:[\"Вс\",\"Пн\",\"Вт\",\"Ср\",\"Чт\",\"Пт\",\"Сб\"],months:[\"Январь\",\"Февраль\",\"Март\",\"Апрель\",\"Май\",\"Июнь\",\"Июль\",\"Август\",\"Сентябрь\",\"Октябрь\",\"Ноябрь\",\"Декабрь\"],monthsShort:[\"Янв\",\"Фев\",\"Мар\",\"Апр\",\"Май\",\"Июн\",\"Июл\",\"Авг\",\"Сен\",\"Окт\",\"Ноя\",\"Дек\"],today:\"Сегодня\",clear:\"Очистить\",dateFormat:\"dd.MM.yyyy\",timeFormat:\"HH:mm\",firstDay:1},startDate:new Date,firstDay:\"\",weekends:[6,0],dateFormat:\"\",altField:\"\",altFieldDateFormat:\"T\",toggleSelected:!0,keyboardNav:!0,selectedDates:!1,container:\"\",isMobile:!1,visible:!1,position:\"bottom left\",offset:12,view:i.days,minView:i.days,showOtherMonths:!0,selectOtherMonths:!0,moveToOtherMonthsOnSelect:!0,showOtherYears:!0,selectOtherYears:!0,moveToOtherYearsOnSelect:!0,minDate:\"\",maxDate:\"\",disableNavWhenOutOfRange:!0,multipleDates:!1,multipleDatesSeparator:\", \",range:!1,dynamicRange:!0,buttons:!1,monthsField:\"monthsShort\",showEvent:\"focus\",autoClose:!1,fixedHeight:!1,prevHtml:'<svg><path d=\"M 17,12 l -5,5 l 5,5\"></path></svg>',nextHtml:'<svg><path d=\"M 14,12 l 5,5 l -5,5\"></path></svg>',navTitles:{days:\"MMMM, <i>yyyy</i>\",months:\"yyyy\",years:\"yyyy1 - yyyy2\"},timepicker:!1,onlyTimepicker:!1,dateTimeSeparator:\" \",timeFormat:\"\",minHours:0,maxHours:24,minMinutes:0,maxMinutes:59,hoursStep:1,minutesStep:1,onSelect:!1,onChangeViewDate:!1,onChangeView:!1,onRenderCell:!1,onShow:!1,onHide:!1,onClickDayName:!1};function a(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:document;return\"string\"==typeof e?t.querySelector(e):e}function n(){let{tagName:e=\"div\",className:t=\"\",innerHtml:i=\"\",id:s=\"\",attrs:a={}}=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},n=document.createElement(e);return t&&n.classList.add(...t.split(\" \")),s&&(n.id=s),i&&(n.innerHTML=i),a&&r(n,a),n}function r(e,t){for(let[i,s]of Object.entries(t))void 0!==s&&e.setAttribute(i,s);return e}function o(e){return new Date(e.getFullYear(),e.getMonth()+1,0).getDate()}function h(e){let t=e.getHours(),{hours:i,dayPeriod:s}=l(t);return{year:e.getFullYear(),month:e.getMonth(),fullMonth:e.getMonth()+1<10?\"0\"+(e.getMonth()+1):e.getMonth()+1,date:e.getDate(),fullDate:e.getDate()<10?\"0\"+e.getDate():e.getDate(),day:e.getDay(),hours:t,fullHours:d(t),hours12:i,dayPeriod:s,fullHours12:d(i),minutes:e.getMinutes(),fullMinutes:e.getMinutes()<10?\"0\"+e.getMinutes():e.getMinutes()}}function l(e){return{dayPeriod:e>11?\"pm\":\"am\",hours:e%12==0?12:e%12}}function d(e){return e<10?\"0\"+e:e}function c(e){let t=10*Math.floor(e.getFullYear()/10);return[t,t+9]}function u(){let e=[];for(var t=arguments.length,i=new Array(t),s=0;s<t;s++)i[s]=arguments[s];return i.forEach((t=>{if(\"object\"==typeof t)for(let i in t)t[i]&&e.push(i);else t&&e.push(t)})),e.join(\" \")}function p(e,t){let s=arguments.length>2&&void 0!==arguments[2]?arguments[2]:i.days;if(!e||!t)return!1;let a=h(e),n=h(t);return{[i.days]:a.date===n.date&&a.month===n.month&&a.year===n.year,[i.months]:a.month===n.month&&a.year===n.year,[i.years]:a.year===n.year}[s]}function m(e,t,i){let s=g(e,!1).getTime(),a=g(t,!1).getTime();return i?s>=a:s>a}function v(e,t){return!m(e,t,!0)}function g(e){let t=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=new Date(e.getTime());return\"boolean\"!=typeof t||t||function(e){e.setHours(0,0,0,0)}(i),i}function D(e,t,i){e.length?e.forEach((e=>{e.addEventListener(t,i)})):e.addEventListener(t,i)}function y(e,t){return!(!e||e===document||e instanceof DocumentFragment)&&(e.matches(t)?e:y(e.parentNode,t))}function f(e,t,i){return e>i?i:e<t?t:e}function w(e){for(var t=arguments.length,i=new Array(t>1?t-1:0),s=1;s<t;s++)i[s-1]=arguments[s];return i.filter((e=>e)).forEach((t=>{for(let[i,s]of Object.entries(t))if(void 0!==s&&\"[object Object]\"===s.toString()){let t=void 0!==e[i]?e[i].toString():void 0,a=s.toString(),n=Array.isArray(s)?[]:{};e[i]=e[i]?t!==a?n:e[i]:n,w(e[i],s)}else e[i]=s})),e}function b(e){let t=e;return e instanceof Date||(\"string\"==typeof e&&/^\\d{4}-\\d{2}-\\d{2}$/.test(e)&&(e+=\"T00:00:00\"),t=new Date(e)),isNaN(t.getTime())&&(console.log(`Unable to convert value \"${e}\" to Date object`),t=!1),t}function k(e){let t=\"\\\\s|\\\\.|-|/|\\\\\\\\|,|\\\\$|\\\\!|\\\\?|:|;\";return new RegExp(\"(^|>|\"+t+\")(\"+e+\")($|<|\"+t+\")\",\"g\")}function $(e,t,i){return(t=function(e){var t=function(e,t){if(\"object\"!=typeof e||null===e)return e;var i=e[Symbol.toPrimitive];if(void 0!==i){var s=i.call(e,\"string\");if(\"object\"!=typeof s)return s;throw new TypeError(\"@@toPrimitive must return a primitive value.\")}return String(e)}(e);return\"symbol\"==typeof t?t:String(t)}(t))in e?Object.defineProperty(e,t,{value:i,enumerable:!0,configurable:!0,writable:!0}):e[t]=i,e}class C{constructor(){let{type:e,date:t,dp:i,opts:s,body:a}=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};$(this,\"focus\",(()=>{this.$cell.classList.add(\"-focus-\"),this.focused=!0})),$(this,\"removeFocus\",(()=>{this.$cell.classList.remove(\"-focus-\"),this.focused=!1})),$(this,\"select\",(()=>{this.$cell.classList.add(\"-selected-\"),this.selected=!0})),$(this,\"removeSelect\",(()=>{this.$cell.classList.remove(\"-selected-\",\"-range-from-\",\"-range-to-\"),this.selected=!1})),$(this,\"onChangeSelectedDate\",(()=>{this.isDisabled||(this._handleSelectedStatus(),this.opts.range&&this._handleRangeStatus())})),$(this,\"onChangeFocusDate\",(e=>{if(!e)return void(this.focused&&this.removeFocus());let t=p(e,this.date,this.type);t?this.focus():!t&&this.focused&&this.removeFocus(),this.opts.range&&this._handleRangeStatus()})),$(this,\"render\",(()=>(this.$cell.innerHTML=this._getHtml(),this._handleClasses(),this.$cell))),this.type=e,this.singleType=this.type.slice(0,-1),this.date=t,this.dp=i,this.opts=s,this.body=a,this.customData=!1,this.init()}init(){var e;let{onRenderCell:t}=this.opts;t&&(this.customData=t({date:this.date,cellType:this.singleType,datepicker:this.dp})),this._createElement(),this._bindDatepickerEvents(),null!==(e=this.customData)&&void 0!==e&&e.disabled&&this.dp.disableDate(this.date)}_bindDatepickerEvents(){this.dp.on(i.eventChangeSelectedDate,this.onChangeSelectedDate),this.dp.on(i.eventChangeFocusDate,this.onChangeFocusDate)}unbindDatepickerEvents(){this.dp.off(i.eventChangeSelectedDate,this.onChangeSelectedDate),this.dp.off(i.eventChangeFocusDate,this.onChangeFocusDate)}_createElement(){var e;let{year:t,month:i,date:s}=h(this.date),a=(null===(e=this.customData)||void 0===e?void 0:e.attrs)||{};this.$cell=n({attrs:{\"data-year\":t,\"data-month\":i,\"data-date\":s,...a}}),this.$cell.adpCell=this}_getClassName(){var e;let t=new Date,{selectOtherMonths:s,selectOtherYears:a}=this.opts,{minDate:n,maxDate:r,isDateDisabled:o}=this.dp,{day:l}=h(this.date),d=this._isOutOfMinMaxRange(),c=o(this.date),m=u(\"air-datepicker-cell\",`-${this.singleType}-`,{\"-current-\":p(t,this.date,this.type),\"-min-date-\":n&&p(n,this.date,this.type),\"-max-date-\":r&&p(r,this.date,this.type)}),v=\"\";switch(this.type){case i.days:v=u({\"-weekend-\":this.dp.isWeekend(l),\"-other-month-\":this.isOtherMonth,\"-disabled-\":this.isOtherMonth&&!s||d||c});break;case i.months:v=u({\"-disabled-\":d});break;case i.years:v=u({\"-other-decade-\":this.isOtherDecade,\"-disabled-\":d||this.isOtherDecade&&!a})}return u(m,v,null===(e=this.customData)||void 0===e?void 0:e.classes).split(\" \")}_getHtml(){var e;let{year:t,month:s,date:a}=h(this.date),{showOtherMonths:n,showOtherYears:r}=this.opts;if(null!==(e=this.customData)&&void 0!==e&&e.html)return this.customData.html;switch(this.type){case i.days:return!n&&this.isOtherMonth?\"\":a;case i.months:return this.dp.locale[this.opts.monthsField][s];case i.years:return!r&&this.isOtherDecade?\"\":t}}_isOutOfMinMaxRange(){let{minDate:e,maxDate:t}=this.dp,{type:s,date:a}=this,{month:n,year:r,date:o}=h(a),l=s===i.days,d=s===i.years,c=!!e&&new Date(r,d?e.getMonth():n,l?o:e.getDate()),u=!!t&&new Date(r,d?t.getMonth():n,l?o:t.getDate());return e&&t?v(c,e)||m(u,t):e?v(c,e):t?m(u,t):void 0}destroy(){this.unbindDatepickerEvents()}_handleRangeStatus(){const{selectedDates:e,focusDate:t,rangeDateTo:i,rangeDateFrom:s}=this.dp,a=e.length;if(!a)return;let n=s,r=i;if(1===a&&t){const i=m(t,e[0]);n=i?e[0]:t,r=i?t:e[0]}let o=u({\"-in-range-\":n&&r&&(h=this.date,l=n,d=r,m(h,l)&&v(h,d)),\"-range-from-\":n&&p(this.date,n,this.type),\"-range-to-\":r&&p(this.date,r,this.type)});var h,l,d;this.$cell.classList.remove(\"-range-from-\",\"-range-to-\",\"-in-range-\"),o&&this.$cell.classList.add(...o.split(\" \"))}_handleSelectedStatus(){let e=this.dp._checkIfDateIsSelected(this.date,this.type);e?this.select():!e&&this.selected&&this.removeSelect()}_handleInitialFocusStatus(){p(this.dp.focusDate,this.date,this.type)&&this.focus()}_handleClasses(){this.$cell.setAttribute(\"class\",\"\"),this._handleInitialFocusStatus(),this.dp.hasSelectedDates&&(this._handleSelectedStatus(),this.dp.opts.range&&this._handleRangeStatus()),this.$cell.classList.add(...this._getClassName())}get isDisabled(){return this.$cell.matches(\".-disabled-\")}get isOtherMonth(){return this.dp.isOtherMonth(this.date)}get isOtherDecade(){return this.dp.isOtherDecade(this.date)}}function _(e,t,i){return(t=function(e){var t=function(e,t){if(\"object\"!=typeof e||null===e)return e;var i=e[Symbol.toPrimitive];if(void 0!==i){var s=i.call(e,\"string\");if(\"object\"!=typeof s)return s;throw new TypeError(\"@@toPrimitive must return a primitive value.\")}return String(e)}(e);return\"symbol\"==typeof t?t:String(t)}(t))in e?Object.defineProperty(e,t,{value:i,enumerable:!0,configurable:!0,writable:!0}):e[t]=i,e}let M={[i.days]:`<div class=\"air-datepicker-body--day-names\"></div><div class=\"air-datepicker-body--cells -${i.days}-\"></div>`,[i.months]:`<div class=\"air-datepicker-body--cells -${i.months}-\"></div>`,[i.years]:`<div class=\"air-datepicker-body--cells -${i.years}-\"></div>`};const S=\".air-datepicker-cell\";class T{constructor(e){let{dp:t,type:s,opts:a}=e;_(this,\"handleClick\",(e=>{let t=e.target.closest(S).adpCell;if(t.isDisabled)return;if(!this.dp.isMinViewReached)return void this.dp.down();let i=this.dp._checkIfDateIsSelected(t.date,t.type);i?this.dp._handleAlreadySelectedDates(i,t.date):this.dp.selectDate(t.date)})),_(this,\"handleDayNameClick\",(e=>{let t=e.target.getAttribute(\"data-day-index\");this.opts.onClickDayName({dayIndex:Number(t),datepicker:this.dp})})),_(this,\"onChangeCurrentView\",(e=>{e!==this.type?this.hide():(this.show(),this.render())})),_(this,\"onMouseOverCell\",(e=>{let t=y(e.target,S);this.dp.setFocusDate(!!t&&t.adpCell.date)})),_(this,\"onMouseOutCell\",(()=>{this.dp.setFocusDate(!1)})),_(this,\"onClickBody\",(e=>{let{onClickDayName:t}=this.opts,i=e.target;i.closest(S)&&this.handleClick(e),t&&i.closest(\".air-datepicker-body--day-name\")&&this.handleDayNameClick(e)})),_(this,\"onMouseDown\",(e=>{this.pressed=!0;let t=y(e.target,S),i=t&&t.adpCell;p(i.date,this.dp.rangeDateFrom)&&(this.rangeFromFocused=!0),p(i.date,this.dp.rangeDateTo)&&(this.rangeToFocused=!0)})),_(this,\"onMouseMove\",(e=>{if(!this.pressed||!this.dp.isMinViewReached)return;e.preventDefault();let t=y(e.target,S),i=t&&t.adpCell,{selectedDates:s,rangeDateTo:a,rangeDateFrom:n}=this.dp;if(!i||i.isDisabled)return;let{date:r}=i;if(2===s.length){if(this.rangeFromFocused&&!m(r,a)){let{hours:e,minutes:t}=h(n);r.setHours(e),r.setMinutes(t),this.dp.rangeDateFrom=r,this.dp.replaceDate(n,r)}if(this.rangeToFocused&&!v(r,n)){let{hours:e,minutes:t}=h(a);r.setHours(e),r.setMinutes(t),this.dp.rangeDateTo=r,this.dp.replaceDate(a,r)}}})),_(this,\"onMouseUp\",(()=>{this.pressed=!1,this.rangeFromFocused=!1,this.rangeToFocused=!1})),_(this,\"onChangeViewDate\",((e,t)=>{if(!this.isVisible)return;let s=c(e),a=c(t);switch(this.dp.currentView){case i.days:if(p(e,t,i.months))return;break;case i.months:if(p(e,t,i.years))return;break;case i.years:if(s[0]===a[0]&&s[1]===a[1])return}this.render()})),_(this,\"render\",(()=>{this.destroyCells(),this._generateCells(),this.cells.forEach((e=>{this.$cells.appendChild(e.render())}))})),this.dp=t,this.type=s,this.opts=a,this.cells=[],this.$el=\"\",this.pressed=!1,this.isVisible=!0,this.init()}init(){this._buildBaseHtml(),this.type===i.days&&this.renderDayNames(),this.render(),this._bindEvents(),this._bindDatepickerEvents()}_bindEvents(){let{range:e,dynamicRange:t}=this.opts;D(this.$el,\"mouseover\",this.onMouseOverCell),D(this.$el,\"mouseout\",this.onMouseOutCell),D(this.$el,\"click\",this.onClickBody),e&&t&&(D(this.$el,\"mousedown\",this.onMouseDown),D(this.$el,\"mousemove\",this.onMouseMove),D(window.document,\"mouseup\",this.onMouseUp))}_bindDatepickerEvents(){this.dp.on(i.eventChangeViewDate,this.onChangeViewDate),this.dp.on(i.eventChangeCurrentView,this.onChangeCurrentView)}_buildBaseHtml(){this.$el=n({className:`air-datepicker-body -${this.type}-`,innerHtml:M[this.type]}),this.$names=a(\".air-datepicker-body--day-names\",this.$el),this.$cells=a(\".air-datepicker-body--cells\",this.$el)}_getDayNamesHtml(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.dp.locale.firstDay,t=\"\",s=this.dp.isWeekend,{onClickDayName:a}=this.opts,n=e,r=0;for(;r<7;){let e=n%7;t+=`<div class=\"${u(\"air-datepicker-body--day-name\",{[i.cssClassWeekend]:s(e),\"-clickable-\":!!a})}\" data-day-index='${e}'>${this.dp.locale.daysMin[e]}</div>`,r++,n++}return t}renderDayNames(){this.$names.innerHTML=this._getDayNamesHtml()}_generateCell(e){let{type:t,dp:i,opts:s}=this;return new C({type:t,dp:i,opts:s,date:e,body:this})}_generateCells(){T.getDatesFunction(this.type)(this.dp,(e=>{this.cells.push(this._generateCell(e))}))}show(){this.isVisible=!0,this.$el.classList.remove(\"-hidden-\")}hide(){this.isVisible=!1,this.$el.classList.add(\"-hidden-\")}destroyCells(){this.cells.forEach((e=>e.destroy())),this.cells=[],this.$cells.innerHTML=\"\"}destroy(){this.destroyCells(),this.dp.off(i.eventChangeViewDate,this.onChangeViewDate),this.dp.off(i.eventChangeCurrentView,this.onChangeCurrentView)}static getDaysDates(e,t){let{viewDate:i,opts:{fixedHeight:s},locale:{firstDay:a}}=e,n=o(i),{year:r,month:l}=h(i),d=new Date(r,l,1),c=new Date(r,l,n),u=d.getDay()-a,p=6-c.getDay()+a;u=u<0?u+7:u,p=p>6?p-7:p;let m=function(e,t){let{year:i,month:s,date:a}=h(e);return new Date(i,s,a-t)}(d,u),v=n+u+p,g=m.getDate(),{year:D,month:y}=h(m),f=0;s&&(v=42);const w=[];for(;f<v;){let e=new Date(D,y,g+f);t&&t(e),w.push(e),f++}return w}static getMonthsDates(e,t){let{year:i}=e.parsedViewDate,s=0,a=[];for(;s<12;){const e=new Date(i,s);a.push(e),t&&t(e),s++}return a}static getYearsDates(e,t){let i=c(e.viewDate),s=i[0]-1,a=i[1]+1,n=s,r=[];for(;n<=a;){const e=new Date(n,0);r.push(e),t&&t(e),n++}return r}static getDatesFunction(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:i.days;return{[i.days]:T.getDaysDates,[i.months]:T.getMonthsDates,[i.years]:T.getYearsDates}[e]}}function F(e,t,i){return(t=function(e){var t=function(e,t){if(\"object\"!=typeof e||null===e)return e;var i=e[Symbol.toPrimitive];if(void 0!==i){var s=i.call(e,\"string\");if(\"object\"!=typeof s)return s;throw new TypeError(\"@@toPrimitive must return a primitive value.\")}return String(e)}(e);return\"symbol\"==typeof t?t:String(t)}(t))in e?Object.defineProperty(e,t,{value:i,enumerable:!0,configurable:!0,writable:!0}):e[t]=i,e}class V{constructor(e){let{dp:t,opts:i}=e;F(this,\"onClickNav\",(e=>{let t=y(e.target,\".air-datepicker-nav--action\");if(!t)return;let i=t.dataset.action;this.dp[i]()})),F(this,\"onChangeViewDate\",(()=>{this.render(),this._resetNavStatus(),this.handleNavStatus()})),F(this,\"onChangeCurrentView\",(()=>{this.render(),this._resetNavStatus(),this.handleNavStatus()})),F(this,\"onClickNavTitle\",(()=>{this.dp.isFinalView||this.dp.up()})),F(this,\"update\",(()=>{let{prevHtml:e,nextHtml:t}=this.opts;this.$prev.innerHTML=e,this.$next.innerHTML=t,this._resetNavStatus(),this.render(),this.handleNavStatus()})),F(this,\"renderDelay\",(()=>{setTimeout(this.render)})),F(this,\"render\",(()=>{this.$title.innerHTML=this._getTitle(),function(e,t){for(let i in t)t[i]?e.classList.add(i):e.classList.remove(i)}(this.$title,{\"-disabled-\":this.dp.isFinalView})})),this.dp=t,this.opts=i,this.init()}init(){this._createElement(),this._buildBaseHtml(),this._defineDOM(),this.render(),this.handleNavStatus(),this._bindEvents(),this._bindDatepickerEvents()}_defineDOM(){this.$title=a(\".air-datepicker-nav--title\",this.$el),this.$prev=a('[data-action=\"prev\"]',this.$el),this.$next=a('[data-action=\"next\"]',this.$el)}_bindEvents(){this.$el.addEventListener(\"click\",this.onClickNav),this.$title.addEventListener(\"click\",this.onClickNavTitle)}_bindDatepickerEvents(){this.dp.on(i.eventChangeViewDate,this.onChangeViewDate),this.dp.on(i.eventChangeCurrentView,this.onChangeCurrentView),this.isNavIsFunction&&(this.dp.on(i.eventChangeSelectedDate,this.renderDelay),this.dp.opts.timepicker&&this.dp.on(i.eventChangeTime,this.render))}destroy(){this.dp.off(i.eventChangeViewDate,this.onChangeViewDate),this.dp.off(i.eventChangeCurrentView,this.onChangeCurrentView),this.isNavIsFunction&&(this.dp.off(i.eventChangeSelectedDate,this.renderDelay),this.dp.opts.timepicker&&this.dp.off(i.eventChangeTime,this.render))}_createElement(){this.$el=n({tagName:\"nav\",className:\"air-datepicker-nav\"})}_getTitle(){let{dp:e,opts:t}=this,i=t.navTitles[e.currentView];return\"function\"==typeof i?i(e):e.formatDate(e.viewDate,i)}handleNavStatus(){let{disableNavWhenOutOfRange:e}=this.opts,{minDate:t,maxDate:s}=this.dp;if(!t&&!s||!e)return;let{year:a,month:n}=this.dp.parsedViewDate,r=!!t&&h(t),o=!!s&&h(s);switch(this.dp.currentView){case i.days:t&&r.month>=n&&r.year>=a&&this._disableNav(\"prev\"),s&&o.month<=n&&o.year<=a&&this._disableNav(\"next\");break;case i.months:t&&r.year>=a&&this._disableNav(\"prev\"),s&&o.year<=a&&this._disableNav(\"next\");break;case i.years:{let e=c(this.dp.viewDate);t&&r.year>=e[0]&&this._disableNav(\"prev\"),s&&o.year<=e[1]&&this._disableNav(\"next\");break}}}_disableNav(e){a('[data-action=\"'+e+'\"]',this.$el).classList.add(\"-disabled-\")}_resetNavStatus(){!function(e){for(var t=arguments.length,i=new Array(t>1?t-1:0),s=1;s<t;s++)i[s-1]=arguments[s];e.length?e.forEach((e=>{e.classList.remove(...i)})):e.classList.remove(...i)}(this.$el.querySelectorAll(\".air-datepicker-nav--action\"),\"-disabled-\")}_buildBaseHtml(){let{prevHtml:e,nextHtml:t}=this.opts;this.$el.innerHTML=`<div class=\"air-datepicker-nav--action\" data-action=\"prev\">${e}</div><div class=\"air-datepicker-nav--title\"></div><div class=\"air-datepicker-nav--action\" data-action=\"next\">${t}</div>`}get isNavIsFunction(){let{navTitles:e}=this.opts;return Object.keys(e).find((t=>\"function\"==typeof e[t]))}}var x={today:{content:e=>e.locale.today,onClick:e=>e.setViewDate(new Date)},clear:{content:e=>e.locale.clear,onClick:e=>e.clear()}};class H{constructor(e){let{dp:t,opts:i}=e;this.dp=t,this.opts=i,this.init()}init(){this.createElement(),this.render()}createElement(){this.$el=n({className:\"air-datepicker-buttons\"})}destroy(){this.$el.parentNode.removeChild(this.$el)}clearHtml(){return this.$el.innerHTML=\"\",this}generateButtons(){let{buttons:e}=this.opts;Array.isArray(e)||(e=[e]),e.forEach((e=>{let t=e;\"string\"==typeof e&&x[e]&&(t=x[e]);let i=this.createButton(t);t.onClick&&this.attachEventToButton(i,t.onClick),this.$el.appendChild(i)}))}attachEventToButton(e,t){e.addEventListener(\"click\",(()=>{t(this.dp)}))}createButton(e){let{content:t,className:i,tagName:s=\"button\",attrs:a={}}=e;return n({tagName:s,innerHtml:`<span tabindex='-1'>${\"function\"==typeof t?t(this.dp):t}</span>`,className:u(\"air-datepicker-button\",i),attrs:a})}render(){this.generateButtons()}}function E(e,t,i){return(t=function(e){var t=function(e,t){if(\"object\"!=typeof e||null===e)return e;var i=e[Symbol.toPrimitive];if(void 0!==i){var s=i.call(e,\"string\");if(\"object\"!=typeof s)return s;throw new TypeError(\"@@toPrimitive must return a primitive value.\")}return String(e)}(e);return\"symbol\"==typeof t?t:String(t)}(t))in e?Object.defineProperty(e,t,{value:i,enumerable:!0,configurable:!0,writable:!0}):e[t]=i,e}class L{constructor(){let{opts:e,dp:t}=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};E(this,\"toggleTimepickerIsActive\",(e=>{this.dp.timepickerIsActive=e})),E(this,\"onChangeSelectedDate\",(e=>{let{date:t,updateTime:i=!1}=e;t&&(this.setMinMaxTime(t),this.setCurrentTime(!!i&&t),this.addTimeToDate(t))})),E(this,\"onChangeLastSelectedDate\",(e=>{e&&(this.setTime(e),this.render())})),E(this,\"onChangeInputRange\",(e=>{let t=e.target;this[t.getAttribute(\"name\")]=t.value,this.updateText(),this.dp.trigger(i.eventChangeTime,{hours:this.hours,minutes:this.minutes})})),E(this,\"onMouseEnterLeave\",(e=>{let t=e.target.getAttribute(\"name\"),i=this.$minutesText;\"hours\"===t&&(i=this.$hoursText),i.classList.toggle(\"-focus-\")})),E(this,\"onFocus\",(()=>{this.toggleTimepickerIsActive(!0)})),E(this,\"onBlur\",(()=>{this.toggleTimepickerIsActive(!1)})),this.opts=e,this.dp=t;let{timeFormat:s}=this.dp.locale;s&&(s.match(k(\"h\"))||s.match(k(\"hh\")))&&(this.ampm=!0),this.init()}init(){this.setTime(this.dp.lastSelectedDate||this.dp.viewDate),this.createElement(),this.buildHtml(),this.defineDOM(),this.render(),this.bindDatepickerEvents(),this.bindDOMEvents()}bindDatepickerEvents(){this.dp.on(i.eventChangeSelectedDate,this.onChangeSelectedDate),this.dp.on(i.eventChangeLastSelectedDate,this.onChangeLastSelectedDate)}bindDOMEvents(){let e=\"input\";navigator.userAgent.match(/trident/gi)&&(e=\"change\"),D(this.$ranges,e,this.onChangeInputRange),D(this.$ranges,\"mouseenter\",this.onMouseEnterLeave),D(this.$ranges,\"mouseleave\",this.onMouseEnterLeave),D(this.$ranges,\"focus\",this.onFocus),D(this.$ranges,\"mousedown\",this.onFocus),D(this.$ranges,\"blur\",this.onBlur)}createElement(){this.$el=n({className:u(\"air-datepicker-time\",{\"-am-pm-\":this.dp.ampm})})}destroy(){this.dp.off(i.eventChangeSelectedDate,this.onChangeSelectedDate),this.dp.off(i.eventChangeLastSelectedDate,this.onChangeLastSelectedDate),this.$el.parentNode.removeChild(this.$el)}buildHtml(){let{ampm:e,hours:t,displayHours:i,minutes:s,minHours:a,minMinutes:n,maxHours:r,maxMinutes:o,dayPeriod:h,opts:{hoursStep:l,minutesStep:c}}=this;this.$el.innerHTML=`<div class=\"air-datepicker-time--current\"> <span class=\"air-datepicker-time--current-hours\">${d(i)}</span> <span class=\"air-datepicker-time--current-colon\">:</span> <span class=\"air-datepicker-time--current-minutes\">${d(s)}</span> `+(e?`<span class='air-datepicker-time--current-ampm'>${h}</span>`:\"\")+'</div><div class=\"air-datepicker-time--sliders\"> <div class=\"air-datepicker-time--row\">'+` <input type=\"range\" name=\"hours\" value=\"${t}\" min=\"${a}\" max=\"${r}\" step=\"${l}\"/> </div> <div class=\"air-datepicker-time--row\">`+` <input type=\"range\" name=\"minutes\" value=\"${s}\" min=\"${n}\" max=\"${o}\" step=\"${c}\"/> </div></div>`}defineDOM(){let e=e=>a(e,this.$el);this.$ranges=this.$el.querySelectorAll('[type=\"range\"]'),this.$hours=e('[name=\"hours\"]'),this.$minutes=e('[name=\"minutes\"]'),this.$hoursText=e(\".air-datepicker-time--current-hours\"),this.$minutesText=e(\".air-datepicker-time--current-minutes\"),this.$ampm=e(\".air-datepicker-time--current-ampm\")}setTime(e){this.setMinMaxTime(e),this.setCurrentTime(e)}addTimeToDate(e){e&&(e.setHours(this.hours),e.setMinutes(this.minutes))}setMinMaxTime(e){if(this.setMinMaxTimeFromOptions(),e){let{minDate:t,maxDate:i}=this.dp;t&&p(e,t)&&this.setMinTimeFromMinDate(t),i&&p(e,i)&&this.setMaxTimeFromMaxDate(i)}}setCurrentTime(e){let{hours:t,minutes:i}=e?h(e):this;this.hours=f(t,this.minHours,this.maxHours),this.minutes=f(i,this.minMinutes,this.maxMinutes)}setMinMaxTimeFromOptions(){let{minHours:e,minMinutes:t,maxHours:i,maxMinutes:s}=this.opts;this.minHours=f(e,0,23),this.minMinutes=f(t,0,59),this.maxHours=f(i,0,23),this.maxMinutes=f(s,0,59)}setMinTimeFromMinDate(e){let{lastSelectedDate:t}=this.dp;this.minHours=e.getHours(),t&&t.getHours()>e.getHours()?this.minMinutes=this.opts.minMinutes:this.minMinutes=e.getMinutes()}setMaxTimeFromMaxDate(e){let{lastSelectedDate:t}=this.dp;this.maxHours=e.getHours(),t&&t.getHours()<e.getHours()?this.maxMinutes=this.opts.maxMinutes:this.maxMinutes=e.getMinutes()}updateSliders(){r(this.$hours,{min:this.minHours,max:this.maxHours}).value=this.hours,r(this.$minutes,{min:this.minMinutes,max:this.maxMinutes}).value=this.minutes}updateText(){this.$hoursText.innerHTML=d(this.displayHours),this.$minutesText.innerHTML=d(this.minutes),this.ampm&&(this.$ampm.innerHTML=this.dayPeriod)}set hours(e){this._hours=e;let{hours:t,dayPeriod:i}=l(e);this.displayHours=this.ampm?t:e,this.dayPeriod=i}get hours(){return this._hours}render(){this.updateSliders(),this.updateText()}}function O(e,t,i){return(t=function(e){var t=function(e,t){if(\"object\"!=typeof e||null===e)return e;var i=e[Symbol.toPrimitive];if(void 0!==i){var s=i.call(e,\"string\");if(\"object\"!=typeof s)return s;throw new TypeError(\"@@toPrimitive must return a primitive value.\")}return String(e)}(e);return\"symbol\"==typeof t?t:String(t)}(t))in e?Object.defineProperty(e,t,{value:i,enumerable:!0,configurable:!0,writable:!0}):e[t]=i,e}class A{constructor(e){let{dp:t,opts:i}=e;O(this,\"pressedKeys\",new Set),O(this,\"hotKeys\",new Map([[[[\"Control\",\"ArrowRight\"],[\"Control\",\"ArrowUp\"]],e=>e.month++],[[[\"Control\",\"ArrowLeft\"],[\"Control\",\"ArrowDown\"]],e=>e.month--],[[[\"Shift\",\"ArrowRight\"],[\"Shift\",\"ArrowUp\"]],e=>e.year++],[[[\"Shift\",\"ArrowLeft\"],[\"Shift\",\"ArrowDown\"]],e=>e.year--],[[[\"Alt\",\"ArrowRight\"],[\"Alt\",\"ArrowUp\"]],e=>e.year+=10],[[[\"Alt\",\"ArrowLeft\"],[\"Alt\",\"ArrowDown\"]],e=>e.year-=10],[[\"Control\",\"Shift\",\"ArrowUp\"],(e,t)=>t.up()]])),O(this,\"handleHotKey\",(e=>{let t=this.hotKeys.get(e),i=h(this.getInitialFocusDate());t(i,this.dp);let{year:s,month:a,date:n}=i,r=o(new Date(s,a));r<n&&(n=r);let l=this.dp.getClampedDate(new Date(s,a,n));this.dp.setFocusDate(l,{viewDateTransition:!0})})),O(this,\"isHotKeyPressed\",(()=>{let e=!1,t=this.pressedKeys.size,i=e=>this.pressedKeys.has(e);for(let[s]of this.hotKeys){if(e)break;if(Array.isArray(s[0]))s.forEach((a=>{e||t!==a.length||(e=a.every(i)&&s)}));else{if(t!==s.length)continue;e=s.every(i)&&s}}return e})),O(this,\"isArrow\",(e=>e>=37&&e<=40)),O(this,\"onKeyDown\",(e=>{let{key:t,which:i}=e,{dp:s,dp:{focusDate:a},opts:n}=this;this.registerKey(t);let r=this.isHotKeyPressed();if(r)return e.preventDefault(),void this.handleHotKey(r);if(this.isArrow(i))return e.preventDefault(),void this.focusNextCell(t);if(\"Enter\"===t){if(s.currentView!==n.minView)return void s.down();if(a){let e=s._checkIfDateIsSelected(a);return void(e?s._handleAlreadySelectedDates(e,a):s.selectDate(a))}}\"Escape\"===t&&this.dp.hide()})),O(this,\"onKeyUp\",(e=>{this.removeKey(e.key)})),this.dp=t,this.opts=i,this.init()}init(){this.bindKeyboardEvents()}bindKeyboardEvents(){let{$el:e}=this.dp;e.addEventListener(\"keydown\",this.onKeyDown),e.addEventListener(\"keyup\",this.onKeyUp)}destroy(){let{$el:e}=this.dp;e.removeEventListener(\"keydown\",this.onKeyDown),e.removeEventListener(\"keyup\",this.onKeyUp),this.hotKeys=null,this.pressedKeys=null}getInitialFocusDate(){let{focusDate:e,currentView:t,selectedDates:s,parsedViewDate:{year:a,month:n}}=this.dp,r=e||s[s.length-1];if(!r)switch(t){case i.days:r=new Date(a,n,(new Date).getDate());break;case i.months:r=new Date(a,n,1);break;case i.years:r=new Date(a,0,1)}return r}focusNextCell(e){let t=this.getInitialFocusDate(),{currentView:s}=this.dp,{days:a,months:n,years:r}=i,o=h(t),l=o.year,d=o.month,c=o.date;switch(e){case\"ArrowLeft\":s===a&&(c-=1),s===n&&(d-=1),s===r&&(l-=1);break;case\"ArrowUp\":s===a&&(c-=7),s===n&&(d-=3),s===r&&(l-=4);break;case\"ArrowRight\":s===a&&(c+=1),s===n&&(d+=1),s===r&&(l+=1);break;case\"ArrowDown\":s===a&&(c+=7),s===n&&(d+=3),s===r&&(l+=4)}let u=this.dp.getClampedDate(new Date(l,d,c));this.dp.setFocusDate(u,{viewDateTransition:!0})}registerKey(e){this.pressedKeys.add(e)}removeKey(e){this.pressedKeys.delete(e)}}let N={on(e,t){this.__events||(this.__events={}),this.__events[e]?this.__events[e].push(t):this.__events[e]=[t]},off(e,t){this.__events&&this.__events[e]&&(this.__events[e]=this.__events[e].filter((e=>e!==t)))},removeAllEvents(){this.__events={}},trigger(e){for(var t=arguments.length,i=new Array(t>1?t-1:0),s=1;s<t;s++)i[s-1]=arguments[s];this.__events&&this.__events[e]&&this.__events[e].forEach((e=>{e(...i)}))}};function I(e,t,i){return(t=function(e){var t=function(e,t){if(\"object\"!=typeof e||null===e)return e;var i=e[Symbol.toPrimitive];if(void 0!==i){var s=i.call(e,\"string\");if(\"object\"!=typeof s)return s;throw new TypeError(\"@@toPrimitive must return a primitive value.\")}return String(e)}(e);return\"symbol\"==typeof t?t:String(t)}(t))in e?Object.defineProperty(e,t,{value:i,enumerable:!0,configurable:!0,writable:!0}):e[t]=i,e}let P=\"\",j=\"\",B=!1;class R{static buildGlobalContainer(e){B=!0,P=n({className:e,id:e}),a(\"body\").appendChild(P)}constructor(e,t){var r=this;if(I(this,\"viewIndexes\",[i.days,i.months,i.years]),I(this,\"next\",(()=>{let{year:e,month:t}=this.parsedViewDate;switch(this.currentView){case i.days:this.setViewDate(new Date(e,t+1,1));break;case i.months:this.setViewDate(new Date(e+1,t,1));break;case i.years:this.setViewDate(new Date(e+10,0,1))}})),I(this,\"prev\",(()=>{let{year:e,month:t}=this.parsedViewDate;switch(this.currentView){case i.days:this.setViewDate(new Date(e,t-1,1));break;case i.months:this.setViewDate(new Date(e-1,t,1));break;case i.years:this.setViewDate(new Date(e-10,0,1))}})),I(this,\"_finishHide\",(()=>{this.hideAnimation=!1,this._destroyComponents(),this.$container.removeChild(this.$datepicker)})),I(this,\"setPosition\",(function(e){let t=arguments.length>1&&void 0!==arguments[1]&&arguments[1];if(\"function\"==typeof(e=e||r.opts.position))return void(r.customHide=e({$datepicker:r.$datepicker,$target:r.$el,$pointer:r.$pointer,isViewChange:t,done:r._finishHide}));let i,s,{isMobile:a}=r.opts,n=r.$el.getBoundingClientRect(),o=r.$el.getBoundingClientRect(),h=r.$datepicker.offsetParent,l=r.$el.offsetParent,d=r.$datepicker.getBoundingClientRect(),c=e.split(\" \"),u=window.scrollY,p=window.scrollX,m=r.opts.offset,v=c[0],g=c[1];if(a)r.$datepicker.style.cssText=\"left: 50%; top: 50%\";else{if(h===l&&h!==document.body&&(o={top:r.$el.offsetTop,left:r.$el.offsetLeft,width:n.width,height:r.$el.offsetHeight},u=0,p=0),h!==l&&h!==document.body){let e=h.getBoundingClientRect();o={top:n.top-e.top,left:n.left-e.left,width:n.width,height:n.height},u=0,p=0}switch(v){case\"top\":i=o.top-d.height-m;break;case\"right\":s=o.left+o.width+m;break;case\"bottom\":i=o.top+o.height+m;break;case\"left\":s=o.left-d.width-m}switch(g){case\"top\":i=o.top;break;case\"right\":s=o.left+o.width-d.width;break;case\"bottom\":i=o.top+o.height-d.height;break;case\"left\":s=o.left;break;case\"center\":/left|right/.test(v)?i=o.top+o.height/2-d.height/2:s=o.left+o.width/2-d.width/2}r.$datepicker.style.cssText=`left: ${s+p}px; top: ${i+u}px`}})),I(this,\"_setInputValue\",(()=>{let{opts:e,$altField:t,locale:{dateFormat:i}}=this,{altFieldDateFormat:s,altField:a}=e;a&&t&&(t.value=this._getInputValue(s)),this.$el.value=this._getInputValue(i)})),I(this,\"_getInputValue\",(e=>{let{selectedDates:t,opts:i}=this,{multipleDates:s,multipleDatesSeparator:a}=i;if(!t.length)return\"\";let n=\"function\"==typeof e,r=n?e(s?t:t[0]):t.map((t=>this.formatDate(t,e)));return r=n?r:r.join(a),r})),I(this,\"_checkIfDateIsSelected\",(function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:i.days,s=!1;return r.selectedDates.some((i=>{let a=p(e,i,t);return s=a&&i,a})),s})),I(this,\"_scheduleCallAfterTransition\",(e=>{this._cancelScheduledCall(),e&&e(!1),this._onTransitionEnd=()=>{e&&e(!0)},this.$datepicker.addEventListener(\"transitionend\",this._onTransitionEnd,{once:!0})})),I(this,\"_cancelScheduledCall\",(()=>{this.$datepicker.removeEventListener(\"transitionend\",this._onTransitionEnd)})),I(this,\"setViewDate\",(e=>{if(!((e=b(e))instanceof Date))return;if(p(e,this.viewDate))return;let t=this.viewDate;this.viewDate=e;let{onChangeViewDate:s}=this.opts;if(s){let{month:e,year:t}=this.parsedViewDate;s({month:e,year:t,decade:this.curDecade})}this.trigger(i.eventChangeViewDate,e,t)})),I(this,\"setFocusDate\",(function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};(!e||(e=b(e))instanceof Date)&&(r.focusDate=e,r.trigger(i.eventChangeFocusDate,e,t))})),I(this,\"setCurrentView\",(function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(r.viewIndexes.includes(e)){if(r.currentView=e,r.elIsInput&&r.visible&&r.setPosition(void 0,!0),r.trigger(i.eventChangeCurrentView,e),!r.views[e]){let t=r.views[e]=new T({dp:r,opts:r.opts,type:e});r.shouldUpdateDOM&&r.$content.appendChild(t.$el)}r.opts.onChangeView&&!t.silent&&r.opts.onChangeView(e)}})),I(this,\"_updateLastSelectedDate\",(e=>{this.lastSelectedDate=e,this.trigger(i.eventChangeLastSelectedDate,e)})),I(this,\"destroy\",(()=>{if(this.isDestroyed)return;let{showEvent:e,isMobile:t}=this.opts,i=this.$datepicker.parentNode;i&&i.removeChild(this.$datepicker),this.$el.removeEventListener(e,this._onFocus),this.$el.removeEventListener(\"blur\",this._onBlur),window.removeEventListener(\"resize\",this._onResize),t&&this._removeMobileAttributes(),this.keyboardNav&&this.keyboardNav.destroy(),this.views=null,this.nav=null,this.$datepicker=null,this.opts={},this.$customContainer=null,this.viewDate=null,this.focusDate=null,this.selectedDates=[],this.rangeDateFrom=null,this.rangeDateTo=null,this.isDestroyed=!0})),I(this,\"update\",(function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},s=w({},r.opts),{silent:a}=t;w(r.opts,e);let{timepicker:n,buttons:o,range:h,selectedDates:l,isMobile:d}=r.opts,c=r.visible||r.treatAsInline;r._createMinMaxDates(),r._limitViewDateByMaxMinDates(),r._handleLocale(),l&&(r.selectedDates=[],r.selectDate(l,{silent:a})),e.view&&r.setCurrentView(e.view,{silent:a}),r._setInputValue(),s.range&&!h?(r.rangeDateTo=!1,r.rangeDateFrom=!1):!s.range&&h&&r.selectedDates.length&&(r.rangeDateFrom=r.selectedDates[0],r.rangeDateTo=r.selectedDates[1]),s.timepicker&&!n?(c&&r.timepicker.destroy(),r.timepicker=!1,r.$timepicker.parentNode.removeChild(r.$timepicker)):!s.timepicker&&n&&r._addTimepicker(),!s.buttons&&o?r._addButtons():s.buttons&&!o?(r.buttons.destroy(),r.$buttons.parentNode.removeChild(r.$buttons)):c&&s.buttons&&o&&r.buttons.clearHtml().render(),!s.isMobile&&d?(r.treatAsInline||j||r._createMobileOverlay(),r._addMobileAttributes(),r.visible&&r._showMobileOverlay()):s.isMobile&&!d&&(r._removeMobileAttributes(),r.visible&&(j.classList.remove(\"-active-\"),\"function\"!=typeof r.opts.position&&r.setPosition())),c&&(r.nav.update(),r.views[r.currentView].render(),r.currentView===i.days&&r.views[r.currentView].renderDayNames())})),I(this,\"disableDate\",((e,t)=>{(Array.isArray(e)?e:[e]).forEach((e=>{let i=b(e);if(!i)return;let s=t?\"delete\":\"add\";this.disabledDates[s](this.formatDate(i,\"yyyy-MM-dd\"));let a=this.getCell(i,this.currentViewSingular);a&&a.adpCell.render()}),[])})),I(this,\"enableDate\",(e=>{this.disableDate(e,!0)})),I(this,\"isDateDisabled\",(e=>{let t=b(e);return this.disabledDates.has(this.formatDate(t,\"yyyy-MM-dd\"))})),I(this,\"isOtherMonth\",(e=>{let{month:t}=h(e);return t!==this.parsedViewDate.month})),I(this,\"isOtherYear\",(e=>{let{year:t}=h(e);return t!==this.parsedViewDate.year})),I(this,\"isOtherDecade\",(e=>{let{year:t}=h(e),[i,s]=c(this.viewDate);return t<i||t>s})),I(this,\"_onChangeSelectedDate\",(e=>{let{silent:t}=e;setTimeout((()=>{this._setInputValue(),this.opts.onSelect&&!t&&this._triggerOnSelect()}))})),I(this,\"_onChangeFocusedDate\",(function(e){let{viewDateTransition:t}=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(!e)return;let i=!1;t&&(i=r.isOtherMonth(e)||r.isOtherYear(e)||r.isOtherDecade(e)),i&&r.setViewDate(e),r.opts.onFocus&&r.opts.onFocus({datepicker:r,date:e})})),I(this,\"_onChangeTime\",(e=>{let{hours:t,minutes:i}=e,s=new Date,{lastSelectedDate:a,opts:{onSelect:n}}=this,r=a;a||(r=s);let o=this.getCell(r,this.currentViewSingular),h=o&&o.adpCell;h&&h.isDisabled||(r.setHours(t),r.setMinutes(i),a?(this._setInputValue(),n&&this._triggerOnSelect()):this.selectDate(r))})),I(this,\"_onFocus\",(e=>{this.visible||this.show()})),I(this,\"_onBlur\",(e=>{this.inFocus||!this.visible||this.opts.isMobile||this.hide()})),I(this,\"_onMouseDown\",(e=>{this.inFocus=!0})),I(this,\"_onMouseUp\",(e=>{this.inFocus=!1,this.$el.focus()})),I(this,\"_onResize\",(()=>{this.visible&&\"function\"!=typeof this.opts.position&&this.setPosition()})),I(this,\"_onClickOverlay\",(()=>{this.visible&&this.hide()})),I(this,\"getViewDates\",(function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:i.days;return T.getDatesFunction(e)(r)})),I(this,\"isWeekend\",(e=>this.opts.weekends.includes(e))),I(this,\"getClampedDate\",(e=>{let{minDate:t,maxDate:i}=this,s=e;return i&&m(e,i)?s=i:t&&v(e,t)&&(s=t),s})),this.$el=a(e),!this.$el)return;this.$datepicker=n({className:\"air-datepicker\"}),this.opts=w({},s,t),this.$customContainer=!!this.opts.container&&a(this.opts.container),this.$altField=a(this.opts.altField||!1);let{view:o,startDate:l}=this.opts;l||(this.opts.startDate=new Date),\"INPUT\"===this.$el.nodeName&&(this.elIsInput=!0),this.inited=!1,this.visible=!1,this.viewDate=b(this.opts.startDate),this.focusDate=!1,this.initialReadonly=this.$el.getAttribute(\"readonly\"),this.customHide=!1,this.currentView=o,this.selectedDates=[],this.disabledDates=new Set,this.isDestroyed=!1,this.views={},this.keys=[],this.rangeDateFrom=\"\",this.rangeDateTo=\"\",this.timepickerIsActive=!1,this.treatAsInline=this.opts.inline||!this.elIsInput,this.init()}init(){let{opts:e,treatAsInline:t,opts:{inline:i,isMobile:s,selectedDates:n,keyboardNav:r,onlyTimepicker:o}}=this,h=a(\"body\");(!B||B&&P&&!h.contains(P))&&!i&&this.elIsInput&&!this.$customContainer&&R.buildGlobalContainer(R.defaultGlobalContainerId),!s||j||t||this._createMobileOverlay(),this._handleLocale(),this._bindSubEvents(),this._createMinMaxDates(),this._limitViewDateByMaxMinDates(),this.elIsInput&&(i||this._bindEvents(),r&&!o&&(this.keyboardNav=new A({dp:this,opts:e}))),n&&this.selectDate(n,{silent:!0}),this.opts.visible&&!t&&this.show(),s&&!t&&this.$el.setAttribute(\"readonly\",!0),t&&this._createComponents()}_createMobileOverlay(){j=n({className:\"air-datepicker-overlay\"}),P.appendChild(j)}_createComponents(){let{opts:e,treatAsInline:t,opts:{inline:i,buttons:s,timepicker:a,position:n,classes:r,onlyTimepicker:o,isMobile:h}}=this;this._buildBaseHtml(),this.elIsInput&&(i||this._setPositionClasses(n)),!i&&this.elIsInput||this.$datepicker.classList.add(\"-inline-\"),r&&this.$datepicker.classList.add(...r.split(\" \")),o&&this.$datepicker.classList.add(\"-only-timepicker-\"),h&&!t&&this._addMobileAttributes(),this.views[this.currentView]=new T({dp:this,type:this.currentView,opts:e}),this.nav=new V({dp:this,opts:e}),a&&this._addTimepicker(),s&&this._addButtons(),this.$content.appendChild(this.views[this.currentView].$el),this.$nav.appendChild(this.nav.$el)}_destroyComponents(){for(let e in this.views)this.views[e].destroy();this.views={},this.nav.destroy(),this.timepicker&&this.timepicker.destroy()}_addMobileAttributes(){j.addEventListener(\"click\",this._onClickOverlay),this.$datepicker.classList.add(\"-is-mobile-\"),this.$el.setAttribute(\"readonly\",!0)}_removeMobileAttributes(){j.removeEventListener(\"click\",this._onClickOverlay),this.$datepicker.classList.remove(\"-is-mobile-\"),this.initialReadonly||\"\"===this.initialReadonly||this.$el.removeAttribute(\"readonly\")}_createMinMaxDates(){let{minDate:e,maxDate:t}=this.opts;this.minDate=!!e&&b(e),this.maxDate=!!t&&b(t)}_addTimepicker(){this.$timepicker=n({className:\"air-datepicker--time\"}),this.$datepicker.appendChild(this.$timepicker),this.timepicker=new L({dp:this,opts:this.opts}),this.$timepicker.appendChild(this.timepicker.$el)}_addButtons(){this.$buttons=n({className:\"air-datepicker--buttons\"}),this.$datepicker.appendChild(this.$buttons),this.buttons=new H({dp:this,opts:this.opts}),this.$buttons.appendChild(this.buttons.$el)}_bindSubEvents(){this.on(i.eventChangeSelectedDate,this._onChangeSelectedDate),this.on(i.eventChangeFocusDate,this._onChangeFocusedDate),this.on(i.eventChangeTime,this._onChangeTime)}_buildBaseHtml(){let{inline:e}=this.opts;var t,i;this.elIsInput?e?(t=this.$datepicker,(i=this.$el).parentNode.insertBefore(t,i.nextSibling)):this.$container.appendChild(this.$datepicker):this.$el.appendChild(this.$datepicker),this.$datepicker.innerHTML='<i class=\"air-datepicker--pointer\"></i><div class=\"air-datepicker--navigation\"></div><div class=\"air-datepicker--content\"></div>',this.$content=a(\".air-datepicker--content\",this.$datepicker),this.$pointer=a(\".air-datepicker--pointer\",this.$datepicker),this.$nav=a(\".air-datepicker--navigation\",this.$datepicker)}_handleLocale(){let{locale:e,dateFormat:t,firstDay:i,timepicker:s,onlyTimepicker:a,timeFormat:n,dateTimeSeparator:r}=this.opts;var o;this.locale=(o=e,JSON.parse(JSON.stringify(o))),t&&(this.locale.dateFormat=t),void 0!==n&&\"\"!==n&&(this.locale.timeFormat=n);let{timeFormat:h}=this.locale;if(\"\"!==i&&(this.locale.firstDay=i),s&&\"function\"!=typeof t){let e=h?r:\"\";this.locale.dateFormat=[this.locale.dateFormat,h||\"\"].join(e)}a&&\"function\"!=typeof t&&(this.locale.dateFormat=this.locale.timeFormat)}_setPositionClasses(e){if(\"function\"==typeof e)return void this.$datepicker.classList.add(\"-custom-position-\");let t=(e=e.split(\" \"))[0],i=`air-datepicker -${t}-${e[1]}- -from-${t}-`;this.$datepicker.classList.add(...i.split(\" \"))}_bindEvents(){this.$el.addEventListener(this.opts.showEvent,this._onFocus),this.$el.addEventListener(\"blur\",this._onBlur),this.$datepicker.addEventListener(\"mousedown\",this._onMouseDown),this.$datepicker.addEventListener(\"mouseup\",this._onMouseUp),window.addEventListener(\"resize\",this._onResize)}_limitViewDateByMaxMinDates(){let{viewDate:e,minDate:t,maxDate:i}=this;i&&m(e,i)&&this.setViewDate(i),t&&v(e,t)&&this.setViewDate(t)}formatDate(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.viewDate,t=arguments.length>1?arguments[1]:void 0;if(e=b(e),!(e instanceof Date))return;let i=t,s=this.locale,a=h(e),n=a.dayPeriod,r=c(e),o=R.replacer,l={T:e.getTime(),m:a.minutes,mm:a.fullMinutes,h:a.hours12,hh:a.fullHours12,H:a.hours,HH:a.fullHours,aa:n,AA:n.toUpperCase(),E:s.daysShort[a.day],EEEE:s.days[a.day],d:a.date,dd:a.fullDate,M:a.month+1,MM:a.fullMonth,MMM:s.monthsShort[a.month],MMMM:s.months[a.month],yy:a.year.toString().slice(-2),yyyy:a.year,yyyy1:r[0],yyyy2:r[1]};for(let[e,t]of Object.entries(l))i=o(i,k(e),t);return i}down(e){this._handleUpDownActions(e,\"down\")}up(e){this._handleUpDownActions(e,\"up\")}selectDate(e){let t,s=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},{currentView:a,parsedViewDate:n,selectedDates:r}=this,{updateTime:o}=s,{moveToOtherMonthsOnSelect:h,moveToOtherYearsOnSelect:l,multipleDates:d,range:c,autoClose:u,onBeforeSelect:p}=this.opts,v=r.length;if(Array.isArray(e))return e.forEach((e=>{this.selectDate(e,s)})),new Promise((e=>{setTimeout(e)}));if((e=b(e))instanceof Date){if(p&&!p({date:e,datepicker:this}))return Promise.resolve();if(a===i.days&&e.getMonth()!==n.month&&h&&(t=new Date(e.getFullYear(),e.getMonth(),1)),a===i.years&&e.getFullYear()!==n.year&&l&&(t=new Date(e.getFullYear(),0,1)),t&&this.setViewDate(t),d&&!c){if(v===d)return;this._checkIfDateIsSelected(e)||r.push(e)}else if(c)switch(v){case 1:r.push(e),this.rangeDateTo||(this.rangeDateTo=e),m(this.rangeDateFrom,this.rangeDateTo)&&(this.rangeDateTo=this.rangeDateFrom,this.rangeDateFrom=e),this.selectedDates=[this.rangeDateFrom,this.rangeDateTo];break;case 2:this.selectedDates=[e],this.rangeDateFrom=e,this.rangeDateTo=\"\";break;default:this.selectedDates=[e],this.rangeDateFrom=e}else this.selectedDates=[e];return this.trigger(i.eventChangeSelectedDate,{action:i.actionSelectDate,silent:null==s?void 0:s.silent,date:e,updateTime:o}),this._updateLastSelectedDate(e),u&&!this.timepickerIsActive&&this.visible&&(d||c?c&&1===v&&this.hide():this.hide()),new Promise((e=>{setTimeout(e)}))}}unselectDate(e){let t=this.selectedDates,s=this;if((e=b(e))instanceof Date)return t.some(((a,n)=>{if(p(a,e))return t.splice(n,1),s.selectedDates.length?(s.rangeDateTo=\"\",s.rangeDateFrom=t[0],s._updateLastSelectedDate(s.selectedDates[s.selectedDates.length-1])):(s.rangeDateFrom=\"\",s.rangeDateTo=\"\",s._updateLastSelectedDate(!1)),this.trigger(i.eventChangeSelectedDate,{action:i.actionUnselectDate,date:e}),!0}))}replaceDate(e,t){let s=this.selectedDates.find((t=>p(t,e,this.currentView))),a=this.selectedDates.indexOf(s);a<0||p(this.selectedDates[a],t,this.currentView)||(this.selectedDates[a]=t,this.trigger(i.eventChangeSelectedDate,{action:i.actionSelectDate,date:t,updateTime:!0}),this._updateLastSelectedDate(t))}clear(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return this.selectedDates=[],this.rangeDateFrom=!1,this.rangeDateTo=!1,this.lastSelectedDate=!1,this.trigger(i.eventChangeSelectedDate,{action:i.actionUnselectDate,silent:e.silent}),new Promise((e=>{setTimeout(e)}))}show(){let{onShow:e,isMobile:t}=this.opts;this._cancelScheduledCall(),this.visible||this.hideAnimation||this._createComponents(),this.setPosition(this.opts.position),this.$datepicker.classList.add(\"-active-\"),this.visible=!0,e&&this._scheduleCallAfterTransition(e),t&&this._showMobileOverlay()}hide(){let{onHide:e,isMobile:t}=this.opts,i=this._hasTransition();this.visible=!1,this.hideAnimation=!0,this.$datepicker.classList.remove(\"-active-\"),this.customHide&&this.customHide(),this.elIsInput&&this.$el.blur(),this._scheduleCallAfterTransition((t=>{!this.customHide&&(t&&i||!t&&!i)&&this._finishHide(),e&&e(t)})),t&&j.classList.remove(\"-active-\")}_triggerOnSelect(){let e=[],t=[],{selectedDates:i,locale:s,opts:{onSelect:a,multipleDates:n,range:r}}=this,o=n||r,h=\"function\"==typeof s.dateFormat;i.length&&(e=i.map(g),t=h?n?s.dateFormat(e):e.map((e=>s.dateFormat(e))):e.map((e=>this.formatDate(e,s.dateFormat)))),a({date:o?e:e[0],formattedDate:o?t:t[0],datepicker:this})}_handleAlreadySelectedDates(e,t){let{selectedDates:i,rangeDateFrom:s,rangeDateTo:a}=this,{range:n,toggleSelected:r}=this.opts,o=i.length,h=\"function\"==typeof r?r({datepicker:this,date:t}):r,l=Boolean(n&&1===o&&e),d=l?g(t):t;n&&!h&&(2!==o&&this.selectDate(d),2===o&&p(s,a))||(h?this.unselectDate(d):this._updateLastSelectedDate(l?d:e))}_handleUpDownActions(e,t){if(!((e=b(e||this.focusDate||this.viewDate))instanceof Date))return;let i=\"up\"===t?this.viewIndex+1:this.viewIndex-1;i>2&&(i=2),i<0&&(i=0),this.setViewDate(new Date(e.getFullYear(),e.getMonth(),1)),this.setCurrentView(this.viewIndexes[i])}getCell(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:i.day;if(!((e=b(e))instanceof Date))return;let{year:s,month:a,date:n}=h(e),r=`[data-year=\"${s}\"]`,o=`[data-month=\"${a}\"]`,l={[i.day]:`${r}${o}[data-date=\"${n}\"]`,[i.month]:`${r}${o}`,[i.year]:`${r}`};return this.views[this.currentView]?this.views[this.currentView].$el.querySelector(l[t]):void 0}_showMobileOverlay(){j.classList.add(\"-active-\")}_hasTransition(){return window.getComputedStyle(this.$datepicker).getPropertyValue(\"transition-duration\").split(\", \").reduce(((e,t)=>parseFloat(t)+e),0)>0}get shouldUpdateDOM(){return this.visible||this.treatAsInline}get parsedViewDate(){return h(this.viewDate)}get currentViewSingular(){return this.currentView.slice(0,-1)}get curDecade(){return c(this.viewDate)}get viewIndex(){return this.viewIndexes.indexOf(this.currentView)}get isFinalView(){return this.currentView===i.years}get hasSelectedDates(){return this.selectedDates.length>0}get isMinViewReached(){return this.currentView===this.opts.minView||this.currentView===i.days}get $container(){return this.$customContainer||P}static replacer(e,t,i){return e.replace(t,(function(e,t,s,a){return t+i+a}))}}var K;return I(R,\"defaults\",s),I(R,\"version\",\"3.5.3\"),I(R,\"defaultGlobalContainerId\",\"air-datepicker-global-container\"),K=R.prototype,Object.assign(K,N),t.default}()}));","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _default = {\n days: ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'],\n daysShort: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],\n daysMin: ['Su', 'Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa'],\n months: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'],\n monthsShort: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'],\n today: 'Today',\n clear: 'Clear',\n dateFormat: 'MM/dd/yyyy',\n timeFormat: 'hh:mm aa',\n firstDay: 0\n};\nexports.default = _default;","@import '../../../theme.scss';\n\nverdocs-field-date {\n font-family: $verdocs-primary-font;\n width: 74px;\n height: 20px;\n display: block;\n font-size: 11px;\n position: relative;\n scroll-margin: 20px 0;\n letter-spacing: 0.3px;\n background-color: transparent;\n transform-origin: bottom left;\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n label {\n top: -14px;\n left: 0;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n input {\n position: absolute;\n\n font-size: 12px;\n\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n box-sizing: border-box;\n color: rgba(0, 0, 0, 0.87);\n font-weight: 500;\n transform-origin: 0 0;\n height: 100%;\n width: 100%;\n background: none;\n border: 1px solid $light-border-color;\n appearance: none;\n\n &.hide {\n display: none;\n }\n }\n\n &.disabled input {\n opacity: 0.5;\n }\n\n &.required {\n input {\n border: 1px solid $verdocs-red-1;\n }\n }\n\n verdocs-button-panel {\n top: -3px;\n left: -2px;\n opacity: 0.5;\n z-index: 1000;\n cursor: pointer;\n position: absolute;\n transform: scale(0.6);\n\n &[data-active],\n &:hover {\n opacity: 1;\n }\n\n .icon {\n svg {\n fill: #333333;\n }\n\n &:hover {\n svg {\n fill: #000000;\n }\n }\n }\n }\n\n .settings-icon {\n position: absolute;\n top: -3px;\n left: -18px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n.air-datepicker-cell.-year-.-other-decade-,\n.air-datepicker-cell.-day-.-other-month- {\n color: var(--adp-color-other-month);\n}\n.air-datepicker-cell.-year-.-other-decade-:hover,\n.air-datepicker-cell.-day-.-other-month-:hover {\n color: var(--adp-color-other-month-hover);\n}\n.-disabled-.-focus-.air-datepicker-cell.-year-.-other-decade-,\n.-disabled-.-focus-.air-datepicker-cell.-day-.-other-month- {\n color: var(--adp-color-other-month);\n}\n.-selected-.air-datepicker-cell.-year-.-other-decade-,\n.-selected-.air-datepicker-cell.-day-.-other-month- {\n color: #fff;\n background: var(--adp-background-color-selected-other-month);\n}\n.-selected-.-focus-.air-datepicker-cell.-year-.-other-decade-,\n.-selected-.-focus-.air-datepicker-cell.-day-.-other-month- {\n background: var(--adp-background-color-selected-other-month-focused);\n}\n.-in-range-.air-datepicker-cell.-year-.-other-decade-,\n.-in-range-.air-datepicker-cell.-day-.-other-month- {\n background-color: var(--adp-background-color-in-range);\n color: var(--adp-color);\n}\n.-in-range-.-focus-.air-datepicker-cell.-year-.-other-decade-,\n.-in-range-.-focus-.air-datepicker-cell.-day-.-other-month- {\n background-color: var(--adp-background-color-in-range-focused);\n}\n.air-datepicker-cell.-year-.-other-decade-:empty,\n.air-datepicker-cell.-day-.-other-month-:empty {\n background: none;\n border: none;\n}\n.air-datepicker-cell {\n border-radius: var(--adp-cell-border-radius);\n box-sizing: border-box;\n cursor: pointer;\n display: flex;\n position: relative;\n align-items: center;\n justify-content: center;\n z-index: 1;\n}\n.air-datepicker-cell.-focus- {\n background: var(--adp-cell-background-color-hover);\n}\n.air-datepicker-cell.-current- {\n color: var(--adp-color-current-date);\n}\n.air-datepicker-cell.-current-.-focus- {\n color: var(--adp-color);\n}\n.air-datepicker-cell.-current-.-in-range- {\n color: var(--adp-color-current-date);\n}\n.air-datepicker-cell.-disabled- {\n cursor: default;\n color: var(--adp-color-disabled);\n}\n.air-datepicker-cell.-disabled-.-focus- {\n color: var(--adp-color-disabled);\n}\n.air-datepicker-cell.-disabled-.-in-range- {\n color: var(--adp-color-disabled-in-range);\n}\n.air-datepicker-cell.-disabled-.-current-.-focus- {\n color: var(--adp-color-disabled);\n}\n.air-datepicker-cell.-in-range- {\n background: var(--adp-cell-background-color-in-range);\n border-radius: 0;\n}\n.air-datepicker-cell.-in-range-:hover {\n background: var(--adp-cell-background-color-in-range-hover);\n}\n.air-datepicker-cell.-range-from- {\n border: 1px solid var(--adp-cell-border-color-in-range);\n background-color: var(--adp-cell-background-color-in-range);\n border-radius: var(--adp-cell-border-radius) 0 0 var(--adp-cell-border-radius);\n}\n.air-datepicker-cell.-range-to- {\n border: 1px solid var(--adp-cell-border-color-in-range);\n background-color: var(--adp-cell-background-color-in-range);\n border-radius: 0 var(--adp-cell-border-radius) var(--adp-cell-border-radius) 0;\n}\n.air-datepicker-cell.-range-to-.-range-from- {\n border-radius: var(--adp-cell-border-radius);\n}\n.air-datepicker-cell.-selected- {\n color: #fff;\n border: none;\n background: var(--adp-cell-background-color-selected);\n}\n.air-datepicker-cell.-selected-.-current- {\n color: #fff;\n background: var(--adp-cell-background-color-selected);\n}\n.air-datepicker-cell.-selected-.-focus- {\n background: var(--adp-cell-background-color-selected-hover);\n}\n.air-datepicker-body {\n transition: all var(--adp-transition-duration) var(--adp-transition-ease);\n}\n.air-datepicker-body.-hidden- {\n display: none;\n}\n.air-datepicker-body--day-names {\n display: grid;\n grid-template-columns: repeat(7, var(--adp-day-cell-width));\n margin: 8px 0 3px;\n}\n.air-datepicker-body--day-name {\n color: var(--adp-day-name-color);\n display: flex;\n align-items: center;\n justify-content: center;\n flex: 1;\n text-align: center;\n text-transform: uppercase;\n font-size: 0.8em;\n}\n.air-datepicker-body--day-name.-clickable- {\n cursor: pointer;\n}\n.air-datepicker-body--day-name.-clickable-:hover {\n color: var(--adp-day-name-color-hover);\n}\n.air-datepicker-body--cells {\n display: grid;\n}\n.air-datepicker-body--cells.-days- {\n grid-template-columns: repeat(7, var(--adp-day-cell-width));\n grid-auto-rows: var(--adp-day-cell-height);\n}\n.air-datepicker-body--cells.-months- {\n grid-template-columns: repeat(3, 1fr);\n grid-auto-rows: var(--adp-month-cell-height);\n}\n.air-datepicker-body--cells.-years- {\n grid-template-columns: repeat(4, 1fr);\n grid-auto-rows: var(--adp-year-cell-height);\n}\n.air-datepicker-nav {\n display: flex;\n justify-content: space-between;\n border-bottom: 1px solid var(--adp-border-color-inner);\n min-height: var(--adp-nav-height);\n padding: var(--adp-padding);\n box-sizing: content-box;\n}\n.-only-timepicker- .air-datepicker-nav {\n display: none;\n}\n.air-datepicker-nav--title,\n.air-datepicker-nav--action {\n display: flex;\n cursor: pointer;\n align-items: center;\n justify-content: center;\n}\n.air-datepicker-nav--action {\n width: var(--adp-nav-action-size);\n border-radius: var(--adp-border-radius);\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n}\n.air-datepicker-nav--action:hover {\n background: var(--adp-background-color-hover);\n}\n.air-datepicker-nav--action:active {\n background: var(--adp-background-color-active);\n}\n.air-datepicker-nav--action.-disabled- {\n visibility: hidden;\n}\n.air-datepicker-nav--action svg {\n width: 32px;\n height: 32px;\n}\n.air-datepicker-nav--action path {\n fill: none;\n stroke: var(--adp-nav-arrow-color);\n stroke-width: 2px;\n}\n.air-datepicker-nav--title {\n border-radius: var(--adp-border-radius);\n padding: 0 8px;\n}\n.air-datepicker-nav--title i {\n font-style: normal;\n color: var(--adp-nav-color-secondary);\n margin-left: 0.3em;\n}\n.air-datepicker-nav--title:hover {\n background: var(--adp-background-color-hover);\n}\n.air-datepicker-nav--title:active {\n background: var(--adp-background-color-active);\n}\n.air-datepicker-nav--title.-disabled- {\n cursor: default;\n background: none;\n}\n.air-datepicker-buttons {\n display: grid;\n grid-auto-columns: 1fr;\n grid-auto-flow: column;\n}\n.air-datepicker-button {\n display: inline-flex;\n color: var(--adp-btn-color);\n border-radius: var(--adp-btn-border-radius);\n cursor: pointer;\n height: var(--adp-btn-height);\n border: none;\n background: rgba(255, 255, 255, 0);\n}\n.air-datepicker-button:hover {\n color: var(--adp-btn-color-hover);\n background: var(--adp-btn-background-color-hover);\n}\n.air-datepicker-button:focus {\n color: var(--adp-btn-color-hover);\n background: var(--adp-btn-background-color-hover);\n outline: none;\n}\n.air-datepicker-button:active {\n background: var(--adp-btn-background-color-active);\n}\n.air-datepicker-button span {\n outline: none;\n display: flex;\n align-items: center;\n justify-content: center;\n width: 100%;\n height: 100%;\n}\n.air-datepicker-time {\n display: grid;\n grid-template-columns: max-content 1fr;\n grid-column-gap: 12px;\n align-items: center;\n position: relative;\n padding: 0 var(--adp-time-padding-inner);\n}\n.-only-timepicker- .air-datepicker-time {\n border-top: none;\n}\n.air-datepicker-time--current {\n display: flex;\n align-items: center;\n flex: 1;\n font-size: 14px;\n text-align: center;\n}\n.air-datepicker-time--current-colon {\n margin: 0 2px 3px;\n line-height: 1;\n}\n.air-datepicker-time--current-hours,\n.air-datepicker-time--current-minutes {\n line-height: 1;\n font-size: 19px;\n font-family: 'Century Gothic', CenturyGothic, AppleGothic, sans-serif;\n position: relative;\n z-index: 1;\n}\n.air-datepicker-time--current-hours:after,\n.air-datepicker-time--current-minutes:after {\n content: '';\n background: var(--adp-background-color-hover);\n border-radius: var(--adp-border-radius);\n position: absolute;\n left: -2px;\n top: -3px;\n right: -2px;\n bottom: -2px;\n z-index: -1;\n opacity: 0;\n}\n.air-datepicker-time--current-hours.-focus-:after,\n.air-datepicker-time--current-minutes.-focus-:after {\n opacity: 1;\n}\n.air-datepicker-time--current-ampm {\n text-transform: uppercase;\n align-self: flex-end;\n color: var(--adp-time-day-period-color);\n margin-left: 6px;\n font-size: 11px;\n margin-bottom: 1px;\n}\n.air-datepicker-time--row {\n display: flex;\n align-items: center;\n font-size: 11px;\n height: 17px;\n background: linear-gradient(to right, var(--adp-time-track-color), var(--adp-time-track-color)) left 50%/100% var(--adp-time-track-height) no-repeat;\n}\n.air-datepicker-time--row:first-child {\n margin-bottom: 4px;\n}\n.air-datepicker-time--row input[type='range'] {\n background: none;\n cursor: pointer;\n flex: 1;\n height: 100%;\n width: 100%;\n padding: 0;\n margin: 0;\n -webkit-appearance: none;\n}\n.air-datepicker-time--row input[type='range']::-webkit-slider-thumb {\n -webkit-appearance: none;\n}\n.air-datepicker-time--row input[type='range']::-ms-tooltip {\n display: none;\n}\n.air-datepicker-time--row input[type='range']:hover::-webkit-slider-thumb {\n border-color: var(--adp-time-track-color-hover);\n}\n.air-datepicker-time--row input[type='range']:hover::-moz-range-thumb {\n border-color: var(--adp-time-track-color-hover);\n}\n.air-datepicker-time--row input[type='range']:hover::-ms-thumb {\n border-color: var(--adp-time-track-color-hover);\n}\n.air-datepicker-time--row input[type='range']:focus {\n outline: none;\n}\n.air-datepicker-time--row input[type='range']:focus::-webkit-slider-thumb {\n background: var(--adp-cell-background-color-selected);\n border-color: var(--adp-cell-background-color-selected);\n}\n.air-datepicker-time--row input[type='range']:focus::-moz-range-thumb {\n background: var(--adp-cell-background-color-selected);\n border-color: var(--adp-cell-background-color-selected);\n}\n.air-datepicker-time--row input[type='range']:focus::-ms-thumb {\n background: var(--adp-cell-background-color-selected);\n border-color: var(--adp-cell-background-color-selected);\n}\n.air-datepicker-time--row input[type='range']::-webkit-slider-thumb {\n box-sizing: border-box;\n height: 12px;\n width: 12px;\n border-radius: 3px;\n border: 1px solid var(--adp-time-track-color);\n background: #fff;\n cursor: pointer;\n -webkit-transition: background var(--adp-transition-duration);\n transition: background var(--adp-transition-duration);\n}\n.air-datepicker-time--row input[type='range']::-moz-range-thumb {\n box-sizing: border-box;\n height: 12px;\n width: 12px;\n border-radius: 3px;\n border: 1px solid var(--adp-time-track-color);\n background: #fff;\n cursor: pointer;\n -moz-transition: background var(--adp-transition-duration);\n transition: background var(--adp-transition-duration);\n}\n.air-datepicker-time--row input[type='range']::-ms-thumb {\n box-sizing: border-box;\n height: 12px;\n width: 12px;\n border-radius: 3px;\n border: 1px solid var(--adp-time-track-color);\n background: #fff;\n cursor: pointer;\n -ms-transition: background var(--adp-transition-duration);\n transition: background var(--adp-transition-duration);\n}\n.air-datepicker-time--row input[type='range']::-webkit-slider-thumb {\n margin-top: calc(var(--adp-time-thumb-size) / 2 * -1);\n}\n.air-datepicker-time--row input[type='range']::-webkit-slider-runnable-track {\n border: none;\n height: var(--adp-time-track-height);\n cursor: pointer;\n color: rgba(0, 0, 0, 0);\n background: rgba(0, 0, 0, 0);\n}\n.air-datepicker-time--row input[type='range']::-moz-range-track {\n border: none;\n height: var(--adp-time-track-height);\n cursor: pointer;\n color: rgba(0, 0, 0, 0);\n background: rgba(0, 0, 0, 0);\n}\n.air-datepicker-time--row input[type='range']::-ms-track {\n border: none;\n height: var(--adp-time-track-height);\n cursor: pointer;\n color: rgba(0, 0, 0, 0);\n background: rgba(0, 0, 0, 0);\n}\n.air-datepicker-time--row input[type='range']::-ms-fill-lower {\n background: rgba(0, 0, 0, 0);\n}\n.air-datepicker-time--row input[type='range']::-ms-fill-upper {\n background: rgba(0, 0, 0, 0);\n}\n.air-datepicker {\n --adp-font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol';\n --adp-font-size: 14px;\n --adp-width: 246px;\n --adp-z-index: 100;\n --adp-padding: 4px;\n --adp-grid-areas: 'nav' 'body' 'timepicker' 'buttons';\n --adp-transition-duration: 0.3s;\n --adp-transition-ease: ease-out;\n --adp-transition-offset: 8px;\n --adp-background-color: #fff;\n --adp-background-color-hover: #f0f0f0;\n --adp-background-color-active: #eaeaea;\n --adp-background-color-in-range: rgba(92, 196, 239, 0.1);\n --adp-background-color-in-range-focused: rgba(92, 196, 239, 0.2);\n --adp-background-color-selected-other-month-focused: #8ad5f4;\n --adp-background-color-selected-other-month: #a2ddf6;\n --adp-color: #4a4a4a;\n --adp-color-secondary: #9c9c9c;\n --adp-accent-color: #4eb5e6;\n --adp-color-current-date: var(--adp-accent-color);\n --adp-color-other-month: #dedede;\n --adp-color-disabled: #aeaeae;\n --adp-color-disabled-in-range: #939393;\n --adp-color-other-month-hover: #c5c5c5;\n --adp-border-color: #dbdbdb;\n --adp-border-color-inner: #efefef;\n --adp-border-radius: 4px;\n --adp-border-color-inline: #d7d7d7;\n --adp-nav-height: 32px;\n --adp-nav-arrow-color: var(--adp-color-secondary);\n --adp-nav-action-size: 32px;\n --adp-nav-color-secondary: var(--adp-color-secondary);\n --adp-day-name-color: #ff9a19;\n --adp-day-name-color-hover: #8ad5f4;\n --adp-day-cell-width: 1fr;\n --adp-day-cell-height: 32px;\n --adp-month-cell-height: 42px;\n --adp-year-cell-height: 56px;\n --adp-pointer-size: 10px;\n --adp-poiner-border-radius: 2px;\n --adp-pointer-offset: 14px;\n --adp-cell-border-radius: 4px;\n --adp-cell-background-color-hover: var(--adp-background-color-hover);\n --adp-cell-background-color-selected: #5cc4ef;\n --adp-cell-background-color-selected-hover: #45bced;\n --adp-cell-background-color-in-range: rgba(92, 196, 239, 0.1);\n --adp-cell-background-color-in-range-hover: rgba(92, 196, 239, 0.2);\n --adp-cell-border-color-in-range: var(--adp-cell-background-color-selected);\n --adp-btn-height: 32px;\n --adp-btn-color: var(--adp-accent-color);\n --adp-btn-color-hover: var(--adp-color);\n --adp-btn-border-radius: var(--adp-border-radius);\n --adp-btn-background-color-hover: var(--adp-background-color-hover);\n --adp-btn-background-color-active: var(--adp-background-color-active);\n --adp-time-track-height: 1px;\n --adp-time-track-color: #dedede;\n --adp-time-track-color-hover: #b1b1b1;\n --adp-time-thumb-size: 12px;\n --adp-time-padding-inner: 10px;\n --adp-time-day-period-color: var(--adp-color-secondary);\n --adp-mobile-font-size: 16px;\n --adp-mobile-nav-height: 40px;\n --adp-mobile-width: 320px;\n --adp-mobile-day-cell-height: 38px;\n --adp-mobile-month-cell-height: 48px;\n --adp-mobile-year-cell-height: 64px;\n}\n.air-datepicker-overlay {\n --adp-overlay-background-color: rgba(0, 0, 0, 0.3);\n --adp-overlay-transition-duration: 0.3s;\n --adp-overlay-transition-ease: ease-out;\n --adp-overlay-z-index: 99;\n}\n.air-datepicker {\n background: var(--adp-background-color);\n border: 1px solid var(--adp-border-color);\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);\n border-radius: var(--adp-border-radius);\n box-sizing: content-box;\n display: grid;\n grid-template-columns: 1fr;\n grid-template-rows: repeat(4, max-content);\n grid-template-areas: var(--adp-grid-areas);\n font-family: var(--adp-font-family), sans-serif;\n font-size: var(--adp-font-size);\n color: var(--adp-color);\n width: var(--adp-width);\n position: absolute;\n transition:\n opacity var(--adp-transition-duration) var(--adp-transition-ease),\n transform var(--adp-transition-duration) var(--adp-transition-ease);\n z-index: var(--adp-z-index);\n}\n.air-datepicker:not(.-custom-position-) {\n opacity: 0;\n}\n.air-datepicker.-from-top- {\n transform: translateY(calc(var(--adp-transition-offset) * -1));\n}\n.air-datepicker.-from-right- {\n transform: translateX(var(--adp-transition-offset));\n}\n.air-datepicker.-from-bottom- {\n transform: translateY(var(--adp-transition-offset));\n}\n.air-datepicker.-from-left- {\n transform: translateX(calc(var(--adp-transition-offset) * -1));\n}\n.air-datepicker.-active-:not(.-custom-position-) {\n transform: translate(0, 0);\n opacity: 1;\n}\n.air-datepicker.-active-.-custom-position- {\n transition: none;\n}\n.air-datepicker.-inline- {\n border-color: var(--adp-border-color-inline);\n box-shadow: none;\n position: static;\n left: auto;\n right: auto;\n opacity: 1;\n transform: none;\n}\n.air-datepicker.-inline- .air-datepicker--pointer {\n display: none;\n}\n.air-datepicker.-is-mobile- {\n --adp-font-size: var(--adp-mobile-font-size);\n --adp-day-cell-height: var(--adp-mobile-day-cell-height);\n --adp-month-cell-height: var(--adp-mobile-month-cell-height);\n --adp-year-cell-height: var(--adp-mobile-year-cell-height);\n --adp-nav-height: var(--adp-mobile-nav-height);\n --adp-nav-action-size: var(--adp-mobile-nav-height);\n position: fixed;\n width: var(--adp-mobile-width);\n border: none;\n}\n.air-datepicker.-is-mobile- * {\n -webkit-tap-highlight-color: rgba(0, 0, 0, 0);\n}\n.air-datepicker.-is-mobile- .air-datepicker--pointer {\n display: none;\n}\n.air-datepicker.-is-mobile-:not(.-custom-position-) {\n transform: translate(-50%, calc(-50% + var(--adp-transition-offset)));\n}\n.air-datepicker.-is-mobile-.-active-:not(.-custom-position-) {\n transform: translate(-50%, -50%);\n}\n.air-datepicker.-custom-position- {\n transition: none;\n}\n.air-datepicker-global-container {\n position: absolute;\n left: 0;\n top: 0;\n}\n.air-datepicker--pointer {\n --pointer-half-size: calc(var(--adp-pointer-size) / 2);\n position: absolute;\n width: var(--adp-pointer-size);\n height: var(--adp-pointer-size);\n z-index: -1;\n}\n.air-datepicker--pointer:after {\n content: '';\n position: absolute;\n background: #fff;\n border-top: 1px solid var(--adp-border-color-inline);\n border-right: 1px solid var(--adp-border-color-inline);\n border-top-right-radius: var(--adp-poiner-border-radius);\n width: var(--adp-pointer-size);\n height: var(--adp-pointer-size);\n box-sizing: border-box;\n}\n.-top-left- .air-datepicker--pointer,\n.-top-center- .air-datepicker--pointer,\n.-top-right- .air-datepicker--pointer,\n[data-popper-placement^='top'] .air-datepicker--pointer {\n top: calc(100% - var(--pointer-half-size) + 1px);\n}\n.-top-left- .air-datepicker--pointer:after,\n.-top-center- .air-datepicker--pointer:after,\n.-top-right- .air-datepicker--pointer:after,\n[data-popper-placement^='top'] .air-datepicker--pointer:after {\n transform: rotate(135deg);\n}\n.-right-top- .air-datepicker--pointer,\n.-right-center- .air-datepicker--pointer,\n.-right-bottom- .air-datepicker--pointer,\n[data-popper-placement^='right'] .air-datepicker--pointer {\n right: calc(100% - var(--pointer-half-size) + 1px);\n}\n.-right-top- .air-datepicker--pointer:after,\n.-right-center- .air-datepicker--pointer:after,\n.-right-bottom- .air-datepicker--pointer:after,\n[data-popper-placement^='right'] .air-datepicker--pointer:after {\n transform: rotate(225deg);\n}\n.-bottom-left- .air-datepicker--pointer,\n.-bottom-center- .air-datepicker--pointer,\n.-bottom-right- .air-datepicker--pointer,\n[data-popper-placement^='bottom'] .air-datepicker--pointer {\n bottom: calc(100% - var(--pointer-half-size) + 1px);\n}\n.-bottom-left- .air-datepicker--pointer:after,\n.-bottom-center- .air-datepicker--pointer:after,\n.-bottom-right- .air-datepicker--pointer:after,\n[data-popper-placement^='bottom'] .air-datepicker--pointer:after {\n transform: rotate(315deg);\n}\n.-left-top- .air-datepicker--pointer,\n.-left-center- .air-datepicker--pointer,\n.-left-bottom- .air-datepicker--pointer,\n[data-popper-placement^='left'] .air-datepicker--pointer {\n left: calc(100% - var(--pointer-half-size) + 1px);\n}\n.-left-top- .air-datepicker--pointer:after,\n.-left-center- .air-datepicker--pointer:after,\n.-left-bottom- .air-datepicker--pointer:after,\n[data-popper-placement^='left'] .air-datepicker--pointer:after {\n transform: rotate(45deg);\n}\n.-top-left- .air-datepicker--pointer,\n.-bottom-left- .air-datepicker--pointer {\n left: var(--adp-pointer-offset);\n}\n.-top-right- .air-datepicker--pointer,\n.-bottom-right- .air-datepicker--pointer {\n right: var(--adp-pointer-offset);\n}\n.-top-center- .air-datepicker--pointer,\n.-bottom-center- .air-datepicker--pointer {\n left: calc(50% - var(--adp-pointer-size) / 2);\n}\n.-left-top- .air-datepicker--pointer,\n.-right-top- .air-datepicker--pointer {\n top: var(--adp-pointer-offset);\n}\n.-left-bottom- .air-datepicker--pointer,\n.-right-bottom- .air-datepicker--pointer {\n bottom: var(--adp-pointer-offset);\n}\n.-left-center- .air-datepicker--pointer,\n.-right-center- .air-datepicker--pointer {\n top: calc(50% - var(--adp-pointer-size) / 2);\n}\n.air-datepicker--navigation {\n grid-area: nav;\n}\n.air-datepicker--content {\n box-sizing: content-box;\n padding: var(--adp-padding);\n grid-area: body;\n}\n.-only-timepicker- .air-datepicker--content {\n display: none;\n}\n.air-datepicker--time {\n grid-area: timepicker;\n}\n.air-datepicker--buttons {\n grid-area: buttons;\n}\n.air-datepicker--buttons,\n.air-datepicker--time {\n padding: var(--adp-padding);\n border-top: 1px solid var(--adp-border-color-inner);\n}\n.air-datepicker-overlay {\n position: fixed;\n background: var(--adp-overlay-background-color);\n left: 0;\n top: 0;\n width: 0;\n height: 0;\n opacity: 0;\n transition:\n opacity var(--adp-overlay-transition-duration) var(--adp-overlay-transition-ease),\n left 0s,\n height 0s,\n width 0s;\n transition-delay: 0s, var(--adp-overlay-transition-duration), var(--adp-overlay-transition-duration), var(--adp-overlay-transition-duration);\n z-index: var(--adp-overlay-z-index);\n}\n.air-datepicker-overlay.-active- {\n opacity: 1;\n width: 100%;\n height: 100%;\n transition:\n opacity var(--adp-overlay-transition-duration) var(--adp-overlay-transition-ease),\n height 0s,\n width 0s;\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import {format} from 'date-fns';\nimport {getRGBA} from '@verdocs/js-sdk';\nimport AirDatepicker from 'air-datepicker';\nimport localeEn from 'air-datepicker/locale/en';\nimport type {ITemplateField} from '@verdocs/js-sdk';\nimport {Component, Element, Event, EventEmitter, h, Host, Method, Prop, Fragment, State} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {FORMAT_DATE} from '../../../utils/Types';\nimport {Store} from '../../../utils/Datastore';\n\n/**\n * Displays a date field. When tapped or clicked, the input element will display a date picker component.\n */\n@Component({\n tag: 'verdocs-field-date',\n styleUrl: 'verdocs-field-date.scss',\n shadow: false,\n})\nexport class VerdocsFieldDate {\n @Element()\n private hostEl: HTMLInputElement;\n\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop() field?: ITemplateField;\n\n /**\n * Event fired on every character entered into / deleted from the field.\n */\n @Event({composed: true}) settingsPress: EventEmitter;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() containerId = `verdocs-date-picker-${Math.random().toString(36).substring(2, 11)}`;\n\n @State() showingProperties?: boolean = false;\n\n @Method()\n async focusField() {\n // Our input field is fake, so we fake the flash too\n this.focused = true;\n this.picker?.show();\n setTimeout(() => {\n this.focused = false;\n }, 500);\n }\n\n picker: AirDatepicker<HTMLElement> | null = null;\n\n componentDidLoad() {\n this.picker = new AirDatepicker<HTMLElement>(`#${this.containerId}`, {\n locale: localeEn,\n isMobile: true,\n autoClose: true,\n onShow: () => (this.focused = true),\n onHide: () => (this.focused = false),\n onSelect: ({date, formattedDate}) => {\n const event = new CustomEvent('fieldChange', {detail: {date, formattedDate}});\n this.hostEl.dispatchEvent(event);\n },\n });\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n }\n\n @State() focused?: boolean = false;\n\n // NOTE: We don't use a \"date\" field here because browsers vary widely in their formatting of it.\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n const {required = false, placeholder = 'Date...', value = '', label = ''} = field || {};\n const backgroundColor = getRGBA(index);\n\n const formattedValue = value ? format(new Date(value), FORMAT_DATE) : '';\n\n if (this.done) {\n return <Host class={{done}}>{formattedValue}</Host>;\n }\n\n return (\n <Host class={{required, disabled, done, focused}} style={{backgroundColor}}>\n {label && <label>{label}</label>}\n\n <input\n name={fieldname}\n class=\"input-el\"\n type=\"text\"\n value={formattedValue}\n id={this.containerId}\n disabled={disabled}\n placeholder={placeholder}\n onFocus={() => (this.focused = true)}\n onBlur={() => (this.focused = false)}\n />\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${field.name}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => (this.showingProperties = false)}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={'Date fields allow the user to select a date.'}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-field-dropdown {\n font-family: $verdocs-primary-font;\n width: 85px;\n height: 20px;\n display: block;\n font-size: 11px;\n position: relative;\n scroll-margin: 20px 0;\n background-color: transparent;\n transform-origin: bottom left;\n\n label {\n top: -14px;\n left: 0;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n select {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n position: absolute;\n background: linear-gradient(55deg, transparent 50%, #333 50%), linear-gradient(125deg, #333 50%, transparent 50%), linear-gradient(to right, transparent, transparent);\n background-position:\n calc(100% - 7px) 6px,\n calc(100% - 3px) 6px,\n 100% 0;\n background-size:\n 5px 5px,\n 5px 5px,\n 2.5em 2.5em;\n background-repeat: no-repeat;\n appearance: none;\n\n box-sizing: border-box;\n color: rgba(0, 0, 0, 0.87);\n font-weight: 500;\n transform-origin: 0 0;\n height: 100%;\n width: 100%;\n font-size: 11px;\n border: 1px solid rgba(0, 0, 0, 0.2);\n padding: 0 5px;\n\n &:focus {\n outline: none;\n }\n\n &.hide {\n display: none;\n }\n }\n\n &.disabled select {\n opacity: 0.5;\n }\n\n &.required {\n select {\n border: 1px solid $verdocs-red-1;\n }\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n verdocs-button-panel {\n display: block;\n margin-left: -33px;\n margin-top: -1px;\n transform: scale(0.7);\n }\n\n .settings-icon {\n position: absolute;\n top: -2px;\n left: -20px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import {ITemplateField, getRGBA, IEnvelopeField} from '@verdocs/js-sdk';\nimport {Component, Event, EventEmitter, h, Host, Method, Prop, Fragment, State} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\n/**\n * Displays a dropdown field that allows the user to choose one of a list of options.\n */\n@Component({\n tag: 'verdocs-field-dropdown',\n styleUrl: 'verdocs-field-dropdown.scss',\n shadow: false,\n})\nexport class VerdocsFieldDropdown {\n selectEl: HTMLSelectElement;\n\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n /**\n * Event fired when the input field value changes. Note that this will only be fired on blur, tab-out, ENTER key press, etc.\n * It is generally the best event to subscribe to than `input` for most cases EXCEPT autocomplete fields that need to see every\n * keypress.\n */\n @Event({composed: true}) fieldChange: EventEmitter<string>;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() showingProperties?: boolean = false;\n @State() focused = false;\n\n @Method()\n async focusField() {\n // Our input field is fake, so we fake the flash too\n this.focused = true;\n setTimeout(() => {\n this.focused = false;\n }, 500);\n\n this.selectEl?.showPicker();\n }\n\n handleChange(e: any) {\n this.fieldChange.emit(e.target.value);\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n }\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n let {required = false, value = '', label = '', options} = field || {};\n const backgroundColor = getRGBA(index);\n\n if (done) {\n return <Host class={{done}}>{value}</Host>;\n }\n\n // TODO: Look for other places this mistaken assumption was made.\n // Defaults only apply in destructuring if undefined. null doesn't trigger it.\n options ||= [];\n\n return (\n <Host class={{required, disabled, done, focused}} style={{backgroundColor}}>\n {label && <label>{label}</label>}\n\n <select disabled={disabled} onChange={e => this.handleChange(e)} ref={el => (this.selectEl = el as HTMLSelectElement)}>\n <option value=\"\">Select...</option>\n {options.map(option => (\n <option value={option.id} selected={option.id === value}>\n {option.label}\n </option>\n ))}\n {!options.length && <option value=\"NA\">N/A</option>}\n </select>\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${fieldname}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => (this.showingProperties = false)}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={\"Dropdowns are used to capture a recipient's selection of one of several options.\"}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-field-initial {\n font-family: $verdocs-primary-font;\n width: 83px;\n height: 36px;\n display: block;\n font-size: 11px;\n position: relative;\n letter-spacing: 0.3px;\n scroll-margin: 20px 0;\n background-color: transparent;\n transform-origin: bottom left;\n border: 1px solid rgba(0, 0, 0, 0.2);\n\n label {\n top: -14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n &.done {\n border: none;\n opacity: 1;\n }\n\n img {\n display: block;\n max-width: 100%;\n max-height: 100%;\n }\n\n &.disabled img {\n opacity: 0.5;\n }\n\n button {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n box-sizing: border-box;\n border: none;\n color: rgba(0, 0, 0, 0.87);\n font-weight: 500;\n transform-origin: 0 0;\n height: 100%;\n width: 100%;\n background: none;\n font-size: 11px;\n\n &.hide {\n display: none;\n }\n }\n\n &.required {\n border: 1px solid $verdocs-red-1;\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n verdocs-button-panel {\n top: -3px;\n left: -2px;\n opacity: 0.5;\n z-index: 1000;\n cursor: pointer;\n position: absolute;\n transform: scale(0.6);\n\n &[data-active],\n &:hover {\n opacity: 1;\n }\n\n .icon {\n svg {\n fill: #333333;\n }\n\n &:hover {\n svg {\n fill: #000000;\n }\n }\n }\n }\n\n .settings-icon {\n position: absolute;\n top: -3px;\n left: -20px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import {ITemplateField, getRGBA, IEnvelopeField} from '@verdocs/js-sdk';\nimport {Component, Event, EventEmitter, h, Host, Method, Prop, Fragment, State} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\n/**\n * Displays an initial field. If an initial already exists, it will be displayed and the field\n * will be disabled. Otherwise, a placeholder button will be shown. Clicking the button will\n * show a dialog to adopt an initial.\n *\n * NOTE: When initial fields are completed they will be filled with an initial \"stamp\".\n * This requires operation against a live, valid envelope. If you are testing this component\n * in Storybook, it will not be visible here.\n */\n@Component({\n tag: 'verdocs-field-initial',\n styleUrl: 'verdocs-field-initial.scss',\n shadow: false,\n})\nexport class VerdocsFieldInitial {\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * The document or template field to display.\n */\n @Prop({reflect: true}) initials: string = '';\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n /**\n * Event emitted when an initial block is adopted by the user. The event detail will contain the base64 string of the initial image.\n */\n @Event({composed: true}) adopt: EventEmitter<string>;\n\n /**\n * Event fired when the step is cancelled. This is called exit to avoid conflicts with the JS-reserved \"cancel\" event name.\n */\n @Event({composed: true}) exit: EventEmitter;\n\n /**\n * Event fired when the input field value changes. Note that this will only be fired on blur, tab-out, ENTER key press, etc.\n * It is generally the best event to subscribe to than `input` for most cases EXCEPT autocomplete fields that need to see every\n * keypress.\n */\n @Event({composed: true}) fieldChange: EventEmitter<string>;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired on every character entered into / deleted from the field.\n */\n @Event({composed: true}) settingsPress: EventEmitter;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() showingProperties?: boolean = false;\n @State() focused?: boolean = false;\n\n @Method() async focusField() {\n this.handleShow();\n }\n\n @State()\n tempInitials: string = '';\n\n private dialog?: any;\n\n hideDialog() {\n this.dialog?.remove();\n this.dialog = null;\n this.focused = false;\n }\n\n handleAdopt(e: any) {\n console.log('[INITIAL] Adopted initials');\n this.tempInitials = e.detail;\n this.fieldChange?.emit(this.tempInitials);\n this.hideDialog();\n }\n\n handleShow() {\n this.dialog = document.createElement('verdocs-initial-dialog');\n this.dialog.setAttribute('initials', this.initials);\n // this.dialog.setAttribute('roleindex', this.roleindex);\n this.dialog.addEventListener('exit', () => this.hideDialog());\n this.dialog.addEventListener('next', (e: any) => this.handleAdopt(e));\n document.body.append(this.dialog);\n this.focused = true;\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n }\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n const {required = false, value = '', label = '', settings = {}} = field || {};\n const backgroundColor = getRGBA(index);\n const {base64} = settings;\n\n if (done) {\n return <Host class={{done}}>{value && <img src={value} alt=\"Initial\" />}</Host>;\n }\n\n return (\n <Host class={{required, disabled, done, focused}} style={{backgroundColor}}>\n {label && <label>{label}</label>}\n\n {base64 ? <img src={base64} alt=\"Initial\" /> : <button onClick={() => !disabled && this.handleShow()}>Initial</button>}\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${fieldname}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => (this.showingProperties = false)}\n onDelete={() => {\n this.deleted?.emit({fieldName: field.name});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={\"initial fields capture the recipient's initials on a clause or page.\"}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\n// See https://www.sliderrevolution.com/resources/styling-radio-buttons/\nverdocs-field-radio {\n font-family: $verdocs-primary-font;\n width: 14px;\n height: 14px;\n display: block;\n font-size: 11px;\n position: relative;\n scroll-margin: 20px 0;\n background-color: transparent;\n transform-origin: bottom left;\n border-radius: 100%;\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n svg {\n margin-top: 4px;\n }\n\n &.disabled.done {\n opacity: 1;\n }\n\n // To avoid conflicting with the use of a label for the checkbox itself\n div.label {\n top: -14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n div.group {\n top: 14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #bb0589;\n border-bottom-left-radius: 2px;\n border-bottom-right-radius: 2px;\n }\n\n input {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n }\n\n &.disabled input {\n opacity: 0.5;\n }\n\n &.done input[type='radio'] {\n margin: 0;\n padding: 0;\n width: 10px;\n height: 10px;\n }\n\n &:not(.done) input[type='radio'] {\n position: absolute;\n opacity: 0;\n\n + label {\n &:before {\n content: '';\n //background: $verdocs-grey-3;\n border-radius: 100%;\n border: 1px solid rgba(0, 0, 0, 0.6);\n display: inline-block;\n width: 12px;\n height: 12px;\n position: absolute;\n left: 0;\n top: 0;\n cursor: pointer;\n text-align: center;\n transition: all 250ms ease;\n }\n }\n\n &:checked {\n + label {\n &:before {\n background-color: $verdocs-green;\n box-shadow: inset 0 0 0 2px $verdocs-grey-3;\n }\n }\n }\n\n &:focus {\n + label {\n &:before {\n outline: none;\n border-color: $verdocs-green;\n }\n }\n }\n\n &:disabled {\n + label {\n &:before {\n box-shadow: inset 0 0 0 4px $verdocs-grey-3;\n border-color: darken($verdocs-grey-3, 25%);\n background: darken($verdocs-grey-3, 25%);\n }\n }\n }\n\n + label {\n &:empty {\n &:before {\n margin-right: 0;\n }\n }\n }\n }\n\n &.required {\n border: 1px solid $verdocs-red-1;\n }\n\n &.hide {\n display: none;\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n verdocs-button-panel {\n margin-left: -20px;\n margin-top: -7px;\n transform: scale(0.7);\n }\n\n .settings-icon {\n position: absolute;\n top: -6px;\n left: -20px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import {ITemplateField, getRGBA, IEnvelopeField} from '@verdocs/js-sdk';\nimport {Component, Event, EventEmitter, h, Host, Method, Prop, Fragment, State} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\nconst RadioIconUnselected = `<svg focusable=\"false\" aria-hidden=\"true\" viewBox=\"0 0 24 24\"><path d=\"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z\"></path></svg>`;\n\nconst RadioIconSelected = `<svg focusable=\"false\" aria-hidden=\"true\" viewBox=\"0 0 24 24\"><path d=\"M12 7c-2.76 0-5 2.24-5 5s2.24 5 5 5 5-2.24 5-5-2.24-5-5-5zm0-5C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z\"></path></svg>`;\n\n/**\n * Displays a radio button.\n */\n@Component({\n tag: 'verdocs-field-radio',\n styleUrl: 'verdocs-field-radio.scss',\n shadow: false,\n})\nexport class VerdocsFieldRadio {\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, overrides the field's settings object. Primarily used in Storybook mode.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, overrides the field's required object. Primarily used in Storybook mode.\n */\n @Prop({reflect: true}) required?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n @State() showingProperties?: boolean = false;\n @State() focused = false;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @Method()\n async focusField() {\n // Our input field is fake, so we fake the flash too\n this.focused = true;\n setTimeout(() => {\n this.focused = false;\n }, 500);\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n }\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n const {name, required = false, label = '', group = '', value = false} = field || {};\n const backgroundColor = getRGBA(index);\n\n const selected = value === 'true';\n\n if (done) {\n return (\n <Host class={{done}} style={{maxWidth: '10px'}}>\n <span innerHTML={selected ? RadioIconSelected : RadioIconUnselected} />\n </Host>\n );\n }\n\n return (\n <Host class={{required: this.required || required, disabled, done, focused}} style={{backgroundColor}}>\n {label && <div class=\"label\">{label}</div>}\n {editable && group && <div class=\"group\">{group}</div>}\n\n <input id={fieldname} type=\"radio\" name={group || fieldname} value={name} checked={!!selected} disabled={disabled} required={required} />\n <label htmlFor={fieldname} />\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${fieldname}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => (this.showingProperties = false)}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={\"Radio buttons capture the recipient's selection of just one of several related (exclusive) options.\"}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-field-signature {\n font-family: $verdocs-primary-font;\n width: 83px;\n height: 36px;\n display: block;\n font-size: 11px;\n position: relative;\n scroll-margin: 20px 0;\n letter-spacing: 0.3px;\n background-color: transparent;\n transform-origin: bottom left;\n border: 1px solid rgba(0, 0, 0, 0.2);\n\n label {\n top: -14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n &.done {\n border: none;\n opacity: 1;\n }\n\n img {\n display: block;\n max-width: 100%;\n max-height: 100%;\n }\n\n &.disabled img {\n opacity: 0.5;\n }\n\n button {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n box-sizing: border-box;\n border: none;\n color: rgba(0, 0, 0, 0.87);\n font-weight: 500;\n transform-origin: 0 0;\n height: 100%;\n width: 100%;\n background: none;\n font-size: 11px;\n\n &.hide {\n display: none;\n }\n }\n\n &.required {\n border: 1px solid rgb(204, 0, 0);\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n verdocs-button-panel {\n top: -3px;\n left: -2px;\n opacity: 0.5;\n z-index: 1000;\n cursor: pointer;\n position: absolute;\n transform: scale(0.6);\n\n &[data-active],\n &:hover {\n opacity: 1;\n }\n\n .icon {\n svg {\n fill: #333333;\n }\n\n &:hover {\n svg {\n fill: #000000;\n }\n }\n }\n }\n\n .settings-icon {\n position: absolute;\n top: -3px;\n left: -20px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import {ITemplateField, getRGBA, IEnvelopeField} from '@verdocs/js-sdk';\nimport {Component, h, Host, Prop, Event, EventEmitter, Method, Fragment, State} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\n/**\n * Displays a signature field. If a signature already exists, it will be displayed and the field\n * will be disabled. Otherwise, a placeholder button will be shown. Clicking the button will\n * show a dialog to adopt a signature.\n *\n * NOTE: When signature fields are completed they will be filled with a signature \"stamp\".\n * This requires operation against a live, valid envelope. If you are testing this component\n * in Storybook, it will not be visible here.\n */\n@Component({\n tag: 'verdocs-field-signature',\n styleUrl: 'verdocs-field-signature.scss',\n shadow: false,\n})\nexport class VerdocsFieldSignature {\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, the signature creation dialog will be initialized with this text.\n */\n @Prop({reflect: true}) name?: string = '';\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n /**\n * Event emitted when the field has changed.\n */\n @Event({composed: true}) fieldChange: EventEmitter<string>;\n\n /**\n * Event fired on every character entered into / deleted from the field.\n */\n @Event({composed: true}) settingsPress: EventEmitter;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() showingProperties?: boolean = false;\n @State() focused?: boolean = false;\n\n @Method() async focusField() {\n this.handleShow();\n }\n\n @State()\n tempSignature: string = '';\n\n private dialog?: any;\n\n hideDialog() {\n this.dialog?.remove();\n this.dialog = null;\n this.focused = false;\n }\n\n handleAdopt(e: any) {\n console.log('[SIGNATURE] Adopted signature');\n this.tempSignature = e.detail;\n this.fieldChange?.emit(this.tempSignature);\n this.hideDialog();\n }\n\n handleShow() {\n this.dialog = document.createElement('verdocs-signature-dialog');\n this.dialog.setAttribute('name', this.name);\n // this.dialog.setAttribute('roleindex', this.roleindex);\n this.dialog.addEventListener('exit', () => this.hideDialog());\n this.dialog.addEventListener('next', (e: any) => this.handleAdopt(e));\n document.body.append(this.dialog);\n this.focused = true;\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n this.showingProperties = false;\n }\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n const {required = false, value = '', label = '', settings = {}} = field || {};\n const {base64} = settings;\n const backgroundColor = getRGBA(index);\n\n if (done) {\n return <Host class={{done}}>{value && <img src={base64} alt=\"\" />}</Host>;\n }\n\n return (\n <Host class={{required, disabled, done, focused}} style={{backgroundColor}}>\n {label && <label>{label}</label>}\n\n {base64 ? <img src={base64} alt=\"\" /> : <button onClick={() => !disabled && this.handleShow()}>Signature</button>}\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${fieldname}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => this.hideSettingsPanel()}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={\"Signature fields capture a recipient's signature on a document.\"}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-field-textarea {\n width: 150px;\n height: 15px;\n display: block;\n font-size: 11px;\n position: relative;\n scroll-margin: 20px 0;\n box-sizing: border-box;\n background-color: transparent;\n transform-origin: bottom left;\n font-family: $verdocs-primary-font;\n border: 1px solid rgba(0, 0, 0, 0.2);\n\n textarea {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n width: 100%;\n height: 100%;\n resize: none;\n border: none;\n outline: none;\n padding: 0 3px;\n font-size: 11px;\n background: none;\n font-weight: 500;\n transform-origin: 0 0;\n box-sizing: border-box;\n color: rgba(0, 0, 0, 0.87);\n\n &.hide {\n display: none;\n }\n }\n\n &.disabled textarea {\n opacity: 0.5;\n }\n\n label {\n top: -14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n &.required {\n border: 1px solid rgb(204, 0, 0);\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n verdocs-button-panel {\n top: -3px;\n left: -2px;\n opacity: 0.5;\n z-index: 1000;\n cursor: pointer;\n position: absolute;\n transform: scale(0.6);\n\n &[data-active],\n &:hover {\n opacity: 1;\n }\n\n .icon {\n svg {\n fill: #333333;\n }\n\n &:hover {\n svg {\n fill: #000000;\n }\n }\n }\n }\n\n .settings-icon {\n position: absolute;\n top: -3px;\n left: -20px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import interact from 'interactjs';\nimport {IEnvelopeField, VerdocsEndpoint} from '@verdocs/js-sdk';\nimport {ITemplateField, updateField, getRGBA} from '@verdocs/js-sdk';\nimport {Component, h, Host, Prop, Method, Event, EventEmitter, Element, Fragment, State} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\n/**\n * Display a multi-line text input field. Reminder: the \"position\" of the field is specified\n * as the BOTTOM-LEFT corner.\n */\n@Component({\n tag: 'verdocs-field-textarea',\n styleUrl: 'verdocs-field-textarea.scss',\n shadow: false,\n})\nexport class VerdocsFieldTextarea {\n @Element() el: HTMLElement;\n private inputEl: HTMLTextAreaElement;\n\n /**\n * The endpoint to use to communicate with Verdocs. If not set, the default endpoint will be used.\n * This component self-manages its resize (width) behavior when in edit-template mode, and uses\n * this endpoint to save changes.\n */\n @Prop() endpoint: VerdocsEndpoint = VerdocsEndpoint.getDefault();\n\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n @Method()\n async focusField() {\n this.inputEl.focus();\n }\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() showingProperties?: boolean = false;\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n }\n\n @State() focused?: boolean = false;\n\n componentDidRender() {\n interact.dynamicDrop(true);\n\n if (this.editable) {\n interact(this.el).resizable({\n edges: {top: true, bottom: true, left: true, right: true},\n listeners: {\n start: this.handleResizeStart.bind(this),\n move: this.handleResize.bind(this),\n end: this.handleResizeEnd.bind(this),\n },\n });\n }\n }\n\n handleResizeStart(e: any) {\n e.preventDefault();\n e.stopPropagation();\n }\n\n handleResize(e: any) {\n let {x = 0, y = 0, h = 0} = e.target.dataset;\n let {width, height} = e.rect;\n\n x = (parseFloat(x) || 0) + e.deltaRect.left;\n y = (parseFloat(y) || 0) + e.deltaRect.top;\n h = (parseFloat(h) || 0) + e.deltaRect.height;\n\n Object.assign(e.target.style, {\n width: `${width}px`,\n height: `${height}px`,\n transform: `translate(${x}px, ${y + h}px)`,\n });\n\n Object.assign(e.target.dataset, {x, y, h});\n }\n\n handleResizeEnd(e: any) {\n const {source, sourceid, fieldname} = this;\n const {field} = Store.getField(source, sourceid, fieldname, this.field);\n if (!field) {\n return;\n }\n\n const [translateX, translateY] = e.target.style.transform.split('(')[1].split(')')[0].split(',').map(parseFloat);\n\n const width = Math.round(parseFloat(e.target.style.width) / this.xscale);\n const height = Math.round(parseFloat(e.target.style.height) / this.yscale);\n const x = Math.round(field.x + translateX / this.xscale);\n const y = Math.round(field.y - translateY / this.yscale);\n\n updateField(this.endpoint, this.sourceid, this.fieldname, {x, y, width, height})\n .then(field => {\n this.settingsChanged?.emit({fieldName: this.fieldname, field});\n Object.assign(e.target.dataset, {x: 0, y: 0, h: 0});\n })\n .catch(e => console.log('Field update failed', e));\n }\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n const {required = false, placeholder = '', value = '', label = ''} = field || {};\n const backgroundColor = getRGBA(index);\n\n if (done) {\n return <Host class={{done}}>{value}</Host>;\n }\n\n return (\n <Host class={{required, disabled, done, focused}} style={{backgroundColor}}>\n {label && <label>{label}</label>}\n\n <textarea\n name={fieldname}\n disabled={disabled}\n required={required}\n placeholder={placeholder}\n ref={el => (this.inputEl = el)}\n onFocus={() => (this.focused = true)}\n onBlur={() => (this.focused = false)}\n >\n {value}\n </textarea>\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${fieldname}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => (this.showingProperties = false)}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={'Text areas may be used to create multi-line text fields.'}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-field-textbox {\n font-family: $verdocs-primary-font;\n box-sizing: border-box;\n width: 150px;\n height: 15px;\n display: block;\n font-size: 11px;\n position: relative;\n scroll-margin: 20px 0;\n letter-spacing: -0.2px;\n background-color: transparent;\n transform-origin: bottom left;\n border: 1px solid rgba(0, 0, 0, 0.2);\n\n .edge-top,\n .edge-right,\n .edge-left,\n .edge-bottom {\n position: absolute;\n z-index: 10;\n }\n\n .edge-top {\n top: -2px;\n left: 0;\n right: 0;\n height: 5px;\n }\n\n .edge-right {\n top: 0;\n bottom: 0;\n right: -2px;\n width: 5px;\n }\n\n .edge-left {\n top: 0;\n left: -2px;\n bottom: 0;\n width: 5px;\n }\n\n .edge-bottom {\n bottom: -2px;\n left: 0;\n right: 0;\n height: 5px;\n }\n\n input {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n width: 100%;\n height: 100%;\n border: none;\n outline: none;\n padding: 0 3px;\n font-size: 11px;\n background: none;\n font-weight: 500;\n position: absolute;\n transform-origin: 0 0;\n box-sizing: border-box;\n color: rgba(0, 0, 0, 0.87);\n\n &.hide {\n display: none;\n }\n }\n\n &.disabled input {\n opacity: 0.5;\n }\n\n textarea {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n width: 100%;\n height: 100%;\n resize: none;\n border: none;\n outline: none;\n padding: 0 3px;\n font-size: 11px;\n background: none;\n font-weight: 500;\n transform-origin: 0 0;\n box-sizing: border-box;\n color: rgba(0, 0, 0, 0.87);\n\n &.hide {\n display: none;\n }\n }\n\n &.disabled textarea {\n opacity: 0.5;\n }\n\n label {\n top: -14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n &.required {\n border: 1px solid rgb(204, 0, 0);\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n verdocs-button-panel {\n top: -3px;\n left: -2px;\n opacity: 0.5;\n z-index: 1000;\n cursor: pointer;\n position: absolute;\n transform: scale(0.6);\n\n &[data-active],\n &:hover {\n opacity: 1;\n }\n\n .icon {\n svg {\n fill: #333333;\n }\n\n &:hover {\n svg {\n fill: #000000;\n }\n }\n }\n }\n\n // @see https://community.logmein.com/t5/LastPass-Support-Discussions/placeholder-text-overrides-data-lpignore-quot-true-quot/td-p/295135\n // LastPass is ignoring the data-lpignore attribute in some cases\n [data-lastpass-icon-root] {\n display: none !important;\n }\n\n .settings-icon {\n position: absolute;\n top: -4px;\n left: -18px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import interact from 'interactjs';\nimport {getRGBA, IEnvelopeField, ITemplateField, updateField, VerdocsEndpoint} from '@verdocs/js-sdk';\nimport {Component, h, Host, Element, Prop, Method, Event, EventEmitter, Fragment, State} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\n/**\n * Display a simple 1-line text input field.\n */\n@Component({\n tag: 'verdocs-field-textbox',\n styleUrl: 'verdocs-field-textbox.scss',\n shadow: false,\n})\nexport class VerdocsFieldTextbox {\n @Element() el: HTMLElement;\n private inputEl: HTMLInputElement | HTMLTextAreaElement;\n\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) multiline?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() showingProperties?: boolean = false;\n @State() focused?: boolean = false;\n\n @Method()\n async focusField() {\n this.inputEl.focus();\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n this.showingProperties = false;\n }\n\n componentDidRender() {\n interact.dynamicDrop(true);\n\n if (this.editable) {\n interact(this.el).resizable({\n edges: {\n top: '.edge-top',\n left: '.edge-left',\n bottom: '.edge-bottom',\n right: '.edge-right',\n },\n modifiers: [\n interact.modifiers.restrictSize({\n min: {width: 30, height: 15},\n }),\n ],\n listeners: {\n start: this.handleResizeStart.bind(this),\n move: this.handleResize.bind(this),\n end: this.handleResizeEnd.bind(this),\n },\n });\n }\n }\n\n handleResizeStart(e: any) {\n e.preventDefault();\n e.stopPropagation();\n }\n\n handleResize(e: any) {\n let {width, height} = e.rect;\n\n const dX = e.deltaRect.left;\n const dY = e.deltaRect.bottom;\n const currentLeft = parseFloat(e.target.style.left);\n const currentBottom = parseFloat(e.target.style.bottom);\n\n width /= this.xscale;\n height /= this.yscale;\n\n Object.assign(e.target.style, {\n width: `${width}px`,\n height: `${height}px`,\n left: `${currentLeft + dX}px`,\n bottom: `${currentBottom - dY}px`,\n });\n }\n\n handleResizeEnd(e: any) {\n const {sourceid, fieldname} = this;\n\n const width = Math.round(parseFloat(e.target.style.width));\n let height = Math.round(parseFloat(e.target.style.height));\n\n if (height < 20) {\n height = 15;\n }\n const multiline = height > 15;\n\n updateField(VerdocsEndpoint.getDefault(), sourceid, fieldname, {width, height, multiline})\n .then(async updatedField => {\n const template = await Store.getTemplate(VerdocsEndpoint.getDefault(), this.sourceid);\n const newTemplate = JSON.parse(JSON.stringify(template));\n const fieldIndex = newTemplate.fields.findIndex(field => field.name === fieldname);\n if (fieldIndex > -1) {\n newTemplate.fields[fieldIndex] = updatedField;\n }\n Store.updateTemplate(this.sourceid, newTemplate);\n\n this.settingsChanged?.emit({fieldName: fieldname, field: updatedField});\n Object.assign(e.target.dataset, {x: 0, y: 0, h: 0});\n })\n .catch(e => console.log('Field update failed', e));\n }\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n let {required = false, placeholder = '', label = '', width = 150, default: value = '', multiline = false} = field || {};\n const backgroundColor = getRGBA(index);\n\n // TODO: Consolidate value/defaultValue handling between template and envelope fields.\n if ((field as any)?.value) {\n value = (field as any)?.value;\n }\n\n // TODO: This is an outdated technique from the old system. We should compute it.\n const maxlength = width / 5;\n\n if (done) {\n return <Host class={{done}}>{value}</Host>;\n }\n\n return (\n <Host class={{required, disabled, done, focused}} style={{backgroundColor}}>\n {editable && <div class=\"edge-top\" />}\n {editable && <div class=\"edge-right\" />}\n {editable && <div class=\"edge-left\" />}\n {editable && <div class=\"edge-bottom\" />}\n\n {label && <label>{label}</label>}\n\n {multiline ? (\n <textarea\n name={fieldname}\n disabled={disabled}\n required={required}\n placeholder={placeholder}\n ref={el => (this.inputEl = el)}\n onFocus={() => (this.focused = true)}\n onBlur={() => (this.focused = false)}\n >\n {value}\n </textarea>\n ) : (\n <input\n type=\"text\"\n name={fieldname}\n value={value}\n disabled={disabled}\n required={required}\n placeholder={placeholder}\n maxlength={maxlength}\n ref={el => (this.inputEl = el)}\n onFocus={() => (this.focused = true)}\n onBlur={() => (this.focused = false)}\n />\n )}\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${fieldname}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => this.hideSettingsPanel()}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={\n 'Text boxes may be used to capture simple text input. Participant-entered values will be stored for later retrieval via the \"name\" field.<br /><br />If marked required, the participant must complete the field before proceeding.'\n }\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-field-timestamp {\n width: 160px;\n height: 15px;\n display: block;\n font-size: 9px;\n position: relative;\n scroll-margin: 20px 0;\n background-color: transparent;\n transform-origin: bottom left;\n font-family: $verdocs-primary-font;\n\n &.done {\n opacity: 1;\n }\n\n input {\n position: absolute;\n\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n opacity: 0.5;\n width: 100%;\n height: 100%;\n font-size: 9px;\n background: none;\n font-weight: 500;\n transform-origin: 0 0;\n box-sizing: border-box;\n color: rgba(0, 0, 0, 0.87);\n border: 1px solid rgba(0, 0, 0, 0.2);\n\n &.hide {\n display: none;\n }\n }\n\n label {\n top: -14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n &.required {\n border: 1px solid rgb(204, 0, 0);\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n verdocs-button-panel {\n top: -3px;\n left: -2px;\n opacity: 0.5;\n z-index: 1000;\n cursor: pointer;\n position: absolute;\n transform: scale(0.6);\n\n &[data-active],\n &:hover {\n opacity: 1;\n }\n\n .icon {\n svg {\n fill: #333333;\n }\n\n &:hover {\n svg {\n fill: #000000;\n }\n }\n }\n }\n\n .settings-icon {\n position: absolute;\n top: -3px;\n left: -20px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n","import {format} from 'date-fns/format';\nimport {ITemplateField, getRGBA, IEnvelopeField} from '@verdocs/js-sdk';\nimport {Component, h, Host, Prop, Method, Event, EventEmitter, Fragment, State} from '@stencil/core';\nimport {FORMAT_TIMESTAMP} from '../../../utils/Types';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\n/**\n * Display a timestamp. Timestamps are not editable by signers. Instead, they are automatically\n * filled when the signer submits the document.\n */\n@Component({\n tag: 'verdocs-field-timestamp',\n styleUrl: 'verdocs-field-timestamp.scss',\n shadow: false,\n})\nexport class VerdocsFieldTimestamp {\n private el: HTMLInputElement;\n\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop() pagenumber?: number = 1;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() showingProperties?: boolean = false;\n\n @Method() async focusField() {\n this.el.focus();\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n this.showingProperties = false;\n }\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, xscale = 1, yscale = 1} = this;\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n const {required = false, placeholder = '', value = '', label = ''} = field || {};\n const backgroundColor = getRGBA(index);\n\n const formatted = format(new Date(value || new Date().toISOString()), FORMAT_TIMESTAMP);\n\n if (done) {\n return <Host class={{done}}>{formatted}</Host>;\n }\n\n return (\n <Host class={{required, disabled, done}} style={{backgroundColor}}>\n {label && <label>{label}</label>}\n <input type=\"text\" placeholder={placeholder} value={formatted} disabled={true} ref={el => (this.el = el)} />\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${fieldname}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => this.hideSettingsPanel()}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={'Time stamps are automatically set when the recipient signs the document.'}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-initial-dialog {\n font-family: $primary-font;\n box-sizing: border-box;\n position: fixed;\n z-index: 10000;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n display: flex;\n align-items: center;\n justify-content: center;\n background: #0000007f;\n\n .dialog {\n width: 100%;\n max-width: 340px;\n border-radius: 4px;\n overflow: hidden;\n box-shadow: 3px 3px 5px 1px rgba(40, 40, 40, 0.4);\n background: $dialog-bg;\n }\n\n .heading {\n display: flex;\n flex-direction: row;\n padding: 20px 20px 0 20px;\n line-height: 28px;\n font-size: 20px;\n font-weight: 500;\n }\n\n .content {\n font-size: 14px;\n padding: 20px;\n }\n\n .buttons {\n display: flex;\n margin: 20px 0 0 0;\n flex-direction: row;\n justify-content: flex-end;\n align-items: center;\n\n verdocs-button {\n margin-left: 16px;\n }\n }\n\n canvas {\n background: #fff;\n box-sizing: border-box;\n margin: 0 auto;\n width: 300px;\n // TODO: The original app had an aspect ratio of (80 / 305) * (signatureBodyWidth - 20)\n height: 79px;\n max-width: 100%;\n box-shadow: 0 0 6px 0 #0000001f;\n }\n\n .disclaimer {\n text-align: justify;\n padding: 8px 0;\n font-size: 11px;\n line-height: 14px;\n color: rgba(0, 0, 0, 0.54);\n }\n\n .as-shown {\n font-size: 11px;\n margin: 4px 0 20px 4px;\n color: rgba(0, 0, 0, 0.54);\n }\n\n .tabs {\n display: flex;\n flex-direction: row;\n\n .tab {\n padding: 8px 15px;\n cursor: pointer;\n\n &.active {\n border-bottom: 2px solid $light-border-color;\n }\n\n &:hover {\n color: $primary-color;\n }\n }\n }\n}\n","import {Component, Prop, Host, h, Event, EventEmitter, State} from '@stencil/core';\n\n/**\n * Display a dialog that allows the user to specify an initials image, either by using a signature-font-generated image\n * based on their full name, or by hand-drawing their initials with a mouse or tablet.\n */\n@Component({\n tag: 'verdocs-initial-dialog',\n styleUrl: 'verdocs-initial-dialog.scss',\n})\nexport class VerdocsInitialDialog {\n private canvasElement?: HTMLCanvasElement;\n\n /**\n * Initial signature text\n */\n @Prop() initials: string = '';\n\n /**\n * Event fired when the initials are adopted.\n */\n @Event({composed: true}) next: EventEmitter<string>;\n\n /**\n * Event fired when the step is cancelled. This is called exit to avoid conflicts with the JS-reserved \"cancel\" event name.\n */\n @Event({composed: true}) exit: EventEmitter;\n\n @State() fontLoaded = false;\n\n @State() enteredInitials: string = '';\n\n @State() mode: string = 'type';\n\n componentWillLoad() {\n this.enteredInitials = this.initials.toUpperCase();\n\n const ds = new FontFace('Dancing Script', 'url(https://fonts.gstatic.com/s/dancingscript/v19/If2cXTr6YS-zF4S-kcSWSVi_sxjsohD9F50Ruu7BMSo3Sup6hNX6plRP.woff)');\n ds.load().then(font => {\n document.fonts.add(font);\n this.fontLoaded = true;\n });\n }\n\n componentDidLoad() {\n this.redrawSignature();\n }\n\n componentDidUpdate() {\n this.redrawSignature();\n }\n\n redrawSignature() {\n console.log('redrawing sig');\n if (!this.canvasElement) {\n console.log('no canvas');\n return;\n }\n\n const canvasWidth = this.canvasElement.width;\n console.log('cw', canvasWidth);\n\n const context = this.canvasElement.getContext('2d');\n context.clearRect(0, 0, this.canvasElement.width, this.canvasElement.height);\n\n let fontSize = 100;\n do {\n fontSize -= 2;\n context.font = `${fontSize}px Dancing Script`;\n } while (context.measureText(this.enteredInitials).width > canvasWidth - 32); // 32px padding each side\n\n context.textAlign = 'center';\n context.textBaseline = 'middle';\n context.font = `${fontSize}px Dancing Script`;\n context.fillText(this.enteredInitials, this.canvasElement.width / 2, this.canvasElement.height / 2);\n }\n\n handleNameChange(e: any) {\n this.enteredInitials = e.target.value;\n }\n\n handleCancel(e: any) {\n e.stopPropagation();\n e.preventDefault();\n this.exit.emit();\n }\n\n handleAdopt(e: any) {\n e.stopPropagation();\n e.preventDefault();\n const data = this.canvasElement.toDataURL('image/png');\n this.next.emit(data);\n }\n\n /*\n selColor(hex: string) {\n this.color = hex;\n this.animateDraw();\n }\n\n stopDraw() {\n this.paint = false;\n this.adoptedAndSigned = !this.hasSignature();\n }\n\n draw(e) {\n this.paint = true;\n this.addPoints(e, false);\n this.animateDraw();\n }\n\n recordPoints(e) {\n if (this.paint) {\n this.addPoints(e, true);\n this.animateDraw();\n }\n }\n\n animateDraw() {\n this.canvas.clearRect(0, 0, this.canvas.canvas.offsetWidth, this.canvas.canvas.offsetHeight);\n\n this.canvas.strokeStyle = this.color || '#000000';\n this.canvas.lineJoin = 'round';\n this.canvas.lineWidth = 3;\n\n for (let i = 0; i < this.points.length; i++) {\n this.canvas.beginPath();\n if (this.points[i].drag && i) {\n this.canvas.moveTo(this.points[i - 1].x, this.points[i - 1].y);\n // this.canvas.arc(this.points[i - 1].x, this.points[i - 1].y, 2, 0, 2 * Math.PI, false);\n } else {\n this.canvas.moveTo(this.points[i].x - 1, this.points[i].y);\n // this.canvas.arc(this.points[i].x, this.points[i].y, 2, 0, 2 * Math.PI, false);\n }\n\n this.canvas.lineTo(this.points[i].x, this.points[i].y);\n this.canvas.closePath();\n this.canvas.stroke();\n }\n }\n\n drawCurve(color: string, curve: number) {\n this.canvas.beginPath();\n }\n\n\n\n addPoints(e, drag: boolean) {\n if (window) {\n let x;\n let y;\n e.preventDefault();\n if (e.touches && e.touches.length > 0) {\n x = e.touches[0].clientX;\n } else {\n x = e.clientX;\n }\n\n if (e.touches && e.touches.length > 0) {\n y = e.touches[0].clientY;\n } else {\n y = e.clientY;\n }\n const rect = this.signatureCanvas.nativeElement.getBoundingClientRect();\n this.points.push({\n x: x - rect.left,\n y: y - rect.top,\n drag: drag\n });\n }\n }\n\n clearPad() {\n this.canvas.clearRect(0, 0, this.canvas.canvas.offsetWidth, this.canvas.canvas.offsetHeight);\n this.points = [];\n this.adoptedAndSigned = !this.hasSignature();\n }\n\n async adoptAndSign() {\n try {\n this.adoptedAndSigned = true;\n await this.updateFullName();\n await this.captureSignatureFromCanvas();\n const message = this.signatureMode === 'Signature' ? 'Saving Signature' : 'Saving Initial';\n this.snackbarService.open(message, 'OK', this.snackbarService.initConfig(null, 'bottom'));\n this.handleMode();\n } catch (err) {\n this.snackbarService.open('Failed to apply signature', 'OK', this.snackbarService.initConfig(null, 'bottom'));\n }\n }\n\n handleMode() {\n let currentField;\n switch (this.mode) {\n case 'signerview':\n if (this.signatureMode === 'Signature') {\n this.signatureService.postSignatureBlob().then(result => {\n if (result && result.id && result.url) {\n currentField = this.signatureService.currField;\n this.signatureService.updateSigned(currentField.fName, true);\n this.signatureService.toggleSig(false);\n this.signatureService.setSignatureId(result.id);\n this.signatureService.putSignatureField(this.envelopeId, this.fieldName, result.id).then(res => {\n this.eventTracker.createEvent({\n category: 'verdoc',\n action: 'verdoc signed',\n label: `verdoc id: ${this.envelopeId}`\n })\n if (res && res.settings) {\n this.signatureService.setSignatureData(res.settings.base64);\n this.signatureService.setSignatureId(res.settings.signature_id);\n }\n this.snackbarService.dismiss();\n this.dialog.close({ status: 'saved', temp_sig: res.settings.base64, sig_id: res.settings.signature_id });\n }).catch(err => {\n this.snackbarService.open('Failed to save signature. Please try again.', 'DISMISS', {\n duration: 3000\n });\n this.adoptedAndSigned = false;\n return err;\n });\n }\n });\n } else {\n this.signatureService.postInitialBlob().then(result => {\n if (result && result.id && result.url) {\n currentField = this.signatureService.currField;\n this.signatureService.updateInitialed(currentField.fName, true);\n this.signatureService.setInitialId(result.id);\n this.signatureService.toggleSig(false);\n this.signatureService.putInitialField(this.envelopeId, this.fieldName, result.id).then(res => {\n if (res && res.settings) {\n this.signatureService.setInitialData(res.settings.base64);\n this.signatureService.setInitialId(res.settings.initial_id);\n }\n this.snackbarService.dismiss();\n this.dialog.close({ status: 'saved', temp_int: res.settings.base64, int_id: res.settings.initial_id });\n }).catch(err => {\n this.snackbarService.open('Failed to save initial. Please try again.', 'DISMISS', {\n duration: 3000\n });\n this.adoptedAndSigned = false;\n return err;\n });\n }\n });\n }\n break;\n }\n }\n */\n\n render() {\n return (\n <Host onClick={e => this.handleCancel(e)}>\n <div class=\"dialog\">\n <div class=\"heading\">Create Your Initial</div>\n\n <div class=\"content\">\n <verdocs-text-input placeholder=\"Initials...\" label=\"Initials\" value={this.enteredInitials} onInput={e => this.handleNameChange(e)} />\n <div class=\"as-shown\">As shown on driver's license or govt. ID card.</div>\n\n {/*<div class=\"tabs\">*/}\n {/* <div class={{tab: true, active: this.mode === 'type'}} onClick={() => (this.mode = 'type')}>*/}\n {/* Type*/}\n {/* </div>*/}\n {/* <div class={{tab: true, active: this.mode === 'draw'}} onClick={() => (this.mode = 'draw')}>*/}\n {/* Draw*/}\n {/* </div>*/}\n {/*</div>*/}\n\n {this.fontLoaded ? <canvas ref={el => (this.canvasElement = el as HTMLCanvasElement)} /> : <div style={{display: 'none'}} />}\n\n <div class=\"disclaimer\">\n By clicking Adopt, I agree that the signature will be the electronic representation of my signature for all purposes when I (or my agent) use them on documents,\n including legally binding contracts &mdash; just the same as a pen-and-paper signature or initial.\n </div>\n\n <div class=\"buttons\">\n <verdocs-button label=\"CANCEL\" variant=\"outline\" onClick={e => this.handleCancel(e)} />\n <verdocs-button label=\"Adopt & Sign\" onClick={e => this.handleAdopt(e)} />\n </div>\n </div>\n </div>\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-signature-dialog {\n font-family: $primary-font;\n box-sizing: border-box;\n position: fixed;\n z-index: 10000;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n display: flex;\n align-items: center;\n justify-content: center;\n background: #0000007f;\n\n .dialog {\n width: 100%;\n max-width: 340px;\n border-radius: 4px;\n overflow: hidden;\n box-shadow: 3px 3px 5px 1px rgba(40, 40, 40, 0.4);\n background: $dialog-bg;\n }\n\n .heading {\n display: flex;\n flex-direction: row;\n padding: 20px 20px 0 20px;\n line-height: 28px;\n font-size: 20px;\n font-weight: 500;\n }\n\n .content {\n font-size: 14px;\n padding: 20px;\n }\n\n .buttons {\n display: flex;\n margin: 20px 0 0 0;\n flex-direction: row;\n justify-content: flex-end;\n align-items: center;\n\n verdocs-button {\n margin-left: 16px;\n }\n }\n\n canvas {\n background: $verdocs-grey-4;\n box-sizing: border-box;\n margin: 0 auto;\n width: 300px;\n // TODO: The original app had an aspect ratio of (80 / 305) * (signatureBodyWidth - 20)\n height: 79px;\n max-width: 100%;\n box-shadow: 0 0 6px 0 #0000001f;\n }\n\n .disclaimer {\n text-align: justify;\n padding: 8px 0;\n font-size: 11px;\n line-height: 14px;\n color: rgba(0, 0, 0, 0.54);\n }\n\n .as-shown {\n font-size: 11px;\n margin: 4px 0 20px 4px;\n color: rgba(0, 0, 0, 0.54);\n }\n\n .tabs {\n display: flex;\n flex-direction: row;\n\n .tab {\n padding: 8px 15px;\n cursor: pointer;\n\n &.active {\n border-bottom: 2px solid $light-border-color;\n }\n\n &:hover {\n color: $primary-color;\n }\n }\n }\n}\n","import {Component, Prop, h, Event, EventEmitter, State, Host} from '@stencil/core';\n\n/**\n * Display a dialog that allows the user to specify a signature image, either by using a signature-font-generated image\n * based on their full name, or by hand-drawing their signature with a mouse or tablet.\n */\n@Component({\n tag: 'verdocs-signature-dialog',\n styleUrl: 'verdocs-signature-dialog.scss',\n})\nexport class VerdocsSignatureDialog {\n private canvasElement?: HTMLCanvasElement;\n\n /**\n * Initial signature text\n */\n @Prop() name: string = '';\n\n /**\n * Fired when the user completes the dialog and clicks Adopt. The event detail will contain a base64-encoded string\n * representation of the signature adopted.\n */\n @Event({composed: true}) next: EventEmitter<string>;\n\n /**\n * Event fired when the step is cancelled. This is called exit to avoid conflicts with the JS-reserved \"cancel\" event name.\n */\n @Event({composed: true}) exit: EventEmitter;\n\n @State() fontLoaded = false;\n\n @State() enteredName: string = '';\n\n @State() mode: string = 'type';\n\n componentWillLoad() {\n this.enteredName = this.name;\n\n const ds = new FontFace('Dancing Script', 'url(https://fonts.gstatic.com/s/dancingscript/v19/If2cXTr6YS-zF4S-kcSWSVi_sxjsohD9F50Ruu7BMSo3Sup6hNX6plRP.woff)');\n ds.load().then(font => {\n document.fonts.add(font);\n this.fontLoaded = true;\n });\n }\n\n componentDidLoad() {\n this.redrawSignature();\n }\n\n componentDidUpdate() {\n this.redrawSignature();\n }\n\n redrawSignature() {\n if (!this.canvasElement) {\n return;\n }\n\n const canvasWidth = this.canvasElement.width;\n\n const context = this.canvasElement.getContext('2d');\n context.clearRect(0, 0, this.canvasElement.width, this.canvasElement.height);\n\n let fontSize = 100;\n do {\n fontSize -= 2;\n context.font = `${fontSize}px Dancing Script`;\n } while (context.measureText(this.enteredName).width > canvasWidth - 32); // 32px padding each side\n\n context.textAlign = 'center';\n context.textBaseline = 'middle';\n context.font = `${fontSize}px Dancing Script`;\n context.fillText(this.enteredName, this.canvasElement.width / 2, this.canvasElement.height / 2);\n }\n\n handleNameChange(e: any) {\n this.enteredName = e.target.value;\n }\n\n handleCancel(e: any) {\n e.stopPropagation();\n e.preventDefault();\n this.exit.emit();\n }\n\n handleAdopt(e: any) {\n e.stopPropagation();\n e.preventDefault();\n const data = this.canvasElement.toDataURL('image/png');\n this.next.emit(data);\n }\n\n /*\n selColor(hex: string) {\n this.color = hex;\n this.animateDraw();\n }\n\n stopDraw() {\n this.paint = false;\n this.adoptedAndSigned = !this.hasSignature();\n }\n\n draw(e) {\n this.paint = true;\n this.addPoints(e, false);\n this.animateDraw();\n }\n\n recordPoints(e) {\n if (this.paint) {\n this.addPoints(e, true);\n this.animateDraw();\n }\n }\n\n animateDraw() {\n this.canvas.clearRect(0, 0, this.canvas.canvas.offsetWidth, this.canvas.canvas.offsetHeight);\n\n this.canvas.strokeStyle = this.color || '#000000';\n this.canvas.lineJoin = 'round';\n this.canvas.lineWidth = 3;\n\n for (let i = 0; i < this.points.length; i++) {\n this.canvas.beginPath();\n if (this.points[i].drag && i) {\n this.canvas.moveTo(this.points[i - 1].x, this.points[i - 1].y);\n // this.canvas.arc(this.points[i - 1].x, this.points[i - 1].y, 2, 0, 2 * Math.PI, false);\n } else {\n this.canvas.moveTo(this.points[i].x - 1, this.points[i].y);\n // this.canvas.arc(this.points[i].x, this.points[i].y, 2, 0, 2 * Math.PI, false);\n }\n\n this.canvas.lineTo(this.points[i].x, this.points[i].y);\n this.canvas.closePath();\n this.canvas.stroke();\n }\n }\n\n drawCurve(color: string, curve: number) {\n this.canvas.beginPath();\n }\n\n\n\n addPoints(e, drag: boolean) {\n if (window) {\n let x;\n let y;\n e.preventDefault();\n if (e.touches && e.touches.length > 0) {\n x = e.touches[0].clientX;\n } else {\n x = e.clientX;\n }\n\n if (e.touches && e.touches.length > 0) {\n y = e.touches[0].clientY;\n } else {\n y = e.clientY;\n }\n const rect = this.signatureCanvas.nativeElement.getBoundingClientRect();\n this.points.push({\n x: x - rect.left,\n y: y - rect.top,\n drag: drag\n });\n }\n }\n\n clearPad() {\n this.canvas.clearRect(0, 0, this.canvas.canvas.offsetWidth, this.canvas.canvas.offsetHeight);\n this.points = [];\n this.adoptedAndSigned = !this.hasSignature();\n }\n\n async adoptAndSign() {\n try {\n this.adoptedAndSigned = true;\n await this.updateFullName();\n await this.captureSignatureFromCanvas();\n const message = this.signatureMode === 'Signature' ? 'Saving Signature' : 'Saving Initial';\n this.snackbarService.open(message, 'OK', this.snackbarService.initConfig(null, 'bottom'));\n this.handleMode();\n } catch (err) {\n this.snackbarService.open('Failed to apply signature', 'OK', this.snackbarService.initConfig(null, 'bottom'));\n }\n }\n\n handleMode() {\n let currentField;\n switch (this.mode) {\n case 'signerview':\n if (this.signatureMode === 'Signature') {\n this.signatureService.postSignatureBlob().then(result => {\n if (result && result.id && result.url) {\n currentField = this.signatureService.currField;\n this.signatureService.updateSigned(currentField.fName, true);\n this.signatureService.toggleSig(false);\n this.signatureService.setSignatureId(result.id);\n this.signatureService.putSignatureField(this.envelopeId, this.fieldName, result.id).then(res => {\n this.eventTracker.createEvent({\n category: 'verdoc',\n action: 'verdoc signed',\n label: `verdoc id: ${this.envelopeId}`\n })\n if (res && res.settings) {\n this.signatureService.setSignatureData(res.settings.base64);\n this.signatureService.setSignatureId(res.settings.signature_id);\n }\n this.snackbarService.dismiss();\n this.dialog.close({ status: 'saved', temp_sig: res.settings.base64, sig_id: res.settings.signature_id });\n }).catch(err => {\n this.snackbarService.open('Failed to save signature. Please try again.', 'DISMISS', {\n duration: 3000\n });\n this.adoptedAndSigned = false;\n return err;\n });\n }\n });\n } else {\n this.signatureService.postInitialBlob().then(result => {\n if (result && result.id && result.url) {\n currentField = this.signatureService.currField;\n this.signatureService.updateInitialed(currentField.fName, true);\n this.signatureService.setInitialId(result.id);\n this.signatureService.toggleSig(false);\n this.signatureService.putInitialField(this.envelopeId, this.fieldName, result.id).then(res => {\n if (res && res.settings) {\n this.signatureService.setInitialData(res.settings.base64);\n this.signatureService.setInitialId(res.settings.initial_id);\n }\n this.snackbarService.dismiss();\n this.dialog.close({ status: 'saved', temp_int: res.settings.base64, int_id: res.settings.initial_id });\n }).catch(err => {\n this.snackbarService.open('Failed to save initial. Please try again.', 'DISMISS', {\n duration: 3000\n });\n this.adoptedAndSigned = false;\n return err;\n });\n }\n });\n }\n break;\n }\n }\n */\n\n render() {\n return (\n <Host onClick={e => this.handleCancel(e)}>\n <div class=\"dialog\">\n <div class=\"heading\">Create Your Signature</div>\n\n <div class=\"content\">\n <verdocs-text-input placeholder=\"Full Name...\" label=\"Full Name\" value={this.enteredName} onInput={e => this.handleNameChange(e)} onClick={e => e.stopPropagation()} />\n <div class=\"as-shown\">As shown on driver's license or govt. ID card.</div>\n\n {/*<div class=\"tabs\">*/}\n {/* <div class={{tab: true, active: this.mode === 'type'}} onClick={() => (this.mode = 'type')}>*/}\n {/* Type*/}\n {/* </div>*/}\n {/*<div class={{tab: true, active: this.mode === 'draw'}} onClick={() => (this.mode = 'draw')}>*/}\n {/* Draw*/}\n {/*</div>*/}\n {/*</div>*/}\n\n {this.fontLoaded ? <canvas ref={el => (this.canvasElement = el as HTMLCanvasElement)} /> : <div style={{display: 'none'}} />}\n\n <div class=\"disclaimer\">\n By clicking Adopt, I agree that the signature will be the electronic representation of my signature for all purposes when I (or my agent) use them on documents,\n including legally binding contracts &mdash; just the same as a pen-and-paper signature or initial.\n </div>\n\n <div class=\"buttons\">\n <verdocs-button label=\"CANCEL\" size=\"normal\" variant=\"outline\" onClick={e => this.handleCancel(e)} />\n <verdocs-button label=\"Adopt & Sign\" size=\"normal\" onClick={e => this.handleAdopt(e)} />\n </div>\n </div>\n </div>\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-upload-dialog {\n position: fixed;\n box-sizing: border-box;\n font-family: $primary-font;\n\n div {\n box-sizing: border-box;\n }\n\n .background-overlay {\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n display: flex;\n z-index: 10000;\n position: fixed;\n align-items: center;\n background: #0000007f;\n justify-content: center;\n }\n\n // Not simple .dialog to avoid conflicts with ok-dialog. Should review that more.\n .upload-dialog-content {\n width: 320px;\n display: flex;\n flex-direction: column;\n border-radius: 4px;\n overflow: hidden;\n background: $verdocs-grey-4;\n padding: 16px;\n box-shadow: 3px 3px 5px 1px rgba(40, 40, 40, 0.4);\n }\n\n .heading {\n display: flex;\n font-size: 20px;\n font-weight: 500;\n flex-direction: row;\n }\n\n .buttons {\n display: flex;\n align-items: center;\n flex-direction: row;\n justify-content: flex-end;\n\n verdocs-button {\n margin-left: 16px;\n }\n }\n\n .current-label {\n margin: 20px 0 5px 0;\n }\n\n .drop-target {\n opacity: 1;\n width: 100%;\n display: flex;\n margin: 20px 0;\n min-height: 260px;\n padding: 30px 15px;\n text-align: center;\n align-items: center;\n flex-direction: column;\n justify-content: center;\n background-color: #f5f5f5;\n color: $verdocs-grey-1;\n border: 2px dashed #979797;\n\n p {\n margin: 12px 0;\n font-weight: 500;\n\n &.subscript {\n margin: 20px;\n color: $verdocs-bg-4;\n font-size: 14px;\n }\n }\n\n &.dragging-over {\n border: 5px solid $verdocs-deep-blue;\n }\n\n > verdocs-button {\n margin: 12px 0;\n display: inline-block;\n }\n }\n\n .attachments {\n height: 56px;\n font-size: 0;\n margin: 20px 0;\n padding: 0 16px;\n line-height: 56px;\n white-space: normal;\n box-shadow:\n 0 1px 3px 0 rgb(0 0 0 / 20%),\n 0 2px 2px 0 rgb(0 0 0 / 12%),\n 0 0 2px 0 rgb(0 0 0 / 14%);\n\n .attachment {\n gap: 10px;\n display: flex;\n align-items: center;\n flex-direction: row;\n\n .icon {\n width: 18px;\n height: 18px;\n line-height: 18px;\n\n &.trash {\n cursor: pointer;\n }\n }\n\n .name {\n flex: 1;\n font-size: 14px;\n overflow: hidden;\n font-weight: 400;\n white-space: nowrap;\n text-overflow: ellipsis;\n }\n }\n }\n\n .error {\n margin: 20px 0;\n color: $verdocs-red-1;\n }\n}\n","import {Component, h, Event, EventEmitter, Fragment, Host, State, Prop} from '@stencil/core';\n\nconst TrashIcon = `<svg xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\"><path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M19 7l-.867 12.142A2 2 0 0116.138 21H7.862a2 2 0 01-1.995-1.858L5 7m5 4v6m4-6v6m1-10V4a1 1 0 00-1-1h-4a1 1 0 00-1 1v3M4 7h16\" /></svg>`;\n\nconst PaperclipIcon = `<svg xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\"><path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M15.172 7l-6.586 6.586a2 2 0 102.828 2.828l6.414-6.586a4 4 0 00-5.656-5.656l-6.415 6.585a6 6 0 108.486 8.486L20.5 13\" /></svg>`;\n\n/**\n * Display a file upload tool. Note that the file is not actually transmitted, so it may be used by\n * callers with a variety of workflows. Instead, data about the chosen file will be passed to the\n * caller via the onNext event handler. A delete event is also exposed to delete existing attachments.\n * To represent an existing attachment, set the existingFile property.\n */\n@Component({\n tag: 'verdocs-upload-dialog',\n styleUrl: 'verdocs-upload-dialog.scss',\n})\nexport class VerdocsUploadDialog {\n private fileInput?: HTMLInputElement;\n\n @Prop({mutable: true})\n maxSize: number = 20 * 1024 * 1024;\n\n @Prop({mutable: true})\n existingFile: any;\n\n /**\n * Event fired when the step is cancelled. This is called exit to avoid conflicts with the JS-reserved \"cancel\" event name.\n */\n @Event({composed: true}) exit: EventEmitter;\n\n /**\n * Event fired when the dialog is closed. The event data will contain the file selected.\n */\n @Event({composed: true}) next: EventEmitter<File[]>;\n\n /**\n * Event fired when an existing attachment is deleted. The parent component is\n * responsible for the actual removal.\n */\n @Event({composed: true}) remove: EventEmitter;\n\n @State() draggingOver = false;\n @State() confirmDelete = false;\n @State() selectedFiles = [] as File[];\n @State() errorMessage = '';\n\n handleCancel() {\n this.exit.emit();\n }\n\n // We need a separate event handler for clicking the background because it can receive events \"through\" other child components\n handleDismiss(e: any) {\n if (e.target.class === 'background-overlay') {\n e.preventDefault();\n this.handleCancel();\n }\n }\n\n handleDone() {\n this.next.emit(this.selectedFiles);\n }\n\n handleDragOver(e) {\n e.preventDefault();\n this.draggingOver = true;\n }\n\n handleDragLeave(e) {\n e.preventDefault();\n this.draggingOver = false;\n }\n\n async handleDrop(e) {\n e.preventDefault();\n this.draggingOver = false;\n this.handleSetSelected(Array.from(e.dataTransfer.files));\n }\n\n handleRemoveAttachment(index: number) {\n const newFiles = [...this.selectedFiles];\n newFiles.splice(index, 1);\n this.handleSetSelected(newFiles);\n }\n\n handleSetSelected(files: any[]) {\n this.selectedFiles = files;\n this.errorMessage = '';\n\n const totalSize = this.selectedFiles.reduce((acc, file) => acc + file.size, 0);\n if (totalSize > this.maxSize) {\n this.errorMessage = 'Total file size must not exceed 20MB.';\n }\n }\n\n handleDeleteAttachment(e: any) {\n // Stop the parent from seeing \"next\" and thinking an upload was done.\n // TODO: Rethink having so many commonalities in nested dialogs (next/exit).\n e.preventDefault();\n e.stopPropagation();\n\n this.remove?.emit();\n this.existingFile = null;\n this.confirmDelete = false;\n }\n\n handleSelectFile() {\n this.fileInput?.click();\n }\n\n async handleFileChange() {\n const selectedFiles = Array.from(this.fileInput?.files);\n let droppedFiles = [] as File[];\n for (let i = 0; i < this.fileInput?.files.length; i++) {\n droppedFiles.push(this.fileInput?.files[i]);\n }\n\n this.handleSetSelected(selectedFiles);\n }\n\n render() {\n const existingFile = this.existingFile?.name ? this.existingFile : null;\n\n return (\n <Host>\n <div class=\"background-overlay\" onClick={e => this.handleDismiss(e)}>\n <div class=\"upload-dialog-content\">\n <div class=\"heading\">Upload attachment</div>\n\n {this.selectedFiles.length < 1 && existingFile && (\n <Fragment>\n <div class=\"current-label\">Current Attachment</div>\n <div class=\"attachments\" style={{marginTop: '0'}}>\n <div class=\"attachment\">\n <div class=\"icon\" innerHTML={PaperclipIcon} />\n <div class=\"name\">{existingFile.name}</div>\n <div class=\"icon trash\" innerHTML={TrashIcon} onClick={() => (this.confirmDelete = true)} />\n </div>\n </div>\n </Fragment>\n )}\n\n {this.selectedFiles.length < 1 && !existingFile && (\n <div\n class={{'drop-target': true, 'dragging-over': this.draggingOver}}\n onDragOver={e => this.handleDragOver(e)}\n onDragLeave={e => this.handleDragLeave(e)}\n onDrop={e => this.handleDrop(e)}\n >\n <p>Drag and drop your files here</p>\n <p class=\"subscript\">Supported files: PDF, Word, JPG, PNG</p>\n\n <verdocs-button label={!!existingFile ? 'Replace files' : 'Select files'} onClick={() => this.handleSelectFile()} />\n <input\n type=\"file\"\n ref={el => (this.fileInput = el as HTMLInputElement)}\n style={{display: 'none'}}\n accept=\".pdf,application/pdf,.doc,.docx,application/msword,application/vnd.openxmlformats-officedocument.wordprocessingml.document,image/*\"\n onChange={() => this.handleFileChange()}\n />\n </div>\n )}\n\n {this.selectedFiles.length > 0 && (\n <div class=\"attachments\">\n {this.selectedFiles.map((file, index) => (\n <div class=\"attachment\">\n <div class=\"icon\" innerHTML={PaperclipIcon} />\n <div class=\"name\">{file.name}</div>\n <div class=\"icon trash\" innerHTML={TrashIcon} onClick={() => this.handleRemoveAttachment(index)} />\n </div>\n ))}\n </div>\n )}\n\n {!!this.errorMessage && <div class=\"error\">{this.errorMessage}</div>}\n\n <div class=\"buttons\">\n <verdocs-button label=\"Cancel\" variant=\"outline\" onClick={() => this.handleCancel()} />\n <verdocs-button label=\"Upload\" onClick={() => this.handleDone()} disabled={!!this.errorMessage || this.selectedFiles.length < 1} />\n </div>\n </div>\n </div>\n\n {this.confirmDelete && (\n <verdocs-ok-dialog\n heading=\"Delete Attachment?\"\n message=\"Are you sure you wish to delete this attachment? This action cannot be undone.\"\n showCancel={true}\n onExit={e => {\n // So we don't close the upload dialog\n e.preventDefault();\n e.stopPropagation();\n this.confirmDelete = false;\n }}\n onNext={e => this.handleDeleteAttachment(e)}\n />\n )}\n </Host>\n );\n }\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["verdocsFieldAttachmentCss","VerdocsFieldAttachmentStyle0","PaperclipIcon","AttachedIcon","VerdocsFieldAttachment","class_1","hostRef","_this","this","endpoint","VerdocsEndpoint","getDefault","source","sourceid","fieldname","field","disabled","editable","moveable","done","xscale","yscale","pagenumber","showingProperties","dialogOpen","selectedFile","focused","handleUploadNext","e","console","log","detail","_a","attached","emit","handleUploadRemove","preventDefault","stopPropagation","deleted","fieldName","prototype","focusField","setTimeout","showSettingsPanel","settingsPanel","document","getElementById","concat","showPanel","hideSettingsPanel","hidePanel","handleShow","render","_b","_c","_d","_e","_f","_g","_h","Store","getField","index","_j","_k","required","_l","value","_m","label","_o","settings","backgroundColor","getRGBA","hasFile","h","Host","class","innerHTML","style","onClick","Fragment","id","transform","Math","floor","SettingsIcon","anchor","onClickAway","templateId","onClose","onDelete","onSettingsChanged","settingsChanged","helpText","existingFile","onNext","onRemove","onExit","verdocsFieldCheckboxCss","VerdocsFieldCheckboxStyle0","VerdocsFieldCheckbox","class_2","checked","htmlFor","name","type","verdocsFieldDateCss","VerdocsFieldDateStyle0","VerdocsFieldDate","class_3","containerId","random","toString","substring","picker","show","componentDidLoad","AirDatepicker","locale","localeEn","isMobile","autoClose","onShow","onHide","onSelect","date","formattedDate","event","CustomEvent","hostEl","dispatchEvent","placeholder","formattedValue","format","Date","FORMAT_DATE","onFocus","onBlur","verdocsFieldDropdownCss","VerdocsFieldDropdownStyle0","VerdocsFieldDropdown","class_4","selectEl","showPicker","handleChange","fieldChange","target","options","onChange","ref","el","map","option","selected","length","verdocsFieldInitialCss","VerdocsFieldInitialStyle0","VerdocsFieldInitial","class_5","initials","tempInitials","hideDialog","dialog","remove","handleAdopt","createElement","setAttribute","addEventListener","body","append","base64","src","alt","verdocsFieldRadioCss","VerdocsFieldRadioStyle0","RadioIconUnselected","RadioIconSelected","VerdocsFieldRadio","class_6","group","maxWidth","verdocsFieldSignatureCss","VerdocsFieldSignatureStyle0","VerdocsFieldSignature","class_7","tempSignature","verdocsFieldTextareaCss","VerdocsFieldTextareaStyle0","VerdocsFieldTextarea","class_8","inputEl","focus","componentDidRender","interact","dynamicDrop","resizable","edges","top","bottom","left","right","listeners","start","handleResizeStart","bind","move","handleResize","end","handleResizeEnd","dataset","x","y","rect","width","height","parseFloat","deltaRect","Object","assign","split","translateX","translateY","round","updateField","then","catch","verdocsFieldTextboxCss","VerdocsFieldTextboxStyle0","VerdocsFieldTextbox","class_9","multiline","modifiers","restrictSize","min","dX","dY","currentLeft","currentBottom","updatedField","__awaiter","getTemplate","template","sent","newTemplate","JSON","parse","stringify","fieldIndex","fields","findIndex","updateTemplate","_p","default","_q","maxlength","verdocsFieldTimestampCss","VerdocsFieldTimestampStyle0","VerdocsFieldTimestamp","class_10","formatted","toISOString","FORMAT_TIMESTAMP","verdocsInitialDialogCss","VerdocsInitialDialogStyle0","VerdocsInitialDialog","fontLoaded","enteredInitials","mode","componentWillLoad","toUpperCase","ds","FontFace","load","font","fonts","add","redrawSignature","componentDidUpdate","canvasElement","canvasWidth","context","getContext","clearRect","fontSize","measureText","textAlign","textBaseline","fillText","handleNameChange","handleCancel","exit","data","toDataURL","next","key","onInput","display","variant","verdocsSignatureDialogCss","VerdocsSignatureDialogStyle0","VerdocsSignatureDialog","enteredName","size","verdocsUploadDialogCss","VerdocsUploadDialogStyle0","TrashIcon","VerdocsUploadDialog","class_11","maxSize","draggingOver","confirmDelete","selectedFiles","errorMessage","handleDismiss","handleDone","handleDragOver","handleDragLeave","handleDrop","handleSetSelected","Array","from","dataTransfer","files","handleRemoveAttachment","newFiles","__spreadArray","splice","totalSize","reduce","acc","file","handleDeleteAttachment","handleSelectFile","fileInput","click","handleFileChange","marginTop","onDragOver","onDragLeave","onDrop","accept","heading","message","showCancel"],"sources":["src/components/fields/verdocs-field-attachment/verdocs-field-attachment.scss?tag=verdocs-field-attachment","src/components/fields/verdocs-field-attachment/verdocs-field-attachment.tsx","src/components/fields/verdocs-field-checkbox/verdocs-field-checkbox.scss?tag=verdocs-field-checkbox","src/components/fields/verdocs-field-checkbox/verdocs-field-checkbox.tsx","src/components/fields/verdocs-field-date/verdocs-field-date.scss?tag=verdocs-field-date","src/components/fields/verdocs-field-date/verdocs-field-date.tsx","src/components/fields/verdocs-field-dropdown/verdocs-field-dropdown.scss?tag=verdocs-field-dropdown","src/components/fields/verdocs-field-dropdown/verdocs-field-dropdown.tsx","src/components/fields/verdocs-field-initial/verdocs-field-initial.scss?tag=verdocs-field-initial","src/components/fields/verdocs-field-initial/verdocs-field-initial.tsx","src/components/fields/verdocs-field-radio/verdocs-field-radio.scss?tag=verdocs-field-radio","src/components/fields/verdocs-field-radio/verdocs-field-radio.tsx","src/components/fields/verdocs-field-signature/verdocs-field-signature.scss?tag=verdocs-field-signature","src/components/fields/verdocs-field-signature/verdocs-field-signature.tsx","src/components/fields/verdocs-field-textarea/verdocs-field-textarea.scss?tag=verdocs-field-textarea","src/components/fields/verdocs-field-textarea/verdocs-field-textarea.tsx","src/components/fields/verdocs-field-textbox/verdocs-field-textbox.scss?tag=verdocs-field-textbox","src/components/fields/verdocs-field-textbox/verdocs-field-textbox.tsx","src/components/fields/verdocs-field-timestamp/verdocs-field-timestamp.scss?tag=verdocs-field-timestamp","src/components/fields/verdocs-field-timestamp/verdocs-field-timestamp.tsx","src/components/dialogs/verdocs-initial-dialog/verdocs-initial-dialog.scss?tag=verdocs-initial-dialog","src/components/dialogs/verdocs-initial-dialog/verdocs-initial-dialog.tsx","src/components/dialogs/verdocs-signature-dialog/verdocs-signature-dialog.scss?tag=verdocs-signature-dialog","src/components/dialogs/verdocs-signature-dialog/verdocs-signature-dialog.tsx","src/components/dialogs/verdocs-upload-dialog/verdocs-upload-dialog.scss?tag=verdocs-upload-dialog","src/components/dialogs/verdocs-upload-dialog/verdocs-upload-dialog.tsx"],"sourcesContent":["@import '../../../theme.scss';\n\nverdocs-field-attachment {\n font-family: $verdocs-primary-font;\n box-sizing: border-box;\n width: 24px;\n height: 24px;\n display: block;\n font-size: 11px;\n position: relative;\n scroll-margin: 20px 0;\n background-color: transparent;\n transform-origin: bottom left;\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n label {\n top: -14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n svg {\n width: 16px;\n height: 16px;\n }\n\n &.disabled svg {\n opacity: 0.5;\n\n span {\n cursor: inherit;\n }\n }\n\n .attach {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n width: 24px;\n height: 24px;\n display: flex;\n align-items: center;\n justify-content: center;\n }\n\n &.required {\n .attach {\n border: 1px solid $verdocs-red-1;\n }\n }\n\n verdocs-button-panel {\n top: 1px;\n left: -19px;\n opacity: 0.5;\n z-index: 1000;\n cursor: pointer;\n position: absolute;\n transform: scale(0.6);\n\n &[data-active],\n &:hover {\n opacity: 1;\n }\n\n .icon {\n svg {\n fill: #333333;\n }\n\n &:hover {\n svg {\n fill: #000000;\n }\n }\n }\n }\n\n .settings-icon {\n position: absolute;\n top: -3px;\n left: -20px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import {ITemplateField, getRGBA, VerdocsEndpoint, IEnvelopeField} from '@verdocs/js-sdk';\nimport {Component, h, Host, Prop, Method, Event, EventEmitter, State, Fragment, Element} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\nexport interface ISelectedFile {\n lastModified: number;\n size: number;\n type: string;\n name: string;\n data: string;\n}\n\nconst PaperclipIcon = `<svg xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\"><path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M15.172 7l-6.586 6.586a2 2 0 102.828 2.828l6.414-6.586a4 4 0 00-5.656-5.656l-6.415 6.585a6 6 0 108.486 8.486L20.5 13\" /></svg>`;\n\nconst AttachedIcon = `<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"#339933\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" class=\"lucide lucide-file-check\"><path d=\"M15 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V7Z\"/><path d=\"M14 2v4a2 2 0 0 0 2 2h4\"/><path d=\"m9 15 2 2 4-4\"/></svg>`;\n\n/**\n * Displays an attachment field.\n */\n@Component({\n tag: 'verdocs-field-attachment',\n styleUrl: 'verdocs-field-attachment.scss',\n shadow: false,\n})\nexport class VerdocsFieldAttachment {\n @Element() el: HTMLElement;\n\n /**\n * The endpoint to use to communicate with Verdocs. If not set, the default endpoint will be used.\n * This component self-manages its resize (width) behavior when in edit-template mode, and uses\n * this endpoint to save changes.\n */\n @Prop() endpoint: VerdocsEndpoint = VerdocsEndpoint.getDefault();\n\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when a file is attached by the signer.\n */\n @Event({composed: true}) attached: EventEmitter<ISelectedFile>;\n\n /**\n * Event fired when the field is deleted. Note that this is for the FIELD (e.g. in\n * Build) not for any attachments (during signing).\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() showingProperties?: boolean = false;\n @State() dialogOpen?: boolean = false;\n @State() selectedFile?: ISelectedFile | null = null;\n @State() focused = false;\n\n @Method()\n async focusField() {\n // Our input field is fake, so we fake the flash too\n this.focused = true;\n this.dialogOpen = true;\n setTimeout(() => {\n this.focused = false;\n }, 500);\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n }\n\n handleShow() {\n this.dialogOpen = true;\n }\n\n handleUploadNext = (e: any) => {\n console.log('Upload next', e);\n this.dialogOpen = false;\n this.selectedFile = e.detail[0];\n this.attached?.emit(e.detail[0]);\n };\n\n handleUploadRemove = (e: any) => {\n e.preventDefault();\n e.stopPropagation();\n this.dialogOpen = false;\n this.selectedFile = null;\n this.deleted?.emit({fieldName: this.fieldname});\n };\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n const {required = false, value = '', label = '', settings = {}} = field || {};\n const backgroundColor = getRGBA(index);\n\n const hasFile = value || !!this.selectedFile;\n\n if (done) {\n return (\n <Host class={{done}}>\n <div class=\"attach\" innerHTML={hasFile ? AttachedIcon : PaperclipIcon} />\n </Host>\n );\n }\n\n return (\n <Host class={{required, disabled, done, focused}} style={{backgroundColor}}>\n {label && <label>{label}</label>}\n\n <div class=\"attach\" innerHTML={hasFile ? AttachedIcon : PaperclipIcon} onClick={() => !disabled && this.handleShow()} />\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${fieldname}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => (this.showingProperties = false)}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={'Attachments allow the user to attach their own documents (e.g. resumes or disclosures) to a signing flow.'}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n\n {this.dialogOpen && (\n <verdocs-portal>\n <verdocs-upload-dialog\n existingFile={settings}\n onNext={e => this.handleUploadNext(e)}\n onRemove={e => this.handleUploadRemove(e)}\n onExit={() => (this.dialogOpen = false)}\n />\n </verdocs-portal>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\n// See https://www.kallmanation.com/styling-a-checkbox-with-only-css\nverdocs-field-checkbox {\n padding: 0;\n width: 16px;\n height: 16px;\n display: block;\n scroll-margin: 20px 0;\n box-sizing: border-box;\n transform-origin: bottom left;\n font-family: $verdocs-primary-font;\n\n // To avoid conflicting with the use of a label for the checkbox itself\n div.label {\n top: -14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n label {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n width: 14px;\n height: 14px;\n display: block;\n box-sizing: border-box;\n }\n\n &.disabled label {\n opacity: 0.5;\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n label > input[type='checkbox'] {\n display: none;\n }\n\n label > input[type='checkbox'] + *::before {\n margin: 0;\n content: '';\n width: 12px;\n height: 12px;\n display: block;\n line-height: 12px;\n border-radius: 2px;\n box-sizing: border-box;\n border: 1px solid $verdocs-grey-2;\n }\n\n label > input[type='checkbox']:checked + * {\n color: $verdocs-green;\n }\n\n label > input[type='checkbox']:checked + *::before {\n content: '✓';\n color: white;\n font-size: 12px;\n text-align: center;\n background: $verdocs-green;\n border-color: $verdocs-green;\n }\n\n &.required {\n border: 1px solid $verdocs-red-1;\n }\n\n &.hide {\n display: none;\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n verdocs-button-panel {\n display: block;\n margin-left: -20px;\n margin-top: -17px;\n transform: scale(0.7);\n }\n\n .settings-icon {\n position: absolute;\n top: -5px;\n left: -20px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import {ITemplateField, getRGBA, IEnvelopeField} from '@verdocs/js-sdk';\nimport {Component, Event, EventEmitter, Fragment, h, Host, Method, Prop, State} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\n/**\n * Displays a checkbox.\n */\n@Component({\n tag: 'verdocs-field-checkbox',\n styleUrl: 'verdocs-field-checkbox.scss',\n shadow: false,\n})\nexport class VerdocsFieldCheckbox {\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() showingProperties?: boolean = false;\n @State() focused?: boolean = false;\n\n @Method()\n async focusField() {\n // We don't have a visible input that we can actually focus on, so we fake it\n this.focused = true;\n setTimeout(() => {\n this.focused = false;\n }, 500);\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n }\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n const {required = false, label = '', value = false} = field || {};\n const backgroundColor = getRGBA(index);\n\n const checked = value === 'true';\n\n if (done) {\n return <Host class={{done}}>{checked ? '✓' : '☐'}</Host>;\n }\n\n return (\n <Host class={{required, disabled, done, focused}} style={{backgroundColor}}>\n {label && <div class=\"label\">{label}</div>}\n\n <label htmlFor={fieldname}>\n <input id={fieldname} name={fieldname} type=\"checkbox\" checked={checked} disabled={disabled} required={required} />\n <span />\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${field.name}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={field.name}\n onClose={() => (this.showingProperties = false)}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={'Check boxes allow the user to select one or more (non-exclusive) options.'}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </label>\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-field-date {\n font-family: $verdocs-primary-font;\n width: 74px;\n height: 20px;\n display: block;\n font-size: 11px;\n position: relative;\n scroll-margin: 20px 0;\n letter-spacing: 0.3px;\n background-color: transparent;\n transform-origin: bottom left;\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n label {\n top: -14px;\n left: 0;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n input {\n position: absolute;\n\n font-size: 12px;\n\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n box-sizing: border-box;\n color: rgba(0, 0, 0, 0.87);\n font-weight: 500;\n transform-origin: 0 0;\n height: 100%;\n width: 100%;\n background: none;\n border: 1px solid $light-border-color;\n appearance: none;\n\n &.hide {\n display: none;\n }\n }\n\n &.disabled input {\n opacity: 0.5;\n }\n\n &.required {\n input {\n border: 1px solid $verdocs-red-1;\n }\n }\n\n verdocs-button-panel {\n top: -3px;\n left: -2px;\n opacity: 0.5;\n z-index: 1000;\n cursor: pointer;\n position: absolute;\n transform: scale(0.6);\n\n &[data-active],\n &:hover {\n opacity: 1;\n }\n\n .icon {\n svg {\n fill: #333333;\n }\n\n &:hover {\n svg {\n fill: #000000;\n }\n }\n }\n }\n\n .settings-icon {\n position: absolute;\n top: -3px;\n left: -18px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n.air-datepicker-cell.-year-.-other-decade-,\n.air-datepicker-cell.-day-.-other-month- {\n color: var(--adp-color-other-month);\n}\n.air-datepicker-cell.-year-.-other-decade-:hover,\n.air-datepicker-cell.-day-.-other-month-:hover {\n color: var(--adp-color-other-month-hover);\n}\n.-disabled-.-focus-.air-datepicker-cell.-year-.-other-decade-,\n.-disabled-.-focus-.air-datepicker-cell.-day-.-other-month- {\n color: var(--adp-color-other-month);\n}\n.-selected-.air-datepicker-cell.-year-.-other-decade-,\n.-selected-.air-datepicker-cell.-day-.-other-month- {\n color: #fff;\n background: var(--adp-background-color-selected-other-month);\n}\n.-selected-.-focus-.air-datepicker-cell.-year-.-other-decade-,\n.-selected-.-focus-.air-datepicker-cell.-day-.-other-month- {\n background: var(--adp-background-color-selected-other-month-focused);\n}\n.-in-range-.air-datepicker-cell.-year-.-other-decade-,\n.-in-range-.air-datepicker-cell.-day-.-other-month- {\n background-color: var(--adp-background-color-in-range);\n color: var(--adp-color);\n}\n.-in-range-.-focus-.air-datepicker-cell.-year-.-other-decade-,\n.-in-range-.-focus-.air-datepicker-cell.-day-.-other-month- {\n background-color: var(--adp-background-color-in-range-focused);\n}\n.air-datepicker-cell.-year-.-other-decade-:empty,\n.air-datepicker-cell.-day-.-other-month-:empty {\n background: none;\n border: none;\n}\n.air-datepicker-cell {\n border-radius: var(--adp-cell-border-radius);\n box-sizing: border-box;\n cursor: pointer;\n display: flex;\n position: relative;\n align-items: center;\n justify-content: center;\n z-index: 1;\n}\n.air-datepicker-cell.-focus- {\n background: var(--adp-cell-background-color-hover);\n}\n.air-datepicker-cell.-current- {\n color: var(--adp-color-current-date);\n}\n.air-datepicker-cell.-current-.-focus- {\n color: var(--adp-color);\n}\n.air-datepicker-cell.-current-.-in-range- {\n color: var(--adp-color-current-date);\n}\n.air-datepicker-cell.-disabled- {\n cursor: default;\n color: var(--adp-color-disabled);\n}\n.air-datepicker-cell.-disabled-.-focus- {\n color: var(--adp-color-disabled);\n}\n.air-datepicker-cell.-disabled-.-in-range- {\n color: var(--adp-color-disabled-in-range);\n}\n.air-datepicker-cell.-disabled-.-current-.-focus- {\n color: var(--adp-color-disabled);\n}\n.air-datepicker-cell.-in-range- {\n background: var(--adp-cell-background-color-in-range);\n border-radius: 0;\n}\n.air-datepicker-cell.-in-range-:hover {\n background: var(--adp-cell-background-color-in-range-hover);\n}\n.air-datepicker-cell.-range-from- {\n border: 1px solid var(--adp-cell-border-color-in-range);\n background-color: var(--adp-cell-background-color-in-range);\n border-radius: var(--adp-cell-border-radius) 0 0 var(--adp-cell-border-radius);\n}\n.air-datepicker-cell.-range-to- {\n border: 1px solid var(--adp-cell-border-color-in-range);\n background-color: var(--adp-cell-background-color-in-range);\n border-radius: 0 var(--adp-cell-border-radius) var(--adp-cell-border-radius) 0;\n}\n.air-datepicker-cell.-range-to-.-range-from- {\n border-radius: var(--adp-cell-border-radius);\n}\n.air-datepicker-cell.-selected- {\n color: #fff;\n border: none;\n background: var(--adp-cell-background-color-selected);\n}\n.air-datepicker-cell.-selected-.-current- {\n color: #fff;\n background: var(--adp-cell-background-color-selected);\n}\n.air-datepicker-cell.-selected-.-focus- {\n background: var(--adp-cell-background-color-selected-hover);\n}\n.air-datepicker-body {\n transition: all var(--adp-transition-duration) var(--adp-transition-ease);\n}\n.air-datepicker-body.-hidden- {\n display: none;\n}\n.air-datepicker-body--day-names {\n display: grid;\n grid-template-columns: repeat(7, var(--adp-day-cell-width));\n margin: 8px 0 3px;\n}\n.air-datepicker-body--day-name {\n color: var(--adp-day-name-color);\n display: flex;\n align-items: center;\n justify-content: center;\n flex: 1;\n text-align: center;\n text-transform: uppercase;\n font-size: 0.8em;\n}\n.air-datepicker-body--day-name.-clickable- {\n cursor: pointer;\n}\n.air-datepicker-body--day-name.-clickable-:hover {\n color: var(--adp-day-name-color-hover);\n}\n.air-datepicker-body--cells {\n display: grid;\n}\n.air-datepicker-body--cells.-days- {\n grid-template-columns: repeat(7, var(--adp-day-cell-width));\n grid-auto-rows: var(--adp-day-cell-height);\n}\n.air-datepicker-body--cells.-months- {\n grid-template-columns: repeat(3, 1fr);\n grid-auto-rows: var(--adp-month-cell-height);\n}\n.air-datepicker-body--cells.-years- {\n grid-template-columns: repeat(4, 1fr);\n grid-auto-rows: var(--adp-year-cell-height);\n}\n.air-datepicker-nav {\n display: flex;\n justify-content: space-between;\n border-bottom: 1px solid var(--adp-border-color-inner);\n min-height: var(--adp-nav-height);\n padding: var(--adp-padding);\n box-sizing: content-box;\n}\n.-only-timepicker- .air-datepicker-nav {\n display: none;\n}\n.air-datepicker-nav--title,\n.air-datepicker-nav--action {\n display: flex;\n cursor: pointer;\n align-items: center;\n justify-content: center;\n}\n.air-datepicker-nav--action {\n width: var(--adp-nav-action-size);\n border-radius: var(--adp-border-radius);\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n}\n.air-datepicker-nav--action:hover {\n background: var(--adp-background-color-hover);\n}\n.air-datepicker-nav--action:active {\n background: var(--adp-background-color-active);\n}\n.air-datepicker-nav--action.-disabled- {\n visibility: hidden;\n}\n.air-datepicker-nav--action svg {\n width: 32px;\n height: 32px;\n}\n.air-datepicker-nav--action path {\n fill: none;\n stroke: var(--adp-nav-arrow-color);\n stroke-width: 2px;\n}\n.air-datepicker-nav--title {\n border-radius: var(--adp-border-radius);\n padding: 0 8px;\n}\n.air-datepicker-nav--title i {\n font-style: normal;\n color: var(--adp-nav-color-secondary);\n margin-left: 0.3em;\n}\n.air-datepicker-nav--title:hover {\n background: var(--adp-background-color-hover);\n}\n.air-datepicker-nav--title:active {\n background: var(--adp-background-color-active);\n}\n.air-datepicker-nav--title.-disabled- {\n cursor: default;\n background: none;\n}\n.air-datepicker-buttons {\n display: grid;\n grid-auto-columns: 1fr;\n grid-auto-flow: column;\n}\n.air-datepicker-button {\n display: inline-flex;\n color: var(--adp-btn-color);\n border-radius: var(--adp-btn-border-radius);\n cursor: pointer;\n height: var(--adp-btn-height);\n border: none;\n background: rgba(255, 255, 255, 0);\n}\n.air-datepicker-button:hover {\n color: var(--adp-btn-color-hover);\n background: var(--adp-btn-background-color-hover);\n}\n.air-datepicker-button:focus {\n color: var(--adp-btn-color-hover);\n background: var(--adp-btn-background-color-hover);\n outline: none;\n}\n.air-datepicker-button:active {\n background: var(--adp-btn-background-color-active);\n}\n.air-datepicker-button span {\n outline: none;\n display: flex;\n align-items: center;\n justify-content: center;\n width: 100%;\n height: 100%;\n}\n.air-datepicker-time {\n display: grid;\n grid-template-columns: max-content 1fr;\n grid-column-gap: 12px;\n align-items: center;\n position: relative;\n padding: 0 var(--adp-time-padding-inner);\n}\n.-only-timepicker- .air-datepicker-time {\n border-top: none;\n}\n.air-datepicker-time--current {\n display: flex;\n align-items: center;\n flex: 1;\n font-size: 14px;\n text-align: center;\n}\n.air-datepicker-time--current-colon {\n margin: 0 2px 3px;\n line-height: 1;\n}\n.air-datepicker-time--current-hours,\n.air-datepicker-time--current-minutes {\n line-height: 1;\n font-size: 19px;\n font-family: 'Century Gothic', CenturyGothic, AppleGothic, sans-serif;\n position: relative;\n z-index: 1;\n}\n.air-datepicker-time--current-hours:after,\n.air-datepicker-time--current-minutes:after {\n content: '';\n background: var(--adp-background-color-hover);\n border-radius: var(--adp-border-radius);\n position: absolute;\n left: -2px;\n top: -3px;\n right: -2px;\n bottom: -2px;\n z-index: -1;\n opacity: 0;\n}\n.air-datepicker-time--current-hours.-focus-:after,\n.air-datepicker-time--current-minutes.-focus-:after {\n opacity: 1;\n}\n.air-datepicker-time--current-ampm {\n text-transform: uppercase;\n align-self: flex-end;\n color: var(--adp-time-day-period-color);\n margin-left: 6px;\n font-size: 11px;\n margin-bottom: 1px;\n}\n.air-datepicker-time--row {\n display: flex;\n align-items: center;\n font-size: 11px;\n height: 17px;\n background: linear-gradient(to right, var(--adp-time-track-color), var(--adp-time-track-color)) left 50%/100% var(--adp-time-track-height) no-repeat;\n}\n.air-datepicker-time--row:first-child {\n margin-bottom: 4px;\n}\n.air-datepicker-time--row input[type='range'] {\n background: none;\n cursor: pointer;\n flex: 1;\n height: 100%;\n width: 100%;\n padding: 0;\n margin: 0;\n -webkit-appearance: none;\n}\n.air-datepicker-time--row input[type='range']::-webkit-slider-thumb {\n -webkit-appearance: none;\n}\n.air-datepicker-time--row input[type='range']::-ms-tooltip {\n display: none;\n}\n.air-datepicker-time--row input[type='range']:hover::-webkit-slider-thumb {\n border-color: var(--adp-time-track-color-hover);\n}\n.air-datepicker-time--row input[type='range']:hover::-moz-range-thumb {\n border-color: var(--adp-time-track-color-hover);\n}\n.air-datepicker-time--row input[type='range']:hover::-ms-thumb {\n border-color: var(--adp-time-track-color-hover);\n}\n.air-datepicker-time--row input[type='range']:focus {\n outline: none;\n}\n.air-datepicker-time--row input[type='range']:focus::-webkit-slider-thumb {\n background: var(--adp-cell-background-color-selected);\n border-color: var(--adp-cell-background-color-selected);\n}\n.air-datepicker-time--row input[type='range']:focus::-moz-range-thumb {\n background: var(--adp-cell-background-color-selected);\n border-color: var(--adp-cell-background-color-selected);\n}\n.air-datepicker-time--row input[type='range']:focus::-ms-thumb {\n background: var(--adp-cell-background-color-selected);\n border-color: var(--adp-cell-background-color-selected);\n}\n.air-datepicker-time--row input[type='range']::-webkit-slider-thumb {\n box-sizing: border-box;\n height: 12px;\n width: 12px;\n border-radius: 3px;\n border: 1px solid var(--adp-time-track-color);\n background: #fff;\n cursor: pointer;\n -webkit-transition: background var(--adp-transition-duration);\n transition: background var(--adp-transition-duration);\n}\n.air-datepicker-time--row input[type='range']::-moz-range-thumb {\n box-sizing: border-box;\n height: 12px;\n width: 12px;\n border-radius: 3px;\n border: 1px solid var(--adp-time-track-color);\n background: #fff;\n cursor: pointer;\n -moz-transition: background var(--adp-transition-duration);\n transition: background var(--adp-transition-duration);\n}\n.air-datepicker-time--row input[type='range']::-ms-thumb {\n box-sizing: border-box;\n height: 12px;\n width: 12px;\n border-radius: 3px;\n border: 1px solid var(--adp-time-track-color);\n background: #fff;\n cursor: pointer;\n -ms-transition: background var(--adp-transition-duration);\n transition: background var(--adp-transition-duration);\n}\n.air-datepicker-time--row input[type='range']::-webkit-slider-thumb {\n margin-top: calc(var(--adp-time-thumb-size) / 2 * -1);\n}\n.air-datepicker-time--row input[type='range']::-webkit-slider-runnable-track {\n border: none;\n height: var(--adp-time-track-height);\n cursor: pointer;\n color: rgba(0, 0, 0, 0);\n background: rgba(0, 0, 0, 0);\n}\n.air-datepicker-time--row input[type='range']::-moz-range-track {\n border: none;\n height: var(--adp-time-track-height);\n cursor: pointer;\n color: rgba(0, 0, 0, 0);\n background: rgba(0, 0, 0, 0);\n}\n.air-datepicker-time--row input[type='range']::-ms-track {\n border: none;\n height: var(--adp-time-track-height);\n cursor: pointer;\n color: rgba(0, 0, 0, 0);\n background: rgba(0, 0, 0, 0);\n}\n.air-datepicker-time--row input[type='range']::-ms-fill-lower {\n background: rgba(0, 0, 0, 0);\n}\n.air-datepicker-time--row input[type='range']::-ms-fill-upper {\n background: rgba(0, 0, 0, 0);\n}\n.air-datepicker {\n --adp-font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol';\n --adp-font-size: 14px;\n --adp-width: 246px;\n --adp-z-index: 100;\n --adp-padding: 4px;\n --adp-grid-areas: 'nav' 'body' 'timepicker' 'buttons';\n --adp-transition-duration: 0.3s;\n --adp-transition-ease: ease-out;\n --adp-transition-offset: 8px;\n --adp-background-color: #fff;\n --adp-background-color-hover: #f0f0f0;\n --adp-background-color-active: #eaeaea;\n --adp-background-color-in-range: rgba(92, 196, 239, 0.1);\n --adp-background-color-in-range-focused: rgba(92, 196, 239, 0.2);\n --adp-background-color-selected-other-month-focused: #8ad5f4;\n --adp-background-color-selected-other-month: #a2ddf6;\n --adp-color: #4a4a4a;\n --adp-color-secondary: #9c9c9c;\n --adp-accent-color: #4eb5e6;\n --adp-color-current-date: var(--adp-accent-color);\n --adp-color-other-month: #dedede;\n --adp-color-disabled: #aeaeae;\n --adp-color-disabled-in-range: #939393;\n --adp-color-other-month-hover: #c5c5c5;\n --adp-border-color: #dbdbdb;\n --adp-border-color-inner: #efefef;\n --adp-border-radius: 4px;\n --adp-border-color-inline: #d7d7d7;\n --adp-nav-height: 32px;\n --adp-nav-arrow-color: var(--adp-color-secondary);\n --adp-nav-action-size: 32px;\n --adp-nav-color-secondary: var(--adp-color-secondary);\n --adp-day-name-color: #ff9a19;\n --adp-day-name-color-hover: #8ad5f4;\n --adp-day-cell-width: 1fr;\n --adp-day-cell-height: 32px;\n --adp-month-cell-height: 42px;\n --adp-year-cell-height: 56px;\n --adp-pointer-size: 10px;\n --adp-poiner-border-radius: 2px;\n --adp-pointer-offset: 14px;\n --adp-cell-border-radius: 4px;\n --adp-cell-background-color-hover: var(--adp-background-color-hover);\n --adp-cell-background-color-selected: #5cc4ef;\n --adp-cell-background-color-selected-hover: #45bced;\n --adp-cell-background-color-in-range: rgba(92, 196, 239, 0.1);\n --adp-cell-background-color-in-range-hover: rgba(92, 196, 239, 0.2);\n --adp-cell-border-color-in-range: var(--adp-cell-background-color-selected);\n --adp-btn-height: 32px;\n --adp-btn-color: var(--adp-accent-color);\n --adp-btn-color-hover: var(--adp-color);\n --adp-btn-border-radius: var(--adp-border-radius);\n --adp-btn-background-color-hover: var(--adp-background-color-hover);\n --adp-btn-background-color-active: var(--adp-background-color-active);\n --adp-time-track-height: 1px;\n --adp-time-track-color: #dedede;\n --adp-time-track-color-hover: #b1b1b1;\n --adp-time-thumb-size: 12px;\n --adp-time-padding-inner: 10px;\n --adp-time-day-period-color: var(--adp-color-secondary);\n --adp-mobile-font-size: 16px;\n --adp-mobile-nav-height: 40px;\n --adp-mobile-width: 320px;\n --adp-mobile-day-cell-height: 38px;\n --adp-mobile-month-cell-height: 48px;\n --adp-mobile-year-cell-height: 64px;\n}\n.air-datepicker-overlay {\n --adp-overlay-background-color: rgba(0, 0, 0, 0.3);\n --adp-overlay-transition-duration: 0.3s;\n --adp-overlay-transition-ease: ease-out;\n --adp-overlay-z-index: 99;\n}\n.air-datepicker {\n background: var(--adp-background-color);\n border: 1px solid var(--adp-border-color);\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);\n border-radius: var(--adp-border-radius);\n box-sizing: content-box;\n display: grid;\n grid-template-columns: 1fr;\n grid-template-rows: repeat(4, max-content);\n grid-template-areas: var(--adp-grid-areas);\n font-family: var(--adp-font-family), sans-serif;\n font-size: var(--adp-font-size);\n color: var(--adp-color);\n width: var(--adp-width);\n position: absolute;\n transition:\n opacity var(--adp-transition-duration) var(--adp-transition-ease),\n transform var(--adp-transition-duration) var(--adp-transition-ease);\n z-index: var(--adp-z-index);\n}\n.air-datepicker:not(.-custom-position-) {\n opacity: 0;\n}\n.air-datepicker.-from-top- {\n transform: translateY(calc(var(--adp-transition-offset) * -1));\n}\n.air-datepicker.-from-right- {\n transform: translateX(var(--adp-transition-offset));\n}\n.air-datepicker.-from-bottom- {\n transform: translateY(var(--adp-transition-offset));\n}\n.air-datepicker.-from-left- {\n transform: translateX(calc(var(--adp-transition-offset) * -1));\n}\n.air-datepicker.-active-:not(.-custom-position-) {\n transform: translate(0, 0);\n opacity: 1;\n}\n.air-datepicker.-active-.-custom-position- {\n transition: none;\n}\n.air-datepicker.-inline- {\n border-color: var(--adp-border-color-inline);\n box-shadow: none;\n position: static;\n left: auto;\n right: auto;\n opacity: 1;\n transform: none;\n}\n.air-datepicker.-inline- .air-datepicker--pointer {\n display: none;\n}\n.air-datepicker.-is-mobile- {\n --adp-font-size: var(--adp-mobile-font-size);\n --adp-day-cell-height: var(--adp-mobile-day-cell-height);\n --adp-month-cell-height: var(--adp-mobile-month-cell-height);\n --adp-year-cell-height: var(--adp-mobile-year-cell-height);\n --adp-nav-height: var(--adp-mobile-nav-height);\n --adp-nav-action-size: var(--adp-mobile-nav-height);\n position: fixed;\n width: var(--adp-mobile-width);\n border: none;\n}\n.air-datepicker.-is-mobile- * {\n -webkit-tap-highlight-color: rgba(0, 0, 0, 0);\n}\n.air-datepicker.-is-mobile- .air-datepicker--pointer {\n display: none;\n}\n.air-datepicker.-is-mobile-:not(.-custom-position-) {\n transform: translate(-50%, calc(-50% + var(--adp-transition-offset)));\n}\n.air-datepicker.-is-mobile-.-active-:not(.-custom-position-) {\n transform: translate(-50%, -50%);\n}\n.air-datepicker.-custom-position- {\n transition: none;\n}\n.air-datepicker-global-container {\n position: absolute;\n left: 0;\n top: 0;\n}\n.air-datepicker--pointer {\n --pointer-half-size: calc(var(--adp-pointer-size) / 2);\n position: absolute;\n width: var(--adp-pointer-size);\n height: var(--adp-pointer-size);\n z-index: -1;\n}\n.air-datepicker--pointer:after {\n content: '';\n position: absolute;\n background: #fff;\n border-top: 1px solid var(--adp-border-color-inline);\n border-right: 1px solid var(--adp-border-color-inline);\n border-top-right-radius: var(--adp-poiner-border-radius);\n width: var(--adp-pointer-size);\n height: var(--adp-pointer-size);\n box-sizing: border-box;\n}\n.-top-left- .air-datepicker--pointer,\n.-top-center- .air-datepicker--pointer,\n.-top-right- .air-datepicker--pointer,\n[data-popper-placement^='top'] .air-datepicker--pointer {\n top: calc(100% - var(--pointer-half-size) + 1px);\n}\n.-top-left- .air-datepicker--pointer:after,\n.-top-center- .air-datepicker--pointer:after,\n.-top-right- .air-datepicker--pointer:after,\n[data-popper-placement^='top'] .air-datepicker--pointer:after {\n transform: rotate(135deg);\n}\n.-right-top- .air-datepicker--pointer,\n.-right-center- .air-datepicker--pointer,\n.-right-bottom- .air-datepicker--pointer,\n[data-popper-placement^='right'] .air-datepicker--pointer {\n right: calc(100% - var(--pointer-half-size) + 1px);\n}\n.-right-top- .air-datepicker--pointer:after,\n.-right-center- .air-datepicker--pointer:after,\n.-right-bottom- .air-datepicker--pointer:after,\n[data-popper-placement^='right'] .air-datepicker--pointer:after {\n transform: rotate(225deg);\n}\n.-bottom-left- .air-datepicker--pointer,\n.-bottom-center- .air-datepicker--pointer,\n.-bottom-right- .air-datepicker--pointer,\n[data-popper-placement^='bottom'] .air-datepicker--pointer {\n bottom: calc(100% - var(--pointer-half-size) + 1px);\n}\n.-bottom-left- .air-datepicker--pointer:after,\n.-bottom-center- .air-datepicker--pointer:after,\n.-bottom-right- .air-datepicker--pointer:after,\n[data-popper-placement^='bottom'] .air-datepicker--pointer:after {\n transform: rotate(315deg);\n}\n.-left-top- .air-datepicker--pointer,\n.-left-center- .air-datepicker--pointer,\n.-left-bottom- .air-datepicker--pointer,\n[data-popper-placement^='left'] .air-datepicker--pointer {\n left: calc(100% - var(--pointer-half-size) + 1px);\n}\n.-left-top- .air-datepicker--pointer:after,\n.-left-center- .air-datepicker--pointer:after,\n.-left-bottom- .air-datepicker--pointer:after,\n[data-popper-placement^='left'] .air-datepicker--pointer:after {\n transform: rotate(45deg);\n}\n.-top-left- .air-datepicker--pointer,\n.-bottom-left- .air-datepicker--pointer {\n left: var(--adp-pointer-offset);\n}\n.-top-right- .air-datepicker--pointer,\n.-bottom-right- .air-datepicker--pointer {\n right: var(--adp-pointer-offset);\n}\n.-top-center- .air-datepicker--pointer,\n.-bottom-center- .air-datepicker--pointer {\n left: calc(50% - var(--adp-pointer-size) / 2);\n}\n.-left-top- .air-datepicker--pointer,\n.-right-top- .air-datepicker--pointer {\n top: var(--adp-pointer-offset);\n}\n.-left-bottom- .air-datepicker--pointer,\n.-right-bottom- .air-datepicker--pointer {\n bottom: var(--adp-pointer-offset);\n}\n.-left-center- .air-datepicker--pointer,\n.-right-center- .air-datepicker--pointer {\n top: calc(50% - var(--adp-pointer-size) / 2);\n}\n.air-datepicker--navigation {\n grid-area: nav;\n}\n.air-datepicker--content {\n box-sizing: content-box;\n padding: var(--adp-padding);\n grid-area: body;\n}\n.-only-timepicker- .air-datepicker--content {\n display: none;\n}\n.air-datepicker--time {\n grid-area: timepicker;\n}\n.air-datepicker--buttons {\n grid-area: buttons;\n}\n.air-datepicker--buttons,\n.air-datepicker--time {\n padding: var(--adp-padding);\n border-top: 1px solid var(--adp-border-color-inner);\n}\n.air-datepicker-overlay {\n position: fixed;\n background: var(--adp-overlay-background-color);\n left: 0;\n top: 0;\n width: 0;\n height: 0;\n opacity: 0;\n transition:\n opacity var(--adp-overlay-transition-duration) var(--adp-overlay-transition-ease),\n left 0s,\n height 0s,\n width 0s;\n transition-delay: 0s, var(--adp-overlay-transition-duration), var(--adp-overlay-transition-duration), var(--adp-overlay-transition-duration);\n z-index: var(--adp-overlay-z-index);\n}\n.air-datepicker-overlay.-active- {\n opacity: 1;\n width: 100%;\n height: 100%;\n transition:\n opacity var(--adp-overlay-transition-duration) var(--adp-overlay-transition-ease),\n height 0s,\n width 0s;\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import {format} from 'date-fns';\nimport {getRGBA} from '@verdocs/js-sdk';\nimport AirDatepicker from 'air-datepicker';\nimport localeEn from 'air-datepicker/locale/en';\nimport type {ITemplateField} from '@verdocs/js-sdk';\nimport {Component, Element, Event, EventEmitter, h, Host, Method, Prop, Fragment, State} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {FORMAT_DATE} from '../../../utils/Types';\nimport {Store} from '../../../utils/Datastore';\n\n/**\n * Displays a date field. When tapped or clicked, the input element will display a date picker component.\n */\n@Component({\n tag: 'verdocs-field-date',\n styleUrl: 'verdocs-field-date.scss',\n shadow: false,\n})\nexport class VerdocsFieldDate {\n @Element()\n private hostEl: HTMLInputElement;\n\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop() field?: ITemplateField;\n\n /**\n * Event fired on every character entered into / deleted from the field.\n */\n @Event({composed: true}) settingsPress: EventEmitter;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() containerId = `verdocs-date-picker-${Math.random().toString(36).substring(2, 11)}`;\n\n @State() showingProperties?: boolean = false;\n\n @Method()\n async focusField() {\n // Our input field is fake, so we fake the flash too\n this.focused = true;\n this.picker?.show();\n setTimeout(() => {\n this.focused = false;\n }, 500);\n }\n\n picker: AirDatepicker<HTMLElement> | null = null;\n\n componentDidLoad() {\n this.picker = new AirDatepicker<HTMLElement>(`#${this.containerId}`, {\n locale: localeEn,\n isMobile: true,\n autoClose: true,\n onShow: () => (this.focused = true),\n onHide: () => (this.focused = false),\n onSelect: ({date, formattedDate}) => {\n const event = new CustomEvent('fieldChange', {detail: {date, formattedDate}});\n this.hostEl.dispatchEvent(event);\n },\n });\n console.log('p', this.picker);\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n }\n\n @State() focused?: boolean = false;\n\n // NOTE: We don't use a \"date\" field here because browsers vary widely in their formatting of it.\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n const {required = false, placeholder = 'Date...', value = '', label = ''} = field || {};\n const backgroundColor = getRGBA(index);\n\n const formattedValue = value ? format(new Date(value), FORMAT_DATE) : '';\n\n if (this.done) {\n return <Host class={{done}}>{formattedValue}</Host>;\n }\n\n return (\n <Host class={{required, disabled, done, focused}} style={{backgroundColor}}>\n {label && <label>{label}</label>}\n\n <input\n name={fieldname}\n class=\"input-el\"\n type=\"text\"\n value={formattedValue}\n id={this.containerId}\n disabled={disabled}\n placeholder={placeholder}\n onFocus={() => (this.focused = true)}\n onBlur={() => (this.focused = false)}\n />\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${field.name}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => (this.showingProperties = false)}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={'Date fields allow the user to select a date.'}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-field-dropdown {\n font-family: $verdocs-primary-font;\n width: 85px;\n height: 20px;\n display: block;\n font-size: 11px;\n position: relative;\n scroll-margin: 20px 0;\n background-color: transparent;\n transform-origin: bottom left;\n\n label {\n top: -14px;\n left: 0;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n select {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n position: absolute;\n background: linear-gradient(55deg, transparent 50%, #333 50%), linear-gradient(125deg, #333 50%, transparent 50%), linear-gradient(to right, transparent, transparent);\n background-position:\n calc(100% - 7px) 6px,\n calc(100% - 3px) 6px,\n 100% 0;\n background-size:\n 5px 5px,\n 5px 5px,\n 2.5em 2.5em;\n background-repeat: no-repeat;\n appearance: none;\n\n box-sizing: border-box;\n color: rgba(0, 0, 0, 0.87);\n font-weight: 500;\n transform-origin: 0 0;\n height: 100%;\n width: 100%;\n font-size: 11px;\n border: 1px solid rgba(0, 0, 0, 0.2);\n padding: 0 5px;\n\n &:focus {\n outline: none;\n }\n\n &.hide {\n display: none;\n }\n }\n\n &.disabled select {\n opacity: 0.5;\n }\n\n &.required {\n select {\n border: 1px solid $verdocs-red-1;\n }\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n verdocs-button-panel {\n display: block;\n margin-left: -33px;\n margin-top: -1px;\n transform: scale(0.7);\n }\n\n .settings-icon {\n position: absolute;\n top: -2px;\n left: -20px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import {ITemplateField, getRGBA, IEnvelopeField} from '@verdocs/js-sdk';\nimport {Component, Event, EventEmitter, h, Host, Method, Prop, Fragment, State} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\n/**\n * Displays a dropdown field that allows the user to choose one of a list of options.\n */\n@Component({\n tag: 'verdocs-field-dropdown',\n styleUrl: 'verdocs-field-dropdown.scss',\n shadow: false,\n})\nexport class VerdocsFieldDropdown {\n selectEl: HTMLSelectElement;\n\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n /**\n * Event fired when the input field value changes. Note that this will only be fired on blur, tab-out, ENTER key press, etc.\n * It is generally the best event to subscribe to than `input` for most cases EXCEPT autocomplete fields that need to see every\n * keypress.\n */\n @Event({composed: true}) fieldChange: EventEmitter<string>;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() showingProperties?: boolean = false;\n @State() focused = false;\n\n @Method()\n async focusField() {\n // Our input field is fake, so we fake the flash too\n this.focused = true;\n setTimeout(() => {\n this.focused = false;\n }, 500);\n\n this.selectEl?.showPicker();\n }\n\n handleChange(e: any) {\n this.fieldChange.emit(e.target.value);\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n }\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n let {required = false, value = '', label = '', options} = field || {};\n const backgroundColor = getRGBA(index);\n\n if (done) {\n return <Host class={{done}}>{value}</Host>;\n }\n\n // TODO: Look for other places this mistaken assumption was made.\n // Defaults only apply in destructuring if undefined. null doesn't trigger it.\n options ||= [];\n\n return (\n <Host class={{required, disabled, done, focused}} style={{backgroundColor}}>\n {label && <label>{label}</label>}\n\n <select disabled={disabled} onChange={e => this.handleChange(e)} ref={el => (this.selectEl = el as HTMLSelectElement)}>\n <option value=\"\">Select...</option>\n {options.map(option => (\n <option value={option.id} selected={option.id === value}>\n {option.label}\n </option>\n ))}\n {!options.length && <option value=\"NA\">N/A</option>}\n </select>\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${fieldname}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => (this.showingProperties = false)}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={\"Dropdowns are used to capture a recipient's selection of one of several options.\"}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-field-initial {\n font-family: $verdocs-primary-font;\n width: 83px;\n height: 36px;\n display: block;\n font-size: 11px;\n position: relative;\n letter-spacing: 0.3px;\n scroll-margin: 20px 0;\n background-color: transparent;\n transform-origin: bottom left;\n border: 1px solid rgba(0, 0, 0, 0.2);\n\n label {\n top: -14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n &.done {\n border: none;\n opacity: 1;\n }\n\n img {\n display: block;\n max-width: 100%;\n max-height: 100%;\n }\n\n &.disabled img {\n opacity: 0.5;\n }\n\n button {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n box-sizing: border-box;\n border: none;\n color: rgba(0, 0, 0, 0.87);\n font-weight: 500;\n transform-origin: 0 0;\n height: 100%;\n width: 100%;\n background: none;\n font-size: 11px;\n\n &.hide {\n display: none;\n }\n }\n\n &.required {\n border: 1px solid $verdocs-red-1;\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n verdocs-button-panel {\n top: -3px;\n left: -2px;\n opacity: 0.5;\n z-index: 1000;\n cursor: pointer;\n position: absolute;\n transform: scale(0.6);\n\n &[data-active],\n &:hover {\n opacity: 1;\n }\n\n .icon {\n svg {\n fill: #333333;\n }\n\n &:hover {\n svg {\n fill: #000000;\n }\n }\n }\n }\n\n .settings-icon {\n position: absolute;\n top: -3px;\n left: -20px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import {ITemplateField, getRGBA, IEnvelopeField} from '@verdocs/js-sdk';\nimport {Component, Event, EventEmitter, h, Host, Method, Prop, Fragment, State} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\n/**\n * Displays an initial field. If an initial already exists, it will be displayed and the field\n * will be disabled. Otherwise, a placeholder button will be shown. Clicking the button will\n * show a dialog to adopt an initial.\n *\n * NOTE: When initial fields are completed they will be filled with an initial \"stamp\".\n * This requires operation against a live, valid envelope. If you are testing this component\n * in Storybook, it will not be visible here.\n */\n@Component({\n tag: 'verdocs-field-initial',\n styleUrl: 'verdocs-field-initial.scss',\n shadow: false,\n})\nexport class VerdocsFieldInitial {\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * The document or template field to display.\n */\n @Prop({reflect: true}) initials: string = '';\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n /**\n * Event emitted when an initial block is adopted by the user. The event detail will contain the base64 string of the initial image.\n */\n @Event({composed: true}) adopt: EventEmitter<string>;\n\n /**\n * Event fired when the step is cancelled. This is called exit to avoid conflicts with the JS-reserved \"cancel\" event name.\n */\n @Event({composed: true}) exit: EventEmitter;\n\n /**\n * Event fired when the input field value changes. Note that this will only be fired on blur, tab-out, ENTER key press, etc.\n * It is generally the best event to subscribe to than `input` for most cases EXCEPT autocomplete fields that need to see every\n * keypress.\n */\n @Event({composed: true}) fieldChange: EventEmitter<string>;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired on every character entered into / deleted from the field.\n */\n @Event({composed: true}) settingsPress: EventEmitter;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() showingProperties?: boolean = false;\n @State() focused?: boolean = false;\n\n @Method() async focusField() {\n this.handleShow();\n }\n\n @State()\n tempInitials: string = '';\n\n private dialog?: any;\n\n hideDialog() {\n this.dialog?.remove();\n this.dialog = null;\n this.focused = false;\n }\n\n handleAdopt(e: any) {\n console.log('[INITIAL] Adopted initials');\n this.tempInitials = e.detail;\n this.fieldChange?.emit(this.tempInitials);\n this.hideDialog();\n }\n\n handleShow() {\n this.dialog = document.createElement('verdocs-initial-dialog');\n this.dialog.setAttribute('initials', this.initials);\n // this.dialog.setAttribute('roleindex', this.roleindex);\n this.dialog.addEventListener('exit', () => this.hideDialog());\n this.dialog.addEventListener('next', (e: any) => this.handleAdopt(e));\n document.body.append(this.dialog);\n this.focused = true;\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n }\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n const {required = false, value = '', label = '', settings = {}} = field || {};\n const backgroundColor = getRGBA(index);\n const {base64} = settings;\n\n if (done) {\n return <Host class={{done}}>{value && <img src={value} alt=\"Initial\" />}</Host>;\n }\n\n return (\n <Host class={{required, disabled, done, focused}} style={{backgroundColor}}>\n {label && <label>{label}</label>}\n\n {base64 ? <img src={base64} alt=\"Initial\" /> : <button onClick={() => !disabled && this.handleShow()}>Initial</button>}\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${fieldname}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => (this.showingProperties = false)}\n onDelete={() => {\n this.deleted?.emit({fieldName: field.name});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={\"initial fields capture the recipient's initials on a clause or page.\"}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\n// See https://www.sliderrevolution.com/resources/styling-radio-buttons/\nverdocs-field-radio {\n font-family: $verdocs-primary-font;\n width: 14px;\n height: 14px;\n display: block;\n font-size: 11px;\n position: relative;\n scroll-margin: 20px 0;\n background-color: transparent;\n transform-origin: bottom left;\n border-radius: 100%;\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n svg {\n margin-top: 4px;\n }\n\n &.disabled.done {\n opacity: 1;\n }\n\n // To avoid conflicting with the use of a label for the checkbox itself\n div.label {\n top: -14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n div.group {\n top: 14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #bb0589;\n border-bottom-left-radius: 2px;\n border-bottom-right-radius: 2px;\n }\n\n input {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n }\n\n &.disabled input {\n opacity: 0.5;\n }\n\n &.done input[type='radio'] {\n margin: 0;\n padding: 0;\n width: 10px;\n height: 10px;\n }\n\n &:not(.done) input[type='radio'] {\n position: absolute;\n opacity: 0;\n\n + label {\n &:before {\n content: '';\n //background: $verdocs-grey-3;\n border-radius: 100%;\n border: 1px solid rgba(0, 0, 0, 0.6);\n display: inline-block;\n width: 12px;\n height: 12px;\n position: absolute;\n left: 0;\n top: 0;\n cursor: pointer;\n text-align: center;\n transition: all 250ms ease;\n }\n }\n\n &:checked {\n + label {\n &:before {\n background-color: $verdocs-green;\n box-shadow: inset 0 0 0 2px $verdocs-grey-3;\n }\n }\n }\n\n &:focus {\n + label {\n &:before {\n outline: none;\n border-color: $verdocs-green;\n }\n }\n }\n\n &:disabled {\n + label {\n &:before {\n box-shadow: inset 0 0 0 4px $verdocs-grey-3;\n border-color: darken($verdocs-grey-3, 25%);\n background: darken($verdocs-grey-3, 25%);\n }\n }\n }\n\n + label {\n &:empty {\n &:before {\n margin-right: 0;\n }\n }\n }\n }\n\n &.required {\n border: 1px solid $verdocs-red-1;\n }\n\n &.hide {\n display: none;\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n verdocs-button-panel {\n margin-left: -20px;\n margin-top: -7px;\n transform: scale(0.7);\n }\n\n .settings-icon {\n position: absolute;\n top: -6px;\n left: -20px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import {ITemplateField, getRGBA, IEnvelopeField} from '@verdocs/js-sdk';\nimport {Component, Event, EventEmitter, h, Host, Method, Prop, Fragment, State} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\nconst RadioIconUnselected = `<svg focusable=\"false\" aria-hidden=\"true\" viewBox=\"0 0 24 24\"><path d=\"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z\"></path></svg>`;\n\nconst RadioIconSelected = `<svg focusable=\"false\" aria-hidden=\"true\" viewBox=\"0 0 24 24\"><path d=\"M12 7c-2.76 0-5 2.24-5 5s2.24 5 5 5 5-2.24 5-5-2.24-5-5-5zm0-5C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z\"></path></svg>`;\n\n/**\n * Displays a radio button.\n */\n@Component({\n tag: 'verdocs-field-radio',\n styleUrl: 'verdocs-field-radio.scss',\n shadow: false,\n})\nexport class VerdocsFieldRadio {\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, overrides the field's settings object. Primarily used in Storybook mode.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, overrides the field's required object. Primarily used in Storybook mode.\n */\n @Prop({reflect: true}) required?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n @State() showingProperties?: boolean = false;\n @State() focused = false;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @Method()\n async focusField() {\n // Our input field is fake, so we fake the flash too\n this.focused = true;\n setTimeout(() => {\n this.focused = false;\n }, 500);\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n }\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n const {name, required = false, label = '', group = '', value = false} = field || {};\n const backgroundColor = getRGBA(index);\n\n const selected = value === 'true';\n\n if (done) {\n return (\n <Host class={{done}} style={{maxWidth: '10px'}}>\n <span innerHTML={selected ? RadioIconSelected : RadioIconUnselected} />\n </Host>\n );\n }\n\n return (\n <Host class={{required: this.required || required, disabled, done, focused}} style={{backgroundColor}}>\n {label && <div class=\"label\">{label}</div>}\n {editable && group && <div class=\"group\">{group}</div>}\n\n <input id={fieldname} type=\"radio\" name={group || fieldname} value={name} checked={!!selected} disabled={disabled} required={required} />\n <label htmlFor={fieldname} />\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${fieldname}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => (this.showingProperties = false)}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={\"Radio buttons capture the recipient's selection of just one of several related (exclusive) options.\"}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-field-signature {\n font-family: $verdocs-primary-font;\n width: 83px;\n height: 36px;\n display: block;\n font-size: 11px;\n position: relative;\n scroll-margin: 20px 0;\n letter-spacing: 0.3px;\n background-color: transparent;\n transform-origin: bottom left;\n border: 1px solid rgba(0, 0, 0, 0.2);\n\n label {\n top: -14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n &.done {\n border: none;\n opacity: 1;\n }\n\n img {\n display: block;\n max-width: 100%;\n max-height: 100%;\n }\n\n &.disabled img {\n opacity: 0.5;\n }\n\n button {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n box-sizing: border-box;\n border: none;\n color: rgba(0, 0, 0, 0.87);\n font-weight: 500;\n transform-origin: 0 0;\n height: 100%;\n width: 100%;\n background: none;\n font-size: 11px;\n\n &.hide {\n display: none;\n }\n }\n\n &.required {\n border: 1px solid rgb(204, 0, 0);\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n verdocs-button-panel {\n top: -3px;\n left: -2px;\n opacity: 0.5;\n z-index: 1000;\n cursor: pointer;\n position: absolute;\n transform: scale(0.6);\n\n &[data-active],\n &:hover {\n opacity: 1;\n }\n\n .icon {\n svg {\n fill: #333333;\n }\n\n &:hover {\n svg {\n fill: #000000;\n }\n }\n }\n }\n\n .settings-icon {\n position: absolute;\n top: -3px;\n left: -20px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import {ITemplateField, getRGBA, IEnvelopeField} from '@verdocs/js-sdk';\nimport {Component, h, Host, Prop, Event, EventEmitter, Method, Fragment, State} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\n/**\n * Displays a signature field. If a signature already exists, it will be displayed and the field\n * will be disabled. Otherwise, a placeholder button will be shown. Clicking the button will\n * show a dialog to adopt a signature.\n *\n * NOTE: When signature fields are completed they will be filled with a signature \"stamp\".\n * This requires operation against a live, valid envelope. If you are testing this component\n * in Storybook, it will not be visible here.\n */\n@Component({\n tag: 'verdocs-field-signature',\n styleUrl: 'verdocs-field-signature.scss',\n shadow: false,\n})\nexport class VerdocsFieldSignature {\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, the signature creation dialog will be initialized with this text.\n */\n @Prop({reflect: true}) name?: string = '';\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n /**\n * Event emitted when the field has changed.\n */\n @Event({composed: true}) fieldChange: EventEmitter<string>;\n\n /**\n * Event fired on every character entered into / deleted from the field.\n */\n @Event({composed: true}) settingsPress: EventEmitter;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() showingProperties?: boolean = false;\n @State() focused?: boolean = false;\n\n @Method() async focusField() {\n this.handleShow();\n }\n\n @State()\n tempSignature: string = '';\n\n private dialog?: any;\n\n hideDialog() {\n this.dialog?.remove();\n this.dialog = null;\n this.focused = false;\n }\n\n handleAdopt(e: any) {\n console.log('[SIGNATURE] Adopted signature');\n this.tempSignature = e.detail;\n this.fieldChange?.emit(this.tempSignature);\n this.hideDialog();\n }\n\n handleShow() {\n this.dialog = document.createElement('verdocs-signature-dialog');\n this.dialog.setAttribute('name', this.name);\n // this.dialog.setAttribute('roleindex', this.roleindex);\n this.dialog.addEventListener('exit', () => this.hideDialog());\n this.dialog.addEventListener('next', (e: any) => this.handleAdopt(e));\n document.body.append(this.dialog);\n this.focused = true;\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n this.showingProperties = false;\n }\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n const {required = false, value = '', label = '', settings = {}} = field || {};\n const {base64} = settings;\n const backgroundColor = getRGBA(index);\n\n if (done) {\n return <Host class={{done}}>{value && <img src={base64} alt=\"\" />}</Host>;\n }\n\n return (\n <Host class={{required, disabled, done, focused}} style={{backgroundColor}}>\n {label && <label>{label}</label>}\n\n {base64 ? <img src={base64} alt=\"\" /> : <button onClick={() => !disabled && this.handleShow()}>Signature</button>}\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${fieldname}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => this.hideSettingsPanel()}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={\"Signature fields capture a recipient's signature on a document.\"}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-field-textarea {\n width: 150px;\n height: 15px;\n display: block;\n font-size: 11px;\n position: relative;\n scroll-margin: 20px 0;\n box-sizing: border-box;\n background-color: transparent;\n transform-origin: bottom left;\n font-family: $verdocs-primary-font;\n border: 1px solid rgba(0, 0, 0, 0.2);\n\n textarea {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n width: 100%;\n height: 100%;\n resize: none;\n border: none;\n outline: none;\n padding: 0 3px;\n font-size: 11px;\n background: none;\n font-weight: 500;\n transform-origin: 0 0;\n box-sizing: border-box;\n color: rgba(0, 0, 0, 0.87);\n\n &.hide {\n display: none;\n }\n }\n\n &.disabled textarea {\n opacity: 0.5;\n }\n\n label {\n top: -14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n &.required {\n border: 1px solid rgb(204, 0, 0);\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n verdocs-button-panel {\n top: -3px;\n left: -2px;\n opacity: 0.5;\n z-index: 1000;\n cursor: pointer;\n position: absolute;\n transform: scale(0.6);\n\n &[data-active],\n &:hover {\n opacity: 1;\n }\n\n .icon {\n svg {\n fill: #333333;\n }\n\n &:hover {\n svg {\n fill: #000000;\n }\n }\n }\n }\n\n .settings-icon {\n position: absolute;\n top: -3px;\n left: -20px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import interact from 'interactjs';\nimport {IEnvelopeField, VerdocsEndpoint} from '@verdocs/js-sdk';\nimport {ITemplateField, updateField, getRGBA} from '@verdocs/js-sdk';\nimport {Component, h, Host, Prop, Method, Event, EventEmitter, Element, Fragment, State} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\n/**\n * Display a multi-line text input field. Reminder: the \"position\" of the field is specified\n * as the BOTTOM-LEFT corner.\n */\n@Component({\n tag: 'verdocs-field-textarea',\n styleUrl: 'verdocs-field-textarea.scss',\n shadow: false,\n})\nexport class VerdocsFieldTextarea {\n @Element() el: HTMLElement;\n private inputEl: HTMLTextAreaElement;\n\n /**\n * The endpoint to use to communicate with Verdocs. If not set, the default endpoint will be used.\n * This component self-manages its resize (width) behavior when in edit-template mode, and uses\n * this endpoint to save changes.\n */\n @Prop() endpoint: VerdocsEndpoint = VerdocsEndpoint.getDefault();\n\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n @Method()\n async focusField() {\n this.inputEl.focus();\n }\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() showingProperties?: boolean = false;\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n }\n\n @State() focused?: boolean = false;\n\n componentDidRender() {\n interact.dynamicDrop(true);\n\n if (this.editable) {\n interact(this.el).resizable({\n edges: {top: true, bottom: true, left: true, right: true},\n listeners: {\n start: this.handleResizeStart.bind(this),\n move: this.handleResize.bind(this),\n end: this.handleResizeEnd.bind(this),\n },\n });\n }\n }\n\n handleResizeStart(e: any) {\n e.preventDefault();\n e.stopPropagation();\n }\n\n handleResize(e: any) {\n let {x = 0, y = 0, h = 0} = e.target.dataset;\n let {width, height} = e.rect;\n\n x = (parseFloat(x) || 0) + e.deltaRect.left;\n y = (parseFloat(y) || 0) + e.deltaRect.top;\n h = (parseFloat(h) || 0) + e.deltaRect.height;\n\n Object.assign(e.target.style, {\n width: `${width}px`,\n height: `${height}px`,\n transform: `translate(${x}px, ${y + h}px)`,\n });\n\n Object.assign(e.target.dataset, {x, y, h});\n }\n\n handleResizeEnd(e: any) {\n const {source, sourceid, fieldname} = this;\n const {field} = Store.getField(source, sourceid, fieldname, this.field);\n if (!field) {\n return;\n }\n\n const [translateX, translateY] = e.target.style.transform.split('(')[1].split(')')[0].split(',').map(parseFloat);\n\n const width = Math.round(parseFloat(e.target.style.width) / this.xscale);\n const height = Math.round(parseFloat(e.target.style.height) / this.yscale);\n const x = Math.round(field.x + translateX / this.xscale);\n const y = Math.round(field.y - translateY / this.yscale);\n\n updateField(this.endpoint, this.sourceid, this.fieldname, {x, y, width, height})\n .then(field => {\n this.settingsChanged?.emit({fieldName: this.fieldname, field});\n Object.assign(e.target.dataset, {x: 0, y: 0, h: 0});\n })\n .catch(e => console.log('Field update failed', e));\n }\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n const {required = false, placeholder = '', value = '', label = ''} = field || {};\n const backgroundColor = getRGBA(index);\n\n if (done) {\n return <Host class={{done}}>{value}</Host>;\n }\n\n return (\n <Host class={{required, disabled, done, focused}} style={{backgroundColor}}>\n {label && <label>{label}</label>}\n\n <textarea\n name={fieldname}\n disabled={disabled}\n required={required}\n placeholder={placeholder}\n ref={el => (this.inputEl = el)}\n onFocus={() => (this.focused = true)}\n onBlur={() => (this.focused = false)}\n >\n {value}\n </textarea>\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${fieldname}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => (this.showingProperties = false)}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={'Text areas may be used to create multi-line text fields.'}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-field-textbox {\n font-family: $verdocs-primary-font;\n box-sizing: border-box;\n width: 150px;\n height: 15px;\n display: block;\n font-size: 11px;\n position: relative;\n scroll-margin: 20px 0;\n letter-spacing: -0.2px;\n background-color: transparent;\n transform-origin: bottom left;\n border: 1px solid rgba(0, 0, 0, 0.2);\n\n .edge-top,\n .edge-right,\n .edge-left,\n .edge-bottom {\n position: absolute;\n z-index: 10;\n }\n\n .edge-top {\n top: -2px;\n left: 0;\n right: 0;\n height: 5px;\n }\n\n .edge-right {\n top: 0;\n bottom: 0;\n right: -2px;\n width: 5px;\n }\n\n .edge-left {\n top: 0;\n left: -2px;\n bottom: 0;\n width: 5px;\n }\n\n .edge-bottom {\n bottom: -2px;\n left: 0;\n right: 0;\n height: 5px;\n }\n\n input {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n width: 100%;\n height: 100%;\n border: none;\n outline: none;\n padding: 0 3px;\n font-size: 11px;\n background: none;\n font-weight: 500;\n position: absolute;\n transform-origin: 0 0;\n box-sizing: border-box;\n color: rgba(0, 0, 0, 0.87);\n\n &.hide {\n display: none;\n }\n }\n\n &.disabled input {\n opacity: 0.5;\n }\n\n textarea {\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n width: 100%;\n height: 100%;\n resize: none;\n border: none;\n outline: none;\n padding: 0 3px;\n font-size: 11px;\n background: none;\n font-weight: 500;\n transform-origin: 0 0;\n box-sizing: border-box;\n color: rgba(0, 0, 0, 0.87);\n\n &.hide {\n display: none;\n }\n }\n\n &.disabled textarea {\n opacity: 0.5;\n }\n\n label {\n top: -14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n &.required {\n border: 1px solid rgb(204, 0, 0);\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n verdocs-button-panel {\n top: -3px;\n left: -2px;\n opacity: 0.5;\n z-index: 1000;\n cursor: pointer;\n position: absolute;\n transform: scale(0.6);\n\n &[data-active],\n &:hover {\n opacity: 1;\n }\n\n .icon {\n svg {\n fill: #333333;\n }\n\n &:hover {\n svg {\n fill: #000000;\n }\n }\n }\n }\n\n // @see https://community.logmein.com/t5/LastPass-Support-Discussions/placeholder-text-overrides-data-lpignore-quot-true-quot/td-p/295135\n // LastPass is ignoring the data-lpignore attribute in some cases\n [data-lastpass-icon-root] {\n display: none !important;\n }\n\n .settings-icon {\n position: absolute;\n top: -4px;\n left: -18px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n\n@keyframes verdocs-field-pulse {\n 0% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n 50% {\n background-color: rgba(0, 0, 0, 0);\n }\n 100% {\n background-color: rgba(0, 0, 0, 0.35);\n }\n}\n","import interact from 'interactjs';\nimport {getRGBA, IEnvelopeField, ITemplateField, updateField, VerdocsEndpoint} from '@verdocs/js-sdk';\nimport {Component, h, Host, Element, Prop, Method, Event, EventEmitter, Fragment, State} from '@stencil/core';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\n/**\n * Display a simple 1-line text input field.\n */\n@Component({\n tag: 'verdocs-field-textbox',\n styleUrl: 'verdocs-field-textbox.scss',\n shadow: false,\n})\nexport class VerdocsFieldTextbox {\n @Element() el: HTMLElement;\n private inputEl: HTMLInputElement | HTMLTextAreaElement;\n\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) multiline?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop({reflect: true}) pagenumber?: number = 1;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() showingProperties?: boolean = false;\n @State() focused?: boolean = false;\n\n @Method()\n async focusField() {\n this.inputEl.focus();\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n this.showingProperties = false;\n }\n\n componentDidRender() {\n interact.dynamicDrop(true);\n\n if (this.editable) {\n interact(this.el).resizable({\n edges: {\n top: '.edge-top',\n left: '.edge-left',\n bottom: '.edge-bottom',\n right: '.edge-right',\n },\n modifiers: [\n interact.modifiers.restrictSize({\n min: {width: 30, height: 15},\n }),\n ],\n listeners: {\n start: this.handleResizeStart.bind(this),\n move: this.handleResize.bind(this),\n end: this.handleResizeEnd.bind(this),\n },\n });\n }\n }\n\n handleResizeStart(e: any) {\n e.preventDefault();\n e.stopPropagation();\n }\n\n handleResize(e: any) {\n let {width, height} = e.rect;\n\n const dX = e.deltaRect.left;\n const dY = e.deltaRect.bottom;\n const currentLeft = parseFloat(e.target.style.left);\n const currentBottom = parseFloat(e.target.style.bottom);\n\n width /= this.xscale;\n height /= this.yscale;\n\n Object.assign(e.target.style, {\n width: `${width}px`,\n height: `${height}px`,\n left: `${currentLeft + dX}px`,\n bottom: `${currentBottom - dY}px`,\n });\n }\n\n handleResizeEnd(e: any) {\n const {sourceid, fieldname} = this;\n\n const width = Math.round(parseFloat(e.target.style.width));\n let height = Math.round(parseFloat(e.target.style.height));\n\n if (height < 20) {\n height = 15;\n }\n const multiline = height > 15;\n\n updateField(VerdocsEndpoint.getDefault(), sourceid, fieldname, {width, height, multiline})\n .then(async updatedField => {\n const template = await Store.getTemplate(VerdocsEndpoint.getDefault(), this.sourceid);\n const newTemplate = JSON.parse(JSON.stringify(template));\n const fieldIndex = newTemplate.fields.findIndex(field => field.name === fieldname);\n if (fieldIndex > -1) {\n newTemplate.fields[fieldIndex] = updatedField;\n }\n Store.updateTemplate(this.sourceid, newTemplate);\n\n this.settingsChanged?.emit({fieldName: fieldname, field: updatedField});\n Object.assign(e.target.dataset, {x: 0, y: 0, h: 0});\n })\n .catch(e => console.log('Field update failed', e));\n }\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, focused, xscale = 1, yscale = 1} = this;\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n let {required = false, placeholder = '', label = '', width = 150, default: value = '', multiline = false} = field || {};\n const backgroundColor = getRGBA(index);\n\n // TODO: Consolidate value/defaultValue handling between template and envelope fields.\n if ((field as any)?.value) {\n value = (field as any)?.value;\n }\n\n // TODO: This is an outdated technique from the old system. We should compute it.\n const maxlength = width / 5;\n\n if (done) {\n return <Host class={{done}}>{value}</Host>;\n }\n\n return (\n <Host class={{required, disabled, done, focused}} style={{backgroundColor}}>\n {editable && <div class=\"edge-top\" />}\n {editable && <div class=\"edge-right\" />}\n {editable && <div class=\"edge-left\" />}\n {editable && <div class=\"edge-bottom\" />}\n\n {label && <label>{label}</label>}\n\n {multiline ? (\n <textarea\n name={fieldname}\n disabled={disabled}\n required={required}\n placeholder={placeholder}\n ref={el => (this.inputEl = el)}\n onFocus={() => (this.focused = true)}\n onBlur={() => (this.focused = false)}\n >\n {value}\n </textarea>\n ) : (\n <input\n type=\"text\"\n name={fieldname}\n value={value}\n disabled={disabled}\n required={required}\n placeholder={placeholder}\n maxlength={maxlength}\n ref={el => (this.inputEl = el)}\n onFocus={() => (this.focused = true)}\n onBlur={() => (this.focused = false)}\n />\n )}\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${fieldname}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => this.hideSettingsPanel()}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={\n 'Text boxes may be used to capture simple text input. Participant-entered values will be stored for later retrieval via the \"name\" field.<br /><br />If marked required, the participant must complete the field before proceeding.'\n }\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-field-timestamp {\n width: 160px;\n height: 15px;\n display: block;\n font-size: 9px;\n position: relative;\n scroll-margin: 20px 0;\n background-color: transparent;\n transform-origin: bottom left;\n font-family: $verdocs-primary-font;\n\n &.done {\n opacity: 1;\n }\n\n input {\n position: absolute;\n\n // This is needed to bring down the cursor from the parent element, which is where interactjs applies it\n cursor: inherit;\n\n opacity: 0.5;\n width: 100%;\n height: 100%;\n font-size: 9px;\n background: none;\n font-weight: 500;\n transform-origin: 0 0;\n box-sizing: border-box;\n color: rgba(0, 0, 0, 0.87);\n border: 1px solid rgba(0, 0, 0, 0.2);\n\n &.hide {\n display: none;\n }\n }\n\n label {\n top: -14px;\n left: -1px;\n height: 14px;\n color: white;\n padding: 0 4px;\n font-size: 9px;\n line-height: 13px;\n position: absolute;\n background: #4a4a99;\n border-top-left-radius: 2px;\n border-top-right-radius: 2px;\n }\n\n &.required {\n border: 1px solid rgb(204, 0, 0);\n }\n\n &.focused {\n animation: verdocs-field-pulse 0.4s 1;\n }\n\n verdocs-button-panel {\n top: -3px;\n left: -2px;\n opacity: 0.5;\n z-index: 1000;\n cursor: pointer;\n position: absolute;\n transform: scale(0.6);\n\n &[data-active],\n &:hover {\n opacity: 1;\n }\n\n .icon {\n svg {\n fill: #333333;\n }\n\n &:hover {\n svg {\n fill: #000000;\n }\n }\n }\n }\n\n .settings-icon {\n position: absolute;\n top: -3px;\n left: -20px;\n display: inline-block;\n cursor: pointer;\n opacity: 0.3;\n\n svg {\n fill: $border-color;\n }\n\n &:hover {\n opacity: 1;\n }\n }\n}\n","import {format} from 'date-fns/format';\nimport {ITemplateField, getRGBA, IEnvelopeField} from '@verdocs/js-sdk';\nimport {Component, h, Host, Prop, Method, Event, EventEmitter, Fragment, State} from '@stencil/core';\nimport {FORMAT_TIMESTAMP} from '../../../utils/Types';\nimport {SettingsIcon} from '../../../utils/Icons';\nimport {Store} from '../../../utils/Datastore';\n\n/**\n * Display a timestamp. Timestamps are not editable by signers. Instead, they are automatically\n * filled when the signer submits the document.\n */\n@Component({\n tag: 'verdocs-field-timestamp',\n styleUrl: 'verdocs-field-timestamp.scss',\n shadow: false,\n})\nexport class VerdocsFieldTimestamp {\n private el: HTMLInputElement;\n\n /**\n * Fields may be attached to templates or envelopes, but only template fields may be edited.\n */\n @Prop({reflect: true}) source: 'template' | 'envelope' = 'template';\n\n /**\n * The source template or envelope ID the field is found in.\n */\n @Prop({reflect: true}) sourceid: string = '';\n\n /**\n * The name of the field to display.\n */\n @Prop({reflect: true}) fieldname: string = '';\n\n /**\n * Override the field's settings. This is intended to be used during signing when fields are being\n * mutated.\n */\n @Prop() field: IEnvelopeField | null | undefined = null;\n\n /**\n * If set, overrides the field's settings object. Primarily used to support \"preview\" modes where all fields are disabled.\n */\n @Prop({reflect: true}) disabled?: boolean = false;\n\n /**\n * If set, a settings icon will be displayed on hover. The settings shown allow the field's recipient and other settings to be\n * changed, so it should typically only be enabled in the Builder.\n */\n @Prop({reflect: true}) editable?: boolean = false;\n\n /**\n * If set, the field may be dragged to a new location. This should only be enabled in the Builder, or for self-placed fields.\n */\n @Prop({reflect: true}) moveable?: boolean = false;\n\n /**\n * If set, the field is considered \"done\" and is drawn in a display-final-value state.\n */\n @Prop({reflect: true}) done?: boolean = false;\n\n /**\n * If set, the field will be be scaled horizontally by this factor.\n */\n @Prop({reflect: true}) xscale?: number = 1;\n\n /**\n * If set, the field will be be scaled vertically by this factor.\n */\n @Prop({reflect: true}) yscale?: number = 1;\n\n /**\n * The page the field is on\n */\n @Prop() pagenumber?: number = 1;\n\n /**\n * Event fired when the field's settings are changed.\n */\n @Event({composed: true}) settingsChanged: EventEmitter<{fieldName: string; field: ITemplateField}>;\n\n /**\n * Event fired when the field is deleted.\n */\n @Event({composed: true}) deleted: EventEmitter<{fieldName: string}>;\n\n @State() showingProperties?: boolean = false;\n\n @Method() async focusField() {\n this.el.focus();\n }\n\n @Method()\n async showSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.showPanel) {\n settingsPanel.showPanel();\n }\n }\n\n @Method()\n async hideSettingsPanel() {\n const settingsPanel = document.getElementById(`verdocs-settings-panel-${this.fieldname}`) as any;\n if (settingsPanel && settingsPanel.hidePanel) {\n settingsPanel.hidePanel();\n }\n this.showingProperties = false;\n }\n\n render() {\n const {source, sourceid, fieldname, editable = false, done = false, disabled = false, xscale = 1, yscale = 1} = this;\n\n const {index, field} = Store.getField(source, sourceid, fieldname, this.field);\n const {required = false, placeholder = '', value = '', label = ''} = field || {};\n const backgroundColor = getRGBA(index);\n\n const formatted = format(new Date(value || new Date().toISOString()), FORMAT_TIMESTAMP);\n\n if (done) {\n return <Host class={{done}}>{formatted}</Host>;\n }\n\n return (\n <Host class={{required, disabled, done}} style={{backgroundColor}}>\n {label && <label>{label}</label>}\n <input type=\"text\" placeholder={placeholder} value={formatted} disabled={true} ref={el => (this.el = el)} />\n\n {editable && (\n <Fragment>\n <div\n id={`verdocs-settings-panel-trigger-${fieldname}`}\n style={{transform: `scale(${Math.floor((1 / xscale) * 1000) / 1000}, ${Math.floor((1 / yscale) * 1000) / 1000})`}}\n class=\"settings-icon\"\n innerHTML={SettingsIcon}\n onClick={(e: any) => {\n e.stopPropagation();\n this.showingProperties = !this.showingProperties;\n }}\n />\n\n {this.showingProperties && (\n <verdocs-portal anchor={`verdocs-settings-panel-trigger-${fieldname}`} onClickAway={() => (this.showingProperties = false)}>\n <verdocs-template-field-properties\n templateId={sourceid}\n fieldName={fieldname}\n onClose={() => this.hideSettingsPanel()}\n onDelete={() => {\n this.deleted?.emit({fieldName: fieldname});\n return this.hideSettingsPanel();\n }}\n onSettingsChanged={e => {\n this.settingsChanged?.emit(e.detail);\n return this.hideSettingsPanel();\n }}\n helpText={'Time stamps are automatically set when the recipient signs the document.'}\n />\n </verdocs-portal>\n )}\n </Fragment>\n )}\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-initial-dialog {\n font-family: $primary-font;\n box-sizing: border-box;\n position: fixed;\n z-index: 10000;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n display: flex;\n align-items: center;\n justify-content: center;\n background: #0000007f;\n\n .dialog {\n width: 100%;\n max-width: 340px;\n border-radius: 4px;\n overflow: hidden;\n box-shadow: 3px 3px 5px 1px rgba(40, 40, 40, 0.4);\n background: $dialog-bg;\n }\n\n .heading {\n display: flex;\n flex-direction: row;\n padding: 20px 20px 0 20px;\n line-height: 28px;\n font-size: 20px;\n font-weight: 500;\n }\n\n .content {\n font-size: 14px;\n padding: 20px;\n }\n\n .buttons {\n display: flex;\n margin: 20px 0 0 0;\n flex-direction: row;\n justify-content: flex-end;\n align-items: center;\n\n verdocs-button {\n margin-left: 16px;\n }\n }\n\n canvas {\n background: #fff;\n box-sizing: border-box;\n margin: 0 auto;\n width: 300px;\n // TODO: The original app had an aspect ratio of (80 / 305) * (signatureBodyWidth - 20)\n height: 79px;\n max-width: 100%;\n box-shadow: 0 0 6px 0 #0000001f;\n }\n\n .disclaimer {\n text-align: justify;\n padding: 8px 0;\n font-size: 11px;\n line-height: 14px;\n color: rgba(0, 0, 0, 0.54);\n }\n\n .as-shown {\n font-size: 11px;\n margin: 4px 0 20px 4px;\n color: rgba(0, 0, 0, 0.54);\n }\n\n .tabs {\n display: flex;\n flex-direction: row;\n\n .tab {\n padding: 8px 15px;\n cursor: pointer;\n\n &.active {\n border-bottom: 2px solid $light-border-color;\n }\n\n &:hover {\n color: $primary-color;\n }\n }\n }\n}\n","import {Component, Prop, Host, h, Event, EventEmitter, State} from '@stencil/core';\n\n/**\n * Display a dialog that allows the user to specify an initials image, either by using a signature-font-generated image\n * based on their full name, or by hand-drawing their initials with a mouse or tablet.\n */\n@Component({\n tag: 'verdocs-initial-dialog',\n styleUrl: 'verdocs-initial-dialog.scss',\n})\nexport class VerdocsInitialDialog {\n private canvasElement?: HTMLCanvasElement;\n\n /**\n * Initial signature text\n */\n @Prop() initials: string = '';\n\n /**\n * Event fired when the initials are adopted.\n */\n @Event({composed: true}) next: EventEmitter<string>;\n\n /**\n * Event fired when the step is cancelled. This is called exit to avoid conflicts with the JS-reserved \"cancel\" event name.\n */\n @Event({composed: true}) exit: EventEmitter;\n\n @State() fontLoaded = false;\n\n @State() enteredInitials: string = '';\n\n @State() mode: string = 'type';\n\n componentWillLoad() {\n this.enteredInitials = this.initials.toUpperCase();\n\n const ds = new FontFace('Dancing Script', 'url(https://fonts.gstatic.com/s/dancingscript/v19/If2cXTr6YS-zF4S-kcSWSVi_sxjsohD9F50Ruu7BMSo3Sup6hNX6plRP.woff)');\n ds.load().then(font => {\n document.fonts.add(font);\n this.fontLoaded = true;\n });\n }\n\n componentDidLoad() {\n this.redrawSignature();\n }\n\n componentDidUpdate() {\n this.redrawSignature();\n }\n\n redrawSignature() {\n console.log('redrawing sig');\n if (!this.canvasElement) {\n console.log('no canvas');\n return;\n }\n\n const canvasWidth = this.canvasElement.width;\n console.log('cw', canvasWidth);\n\n const context = this.canvasElement.getContext('2d');\n context.clearRect(0, 0, this.canvasElement.width, this.canvasElement.height);\n\n let fontSize = 100;\n do {\n fontSize -= 2;\n context.font = `${fontSize}px Dancing Script`;\n } while (context.measureText(this.enteredInitials).width > canvasWidth - 32); // 32px padding each side\n\n context.textAlign = 'center';\n context.textBaseline = 'middle';\n context.font = `${fontSize}px Dancing Script`;\n context.fillText(this.enteredInitials, this.canvasElement.width / 2, this.canvasElement.height / 2);\n }\n\n handleNameChange(e: any) {\n this.enteredInitials = e.target.value;\n }\n\n handleCancel(e: any) {\n e.stopPropagation();\n e.preventDefault();\n this.exit.emit();\n }\n\n handleAdopt(e: any) {\n e.stopPropagation();\n e.preventDefault();\n const data = this.canvasElement.toDataURL('image/png');\n this.next.emit(data);\n }\n\n /*\n selColor(hex: string) {\n this.color = hex;\n this.animateDraw();\n }\n\n stopDraw() {\n this.paint = false;\n this.adoptedAndSigned = !this.hasSignature();\n }\n\n draw(e) {\n this.paint = true;\n this.addPoints(e, false);\n this.animateDraw();\n }\n\n recordPoints(e) {\n if (this.paint) {\n this.addPoints(e, true);\n this.animateDraw();\n }\n }\n\n animateDraw() {\n this.canvas.clearRect(0, 0, this.canvas.canvas.offsetWidth, this.canvas.canvas.offsetHeight);\n\n this.canvas.strokeStyle = this.color || '#000000';\n this.canvas.lineJoin = 'round';\n this.canvas.lineWidth = 3;\n\n for (let i = 0; i < this.points.length; i++) {\n this.canvas.beginPath();\n if (this.points[i].drag && i) {\n this.canvas.moveTo(this.points[i - 1].x, this.points[i - 1].y);\n // this.canvas.arc(this.points[i - 1].x, this.points[i - 1].y, 2, 0, 2 * Math.PI, false);\n } else {\n this.canvas.moveTo(this.points[i].x - 1, this.points[i].y);\n // this.canvas.arc(this.points[i].x, this.points[i].y, 2, 0, 2 * Math.PI, false);\n }\n\n this.canvas.lineTo(this.points[i].x, this.points[i].y);\n this.canvas.closePath();\n this.canvas.stroke();\n }\n }\n\n drawCurve(color: string, curve: number) {\n this.canvas.beginPath();\n }\n\n\n\n addPoints(e, drag: boolean) {\n if (window) {\n let x;\n let y;\n e.preventDefault();\n if (e.touches && e.touches.length > 0) {\n x = e.touches[0].clientX;\n } else {\n x = e.clientX;\n }\n\n if (e.touches && e.touches.length > 0) {\n y = e.touches[0].clientY;\n } else {\n y = e.clientY;\n }\n const rect = this.signatureCanvas.nativeElement.getBoundingClientRect();\n this.points.push({\n x: x - rect.left,\n y: y - rect.top,\n drag: drag\n });\n }\n }\n\n clearPad() {\n this.canvas.clearRect(0, 0, this.canvas.canvas.offsetWidth, this.canvas.canvas.offsetHeight);\n this.points = [];\n this.adoptedAndSigned = !this.hasSignature();\n }\n\n async adoptAndSign() {\n try {\n this.adoptedAndSigned = true;\n await this.updateFullName();\n await this.captureSignatureFromCanvas();\n const message = this.signatureMode === 'Signature' ? 'Saving Signature' : 'Saving Initial';\n this.snackbarService.open(message, 'OK', this.snackbarService.initConfig(null, 'bottom'));\n this.handleMode();\n } catch (err) {\n this.snackbarService.open('Failed to apply signature', 'OK', this.snackbarService.initConfig(null, 'bottom'));\n }\n }\n\n handleMode() {\n let currentField;\n switch (this.mode) {\n case 'signerview':\n if (this.signatureMode === 'Signature') {\n this.signatureService.postSignatureBlob().then(result => {\n if (result && result.id && result.url) {\n currentField = this.signatureService.currField;\n this.signatureService.updateSigned(currentField.fName, true);\n this.signatureService.toggleSig(false);\n this.signatureService.setSignatureId(result.id);\n this.signatureService.putSignatureField(this.envelopeId, this.fieldName, result.id).then(res => {\n this.eventTracker.createEvent({\n category: 'verdoc',\n action: 'verdoc signed',\n label: `verdoc id: ${this.envelopeId}`\n })\n if (res && res.settings) {\n this.signatureService.setSignatureData(res.settings.base64);\n this.signatureService.setSignatureId(res.settings.signature_id);\n }\n this.snackbarService.dismiss();\n this.dialog.close({ status: 'saved', temp_sig: res.settings.base64, sig_id: res.settings.signature_id });\n }).catch(err => {\n this.snackbarService.open('Failed to save signature. Please try again.', 'DISMISS', {\n duration: 3000\n });\n this.adoptedAndSigned = false;\n return err;\n });\n }\n });\n } else {\n this.signatureService.postInitialBlob().then(result => {\n if (result && result.id && result.url) {\n currentField = this.signatureService.currField;\n this.signatureService.updateInitialed(currentField.fName, true);\n this.signatureService.setInitialId(result.id);\n this.signatureService.toggleSig(false);\n this.signatureService.putInitialField(this.envelopeId, this.fieldName, result.id).then(res => {\n if (res && res.settings) {\n this.signatureService.setInitialData(res.settings.base64);\n this.signatureService.setInitialId(res.settings.initial_id);\n }\n this.snackbarService.dismiss();\n this.dialog.close({ status: 'saved', temp_int: res.settings.base64, int_id: res.settings.initial_id });\n }).catch(err => {\n this.snackbarService.open('Failed to save initial. Please try again.', 'DISMISS', {\n duration: 3000\n });\n this.adoptedAndSigned = false;\n return err;\n });\n }\n });\n }\n break;\n }\n }\n */\n\n render() {\n return (\n <Host onClick={e => this.handleCancel(e)}>\n <div class=\"dialog\">\n <div class=\"heading\">Create Your Initial</div>\n\n <div class=\"content\">\n <verdocs-text-input placeholder=\"Initials...\" label=\"Initials\" value={this.enteredInitials} onInput={e => this.handleNameChange(e)} />\n <div class=\"as-shown\">As shown on driver's license or govt. ID card.</div>\n\n {/*<div class=\"tabs\">*/}\n {/* <div class={{tab: true, active: this.mode === 'type'}} onClick={() => (this.mode = 'type')}>*/}\n {/* Type*/}\n {/* </div>*/}\n {/* <div class={{tab: true, active: this.mode === 'draw'}} onClick={() => (this.mode = 'draw')}>*/}\n {/* Draw*/}\n {/* </div>*/}\n {/*</div>*/}\n\n {this.fontLoaded ? <canvas ref={el => (this.canvasElement = el as HTMLCanvasElement)} /> : <div style={{display: 'none'}} />}\n\n <div class=\"disclaimer\">\n By clicking Adopt, I agree that the signature will be the electronic representation of my signature for all purposes when I (or my agent) use them on documents,\n including legally binding contracts &mdash; just the same as a pen-and-paper signature or initial.\n </div>\n\n <div class=\"buttons\">\n <verdocs-button label=\"CANCEL\" variant=\"outline\" onClick={e => this.handleCancel(e)} />\n <verdocs-button label=\"Adopt & Sign\" onClick={e => this.handleAdopt(e)} />\n </div>\n </div>\n </div>\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-signature-dialog {\n font-family: $primary-font;\n box-sizing: border-box;\n position: fixed;\n z-index: 10000;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n display: flex;\n align-items: center;\n justify-content: center;\n background: #0000007f;\n\n .dialog {\n width: 100%;\n max-width: 340px;\n border-radius: 4px;\n overflow: hidden;\n box-shadow: 3px 3px 5px 1px rgba(40, 40, 40, 0.4);\n background: $dialog-bg;\n }\n\n .heading {\n display: flex;\n flex-direction: row;\n padding: 20px 20px 0 20px;\n line-height: 28px;\n font-size: 20px;\n font-weight: 500;\n }\n\n .content {\n font-size: 14px;\n padding: 20px;\n }\n\n .buttons {\n display: flex;\n margin: 20px 0 0 0;\n flex-direction: row;\n justify-content: flex-end;\n align-items: center;\n\n verdocs-button {\n margin-left: 16px;\n }\n }\n\n canvas {\n background: $verdocs-grey-4;\n box-sizing: border-box;\n margin: 0 auto;\n width: 300px;\n // TODO: The original app had an aspect ratio of (80 / 305) * (signatureBodyWidth - 20)\n height: 79px;\n max-width: 100%;\n box-shadow: 0 0 6px 0 #0000001f;\n }\n\n .disclaimer {\n text-align: justify;\n padding: 8px 0;\n font-size: 11px;\n line-height: 14px;\n color: rgba(0, 0, 0, 0.54);\n }\n\n .as-shown {\n font-size: 11px;\n margin: 4px 0 20px 4px;\n color: rgba(0, 0, 0, 0.54);\n }\n\n .tabs {\n display: flex;\n flex-direction: row;\n\n .tab {\n padding: 8px 15px;\n cursor: pointer;\n\n &.active {\n border-bottom: 2px solid $light-border-color;\n }\n\n &:hover {\n color: $primary-color;\n }\n }\n }\n}\n","import {Component, Prop, h, Event, EventEmitter, State, Host} from '@stencil/core';\n\n/**\n * Display a dialog that allows the user to specify a signature image, either by using a signature-font-generated image\n * based on their full name, or by hand-drawing their signature with a mouse or tablet.\n */\n@Component({\n tag: 'verdocs-signature-dialog',\n styleUrl: 'verdocs-signature-dialog.scss',\n})\nexport class VerdocsSignatureDialog {\n private canvasElement?: HTMLCanvasElement;\n\n /**\n * Initial signature text\n */\n @Prop() name: string = '';\n\n /**\n * Fired when the user completes the dialog and clicks Adopt. The event detail will contain a base64-encoded string\n * representation of the signature adopted.\n */\n @Event({composed: true}) next: EventEmitter<string>;\n\n /**\n * Event fired when the step is cancelled. This is called exit to avoid conflicts with the JS-reserved \"cancel\" event name.\n */\n @Event({composed: true}) exit: EventEmitter;\n\n @State() fontLoaded = false;\n\n @State() enteredName: string = '';\n\n @State() mode: string = 'type';\n\n componentWillLoad() {\n this.enteredName = this.name;\n\n const ds = new FontFace('Dancing Script', 'url(https://fonts.gstatic.com/s/dancingscript/v19/If2cXTr6YS-zF4S-kcSWSVi_sxjsohD9F50Ruu7BMSo3Sup6hNX6plRP.woff)');\n ds.load().then(font => {\n document.fonts.add(font);\n this.fontLoaded = true;\n });\n }\n\n componentDidLoad() {\n this.redrawSignature();\n }\n\n componentDidUpdate() {\n this.redrawSignature();\n }\n\n redrawSignature() {\n if (!this.canvasElement) {\n return;\n }\n\n const canvasWidth = this.canvasElement.width;\n\n const context = this.canvasElement.getContext('2d');\n context.clearRect(0, 0, this.canvasElement.width, this.canvasElement.height);\n\n let fontSize = 100;\n do {\n fontSize -= 2;\n context.font = `${fontSize}px Dancing Script`;\n } while (context.measureText(this.enteredName).width > canvasWidth - 32); // 32px padding each side\n\n context.textAlign = 'center';\n context.textBaseline = 'middle';\n context.font = `${fontSize}px Dancing Script`;\n context.fillText(this.enteredName, this.canvasElement.width / 2, this.canvasElement.height / 2);\n }\n\n handleNameChange(e: any) {\n this.enteredName = e.target.value;\n }\n\n handleCancel(e: any) {\n e.stopPropagation();\n e.preventDefault();\n this.exit.emit();\n }\n\n handleAdopt(e: any) {\n e.stopPropagation();\n e.preventDefault();\n const data = this.canvasElement.toDataURL('image/png');\n this.next.emit(data);\n }\n\n /*\n selColor(hex: string) {\n this.color = hex;\n this.animateDraw();\n }\n\n stopDraw() {\n this.paint = false;\n this.adoptedAndSigned = !this.hasSignature();\n }\n\n draw(e) {\n this.paint = true;\n this.addPoints(e, false);\n this.animateDraw();\n }\n\n recordPoints(e) {\n if (this.paint) {\n this.addPoints(e, true);\n this.animateDraw();\n }\n }\n\n animateDraw() {\n this.canvas.clearRect(0, 0, this.canvas.canvas.offsetWidth, this.canvas.canvas.offsetHeight);\n\n this.canvas.strokeStyle = this.color || '#000000';\n this.canvas.lineJoin = 'round';\n this.canvas.lineWidth = 3;\n\n for (let i = 0; i < this.points.length; i++) {\n this.canvas.beginPath();\n if (this.points[i].drag && i) {\n this.canvas.moveTo(this.points[i - 1].x, this.points[i - 1].y);\n // this.canvas.arc(this.points[i - 1].x, this.points[i - 1].y, 2, 0, 2 * Math.PI, false);\n } else {\n this.canvas.moveTo(this.points[i].x - 1, this.points[i].y);\n // this.canvas.arc(this.points[i].x, this.points[i].y, 2, 0, 2 * Math.PI, false);\n }\n\n this.canvas.lineTo(this.points[i].x, this.points[i].y);\n this.canvas.closePath();\n this.canvas.stroke();\n }\n }\n\n drawCurve(color: string, curve: number) {\n this.canvas.beginPath();\n }\n\n\n\n addPoints(e, drag: boolean) {\n if (window) {\n let x;\n let y;\n e.preventDefault();\n if (e.touches && e.touches.length > 0) {\n x = e.touches[0].clientX;\n } else {\n x = e.clientX;\n }\n\n if (e.touches && e.touches.length > 0) {\n y = e.touches[0].clientY;\n } else {\n y = e.clientY;\n }\n const rect = this.signatureCanvas.nativeElement.getBoundingClientRect();\n this.points.push({\n x: x - rect.left,\n y: y - rect.top,\n drag: drag\n });\n }\n }\n\n clearPad() {\n this.canvas.clearRect(0, 0, this.canvas.canvas.offsetWidth, this.canvas.canvas.offsetHeight);\n this.points = [];\n this.adoptedAndSigned = !this.hasSignature();\n }\n\n async adoptAndSign() {\n try {\n this.adoptedAndSigned = true;\n await this.updateFullName();\n await this.captureSignatureFromCanvas();\n const message = this.signatureMode === 'Signature' ? 'Saving Signature' : 'Saving Initial';\n this.snackbarService.open(message, 'OK', this.snackbarService.initConfig(null, 'bottom'));\n this.handleMode();\n } catch (err) {\n this.snackbarService.open('Failed to apply signature', 'OK', this.snackbarService.initConfig(null, 'bottom'));\n }\n }\n\n handleMode() {\n let currentField;\n switch (this.mode) {\n case 'signerview':\n if (this.signatureMode === 'Signature') {\n this.signatureService.postSignatureBlob().then(result => {\n if (result && result.id && result.url) {\n currentField = this.signatureService.currField;\n this.signatureService.updateSigned(currentField.fName, true);\n this.signatureService.toggleSig(false);\n this.signatureService.setSignatureId(result.id);\n this.signatureService.putSignatureField(this.envelopeId, this.fieldName, result.id).then(res => {\n this.eventTracker.createEvent({\n category: 'verdoc',\n action: 'verdoc signed',\n label: `verdoc id: ${this.envelopeId}`\n })\n if (res && res.settings) {\n this.signatureService.setSignatureData(res.settings.base64);\n this.signatureService.setSignatureId(res.settings.signature_id);\n }\n this.snackbarService.dismiss();\n this.dialog.close({ status: 'saved', temp_sig: res.settings.base64, sig_id: res.settings.signature_id });\n }).catch(err => {\n this.snackbarService.open('Failed to save signature. Please try again.', 'DISMISS', {\n duration: 3000\n });\n this.adoptedAndSigned = false;\n return err;\n });\n }\n });\n } else {\n this.signatureService.postInitialBlob().then(result => {\n if (result && result.id && result.url) {\n currentField = this.signatureService.currField;\n this.signatureService.updateInitialed(currentField.fName, true);\n this.signatureService.setInitialId(result.id);\n this.signatureService.toggleSig(false);\n this.signatureService.putInitialField(this.envelopeId, this.fieldName, result.id).then(res => {\n if (res && res.settings) {\n this.signatureService.setInitialData(res.settings.base64);\n this.signatureService.setInitialId(res.settings.initial_id);\n }\n this.snackbarService.dismiss();\n this.dialog.close({ status: 'saved', temp_int: res.settings.base64, int_id: res.settings.initial_id });\n }).catch(err => {\n this.snackbarService.open('Failed to save initial. Please try again.', 'DISMISS', {\n duration: 3000\n });\n this.adoptedAndSigned = false;\n return err;\n });\n }\n });\n }\n break;\n }\n }\n */\n\n render() {\n return (\n <Host onClick={e => this.handleCancel(e)}>\n <div class=\"dialog\">\n <div class=\"heading\">Create Your Signature</div>\n\n <div class=\"content\">\n <verdocs-text-input placeholder=\"Full Name...\" label=\"Full Name\" value={this.enteredName} onInput={e => this.handleNameChange(e)} onClick={e => e.stopPropagation()} />\n <div class=\"as-shown\">As shown on driver's license or govt. ID card.</div>\n\n {/*<div class=\"tabs\">*/}\n {/* <div class={{tab: true, active: this.mode === 'type'}} onClick={() => (this.mode = 'type')}>*/}\n {/* Type*/}\n {/* </div>*/}\n {/*<div class={{tab: true, active: this.mode === 'draw'}} onClick={() => (this.mode = 'draw')}>*/}\n {/* Draw*/}\n {/*</div>*/}\n {/*</div>*/}\n\n {this.fontLoaded ? <canvas ref={el => (this.canvasElement = el as HTMLCanvasElement)} /> : <div style={{display: 'none'}} />}\n\n <div class=\"disclaimer\">\n By clicking Adopt, I agree that the signature will be the electronic representation of my signature for all purposes when I (or my agent) use them on documents,\n including legally binding contracts &mdash; just the same as a pen-and-paper signature or initial.\n </div>\n\n <div class=\"buttons\">\n <verdocs-button label=\"CANCEL\" size=\"normal\" variant=\"outline\" onClick={e => this.handleCancel(e)} />\n <verdocs-button label=\"Adopt & Sign\" size=\"normal\" onClick={e => this.handleAdopt(e)} />\n </div>\n </div>\n </div>\n </Host>\n );\n }\n}\n","@import '../../../theme.scss';\n\nverdocs-upload-dialog {\n position: fixed;\n box-sizing: border-box;\n font-family: $primary-font;\n\n div {\n box-sizing: border-box;\n }\n\n .background-overlay {\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n display: flex;\n z-index: 10000;\n position: fixed;\n align-items: center;\n background: #0000007f;\n justify-content: center;\n }\n\n // Not simple .dialog to avoid conflicts with ok-dialog. Should review that more.\n .upload-dialog-content {\n width: 320px;\n display: flex;\n flex-direction: column;\n border-radius: 4px;\n overflow: hidden;\n background: $verdocs-grey-4;\n padding: 16px;\n box-shadow: 3px 3px 5px 1px rgba(40, 40, 40, 0.4);\n }\n\n .heading {\n display: flex;\n font-size: 20px;\n font-weight: 500;\n flex-direction: row;\n }\n\n .buttons {\n display: flex;\n align-items: center;\n flex-direction: row;\n justify-content: flex-end;\n\n verdocs-button {\n margin-left: 16px;\n }\n }\n\n .current-label {\n margin: 20px 0 5px 0;\n }\n\n .drop-target {\n opacity: 1;\n width: 100%;\n display: flex;\n margin: 20px 0;\n min-height: 260px;\n padding: 30px 15px;\n text-align: center;\n align-items: center;\n flex-direction: column;\n justify-content: center;\n background-color: #f5f5f5;\n color: $verdocs-grey-1;\n border: 2px dashed #979797;\n\n p {\n margin: 12px 0;\n font-weight: 500;\n\n &.subscript {\n margin: 20px;\n color: $verdocs-bg-4;\n font-size: 14px;\n }\n }\n\n &.dragging-over {\n border: 5px solid $verdocs-deep-blue;\n }\n\n > verdocs-button {\n margin: 12px 0;\n display: inline-block;\n }\n }\n\n .attachments {\n height: 56px;\n font-size: 0;\n margin: 20px 0;\n padding: 0 16px;\n line-height: 56px;\n white-space: normal;\n box-shadow:\n 0 1px 3px 0 rgb(0 0 0 / 20%),\n 0 2px 2px 0 rgb(0 0 0 / 12%),\n 0 0 2px 0 rgb(0 0 0 / 14%);\n\n .attachment {\n gap: 10px;\n display: flex;\n align-items: center;\n flex-direction: row;\n\n .icon {\n width: 18px;\n height: 18px;\n line-height: 18px;\n\n &.trash {\n cursor: pointer;\n }\n }\n\n .name {\n flex: 1;\n font-size: 14px;\n overflow: hidden;\n font-weight: 400;\n white-space: nowrap;\n text-overflow: ellipsis;\n }\n }\n }\n\n .error {\n margin: 20px 0;\n color: $verdocs-red-1;\n }\n}\n","import {Component, h, Event, EventEmitter, Fragment, Host, State, Prop} from '@stencil/core';\n\nconst TrashIcon = `<svg xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\"><path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M19 7l-.867 12.142A2 2 0 0116.138 21H7.862a2 2 0 01-1.995-1.858L5 7m5 4v6m4-6v6m1-10V4a1 1 0 00-1-1h-4a1 1 0 00-1 1v3M4 7h16\" /></svg>`;\n\nconst PaperclipIcon = `<svg xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\"><path stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M15.172 7l-6.586 6.586a2 2 0 102.828 2.828l6.414-6.586a4 4 0 00-5.656-5.656l-6.415 6.585a6 6 0 108.486 8.486L20.5 13\" /></svg>`;\n\n/**\n * Display a file upload tool. Note that the file is not actually transmitted, so it may be used by\n * callers with a variety of workflows. Instead, data about the chosen file will be passed to the\n * caller via the onNext event handler. A delete event is also exposed to delete existing attachments.\n * To represent an existing attachment, set the existingFile property.\n */\n@Component({\n tag: 'verdocs-upload-dialog',\n styleUrl: 'verdocs-upload-dialog.scss',\n})\nexport class VerdocsUploadDialog {\n private fileInput?: HTMLInputElement;\n\n @Prop({mutable: true})\n maxSize: number = 20 * 1024 * 1024;\n\n @Prop({mutable: true})\n existingFile: any;\n\n /**\n * Event fired when the step is cancelled. This is called exit to avoid conflicts with the JS-reserved \"cancel\" event name.\n */\n @Event({composed: true}) exit: EventEmitter;\n\n /**\n * Event fired when the dialog is closed. The event data will contain the file selected.\n */\n @Event({composed: true}) next: EventEmitter<File[]>;\n\n /**\n * Event fired when an existing attachment is deleted. The parent component is\n * responsible for the actual removal.\n */\n @Event({composed: true}) remove: EventEmitter;\n\n @State() draggingOver = false;\n @State() confirmDelete = false;\n @State() selectedFiles = [] as File[];\n @State() errorMessage = '';\n\n handleCancel() {\n this.exit.emit();\n }\n\n // We need a separate event handler for clicking the background because it can receive events \"through\" other child components\n handleDismiss(e: any) {\n if (e.target.class === 'background-overlay') {\n e.preventDefault();\n this.handleCancel();\n }\n }\n\n handleDone() {\n this.next.emit(this.selectedFiles);\n }\n\n handleDragOver(e) {\n e.preventDefault();\n this.draggingOver = true;\n }\n\n handleDragLeave(e) {\n e.preventDefault();\n this.draggingOver = false;\n }\n\n async handleDrop(e) {\n e.preventDefault();\n this.draggingOver = false;\n this.handleSetSelected(Array.from(e.dataTransfer.files));\n }\n\n handleRemoveAttachment(index: number) {\n const newFiles = [...this.selectedFiles];\n newFiles.splice(index, 1);\n this.handleSetSelected(newFiles);\n }\n\n handleSetSelected(files: any[]) {\n this.selectedFiles = files;\n this.errorMessage = '';\n\n const totalSize = this.selectedFiles.reduce((acc, file) => acc + file.size, 0);\n if (totalSize > this.maxSize) {\n this.errorMessage = 'Total file size must not exceed 20MB.';\n }\n }\n\n handleDeleteAttachment(e: any) {\n // Stop the parent from seeing \"next\" and thinking an upload was done.\n // TODO: Rethink having so many commonalities in nested dialogs (next/exit).\n e.preventDefault();\n e.stopPropagation();\n\n this.remove?.emit();\n this.existingFile = null;\n this.confirmDelete = false;\n }\n\n handleSelectFile() {\n this.fileInput?.click();\n }\n\n async handleFileChange() {\n const selectedFiles = Array.from(this.fileInput?.files);\n let droppedFiles = [] as File[];\n for (let i = 0; i < this.fileInput?.files.length; i++) {\n droppedFiles.push(this.fileInput?.files[i]);\n }\n\n this.handleSetSelected(selectedFiles);\n }\n\n render() {\n const existingFile = this.existingFile?.name ? this.existingFile : null;\n\n return (\n <Host>\n <div class=\"background-overlay\" onClick={e => this.handleDismiss(e)}>\n <div class=\"upload-dialog-content\">\n <div class=\"heading\">Upload attachment</div>\n\n {this.selectedFiles.length < 1 && existingFile && (\n <Fragment>\n <div class=\"current-label\">Current Attachment</div>\n <div class=\"attachments\" style={{marginTop: '0'}}>\n <div class=\"attachment\">\n <div class=\"icon\" innerHTML={PaperclipIcon} />\n <div class=\"name\">{existingFile.name}</div>\n <div class=\"icon trash\" innerHTML={TrashIcon} onClick={() => (this.confirmDelete = true)} />\n </div>\n </div>\n </Fragment>\n )}\n\n {this.selectedFiles.length < 1 && !existingFile && (\n <div\n class={{'drop-target': true, 'dragging-over': this.draggingOver}}\n onDragOver={e => this.handleDragOver(e)}\n onDragLeave={e => this.handleDragLeave(e)}\n onDrop={e => this.handleDrop(e)}\n >\n <p>Drag and drop your files here</p>\n <p class=\"subscript\">Supported files: PDF, Word, JPG, PNG</p>\n\n <verdocs-button label={!!existingFile ? 'Replace files' : 'Select files'} onClick={() => this.handleSelectFile()} />\n <input\n type=\"file\"\n ref={el => (this.fileInput = el as HTMLInputElement)}\n style={{display: 'none'}}\n accept=\".pdf,application/pdf,.doc,.docx,application/msword,application/vnd.openxmlformats-officedocument.wordprocessingml.document,image/*\"\n onChange={() => this.handleFileChange()}\n />\n </div>\n )}\n\n {this.selectedFiles.length > 0 && (\n <div class=\"attachments\">\n {this.selectedFiles.map((file, index) => (\n <div class=\"attachment\">\n <div class=\"icon\" innerHTML={PaperclipIcon} />\n <div class=\"name\">{file.name}</div>\n <div class=\"icon trash\" innerHTML={TrashIcon} onClick={() => this.handleRemoveAttachment(index)} />\n </div>\n ))}\n </div>\n )}\n\n {!!this.errorMessage && <div class=\"error\">{this.errorMessage}</div>}\n\n <div class=\"buttons\">\n <verdocs-button label=\"Cancel\" variant=\"outline\" onClick={() => this.handleCancel()} />\n <verdocs-button label=\"Upload\" onClick={() => this.handleDone()} disabled={!!this.errorMessage || this.selectedFiles.length < 1} />\n </div>\n </div>\n </div>\n\n {this.confirmDelete && (\n <verdocs-ok-dialog\n heading=\"Delete Attachment?\"\n message=\"Are you sure you wish to delete this attachment? This action cannot be undone.\"\n showCancel={true}\n onExit={e => {\n // So we don't close the upload dialog\n e.preventDefault();\n e.stopPropagation();\n this.confirmDelete = false;\n }}\n onNext={e => this.handleDeleteAttachment(e)}\n />\n )}\n </Host>\n );\n }\n}\n"],"mappings":"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","ignoreList":[]}