@verdocs/web-sdk 1.13.35 → 1.14.1

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 (359) hide show
  1. package/dist/cjs/{Envelopes-699531b7.js → Envelopes-e5ffb6a5.js} +1 -0
  2. package/dist/cjs/Permissions-4b710db2.js +39 -0
  3. package/dist/cjs/TemplateStore-19f84862.js +90 -0
  4. package/dist/cjs/Toast-26bf925e.js +67 -0
  5. package/dist/cjs/{TemplateStore-95728963.js → index-e84e0687.js} +1 -87
  6. package/dist/cjs/ipc-test.cjs.entry.js +2 -1
  7. package/dist/cjs/loader.cjs.js +1 -1
  8. package/dist/cjs/{utils-12a82a63.js → utils-a9022729.js} +1 -1
  9. package/dist/cjs/verdocs-build.cjs.entry.js +2 -1
  10. package/dist/cjs/verdocs-button-panel_3.cjs.entry.js +3 -2
  11. package/dist/cjs/verdocs-checkbox_4.cjs.entry.js +1 -1
  12. package/dist/cjs/verdocs-dropdown_2.cjs.entry.js +3 -3
  13. package/dist/cjs/verdocs-envelope-recipient-summary.cjs.entry.js +191 -0
  14. package/dist/cjs/verdocs-envelope-sidebar.cjs.entry.js +22 -16
  15. package/dist/cjs/verdocs-field-checkbox.cjs.entry.js +2 -2
  16. package/dist/cjs/verdocs-field-date.cjs.entry.js +2 -2
  17. package/dist/cjs/verdocs-field-dropdown.cjs.entry.js +2 -2
  18. package/dist/cjs/verdocs-field-initial.cjs.entry.js +2 -2
  19. package/dist/cjs/verdocs-field-payment.cjs.entry.js +2 -2
  20. package/dist/cjs/verdocs-field-radio-button.cjs.entry.js +2 -2
  21. package/dist/cjs/verdocs-field-signature.cjs.entry.js +2 -2
  22. package/dist/cjs/verdocs-field-textarea.cjs.entry.js +2 -2
  23. package/dist/cjs/verdocs-field-textbox.cjs.entry.js +2 -2
  24. package/dist/cjs/verdocs-field-timestamp.cjs.entry.js +2 -2
  25. package/dist/cjs/verdocs-file-chooser_2.cjs.entry.js +1 -1
  26. package/dist/cjs/verdocs-initial-dialog.cjs.entry.js +1 -1
  27. package/dist/cjs/verdocs-kba-dialog.cjs.entry.js +1 -1
  28. package/dist/cjs/verdocs-ok-dialog.cjs.entry.js +1 -1
  29. package/dist/cjs/verdocs-organization-card.cjs.entry.js +1 -1
  30. package/dist/cjs/verdocs-preview.cjs.entry.js +4 -3
  31. package/dist/cjs/verdocs-send.cjs.entry.js +4 -3
  32. package/dist/cjs/verdocs-sign.cjs.entry.js +4 -3
  33. package/dist/cjs/verdocs-signature-dialog.cjs.entry.js +1 -1
  34. package/dist/cjs/verdocs-status-indicator.cjs.entry.js +1 -1
  35. package/dist/cjs/verdocs-template-attachments_2.cjs.entry.js +2 -1
  36. package/dist/cjs/verdocs-template-card.cjs.entry.js +1 -1
  37. package/dist/cjs/verdocs-template-document-page_2.cjs.entry.js +2 -2
  38. package/dist/cjs/verdocs-template-fields_4.cjs.entry.js +6 -5
  39. package/dist/cjs/verdocs-template-name.cjs.entry.js +2 -1
  40. package/dist/cjs/verdocs-template-properties.cjs.entry.js +2 -1
  41. package/dist/cjs/verdocs-template-reminders.cjs.entry.js +2 -1
  42. package/dist/cjs/verdocs-template-tags.cjs.entry.js +1 -1
  43. package/dist/cjs/verdocs-template-visibility.cjs.entry.js +2 -1
  44. package/dist/cjs/verdocs-toggle-button.cjs.entry.js +1 -1
  45. package/dist/cjs/verdocs-toggle.cjs.entry.js +1 -1
  46. package/dist/cjs/verdocs-upload-dialog.cjs.entry.js +1 -1
  47. package/dist/cjs/verdocs-view.cjs.entry.js +8 -23
  48. package/dist/cjs/verdocs-web-sdk.cjs.js +1 -1
  49. package/dist/collection/collection-manifest.json +1 -0
  50. package/dist/collection/components/controls/verdocs-dropdown/verdocs-dropdown.css +1 -1
  51. package/dist/collection/components/controls/verdocs-organization-card/verdocs-organization-card.css +1 -1
  52. package/dist/collection/components/controls/verdocs-progress-bar/verdocs-progress-bar.css +1 -1
  53. package/dist/collection/components/controls/verdocs-select-input/verdocs-select-input.css +1 -1
  54. package/dist/collection/components/controls/verdocs-text-input/verdocs-text-input.css +1 -1
  55. package/dist/collection/components/controls/verdocs-toast/verdocs-toast.stories.js +24 -0
  56. package/dist/collection/components/controls/verdocs-toggle/verdocs-toggle.css +1 -1
  57. package/dist/collection/components/controls/verdocs-toggle-button/verdocs-toggle-button.css +1 -1
  58. package/dist/collection/components/dialogs/verdocs-initial-dialog/verdocs-initial-dialog.css +1 -1
  59. package/dist/collection/components/dialogs/verdocs-kba-dialog/verdocs-kba-dialog.css +1 -1
  60. package/dist/collection/components/dialogs/verdocs-ok-dialog/verdocs-ok-dialog.css +1 -1
  61. package/dist/collection/components/dialogs/verdocs-signature-dialog/verdocs-signature-dialog.css +1 -1
  62. package/dist/collection/components/dialogs/verdocs-upload-dialog/verdocs-upload-dialog.css +1 -1
  63. package/dist/collection/components/embeds/verdocs-sign/verdocs-sign.js +3 -2
  64. package/dist/collection/components/embeds/verdocs-view/verdocs-view.js +45 -0
  65. package/dist/collection/components/envelopes/verdocs-envelope-recipient-summary/verdocs-envelope-recipient-summary.css +108 -0
  66. package/dist/collection/components/envelopes/verdocs-envelope-recipient-summary/verdocs-envelope-recipient-summary.js +311 -0
  67. package/dist/collection/components/envelopes/verdocs-envelope-recipient-summary/verdocs-envelope-recipient-summary.stories.js +25 -0
  68. package/dist/collection/components/envelopes/verdocs-envelope-sidebar/verdocs-envelope-sidebar.css +8 -0
  69. package/dist/collection/components/envelopes/verdocs-envelope-sidebar/verdocs-envelope-sidebar.js +33 -16
  70. package/dist/collection/components/envelopes/verdocs-envelope-sidebar/verdocs-envelope-sidebar.stories.js +3 -1
  71. package/dist/collection/components/envelopes/verdocs-status-indicator/verdocs-status-indicator.css +1 -1
  72. package/dist/collection/components/templates/verdocs-template-card/verdocs-template-card.css +1 -1
  73. package/dist/collection/components/templates/verdocs-template-role-properties/verdocs-template-role-properties.css +1 -1
  74. package/dist/collection/components/templates/verdocs-template-sender/verdocs-template-sender.css +1 -1
  75. package/dist/collection/components/templates/verdocs-template-tags/verdocs-template-tags.css +1 -1
  76. package/dist/collection/utils/EnvelopeStore.js +79 -0
  77. package/dist/collection/utils/TemplateStore.js +0 -1
  78. package/dist/collection/utils/Toast.js +63 -0
  79. package/dist/components/Envelopes.js +1 -1
  80. package/dist/components/Permissions.js +34 -0
  81. package/dist/components/TemplateStore.js +1 -193
  82. package/dist/components/Toast.js +138 -0
  83. package/dist/components/index.d.ts +1 -0
  84. package/dist/components/index.js +1 -0
  85. package/dist/components/index3.js +194 -0
  86. package/dist/components/utils.js +1 -1
  87. package/dist/components/verdocs-dropdown2.js +1 -1
  88. package/dist/components/verdocs-envelope-recipient-summary.d.ts +11 -0
  89. package/dist/components/verdocs-envelope-recipient-summary.js +6 -0
  90. package/dist/components/verdocs-envelope-recipient-summary2.js +219 -0
  91. package/dist/components/verdocs-envelope-sidebar.js +37 -18
  92. package/dist/components/verdocs-initial-dialog2.js +1 -1
  93. package/dist/components/verdocs-kba-dialog.js +1 -1
  94. package/dist/components/verdocs-ok-dialog2.js +1 -1
  95. package/dist/components/verdocs-organization-card.js +1 -1
  96. package/dist/components/verdocs-progress-bar2.js +1 -1
  97. package/dist/components/verdocs-select-input2.js +1 -1
  98. package/dist/components/verdocs-sign.js +2 -2
  99. package/dist/components/verdocs-signature-dialog2.js +1 -1
  100. package/dist/components/verdocs-status-indicator.js +1 -1
  101. package/dist/components/verdocs-template-card.js +1 -1
  102. package/dist/components/verdocs-template-role-properties2.js +1 -1
  103. package/dist/components/verdocs-template-sender2.js +1 -1
  104. package/dist/components/verdocs-template-tags.js +1 -1
  105. package/dist/components/verdocs-text-input2.js +1 -1
  106. package/dist/components/verdocs-toggle-button2.js +1 -1
  107. package/dist/components/verdocs-toggle.js +1 -1
  108. package/dist/components/verdocs-upload-dialog2.js +1 -1
  109. package/dist/components/verdocs-view2.js +6 -21
  110. package/dist/custom-elements.json +25 -0
  111. package/dist/docs.json +220 -3
  112. package/dist/esm/{Envelopes-921cd9d0.js → Envelopes-c3d471e5.js} +1 -1
  113. package/dist/esm/Permissions-7192ef7c.js +34 -0
  114. package/dist/esm/TemplateStore-852097c3.js +87 -0
  115. package/dist/esm/Toast-fbda07e3.js +65 -0
  116. package/dist/esm/{TemplateStore-09fc7336.js → index-29123f30.js} +1 -86
  117. package/dist/esm/ipc-test.entry.js +2 -1
  118. package/dist/esm/loader.js +1 -1
  119. package/dist/esm/{utils-81958236.js → utils-75cee3f6.js} +1 -1
  120. package/dist/esm/verdocs-build.entry.js +2 -1
  121. package/dist/esm/verdocs-button-panel_3.entry.js +3 -2
  122. package/dist/esm/verdocs-checkbox_4.entry.js +1 -1
  123. package/dist/esm/verdocs-dropdown_2.entry.js +3 -3
  124. package/dist/esm/verdocs-envelope-recipient-summary.entry.js +187 -0
  125. package/dist/esm/verdocs-envelope-sidebar.entry.js +22 -16
  126. package/dist/esm/verdocs-field-checkbox.entry.js +2 -2
  127. package/dist/esm/verdocs-field-date.entry.js +2 -2
  128. package/dist/esm/verdocs-field-dropdown.entry.js +2 -2
  129. package/dist/esm/verdocs-field-initial.entry.js +2 -2
  130. package/dist/esm/verdocs-field-payment.entry.js +2 -2
  131. package/dist/esm/verdocs-field-radio-button.entry.js +2 -2
  132. package/dist/esm/verdocs-field-signature.entry.js +2 -2
  133. package/dist/esm/verdocs-field-textarea.entry.js +2 -2
  134. package/dist/esm/verdocs-field-textbox.entry.js +2 -2
  135. package/dist/esm/verdocs-field-timestamp.entry.js +2 -2
  136. package/dist/esm/verdocs-file-chooser_2.entry.js +1 -1
  137. package/dist/esm/verdocs-initial-dialog.entry.js +1 -1
  138. package/dist/esm/verdocs-kba-dialog.entry.js +1 -1
  139. package/dist/esm/verdocs-ok-dialog.entry.js +1 -1
  140. package/dist/esm/verdocs-organization-card.entry.js +1 -1
  141. package/dist/esm/verdocs-preview.entry.js +4 -3
  142. package/dist/esm/verdocs-send.entry.js +4 -3
  143. package/dist/esm/verdocs-sign.entry.js +4 -3
  144. package/dist/esm/verdocs-signature-dialog.entry.js +1 -1
  145. package/dist/esm/verdocs-status-indicator.entry.js +1 -1
  146. package/dist/esm/verdocs-template-attachments_2.entry.js +2 -1
  147. package/dist/esm/verdocs-template-card.entry.js +1 -1
  148. package/dist/esm/verdocs-template-document-page_2.entry.js +2 -2
  149. package/dist/esm/verdocs-template-fields_4.entry.js +6 -5
  150. package/dist/esm/verdocs-template-name.entry.js +2 -1
  151. package/dist/esm/verdocs-template-properties.entry.js +2 -1
  152. package/dist/esm/verdocs-template-reminders.entry.js +2 -1
  153. package/dist/esm/verdocs-template-tags.entry.js +1 -1
  154. package/dist/esm/verdocs-template-visibility.entry.js +2 -1
  155. package/dist/esm/verdocs-toggle-button.entry.js +1 -1
  156. package/dist/esm/verdocs-toggle.entry.js +1 -1
  157. package/dist/esm/verdocs-upload-dialog.entry.js +1 -1
  158. package/dist/esm/verdocs-view.entry.js +7 -22
  159. package/dist/esm/verdocs-web-sdk.js +1 -1
  160. package/dist/esm-es5/{Envelopes-921cd9d0.js → Envelopes-c3d471e5.js} +1 -1
  161. package/dist/esm-es5/Permissions-7192ef7c.js +1 -0
  162. package/dist/esm-es5/TemplateStore-852097c3.js +1 -0
  163. package/dist/esm-es5/Toast-fbda07e3.js +1 -0
  164. package/dist/esm-es5/index-29123f30.js +1 -0
  165. package/dist/esm-es5/ipc-test.entry.js +1 -1
  166. package/dist/esm-es5/loader.js +1 -1
  167. package/dist/esm-es5/{utils-81958236.js → utils-75cee3f6.js} +1 -1
  168. package/dist/esm-es5/verdocs-build.entry.js +1 -1
  169. package/dist/esm-es5/verdocs-button-panel_3.entry.js +1 -1
  170. package/dist/esm-es5/verdocs-checkbox_4.entry.js +1 -1
  171. package/dist/esm-es5/verdocs-dropdown_2.entry.js +1 -1
  172. package/dist/esm-es5/verdocs-envelope-recipient-summary.entry.js +1 -0
  173. package/dist/esm-es5/verdocs-envelope-sidebar.entry.js +1 -1
  174. package/dist/esm-es5/verdocs-field-checkbox.entry.js +1 -1
  175. package/dist/esm-es5/verdocs-field-date.entry.js +1 -1
  176. package/dist/esm-es5/verdocs-field-dropdown.entry.js +1 -1
  177. package/dist/esm-es5/verdocs-field-initial.entry.js +1 -1
  178. package/dist/esm-es5/verdocs-field-payment.entry.js +1 -1
  179. package/dist/esm-es5/verdocs-field-radio-button.entry.js +1 -1
  180. package/dist/esm-es5/verdocs-field-signature.entry.js +1 -1
  181. package/dist/esm-es5/verdocs-field-textarea.entry.js +1 -1
  182. package/dist/esm-es5/verdocs-field-textbox.entry.js +1 -1
  183. package/dist/esm-es5/verdocs-field-timestamp.entry.js +1 -1
  184. package/dist/esm-es5/verdocs-file-chooser_2.entry.js +1 -1
  185. package/dist/esm-es5/verdocs-initial-dialog.entry.js +1 -1
  186. package/dist/esm-es5/verdocs-kba-dialog.entry.js +1 -1
  187. package/dist/esm-es5/verdocs-ok-dialog.entry.js +1 -1
  188. package/dist/esm-es5/verdocs-organization-card.entry.js +1 -1
  189. package/dist/esm-es5/verdocs-preview.entry.js +1 -1
  190. package/dist/esm-es5/verdocs-send.entry.js +1 -1
  191. package/dist/esm-es5/verdocs-sign.entry.js +1 -1
  192. package/dist/esm-es5/verdocs-signature-dialog.entry.js +1 -1
  193. package/dist/esm-es5/verdocs-status-indicator.entry.js +1 -1
  194. package/dist/esm-es5/verdocs-template-attachments_2.entry.js +1 -1
  195. package/dist/esm-es5/verdocs-template-card.entry.js +1 -1
  196. package/dist/esm-es5/verdocs-template-document-page_2.entry.js +1 -1
  197. package/dist/esm-es5/verdocs-template-fields_4.entry.js +1 -1
  198. package/dist/esm-es5/verdocs-template-name.entry.js +1 -1
  199. package/dist/esm-es5/verdocs-template-properties.entry.js +1 -1
  200. package/dist/esm-es5/verdocs-template-reminders.entry.js +1 -1
  201. package/dist/esm-es5/verdocs-template-tags.entry.js +1 -1
  202. package/dist/esm-es5/verdocs-template-visibility.entry.js +1 -1
  203. package/dist/esm-es5/verdocs-toggle-button.entry.js +1 -1
  204. package/dist/esm-es5/verdocs-toggle.entry.js +1 -1
  205. package/dist/esm-es5/verdocs-upload-dialog.entry.js +1 -1
  206. package/dist/esm-es5/verdocs-view.entry.js +1 -1
  207. package/dist/esm-es5/verdocs-web-sdk.js +1 -1
  208. package/dist/types/components/controls/verdocs-toast/verdocs-toast.stories.d.ts +8 -0
  209. package/dist/types/components/embeds/verdocs-view/verdocs-view.d.ts +15 -0
  210. package/dist/types/components/envelopes/verdocs-envelope-recipient-summary/verdocs-envelope-recipient-summary.d.ts +74 -0
  211. package/dist/types/components/envelopes/verdocs-envelope-recipient-summary/verdocs-envelope-recipient-summary.stories.d.ts +12 -0
  212. package/dist/types/components/envelopes/verdocs-envelope-sidebar/verdocs-envelope-sidebar.d.ts +6 -0
  213. package/dist/types/components/envelopes/verdocs-envelope-sidebar/verdocs-envelope-sidebar.stories.d.ts +3 -1
  214. package/dist/types/components.d.ts +97 -0
  215. package/dist/types/utils/EnvelopeStore.d.ts +14 -0
  216. package/dist/types/utils/Toast.d.ts +18 -0
  217. package/dist/verdocs-web-sdk/p-0177fb6c.entry.js +1 -0
  218. package/dist/verdocs-web-sdk/p-0529a428.system.entry.js +1 -0
  219. package/dist/verdocs-web-sdk/{p-542994b3.entry.js → p-05f8c1c8.entry.js} +1 -1
  220. package/dist/verdocs-web-sdk/{p-15505723.entry.js → p-060a5281.entry.js} +1 -1
  221. package/dist/verdocs-web-sdk/p-0b99a23e.entry.js +1 -0
  222. package/dist/verdocs-web-sdk/p-0c0ac290.system.entry.js +1 -0
  223. package/dist/verdocs-web-sdk/{p-cb6b8c75.entry.js → p-0e4fe8f9.entry.js} +1 -1
  224. package/dist/verdocs-web-sdk/{p-135f1746.system.entry.js → p-1420d87e.system.entry.js} +1 -1
  225. package/dist/verdocs-web-sdk/p-18375932.system.entry.js +1 -0
  226. package/dist/verdocs-web-sdk/p-1859687d.system.entry.js +1 -0
  227. package/dist/verdocs-web-sdk/{p-f1cc5b3c.system.entry.js → p-18e8f1b5.system.entry.js} +1 -1
  228. package/dist/verdocs-web-sdk/p-1a875696.system.entry.js +1 -0
  229. package/dist/verdocs-web-sdk/p-1cf38cea.system.js +1 -1
  230. package/dist/verdocs-web-sdk/{p-0bedf11c.system.entry.js → p-1f370439.system.entry.js} +1 -1
  231. package/dist/verdocs-web-sdk/p-257b575f.system.entry.js +1 -0
  232. package/dist/verdocs-web-sdk/{p-8aa4815e.entry.js → p-2cc146cb.entry.js} +1 -1
  233. package/dist/verdocs-web-sdk/p-31be0dfc.system.js +1 -0
  234. package/dist/verdocs-web-sdk/p-3649e7e0.entry.js +1 -0
  235. package/dist/verdocs-web-sdk/p-375b1328.system.entry.js +1 -0
  236. package/dist/verdocs-web-sdk/{p-31295791.entry.js → p-396207e9.entry.js} +1 -1
  237. package/dist/verdocs-web-sdk/p-3a4e52dc.system.entry.js +1 -0
  238. package/dist/verdocs-web-sdk/p-41264548.system.entry.js +1 -0
  239. package/dist/verdocs-web-sdk/{p-8c536274.entry.js → p-438daf23.entry.js} +1 -1
  240. package/dist/verdocs-web-sdk/p-4a9a3134.system.entry.js +1 -0
  241. package/dist/verdocs-web-sdk/p-4b65e2f3.js +1 -0
  242. package/dist/verdocs-web-sdk/p-4cc5d833.system.js +1 -0
  243. package/dist/verdocs-web-sdk/p-4e8ae503.system.entry.js +1 -0
  244. package/dist/verdocs-web-sdk/{p-de9c4feb.system.entry.js → p-4f947df8.system.entry.js} +1 -1
  245. package/dist/verdocs-web-sdk/p-52428dff.entry.js +1 -0
  246. package/dist/verdocs-web-sdk/p-58bb657b.entry.js +1 -0
  247. package/dist/verdocs-web-sdk/{p-0cb24fef.system.entry.js → p-5a456647.system.entry.js} +1 -1
  248. package/dist/verdocs-web-sdk/{p-1f69d9a3.entry.js → p-5a9d6ff0.entry.js} +1 -1
  249. package/dist/verdocs-web-sdk/p-5c21aaa3.entry.js +1 -0
  250. package/dist/verdocs-web-sdk/p-5ed28056.system.entry.js +1 -0
  251. package/dist/verdocs-web-sdk/{p-31f88d95.js → p-5f61a3ec.js} +1 -1
  252. package/dist/verdocs-web-sdk/{p-06f625f2.system.entry.js → p-609e9838.system.entry.js} +1 -1
  253. package/dist/verdocs-web-sdk/p-611e0ebe.entry.js +1 -0
  254. package/dist/verdocs-web-sdk/{p-963a4b4a.system.entry.js → p-63a75b10.system.entry.js} +1 -1
  255. package/dist/verdocs-web-sdk/p-63ad2439.system.entry.js +1 -0
  256. package/dist/verdocs-web-sdk/{p-b5be2016.entry.js → p-650ffab0.entry.js} +1 -1
  257. package/dist/verdocs-web-sdk/{p-fa0eec42.system.entry.js → p-73717726.system.entry.js} +1 -1
  258. package/dist/verdocs-web-sdk/p-73a8954f.system.entry.js +1 -0
  259. package/dist/verdocs-web-sdk/{p-1a0aa7fd.system.entry.js → p-783a95b0.system.entry.js} +1 -1
  260. package/dist/verdocs-web-sdk/p-790beec1.js +1 -0
  261. package/dist/verdocs-web-sdk/p-79844d8f.entry.js +1 -0
  262. package/dist/verdocs-web-sdk/{p-d9843ba6.system.entry.js → p-7b5f4edf.system.entry.js} +1 -1
  263. package/dist/verdocs-web-sdk/p-805d5545.entry.js +1 -0
  264. package/dist/verdocs-web-sdk/{p-5709fbe8.entry.js → p-82155c59.entry.js} +1 -1
  265. package/dist/verdocs-web-sdk/p-848371c9.entry.js +1 -0
  266. package/dist/verdocs-web-sdk/p-861f0272.entry.js +1 -0
  267. package/dist/verdocs-web-sdk/p-886461cd.system.entry.js +1 -0
  268. package/dist/verdocs-web-sdk/p-899cb38a.entry.js +1 -0
  269. package/dist/verdocs-web-sdk/p-8bc60ae5.system.entry.js +1 -0
  270. package/dist/verdocs-web-sdk/p-8c57f5d0.system.js +1 -0
  271. package/dist/verdocs-web-sdk/{p-4c988fa0.system.entry.js → p-935e379f.system.entry.js} +1 -1
  272. package/dist/verdocs-web-sdk/{p-d1c37175.system.js → p-973ebb54.system.js} +1 -1
  273. package/dist/verdocs-web-sdk/p-9b73909f.js +1 -0
  274. package/dist/verdocs-web-sdk/{p-98ef1df0.entry.js → p-a3ab475a.entry.js} +1 -1
  275. package/dist/verdocs-web-sdk/p-a5bce263.entry.js +1 -0
  276. package/dist/verdocs-web-sdk/{p-9be9c835.entry.js → p-a8043f9d.entry.js} +1 -1
  277. package/dist/verdocs-web-sdk/p-aa3a445b.system.entry.js +1 -0
  278. package/dist/verdocs-web-sdk/p-acaf2646.system.entry.js +1 -0
  279. package/dist/verdocs-web-sdk/p-acaf51f7.system.entry.js +1 -0
  280. package/dist/verdocs-web-sdk/{p-a80035a6.entry.js → p-b0b84793.entry.js} +1 -1
  281. package/dist/verdocs-web-sdk/p-b3a8928b.entry.js +1 -0
  282. package/dist/verdocs-web-sdk/p-b4d11d90.system.js +1 -0
  283. package/dist/verdocs-web-sdk/p-b6016e12.entry.js +1 -0
  284. package/dist/verdocs-web-sdk/p-b6293bd1.entry.js +1 -0
  285. package/dist/verdocs-web-sdk/p-b6e9934d.entry.js +1 -0
  286. package/dist/verdocs-web-sdk/p-b7af4b3f.system.entry.js +1 -0
  287. package/dist/verdocs-web-sdk/p-b839d9f0.system.entry.js +1 -0
  288. package/dist/verdocs-web-sdk/{p-b7d66b24.system.entry.js → p-b970a5fe.system.entry.js} +1 -1
  289. package/dist/verdocs-web-sdk/p-bb085c47.system.entry.js +1 -0
  290. package/dist/verdocs-web-sdk/{p-52f39e6b.system.entry.js → p-c472fbd0.system.entry.js} +1 -1
  291. package/dist/verdocs-web-sdk/{p-a8b6ec03.entry.js → p-d146b48e.entry.js} +1 -1
  292. package/dist/verdocs-web-sdk/{p-4cf7c407.entry.js → p-d170f421.entry.js} +1 -1
  293. package/dist/verdocs-web-sdk/p-d2bcbce0.system.entry.js +1 -0
  294. package/dist/verdocs-web-sdk/p-d869c39c.js +1 -0
  295. package/dist/verdocs-web-sdk/p-e2c1857b.entry.js +1 -0
  296. package/dist/verdocs-web-sdk/{p-7c86d53a.entry.js → p-e4aaa309.entry.js} +1 -1
  297. package/dist/verdocs-web-sdk/p-e4ceaebf.system.entry.js +1 -0
  298. package/dist/verdocs-web-sdk/{p-8446f444.entry.js → p-e7f2401c.entry.js} +1 -1
  299. package/dist/verdocs-web-sdk/p-e8ef4d44.entry.js +1 -0
  300. package/dist/verdocs-web-sdk/{p-f4c4f8dd.system.js → p-ee20297a.system.js} +1 -1
  301. package/dist/verdocs-web-sdk/{p-6e7a1333.entry.js → p-ee743904.entry.js} +1 -1
  302. package/dist/verdocs-web-sdk/p-f483cd49.entry.js +1 -0
  303. package/dist/verdocs-web-sdk/{p-e637160a.entry.js → p-f7a1b311.entry.js} +1 -1
  304. package/dist/verdocs-web-sdk/{p-05e83caa.system.entry.js → p-f9c6fa6c.system.entry.js} +1 -1
  305. package/dist/verdocs-web-sdk/{p-27ebad6b.system.entry.js → p-fa4e7dd4.system.entry.js} +1 -1
  306. package/dist/verdocs-web-sdk/{p-ec0925d5.entry.js → p-fb95d3da.entry.js} +1 -1
  307. package/dist/verdocs-web-sdk/p-fce6a5f3.system.entry.js +1 -0
  308. package/dist/verdocs-web-sdk/{p-c99689c1.entry.js → p-fe0da205.entry.js} +1 -1
  309. package/dist/verdocs-web-sdk/p-feb2ae87.js +1 -0
  310. package/dist/verdocs-web-sdk/verdocs-web-sdk.esm.js +1 -1
  311. package/package.json +1 -1
  312. package/dist/components/Recipients.js +0 -74
  313. package/dist/esm-es5/TemplateStore-09fc7336.js +0 -1
  314. package/dist/verdocs-web-sdk/p-0f66f6bb.entry.js +0 -1
  315. package/dist/verdocs-web-sdk/p-109fb530.entry.js +0 -1
  316. package/dist/verdocs-web-sdk/p-1102db6a.entry.js +0 -1
  317. package/dist/verdocs-web-sdk/p-1748d4d6.entry.js +0 -1
  318. package/dist/verdocs-web-sdk/p-1b5e57bb.entry.js +0 -1
  319. package/dist/verdocs-web-sdk/p-1b71f48b.system.entry.js +0 -1
  320. package/dist/verdocs-web-sdk/p-23d77279.system.entry.js +0 -1
  321. package/dist/verdocs-web-sdk/p-25bd103e.system.entry.js +0 -1
  322. package/dist/verdocs-web-sdk/p-2e9fb01e.system.entry.js +0 -1
  323. package/dist/verdocs-web-sdk/p-2ee6b0a0.system.entry.js +0 -1
  324. package/dist/verdocs-web-sdk/p-3784e44a.system.entry.js +0 -1
  325. package/dist/verdocs-web-sdk/p-3da76ad8.entry.js +0 -1
  326. package/dist/verdocs-web-sdk/p-4d5c78b4.system.entry.js +0 -1
  327. package/dist/verdocs-web-sdk/p-4fdcfed5.system.entry.js +0 -1
  328. package/dist/verdocs-web-sdk/p-5597b4b3.entry.js +0 -1
  329. package/dist/verdocs-web-sdk/p-61979b22.system.entry.js +0 -1
  330. package/dist/verdocs-web-sdk/p-661654d8.entry.js +0 -1
  331. package/dist/verdocs-web-sdk/p-6c9a3b1d.system.entry.js +0 -1
  332. package/dist/verdocs-web-sdk/p-6f6bac89.system.entry.js +0 -1
  333. package/dist/verdocs-web-sdk/p-725ee615.system.entry.js +0 -1
  334. package/dist/verdocs-web-sdk/p-750996e5.entry.js +0 -1
  335. package/dist/verdocs-web-sdk/p-7ab07c61.entry.js +0 -1
  336. package/dist/verdocs-web-sdk/p-7c10cd2f.system.entry.js +0 -1
  337. package/dist/verdocs-web-sdk/p-843b717d.entry.js +0 -1
  338. package/dist/verdocs-web-sdk/p-86690cac.system.entry.js +0 -1
  339. package/dist/verdocs-web-sdk/p-92664ee4.js +0 -1
  340. package/dist/verdocs-web-sdk/p-938031a9.system.entry.js +0 -1
  341. package/dist/verdocs-web-sdk/p-953c52a0.system.entry.js +0 -1
  342. package/dist/verdocs-web-sdk/p-9594f6df.entry.js +0 -1
  343. package/dist/verdocs-web-sdk/p-9b18321e.system.entry.js +0 -1
  344. package/dist/verdocs-web-sdk/p-a294ef80.entry.js +0 -1
  345. package/dist/verdocs-web-sdk/p-aa9627a3.entry.js +0 -1
  346. package/dist/verdocs-web-sdk/p-b3ec6306.js +0 -1
  347. package/dist/verdocs-web-sdk/p-b4698fe4.entry.js +0 -1
  348. package/dist/verdocs-web-sdk/p-b507c2a5.entry.js +0 -1
  349. package/dist/verdocs-web-sdk/p-b9a316d7.system.entry.js +0 -1
  350. package/dist/verdocs-web-sdk/p-c3eecad6.entry.js +0 -1
  351. package/dist/verdocs-web-sdk/p-c5dde9c7.system.js +0 -1
  352. package/dist/verdocs-web-sdk/p-da3b66af.system.entry.js +0 -1
  353. package/dist/verdocs-web-sdk/p-db5f1a7d.entry.js +0 -1
  354. package/dist/verdocs-web-sdk/p-e0386f1b.entry.js +0 -1
  355. package/dist/verdocs-web-sdk/p-e7d2709d.system.entry.js +0 -1
  356. package/dist/verdocs-web-sdk/p-e98e2e3d.system.entry.js +0 -1
  357. package/dist/verdocs-web-sdk/p-f43112b2.system.entry.js +0 -1
  358. package/dist/verdocs-web-sdk/p-fa1a552f.system.entry.js +0 -1
  359. package/dist/verdocs-web-sdk/p-ffc8f64d.system.entry.js +0 -1
@@ -0,0 +1,79 @@
1
+ import { createStore } from '@stencil/store';
2
+ import { getEnvelope } from '@verdocs/js-sdk/Envelopes/Envelopes';
3
+ const createEnvelopeStore = (envelopeId) => {
4
+ const now = new Date().toISOString();
5
+ return createStore({
6
+ isLoading: true,
7
+ isLoaded: false,
8
+ isError: false,
9
+ error: null,
10
+ updateCount: 0,
11
+ roleNames: [],
12
+ id: envelopeId,
13
+ template_id: '',
14
+ name: '',
15
+ status: 'pending',
16
+ profile_id: '',
17
+ organization_id: '',
18
+ no_contact: false,
19
+ created_at: now,
20
+ updated_at: now,
21
+ canceled_at: null,
22
+ reminder_id: null,
23
+ envelope_document_id: '',
24
+ certificate_document_id: null,
25
+ visibility: 'private',
26
+ histories: [],
27
+ recipients: [],
28
+ profile: undefined,
29
+ certificate: undefined,
30
+ document: undefined,
31
+ documents: undefined,
32
+ fields: undefined,
33
+ });
34
+ };
35
+ const envelopeStores = {};
36
+ export const getEnvelopeStore = async (endpoint, envelopeId, forceReload = false) => {
37
+ let created = false;
38
+ if (!envelopeStores[envelopeId]) {
39
+ console.debug('[ENVELOPES] No envelope store found for ID, creating', envelopeId);
40
+ envelopeStores[envelopeId] = createEnvelopeStore(envelopeId);
41
+ created = true;
42
+ }
43
+ const store = envelopeStores[envelopeId];
44
+ // NOTE: If we need it, store.use() returns an unsubcribe function
45
+ // See https://github.com/ionic-team/stencil-store#storeusesubscriptions
46
+ store.use({
47
+ reset: () => console.debug('[ENVELOPES] Store got reset'),
48
+ dispose: () => console.debug('[ENVELOPES] Store got disposed'),
49
+ });
50
+ // TODO: This can create a race condition if two components call this at the same time.
51
+ // For now we can probably defer doing something smart here because it's only a
52
+ // double-load issue.
53
+ if (created || forceReload) {
54
+ console.debug('[ENVELOPES] Reloading envelope', { envelopeId, created, forceReload });
55
+ store.state.isLoading = true;
56
+ store.state.isLoaded = false;
57
+ store.state.isError = false;
58
+ store.state.error = undefined;
59
+ try {
60
+ const envelope = await getEnvelope(endpoint, envelopeId);
61
+ console.debug('[ENVELOPES] Got envelope', envelope);
62
+ Object.assign(store.state, envelope);
63
+ store.state.isLoaded = true;
64
+ store.state.isError = false;
65
+ store.state.error = undefined;
66
+ }
67
+ catch (e) {
68
+ console.error('[ENVELOPES] Error loading envelope', e);
69
+ store.state.isLoaded = false;
70
+ store.state.isError = true;
71
+ store.state.error = e;
72
+ throw e;
73
+ }
74
+ store.state.isLoading = false;
75
+ store.state.updateCount++;
76
+ }
77
+ return store;
78
+ };
79
+ export const getRecipientRoleNames = (store) => { var _a; return (((_a = store === null || store === void 0 ? void 0 : store.state) === null || _a === void 0 ? void 0 : _a.recipients) || []).map(r => r.role_name); };
@@ -65,7 +65,6 @@ export const getTemplateStore = async (endpoint, templateId, forceReload = false
65
65
  const template = await getTemplate(endpoint, templateId);
66
66
  console.debug('[TEMPLATES] Got template', template);
67
67
  Object.assign(store.state, template);
68
- // Object.keys(template).forEach(key => store.set(key as keyof TTemplateStore, template[key]));
69
68
  store.state.isLoaded = true;
70
69
  store.state.isError = false;
71
70
  store.state.error = undefined;
@@ -0,0 +1,63 @@
1
+ /**
2
+ * Simple helper to display basic toast messages. These toasts do not stack, and
3
+ * because of this are meant to be used only for infrequent notifications (those
4
+ * that would rarely happen back to back within a few seconds).
5
+ *
6
+ * The main reason to use this and not a toast library is CSS efficiency. All
7
+ * toast libraries require some block of CSS be installed. That works well for
8
+ * an app but every Web Component gets compiled as its own mini sandbox app.
9
+ * That means a toast library's CSS would get compiled over and over. This
10
+ * method is styled inline and minifie to <3K, most of which is the icons. If
11
+ * we wanted to trim it more we could move those out to an icon library because
12
+ * they're reused in other controls as well.
13
+ */
14
+ const Icons = {
15
+ error: `<div class="toast-icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="currentColor" style="width: 24px; height: 24px; display: block;">
16
+ <path fill-rule="evenodd" d="M2.25 12c0-5.385 4.365-9.75 9.75-9.75s9.75 4.365 9.75 9.75-4.365 9.75-9.75 9.75S2.25 17.385 2.25 12zM12 8.25a.75.75 0 01.75.75v3.75a.75.75 0 01-1.5 0V9a.75.75 0 01.75-.75zm0 8.25a.75.75 0 100-1.5.75.75 0 000 1.5z" clip-rule="evenodd" />
17
+ </svg></div>`,
18
+ success: `<div class="toast-icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="currentColor" style="width: 24px; height: 24px; display: block;">
19
+ <path fill-rule="evenodd" d="M2.25 12c0-5.385 4.365-9.75 9.75-9.75s9.75 4.365 9.75 9.75-4.365 9.75-9.75 9.75S2.25 17.385 2.25 12zm13.36-1.814a.75.75 0 10-1.22-.872l-3.236 4.53L9.53 12.22a.75.75 0 00-1.06 1.06l2.25 2.25a.75.75 0 001.14-.094l3.75-5.25z" clip-rule="evenodd" />
20
+ </svg></div>`,
21
+ info: `<div class="toast-icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="currentColor" style="width: 24px; height: 24px; display: block;">
22
+ <path fill-rule="evenodd" d="M2.25 12c0-5.385 4.365-9.75 9.75-9.75s9.75 4.365 9.75 9.75-4.365 9.75-9.75 9.75S2.25 17.385 2.25 12zm8.706-1.442c1.146-.573 2.437.463 2.126 1.706l-.709 2.836.042-.02a.75.75 0 01.67 1.34l-.04.022c-1.147.573-2.438-.463-2.127-1.706l.71-2.836-.042.02a.75.75 0 11-.671-1.34l.041-.022zM12 9a.75.75 0 100-1.5.75.75 0 000 1.5z" clip-rule="evenodd" />
23
+ </svg></div>`,
24
+ // The empty element allows the flex "gap" to still provide the correct spacing, visually
25
+ default: '<div class="toast-icon"></div>',
26
+ };
27
+ const Colors = {
28
+ error: '#ed3d3d',
29
+ success: '#3dc763',
30
+ info: '#2379c7',
31
+ default: '#6a56c1',
32
+ };
33
+ const removeToasts = () => Array.from(document.getElementsByClassName('verdocs-toast')).forEach(oldToast => oldToast.remove());
34
+ const closeClicked = (e) => {
35
+ e.stopPropagation();
36
+ removeToasts();
37
+ };
38
+ export const VerdocsToast = (text, config = {}) => {
39
+ // We don't stack because we have only a few specific use-cases and they would
40
+ // almost never show more than one message at a time.
41
+ removeToasts();
42
+ const { duration = 5000, style = 'default' } = config || {};
43
+ const color = Colors[style] || Colors.default;
44
+ const icon = Icons[style] || Icons.default;
45
+ const toastBody = `
46
+ ${icon}
47
+ <div class="verdocs-toast-text" style="padding: 12px 12px 12px 0;">${text}</div>
48
+ <div class="verdocs-toast-close" style="padding: 12px 8px; background: rgba(0,0,0,0.25); cursor: pointer;">✕</div>
49
+ `;
50
+ const toast = document.createElement('div');
51
+ toast.className = 'verdocs-toast';
52
+ toast.innerHTML = toastBody;
53
+ toast.style.cssText = `
54
+ display: flex; flex-direction: row; gap: 10px; align-items: center;
55
+ position: fixed; top: 20px; right: 20px; z-index: 2147483647; max-width: calc(50% - 20px);
56
+ color: #ffffff; background: ${color}; font-family: 'Barlow', sans-serif;
57
+ border-radius: 2px; padding-left: 10px;
58
+ box-shadow: 0 3px 7px 2px rgba(0, 0, 0, 0.12), 0 10px 36px -4px rgba(77, 96, 232, 0.3);`;
59
+ document.body.append(toast);
60
+ const closeElements = Array.from(document.getElementsByClassName('verdocs-toast-close'));
61
+ closeElements.forEach(closeEl => closeEl.addEventListener('click', closeClicked));
62
+ setTimeout(removeToasts, duration);
63
+ };
@@ -163,4 +163,4 @@ var throttledGetEnvelope = function (endpoint, envelopeId) {
163
163
  });
164
164
  };
165
165
 
166
- export { updateEnvelopeFieldSignature as a, updateEnvelopeFieldInitials as b, getEnvelopeDocumentPageDisplayUri as c, cancelEnvelope as d, getEnvelopeFile as e, getFieldAttachment as f, getSigningSession as g, throttledGetEnvelope as t, updateEnvelopeField as u };
166
+ export { updateEnvelopeFieldSignature as a, updateEnvelopeFieldInitials as b, getEnvelopeDocumentPageDisplayUri as c, getEnvelope as d, cancelEnvelope as e, getEnvelopeFile as f, getSigningSession as g, getFieldAttachment as h, throttledGetEnvelope as t, updateEnvelopeField as u };
@@ -0,0 +1,34 @@
1
+ import { E as EnvelopeStates } from './Types.js';
2
+
3
+ /**
4
+ * Various helpers to identify available operations for an envelope by a user.
5
+ *
6
+ * @module
7
+ */
8
+ /**
9
+ * Check to see if the user owns the envelope.
10
+ */
11
+ var userIsEnvelopeOwner = function (session, envelope) { return envelope.profile_id === (session === null || session === void 0 ? void 0 : session.profile_id); };
12
+ /**
13
+ * Check to see if the user owns the envelope.
14
+ */
15
+ var userCanCancelEnvelope = function (session, envelope) {
16
+ return userIsEnvelopeOwner(session, envelope) &&
17
+ envelope.status !== EnvelopeStates.COMPLETE &&
18
+ envelope.status !== EnvelopeStates.DECLINED &&
19
+ envelope.status !== EnvelopeStates.CANCELED;
20
+ };
21
+ /**
22
+ * Returns true if the recipient has a pending action. Note that this does not necessarily mean the recipient can act (yet).
23
+ */
24
+ var recipientHasAction = function (recipient) { return !['submitted', 'canceled', 'declined'].includes(recipient.status); };
25
+ /**
26
+ * Returns the recipients who still have a pending action. Note that not all of these recipients may be able to act (yet).
27
+ */
28
+ var getRecipientsWithActions = function (envelope) { return ((envelope === null || envelope === void 0 ? void 0 : envelope.recipients) || []).filter(recipientHasAction); };
29
+ /**
30
+ * Returns true if the recipient can act.
31
+ */
32
+ var recipientCanAct = function (recipient, recipientsWithActions) { var _a; return recipient.sequence === ((_a = recipientsWithActions === null || recipientsWithActions === void 0 ? void 0 : recipientsWithActions[0]) === null || _a === void 0 ? void 0 : _a.sequence); };
33
+
34
+ export { userCanCancelEnvelope as a, getRecipientsWithActions as g, recipientCanAct as r, userIsEnvelopeOwner as u };
@@ -1,198 +1,7 @@
1
- import { getRenderingRef, forceUpdate } from '@stencil/core/internal/client';
1
+ import { c as createStore } from './index3.js';
2
2
  import { a as getTemplate } from './Templates.js';
3
3
  import { T as TemplateSenderTypes } from './VerdocsEndpoint.js';
4
4
 
5
- const appendToMap = (map, propName, value) => {
6
- const items = map.get(propName);
7
- if (!items) {
8
- map.set(propName, [value]);
9
- }
10
- else if (!items.includes(value)) {
11
- items.push(value);
12
- }
13
- };
14
- const debounce = (fn, ms) => {
15
- let timeoutId;
16
- return (...args) => {
17
- if (timeoutId) {
18
- clearTimeout(timeoutId);
19
- }
20
- timeoutId = setTimeout(() => {
21
- timeoutId = 0;
22
- fn(...args);
23
- }, ms);
24
- };
25
- };
26
-
27
- /**
28
- * Check if a possible element isConnected.
29
- * The property might not be there, so we check for it.
30
- *
31
- * We want it to return true if isConnected is not a property,
32
- * otherwise we would remove these elements and would not update.
33
- *
34
- * Better leak in Edge than to be useless.
35
- */
36
- const isConnected = (maybeElement) => !('isConnected' in maybeElement) || maybeElement.isConnected;
37
- const cleanupElements = debounce((map) => {
38
- for (let key of map.keys()) {
39
- map.set(key, map.get(key).filter(isConnected));
40
- }
41
- }, 2000);
42
- const stencilSubscription = () => {
43
- if (typeof getRenderingRef !== 'function') {
44
- // If we are not in a stencil project, we do nothing.
45
- // This function is not really exported by @stencil/core.
46
- return {};
47
- }
48
- const elmsToUpdate = new Map();
49
- return {
50
- dispose: () => elmsToUpdate.clear(),
51
- get: (propName) => {
52
- const elm = getRenderingRef();
53
- if (elm) {
54
- appendToMap(elmsToUpdate, propName, elm);
55
- }
56
- },
57
- set: (propName) => {
58
- const elements = elmsToUpdate.get(propName);
59
- if (elements) {
60
- elmsToUpdate.set(propName, elements.filter(forceUpdate));
61
- }
62
- cleanupElements(elmsToUpdate);
63
- },
64
- reset: () => {
65
- elmsToUpdate.forEach((elms) => elms.forEach(forceUpdate));
66
- cleanupElements(elmsToUpdate);
67
- },
68
- };
69
- };
70
-
71
- const unwrap = (val) => (typeof val === 'function' ? val() : val);
72
- const createObservableMap = (defaultState, shouldUpdate = (a, b) => a !== b) => {
73
- const unwrappedState = unwrap(defaultState);
74
- let states = new Map(Object.entries(unwrappedState !== null && unwrappedState !== void 0 ? unwrappedState : {}));
75
- const handlers = {
76
- dispose: [],
77
- get: [],
78
- set: [],
79
- reset: [],
80
- };
81
- const reset = () => {
82
- var _a;
83
- // When resetting the state, the default state may be a function - unwrap it to invoke it.
84
- // otherwise, the state won't be properly reset
85
- states = new Map(Object.entries((_a = unwrap(defaultState)) !== null && _a !== void 0 ? _a : {}));
86
- handlers.reset.forEach((cb) => cb());
87
- };
88
- const dispose = () => {
89
- // Call first dispose as resetting the state would
90
- // cause less updates ;)
91
- handlers.dispose.forEach((cb) => cb());
92
- reset();
93
- };
94
- const get = (propName) => {
95
- handlers.get.forEach((cb) => cb(propName));
96
- return states.get(propName);
97
- };
98
- const set = (propName, value) => {
99
- const oldValue = states.get(propName);
100
- if (shouldUpdate(value, oldValue, propName)) {
101
- states.set(propName, value);
102
- handlers.set.forEach((cb) => cb(propName, value, oldValue));
103
- }
104
- };
105
- const state = (typeof Proxy === 'undefined'
106
- ? {}
107
- : new Proxy(unwrappedState, {
108
- get(_, propName) {
109
- return get(propName);
110
- },
111
- ownKeys(_) {
112
- return Array.from(states.keys());
113
- },
114
- getOwnPropertyDescriptor() {
115
- return {
116
- enumerable: true,
117
- configurable: true,
118
- };
119
- },
120
- has(_, propName) {
121
- return states.has(propName);
122
- },
123
- set(_, propName, value) {
124
- set(propName, value);
125
- return true;
126
- },
127
- }));
128
- const on = (eventName, callback) => {
129
- handlers[eventName].push(callback);
130
- return () => {
131
- removeFromArray(handlers[eventName], callback);
132
- };
133
- };
134
- const onChange = (propName, cb) => {
135
- const unSet = on('set', (key, newValue) => {
136
- if (key === propName) {
137
- cb(newValue);
138
- }
139
- });
140
- // We need to unwrap the defaultState because it might be a function.
141
- // Otherwise we might not be sending the right reset value.
142
- const unReset = on('reset', () => cb(unwrap(defaultState)[propName]));
143
- return () => {
144
- unSet();
145
- unReset();
146
- };
147
- };
148
- const use = (...subscriptions) => {
149
- const unsubs = subscriptions.reduce((unsubs, subscription) => {
150
- if (subscription.set) {
151
- unsubs.push(on('set', subscription.set));
152
- }
153
- if (subscription.get) {
154
- unsubs.push(on('get', subscription.get));
155
- }
156
- if (subscription.reset) {
157
- unsubs.push(on('reset', subscription.reset));
158
- }
159
- if (subscription.dispose) {
160
- unsubs.push(on('dispose', subscription.dispose));
161
- }
162
- return unsubs;
163
- }, []);
164
- return () => unsubs.forEach((unsub) => unsub());
165
- };
166
- const forceUpdate = (key) => {
167
- const oldValue = states.get(key);
168
- handlers.set.forEach((cb) => cb(key, oldValue, oldValue));
169
- };
170
- return {
171
- state,
172
- get,
173
- set,
174
- on,
175
- onChange,
176
- use,
177
- dispose,
178
- reset,
179
- forceUpdate,
180
- };
181
- };
182
- const removeFromArray = (array, item) => {
183
- const index = array.indexOf(item);
184
- if (index >= 0) {
185
- array[index] = array[array.length - 1];
186
- array.length--;
187
- }
188
- };
189
-
190
- const createStore = (defaultState, shouldUpdate) => {
191
- const map = createObservableMap(defaultState, shouldUpdate);
192
- map.use(stencilSubscription());
193
- return map;
194
- };
195
-
196
5
  const createTemplateStore = (templateId) => {
197
6
  const now = new Date().toISOString();
198
7
  return createStore({
@@ -257,7 +66,6 @@ const getTemplateStore = async (endpoint, templateId, forceReload = false) => {
257
66
  const template = await getTemplate(endpoint, templateId);
258
67
  console.debug('[TEMPLATES] Got template', template);
259
68
  Object.assign(store.state, template);
260
- // Object.keys(template).forEach(key => store.set(key as keyof TTemplateStore, template[key]));
261
69
  store.state.isLoaded = true;
262
70
  store.state.isError = false;
263
71
  store.state.error = undefined;
@@ -0,0 +1,138 @@
1
+ var __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {
2
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
+ return new (P || (P = Promise))(function (resolve, reject) {
4
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
8
+ });
9
+ };
10
+ var __generator = (undefined && undefined.__generator) || function (thisArg, body) {
11
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
12
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
13
+ function verb(n) { return function (v) { return step([n, v]); }; }
14
+ function step(op) {
15
+ if (f) throw new TypeError("Generator is already executing.");
16
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
17
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
18
+ if (y = 0, t) op = [op[0] & 2, t.value];
19
+ switch (op[0]) {
20
+ case 0: case 1: t = op; break;
21
+ case 4: _.label++; return { value: op[1], done: false };
22
+ case 5: _.label++; y = op[1]; op = [0]; continue;
23
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
24
+ default:
25
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
26
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
27
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
28
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
29
+ if (t[2]) _.ops.pop();
30
+ _.trys.pop(); continue;
31
+ }
32
+ op = body.call(thisArg, _);
33
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
34
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
35
+ }
36
+ };
37
+ /**
38
+ * Update a recipient's status block
39
+ */
40
+ var updateRecipient = function (endpoint, envelopeId, roleName, params) { return __awaiter(void 0, void 0, void 0, function () {
41
+ return __generator(this, function (_a) {
42
+ return [2 /*return*/, endpoint.api //
43
+ .put("/envelopes/".concat(envelopeId, "/recipients/").concat(roleName), params)
44
+ .then(function (r) { return r.data; })];
45
+ });
46
+ }); };
47
+ /**
48
+ * Submit an envelope (signing is finished). Note that all fields must be valid/completed for this to succeed.
49
+ */
50
+ var envelopeRecipientSubmit = function (endpoint, envelopeId, roleName) {
51
+ return updateRecipient(endpoint, envelopeId, roleName, { action: 'submit' });
52
+ };
53
+ /**
54
+ * Decline to complete an envelope (signing will not terminated).
55
+ */
56
+ var envelopeRecipientDecline = function (endpoint, envelopeId, roleName) {
57
+ return updateRecipient(endpoint, envelopeId, roleName, { action: 'decline' });
58
+ };
59
+ /**
60
+ * Agree to electronic signing.
61
+ */
62
+ var envelopeRecipientAgree = function (endpoint, envelopeId, roleName, agreed) {
63
+ return updateRecipient(endpoint, envelopeId, roleName, { action: 'update', agreed: agreed });
64
+ };
65
+ /**
66
+ * Get an in-person signing link.
67
+ */
68
+ var getInPersonLink = function (endpoint, envelopeId, roleName) {
69
+ return endpoint.api //
70
+ .get("/envelopes/".concat(envelopeId, "/recipients/").concat(encodeURIComponent(roleName), "?in_person_link=true"))
71
+ .then(function (r) { return r.data; });
72
+ };
73
+
74
+ /**
75
+ * Simple helper to display basic toast messages. These toasts do not stack, and
76
+ * because of this are meant to be used only for infrequent notifications (those
77
+ * that would rarely happen back to back within a few seconds).
78
+ *
79
+ * The main reason to use this and not a toast library is CSS efficiency. All
80
+ * toast libraries require some block of CSS be installed. That works well for
81
+ * an app but every Web Component gets compiled as its own mini sandbox app.
82
+ * That means a toast library's CSS would get compiled over and over. This
83
+ * method is styled inline and minifie to <3K, most of which is the icons. If
84
+ * we wanted to trim it more we could move those out to an icon library because
85
+ * they're reused in other controls as well.
86
+ */
87
+ const Icons = {
88
+ error: `<div class="toast-icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="currentColor" style="width: 24px; height: 24px; display: block;">
89
+ <path fill-rule="evenodd" d="M2.25 12c0-5.385 4.365-9.75 9.75-9.75s9.75 4.365 9.75 9.75-4.365 9.75-9.75 9.75S2.25 17.385 2.25 12zM12 8.25a.75.75 0 01.75.75v3.75a.75.75 0 01-1.5 0V9a.75.75 0 01.75-.75zm0 8.25a.75.75 0 100-1.5.75.75 0 000 1.5z" clip-rule="evenodd" />
90
+ </svg></div>`,
91
+ success: `<div class="toast-icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="currentColor" style="width: 24px; height: 24px; display: block;">
92
+ <path fill-rule="evenodd" d="M2.25 12c0-5.385 4.365-9.75 9.75-9.75s9.75 4.365 9.75 9.75-4.365 9.75-9.75 9.75S2.25 17.385 2.25 12zm13.36-1.814a.75.75 0 10-1.22-.872l-3.236 4.53L9.53 12.22a.75.75 0 00-1.06 1.06l2.25 2.25a.75.75 0 001.14-.094l3.75-5.25z" clip-rule="evenodd" />
93
+ </svg></div>`,
94
+ info: `<div class="toast-icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="currentColor" style="width: 24px; height: 24px; display: block;">
95
+ <path fill-rule="evenodd" d="M2.25 12c0-5.385 4.365-9.75 9.75-9.75s9.75 4.365 9.75 9.75-4.365 9.75-9.75 9.75S2.25 17.385 2.25 12zm8.706-1.442c1.146-.573 2.437.463 2.126 1.706l-.709 2.836.042-.02a.75.75 0 01.67 1.34l-.04.022c-1.147.573-2.438-.463-2.127-1.706l.71-2.836-.042.02a.75.75 0 11-.671-1.34l.041-.022zM12 9a.75.75 0 100-1.5.75.75 0 000 1.5z" clip-rule="evenodd" />
96
+ </svg></div>`,
97
+ // The empty element allows the flex "gap" to still provide the correct spacing, visually
98
+ default: '<div class="toast-icon"></div>',
99
+ };
100
+ const Colors = {
101
+ error: '#ed3d3d',
102
+ success: '#3dc763',
103
+ info: '#2379c7',
104
+ default: '#6a56c1',
105
+ };
106
+ const removeToasts = () => Array.from(document.getElementsByClassName('verdocs-toast')).forEach(oldToast => oldToast.remove());
107
+ const closeClicked = (e) => {
108
+ e.stopPropagation();
109
+ removeToasts();
110
+ };
111
+ const VerdocsToast = (text, config = {}) => {
112
+ // We don't stack because we have only a few specific use-cases and they would
113
+ // almost never show more than one message at a time.
114
+ removeToasts();
115
+ const { duration = 5000, style = 'default' } = config || {};
116
+ const color = Colors[style] || Colors.default;
117
+ const icon = Icons[style] || Icons.default;
118
+ const toastBody = `
119
+ ${icon}
120
+ <div class="verdocs-toast-text" style="padding: 12px 12px 12px 0;">${text}</div>
121
+ <div class="verdocs-toast-close" style="padding: 12px 8px; background: rgba(0,0,0,0.25); cursor: pointer;">✕</div>
122
+ `;
123
+ const toast = document.createElement('div');
124
+ toast.className = 'verdocs-toast';
125
+ toast.innerHTML = toastBody;
126
+ toast.style.cssText = `
127
+ display: flex; flex-direction: row; gap: 10px; align-items: center;
128
+ position: fixed; top: 20px; right: 20px; z-index: 2147483647; max-width: calc(50% - 20px);
129
+ color: #ffffff; background: ${color}; font-family: 'Barlow', sans-serif;
130
+ border-radius: 2px; padding-left: 10px;
131
+ box-shadow: 0 3px 7px 2px rgba(0, 0, 0, 0.12), 0 10px 36px -4px rgba(77, 96, 232, 0.3);`;
132
+ document.body.append(toast);
133
+ const closeElements = Array.from(document.getElementsByClassName('verdocs-toast-close'));
134
+ closeElements.forEach(closeEl => closeEl.addEventListener('click', closeClicked));
135
+ setTimeout(removeToasts, duration);
136
+ };
137
+
138
+ export { VerdocsToast as V, envelopeRecipientDecline as a, envelopeRecipientSubmit as b, envelopeRecipientAgree as e, getInPersonLink as g };
@@ -9,6 +9,7 @@ export { VerdocsComponentError as VerdocsComponentError } from '../types/compone
9
9
  export { VerdocsContactPicker as VerdocsContactPicker } from '../types/components/envelopes/verdocs-contact-picker/verdocs-contact-picker';
10
10
  export { VerdocsDropdown as VerdocsDropdown } from '../types/components/controls/verdocs-dropdown/verdocs-dropdown';
11
11
  export { VerdocsEnvelopeDocumentPage as VerdocsEnvelopeDocumentPage } from '../types/components/envelopes/verdocs-envelope-document-page/verdocs-envelope-document-page';
12
+ export { VerdocsEnvelopeRecipientSummary as VerdocsEnvelopeRecipientSummary } from '../types/components/envelopes/verdocs-envelope-recipient-summary/verdocs-envelope-recipient-summary';
12
13
  export { VerdocsEnvelopeSidebar as VerdocsEnvelopeSidebar } from '../types/components/envelopes/verdocs-envelope-sidebar/verdocs-envelope-sidebar';
13
14
  export { VerdocsFieldAttachment as VerdocsFieldAttachment } from '../types/components/fields/verdocs-field-attachment/verdocs-field-attachment';
14
15
  export { VerdocsFieldCheckbox as VerdocsFieldCheckbox } from '../types/components/fields/verdocs-field-checkbox/verdocs-field-checkbox';
@@ -9,6 +9,7 @@ export { VerdocsComponentError, defineCustomElement as defineCustomElementVerdoc
9
9
  export { VerdocsContactPicker, defineCustomElement as defineCustomElementVerdocsContactPicker } from './verdocs-contact-picker.js';
10
10
  export { VerdocsDropdown, defineCustomElement as defineCustomElementVerdocsDropdown } from './verdocs-dropdown.js';
11
11
  export { VerdocsEnvelopeDocumentPage, defineCustomElement as defineCustomElementVerdocsEnvelopeDocumentPage } from './verdocs-envelope-document-page.js';
12
+ export { VerdocsEnvelopeRecipientSummary, defineCustomElement as defineCustomElementVerdocsEnvelopeRecipientSummary } from './verdocs-envelope-recipient-summary.js';
12
13
  export { VerdocsEnvelopeSidebar, defineCustomElement as defineCustomElementVerdocsEnvelopeSidebar } from './verdocs-envelope-sidebar.js';
13
14
  export { VerdocsFieldAttachment, defineCustomElement as defineCustomElementVerdocsFieldAttachment } from './verdocs-field-attachment.js';
14
15
  export { VerdocsFieldCheckbox, defineCustomElement as defineCustomElementVerdocsFieldCheckbox } from './verdocs-field-checkbox.js';