@verdocs/web-sdk 1.14.11 → 1.15.0
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.
- package/dist/cjs/DateTime-ec575ec3.js +45 -0
- package/dist/cjs/{EnvelopeStore-a4231cf7.js → EnvelopeStore-00d2572c.js} +1 -1
- package/dist/cjs/{Envelopes-e5ffb6a5.js → Envelopes-43302e10.js} +17 -0
- package/dist/cjs/{Permissions-4b710db2.js → Permissions-0229bc30.js} +14 -0
- package/dist/cjs/loader.cjs.js +1 -1
- package/dist/cjs/{utils-618c13f1.js → utils-2eefb975.js} +1 -1
- package/dist/cjs/verdocs-activity-box.cjs.entry.js +91 -0
- package/dist/cjs/verdocs-button-panel_3.cjs.entry.js +25 -12
- package/dist/cjs/verdocs-dropdown.cjs.entry.js +88 -0
- package/dist/cjs/{verdocs-dropdown_2.cjs.entry.js → verdocs-envelope-document-page.cjs.entry.js} +2 -84
- package/dist/cjs/verdocs-envelope-recipient-summary.cjs.entry.js +3 -3
- package/dist/cjs/verdocs-envelope-sidebar.cjs.entry.js +3 -3
- package/dist/cjs/verdocs-envelopes-list.cjs.entry.js +233 -0
- package/dist/cjs/verdocs-field-checkbox.cjs.entry.js +2 -2
- package/dist/cjs/verdocs-field-date.cjs.entry.js +2 -2
- package/dist/cjs/verdocs-field-dropdown.cjs.entry.js +2 -2
- package/dist/cjs/verdocs-field-initial.cjs.entry.js +2 -2
- package/dist/cjs/verdocs-field-payment.cjs.entry.js +2 -2
- package/dist/cjs/verdocs-field-radio-button.cjs.entry.js +2 -2
- package/dist/cjs/verdocs-field-signature.cjs.entry.js +2 -2
- package/dist/cjs/verdocs-field-textarea.cjs.entry.js +2 -2
- package/dist/cjs/verdocs-field-textbox.cjs.entry.js +2 -2
- package/dist/cjs/verdocs-field-timestamp.cjs.entry.js +2 -2
- package/dist/cjs/verdocs-preview.cjs.entry.js +2 -2
- package/dist/cjs/verdocs-send.cjs.entry.js +2 -2
- package/dist/cjs/verdocs-sign.cjs.entry.js +2 -2
- package/dist/cjs/verdocs-template-document-page_2.cjs.entry.js +2 -2
- package/dist/cjs/verdocs-template-fields_4.cjs.entry.js +2 -2
- package/dist/cjs/verdocs-templates-list.cjs.entry.js +91 -0
- package/dist/cjs/verdocs-view.cjs.entry.js +3 -3
- package/dist/cjs/verdocs-web-sdk.cjs.js +1 -1
- package/dist/collection/collection-manifest.json +4 -1
- package/dist/collection/components/envelopes/verdocs-activity-box/verdocs-activity-box.css +130 -0
- package/dist/collection/components/envelopes/verdocs-activity-box/verdocs-activity-box.js +246 -0
- package/dist/collection/components/envelopes/verdocs-activity-box/verdocs-activity-box.stories.js +15 -0
- package/dist/collection/components/envelopes/verdocs-envelopes-list/verdocs-envelopes-list.css +74 -0
- package/dist/collection/components/envelopes/verdocs-envelopes-list/verdocs-envelopes-list.js +474 -0
- package/dist/collection/components/envelopes/verdocs-envelopes-list/verdocs-envelopes-list.stories.js +18 -0
- package/dist/collection/components/templates/verdocs-template-field-properties/verdocs-template-field-properties.js +27 -14
- package/dist/collection/components/templates/verdocs-template-fields/verdocs-template-fields.stories.js +1 -1
- package/dist/collection/components/templates/verdocs-templates-list/verdocs-templates-list.css +3 -0
- package/dist/collection/components/templates/verdocs-templates-list/verdocs-templates-list.js +246 -0
- package/dist/collection/components/templates/verdocs-templates-list/verdocs-templates-list.stories.js +16 -0
- package/dist/components/DateTime.js +43 -0
- package/dist/components/Envelopes.js +17 -1
- package/dist/components/Permissions.js +13 -1
- package/dist/components/index.d.ts +3 -0
- package/dist/components/index.js +3 -0
- package/dist/components/utils.js +1 -1
- package/dist/components/verdocs-activity-box.d.ts +11 -0
- package/dist/components/verdocs-activity-box.js +120 -0
- package/dist/components/verdocs-envelope-recipient-summary2.js +1 -1
- package/dist/components/verdocs-envelopes-list.d.ts +11 -0
- package/dist/components/verdocs-envelopes-list.js +298 -0
- package/dist/components/verdocs-sign.js +1 -1
- package/dist/components/verdocs-status-indicator.js +1 -7463
- package/dist/components/verdocs-status-indicator2.js +7465 -0
- package/dist/components/verdocs-template-field-properties2.js +27 -13
- package/dist/components/verdocs-template-fields2.js +1 -1
- package/dist/components/verdocs-templates-list.d.ts +11 -0
- package/dist/components/verdocs-templates-list.js +120 -0
- package/dist/components/verdocs-view2.js +2 -2
- package/dist/docs.json +530 -3
- package/dist/esm/DateTime-402fe7ca.js +43 -0
- package/dist/esm/{EnvelopeStore-28f5d8f5.js → EnvelopeStore-2a74a367.js} +1 -1
- package/dist/esm/{Envelopes-105a4a8f.js → Envelopes-e69b678a.js} +17 -1
- package/dist/esm/{Permissions-7192ef7c.js → Permissions-2ac18553.js} +13 -1
- package/dist/esm/loader.js +1 -1
- package/dist/esm/{utils-60683446.js → utils-8ae39b63.js} +2 -2
- package/dist/esm/verdocs-activity-box.entry.js +87 -0
- package/dist/esm/verdocs-button-panel_3.entry.js +25 -12
- package/dist/esm/verdocs-dropdown.entry.js +84 -0
- package/dist/esm/{verdocs-dropdown_2.entry.js → verdocs-envelope-document-page.entry.js} +3 -84
- package/dist/esm/verdocs-envelope-recipient-summary.entry.js +3 -3
- package/dist/esm/verdocs-envelope-sidebar.entry.js +3 -3
- package/dist/esm/verdocs-envelopes-list.entry.js +229 -0
- package/dist/esm/verdocs-field-checkbox.entry.js +2 -2
- package/dist/esm/verdocs-field-date.entry.js +2 -2
- package/dist/esm/verdocs-field-dropdown.entry.js +2 -2
- package/dist/esm/verdocs-field-initial.entry.js +2 -2
- package/dist/esm/verdocs-field-payment.entry.js +2 -2
- package/dist/esm/verdocs-field-radio-button.entry.js +2 -2
- package/dist/esm/verdocs-field-signature.entry.js +2 -2
- package/dist/esm/verdocs-field-textarea.entry.js +2 -2
- package/dist/esm/verdocs-field-textbox.entry.js +2 -2
- package/dist/esm/verdocs-field-timestamp.entry.js +2 -2
- package/dist/esm/verdocs-preview.entry.js +2 -2
- package/dist/esm/verdocs-send.entry.js +2 -2
- package/dist/esm/verdocs-sign.entry.js +2 -2
- package/dist/esm/verdocs-template-document-page_2.entry.js +2 -2
- package/dist/esm/verdocs-template-fields_4.entry.js +2 -2
- package/dist/esm/verdocs-templates-list.entry.js +87 -0
- package/dist/esm/verdocs-view.entry.js +3 -3
- package/dist/esm/verdocs-web-sdk.js +1 -1
- package/dist/esm-es5/DateTime-402fe7ca.js +1 -0
- package/dist/esm-es5/{EnvelopeStore-28f5d8f5.js → EnvelopeStore-2a74a367.js} +1 -1
- package/dist/esm-es5/Envelopes-e69b678a.js +1 -0
- package/dist/esm-es5/{Permissions-7192ef7c.js → Permissions-2ac18553.js} +1 -1
- package/dist/esm-es5/loader.js +1 -1
- package/dist/esm-es5/{utils-60683446.js → utils-8ae39b63.js} +2 -2
- package/dist/esm-es5/verdocs-activity-box.entry.js +1 -0
- package/dist/esm-es5/verdocs-button-panel_3.entry.js +1 -1
- package/dist/esm-es5/verdocs-dropdown.entry.js +1 -0
- package/dist/esm-es5/verdocs-envelope-document-page.entry.js +1 -0
- package/dist/esm-es5/verdocs-envelope-recipient-summary.entry.js +1 -1
- package/dist/esm-es5/verdocs-envelope-sidebar.entry.js +1 -1
- package/dist/esm-es5/verdocs-envelopes-list.entry.js +1 -0
- package/dist/esm-es5/verdocs-field-checkbox.entry.js +1 -1
- package/dist/esm-es5/verdocs-field-date.entry.js +1 -1
- package/dist/esm-es5/verdocs-field-dropdown.entry.js +1 -1
- package/dist/esm-es5/verdocs-field-initial.entry.js +1 -1
- package/dist/esm-es5/verdocs-field-payment.entry.js +1 -1
- package/dist/esm-es5/verdocs-field-radio-button.entry.js +1 -1
- package/dist/esm-es5/verdocs-field-signature.entry.js +1 -1
- package/dist/esm-es5/verdocs-field-textarea.entry.js +1 -1
- package/dist/esm-es5/verdocs-field-textbox.entry.js +1 -1
- package/dist/esm-es5/verdocs-field-timestamp.entry.js +1 -1
- package/dist/esm-es5/verdocs-preview.entry.js +1 -1
- package/dist/esm-es5/verdocs-send.entry.js +1 -1
- package/dist/esm-es5/verdocs-sign.entry.js +1 -1
- package/dist/esm-es5/verdocs-template-document-page_2.entry.js +1 -1
- package/dist/esm-es5/verdocs-template-fields_4.entry.js +1 -1
- package/dist/esm-es5/verdocs-templates-list.entry.js +1 -0
- package/dist/esm-es5/verdocs-view.entry.js +1 -1
- package/dist/esm-es5/verdocs-web-sdk.js +1 -1
- package/dist/types/components/envelopes/verdocs-activity-box/verdocs-activity-box.d.ts +60 -0
- package/dist/types/components/envelopes/verdocs-activity-box/verdocs-activity-box.stories.d.ts +10 -0
- package/dist/types/components/envelopes/verdocs-envelopes-list/verdocs-envelopes-list.d.ts +76 -0
- package/dist/types/components/envelopes/verdocs-envelopes-list/verdocs-envelopes-list.stories.d.ts +10 -0
- package/dist/types/components/templates/verdocs-template-field-properties/verdocs-template-field-properties.d.ts +3 -2
- package/dist/types/components/templates/verdocs-templates-list/verdocs-templates-list.d.ts +55 -0
- package/dist/types/components/templates/verdocs-templates-list/verdocs-templates-list.stories.d.ts +7 -0
- package/dist/types/components.d.ts +199 -2
- package/dist/verdocs-web-sdk/p-0a5390c7.js +1 -0
- package/dist/verdocs-web-sdk/{p-4a3b037b.system.entry.js → p-0aaca8d5.system.entry.js} +1 -1
- package/dist/verdocs-web-sdk/{p-a3c06b62.entry.js → p-0f8c70ec.entry.js} +1 -1
- package/dist/verdocs-web-sdk/{p-49b3ac56.entry.js → p-10e8d145.entry.js} +1 -1
- package/dist/verdocs-web-sdk/{p-02a70b8e.system.entry.js → p-13200610.system.entry.js} +1 -1
- package/dist/verdocs-web-sdk/p-138fd801.system.js +1 -0
- package/dist/verdocs-web-sdk/p-16baf630.entry.js +1 -0
- package/dist/verdocs-web-sdk/p-18a67b44.system.js +1 -0
- package/dist/verdocs-web-sdk/{p-5cff98bd.entry.js → p-19e1c76a.entry.js} +1 -1
- package/dist/verdocs-web-sdk/{p-94365585.entry.js → p-1ae77200.entry.js} +1 -1
- package/dist/verdocs-web-sdk/p-1cf38cea.system.js +1 -1
- package/dist/verdocs-web-sdk/{p-f0db17e6.system.entry.js → p-208b2e94.system.entry.js} +1 -1
- package/dist/verdocs-web-sdk/{p-1f561c42.entry.js → p-22939ee9.entry.js} +1 -1
- package/dist/verdocs-web-sdk/p-244414ca.entry.js +1 -0
- package/dist/verdocs-web-sdk/p-2672bfb4.system.entry.js +1 -0
- package/dist/verdocs-web-sdk/{p-7850f739.system.entry.js → p-2750155d.system.entry.js} +1 -1
- package/dist/verdocs-web-sdk/{p-9c87f6f8.system.entry.js → p-2d32da1d.system.entry.js} +1 -1
- package/dist/verdocs-web-sdk/{p-c3ef7b4f.entry.js → p-2d7d69a2.entry.js} +1 -1
- package/dist/verdocs-web-sdk/p-2f0cd03d.system.js +1 -0
- package/dist/verdocs-web-sdk/{p-33640d84.entry.js → p-31a49d0c.entry.js} +1 -1
- package/dist/verdocs-web-sdk/{p-e2635788.system.entry.js → p-31e3d00e.system.entry.js} +1 -1
- package/dist/verdocs-web-sdk/{p-fa6b1145.system.js → p-3c6f9c7f.system.js} +2 -2
- package/dist/verdocs-web-sdk/{p-be6d3848.entry.js → p-3f9d879c.entry.js} +1 -1
- package/dist/verdocs-web-sdk/p-4083d24f.system.entry.js +1 -0
- package/dist/verdocs-web-sdk/{p-18ee4fd5.js → p-4391cd11.js} +1 -1
- package/dist/verdocs-web-sdk/{p-6a44fb56.system.entry.js → p-4e025c82.system.entry.js} +1 -1
- package/dist/verdocs-web-sdk/{p-fdda1309.entry.js → p-4f0bf0de.entry.js} +1 -1
- package/dist/verdocs-web-sdk/{p-2c0d7838.system.entry.js → p-51cfde70.system.entry.js} +1 -1
- package/dist/verdocs-web-sdk/p-522127c8.entry.js +1 -0
- package/dist/verdocs-web-sdk/{p-095a3eba.system.entry.js → p-57ee65dc.system.entry.js} +1 -1
- package/dist/verdocs-web-sdk/p-68662f17.entry.js +1 -0
- package/dist/verdocs-web-sdk/{p-8e386265.entry.js → p-6c01e798.entry.js} +1 -1
- package/dist/verdocs-web-sdk/{p-fcfd3193.system.entry.js → p-8080f854.system.entry.js} +1 -1
- package/dist/verdocs-web-sdk/p-87cf1148.entry.js +1 -0
- package/dist/verdocs-web-sdk/p-89aac159.system.entry.js +1 -0
- package/dist/verdocs-web-sdk/{p-f9bea98a.js → p-8ec8d450.js} +2 -2
- package/dist/verdocs-web-sdk/{p-afa1f20b.system.entry.js → p-95fc08e1.system.entry.js} +1 -1
- package/dist/verdocs-web-sdk/p-9e9ab67f.entry.js +1 -0
- package/dist/verdocs-web-sdk/p-aa3fd489.entry.js +1 -0
- package/dist/verdocs-web-sdk/{p-44ec0583.entry.js → p-ac58dba7.entry.js} +1 -1
- package/dist/verdocs-web-sdk/{p-3fe24d0c.system.entry.js → p-ad7f71cf.system.entry.js} +1 -1
- package/dist/verdocs-web-sdk/{p-8c5ffa7b.system.entry.js → p-afeff3d1.system.entry.js} +1 -1
- package/dist/verdocs-web-sdk/p-b43d0cd6.system.entry.js +1 -0
- package/dist/verdocs-web-sdk/{p-9d7fa51d.system.entry.js → p-b56feb8c.system.entry.js} +1 -1
- package/dist/verdocs-web-sdk/{p-a4cbba4a.entry.js → p-be3c4aa9.entry.js} +1 -1
- package/dist/verdocs-web-sdk/p-c16d1ce1.js +1 -0
- package/dist/verdocs-web-sdk/p-c6e4d0fc.system.entry.js +1 -0
- package/dist/verdocs-web-sdk/{p-380efff2.system.entry.js → p-c6f6fe4f.system.entry.js} +1 -1
- package/dist/verdocs-web-sdk/{p-decf6a56.entry.js → p-cafd699c.entry.js} +1 -1
- package/dist/verdocs-web-sdk/{p-717c9fe1.entry.js → p-cc3ff9dc.entry.js} +1 -1
- package/dist/verdocs-web-sdk/{p-0aee25b9.entry.js → p-cd1e5de4.entry.js} +1 -1
- package/dist/verdocs-web-sdk/{p-813c2fae.system.entry.js → p-d35f7faa.system.entry.js} +1 -1
- package/dist/verdocs-web-sdk/p-d5316866.entry.js +1 -0
- package/dist/verdocs-web-sdk/{p-13959c36.system.entry.js → p-e59117c8.system.entry.js} +1 -1
- package/dist/verdocs-web-sdk/p-e82a7328.js +1 -0
- package/dist/verdocs-web-sdk/p-e8418235.entry.js +1 -0
- package/dist/verdocs-web-sdk/p-ee84ffc0.system.js +1 -0
- package/dist/verdocs-web-sdk/{p-f2b225b7.system.entry.js → p-f0749d37.system.entry.js} +1 -1
- package/dist/verdocs-web-sdk/p-f1accb35.system.entry.js +1 -0
- package/dist/verdocs-web-sdk/verdocs-web-sdk.esm.js +1 -1
- package/package.json +2 -2
- package/dist/esm-es5/Envelopes-105a4a8f.js +0 -1
- package/dist/esm-es5/verdocs-dropdown_2.entry.js +0 -1
- package/dist/verdocs-web-sdk/p-0e381c36.entry.js +0 -1
- package/dist/verdocs-web-sdk/p-66f9132c.system.entry.js +0 -1
- package/dist/verdocs-web-sdk/p-73ea1ea3.entry.js +0 -1
- package/dist/verdocs-web-sdk/p-7a23c2c8.system.js +0 -1
- package/dist/verdocs-web-sdk/p-8c57f5d0.system.js +0 -1
- package/dist/verdocs-web-sdk/p-8fd812f4.system.js +0 -1
- package/dist/verdocs-web-sdk/p-a6e5814e.entry.js +0 -1
- package/dist/verdocs-web-sdk/p-cf790f4f.js +0 -1
- package/dist/verdocs-web-sdk/p-d4c8f358.entry.js +0 -1
- package/dist/verdocs-web-sdk/p-d869c39c.js +0 -1
- package/dist/verdocs-web-sdk/p-daf19924.entry.js +0 -1
- package/dist/verdocs-web-sdk/p-e727af9c.system.entry.js +0 -1
@@ -0,0 +1,474 @@
|
|
1
|
+
import { VerdocsEndpoint } from '@verdocs/js-sdk';
|
2
|
+
import { Envelopes } from '@verdocs/js-sdk/Envelopes';
|
3
|
+
import { Host, h } from '@stencil/core';
|
4
|
+
import { cancelEnvelope } from '@verdocs/js-sdk/Envelopes/Envelopes';
|
5
|
+
import { getRecipientsWithActions, userCanAct, userCanCancelEnvelope } from '@verdocs/js-sdk/Envelopes/Permissions';
|
6
|
+
import { saveEnvelopesAsZip } from '../../../utils/utils';
|
7
|
+
import { VerdocsToast } from '../../../utils/Toast';
|
8
|
+
import { SDKError } from '../../../utils/errors';
|
9
|
+
const DocumentIcon = `<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="1.5"><path stroke-linecap="round" stroke-linejoin="round" d="M9 12h3.75M9 15h3.75M9 18h3.75m3 .75H18a2.25 2.25 0 002.25-2.25V6.108c0-1.135-.845-2.098-1.976-2.192a48.424 48.424 0 00-1.123-.08m-5.801 0c-.065.21-.1.433-.1.664 0 .414.336.75.75.75h4.5a.75.75 0 00.75-.75 2.25 2.25 0 00-.1-.664m-5.8 0A2.251 2.251 0 0113.5 2.25H15c1.012 0 1.867.668 2.15 1.586m-5.8 0c-.376.023-.75.05-1.124.08C9.095 4.01 8.25 4.973 8.25 6.108V8.25m0 0H4.875c-.621 0-1.125.504-1.125 1.125v11.25c0 .621.504 1.125 1.125 1.125h9.75c.621 0 1.125-.504 1.125-1.125V9.375c0-.621-.504-1.125-1.125-1.125H8.25zM6.75 12h.008v.008H6.75V12zm0 3h.008v.008H6.75V15zm0 3h.008v.008H6.75V18z" /></svg>`;
|
10
|
+
// const ViewFilters: [string, string][] = [
|
11
|
+
// ['all', 'All'],
|
12
|
+
// ['inbox', 'Inbox'],
|
13
|
+
// ['sent', 'Sent'],
|
14
|
+
// ['completed', 'Completed'],
|
15
|
+
// ['action', 'Action Required'],
|
16
|
+
// ['waiting', 'Waiting on Others'],
|
17
|
+
// ];
|
18
|
+
//
|
19
|
+
// const StatusFilters: [string, string][] = [
|
20
|
+
// ['all', 'All'],
|
21
|
+
// ['pending', 'Pending'],
|
22
|
+
// ['in progress', 'In Progress'],
|
23
|
+
// ['complete', 'Completed'],
|
24
|
+
// ['declined', 'Declined'],
|
25
|
+
// ['canceled', 'Canceled'],
|
26
|
+
// ];
|
27
|
+
//
|
28
|
+
// const SortFilters: [string, string][] = [
|
29
|
+
// ['created_at', 'Created'],
|
30
|
+
// ['updated_at', 'Updated'],
|
31
|
+
// ['canceled_at', 'Canceled'],
|
32
|
+
// ['envelope_name', 'Name'],
|
33
|
+
// ['envelope_status', 'Status'],
|
34
|
+
// ];
|
35
|
+
/**
|
36
|
+
* Displays a list of envelopes matching specified conditions.
|
37
|
+
*/
|
38
|
+
export class VerdocsEnvelopesList {
|
39
|
+
constructor() {
|
40
|
+
this.endpoint = VerdocsEndpoint.getDefault();
|
41
|
+
this.items = 5;
|
42
|
+
this.view = undefined;
|
43
|
+
this.status = 'all';
|
44
|
+
this.sortBy = 'updated_at';
|
45
|
+
this.page = 0;
|
46
|
+
this.count = 0;
|
47
|
+
this.loading = true;
|
48
|
+
this.name = '';
|
49
|
+
this.containing = '';
|
50
|
+
this.selectedEnvelopes = [];
|
51
|
+
this.envelopes = [];
|
52
|
+
}
|
53
|
+
async componentWillLoad() {
|
54
|
+
var _a, _b, _c;
|
55
|
+
try {
|
56
|
+
this.endpoint.loadSession();
|
57
|
+
if (!this.endpoint.session) {
|
58
|
+
console.log('[ENVELOPES] Must be authenticated');
|
59
|
+
return;
|
60
|
+
}
|
61
|
+
let queryParams = {
|
62
|
+
page: this.page,
|
63
|
+
limit: Math.min(Math.max(this.items, 1), 50),
|
64
|
+
ascending: false,
|
65
|
+
sort_by: 'updated_at',
|
66
|
+
};
|
67
|
+
switch (this.view) {
|
68
|
+
case 'inbox':
|
69
|
+
queryParams = {
|
70
|
+
...queryParams,
|
71
|
+
is_recipient: true,
|
72
|
+
sort_by: 'created_at',
|
73
|
+
recipient_status: ['invited', 'declined', 'opened', 'signed', 'submitted', 'canceled'],
|
74
|
+
};
|
75
|
+
break;
|
76
|
+
case 'sent':
|
77
|
+
queryParams = {
|
78
|
+
...queryParams,
|
79
|
+
is_owner: true,
|
80
|
+
sort_by: 'created_at',
|
81
|
+
};
|
82
|
+
break;
|
83
|
+
case 'action':
|
84
|
+
queryParams = {
|
85
|
+
...queryParams,
|
86
|
+
is_recipient: true,
|
87
|
+
envelope_status: ['pending', 'in progress'],
|
88
|
+
recipient_status: ['invited', 'opened', 'signed'],
|
89
|
+
};
|
90
|
+
break;
|
91
|
+
case 'waiting':
|
92
|
+
queryParams = {
|
93
|
+
...queryParams,
|
94
|
+
is_owner: true,
|
95
|
+
envelope_status: ['pending', 'in progress'],
|
96
|
+
};
|
97
|
+
break;
|
98
|
+
case 'completed':
|
99
|
+
queryParams = {
|
100
|
+
...queryParams,
|
101
|
+
envelope_status: ['complete'],
|
102
|
+
};
|
103
|
+
break;
|
104
|
+
default:
|
105
|
+
queryParams = {
|
106
|
+
...queryParams,
|
107
|
+
envelope_status: (this.status === 'all' ? ['pending', 'in progress', 'complete', 'declined', 'canceled'] : [this.status]),
|
108
|
+
};
|
109
|
+
}
|
110
|
+
// These filters should only be applied in "View All" mode. Otherwise the user could have set them to something
|
111
|
+
// then changed the view e.g. to Inbox and the filter could break the view (e.g. View:Inbox, Status:Declined
|
112
|
+
// would never return anything).
|
113
|
+
if (this.view === 'all') {
|
114
|
+
if (this.status !== 'all') {
|
115
|
+
queryParams.envelope_status = [this.status];
|
116
|
+
}
|
117
|
+
}
|
118
|
+
if (this.name.trim()) {
|
119
|
+
queryParams.name = this.name.trim();
|
120
|
+
}
|
121
|
+
if (this.containing.trim()) {
|
122
|
+
queryParams.text_field_value = this.containing.trim();
|
123
|
+
}
|
124
|
+
const response = await Envelopes.searchEnvelopes(this.endpoint, queryParams);
|
125
|
+
console.log('[ACTIVITIES] Got envelopes', response);
|
126
|
+
this.envelopes = response.result;
|
127
|
+
this.count = response.total;
|
128
|
+
this.loading = false;
|
129
|
+
// let queryParams: IEnvelopeSearchParams = {
|
130
|
+
// page: 0,
|
131
|
+
// ascending: false,
|
132
|
+
// sort_by: 'updated_at',
|
133
|
+
// limit: Math.max(Math.min(this.items, 30), 1),
|
134
|
+
// };
|
135
|
+
//
|
136
|
+
// let defaultHeader;
|
137
|
+
// switch (this.view) {
|
138
|
+
// case 'action':
|
139
|
+
// queryParams = {...queryParams, is_recipient: true, envelope_status: ['pending', 'in progress'], recipient_status: ['invited', 'opened', 'signed']};
|
140
|
+
// defaultHeader = 'Action Required';
|
141
|
+
//
|
142
|
+
// break;
|
143
|
+
//
|
144
|
+
// case 'waiting':
|
145
|
+
// queryParams = {...queryParams, is_owner: true, ascending: false, envelope_status: ['pending', 'in progress']};
|
146
|
+
// defaultHeader = 'Waiting on Others';
|
147
|
+
// break;
|
148
|
+
//
|
149
|
+
// case 'completed':
|
150
|
+
// default:
|
151
|
+
// queryParams = {...queryParams, envelope_status: ['complete']};
|
152
|
+
// defaultHeader = 'Completed';
|
153
|
+
// break;
|
154
|
+
// }
|
155
|
+
//
|
156
|
+
// this.title = this.header !== undefined ? this.header : defaultHeader;
|
157
|
+
//
|
158
|
+
// const response = await Envelopes.searchEnvelopes(this.endpoint, queryParams);
|
159
|
+
// console.log('[ENVELOPES] Got envelopes', response);
|
160
|
+
// this.envelopes = response.result;
|
161
|
+
// this.count = response.total;
|
162
|
+
// this.loading = false;
|
163
|
+
}
|
164
|
+
catch (e) {
|
165
|
+
console.log('[ENVELOPES] Error with preview session', e);
|
166
|
+
(_a = this.sdkError) === null || _a === void 0 ? void 0 : _a.emit(new SDKError(e.message, (_b = e.response) === null || _b === void 0 ? void 0 : _b.status, (_c = e.response) === null || _c === void 0 ? void 0 : _c.data));
|
167
|
+
}
|
168
|
+
}
|
169
|
+
handleDownload() {
|
170
|
+
saveEnvelopesAsZip(VerdocsEndpoint.getDefault(), this.selectedEnvelopes)
|
171
|
+
.then(() => {
|
172
|
+
this.selectedEnvelopes = [];
|
173
|
+
})
|
174
|
+
.catch(e => {
|
175
|
+
console.log('Download error', e);
|
176
|
+
VerdocsToast('Download error: ' + e.message, { style: 'error' });
|
177
|
+
});
|
178
|
+
}
|
179
|
+
downloadEnvelope(envelope) {
|
180
|
+
saveEnvelopesAsZip(VerdocsEndpoint.getDefault(), [envelope]).catch(e => {
|
181
|
+
console.log('Download error', e);
|
182
|
+
VerdocsToast('Download error: ' + e.message, { style: 'error' });
|
183
|
+
});
|
184
|
+
}
|
185
|
+
render() {
|
186
|
+
if (this.loading) {
|
187
|
+
return (h(Host, { style: { minHeight: '300px' } }, h("verdocs-loader", null)));
|
188
|
+
}
|
189
|
+
return (h(Host, null, h("div", { class: "header" }, h("div", { class: "filter" }, h("verdocs-text-input", { id: "verdocs-filter-name", value: this.name, autocomplete: "off", placeholder: "Filter by Name...", onInput: (e) => {
|
190
|
+
this.name = e.target.value;
|
191
|
+
} })), h("div", { class: "flex flex-row gap-3 items-center" }, h("div", { class: "filter" }, h("verdocs-text-input", { id: "verdocs-filter-containing", value: this.containing, autocomplete: "off", placeholder: "Fields Containing...", onInput: (e) => {
|
192
|
+
this.containing = e.target.value;
|
193
|
+
} }))), h("div", { class: "flex flex-1" }), this.selectedEnvelopes.length > 0 && h("verdocs-button", { label: `Download (${this.selectedEnvelopes.length})`, onClick: () => this.handleDownload() })), this.envelopes.map(envelope => {
|
194
|
+
var _a;
|
195
|
+
const recipientsWithActions = getRecipientsWithActions(envelope);
|
196
|
+
const userCanCancel = userCanCancelEnvelope(this.endpoint.session, envelope);
|
197
|
+
const userRole = recipientsWithActions.find(recipient => { var _a; return recipient.email === ((_a = this.endpoint.session) === null || _a === void 0 ? void 0 : _a.email) || ''; });
|
198
|
+
const userCanFinish = userRole && userCanCancel && userCanAct(((_a = this.endpoint.session) === null || _a === void 0 ? void 0 : _a.email) || '', recipientsWithActions);
|
199
|
+
return (h("div", { class: "envelope", key: envelope.id, onClick: () => { var _a; return (_a = this.viewEnvelope) === null || _a === void 0 ? void 0 : _a.emit({ endpoint: this.endpoint, envelope }); } }, h("div", { class: "inner" }, h("verdocs-checkbox", { checked: this.selectedEnvelopes.findIndex(e => e.id === envelope.id) !== -1, onClick: e => e.stopPropagation(), onInput: (e) => {
|
200
|
+
if (e.target.checked) {
|
201
|
+
this.selectedEnvelopes = [...this.selectedEnvelopes, envelope];
|
202
|
+
}
|
203
|
+
else {
|
204
|
+
this.selectedEnvelopes = this.selectedEnvelopes.filter(e => e.id !== envelope.id);
|
205
|
+
}
|
206
|
+
} }), h("div", { class: "vert-spacer" }), h("span", { innerHTML: DocumentIcon }), h("div", { class: "envelope-name" }, envelope.name, ":\u00A0 ", h("div", { class: "envelope-recipients" }, envelope.recipients.map(r => r.full_name).join(', '))), h("div", { class: "vert-spacer" }), h("verdocs-status-indicator", { envelope: envelope, style: { width: '125px' } }), h("div", { class: "vert-spacer" }), h("div", { class: "last-modified" }, new Date(envelope.updated_at).toLocaleString()), h("div", { class: "vert-spacer" }), h("verdocs-dropdown", { options: [
|
207
|
+
{ label: 'View Envelope', id: 'view' },
|
208
|
+
{ label: 'Finish Envelope', id: 'finish', disabled: !userCanFinish },
|
209
|
+
{ label: 'Download', id: 'download' },
|
210
|
+
{ label: 'Cancel', id: 'cancel', disabled: !userCanCancel },
|
211
|
+
], onOptionSelected: e => {
|
212
|
+
var _a, _b;
|
213
|
+
switch (e.detail.id) {
|
214
|
+
case 'view':
|
215
|
+
(_a = this.viewEnvelope) === null || _a === void 0 ? void 0 : _a.emit({ endpoint: this.endpoint, envelope });
|
216
|
+
break;
|
217
|
+
case 'finish':
|
218
|
+
(_b = this.finishLater) === null || _b === void 0 ? void 0 : _b.emit({ endpoint: this.endpoint, envelope });
|
219
|
+
break;
|
220
|
+
case 'download':
|
221
|
+
this.downloadEnvelope(envelope);
|
222
|
+
break;
|
223
|
+
case 'cancel':
|
224
|
+
if (window.confirm('Are you sure you want to cancel this envelope?')) {
|
225
|
+
cancelEnvelope(this.endpoint, envelope.id)
|
226
|
+
.then(r => {
|
227
|
+
console.log('Cancel result', r);
|
228
|
+
VerdocsToast('Envelope canceled');
|
229
|
+
})
|
230
|
+
.catch(e => {
|
231
|
+
console.log('cxl error', e);
|
232
|
+
VerdocsToast('Unable to cancel envelope: ' + e.messabge, { style: 'error' });
|
233
|
+
});
|
234
|
+
}
|
235
|
+
break;
|
236
|
+
}
|
237
|
+
} }))));
|
238
|
+
}), !this.envelopes.length ? (h("div", { class: "mt-4 border-2 px-20 py-20 text-center" }, "No matching envelopes found. Please adjust your filters and try again.")) : (h("div", null)
|
239
|
+
// <Pagination page={this.page} total={this.count} onSelectPage={setPage} />
|
240
|
+
)));
|
241
|
+
}
|
242
|
+
static get is() { return "verdocs-envelopes-list"; }
|
243
|
+
static get originalStyleUrls() {
|
244
|
+
return {
|
245
|
+
"$": ["verdocs-envelopes-list.scss"]
|
246
|
+
};
|
247
|
+
}
|
248
|
+
static get styleUrls() {
|
249
|
+
return {
|
250
|
+
"$": ["verdocs-envelopes-list.css"]
|
251
|
+
};
|
252
|
+
}
|
253
|
+
static get properties() {
|
254
|
+
return {
|
255
|
+
"endpoint": {
|
256
|
+
"type": "unknown",
|
257
|
+
"mutable": false,
|
258
|
+
"complexType": {
|
259
|
+
"original": "VerdocsEndpoint",
|
260
|
+
"resolved": "VerdocsEndpoint",
|
261
|
+
"references": {
|
262
|
+
"VerdocsEndpoint": {
|
263
|
+
"location": "import",
|
264
|
+
"path": "@verdocs/js-sdk"
|
265
|
+
}
|
266
|
+
}
|
267
|
+
},
|
268
|
+
"required": false,
|
269
|
+
"optional": false,
|
270
|
+
"docs": {
|
271
|
+
"tags": [],
|
272
|
+
"text": "The endpoint to use to communicate with Verdocs. If not set, the default endpoint will be used."
|
273
|
+
},
|
274
|
+
"defaultValue": "VerdocsEndpoint.getDefault()"
|
275
|
+
},
|
276
|
+
"items": {
|
277
|
+
"type": "number",
|
278
|
+
"mutable": false,
|
279
|
+
"complexType": {
|
280
|
+
"original": "number",
|
281
|
+
"resolved": "number",
|
282
|
+
"references": {}
|
283
|
+
},
|
284
|
+
"required": false,
|
285
|
+
"optional": false,
|
286
|
+
"docs": {
|
287
|
+
"tags": [],
|
288
|
+
"text": "The number of items to display."
|
289
|
+
},
|
290
|
+
"attribute": "items",
|
291
|
+
"reflect": false,
|
292
|
+
"defaultValue": "5"
|
293
|
+
},
|
294
|
+
"view": {
|
295
|
+
"type": "string",
|
296
|
+
"mutable": false,
|
297
|
+
"complexType": {
|
298
|
+
"original": "'all' | 'inbox' | 'sent' | 'completed' | 'action' | 'waiting'",
|
299
|
+
"resolved": "\"action\" | \"all\" | \"completed\" | \"inbox\" | \"sent\" | \"waiting\"",
|
300
|
+
"references": {}
|
301
|
+
},
|
302
|
+
"required": false,
|
303
|
+
"optional": true,
|
304
|
+
"docs": {
|
305
|
+
"tags": [],
|
306
|
+
"text": "The filtered view to display. \"completed\" will show envelopes that have been submitted. \"action\" will\nshow envelopes where the user is a recipient and the envelope is not completed. \"waiting\" will show\nonly envelopes where the user is the sender and the envelope is not completed."
|
307
|
+
},
|
308
|
+
"attribute": "view",
|
309
|
+
"reflect": true,
|
310
|
+
"defaultValue": "undefined"
|
311
|
+
},
|
312
|
+
"status": {
|
313
|
+
"type": "string",
|
314
|
+
"mutable": false,
|
315
|
+
"complexType": {
|
316
|
+
"original": "TEnvelopeStatus | 'all'",
|
317
|
+
"resolved": "\"all\" | \"canceled\" | \"complete\" | \"declined\" | \"in progress\" | \"pending\"",
|
318
|
+
"references": {
|
319
|
+
"TEnvelopeStatus": {
|
320
|
+
"location": "import",
|
321
|
+
"path": "@verdocs/js-sdk/Envelopes/Types"
|
322
|
+
}
|
323
|
+
}
|
324
|
+
},
|
325
|
+
"required": false,
|
326
|
+
"optional": false,
|
327
|
+
"docs": {
|
328
|
+
"tags": [],
|
329
|
+
"text": "The status value to filter by"
|
330
|
+
},
|
331
|
+
"attribute": "status",
|
332
|
+
"reflect": true,
|
333
|
+
"defaultValue": "'all'"
|
334
|
+
},
|
335
|
+
"sortBy": {
|
336
|
+
"type": "string",
|
337
|
+
"mutable": false,
|
338
|
+
"complexType": {
|
339
|
+
"original": "'created_at' | 'updated_at' | 'envelope_name' | 'canceled_at' | 'envelope_status'",
|
340
|
+
"resolved": "\"canceled_at\" | \"created_at\" | \"envelope_name\" | \"envelope_status\" | \"updated_at\"",
|
341
|
+
"references": {}
|
342
|
+
},
|
343
|
+
"required": false,
|
344
|
+
"optional": false,
|
345
|
+
"docs": {
|
346
|
+
"tags": [],
|
347
|
+
"text": "The sort field to use"
|
348
|
+
},
|
349
|
+
"attribute": "sort-by",
|
350
|
+
"reflect": true,
|
351
|
+
"defaultValue": "'updated_at'"
|
352
|
+
},
|
353
|
+
"page": {
|
354
|
+
"type": "number",
|
355
|
+
"mutable": false,
|
356
|
+
"complexType": {
|
357
|
+
"original": "number",
|
358
|
+
"resolved": "number",
|
359
|
+
"references": {}
|
360
|
+
},
|
361
|
+
"required": false,
|
362
|
+
"optional": false,
|
363
|
+
"docs": {
|
364
|
+
"tags": [],
|
365
|
+
"text": "The first page nymbver to display (0-based)"
|
366
|
+
},
|
367
|
+
"attribute": "page",
|
368
|
+
"reflect": true,
|
369
|
+
"defaultValue": "0"
|
370
|
+
}
|
371
|
+
};
|
372
|
+
}
|
373
|
+
static get states() {
|
374
|
+
return {
|
375
|
+
"count": {},
|
376
|
+
"loading": {},
|
377
|
+
"name": {},
|
378
|
+
"containing": {},
|
379
|
+
"selectedEnvelopes": {},
|
380
|
+
"envelopes": {}
|
381
|
+
};
|
382
|
+
}
|
383
|
+
static get events() {
|
384
|
+
return [{
|
385
|
+
"method": "sdkError",
|
386
|
+
"name": "sdkError",
|
387
|
+
"bubbles": true,
|
388
|
+
"cancelable": true,
|
389
|
+
"composed": true,
|
390
|
+
"docs": {
|
391
|
+
"tags": [],
|
392
|
+
"text": "Event fired if an error occurs. The event details will contain information about the error. Most errors will\nterminate the process, and the calling application should correct the condition and re-render the component."
|
393
|
+
},
|
394
|
+
"complexType": {
|
395
|
+
"original": "SDKError",
|
396
|
+
"resolved": "SDKError",
|
397
|
+
"references": {
|
398
|
+
"SDKError": {
|
399
|
+
"location": "import",
|
400
|
+
"path": "../../../utils/errors"
|
401
|
+
}
|
402
|
+
}
|
403
|
+
}
|
404
|
+
}, {
|
405
|
+
"method": "viewEnvelope",
|
406
|
+
"name": "viewEnvelope",
|
407
|
+
"bubbles": true,
|
408
|
+
"cancelable": true,
|
409
|
+
"composed": true,
|
410
|
+
"docs": {
|
411
|
+
"tags": [],
|
412
|
+
"text": "Event fired when the user clicks an activity entry. Typically the host application will use this to navigate\nto the envelope detail view."
|
413
|
+
},
|
414
|
+
"complexType": {
|
415
|
+
"original": "{endpoint: VerdocsEndpoint; envelope: IEnvelope}",
|
416
|
+
"resolved": "{ endpoint: VerdocsEndpoint; envelope: IEnvelope; }",
|
417
|
+
"references": {
|
418
|
+
"VerdocsEndpoint": {
|
419
|
+
"location": "import",
|
420
|
+
"path": "@verdocs/js-sdk"
|
421
|
+
},
|
422
|
+
"IEnvelope": {
|
423
|
+
"location": "import",
|
424
|
+
"path": "@verdocs/js-sdk/Envelopes/Types"
|
425
|
+
}
|
426
|
+
}
|
427
|
+
}
|
428
|
+
}, {
|
429
|
+
"method": "finishLater",
|
430
|
+
"name": "finishLater",
|
431
|
+
"bubbles": true,
|
432
|
+
"cancelable": true,
|
433
|
+
"composed": true,
|
434
|
+
"docs": {
|
435
|
+
"tags": [],
|
436
|
+
"text": "Event fired when the user clicks to finish signing later. Typically the host application should redirect\nthe user to another page."
|
437
|
+
},
|
438
|
+
"complexType": {
|
439
|
+
"original": "{endpoint: VerdocsEndpoint; envelope: IEnvelope}",
|
440
|
+
"resolved": "{ endpoint: VerdocsEndpoint; envelope: IEnvelope; }",
|
441
|
+
"references": {
|
442
|
+
"VerdocsEndpoint": {
|
443
|
+
"location": "import",
|
444
|
+
"path": "@verdocs/js-sdk"
|
445
|
+
},
|
446
|
+
"IEnvelope": {
|
447
|
+
"location": "import",
|
448
|
+
"path": "@verdocs/js-sdk/Envelopes/Types"
|
449
|
+
}
|
450
|
+
}
|
451
|
+
}
|
452
|
+
}, {
|
453
|
+
"method": "viewAll",
|
454
|
+
"name": "viewAll",
|
455
|
+
"bubbles": true,
|
456
|
+
"cancelable": true,
|
457
|
+
"composed": true,
|
458
|
+
"docs": {
|
459
|
+
"tags": [],
|
460
|
+
"text": "Event fired when the user clicks View All in the title bar. The current view will be included in the event\ndetails to help the host application navigate the user to the appropriate screen for the request. Note that\nthe verdocs-envelopes-list control uses the same \"view\" parameter, so host applications can typically pass\nthis value through directly. This button is not visible if the header is hidden."
|
461
|
+
},
|
462
|
+
"complexType": {
|
463
|
+
"original": "{endpoint: VerdocsEndpoint; view: string}",
|
464
|
+
"resolved": "{ endpoint: VerdocsEndpoint; view: string; }",
|
465
|
+
"references": {
|
466
|
+
"VerdocsEndpoint": {
|
467
|
+
"location": "import",
|
468
|
+
"path": "@verdocs/js-sdk"
|
469
|
+
}
|
470
|
+
}
|
471
|
+
}
|
472
|
+
}];
|
473
|
+
}
|
474
|
+
}
|
@@ -0,0 +1,18 @@
|
|
1
|
+
import { html } from 'lit-html';
|
2
|
+
export default {
|
3
|
+
title: 'Envelopes/Envelopes List',
|
4
|
+
component: 'verdocs-envelopes-list',
|
5
|
+
args: {
|
6
|
+
items: 10,
|
7
|
+
view: 'all',
|
8
|
+
sortBy: 'updated_at',
|
9
|
+
},
|
10
|
+
argTypes: {
|
11
|
+
onViewEnvelope: { action: 'viewEnvelope' },
|
12
|
+
onFinishLater: { action: 'finishLater' },
|
13
|
+
},
|
14
|
+
parameters: {
|
15
|
+
layout: 'fullscreen',
|
16
|
+
},
|
17
|
+
};
|
18
|
+
export const EnvelopesList = ({ items, view, sortBy, onViewEnvelope, onFinishLater }) => html `<verdocs-envelopes-list .items="${items}" .view="${view}" .sortBy="${sortBy}" @viewEnvelope=${onViewEnvelope} @finishlater=${onFinishLater} />`;
|
@@ -7,7 +7,6 @@ import { SDKError } from '../../../utils/errors';
|
|
7
7
|
const capitalize = (str) => str.charAt(0).toUpperCase() + str.slice(1);
|
8
8
|
const TrashIcon = `<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="1.5" stroke="#a50021"><path stroke-linecap="round" stroke-linejoin="round" d="M14.74 9l-.346 9m-4.788 0L9.26 9m9.968-3.21c.342.052.682.107 1.022.166m-1.022-.165L18.16 19.673a2.25 2.25 0 01-2.244 2.077H8.084a2.25 2.25 0 01-2.244-2.077L4.772 5.79m14.456 0a48.108 48.108 0 00-3.478-.397m-12 .562c.34-.059.68-.114 1.022-.165m0 0a48.11 48.11 0 013.478-.397m7.5 0v-.916c0-1.18-.91-2.164-2.09-2.201a51.964 51.964 0 00-3.32 0c-1.18.037-2.09 1.022-2.09 2.201v.916m7.5 0a48.667 48.667 0 00-7.5 0" /></svg>`;
|
9
9
|
const HelpIcon = '<svg xmlns="http://www.w3.org/2000/svg" height="24" width="24"><path d="M11.925 18q.55 0 .938-.387.387-.388.387-.938 0-.55-.387-.925-.388-.375-.938-.375-.55 0-.925.375t-.375.925q0 .55.375.938.375.387.925.387Zm-.95-3.85h1.95q0-.8.2-1.287.2-.488 1.025-1.288.65-.625 1.025-1.213.375-.587.375-1.437 0-1.425-1.025-2.175Q13.5 6 12.1 6q-1.425 0-2.35.775t-1.275 1.85l1.775.7q.125-.45.55-.975.425-.525 1.275-.525.725 0 1.1.412.375.413.375.888 0 .475-.287.9-.288.425-.713.775-1.075.95-1.325 1.475-.25.525-.25 1.875ZM12 22.2q-2.125 0-3.988-.8-1.862-.8-3.237-2.175Q3.4 17.85 2.6 15.988 1.8 14.125 1.8 12t.8-3.988q.8-1.862 2.175-3.237Q6.15 3.4 8.012 2.6 9.875 1.8 12 1.8t3.988.8q1.862.8 3.237 2.175Q20.6 6.15 21.4 8.012q.8 1.863.8 3.988t-.8 3.988q-.8 1.862-2.175 3.237Q17.85 20.6 15.988 21.4q-1.863.8-3.988.8Zm0-2.275q3.325 0 5.625-2.3t2.3-5.625q0-3.325-2.3-5.625T12 4.075q-3.325 0-5.625 2.3T4.075 12q0 3.325 2.3 5.625t5.625 2.3ZM12 12Z"/></svg>';
|
10
|
-
// const PlusIcon = `<svg xmlns="http://www.w3.org/2000/svg" fill="#ffffff" viewBox="0 0 24 24" strokeWidth={1.5} stroke="currentColor"><path strokeLinecap="round" strokeLinejoin="round" d="M12 9v6m3-3H9m12 0a9 9 0 11-18 0 9 9 0 0118 0z" /></svg>`;
|
11
10
|
/**
|
12
11
|
* Displays an edit form that allows the user to adjust a field's settings.
|
13
12
|
*/
|
@@ -29,11 +28,12 @@ export class VerdocsTemplateFieldProperties {
|
|
29
28
|
this.required = false;
|
30
29
|
this.options = [];
|
31
30
|
this.placeholder = '';
|
32
|
-
this.
|
31
|
+
this.value = '';
|
32
|
+
this.leading = 0;
|
33
33
|
this.showingHelp = false;
|
34
34
|
}
|
35
35
|
async componentWillLoad() {
|
36
|
-
var _a, _b, _c, _d, _e, _f, _g;
|
36
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j;
|
37
37
|
try {
|
38
38
|
this.endpoint.loadSession();
|
39
39
|
if (!this.templateId) {
|
@@ -59,32 +59,36 @@ export class VerdocsTemplateFieldProperties {
|
|
59
59
|
this.roleName = field.role_name;
|
60
60
|
this.required = field.required;
|
61
61
|
this.fieldType = field.type;
|
62
|
-
|
63
|
-
this.
|
62
|
+
// TODO: Talk about how we want to handle labels/placeholders
|
63
|
+
this.placeholder = ((_c = field.setting) === null || _c === void 0 ? void 0 : _c.placeholder) || '';
|
64
|
+
this.value = ((_d = field.setting) === null || _d === void 0 ? void 0 : _d.result) || '';
|
65
|
+
this.leading = ((_e = field.setting) === null || _e === void 0 ? void 0 : _e.leading) || 0;
|
64
66
|
this.setting = field.setting || {};
|
65
|
-
this.options = ((
|
67
|
+
this.options = ((_f = field.setting) === null || _f === void 0 ? void 0 : _f.options) || [];
|
66
68
|
this.dirty = false;
|
67
69
|
this.loading = false;
|
68
70
|
}
|
69
71
|
catch (e) {
|
70
72
|
console.log('[FIELD PROPERTIES] Error loading template', e);
|
71
73
|
this.loading = false;
|
72
|
-
(
|
74
|
+
(_g = this.sdkError) === null || _g === void 0 ? void 0 : _g.emit(new SDKError(e.message, (_h = e.response) === null || _h === void 0 ? void 0 : _h.status, (_j = e.response) === null || _j === void 0 ? void 0 : _j.data));
|
73
75
|
}
|
74
76
|
}
|
75
77
|
handleCancel(e) {
|
76
|
-
var _a, _b, _c, _d;
|
78
|
+
var _a, _b, _c, _d, _e, _f;
|
77
79
|
e.stopPropagation();
|
78
80
|
const field = (_b = (_a = this.store) === null || _a === void 0 ? void 0 : _a.state) === null || _b === void 0 ? void 0 : _b.fields.find(field => field.name === this.fieldName);
|
79
81
|
if (field) {
|
80
82
|
this.name = field.name;
|
81
83
|
this.roleName = field.role_name;
|
82
84
|
this.required = field.required;
|
83
|
-
|
84
|
-
this.
|
85
|
+
// TODO: Talk about how we want to handle labels/placeholders
|
86
|
+
this.placeholder = ((_c = field.setting) === null || _c === void 0 ? void 0 : _c.placeholder) || '';
|
87
|
+
this.value = ((_d = field.setting) === null || _d === void 0 ? void 0 : _d.result) || '';
|
88
|
+
this.leading = ((_e = field.setting) === null || _e === void 0 ? void 0 : _e.leading) || 0;
|
85
89
|
}
|
86
90
|
this.dirty = false;
|
87
|
-
(
|
91
|
+
(_f = this.close) === null || _f === void 0 ? void 0 : _f.emit();
|
88
92
|
}
|
89
93
|
handleSave(e) {
|
90
94
|
e.stopPropagation();
|
@@ -98,6 +102,10 @@ export class VerdocsTemplateFieldProperties {
|
|
98
102
|
newProperties.setting = this.setting;
|
99
103
|
newProperties.setting.options = this.options;
|
100
104
|
}
|
105
|
+
else if (this.type === 'textarea' || this.type === 'textbox') {
|
106
|
+
newProperties.setting = { ...this.setting };
|
107
|
+
newProperties.setting.result = (this.value || '').trim();
|
108
|
+
}
|
101
109
|
else if (this.type === 'dropdown') {
|
102
110
|
newProperties.setting = {
|
103
111
|
x: this.setting.x,
|
@@ -105,6 +113,7 @@ export class VerdocsTemplateFieldProperties {
|
|
105
113
|
options: this.options,
|
106
114
|
};
|
107
115
|
}
|
116
|
+
console.log('will', newProperties);
|
108
117
|
updateField(this.endpoint, this.templateId, this.fieldName, newProperties)
|
109
118
|
.then(() => {
|
110
119
|
var _a, _b;
|
@@ -209,12 +218,15 @@ export class VerdocsTemplateFieldProperties {
|
|
209
218
|
} })), h("div", { class: "row" }, h("div", { class: "input-label" }, "Role:"), h("verdocs-select-input", { value: this.roleName, options: (_d = (_c = this.store) === null || _c === void 0 ? void 0 : _c.state) === null || _d === void 0 ? void 0 : _d.roles.map(role => ({ label: role.name, value: role.name })), onInput: (e) => {
|
210
219
|
this.roleName = e.target.value;
|
211
220
|
this.dirty = true;
|
212
|
-
} })), ['textbox', 'textarea'].includes(this.type) && (h("verdocs-text-input", { id: "verdocs-field-
|
221
|
+
} })), ['textbox', 'textarea'].includes(this.type) && (h("div", { class: "row", style: { marginTop: '10px', marginBottom: '10px' } }, h("verdocs-text-input", { id: "verdocs-field-value", label: "Value", value: this.value, autocomplete: "off", placeholder: "Pre-defined value...", onInput: (e) => {
|
222
|
+
this.value = e.target.value;
|
223
|
+
this.dirty = true;
|
224
|
+
} }))), ['textbox', 'textarea'].includes(this.type) && (h("div", { class: "row", style: { marginTop: '10px', marginBottom: '10px' } }, h("verdocs-text-input", { id: "verdocs-field-placeholder", label: "Placeholder", value: this.placeholder, autocomplete: "off",
|
213
225
|
// helpText="Placeholder to display if the field is empty."
|
214
226
|
placeholder: "Placeholder...", onInput: (e) => {
|
215
227
|
this.placeholder = e.target.value;
|
216
228
|
this.dirty = true;
|
217
|
-
} })), h("div", { class: "row", style: { marginTop: '15px', marginBottom: '15px' } }, h("label", { htmlFor: "verdocs-is-required", class: "input-label" }, "Required"), h("verdocs-checkbox", { id: "verdocs-is-required", name: "is-required", checked: this.required, value: "on", onInput: (e) => {
|
229
|
+
} }))), h("div", { class: "row", style: { marginTop: '15px', marginBottom: '15px' } }, h("label", { htmlFor: "verdocs-is-required", class: "input-label" }, "Required"), h("verdocs-checkbox", { id: "verdocs-is-required", name: "is-required", checked: this.required, value: "on", onInput: (e) => {
|
218
230
|
this.required = e.target.checked;
|
219
231
|
this.dirty = true;
|
220
232
|
} })), ['checkbox_group', 'radio_button_group'].includes(this.type) && h("verdocs-button", { size: "small", onClick: e => this.handleAddOption(e), label: "Add Option" }), ['dropdown'].includes(this.type) && (h("div", { class: "options" }, h("div", { class: "row", style: {
|
@@ -344,7 +356,8 @@ export class VerdocsTemplateFieldProperties {
|
|
344
356
|
"required": {},
|
345
357
|
"options": {},
|
346
358
|
"placeholder": {},
|
347
|
-
"
|
359
|
+
"value": {},
|
360
|
+
"leading": {},
|
348
361
|
"showingHelp": {}
|
349
362
|
};
|
350
363
|
}
|