@rangertechnologies/ngnxt 2.0.32 → 2.0.34

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.
@@ -49,4 +49,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
49
49
  }], valueChange: [{
50
50
  type: Output
51
51
  }] } });
52
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLXRhYmxlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL254dC1hcHAvc3JjL2xpYi9jb21wb25lbnRzL2N1c3RvbS10YWJsZS9jdXN0b20tdGFibGUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnh0LWFwcC9zcmMvbGliL2NvbXBvbmVudHMvY3VzdG9tLXRhYmxlL2N1c3RvbS10YWJsZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQVUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7O0FBWS9FLE1BQU0sT0FBTyxvQkFBb0I7SUFDdEIsUUFBUSxDQUFVO0lBQ2pCLFdBQVcsR0FBd0IsSUFBSSxZQUFZLEVBQVMsQ0FBQztJQUV2RSxTQUFTLENBQWU7SUFDeEIsV0FBVyxDQUFNO0lBQ2pCLFNBQVMsQ0FBTTtJQUNmLGFBQWEsQ0FBUztJQUV0QixnQkFBZ0IsQ0FBQztJQUVqQixRQUFRO1FBQ04sSUFBRyxJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsSUFBSSxTQUFTLEVBQUU7WUFDekMsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLENBQUM7WUFFdkQsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQztZQUN6QyxJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDO1lBRXJDLElBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLEVBQUU7Z0JBQ3hCLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDO2FBQ2xEO1NBQ0Y7SUFDSCxDQUFDO0lBRUQsTUFBTTtRQUNKLElBQUksT0FBTyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUM7UUFDdkUsTUFBTSxnQkFBZ0IsR0FBRyxDQUFDLEdBQUcsSUFBSSxDQUFDLFNBQVMsRUFBRSxPQUFPLENBQUMsQ0FBQztRQUN0RCxJQUFJLENBQUMsU0FBUyxHQUFHLGdCQUFnQixDQUFDO1FBQ2xDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO0lBQzVDLENBQUM7SUFFRCxXQUFXLENBQUMsSUFBUyxFQUFFLEtBQWE7UUFDbEMsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7UUFDbkIsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUMxQyxDQUFDO0lBRUQsV0FBVyxDQUFDLFFBQWdCLEVBQUUsS0FBYSxFQUFFLEtBQWE7UUFDeEQsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxLQUFLLENBQUMsR0FBRyxLQUFLLENBQUM7UUFDeEMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxJQUFJLEdBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDeEUsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUMxQyxDQUFDO0lBRUQsa0JBQWtCLENBQUMsZ0JBQXVCO1FBQ3hDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLENBQUM7SUFDMUMsQ0FBQzt3R0E1Q1Usb0JBQW9COzRGQUFwQixvQkFBb0IsbUlDWmpDLGs1REFpQ1E7OzRGRHJCSyxvQkFBb0I7a0JBTmhDLFNBQVM7K0JBQ0Usa0JBQWtCOzBFQU1uQixRQUFRO3NCQUFoQixLQUFLO2dCQUNJLFdBQVc7c0JBQXBCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE9uSW5pdCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFRhYmxlV3JhcHBlciB9IGZyb20gJy4uLy4uL21vZGVsL3RhYmxlV3JhcHBlcic7XHJcbmltcG9ydCB7IFF1ZXN0aW9uIH0gZnJvbSAnLi4vLi4vd3JhcHBlcic7XHJcblxyXG5kZWNsYXJlIHZhciAkOiBhbnk7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2FwcC1jdXN0b20tdGFibGUnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9jdXN0b20tdGFibGUuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2N1c3RvbS10YWJsZS5jb21wb25lbnQuY3NzJ11cclxufSlcclxuXHJcbmV4cG9ydCBjbGFzcyBDdXN0b21UYWJsZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgQElucHV0KCkgcXVlc3Rpb246IFF1ZXN0aW9uXHJcbiAgQE91dHB1dCgpIHZhbHVlQ2hhbmdlOiBFdmVudEVtaXR0ZXI8YW55W10+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnlbXT4oKTtcclxuXHJcbiAgdGFibGVJbmZvOiBUYWJsZVdyYXBwZXI7XHJcbiAgdGFibGVIZWFkZXI6IGFueTtcclxuICB0YWJsZURhdGE6IGFueTtcclxuICBhZGRSb3dDb2xTcGFuOiBudW1iZXI7XHJcblxyXG4gIGNvbnN0cnVjdG9yKCkgeyB9XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgaWYodGhpcy5xdWVzdGlvbi5TdWJfVGV4dF9fYyAhPSB1bmRlZmluZWQpIHtcclxuICAgICAgdGhpcy50YWJsZUluZm8gPSBKU09OLnBhcnNlKHRoaXMucXVlc3Rpb24uU3ViX1RleHRfX2MpO1xyXG5cclxuICAgICAgdGhpcy50YWJsZUhlYWRlciA9IHRoaXMudGFibGVJbmZvLmhlYWRlcjtcclxuICAgICAgdGhpcy50YWJsZURhdGEgPSB0aGlzLnRhYmxlSW5mby5kYXRhO1xyXG5cclxuICAgICAgaWYodGhpcy50YWJsZURhdGEuYWRkUm93KSB7XHJcbiAgICAgICAgdGhpcy5hZGRSb3dDb2xTcGFuID0gdGhpcy50YWJsZUhlYWRlci5sZW5ndGggLSAyO1xyXG4gICAgICB9XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBhZGRSb3coKTogdm9pZCB7XHJcbiAgICBsZXQgbmV3SXRlbSA9IEpTT04ucGFyc2UoSlNPTi5zdHJpbmdpZnkodGhpcy50YWJsZUluZm8ubmV3Um93RGVmYXVsdCkpO1xyXG4gICAgY29uc3QgdXBkYXRlZFRhYmxlRGF0YSA9IFsuLi50aGlzLnRhYmxlRGF0YSwgbmV3SXRlbV07XHJcbiAgICB0aGlzLnRhYmxlRGF0YSA9IHVwZGF0ZWRUYWJsZURhdGE7XHJcbiAgICB0aGlzLmVtaXRUYWJsZURhdGFWYWx1ZSh1cGRhdGVkVGFibGVEYXRhKTtcclxuICB9XHJcblxyXG4gIHVwZGF0ZVJhZGlvKGl0ZW06IGFueSwgdmFsdWU6IHN0cmluZyk6IHZvaWQge1xyXG4gICAgaXRlbS52YWx1ZSA9IHZhbHVlO1xyXG4gICAgdGhpcy5lbWl0VGFibGVEYXRhVmFsdWUodGhpcy50YWJsZURhdGEpO1xyXG4gIH1cclxuXHJcbiAgdXBkYXRlTGFiZWwocm93SW5kZXg6IG51bWJlciwgbGFiZWw6IHN0cmluZywgdmFsdWU6IHN0cmluZyk6IHZvaWQge1xyXG4gICAgdGhpcy50YWJsZURhdGFbcm93SW5kZXhdW2xhYmVsXSA9IHZhbHVlO1xyXG4gICAgdGhpcy50YWJsZURhdGFbcm93SW5kZXhdLm5hbWUgPSB2YWx1ZS5yZXBsYWNlKC9cXHMrL2csICcnKS50b0xvd2VyQ2FzZSgpO1xyXG4gICAgdGhpcy5lbWl0VGFibGVEYXRhVmFsdWUodGhpcy50YWJsZURhdGEpO1xyXG4gIH1cclxuXHJcbiAgZW1pdFRhYmxlRGF0YVZhbHVlKHVwZGF0ZWRUYWJsZURhdGE6IGFueVtdKTogdm9pZCB7XHJcbiAgICB0aGlzLnZhbHVlQ2hhbmdlLmVtaXQodXBkYXRlZFRhYmxlRGF0YSk7XHJcbiAgfVxyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIHRhYmxlSXRlbSB7XHJcbiAgc2FmZXR5X3ByZWNhdXRpb246IHN0cmluZztcclxuICBpbWFnZVNyYzpzdHJpbmdcclxuICBhbHRUZXh0OnN0cmluZztcclxuICBuYW1lOiBzdHJpbmc7XHJcbiAgdmFsdWU6IHN0cmluZ1xyXG59XHJcblxyXG4iLCI8dGFibGUgY2xhc3M9XCJ0YWJsZSB0YWJsZS1zdHJpcGVkIHRhYmxlLWJvcmRlcmVkXCI+XHJcbiAgPHRoZWFkPlxyXG4gICAgPHRoICpuZ0Zvcj1cImxldCBoZWFkZXIgb2YgdGFibGVIZWFkZXI7IGxldCBoaSA9IGluZGV4XCIgW2NsYXNzXT1cIidjb2wtbWQtJyArIGhlYWRlci5zaXplXCI+XHJcbiAgICAgIHt7IGhlYWRlci5sYWJlbCB9fVxyXG4gICAgPC90aD5cclxuICA8L3RoZWFkPlxyXG4gIDx0Ym9keSBpZD1cInNhZmV0eU1lYXN1cmVzVGFibGVCb2R5XCI+XHJcbiAgICA8dHIgKm5nRm9yPVwibGV0IGl0ZW0gb2YgdGFibGVEYXRhOyBsZXQgaSA9IGluZGV4XCI+XHJcbiAgICAgIDx0ZCAqbmdGb3I9XCJsZXQgaGVhZGVyIG9mIHRhYmxlSGVhZGVyOyBsZXQgaiA9IGluZGV4XCI+XHJcbiAgICAgICAgPGRpdiAqbmdJZj1cImhlYWRlci50eXBlID09PSAnaW1hZ2V0ZXh0J1wiIFtjbGFzc109XCInY29sLW1kLScgKyBoZWFkZXIuc2l6ZVwiIHN0eWxlPVwiZGlzcGxheTogZmxleDtcIj5cclxuICAgICAgICAgIDxpbWcgc3R5bGU9XCJ3aWR0aDogMzVweDsgaGVpZ2h0OiAzMnB4OyBtYXJnaW4tcmlnaHQ6IDVweDtcIiBbc3JjXT1cIml0ZW0uaW1hZ2VTcmNcIiBbYWx0XT1cIml0ZW0uYWx0VGV4dFwiPlxyXG4gICAgICAgICAgPGlucHV0IHR5cGU9XCJ0ZXh0XCIgWyhuZ01vZGVsKV09XCJpdGVtW2hlYWRlci5maWVsZE5hbWVdXCIgKG5nTW9kZWxDaGFuZ2UpPVwidXBkYXRlTGFiZWwoaSwgaGVhZGVyLmZpZWxkTmFtZSwgaXRlbVtoZWFkZXIuZmllbGROYW1lXSlcIiBjbGFzcz1cInNoZS1saW5lLWlucHV0IHRhYmxlLWlucHV0XCI+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgPGRpdiAqbmdJZj1cImhlYWRlci50eXBlID09PSAnaW1hZ2UnXCIgW2NsYXNzXT1cIidjb2wtbWQtJyArIGhlYWRlci5zaXplXCI+XHJcbiAgICAgICAgICA8aW1nIHN0eWxlPVwid2lkdGg6IDM1cHg7IGhlaWdodDogMzJweDsgbWFyZ2luLXJpZ2h0OiA1cHg7XCIgW3NyY109XCJpdGVtW2hlYWRlci5maWVsZE5hbWVdXCIgW2FsdF09XCJpdGVtLmFsdFRleHRcIj5cclxuICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8ZGl2ICpuZ0lmPVwiaGVhZGVyLnR5cGUgPT09ICd0ZXh0J1wiIFtjbGFzc109XCInY29sLW1kLScgKyBoZWFkZXIuc2l6ZVwiPlxyXG4gICAgICAgICAgPGlucHV0IHR5cGU9XCJ0ZXh0XCIgWyhuZ01vZGVsKV09XCJpdGVtW2hlYWRlci5maWVsZE5hbWVdXCIgKG5nTW9kZWxDaGFuZ2UpPVwidXBkYXRlTGFiZWwoaSwgaGVhZGVyLmZpZWxkTmFtZSwgaXRlbVtoZWFkZXIuZmllbGROYW1lXSlcIiBjbGFzcz1cInNoZS1saW5lLWlucHV0IHRhYmxlLWlucHV0XCI+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgPGRpdiAqbmdJZj1cImhlYWRlci50eXBlID09PSAncmFkaW8nXCIgW2NsYXNzXT1cIidjb2wtbWQtJyArIGhlYWRlci5zaXplXCI+XHJcbiAgICAgICAgICA8aW5wdXQgdHlwZT1cInJhZGlvXCIgW25hbWVdPVwiaXRlbS5uYW1lXCIgW2NoZWNrZWRdPVwiaXRlbS52YWx1ZSA9PSBoZWFkZXIuZmllbGROYW1lXCIgKGNsaWNrKT1cInVwZGF0ZVJhZGlvKGl0ZW0sIGhlYWRlci5maWVsZE5hbWUpXCI+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICAgIDwvdGQ+XHJcbiAgICA8L3RyPlxyXG4gICAgPHRyICpuZ0lmPVwidGFibGVJbmZvLmFkZFJvd1wiPlxyXG4gICAgICA8dGQgY29sc3Bhbj1cIjNcIj5cclxuICAgICAgICA8Yj5BZGQgTW9yZTwvYj5cclxuICAgICAgPC90ZD5cclxuICAgICAgPHRkIGNvbHNwYW49XCIyXCIgc3R5bGU9XCJ0ZXh0LWFsaWduOiBjZW50ZXI7IGN1cnNvcjogcG9pbnRlcjtcIiBpZD1cImFkZFNhZmV0eVwiICAoY2xpY2spPVwiYWRkUm93KClcIj5cclxuICAgICAgICArXHJcbiAgICAgIDwvdGQ+XHJcbiAgICA8L3RyPlxyXG4gIDwvdGJvZHk+XHJcbjwvdGFibGU+Il19
52
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLXRhYmxlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL254dC1hcHAvc3JjL2xpYi9jb21wb25lbnRzL2N1c3RvbS10YWJsZS9jdXN0b20tdGFibGUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnh0LWFwcC9zcmMvbGliL2NvbXBvbmVudHMvY3VzdG9tLXRhYmxlL2N1c3RvbS10YWJsZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQVUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7O0FBWS9FLE1BQU0sT0FBTyxvQkFBb0I7SUFDdEIsUUFBUSxDQUFVO0lBQ2pCLFdBQVcsR0FBd0IsSUFBSSxZQUFZLEVBQVMsQ0FBQztJQUV2RSxTQUFTLENBQWU7SUFDeEIsV0FBVyxDQUFNO0lBQ2pCLFNBQVMsQ0FBTTtJQUNmLGFBQWEsQ0FBUztJQUV0QixnQkFBZ0IsQ0FBQztJQUVqQixRQUFRO1FBQ04sSUFBRyxJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsSUFBSSxTQUFTLEVBQUU7WUFDekMsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLENBQUM7WUFFdkQsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQztZQUN6QyxJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDO1lBRXJDLElBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLEVBQUU7Z0JBQ3hCLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDO2FBQ2xEO1NBQ0Y7SUFDSCxDQUFDO0lBRUQsTUFBTTtRQUNKLElBQUksT0FBTyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUM7UUFDdkUsTUFBTSxnQkFBZ0IsR0FBRyxDQUFDLEdBQUcsSUFBSSxDQUFDLFNBQVMsRUFBRSxPQUFPLENBQUMsQ0FBQztRQUN0RCxJQUFJLENBQUMsU0FBUyxHQUFHLGdCQUFnQixDQUFDO1FBQ2xDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO0lBQzVDLENBQUM7SUFFRCxXQUFXLENBQUMsSUFBUyxFQUFFLEtBQWE7UUFDbEMsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7UUFDbkIsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUMxQyxDQUFDO0lBRUQsV0FBVyxDQUFDLFFBQWdCLEVBQUUsS0FBYSxFQUFFLEtBQWE7UUFDeEQsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxLQUFLLENBQUMsR0FBRyxLQUFLLENBQUM7UUFDeEMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxJQUFJLEdBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDeEUsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUMxQyxDQUFDO0lBRUQsa0JBQWtCLENBQUMsZ0JBQXVCO1FBQ3hDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLENBQUM7SUFDMUMsQ0FBQzt3R0E1Q1Usb0JBQW9COzRGQUFwQixvQkFBb0IsbUlDWmpDLGs1REFpQ1E7OzRGRHJCSyxvQkFBb0I7a0JBTmhDLFNBQVM7K0JBQ0Usa0JBQWtCOzBFQU1uQixRQUFRO3NCQUFoQixLQUFLO2dCQUNJLFdBQVc7c0JBQXBCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE9uSW5pdCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFRhYmxlV3JhcHBlciB9IGZyb20gJy4uLy4uL21vZGVsL3RhYmxlV3JhcHBlcic7XHJcbmltcG9ydCB7IFF1ZXN0aW9uIH0gZnJvbSAnLi4vLi4vd3JhcHBlcic7XHJcblxyXG5kZWNsYXJlIHZhciAkOiBhbnk7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2FwcC1jdXN0b20tdGFibGUnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9jdXN0b20tdGFibGUuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2N1c3RvbS10YWJsZS5jb21wb25lbnQuY3NzJ11cclxufSlcclxuXHJcbmV4cG9ydCBjbGFzcyBDdXN0b21UYWJsZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgQElucHV0KCkgcXVlc3Rpb246IFF1ZXN0aW9uXHJcbiAgQE91dHB1dCgpIHZhbHVlQ2hhbmdlOiBFdmVudEVtaXR0ZXI8YW55W10+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnlbXT4oKTtcclxuXHJcbiAgdGFibGVJbmZvOiBUYWJsZVdyYXBwZXI7XHJcbiAgdGFibGVIZWFkZXI6IGFueTtcclxuICB0YWJsZURhdGE6IGFueTtcclxuICBhZGRSb3dDb2xTcGFuOiBudW1iZXI7XHJcblxyXG4gIGNvbnN0cnVjdG9yKCkgeyB9XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgaWYodGhpcy5xdWVzdGlvbi5TdWJfVGV4dF9fYyAhPSB1bmRlZmluZWQpIHtcclxuICAgICAgdGhpcy50YWJsZUluZm8gPSBKU09OLnBhcnNlKHRoaXMucXVlc3Rpb24uU3ViX1RleHRfX2MpO1xyXG5cclxuICAgICAgdGhpcy50YWJsZUhlYWRlciA9IHRoaXMudGFibGVJbmZvLmhlYWRlcjtcclxuICAgICAgdGhpcy50YWJsZURhdGEgPSB0aGlzLnRhYmxlSW5mby5kYXRhO1xyXG5cclxuICAgICAgaWYodGhpcy50YWJsZURhdGEuYWRkUm93KSB7XHJcbiAgICAgICAgdGhpcy5hZGRSb3dDb2xTcGFuID0gdGhpcy50YWJsZUhlYWRlci5sZW5ndGggLSAyO1xyXG4gICAgICB9XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBhZGRSb3coKTogdm9pZCB7XHJcbiAgICBsZXQgbmV3SXRlbSA9IEpTT04ucGFyc2UoSlNPTi5zdHJpbmdpZnkodGhpcy50YWJsZUluZm8ubmV3Um93RGVmYXVsdCkpO1xyXG4gICAgY29uc3QgdXBkYXRlZFRhYmxlRGF0YSA9IFsuLi50aGlzLnRhYmxlRGF0YSwgbmV3SXRlbV07XHJcbiAgICB0aGlzLnRhYmxlRGF0YSA9IHVwZGF0ZWRUYWJsZURhdGE7XHJcbiAgICB0aGlzLmVtaXRUYWJsZURhdGFWYWx1ZSh1cGRhdGVkVGFibGVEYXRhKTtcclxuICB9XHJcblxyXG4gIHVwZGF0ZVJhZGlvKGl0ZW06IGFueSwgdmFsdWU6IHN0cmluZyk6IHZvaWQge1xyXG4gICAgaXRlbS52YWx1ZSA9IHZhbHVlO1xyXG4gICAgdGhpcy5lbWl0VGFibGVEYXRhVmFsdWUodGhpcy50YWJsZURhdGEpO1xyXG4gIH1cclxuXHJcbiAgdXBkYXRlTGFiZWwocm93SW5kZXg6IG51bWJlciwgbGFiZWw6IHN0cmluZywgdmFsdWU6IHN0cmluZyk6IHZvaWQge1xyXG4gICAgdGhpcy50YWJsZURhdGFbcm93SW5kZXhdW2xhYmVsXSA9IHZhbHVlO1xyXG4gICAgdGhpcy50YWJsZURhdGFbcm93SW5kZXhdLm5hbWUgPSB2YWx1ZS5yZXBsYWNlKC9cXHMrL2csICcnKS50b0xvd2VyQ2FzZSgpO1xyXG4gICAgdGhpcy5lbWl0VGFibGVEYXRhVmFsdWUodGhpcy50YWJsZURhdGEpO1xyXG4gIH1cclxuXHJcbiAgZW1pdFRhYmxlRGF0YVZhbHVlKHVwZGF0ZWRUYWJsZURhdGE6IGFueVtdKTogdm9pZCB7XHJcbiAgICB0aGlzLnZhbHVlQ2hhbmdlLmVtaXQodXBkYXRlZFRhYmxlRGF0YSk7XHJcbiAgfVxyXG59IiwiPHRhYmxlIGNsYXNzPVwidGFibGUgdGFibGUtc3RyaXBlZCB0YWJsZS1ib3JkZXJlZFwiPlxyXG4gIDx0aGVhZD5cclxuICAgIDx0aCAqbmdGb3I9XCJsZXQgaGVhZGVyIG9mIHRhYmxlSGVhZGVyOyBsZXQgaGkgPSBpbmRleFwiIFtjbGFzc109XCInY29sLW1kLScgKyBoZWFkZXIuc2l6ZVwiPlxyXG4gICAgICB7eyBoZWFkZXIubGFiZWwgfX1cclxuICAgIDwvdGg+XHJcbiAgPC90aGVhZD5cclxuICA8dGJvZHkgaWQ9XCJzYWZldHlNZWFzdXJlc1RhYmxlQm9keVwiPlxyXG4gICAgPHRyICpuZ0Zvcj1cImxldCBpdGVtIG9mIHRhYmxlRGF0YTsgbGV0IGkgPSBpbmRleFwiPlxyXG4gICAgICA8dGQgKm5nRm9yPVwibGV0IGhlYWRlciBvZiB0YWJsZUhlYWRlcjsgbGV0IGogPSBpbmRleFwiPlxyXG4gICAgICAgIDxkaXYgKm5nSWY9XCJoZWFkZXIudHlwZSA9PT0gJ2ltYWdldGV4dCdcIiBbY2xhc3NdPVwiJ2NvbC1tZC0nICsgaGVhZGVyLnNpemVcIiBzdHlsZT1cImRpc3BsYXk6IGZsZXg7XCI+XHJcbiAgICAgICAgICA8aW1nIHN0eWxlPVwid2lkdGg6IDM1cHg7IGhlaWdodDogMzJweDsgbWFyZ2luLXJpZ2h0OiA1cHg7XCIgW3NyY109XCJpdGVtLmltYWdlU3JjXCIgW2FsdF09XCJpdGVtLmFsdFRleHRcIj5cclxuICAgICAgICAgIDxpbnB1dCB0eXBlPVwidGV4dFwiIFsobmdNb2RlbCldPVwiaXRlbVtoZWFkZXIuZmllbGROYW1lXVwiIChuZ01vZGVsQ2hhbmdlKT1cInVwZGF0ZUxhYmVsKGksIGhlYWRlci5maWVsZE5hbWUsIGl0ZW1baGVhZGVyLmZpZWxkTmFtZV0pXCIgY2xhc3M9XCJzaGUtbGluZS1pbnB1dCB0YWJsZS1pbnB1dFwiPlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgICAgIDxkaXYgKm5nSWY9XCJoZWFkZXIudHlwZSA9PT0gJ2ltYWdlJ1wiIFtjbGFzc109XCInY29sLW1kLScgKyBoZWFkZXIuc2l6ZVwiPlxyXG4gICAgICAgICAgPGltZyBzdHlsZT1cIndpZHRoOiAzNXB4OyBoZWlnaHQ6IDMycHg7IG1hcmdpbi1yaWdodDogNXB4O1wiIFtzcmNdPVwiaXRlbVtoZWFkZXIuZmllbGROYW1lXVwiIFthbHRdPVwiaXRlbS5hbHRUZXh0XCI+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgPGRpdiAqbmdJZj1cImhlYWRlci50eXBlID09PSAndGV4dCdcIiBbY2xhc3NdPVwiJ2NvbC1tZC0nICsgaGVhZGVyLnNpemVcIj5cclxuICAgICAgICAgIDxpbnB1dCB0eXBlPVwidGV4dFwiIFsobmdNb2RlbCldPVwiaXRlbVtoZWFkZXIuZmllbGROYW1lXVwiIChuZ01vZGVsQ2hhbmdlKT1cInVwZGF0ZUxhYmVsKGksIGhlYWRlci5maWVsZE5hbWUsIGl0ZW1baGVhZGVyLmZpZWxkTmFtZV0pXCIgY2xhc3M9XCJzaGUtbGluZS1pbnB1dCB0YWJsZS1pbnB1dFwiPlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgICAgIDxkaXYgKm5nSWY9XCJoZWFkZXIudHlwZSA9PT0gJ3JhZGlvJ1wiIFtjbGFzc109XCInY29sLW1kLScgKyBoZWFkZXIuc2l6ZVwiPlxyXG4gICAgICAgICAgPGlucHV0IHR5cGU9XCJyYWRpb1wiIFtuYW1lXT1cIml0ZW0ubmFtZVwiIFtjaGVja2VkXT1cIml0ZW0udmFsdWUgPT0gaGVhZGVyLmZpZWxkTmFtZVwiIChjbGljayk9XCJ1cGRhdGVSYWRpbyhpdGVtLCBoZWFkZXIuZmllbGROYW1lKVwiPlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgICA8L3RkPlxyXG4gICAgPC90cj5cclxuICAgIDx0ciAqbmdJZj1cInRhYmxlSW5mby5hZGRSb3dcIj5cclxuICAgICAgPHRkIGNvbHNwYW49XCIzXCI+XHJcbiAgICAgICAgPGI+QWRkIE1vcmU8L2I+XHJcbiAgICAgIDwvdGQ+XHJcbiAgICAgIDx0ZCBjb2xzcGFuPVwiMlwiIHN0eWxlPVwidGV4dC1hbGlnbjogY2VudGVyOyBjdXJzb3I6IHBvaW50ZXI7XCIgaWQ9XCJhZGRTYWZldHlcIiAgKGNsaWNrKT1cImFkZFJvdygpXCI+XHJcbiAgICAgICAgK1xyXG4gICAgICA8L3RkPlxyXG4gICAgPC90cj5cclxuICA8L3Rib2R5PlxyXG48L3RhYmxlPiJdfQ==
@@ -0,0 +1,9 @@
1
+ export class BookletWrapper {
2
+ // List of Question Book contianing inly Book Type Questions
3
+ booklet = [];
4
+ // Store the Questions related to the Question Book
5
+ bookQuestionsMap = new Map();
6
+ // SQ Options
7
+ sqOptions = new Map();
8
+ }
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm9va2xldFdyYXBwZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ueHQtYXBwL3NyYy9saWIvbW9kZWwvYm9va2xldFdyYXBwZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxPQUFPLGNBQWM7SUFFdkIsNERBQTREO0lBQzVELE9BQU8sR0FBVSxFQUFFLENBQUM7SUFFcEIsbURBQW1EO0lBQ25ELGdCQUFnQixHQUFRLElBQUksR0FBRyxFQUFFLENBQUM7SUFFbEMsYUFBYTtJQUNiLFNBQVMsR0FBUSxJQUFJLEdBQUcsRUFBRSxDQUFDO0NBQzlCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNsYXNzIEJvb2tsZXRXcmFwcGVyIHtcclxuICAgIFxyXG4gICAgLy8gTGlzdCBvZiBRdWVzdGlvbiBCb29rIGNvbnRpYW5pbmcgaW5seSBCb29rIFR5cGUgUXVlc3Rpb25zXHJcbiAgICBib29rbGV0OiBhbnlbXSA9IFtdO1xyXG5cclxuICAgIC8vIFN0b3JlIHRoZSBRdWVzdGlvbnMgcmVsYXRlZCB0byB0aGUgUXVlc3Rpb24gQm9va1xyXG4gICAgYm9va1F1ZXN0aW9uc01hcDogYW55ID0gbmV3IE1hcCgpO1xyXG5cclxuICAgIC8vIFNRIE9wdGlvbnNcclxuICAgIHNxT3B0aW9uczogYW55ID0gbmV3IE1hcCgpO1xyXG59XHJcbiJdfQ==
@@ -2,31 +2,37 @@ import { Component, Input, Output, EventEmitter, } from "@angular/core";
2
2
  import * as i0 from "@angular/core";
3
3
  import * as i1 from "../../services/salesforce.service";
4
4
  import * as i2 from "../../services/data.service";
5
- import * as i3 from "@angular/router";
6
- import * as i4 from "@angular/platform-browser";
7
- import * as i5 from "@angular/common";
8
- import * as i6 from "ngx-spinner";
9
- import * as i7 from "../questionbook/questionbook.component";
5
+ import * as i3 from "../../services/storage.service";
6
+ import * as i4 from "@angular/router";
7
+ import * as i5 from "@angular/platform-browser";
8
+ import * as i6 from "@angular/common";
9
+ import * as i7 from "ngx-spinner";
10
+ import * as i8 from "../questionbook/questionbook.component";
10
11
  export class BookletComponent {
11
12
  sfService;
12
13
  dataService;
14
+ storageService;
13
15
  route;
14
16
  sanitizer;
15
17
  bookletId;
16
18
  serv;
17
19
  tkn;
20
+ bookletJSON;
18
21
  handleBookletActionEvent = new EventEmitter();
19
22
  handlePage = new EventEmitter();
23
+ nxtBooklet;
20
24
  booklet = [];
21
25
  abItem = {};
22
26
  actions = [];
23
27
  bookQuestionsMap = new Map();
24
28
  sqOptions = new Map();
29
+ isAnswerFlag = false;
25
30
  spinnerName;
26
31
  spinnerType;
27
- constructor(sfService, dataService, route, sanitizer, el) {
32
+ constructor(sfService, dataService, storageService, route, sanitizer, el) {
28
33
  this.sfService = sfService;
29
34
  this.dataService = dataService;
35
+ this.storageService = storageService;
30
36
  this.route = route;
31
37
  this.sanitizer = sanitizer;
32
38
  this.spinnerName = "sp1";
@@ -48,6 +54,27 @@ export class BookletComponent {
48
54
  this.readBooklet(this.bookletId);
49
55
  }
50
56
  }
57
+ else if (this.bookletJSON) {
58
+ // Try to pass a value from Backend to differentiate the QuestionBook Read and AnswerBook Read
59
+ this.isAnswerFlag = true;
60
+ if (this.bookletJSON != null || this.bookletJSON != undefined) {
61
+ // Storing the API response for future use
62
+ this.storageService.save(this.bookletJSON);
63
+ }
64
+ this.booklet = this.bookletJSON.records;
65
+ this.abItem = this.bookletJSON.answerbook;
66
+ // Process the Sub Question Options - This should be merged with bookQuestionsMap in future
67
+ for (var sq in this.bookletJSON.sqOptions) {
68
+ this.sqOptions.set(sq, this.bookletJSON.sqOptions[sq]);
69
+ }
70
+ // Process the Questions
71
+ for (var value in this.bookletJSON.bookQuestionsMap) {
72
+ this.bookQuestionsMap.set(value, this.bookletJSON.bookQuestionsMap[value]);
73
+ }
74
+ if (this.bookletJSON.questionbook?.Actions__c != undefined) {
75
+ this.actions = JSON.parse(this.bookletJSON.questionbook.Actions__c);
76
+ }
77
+ }
51
78
  }
52
79
  readBooklet = (uuid) => {
53
80
  if (this.serv == "api") {
@@ -61,9 +88,13 @@ export class BookletComponent {
61
88
  console.log('Inside the successReadBooklet');
62
89
  // console.log(response);
63
90
  if (response != null || response != undefined) {
91
+ // Storing the API response for future use
92
+ this.storageService.save(response);
93
+ // Try to pass a value from Backend to differentiate the QuestionBook Read and AnswerBook Read
94
+ // this.isAnswerFlag = true;
64
95
  this.booklet = response.records;
65
96
  this.abItem = response.answerbook;
66
- // Process the Sub Question Options
97
+ // Process the Sub Question Options - This should be merged with bookQuestionsMap in future
67
98
  for (var sq in response.sqOptions) {
68
99
  this.sqOptions.set(sq, response.sqOptions[sq]);
69
100
  }
@@ -80,7 +111,10 @@ export class BookletComponent {
80
111
  };
81
112
  handleBookletActionClick(action) {
82
113
  console.log(action);
83
- this.handleBookletActionEvent.emit(action.eventtoemit);
114
+ let dataToParent = {};
115
+ dataToParent['action'] = action.eventtoemit;
116
+ dataToParent['data'] = this.storageService.get();
117
+ this.handleBookletActionEvent.emit(dataToParent);
84
118
  }
85
119
  readQuestions(qbId) {
86
120
  console.log('inside BookletComponent.readQuestions ' + qbId);
@@ -103,21 +137,23 @@ export class BookletComponent {
103
137
  //console.log( doc.documentElement.textContent);
104
138
  return this.sanitizer.bypassSecurityTrustHtml(doc.documentElement.textContent);
105
139
  }
106
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: BookletComponent, deps: [{ token: i1.SalesforceService }, { token: i2.DataService }, { token: i3.ActivatedRoute }, { token: i4.DomSanitizer }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
107
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: BookletComponent, selector: "lib-booklet", inputs: { bookletId: "bookletId", serv: "serv", tkn: "tkn" }, outputs: { handleBookletActionEvent: "handleBookletActionEvent", handlePage: "handlePage" }, usesOnChanges: true, ngImport: i0, template: "<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\r\n<!-- Booklet Handling-->\r\n<div *ngFor=\"let qb of booklet\">\r\n <!-- MR Commented below code to ensure single JSON for UNCONDITIONAL Booklets -->\r\n <!-- <lib-questionnaire [serv]=\"serv\" [qbId]=\"qb.Id\" [tkn]=\"tkn\"></lib-questionnaire> -->\r\n\r\n <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\r\n <div class=\"questiondiv2\">\r\n <div *ngIf=\"!ques.Is_Title__c\" [class]=\"qb.isShengel__c ? 'header-style' : 'question-f-size additional'\">\r\n <div [innerHTML]=\"getText(ques?.Question_Text__c)\" >\r\n {{ ques?.Question_Text__c }}\r\n </div>\r\n </div>\r\n <lib-questionbook [qbItem]=\"qb\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\"></lib-questionbook>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<!-- Group Actions -->\r\n<div class=\"align-submit-row\" *ngIf=\"abItem.Status__c != 'Completed'\">\r\n <div *ngFor=\"let action of actions\">\r\n <button (click)=\"handleBookletActionClick(action)\">\r\n {{ action.name }}\r\n </button>\r\n </div>\r\n</div>\r\n", styles: [".align-submit-row{display:flex}.align-submit-row button{margin-left:25px;background:#48B7FF;color:#fff;border:none;border-radius:5px;height:50px;width:150px}.header-style{padding:15px;background:#F8F8F8;color:#898989;border:1px solid #e8e8e8;border-top-left-radius:5px;border-top-right-radius:5px;margin-left:0;justify-content:left;font-size:15px}\n"], dependencies: [{ kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i6.NgxSpinnerComponent, selector: "ngx-spinner", inputs: ["disableAnimation", "bdColor", "zIndex", "color", "type", "size", "fullScreen", "name", "template", "showSpinner"] }, { kind: "component", type: i7.QuestionbookComponent, selector: "lib-questionbook", inputs: ["qbItem", "questionItem", "questions"] }] });
140
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: BookletComponent, deps: [{ token: i1.SalesforceService }, { token: i2.DataService }, { token: i3.StorageService }, { token: i4.ActivatedRoute }, { token: i5.DomSanitizer }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
141
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: BookletComponent, selector: "lib-booklet", inputs: { bookletId: "bookletId", serv: "serv", tkn: "tkn", bookletJSON: "bookletJSON" }, outputs: { handleBookletActionEvent: "handleBookletActionEvent", handlePage: "handlePage" }, usesOnChanges: true, ngImport: i0, template: "<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\r\n<!-- Booklet Handling-->\r\n<div *ngFor=\"let qb of booklet\">\r\n <!-- MR Commented below code to ensure single JSON for UNCONDITIONAL Booklets -->\r\n <!-- <lib-questionnaire [serv]=\"serv\" [qbId]=\"qb.Id\" [tkn]=\"tkn\"></lib-questionnaire> -->\r\n\r\n <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\r\n <div class=\"questiondiv2\">\r\n <div *ngIf=\"!ques.Is_Title__c\" [class]=\"qb.isShengel__c ? 'header-style' : 'question-f-size additional'\">\r\n <div [innerHTML]=\"getText(ques?.Question_Text__c)\" >\r\n {{ ques?.Question_Text__c }}\r\n </div>\r\n </div>\r\n <lib-questionbook [qbItem]=\"qb\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\"></lib-questionbook>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<!-- Group Actions -->\r\n<div class=\"align-submit-row\" *ngIf=\"abItem.Status__c != 'Completed'\">\r\n <div *ngFor=\"let action of actions\">\r\n <button (click)=\"handleBookletActionClick(action)\">\r\n {{ action.name }}\r\n </button>\r\n </div>\r\n</div>\r\n", styles: [".align-submit-row{display:flex}.align-submit-row button{margin-left:25px;background:#48B7FF;color:#fff;border:none;border-radius:5px;height:50px;width:150px}.header-style{padding:15px;background:#F8F8F8;color:#898989;border:1px solid #e8e8e8;border-top-left-radius:5px;border-top-right-radius:5px;margin-left:0;justify-content:left;font-size:15px}\n"], dependencies: [{ kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i7.NgxSpinnerComponent, selector: "ngx-spinner", inputs: ["disableAnimation", "bdColor", "zIndex", "color", "type", "size", "fullScreen", "name", "template", "showSpinner"] }, { kind: "component", type: i8.QuestionbookComponent, selector: "lib-questionbook", inputs: ["qbItem", "questionItem", "questions"] }] });
108
142
  }
109
143
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: BookletComponent, decorators: [{
110
144
  type: Component,
111
145
  args: [{ selector: 'lib-booklet', template: "<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\r\n<!-- Booklet Handling-->\r\n<div *ngFor=\"let qb of booklet\">\r\n <!-- MR Commented below code to ensure single JSON for UNCONDITIONAL Booklets -->\r\n <!-- <lib-questionnaire [serv]=\"serv\" [qbId]=\"qb.Id\" [tkn]=\"tkn\"></lib-questionnaire> -->\r\n\r\n <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\r\n <div class=\"questiondiv2\">\r\n <div *ngIf=\"!ques.Is_Title__c\" [class]=\"qb.isShengel__c ? 'header-style' : 'question-f-size additional'\">\r\n <div [innerHTML]=\"getText(ques?.Question_Text__c)\" >\r\n {{ ques?.Question_Text__c }}\r\n </div>\r\n </div>\r\n <lib-questionbook [qbItem]=\"qb\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\"></lib-questionbook>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<!-- Group Actions -->\r\n<div class=\"align-submit-row\" *ngIf=\"abItem.Status__c != 'Completed'\">\r\n <div *ngFor=\"let action of actions\">\r\n <button (click)=\"handleBookletActionClick(action)\">\r\n {{ action.name }}\r\n </button>\r\n </div>\r\n</div>\r\n", styles: [".align-submit-row{display:flex}.align-submit-row button{margin-left:25px;background:#48B7FF;color:#fff;border:none;border-radius:5px;height:50px;width:150px}.header-style{padding:15px;background:#F8F8F8;color:#898989;border:1px solid #e8e8e8;border-top-left-radius:5px;border-top-right-radius:5px;margin-left:0;justify-content:left;font-size:15px}\n"] }]
112
- }], ctorParameters: function () { return [{ type: i1.SalesforceService }, { type: i2.DataService }, { type: i3.ActivatedRoute }, { type: i4.DomSanitizer }, { type: i0.ElementRef }]; }, propDecorators: { bookletId: [{
146
+ }], ctorParameters: function () { return [{ type: i1.SalesforceService }, { type: i2.DataService }, { type: i3.StorageService }, { type: i4.ActivatedRoute }, { type: i5.DomSanitizer }, { type: i0.ElementRef }]; }, propDecorators: { bookletId: [{
113
147
  type: Input
114
148
  }], serv: [{
115
149
  type: Input
116
150
  }], tkn: [{
117
151
  type: Input
152
+ }], bookletJSON: [{
153
+ type: Input
118
154
  }], handleBookletActionEvent: [{
119
155
  type: Output
120
156
  }], handlePage: [{
121
157
  type: Output
122
158
  }] } });
123
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"booklet.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/pages/booklet/booklet.component.ts","../../../../../../projects/nxt-app/src/lib/pages/booklet/booklet.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  OnChanges,\r\n  Inject,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  ViewEncapsulation,\r\n  ElementRef,\r\n} from \"@angular/core\";\r\nimport { SalesforceService } from \"../../services/salesforce.service\";\r\nimport { DataService } from '../../services/data.service';\r\nimport { ActivatedRoute, Params } from \"@angular/router\";\r\nimport { DomSanitizer, SafeHtml } from \"@angular/platform-browser\";\r\nimport { ActionMeta } from '../../interfaces/actionMeta';\r\nimport { Question } from \"../../wrapper\";\r\n\r\n@Component({\r\n  selector: 'lib-booklet',\r\n  templateUrl: './booklet.component.html',\r\n  styleUrls: ['./booklet.component.css']\r\n})\r\nexport class BookletComponent implements OnInit {\r\n  @Input() bookletId: string;\r\n  @Input() serv: string;\r\n  @Input() tkn: string;\r\n  @Output() handleBookletActionEvent = new EventEmitter();\r\n  @Output() handlePage: EventEmitter<any> = new EventEmitter();\r\n\r\n  public booklet: any[] = [];\r\n  public abItem: any = {};\r\n  public actions: ActionMeta[] = [];\r\n  public bookQuestionsMap: any = new Map();\r\n  private sqOptions: any = new Map();\r\n  public spinnerName: string;\r\n  public spinnerType:string;\r\n\r\n  constructor(\r\n    private sfService: SalesforceService,\r\n    private dataService: DataService,\r\n    private route: ActivatedRoute,\r\n    private sanitizer: DomSanitizer,\r\n    el: ElementRef\r\n  ) { \r\n    this.spinnerName = \"sp1\";\r\n    this.spinnerType = \"ball-spin-clockwise\";\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.processBooklet();\r\n  }\r\n\r\n  ngOnChanges() {\r\n    console.log('inside Questionnaire ngOnChanges');\r\n    console.log(this.booklet);\r\n    if(this.booklet == undefined || this.booklet.length == 0) {\r\n      this.processBooklet();\r\n    }\r\n  }\r\n\r\n  processBooklet() {\r\n    if (this.bookletId) {\r\n      if (this.bookletId.length == 18) {\r\n        this.readBooklet(this.bookletId);\r\n      }\r\n    }\r\n  }\r\n\r\n  private readBooklet = (uuid: string) => {\r\n    if(this.serv == \"api\") {\r\n      this.dataService.getAPIData(\r\n        this.tkn,\r\n        [\"Booklet\", \"read\", uuid],\r\n        this.successReadBooklet,\r\n        this.failureReadBooklet\r\n      );\r\n    } else {\r\n      this.sfService.remoteAction(\r\n        \"NxtController.process\",\r\n        [\"Booklet\", \"read\", uuid],\r\n        this.successReadBooklet,\r\n        this.failureReadBooklet\r\n      );\r\n    }\r\n  }\r\n\r\n  private successReadBooklet = (response) => {\r\n    console.log('Inside the successReadBooklet');\r\n    // console.log(response);\r\n    if(response != null || response != undefined) {\r\n      this.booklet = response.records;\r\n      this.abItem = response.answerbook;\r\n      // Process the Sub Question Options\r\n      for (var sq in response.sqOptions) {\r\n        this.sqOptions.set(sq, response.sqOptions[sq]);\r\n      }\r\n      // Process the Questions\r\n      for (var value in response.bookQuestionsMap) {\r\n        this.bookQuestionsMap.set(value, response.bookQuestionsMap[value]);\r\n      }\r\n\r\n      if(response.questionbook?.Actions__c != undefined) {\r\n        this.actions = JSON.parse(response.questionbook.Actions__c);\r\n      }\r\n    }\r\n  }\r\n\r\n  private failureReadBooklet = (response) => {\r\n\r\n  }\r\n\r\n  handleBookletActionClick(action:ActionMeta) {\r\n    console.log(action);\r\n    this.handleBookletActionEvent.emit(action.eventtoemit);\r\n  }\r\n\r\n  readQuestions(qbId: string) {\r\n    console.log('inside BookletComponent.readQuestions ' + qbId);\r\n    // console.log(this.bookQuestionsMap.size);\r\n    let questions = [];\r\n    for(var sq in this.bookQuestionsMap?.get(qbId).Questions__r.records) {\r\n      let q: Question = this.bookQuestionsMap?.get(qbId).Questions__r.records[sq];\r\n      if(q.Type__c == 'Dropdown') {\r\n        questions.push(this.sqOptions.get(q.Id));\r\n      } else {\r\n        questions.push(q);\r\n      }\r\n    }\r\n    // console.log(questions);\r\n    return questions;\r\n  }\r\n\r\n  getText(value) {\r\n    var doc = new DOMParser().parseFromString(value, \"text/html\");\r\n    //console.log( doc.documentElement.textContent);\r\n    return this.sanitizer.bypassSecurityTrustHtml(\r\n      doc.documentElement.textContent\r\n    );\r\n  }\r\n}\r\n","<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\r\n<!-- Booklet Handling-->\r\n<div *ngFor=\"let qb of booklet\">\r\n    <!-- MR Commented below code to ensure single JSON for UNCONDITIONAL Booklets -->\r\n    <!-- <lib-questionnaire [serv]=\"serv\" [qbId]=\"qb.Id\" [tkn]=\"tkn\"></lib-questionnaire> -->\r\n\r\n    <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\r\n        <div class=\"questiondiv2\">\r\n            <div *ngIf=\"!ques.Is_Title__c\" [class]=\"qb.isShengel__c ? 'header-style' : 'question-f-size additional'\">\r\n                <div [innerHTML]=\"getText(ques?.Question_Text__c)\" >\r\n                    {{ ques?.Question_Text__c }}\r\n                </div>\r\n            </div>\r\n            <lib-questionbook [qbItem]=\"qb\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\"></lib-questionbook>\r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n<!-- Group Actions -->\r\n<div class=\"align-submit-row\" *ngIf=\"abItem.Status__c != 'Completed'\">\r\n    <div *ngFor=\"let action of actions\">\r\n        <button (click)=\"handleBookletActionClick(action)\">\r\n            {{ action.name }}\r\n        </button>\r\n    </div>\r\n</div>\r\n"]}
159
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"booklet.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/pages/booklet/booklet.component.ts","../../../../../../projects/nxt-app/src/lib/pages/booklet/booklet.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAIT,KAAK,EACL,MAAM,EACN,YAAY,GAGb,MAAM,eAAe,CAAC;;;;;;;;;;AAevB,MAAM,OAAO,gBAAgB;IAqBjB;IACA;IACA;IACA;IACA;IAxBD,SAAS,CAAS;IAClB,IAAI,CAAS;IACb,GAAG,CAAS;IACZ,WAAW,CAAM;IAEhB,wBAAwB,GAAsB,IAAI,YAAY,EAAE,CAAC;IACjE,UAAU,GAAsB,IAAI,YAAY,EAAE,CAAC;IAEtD,UAAU,CAAiB;IAE3B,OAAO,GAAU,EAAE,CAAC;IACpB,MAAM,GAAQ,EAAE,CAAC;IACjB,OAAO,GAAiB,EAAE,CAAC;IAC3B,gBAAgB,GAAQ,IAAI,GAAG,EAAE,CAAC;IACjC,SAAS,GAAQ,IAAI,GAAG,EAAE,CAAC;IAC5B,YAAY,GAAY,KAAK,CAAC;IAC9B,WAAW,CAAS;IACpB,WAAW,CAAS;IAE3B,YACU,SAA4B,EAC5B,WAAwB,EACxB,cAA8B,EAC9B,KAAqB,EACrB,SAAuB,EAC/B,EAAc;QALN,cAAS,GAAT,SAAS,CAAmB;QAC5B,gBAAW,GAAX,WAAW,CAAa;QACxB,mBAAc,GAAd,cAAc,CAAgB;QAC9B,UAAK,GAAL,KAAK,CAAgB;QACrB,cAAS,GAAT,SAAS,CAAc;QAG/B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,WAAW,GAAG,qBAAqB,CAAC;IAC3C,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAED,WAAW;QACT,OAAO,CAAC,GAAG,CAAC,kCAAkC,CAAC,CAAC;QAChD,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC1B,IAAG,IAAI,CAAC,OAAO,IAAI,SAAS,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,IAAI,CAAC,EAAE;YACxD,IAAI,CAAC,cAAc,EAAE,CAAC;SACvB;IACH,CAAC;IAED,cAAc;QACZ,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,IAAI,EAAE,EAAE;gBAC/B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aAClC;SACF;aAAM,IAAG,IAAI,CAAC,WAAW,EAAE;YAC1B,8FAA8F;YAC9F,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;YAEzB,IAAG,IAAI,CAAC,WAAW,IAAI,IAAI,IAAI,IAAI,CAAC,WAAW,IAAI,SAAS,EAAE;gBAC1D,0CAA0C;gBAC1C,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;aAC9C;YAED,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC;YACxC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC;YAE1C,2FAA2F;YAC3F,KAAK,IAAI,EAAE,IAAI,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE;gBACzC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,EAAE,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC;aACxD;YAED,wBAAwB;YACxB,KAAK,IAAI,KAAK,IAAI,IAAI,CAAC,WAAW,CAAC,gBAAgB,EAAE;gBACnD,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,CAAC;aAC5E;YAED,IAAG,IAAI,CAAC,WAAW,CAAC,YAAY,EAAE,UAAU,IAAI,SAAS,EAAE;gBACzD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC;aACrE;SACF;IACH,CAAC;IAEO,WAAW,GAAG,CAAC,IAAY,EAAE,EAAE;QACrC,IAAG,IAAI,CAAC,IAAI,IAAI,KAAK,EAAE;YACrB,IAAI,CAAC,WAAW,CAAC,UAAU,CACzB,IAAI,CAAC,GAAG,EACR,CAAC,SAAS,EAAE,MAAM,EAAE,IAAI,CAAC,EACzB,IAAI,CAAC,kBAAkB,EACvB,IAAI,CAAC,kBAAkB,CACxB,CAAC;SACH;aAAM;YACL,IAAI,CAAC,SAAS,CAAC,YAAY,CACzB,uBAAuB,EACvB,CAAC,SAAS,EAAE,MAAM,EAAE,IAAI,CAAC,EACzB,IAAI,CAAC,kBAAkB,EACvB,IAAI,CAAC,kBAAkB,CACxB,CAAC;SACH;IACH,CAAC,CAAA;IAEO,kBAAkB,GAAG,CAAC,QAAQ,EAAE,EAAE;QACxC,OAAO,CAAC,GAAG,CAAC,+BAA+B,CAAC,CAAC;QAC7C,yBAAyB;QACzB,IAAG,QAAQ,IAAI,IAAI,IAAI,QAAQ,IAAI,SAAS,EAAE;YAC5C,0CAA0C;YAC1C,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAEnC,8FAA8F;YAC9F,4BAA4B;YAE5B,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC;YAChC,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAC,UAAU,CAAC;YAElC,2FAA2F;YAC3F,KAAK,IAAI,EAAE,IAAI,QAAQ,CAAC,SAAS,EAAE;gBACjC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,EAAE,QAAQ,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC;aAChD;YAED,wBAAwB;YACxB,KAAK,IAAI,KAAK,IAAI,QAAQ,CAAC,gBAAgB,EAAE;gBAC3C,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,KAAK,EAAE,QAAQ,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,CAAC;aACpE;YAED,IAAG,QAAQ,CAAC,YAAY,EAAE,UAAU,IAAI,SAAS,EAAE;gBACjD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC;aAC7D;SACF;IACH,CAAC,CAAA;IAEO,kBAAkB,GAAG,CAAC,QAAQ,EAAE,EAAE;IAE1C,CAAC,CAAA;IAED,wBAAwB,CAAC,MAAiB;QACxC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QACpB,IAAI,YAAY,GAAG,EAAE,CAAC;QACtB,YAAY,CAAC,QAAQ,CAAC,GAAG,MAAM,CAAC,WAAW,CAAC;QAC5C,YAAY,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,EAAE,CAAC;QACjD,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACnD,CAAC;IAED,aAAa,CAAC,IAAY;QACxB,OAAO,CAAC,GAAG,CAAC,wCAAwC,GAAG,IAAI,CAAC,CAAC;QAC7D,2CAA2C;QAC3C,IAAI,SAAS,GAAG,EAAE,CAAC;QACnB,KAAI,IAAI,EAAE,IAAI,IAAI,CAAC,gBAAgB,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC,YAAY,CAAC,OAAO,EAAE;YACnE,IAAI,CAAC,GAAa,IAAI,CAAC,gBAAgB,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC,YAAY,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;YAC5E,IAAG,CAAC,CAAC,OAAO,IAAI,UAAU,EAAE;gBAC1B,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;aAC1C;iBAAM;gBACL,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;aACnB;SACF;QACD,0BAA0B;QAC1B,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,OAAO,CAAC,KAAK;QACX,IAAI,GAAG,GAAG,IAAI,SAAS,EAAE,CAAC,eAAe,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;QAC9D,gDAAgD;QAChD,OAAO,IAAI,CAAC,SAAS,CAAC,uBAAuB,CAC3C,GAAG,CAAC,eAAe,CAAC,WAAW,CAChC,CAAC;IACJ,CAAC;wGA9JU,gBAAgB;4FAAhB,gBAAgB,+PCzB7B,mwCA0BA;;4FDDa,gBAAgB;kBAL5B,SAAS;+BACE,aAAa;gPAKd,SAAS;sBAAjB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,GAAG;sBAAX,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBAEI,wBAAwB;sBAAjC,MAAM;gBACG,UAAU;sBAAnB,MAAM","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  OnChanges,\r\n  Inject,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  ViewEncapsulation,\r\n  ElementRef,\r\n} from \"@angular/core\";\r\nimport { SalesforceService } from \"../../services/salesforce.service\";\r\nimport { DataService } from '../../services/data.service';\r\nimport { ActivatedRoute, Params } from \"@angular/router\";\r\nimport { DomSanitizer, SafeHtml } from \"@angular/platform-browser\";\r\nimport { ActionMeta } from '../../interfaces/actionMeta';\r\nimport { Question } from \"../../wrapper\";\r\nimport { BookletWrapper } from \"../../model/bookletWrapper\";\r\nimport { StorageService } from '../../services/storage.service';\r\n\r\n@Component({\r\n  selector: 'lib-booklet',\r\n  templateUrl: './booklet.component.html',\r\n  styleUrls: ['./booklet.component.css']\r\n})\r\nexport class BookletComponent implements OnInit {\r\n  @Input() bookletId: string;\r\n  @Input() serv: string;\r\n  @Input() tkn: string;\r\n  @Input() bookletJSON: any;\r\n  \r\n  @Output() handleBookletActionEvent: EventEmitter<any> = new EventEmitter();\r\n  @Output() handlePage: EventEmitter<any> = new EventEmitter();\r\n\r\n  public nxtBooklet: BookletWrapper;\r\n\r\n  public booklet: any[] = [];\r\n  public abItem: any = {};\r\n  public actions: ActionMeta[] = [];\r\n  public bookQuestionsMap: any = new Map();\r\n  private sqOptions: any = new Map();\r\n  public isAnswerFlag: boolean = false;\r\n  public spinnerName: string;\r\n  public spinnerType: string;\r\n\r\n  constructor(\r\n    private sfService: SalesforceService,\r\n    private dataService: DataService,\r\n    private storageService: StorageService,\r\n    private route: ActivatedRoute,\r\n    private sanitizer: DomSanitizer,\r\n    el: ElementRef\r\n  ) { \r\n    this.spinnerName = \"sp1\";\r\n    this.spinnerType = \"ball-spin-clockwise\";\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.processBooklet();\r\n  }\r\n\r\n  ngOnChanges() {\r\n    console.log('inside Questionnaire ngOnChanges');\r\n    console.log(this.booklet);\r\n    if(this.booklet == undefined || this.booklet.length == 0) {\r\n      this.processBooklet();\r\n    }\r\n  }\r\n\r\n  processBooklet() {\r\n    if (this.bookletId) {\r\n      if (this.bookletId.length == 18) {\r\n        this.readBooklet(this.bookletId);\r\n      }\r\n    } else if(this.bookletJSON) {\r\n      // Try to pass a value from Backend to differentiate the QuestionBook Read and AnswerBook Read\r\n      this.isAnswerFlag = true;\r\n\r\n      if(this.bookletJSON != null || this.bookletJSON != undefined) {\r\n          // Storing the API response for future use\r\n          this.storageService.save(this.bookletJSON);\r\n      }\r\n      \r\n      this.booklet = this.bookletJSON.records;\r\n      this.abItem = this.bookletJSON.answerbook;\r\n\r\n      // Process the Sub Question Options - This should be merged with bookQuestionsMap in future\r\n      for (var sq in this.bookletJSON.sqOptions) {\r\n        this.sqOptions.set(sq, this.bookletJSON.sqOptions[sq]);\r\n      }\r\n\r\n      // Process the Questions\r\n      for (var value in this.bookletJSON.bookQuestionsMap) {\r\n        this.bookQuestionsMap.set(value, this.bookletJSON.bookQuestionsMap[value]);\r\n      }\r\n\r\n      if(this.bookletJSON.questionbook?.Actions__c != undefined) {\r\n        this.actions = JSON.parse(this.bookletJSON.questionbook.Actions__c);\r\n      }\r\n    }\r\n  }\r\n\r\n  private readBooklet = (uuid: string) => {\r\n    if(this.serv == \"api\") {\r\n      this.dataService.getAPIData(\r\n        this.tkn,\r\n        [\"Booklet\", \"read\", uuid],\r\n        this.successReadBooklet,\r\n        this.failureReadBooklet\r\n      );\r\n    } else {\r\n      this.sfService.remoteAction(\r\n        \"NxtController.process\",\r\n        [\"Booklet\", \"read\", uuid],\r\n        this.successReadBooklet,\r\n        this.failureReadBooklet\r\n      );\r\n    }\r\n  }\r\n\r\n  private successReadBooklet = (response) => {\r\n    console.log('Inside the successReadBooklet');\r\n    // console.log(response);\r\n    if(response != null || response != undefined) {\r\n      // Storing the API response for future use\r\n      this.storageService.save(response);\r\n\r\n      // Try to pass a value from Backend to differentiate the QuestionBook Read and AnswerBook Read\r\n      // this.isAnswerFlag = true;\r\n      \r\n      this.booklet = response.records;\r\n      this.abItem = response.answerbook;\r\n\r\n      // Process the Sub Question Options - This should be merged with bookQuestionsMap in future\r\n      for (var sq in response.sqOptions) {\r\n        this.sqOptions.set(sq, response.sqOptions[sq]);\r\n      }\r\n\r\n      // Process the Questions\r\n      for (var value in response.bookQuestionsMap) {\r\n        this.bookQuestionsMap.set(value, response.bookQuestionsMap[value]);\r\n      }\r\n\r\n      if(response.questionbook?.Actions__c != undefined) {\r\n        this.actions = JSON.parse(response.questionbook.Actions__c);\r\n      }\r\n    }\r\n  }\r\n\r\n  private failureReadBooklet = (response) => {\r\n\r\n  }\r\n\r\n  handleBookletActionClick(action:ActionMeta) {\r\n    console.log(action);\r\n    let dataToParent = {};\r\n    dataToParent['action'] = action.eventtoemit;\r\n    dataToParent['data'] = this.storageService.get();\r\n    this.handleBookletActionEvent.emit(dataToParent);\r\n  }\r\n\r\n  readQuestions(qbId: string) {\r\n    console.log('inside BookletComponent.readQuestions ' + qbId);\r\n    // console.log(this.bookQuestionsMap.size);\r\n    let questions = [];\r\n    for(var sq in this.bookQuestionsMap?.get(qbId).Questions__r.records) {\r\n      let q: Question = this.bookQuestionsMap?.get(qbId).Questions__r.records[sq];\r\n      if(q.Type__c == 'Dropdown') {\r\n        questions.push(this.sqOptions.get(q.Id));\r\n      } else {\r\n        questions.push(q);\r\n      }\r\n    }\r\n    // console.log(questions);\r\n    return questions;\r\n  }\r\n\r\n  getText(value) {\r\n    var doc = new DOMParser().parseFromString(value, \"text/html\");\r\n    //console.log( doc.documentElement.textContent);\r\n    return this.sanitizer.bypassSecurityTrustHtml(\r\n      doc.documentElement.textContent\r\n    );\r\n  }\r\n}\r\n","<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\r\n<!-- Booklet Handling-->\r\n<div *ngFor=\"let qb of booklet\">\r\n    <!-- MR Commented below code to ensure single JSON for UNCONDITIONAL Booklets -->\r\n    <!-- <lib-questionnaire [serv]=\"serv\" [qbId]=\"qb.Id\" [tkn]=\"tkn\"></lib-questionnaire> -->\r\n\r\n    <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\r\n        <div class=\"questiondiv2\">\r\n            <div *ngIf=\"!ques.Is_Title__c\" [class]=\"qb.isShengel__c ? 'header-style' : 'question-f-size additional'\">\r\n                <div [innerHTML]=\"getText(ques?.Question_Text__c)\" >\r\n                    {{ ques?.Question_Text__c }}\r\n                </div>\r\n            </div>\r\n            <lib-questionbook [qbItem]=\"qb\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\"></lib-questionbook>\r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n<!-- Group Actions -->\r\n<div class=\"align-submit-row\" *ngIf=\"abItem.Status__c != 'Completed'\">\r\n    <div *ngFor=\"let action of actions\">\r\n        <button (click)=\"handleBookletActionClick(action)\">\r\n            {{ action.name }}\r\n        </button>\r\n    </div>\r\n</div>\r\n"]}
@@ -3,28 +3,31 @@ import * as i0 from "@angular/core";
3
3
  import * as i1 from "../../services/salesforce.service";
4
4
  import * as i2 from "../../services/data.service";
5
5
  import * as i3 from "../../services/change.service";
6
- import * as i4 from "@angular/common";
7
- import * as i5 from "@angular/forms";
8
- import * as i6 from "../../components/pick-location/pick-location.component";
9
- import * as i7 from "../../components/custom-input/custom-input.component";
10
- import * as i8 from "../../components/custom-text-area/custom-text-area.component";
11
- import * as i9 from "../../components/custom-table/custom-table.component";
12
- import * as i10 from "../../components/custom-date-picker/custom-date-picker.component";
13
- import * as i11 from "../../components/custom-dropdown/custom-dropdown.component";
14
- import * as i12 from "../../components/file-upload/file-upload.component";
6
+ import * as i4 from "../../services/storage.service";
7
+ import * as i5 from "@angular/common";
8
+ import * as i6 from "@angular/forms";
9
+ import * as i7 from "../../components/pick-location/pick-location.component";
10
+ import * as i8 from "../../components/custom-input/custom-input.component";
11
+ import * as i9 from "../../components/custom-text-area/custom-text-area.component";
12
+ import * as i10 from "../../components/custom-table/custom-table.component";
13
+ import * as i11 from "../../components/custom-date-picker/custom-date-picker.component";
14
+ import * as i12 from "../../components/custom-dropdown/custom-dropdown.component";
15
+ import * as i13 from "../../components/file-upload/file-upload.component";
15
16
  export class QuestionbookComponent {
16
17
  sfService;
17
18
  dataService;
18
19
  changeService;
20
+ storageService;
19
21
  qbItem;
20
22
  questionItem;
21
23
  questions;
22
24
  subQuestions;
23
25
  selectedFileData = [];
24
- constructor(sfService, dataService, changeService) {
26
+ constructor(sfService, dataService, changeService, storageService) {
25
27
  this.sfService = sfService;
26
28
  this.dataService = dataService;
27
29
  this.changeService = changeService;
30
+ this.storageService = storageService;
28
31
  }
29
32
  ngOnInit() {
30
33
  console.log('inside QuestionBookComponent OnInit');
@@ -49,7 +52,18 @@ export class QuestionbookComponent {
49
52
  console.log('inside QuestionbookComponent childEventCapture');
50
53
  console.log(event);
51
54
  this.changeService.announceChange(event);
52
- //ques.input = event; // here when using the ng-select got event as value
55
+ // Process the changes in Table and Dropdown and store right value in ques.input
56
+ if (ques.Type__c == 'Table') {
57
+ ques.input = null;
58
+ }
59
+ else if (ques.Type__c == 'Dropdown') {
60
+ ques.input = event.valueObj.name;
61
+ }
62
+ else {
63
+ ques.input = event;
64
+ }
65
+ // Once the right value is stored in ques.input store the ques (with input) in storageService
66
+ this.storageService.update(ques);
53
67
  }
54
68
  assignSelectedFileData(fileData) {
55
69
  console.log('fileDATA', fileData);
@@ -58,17 +72,17 @@ export class QuestionbookComponent {
58
72
  deleteFile(fileData) {
59
73
  console.log('fileDATA', fileData);
60
74
  }
61
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: QuestionbookComponent, deps: [{ token: i1.SalesforceService }, { token: i2.DataService }, { token: i3.ChangeService }], target: i0.ɵɵFactoryTarget.Component });
62
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: QuestionbookComponent, selector: "lib-questionbook", inputs: { qbItem: "qbItem", questionItem: "questionItem", questions: "questions" }, ngImport: i0, template: "<div [class]=\"qbItem.isShengel__c ? 'form-group content-box' : 'form-group'\">\r\n <div class=\"form-row\">\r\n <div [class]=\"qbItem.isShengel__c ? '' : 'myt-align3'\"\r\n [class]=\"qbItem.isShengel__c ? 'col-lg-' + ques.Size__c + ' paddingnone' : 'col-md-' + ques.Size__c + ' paddingnone'\"\r\n *ngFor=\"let ques of questions;let i = index\" [id]=\"ques.Id\">\r\n <!-- Sub Question Label -->\r\n <div [ngClass]=\"{ down2: qbItem?.Progress_Bar__c }\">\r\n <span [class]=\"qbItem.isShengel__c ? 'dis-flex shengel-myt-font3 myt-font7' : 'dis-flex myt-font3 myt-font7' \">{{ ques?.Question__c }}</span>\r\n </div>\r\n\r\n <!-- DateTime -->\r\n <div *ngIf=\"ques.Type__c === 'DateTime'\">\r\n <app-custom-date-picker [minDate]=\"ques.minDate\" [date]=\"ques.input\" (dateChange)=\"childEventCapture($event, ques)\">\r\n </app-custom-date-picker>\r\n </div>\r\n\r\n <!-- Text -->\r\n <div *ngIf=\"ques.Type__c === 'Text'\">\r\n <app-custom-input [fromShengel]=\"qbItem.isShengel__c\" [value]=\"ques.input\" [ngClassValue]=\"{\r\n 'dis-flex dt-line date-line bookText boxoutline myt-font1': qbItem.Progress_Bar__c,\r\n textBox: !qbItem.Progress_Bar__c\r\n }\" [question]=\"ques\" [idValue]=\"ques.Tracking_ID__c\" [focusEvent]=\"clearSQError(ques.Id)\"\r\n [error]=\"ques.error\" [placeholder]=\"ques.Question__c\" (inputValue)=\"childEventCapture($event, ques)\">\r\n </app-custom-input>\r\n </div>\r\n \r\n <!-- for pick location -->\r\n <div *ngIf=\"ques.Type__c === 'Location'\">\r\n <app-pick-location [address]=\"ques.input\" (locationSelected)=\"childEventCapture($event, ques)\">\r\n </app-pick-location>\r\n </div>\r\n\r\n <!-- for text area -->\r\n <div *ngIf=\"ques.Type__c === 'TextArea'\">\r\n <app-custom-text-area [value]=\"ques.input\" [rows]=\"3\" [error]=\"ques.error\" [placeholder]=\"ques.Question__c \"\r\n (textareaValueChange)=\"childEventCapture($event)\"></app-custom-text-area>\r\n </div>\r\n\r\n <!-- Email -->\r\n <div *ngIf=\"ques.Type__c === 'Email'\">\r\n <input type=\"email\" [(ngModel)]=\"ques.input\" [id]=\"ques.Id\" required=\"\" (focus)=\"clearSQError(ques.Id)\"\r\n style.border-color=\"{{ ques.error ? 'red' : '' }}\" placeholder=\"{{ ques.Question__c }}\" />\r\n </div>\r\n\r\n <!-- Table -->\r\n <div *ngIf=\"ques.Type__c === 'Table'\" class=\"\">\r\n <app-custom-table [question]=\"ques\" (valueChange)=\"childEventCapture($event, ques); clearSQError(ques.Id)\">\r\n </app-custom-table>\r\n </div>\r\n\r\n <!-- Dropdown -->\r\n <div *ngIf=\"ques.Type__c === 'Dropdown'\" class=\"\">\r\n <app-custom-dropdown [fromShengel]=\"qbItem.isShengel__c\" [options]=\"ques.Question_Options__r.records\"\r\n [apiMeta]=\"ques.Sub_Text__c\" [id]=\"ques.Id\" [selectedValue]=\"ques.input\" [placeholder]=\"'---Select---'\"\r\n [errorMessage]=\"ques.Error_Message__c\" [error]=\"ques.error\"\r\n (valueChange)=\"childEventCapture($event, ques); clearSQError(ques.Id)\">\r\n </app-custom-dropdown>\r\n <i class=\"fa fa-check \" aria-hidden=\"true\" *ngIf=\"ques?.input?.length > 0\"></i>\r\n </div>\r\n\r\n <!-- file Upload -->\r\n <div *ngIf=\"ques.Type__c === 'File'\" class=\"\">\r\n <app-file-upload [limitFileUploading]=\"5\" [allFiles]=\"selectedFileData\"\r\n (selectedFileData)=\"assignSelectedFileData($event)\" (deletedFileData)=\"deleteFile($event)\"\r\n [isDeleteFileButtonVisible]=\"true\"></app-file-upload>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [".form-group.content-box{background:#ffffff;padding:40px;border:1px solid #e8e8e8;border-bottom-left-radius:5px;border-bottom-right-radius:5px}.form-row{display:flex;flex-wrap:wrap;margin-right:-5px;margin-left:-5px}.col-lg-6{width:100%}.shengel-myt-font3{padding:5px 15px 5px 2px;color:#9a9a9a;font-size:14px;font-weight:400}.myt-font7{display:flex;justify-content:flex-start}@media (min-width: 1200px){.col-lg-6{width:50%!important}}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.PickLocationComponent, selector: "app-pick-location", inputs: ["address"], outputs: ["locationSelected"] }, { kind: "component", type: i7.CustomInputComponent, selector: "app-custom-input", inputs: ["value", "question", "disabled", "placeholder", "error", "fromShengel", "ngClassValue", "idValue", "focusEvent"], outputs: ["inputValue"] }, { kind: "component", type: i8.CustomTextAreaComponent, selector: "app-custom-text-area", inputs: ["value", "placeholder", "rows", "error"], outputs: ["textareaValueChange"] }, { kind: "component", type: i9.CustomTableComponent, selector: "app-custom-table", inputs: ["question"], outputs: ["valueChange"] }, { kind: "component", type: i10.CustomDatePickerComponent, selector: "app-custom-date-picker", inputs: ["date", "minDate", "maxDate"], outputs: ["dateChange"] }, { kind: "component", type: i11.CustomDropdownComponent, selector: "app-custom-dropdown", inputs: ["options", "placeholder", "apiMeta", "selectedValue", "progressBar", "id", "errorMessage", "error", "fromShengel"], outputs: ["valueChange"] }, { kind: "component", type: i12.FileUploadComponent, selector: "app-file-upload", inputs: ["allFiles", "limitFileUploading", "isDeleteFileButtonVisible", "isShowNoFileIcon"], outputs: ["selectedFileData", "deletedFileData"] }] });
75
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: QuestionbookComponent, deps: [{ token: i1.SalesforceService }, { token: i2.DataService }, { token: i3.ChangeService }, { token: i4.StorageService }], target: i0.ɵɵFactoryTarget.Component });
76
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: QuestionbookComponent, selector: "lib-questionbook", inputs: { qbItem: "qbItem", questionItem: "questionItem", questions: "questions" }, ngImport: i0, template: "<div [class]=\"qbItem.isShengel__c ? 'form-group content-box' : 'form-group'\">\r\n <div class=\"form-row\">\r\n <div [class]=\"qbItem.isShengel__c ? '' : 'myt-align3'\"\r\n [class]=\"qbItem.isShengel__c ? 'col-lg-' + ques.Size__c + ' paddingnone' : 'col-md-' + ques.Size__c + ' paddingnone'\"\r\n *ngFor=\"let ques of questions;let i = index\" [id]=\"ques.Id\">\r\n <!-- Sub Question Label -->\r\n <div [ngClass]=\"{ down2: qbItem?.Progress_Bar__c }\">\r\n <span [class]=\"qbItem.isShengel__c ? 'dis-flex shengel-myt-font3 myt-font7' : 'dis-flex myt-font3 myt-font7' \">{{ ques?.Question__c }}</span>\r\n </div>\r\n\r\n <!-- DateTime -->\r\n <div *ngIf=\"ques.Type__c === 'DateTime'\">\r\n <app-custom-date-picker [minDate]=\"ques.minDate\" [date]=\"ques.input\" (dateChange)=\"childEventCapture($event, ques)\">\r\n </app-custom-date-picker>\r\n </div>\r\n\r\n <!-- Text -->\r\n <div *ngIf=\"ques.Type__c === 'Text'\">\r\n <app-custom-input [fromShengel]=\"qbItem.isShengel__c\" [value]=\"ques.input\" [ngClassValue]=\"{\r\n 'dis-flex dt-line date-line bookText boxoutline myt-font1': qbItem.Progress_Bar__c,\r\n textBox: !qbItem.Progress_Bar__c\r\n }\" [question]=\"ques\" [idValue]=\"ques.Tracking_ID__c\" [focusEvent]=\"clearSQError(ques.Id)\"\r\n [error]=\"ques.error\" [placeholder]=\"ques.Question__c\" (inputValue)=\"childEventCapture($event, ques)\">\r\n </app-custom-input>\r\n </div>\r\n \r\n <!-- for pick location -->\r\n <div *ngIf=\"ques.Type__c === 'Location'\">\r\n <app-pick-location [address]=\"ques.input\" (locationSelected)=\"childEventCapture($event, ques)\">\r\n </app-pick-location>\r\n </div>\r\n\r\n <!-- for text area -->\r\n <div *ngIf=\"ques.Type__c === 'TextArea'\">\r\n <app-custom-text-area [value]=\"ques.input\" [rows]=\"3\" [error]=\"ques.error\" [placeholder]=\"ques.Question__c \"\r\n (textareaValueChange)=\"childEventCapture($event)\"></app-custom-text-area>\r\n </div>\r\n\r\n <!-- Email -->\r\n <div *ngIf=\"ques.Type__c === 'Email'\">\r\n <input type=\"email\" [(ngModel)]=\"ques.input\" [id]=\"ques.Id\" required=\"\" (focus)=\"clearSQError(ques.Id)\"\r\n style.border-color=\"{{ ques.error ? 'red' : '' }}\" placeholder=\"{{ ques.Question__c }}\" />\r\n </div>\r\n\r\n <!-- Table -->\r\n <div *ngIf=\"ques.Type__c === 'Table'\" class=\"\">\r\n <app-custom-table [question]=\"ques\" (valueChange)=\"childEventCapture($event, ques); clearSQError(ques.Id)\">\r\n </app-custom-table>\r\n </div>\r\n\r\n <!-- Dropdown -->\r\n <div *ngIf=\"ques.Type__c === 'Dropdown'\" class=\"\">\r\n <app-custom-dropdown [fromShengel]=\"qbItem.isShengel__c\" [options]=\"ques.Question_Options__r.records\"\r\n [apiMeta]=\"ques.Sub_Text__c\" [id]=\"ques.Id\" [selectedValue]=\"ques.input\" [placeholder]=\"'---Select---'\"\r\n [errorMessage]=\"ques.Error_Message__c\" [error]=\"ques.error\"\r\n (valueChange)=\"childEventCapture($event, ques); clearSQError(ques.Id)\">\r\n </app-custom-dropdown>\r\n <i class=\"fa fa-check \" aria-hidden=\"true\" *ngIf=\"ques?.input?.length > 0\"></i>\r\n </div>\r\n\r\n <!-- Attachment / Files -->\r\n <div *ngIf=\"ques.Type__c === 'File'\" class=\"\">\r\n <app-file-upload [limitFileUploading]=\"5\" [allFiles]=\"selectedFileData\"\r\n (selectedFileData)=\"assignSelectedFileData($event)\" (deletedFileData)=\"deleteFile($event)\"\r\n [isDeleteFileButtonVisible]=\"true\"></app-file-upload>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [".form-group.content-box{background:#ffffff;padding:40px;border:1px solid #e8e8e8;border-bottom-left-radius:5px;border-bottom-right-radius:5px}.form-row{display:flex;flex-wrap:wrap;margin-right:-5px;margin-left:-5px}.col-lg-6{width:100%}.shengel-myt-font3{padding:5px 15px 5px 2px;color:#9a9a9a;font-size:14px;font-weight:400}.myt-font7{display:flex;justify-content:flex-start}@media (min-width: 1200px){.col-lg-6{width:50%!important}}\n"], dependencies: [{ kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i7.PickLocationComponent, selector: "app-pick-location", inputs: ["address"], outputs: ["locationSelected"] }, { kind: "component", type: i8.CustomInputComponent, selector: "app-custom-input", inputs: ["value", "question", "disabled", "placeholder", "error", "fromShengel", "ngClassValue", "idValue", "focusEvent"], outputs: ["inputValue"] }, { kind: "component", type: i9.CustomTextAreaComponent, selector: "app-custom-text-area", inputs: ["value", "placeholder", "rows", "error"], outputs: ["textareaValueChange"] }, { kind: "component", type: i10.CustomTableComponent, selector: "app-custom-table", inputs: ["question"], outputs: ["valueChange"] }, { kind: "component", type: i11.CustomDatePickerComponent, selector: "app-custom-date-picker", inputs: ["date", "minDate", "maxDate"], outputs: ["dateChange"] }, { kind: "component", type: i12.CustomDropdownComponent, selector: "app-custom-dropdown", inputs: ["options", "placeholder", "apiMeta", "selectedValue", "progressBar", "id", "errorMessage", "error", "fromShengel"], outputs: ["valueChange"] }, { kind: "component", type: i13.FileUploadComponent, selector: "app-file-upload", inputs: ["allFiles", "limitFileUploading", "isDeleteFileButtonVisible", "isShowNoFileIcon"], outputs: ["selectedFileData", "deletedFileData"] }] });
63
77
  }
64
78
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: QuestionbookComponent, decorators: [{
65
79
  type: Component,
66
- args: [{ selector: 'lib-questionbook', template: "<div [class]=\"qbItem.isShengel__c ? 'form-group content-box' : 'form-group'\">\r\n <div class=\"form-row\">\r\n <div [class]=\"qbItem.isShengel__c ? '' : 'myt-align3'\"\r\n [class]=\"qbItem.isShengel__c ? 'col-lg-' + ques.Size__c + ' paddingnone' : 'col-md-' + ques.Size__c + ' paddingnone'\"\r\n *ngFor=\"let ques of questions;let i = index\" [id]=\"ques.Id\">\r\n <!-- Sub Question Label -->\r\n <div [ngClass]=\"{ down2: qbItem?.Progress_Bar__c }\">\r\n <span [class]=\"qbItem.isShengel__c ? 'dis-flex shengel-myt-font3 myt-font7' : 'dis-flex myt-font3 myt-font7' \">{{ ques?.Question__c }}</span>\r\n </div>\r\n\r\n <!-- DateTime -->\r\n <div *ngIf=\"ques.Type__c === 'DateTime'\">\r\n <app-custom-date-picker [minDate]=\"ques.minDate\" [date]=\"ques.input\" (dateChange)=\"childEventCapture($event, ques)\">\r\n </app-custom-date-picker>\r\n </div>\r\n\r\n <!-- Text -->\r\n <div *ngIf=\"ques.Type__c === 'Text'\">\r\n <app-custom-input [fromShengel]=\"qbItem.isShengel__c\" [value]=\"ques.input\" [ngClassValue]=\"{\r\n 'dis-flex dt-line date-line bookText boxoutline myt-font1': qbItem.Progress_Bar__c,\r\n textBox: !qbItem.Progress_Bar__c\r\n }\" [question]=\"ques\" [idValue]=\"ques.Tracking_ID__c\" [focusEvent]=\"clearSQError(ques.Id)\"\r\n [error]=\"ques.error\" [placeholder]=\"ques.Question__c\" (inputValue)=\"childEventCapture($event, ques)\">\r\n </app-custom-input>\r\n </div>\r\n \r\n <!-- for pick location -->\r\n <div *ngIf=\"ques.Type__c === 'Location'\">\r\n <app-pick-location [address]=\"ques.input\" (locationSelected)=\"childEventCapture($event, ques)\">\r\n </app-pick-location>\r\n </div>\r\n\r\n <!-- for text area -->\r\n <div *ngIf=\"ques.Type__c === 'TextArea'\">\r\n <app-custom-text-area [value]=\"ques.input\" [rows]=\"3\" [error]=\"ques.error\" [placeholder]=\"ques.Question__c \"\r\n (textareaValueChange)=\"childEventCapture($event)\"></app-custom-text-area>\r\n </div>\r\n\r\n <!-- Email -->\r\n <div *ngIf=\"ques.Type__c === 'Email'\">\r\n <input type=\"email\" [(ngModel)]=\"ques.input\" [id]=\"ques.Id\" required=\"\" (focus)=\"clearSQError(ques.Id)\"\r\n style.border-color=\"{{ ques.error ? 'red' : '' }}\" placeholder=\"{{ ques.Question__c }}\" />\r\n </div>\r\n\r\n <!-- Table -->\r\n <div *ngIf=\"ques.Type__c === 'Table'\" class=\"\">\r\n <app-custom-table [question]=\"ques\" (valueChange)=\"childEventCapture($event, ques); clearSQError(ques.Id)\">\r\n </app-custom-table>\r\n </div>\r\n\r\n <!-- Dropdown -->\r\n <div *ngIf=\"ques.Type__c === 'Dropdown'\" class=\"\">\r\n <app-custom-dropdown [fromShengel]=\"qbItem.isShengel__c\" [options]=\"ques.Question_Options__r.records\"\r\n [apiMeta]=\"ques.Sub_Text__c\" [id]=\"ques.Id\" [selectedValue]=\"ques.input\" [placeholder]=\"'---Select---'\"\r\n [errorMessage]=\"ques.Error_Message__c\" [error]=\"ques.error\"\r\n (valueChange)=\"childEventCapture($event, ques); clearSQError(ques.Id)\">\r\n </app-custom-dropdown>\r\n <i class=\"fa fa-check \" aria-hidden=\"true\" *ngIf=\"ques?.input?.length > 0\"></i>\r\n </div>\r\n\r\n <!-- file Upload -->\r\n <div *ngIf=\"ques.Type__c === 'File'\" class=\"\">\r\n <app-file-upload [limitFileUploading]=\"5\" [allFiles]=\"selectedFileData\"\r\n (selectedFileData)=\"assignSelectedFileData($event)\" (deletedFileData)=\"deleteFile($event)\"\r\n [isDeleteFileButtonVisible]=\"true\"></app-file-upload>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [".form-group.content-box{background:#ffffff;padding:40px;border:1px solid #e8e8e8;border-bottom-left-radius:5px;border-bottom-right-radius:5px}.form-row{display:flex;flex-wrap:wrap;margin-right:-5px;margin-left:-5px}.col-lg-6{width:100%}.shengel-myt-font3{padding:5px 15px 5px 2px;color:#9a9a9a;font-size:14px;font-weight:400}.myt-font7{display:flex;justify-content:flex-start}@media (min-width: 1200px){.col-lg-6{width:50%!important}}\n"] }]
67
- }], ctorParameters: function () { return [{ type: i1.SalesforceService }, { type: i2.DataService }, { type: i3.ChangeService }]; }, propDecorators: { qbItem: [{
80
+ args: [{ selector: 'lib-questionbook', template: "<div [class]=\"qbItem.isShengel__c ? 'form-group content-box' : 'form-group'\">\r\n <div class=\"form-row\">\r\n <div [class]=\"qbItem.isShengel__c ? '' : 'myt-align3'\"\r\n [class]=\"qbItem.isShengel__c ? 'col-lg-' + ques.Size__c + ' paddingnone' : 'col-md-' + ques.Size__c + ' paddingnone'\"\r\n *ngFor=\"let ques of questions;let i = index\" [id]=\"ques.Id\">\r\n <!-- Sub Question Label -->\r\n <div [ngClass]=\"{ down2: qbItem?.Progress_Bar__c }\">\r\n <span [class]=\"qbItem.isShengel__c ? 'dis-flex shengel-myt-font3 myt-font7' : 'dis-flex myt-font3 myt-font7' \">{{ ques?.Question__c }}</span>\r\n </div>\r\n\r\n <!-- DateTime -->\r\n <div *ngIf=\"ques.Type__c === 'DateTime'\">\r\n <app-custom-date-picker [minDate]=\"ques.minDate\" [date]=\"ques.input\" (dateChange)=\"childEventCapture($event, ques)\">\r\n </app-custom-date-picker>\r\n </div>\r\n\r\n <!-- Text -->\r\n <div *ngIf=\"ques.Type__c === 'Text'\">\r\n <app-custom-input [fromShengel]=\"qbItem.isShengel__c\" [value]=\"ques.input\" [ngClassValue]=\"{\r\n 'dis-flex dt-line date-line bookText boxoutline myt-font1': qbItem.Progress_Bar__c,\r\n textBox: !qbItem.Progress_Bar__c\r\n }\" [question]=\"ques\" [idValue]=\"ques.Tracking_ID__c\" [focusEvent]=\"clearSQError(ques.Id)\"\r\n [error]=\"ques.error\" [placeholder]=\"ques.Question__c\" (inputValue)=\"childEventCapture($event, ques)\">\r\n </app-custom-input>\r\n </div>\r\n \r\n <!-- for pick location -->\r\n <div *ngIf=\"ques.Type__c === 'Location'\">\r\n <app-pick-location [address]=\"ques.input\" (locationSelected)=\"childEventCapture($event, ques)\">\r\n </app-pick-location>\r\n </div>\r\n\r\n <!-- for text area -->\r\n <div *ngIf=\"ques.Type__c === 'TextArea'\">\r\n <app-custom-text-area [value]=\"ques.input\" [rows]=\"3\" [error]=\"ques.error\" [placeholder]=\"ques.Question__c \"\r\n (textareaValueChange)=\"childEventCapture($event)\"></app-custom-text-area>\r\n </div>\r\n\r\n <!-- Email -->\r\n <div *ngIf=\"ques.Type__c === 'Email'\">\r\n <input type=\"email\" [(ngModel)]=\"ques.input\" [id]=\"ques.Id\" required=\"\" (focus)=\"clearSQError(ques.Id)\"\r\n style.border-color=\"{{ ques.error ? 'red' : '' }}\" placeholder=\"{{ ques.Question__c }}\" />\r\n </div>\r\n\r\n <!-- Table -->\r\n <div *ngIf=\"ques.Type__c === 'Table'\" class=\"\">\r\n <app-custom-table [question]=\"ques\" (valueChange)=\"childEventCapture($event, ques); clearSQError(ques.Id)\">\r\n </app-custom-table>\r\n </div>\r\n\r\n <!-- Dropdown -->\r\n <div *ngIf=\"ques.Type__c === 'Dropdown'\" class=\"\">\r\n <app-custom-dropdown [fromShengel]=\"qbItem.isShengel__c\" [options]=\"ques.Question_Options__r.records\"\r\n [apiMeta]=\"ques.Sub_Text__c\" [id]=\"ques.Id\" [selectedValue]=\"ques.input\" [placeholder]=\"'---Select---'\"\r\n [errorMessage]=\"ques.Error_Message__c\" [error]=\"ques.error\"\r\n (valueChange)=\"childEventCapture($event, ques); clearSQError(ques.Id)\">\r\n </app-custom-dropdown>\r\n <i class=\"fa fa-check \" aria-hidden=\"true\" *ngIf=\"ques?.input?.length > 0\"></i>\r\n </div>\r\n\r\n <!-- Attachment / Files -->\r\n <div *ngIf=\"ques.Type__c === 'File'\" class=\"\">\r\n <app-file-upload [limitFileUploading]=\"5\" [allFiles]=\"selectedFileData\"\r\n (selectedFileData)=\"assignSelectedFileData($event)\" (deletedFileData)=\"deleteFile($event)\"\r\n [isDeleteFileButtonVisible]=\"true\"></app-file-upload>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [".form-group.content-box{background:#ffffff;padding:40px;border:1px solid #e8e8e8;border-bottom-left-radius:5px;border-bottom-right-radius:5px}.form-row{display:flex;flex-wrap:wrap;margin-right:-5px;margin-left:-5px}.col-lg-6{width:100%}.shengel-myt-font3{padding:5px 15px 5px 2px;color:#9a9a9a;font-size:14px;font-weight:400}.myt-font7{display:flex;justify-content:flex-start}@media (min-width: 1200px){.col-lg-6{width:50%!important}}\n"] }]
81
+ }], ctorParameters: function () { return [{ type: i1.SalesforceService }, { type: i2.DataService }, { type: i3.ChangeService }, { type: i4.StorageService }]; }, propDecorators: { qbItem: [{
68
82
  type: Input
69
83
  }], questionItem: [{
70
84
  type: Input
71
85
  }], questions: [{
72
86
  type: Input
73
87
  }] } });
74
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"questionbook.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/pages/questionbook/questionbook.component.ts","../../../../../../projects/nxt-app/src/lib/pages/questionbook/questionbook.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAU,KAAK,GAAyB,MAAM,eAAe,CAAC;;;;;;;;;;;;;;AAWhF,MAAM,OAAO,qBAAqB;IAQZ;IACV;IACA;IATD,MAAM,CAAe;IACrB,YAAY,CAAW;IACvB,SAAS,CAAa;IAE/B,YAAY,CAAa;IACzB,gBAAgB,GAAU,EAAE,CAAC;IAE7B,YAAoB,SAA4B,EACtC,WAAwB,EACxB,aAA4B;QAFlB,cAAS,GAAT,SAAS,CAAmB;QACtC,gBAAW,GAAX,WAAW,CAAa;QACxB,kBAAa,GAAb,aAAa,CAAe;IAEtC,CAAC;IAED,QAAQ;QACN,OAAO,CAAC,GAAG,CAAC,qCAAqC,CAAC,CAAC;QACnD,4BAA4B;QAC5B,+BAA+B;QAC/B,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACvB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACvC,CAAC;IAED,YAAY,CAAC,MAAM;QACjB,4DAA4D;QAC5D,IAAI,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,EAAE,IAAI,MAAM,CAAC,CAAC;QACnE,KAAK,IAAI,EAAE,IAAI,MAAM,EAAE;YACrB,EAAE,CAAC,KAAK,GAAG,IAAI,CAAC;SACjB;IACH,CAAC;IAED,eAAe,CAAC,OAAO;QACrB,OAAO,CAAC,GAAG,CAAC,8CAA8C,CAAC,CAAC;QAC5D,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAClC,CAAC;IAED,kCAAkC;IAClC,iBAAiB,CAAC,KAAK,EAAE,IAAS;QAChC,OAAO,CAAC,GAAG,CAAC,gDAAgD,CAAC,CAAC;QAC9D,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACnB,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QACzC,yEAAyE;IAC3E,CAAC;IACD,sBAAsB,CAAC,QAAY;QACjC,OAAO,CAAC,GAAG,CAAC,UAAU,EAAC,QAAQ,CAAC,CAAC;QACjC,IAAI,CAAC,gBAAgB,GAAG,QAAQ,CAAC;IACnC,CAAC;IACD,UAAU,CAAC,QAAY;QACrB,OAAO,CAAC,GAAG,CAAC,UAAU,EAAC,QAAQ,CAAC,CAAA;IAClC,CAAC;wGAhDU,qBAAqB;4FAArB,qBAAqB,4ICXlC,ilIAoEM;;4FDzDO,qBAAqB;kBALjC,SAAS;+BACE,kBAAkB;8JAKnB,MAAM;sBAAd,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,SAAS;sBAAjB,KAAK","sourcesContent":["import { Component, OnInit, Input, Output, EventEmitter, } from '@angular/core';\r\nimport { Question, QuestionBook } from '../../wrapper';\r\nimport { SalesforceService } from \"../../services/salesforce.service\";\r\nimport { DataService } from '../../services/data.service';\r\nimport { ChangeService } from '../../services/change.service';\r\n\r\n@Component({\r\n  selector: 'lib-questionbook',\r\n  templateUrl: './questionbook.component.html',\r\n  styleUrls: ['./questionbook.component.css']\r\n})\r\nexport class QuestionbookComponent implements OnInit {\r\n  @Input() qbItem: QuestionBook;\r\n  @Input() questionItem: Question;\r\n  @Input() questions: Question[];\r\n  \r\n  subQuestions: Question[];\r\n  selectedFileData: any[] = [];\r\n\r\n  constructor(private sfService: SalesforceService,\r\n    private dataService: DataService,\r\n    private changeService: ChangeService, ) { \r\n      \r\n  }\r\n\r\n  ngOnInit(): void {\r\n    console.log('inside QuestionBookComponent OnInit');\r\n    // console.log(this.qbItem);\r\n    // console.log(this.questions);\r\n    this.subQuestions = [];\r\n    this.setSubQuestions(this.questions);\r\n  }\r\n\r\n  clearSQError(quesId) {\r\n    // console.log('inside QuestionBookComponent clearSQError');\r\n    var sqList = this.subQuestions.filter((item) => item.Id == quesId);\r\n    for (var sq of sqList) {\r\n      sq.error = null;\r\n    }\r\n  }\r\n\r\n  setSubQuestions(records) {\r\n    console.log('inside QuestionbookComponent setSubQuestions');\r\n    this.subQuestions.push(records);\r\n  }\r\n\r\n  // Capture and Process Child Event\r\n  childEventCapture(event, ques?:any) {\r\n    console.log('inside QuestionbookComponent childEventCapture');\r\n    console.log(event);\r\n    this.changeService.announceChange(event);\r\n    //ques.input = event; // here when using the ng-select got event as value\r\n  }\r\n  assignSelectedFileData(fileData:any){\r\n    console.log('fileDATA',fileData);\r\n    this.selectedFileData = fileData;\r\n  }\r\n  deleteFile(fileData:any){\r\n    console.log('fileDATA',fileData)\r\n  }\r\n}\r\n","<div [class]=\"qbItem.isShengel__c ? 'form-group content-box' : 'form-group'\">\r\n    <div class=\"form-row\">\r\n        <div [class]=\"qbItem.isShengel__c ? '' : 'myt-align3'\"\r\n            [class]=\"qbItem.isShengel__c ? 'col-lg-' + ques.Size__c + ' paddingnone' : 'col-md-' + ques.Size__c + ' paddingnone'\"\r\n            *ngFor=\"let ques of questions;let i = index\" [id]=\"ques.Id\">\r\n            <!-- Sub Question Label -->\r\n            <div [ngClass]=\"{ down2: qbItem?.Progress_Bar__c }\">\r\n                <span [class]=\"qbItem.isShengel__c ? 'dis-flex shengel-myt-font3 myt-font7'  : 'dis-flex myt-font3 myt-font7' \">{{ ques?.Question__c }}</span>\r\n            </div>\r\n\r\n            <!-- DateTime -->\r\n            <div *ngIf=\"ques.Type__c === 'DateTime'\">\r\n                <app-custom-date-picker [minDate]=\"ques.minDate\" [date]=\"ques.input\" (dateChange)=\"childEventCapture($event, ques)\">\r\n                </app-custom-date-picker>\r\n            </div>\r\n\r\n            <!-- Text -->\r\n            <div *ngIf=\"ques.Type__c === 'Text'\">\r\n                <app-custom-input [fromShengel]=\"qbItem.isShengel__c\" [value]=\"ques.input\" [ngClassValue]=\"{\r\n                        'dis-flex dt-line date-line bookText boxoutline myt-font1': qbItem.Progress_Bar__c,\r\n                        textBox: !qbItem.Progress_Bar__c\r\n                    }\" [question]=\"ques\" [idValue]=\"ques.Tracking_ID__c\" [focusEvent]=\"clearSQError(ques.Id)\"\r\n                    [error]=\"ques.error\" [placeholder]=\"ques.Question__c\" (inputValue)=\"childEventCapture($event, ques)\">\r\n                </app-custom-input>\r\n            </div>\r\n            \r\n            <!-- for pick location -->\r\n            <div *ngIf=\"ques.Type__c === 'Location'\">\r\n                <app-pick-location [address]=\"ques.input\" (locationSelected)=\"childEventCapture($event, ques)\">\r\n                </app-pick-location>\r\n            </div>\r\n\r\n            <!-- for  text area   -->\r\n            <div *ngIf=\"ques.Type__c === 'TextArea'\">\r\n                <app-custom-text-area [value]=\"ques.input\" [rows]=\"3\" [error]=\"ques.error\" [placeholder]=\"ques.Question__c \"\r\n                    (textareaValueChange)=\"childEventCapture($event)\"></app-custom-text-area>\r\n            </div>\r\n\r\n            <!-- Email -->\r\n            <div *ngIf=\"ques.Type__c === 'Email'\">\r\n                <input type=\"email\" [(ngModel)]=\"ques.input\" [id]=\"ques.Id\" required=\"\" (focus)=\"clearSQError(ques.Id)\"\r\n                    style.border-color=\"{{ ques.error ? 'red' : '' }}\" placeholder=\"{{ ques.Question__c }}\" />\r\n            </div>\r\n\r\n            <!-- Table -->\r\n            <div *ngIf=\"ques.Type__c === 'Table'\" class=\"\">\r\n                <app-custom-table [question]=\"ques\" (valueChange)=\"childEventCapture($event, ques); clearSQError(ques.Id)\">\r\n                </app-custom-table>\r\n            </div>\r\n\r\n            <!-- Dropdown -->\r\n            <div *ngIf=\"ques.Type__c === 'Dropdown'\" class=\"\">\r\n                <app-custom-dropdown [fromShengel]=\"qbItem.isShengel__c\" [options]=\"ques.Question_Options__r.records\"\r\n                    [apiMeta]=\"ques.Sub_Text__c\" [id]=\"ques.Id\" [selectedValue]=\"ques.input\" [placeholder]=\"'---Select---'\"\r\n                    [errorMessage]=\"ques.Error_Message__c\" [error]=\"ques.error\"\r\n                    (valueChange)=\"childEventCapture($event, ques); clearSQError(ques.Id)\">\r\n                </app-custom-dropdown>\r\n                <i class=\"fa fa-check \" aria-hidden=\"true\" *ngIf=\"ques?.input?.length > 0\"></i>\r\n            </div>\r\n\r\n            <!-- file Upload -->\r\n            <div *ngIf=\"ques.Type__c === 'File'\" class=\"\">\r\n                <app-file-upload [limitFileUploading]=\"5\" [allFiles]=\"selectedFileData\"\r\n                (selectedFileData)=\"assignSelectedFileData($event)\" (deletedFileData)=\"deleteFile($event)\"\r\n                [isDeleteFileButtonVisible]=\"true\"></app-file-upload>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>"]}
88
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"questionbook.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/pages/questionbook/questionbook.component.ts","../../../../../../projects/nxt-app/src/lib/pages/questionbook/questionbook.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAU,KAAK,GAAyB,MAAM,eAAe,CAAC;;;;;;;;;;;;;;;AAYhF,MAAM,OAAO,qBAAqB;IAQZ;IACV;IACA;IACA;IAVD,MAAM,CAAe;IACrB,YAAY,CAAW;IACvB,SAAS,CAAa;IAE/B,YAAY,CAAa;IACzB,gBAAgB,GAAU,EAAE,CAAC;IAE7B,YAAoB,SAA4B,EACtC,WAAwB,EACxB,aAA4B,EAC5B,cAA8B;QAHpB,cAAS,GAAT,SAAS,CAAmB;QACtC,gBAAW,GAAX,WAAW,CAAa;QACxB,kBAAa,GAAb,aAAa,CAAe;QAC5B,mBAAc,GAAd,cAAc,CAAgB;IAExC,CAAC;IAED,QAAQ;QACN,OAAO,CAAC,GAAG,CAAC,qCAAqC,CAAC,CAAC;QACnD,4BAA4B;QAC5B,+BAA+B;QAC/B,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACvB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACvC,CAAC;IAED,YAAY,CAAC,MAAM;QACjB,4DAA4D;QAC5D,IAAI,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,EAAE,IAAI,MAAM,CAAC,CAAC;QACnE,KAAK,IAAI,EAAE,IAAI,MAAM,EAAE;YACrB,EAAE,CAAC,KAAK,GAAG,IAAI,CAAC;SACjB;IACH,CAAC;IAED,eAAe,CAAC,OAAO;QACrB,OAAO,CAAC,GAAG,CAAC,8CAA8C,CAAC,CAAC;QAC5D,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAClC,CAAC;IAED,kCAAkC;IAClC,iBAAiB,CAAC,KAAK,EAAE,IAAS;QAChC,OAAO,CAAC,GAAG,CAAC,gDAAgD,CAAC,CAAC;QAC9D,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACnB,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QACzC,gFAAgF;QAChF,IAAG,IAAI,CAAC,OAAO,IAAI,OAAO,EAAE;YAC1B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;SACnB;aAAM,IAAG,IAAI,CAAC,OAAO,IAAI,UAAU,EAAE;YACpC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC;SAClC;aAAI;YACH,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;SACpB;QACD,6FAA6F;QAC7F,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;IAED,sBAAsB,CAAC,QAAY;QACjC,OAAO,CAAC,GAAG,CAAC,UAAU,EAAC,QAAQ,CAAC,CAAC;QACjC,IAAI,CAAC,gBAAgB,GAAG,QAAQ,CAAC;IACnC,CAAC;IACD,UAAU,CAAC,QAAY;QACrB,OAAO,CAAC,GAAG,CAAC,UAAU,EAAC,QAAQ,CAAC,CAAA;IAClC,CAAC;wGA3DU,qBAAqB;4FAArB,qBAAqB,4ICZlC,wlIAoEM;;4FDxDO,qBAAqB;kBALjC,SAAS;+BACE,kBAAkB;2LAKnB,MAAM;sBAAd,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,SAAS;sBAAjB,KAAK","sourcesContent":["import { Component, OnInit, Input, Output, EventEmitter, } from '@angular/core';\r\nimport { Question, QuestionBook } from '../../wrapper';\r\nimport { SalesforceService } from \"../../services/salesforce.service\";\r\nimport { DataService } from '../../services/data.service';\r\nimport { ChangeService } from '../../services/change.service';\r\nimport { StorageService } from '../../services/storage.service';\r\n\r\n@Component({\r\n  selector: 'lib-questionbook',\r\n  templateUrl: './questionbook.component.html',\r\n  styleUrls: ['./questionbook.component.css']\r\n})\r\nexport class QuestionbookComponent implements OnInit {\r\n  @Input() qbItem: QuestionBook;\r\n  @Input() questionItem: Question;\r\n  @Input() questions: Question[];\r\n  \r\n  subQuestions: Question[];\r\n  selectedFileData: any[] = [];\r\n\r\n  constructor(private sfService: SalesforceService,\r\n    private dataService: DataService,\r\n    private changeService: ChangeService, \r\n    private storageService: StorageService) { \r\n      \r\n  }\r\n\r\n  ngOnInit(): void {\r\n    console.log('inside QuestionBookComponent OnInit');\r\n    // console.log(this.qbItem);\r\n    // console.log(this.questions);\r\n    this.subQuestions = [];\r\n    this.setSubQuestions(this.questions);\r\n  }\r\n\r\n  clearSQError(quesId) {\r\n    // console.log('inside QuestionBookComponent clearSQError');\r\n    var sqList = this.subQuestions.filter((item) => item.Id == quesId);\r\n    for (var sq of sqList) {\r\n      sq.error = null;\r\n    }\r\n  }\r\n\r\n  setSubQuestions(records) {\r\n    console.log('inside QuestionbookComponent setSubQuestions');\r\n    this.subQuestions.push(records);\r\n  }\r\n\r\n  // Capture and Process Child Event\r\n  childEventCapture(event, ques?:any) {\r\n    console.log('inside QuestionbookComponent childEventCapture');\r\n    console.log(event);\r\n    this.changeService.announceChange(event);\r\n    // Process the changes in Table and Dropdown and store right value in ques.input\r\n    if(ques.Type__c == 'Table') {\r\n      ques.input = null;\r\n    } else if(ques.Type__c == 'Dropdown') {\r\n      ques.input = event.valueObj.name;\r\n    }else{\r\n      ques.input = event;\r\n    }\r\n    // Once the right value is stored in ques.input store the ques (with input) in storageService\r\n    this.storageService.update(ques);\r\n  }\r\n  \r\n  assignSelectedFileData(fileData:any){\r\n    console.log('fileDATA',fileData);\r\n    this.selectedFileData = fileData;\r\n  }\r\n  deleteFile(fileData:any){\r\n    console.log('fileDATA',fileData)\r\n  }\r\n}\r\n","<div [class]=\"qbItem.isShengel__c ? 'form-group content-box' : 'form-group'\">\r\n    <div class=\"form-row\">\r\n        <div [class]=\"qbItem.isShengel__c ? '' : 'myt-align3'\"\r\n            [class]=\"qbItem.isShengel__c ? 'col-lg-' + ques.Size__c + ' paddingnone' : 'col-md-' + ques.Size__c + ' paddingnone'\"\r\n            *ngFor=\"let ques of questions;let i = index\" [id]=\"ques.Id\">\r\n            <!-- Sub Question Label -->\r\n            <div [ngClass]=\"{ down2: qbItem?.Progress_Bar__c }\">\r\n                <span [class]=\"qbItem.isShengel__c ? 'dis-flex shengel-myt-font3 myt-font7'  : 'dis-flex myt-font3 myt-font7' \">{{ ques?.Question__c }}</span>\r\n            </div>\r\n\r\n            <!-- DateTime -->\r\n            <div *ngIf=\"ques.Type__c === 'DateTime'\">\r\n                <app-custom-date-picker [minDate]=\"ques.minDate\" [date]=\"ques.input\" (dateChange)=\"childEventCapture($event, ques)\">\r\n                </app-custom-date-picker>\r\n            </div>\r\n\r\n            <!-- Text -->\r\n            <div *ngIf=\"ques.Type__c === 'Text'\">\r\n                <app-custom-input [fromShengel]=\"qbItem.isShengel__c\" [value]=\"ques.input\" [ngClassValue]=\"{\r\n                        'dis-flex dt-line date-line bookText boxoutline myt-font1': qbItem.Progress_Bar__c,\r\n                        textBox: !qbItem.Progress_Bar__c\r\n                    }\" [question]=\"ques\" [idValue]=\"ques.Tracking_ID__c\" [focusEvent]=\"clearSQError(ques.Id)\"\r\n                    [error]=\"ques.error\" [placeholder]=\"ques.Question__c\" (inputValue)=\"childEventCapture($event, ques)\">\r\n                </app-custom-input>\r\n            </div>\r\n            \r\n            <!-- for pick location -->\r\n            <div *ngIf=\"ques.Type__c === 'Location'\">\r\n                <app-pick-location [address]=\"ques.input\" (locationSelected)=\"childEventCapture($event, ques)\">\r\n                </app-pick-location>\r\n            </div>\r\n\r\n            <!-- for  text area   -->\r\n            <div *ngIf=\"ques.Type__c === 'TextArea'\">\r\n                <app-custom-text-area [value]=\"ques.input\" [rows]=\"3\" [error]=\"ques.error\" [placeholder]=\"ques.Question__c \"\r\n                    (textareaValueChange)=\"childEventCapture($event)\"></app-custom-text-area>\r\n            </div>\r\n\r\n            <!-- Email -->\r\n            <div *ngIf=\"ques.Type__c === 'Email'\">\r\n                <input type=\"email\" [(ngModel)]=\"ques.input\" [id]=\"ques.Id\" required=\"\" (focus)=\"clearSQError(ques.Id)\"\r\n                    style.border-color=\"{{ ques.error ? 'red' : '' }}\" placeholder=\"{{ ques.Question__c }}\" />\r\n            </div>\r\n\r\n            <!-- Table -->\r\n            <div *ngIf=\"ques.Type__c === 'Table'\" class=\"\">\r\n                <app-custom-table [question]=\"ques\" (valueChange)=\"childEventCapture($event, ques); clearSQError(ques.Id)\">\r\n                </app-custom-table>\r\n            </div>\r\n\r\n            <!-- Dropdown -->\r\n            <div *ngIf=\"ques.Type__c === 'Dropdown'\" class=\"\">\r\n                <app-custom-dropdown [fromShengel]=\"qbItem.isShengel__c\" [options]=\"ques.Question_Options__r.records\"\r\n                    [apiMeta]=\"ques.Sub_Text__c\" [id]=\"ques.Id\" [selectedValue]=\"ques.input\" [placeholder]=\"'---Select---'\"\r\n                    [errorMessage]=\"ques.Error_Message__c\" [error]=\"ques.error\"\r\n                    (valueChange)=\"childEventCapture($event, ques); clearSQError(ques.Id)\">\r\n                </app-custom-dropdown>\r\n                <i class=\"fa fa-check \" aria-hidden=\"true\" *ngIf=\"ques?.input?.length > 0\"></i>\r\n            </div>\r\n\r\n            <!-- Attachment / Files -->\r\n            <div *ngIf=\"ques.Type__c === 'File'\" class=\"\">\r\n                <app-file-upload [limitFileUploading]=\"5\" [allFiles]=\"selectedFileData\"\r\n                (selectedFileData)=\"assignSelectedFileData($event)\" (deletedFileData)=\"deleteFile($event)\"\r\n                [isDeleteFileButtonVisible]=\"true\"></app-file-upload>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>"]}
@@ -0,0 +1,41 @@
1
+ import { Injectable } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class StorageService {
4
+ nxtBookletAnswer;
5
+ constructor() { }
6
+ save(qbJson) {
7
+ this.nxtBookletAnswer = qbJson;
8
+ }
9
+ update(questionWithInput) {
10
+ // Store the Updated Questions (with Answer/Error) in a Map
11
+ // for (var eQuestion in this.nxtBookletAnswer.bookQuestionsMap) {
12
+ // if(eQuestion == questionWithInput.Id) {
13
+ // this.nxtBookletAnswer.bookQuestionsMap[eQuestion] = questionWithInput;
14
+ // }
15
+ // }
16
+ for (var eQuestion in this.nxtBookletAnswer.bookQuestionsMap) {
17
+ if (this.nxtBookletAnswer.bookQuestionsMap.hasOwnProperty(eQuestion)) {
18
+ const questionsR = this.nxtBookletAnswer.bookQuestionsMap[eQuestion].Questions__r;
19
+ for (let i = 0; i < questionsR.records.length; i++) {
20
+ if (questionsR.records[i].Id == questionWithInput.Id) {
21
+ questionsR.records[i] = questionWithInput;
22
+ console.log('assigned success');
23
+ }
24
+ }
25
+ }
26
+ }
27
+ }
28
+ get() {
29
+ // return the stored questions
30
+ return this.nxtBookletAnswer;
31
+ }
32
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: StorageService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
33
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: StorageService, providedIn: 'root' });
34
+ }
35
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: StorageService, decorators: [{
36
+ type: Injectable,
37
+ args: [{
38
+ providedIn: 'root'
39
+ }]
40
+ }], ctorParameters: function () { return []; } });
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RvcmFnZS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnh0LWFwcC9zcmMvbGliL3NlcnZpY2VzL3N0b3JhZ2Uuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQU8zQyxNQUFNLE9BQU8sY0FBYztJQUN6QixnQkFBZ0IsQ0FBaUI7SUFFakMsZ0JBQWdCLENBQUM7SUFFakIsSUFBSSxDQUFDLE1BQXNCO1FBQ3pCLElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxNQUFNLENBQUM7SUFDakMsQ0FBQztJQUVELE1BQU0sQ0FBQyxpQkFBMkI7UUFDaEMsMkRBQTJEO1FBRTNELGtFQUFrRTtRQUNsRSw0Q0FBNEM7UUFDNUMsNkVBQTZFO1FBQzdFLE1BQU07UUFDTixJQUFJO1FBQ0osS0FBSyxJQUFJLFNBQVMsSUFBSSxJQUFJLENBQUMsZ0JBQWdCLENBQUMsZ0JBQWdCLEVBQUU7WUFDNUQsSUFBSSxJQUFJLENBQUMsZ0JBQWdCLENBQUMsZ0JBQWdCLENBQUMsY0FBYyxDQUFDLFNBQVMsQ0FBQyxFQUFFO2dCQUNwRSxNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsZ0JBQWdCLENBQUMsU0FBUyxDQUFDLENBQUMsWUFBWSxDQUFDO2dCQUNsRixLQUFJLElBQUksQ0FBQyxHQUFDLENBQUMsRUFBQyxDQUFDLEdBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUMsQ0FBQyxFQUFFLEVBQUM7b0JBQzFDLElBQUcsVUFBVSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLElBQUksaUJBQWlCLENBQUMsRUFBRSxFQUFDO3dCQUNsRCxVQUFVLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxHQUFHLGlCQUFpQixDQUFDO3dCQUMxQyxPQUFPLENBQUMsR0FBRyxDQUFDLGtCQUFrQixDQUFDLENBQUM7cUJBQ2pDO2lCQUNGO2FBQ0Y7U0FDRjtJQUNILENBQUM7SUFFRCxHQUFHO1FBQ0QsOEJBQThCO1FBQzlCLE9BQU8sSUFBSSxDQUFDLGdCQUFnQixDQUFDO0lBRS9CLENBQUM7d0dBbENVLGNBQWM7NEdBQWQsY0FBYyxjQUZiLE1BQU07OzRGQUVQLGNBQWM7a0JBSDFCLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBRdWVzdGlvbiB9IGZyb20gJy4uL3dyYXBwZXInO1xyXG5pbXBvcnQgeyBCb29rbGV0V3JhcHBlciB9IGZyb20gJy4uL21vZGVsL2Jvb2tsZXRXcmFwcGVyJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCdcclxufSlcclxuZXhwb3J0IGNsYXNzIFN0b3JhZ2VTZXJ2aWNlIHtcclxuICBueHRCb29rbGV0QW5zd2VyOiBCb29rbGV0V3JhcHBlcjtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcbiAgc2F2ZShxYkpzb246IEJvb2tsZXRXcmFwcGVyKSB7XHJcbiAgICB0aGlzLm54dEJvb2tsZXRBbnN3ZXIgPSBxYkpzb247XHJcbiAgfVxyXG5cclxuICB1cGRhdGUocXVlc3Rpb25XaXRoSW5wdXQ6IFF1ZXN0aW9uKSB7XHJcbiAgICAvLyBTdG9yZSB0aGUgVXBkYXRlZCBRdWVzdGlvbnMgKHdpdGggQW5zd2VyL0Vycm9yKSBpbiBhIE1hcFxyXG5cclxuICAgIC8vIGZvciAodmFyIGVRdWVzdGlvbiBpbiB0aGlzLm54dEJvb2tsZXRBbnN3ZXIuYm9va1F1ZXN0aW9uc01hcCkge1xyXG4gICAgLy8gICBpZihlUXVlc3Rpb24gPT0gcXVlc3Rpb25XaXRoSW5wdXQuSWQpIHtcclxuICAgIC8vICAgICB0aGlzLm54dEJvb2tsZXRBbnN3ZXIuYm9va1F1ZXN0aW9uc01hcFtlUXVlc3Rpb25dID0gcXVlc3Rpb25XaXRoSW5wdXQ7XHJcbiAgICAvLyAgIH1cclxuICAgIC8vIH1cclxuICAgIGZvciAodmFyIGVRdWVzdGlvbiBpbiB0aGlzLm54dEJvb2tsZXRBbnN3ZXIuYm9va1F1ZXN0aW9uc01hcCkge1xyXG4gICAgICBpZiAodGhpcy5ueHRCb29rbGV0QW5zd2VyLmJvb2tRdWVzdGlvbnNNYXAuaGFzT3duUHJvcGVydHkoZVF1ZXN0aW9uKSkge1xyXG4gICAgICAgIGNvbnN0IHF1ZXN0aW9uc1IgPSB0aGlzLm54dEJvb2tsZXRBbnN3ZXIuYm9va1F1ZXN0aW9uc01hcFtlUXVlc3Rpb25dLlF1ZXN0aW9uc19fcjtcclxuICAgICAgICBmb3IobGV0IGk9MDtpPHF1ZXN0aW9uc1IucmVjb3Jkcy5sZW5ndGg7aSsrKXtcclxuICAgICAgICAgIGlmKHF1ZXN0aW9uc1IucmVjb3Jkc1tpXS5JZCA9PSBxdWVzdGlvbldpdGhJbnB1dC5JZCl7XHJcbiAgICAgICAgICAgIHF1ZXN0aW9uc1IucmVjb3Jkc1tpXSA9IHF1ZXN0aW9uV2l0aElucHV0O1xyXG4gICAgICAgICAgICBjb25zb2xlLmxvZygnYXNzaWduZWQgc3VjY2VzcycpO1xyXG4gICAgICAgICAgfVxyXG4gICAgICAgIH1cclxuICAgICAgfVxyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgZ2V0KCkge1xyXG4gICAgLy8gcmV0dXJuIHRoZSBzdG9yZWQgcXVlc3Rpb25zXHJcbiAgICByZXR1cm4gdGhpcy5ueHRCb29rbGV0QW5zd2VyO1xyXG5cclxuICB9XHJcbn1cclxuIl19