@hubsync/esign-web-sdk 6.5.3 → 6.5.5
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/verdocs-sign.cjs.entry.js +40 -31
- package/dist/cjs/verdocs-sign.entry.cjs.js.map +1 -1
- package/dist/collection/components/embeds/verdocs-sign/verdocs-sign.js +40 -31
- package/dist/collection/components/embeds/verdocs-sign/verdocs-sign.js.map +1 -1
- package/dist/components/verdocs-sign.js +40 -31
- package/dist/components/verdocs-sign.js.map +1 -1
- package/dist/esm/verdocs-sign.entry.js +40 -31
- package/dist/esm/verdocs-sign.entry.js.map +1 -1
- package/dist/esm-es5/verdocs-sign.entry.js +1 -1
- package/dist/esm-es5/verdocs-sign.entry.js.map +1 -1
- package/dist/types/components/embeds/verdocs-sign/verdocs-sign.d.ts +2 -1
- package/dist/verdocs-web-sdk/p-1UWKyp9k.system.js.map +1 -0
- package/dist/verdocs-web-sdk/p-3c05be8a.entry.js +2 -0
- package/dist/verdocs-web-sdk/p-3c05be8a.entry.js.map +1 -0
- package/dist/verdocs-web-sdk/p-B8zpaHu-.system.js +1 -1
- package/dist/verdocs-web-sdk/p-bac24b35.system.entry.js +2 -0
- package/dist/verdocs-web-sdk/p-bac24b35.system.entry.js.map +1 -0
- package/dist/verdocs-web-sdk/verdocs-sign.entry.esm.js.map +1 -1
- package/dist/verdocs-web-sdk/verdocs-web-sdk.esm.js +1 -1
- package/package.json +1 -1
- package/dist/verdocs-web-sdk/p-CRNRCDCr.system.js.map +0 -1
- package/dist/verdocs-web-sdk/p-cc1ba953.entry.js +0 -2
- package/dist/verdocs-web-sdk/p-cc1ba953.entry.js.map +0 -1
- package/dist/verdocs-web-sdk/p-da7d065e.system.entry.js +0 -2
- package/dist/verdocs-web-sdk/p-da7d065e.system.entry.js.map +0 -1
|
@@ -390,6 +390,8 @@ const VerdocsSign = class {
|
|
|
390
390
|
if (e.detail === null) {
|
|
391
391
|
console.log('[SIGN] Clearing initial');
|
|
392
392
|
const updateResult = await jsSdk.updateEnvelopeField(this.endpoint, this.envelopeId, this.roleId, field.name, null, false);
|
|
393
|
+
updateResult.value = null;
|
|
394
|
+
this.initialId = null;
|
|
393
395
|
return this.updateRecipientFieldValue(field.name, updateResult);
|
|
394
396
|
}
|
|
395
397
|
// If we already have an initials block, apply it
|
|
@@ -430,6 +432,8 @@ const VerdocsSign = class {
|
|
|
430
432
|
if (e.detail === null) {
|
|
431
433
|
console.log('[SIGN] Clearing signature');
|
|
432
434
|
const updateResult = await jsSdk.updateEnvelopeField(this.endpoint, this.envelopeId, this.roleId, field.name, null, false);
|
|
435
|
+
updateResult.value = null;
|
|
436
|
+
this.signatureId = null;
|
|
433
437
|
return this.updateRecipientFieldValue(field.name, updateResult);
|
|
434
438
|
}
|
|
435
439
|
// If we already have a signature block, apply it
|
|
@@ -499,13 +503,13 @@ const VerdocsSign = class {
|
|
|
499
503
|
}
|
|
500
504
|
return;
|
|
501
505
|
}
|
|
502
|
-
const
|
|
503
|
-
if (
|
|
504
|
-
const id = utils.getFieldId(
|
|
506
|
+
const nextField = this.getNextFieldInOrder();
|
|
507
|
+
if (nextField) {
|
|
508
|
+
const id = utils.getFieldId(nextField);
|
|
505
509
|
const el = document.getElementById(id);
|
|
506
510
|
el === null || el === void 0 ? void 0 : el.scrollIntoView({ behavior: 'smooth', block: 'center', inline: 'center' });
|
|
507
511
|
el === null || el === void 0 ? void 0 : el.focusField();
|
|
508
|
-
this.focusedField =
|
|
512
|
+
this.focusedField = nextField.name;
|
|
509
513
|
}
|
|
510
514
|
}
|
|
511
515
|
getRecipientFields() {
|
|
@@ -527,24 +531,36 @@ const VerdocsSign = class {
|
|
|
527
531
|
}
|
|
528
532
|
this.updateAllFlags();
|
|
529
533
|
}
|
|
530
|
-
|
|
531
|
-
// Find
|
|
532
|
-
const
|
|
533
|
-
|
|
534
|
-
// console.log(
|
|
535
|
-
// '[SIGN] Pending fields',
|
|
536
|
-
// emptyFields.map(f => `${f.name} (${f.type}) req=${f.required}`),
|
|
537
|
-
// );
|
|
538
|
-
if (emptyFields.length === 0) {
|
|
539
|
-
const allUnfilled = this.getSortedFillableFields().filter(field => !jsSdk.isFieldFilled(field, this.getRecipientFields()));
|
|
540
|
-
jsSdk.sortFields(allUnfilled);
|
|
541
|
-
if (allUnfilled.length > 0) {
|
|
542
|
-
// If we are here, there are no required fields left, but there are optional ones.
|
|
543
|
-
return this.getNextFieldFromList(allUnfilled);
|
|
544
|
-
}
|
|
534
|
+
getNextFieldInOrder() {
|
|
535
|
+
// Find the next incomplete field in overall order (required + optional).
|
|
536
|
+
const fields = this.getSortedFillableFields();
|
|
537
|
+
if (fields.length === 0)
|
|
545
538
|
return null;
|
|
539
|
+
const recipientFields = this.getRecipientFields();
|
|
540
|
+
const focusedIndex = fields.findIndex(field => field.name === this.focusedField);
|
|
541
|
+
const startIndex = focusedIndex >= 0 ? focusedIndex + 1 : 0;
|
|
542
|
+
for (let i = 0; i < fields.length; i++) {
|
|
543
|
+
const idx = (startIndex + i) % fields.length;
|
|
544
|
+
const field = fields[idx];
|
|
545
|
+
if (!this.isFieldFilledForNav(field, recipientFields)) {
|
|
546
|
+
return field;
|
|
547
|
+
}
|
|
548
|
+
}
|
|
549
|
+
return null;
|
|
550
|
+
}
|
|
551
|
+
isFieldFilledForNav(field, recipientFields) {
|
|
552
|
+
if (field.type === 'signature' || field.type === 'initial') {
|
|
553
|
+
const value = typeof field.value === 'string' ? field.value.trim() : field.value;
|
|
554
|
+
if (!value)
|
|
555
|
+
return false;
|
|
556
|
+
if (value === 'signed' || value === 'initialed')
|
|
557
|
+
return false;
|
|
558
|
+
return true;
|
|
559
|
+
}
|
|
560
|
+
if (field.type === 'dropdown') {
|
|
561
|
+
return jsSdk.isFieldFilled(field, recipientFields) && !!field.value;
|
|
546
562
|
}
|
|
547
|
-
return
|
|
563
|
+
return jsSdk.isFieldFilled(field, recipientFields);
|
|
548
564
|
}
|
|
549
565
|
getNextFieldFromList(fields) {
|
|
550
566
|
const focusedIndex = fields.findIndex(field => field.name === this.focusedField);
|
|
@@ -582,12 +598,12 @@ const VerdocsSign = class {
|
|
|
582
598
|
// Remove existing flags
|
|
583
599
|
const existingFlags = controlsDiv.querySelectorAll('.verdocs-flag-instance');
|
|
584
600
|
existingFlags.forEach(el => el.remove());
|
|
585
|
-
let nextField = this.
|
|
601
|
+
let nextField = this.getNextFieldInOrder();
|
|
586
602
|
const focusedFieldObj = this.getRecipientFields().find(f => f.name === this.focusedField);
|
|
587
603
|
// If the currently focused field is unfilled, we should point the flag to IT, not the next one.
|
|
588
|
-
//
|
|
604
|
+
// getNextFieldInOrder() is designed for the "Next" button (skipping current), but the visual flag
|
|
589
605
|
// should guide the user to the current task if it's incomplete.
|
|
590
|
-
if (focusedFieldObj && !
|
|
606
|
+
if (focusedFieldObj && !this.isFieldFilledForNav(focusedFieldObj, this.getRecipientFields())) {
|
|
591
607
|
nextField = focusedFieldObj;
|
|
592
608
|
}
|
|
593
609
|
if (nextField && nextField.page === pageInfo.pageNumber && nextField.document_id === pageInfo.documentId) {
|
|
@@ -605,13 +621,6 @@ const VerdocsSign = class {
|
|
|
605
621
|
onSkip: () => {
|
|
606
622
|
this.handleNext();
|
|
607
623
|
},
|
|
608
|
-
onClick: () => {
|
|
609
|
-
var _a;
|
|
610
|
-
const id = utils.getFieldId(nextField);
|
|
611
|
-
const el = document.getElementById(id);
|
|
612
|
-
el === null || el === void 0 ? void 0 : el.scrollIntoView({ behavior: 'smooth', block: 'center' });
|
|
613
|
-
(_a = el === null || el === void 0 ? void 0 : el.focusField) === null || _a === void 0 ? void 0 : _a.call(el);
|
|
614
|
-
},
|
|
615
624
|
});
|
|
616
625
|
}
|
|
617
626
|
}
|
|
@@ -928,7 +937,7 @@ const VerdocsSign = class {
|
|
|
928
937
|
}
|
|
929
938
|
return (index.h("verdocs-signing-progress", { mode: mode, current: Math.max(1, currentIndex), total: totalFields, remainingFields: remainingFields, progress: progress, fieldLabel: getFieldLabel(focusedFieldObj), fieldCompleted: focusedFieldObj ? !!isFilled(focusedFieldObj) : false, onStarted: () => {
|
|
930
939
|
this.adoptingSignature = true;
|
|
931
|
-
|
|
940
|
+
this.handleNext();
|
|
932
941
|
}, onNext: () => this.handleNext(), onPrevious: () => this.handlePrev(), onExit: () => this.handleNext() }));
|
|
933
942
|
})(), index.h("div", { class: `document signed-document-container zoom-${this.zoomLevel}` }, (this.envelope.documents || []).map(envelopeDocument => {
|
|
934
943
|
const pageNumbers = jsSdk.integerSequence(1, envelopeDocument.pages);
|