@piserve-tech/form-submission 1.3.310 → 1.3.312

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.
@@ -106,7 +106,6 @@ export class MobileFieldsComponent {
106
106
  this.validationFailed = false;
107
107
  this.validationMessage = '';
108
108
  this.updateAnswer();
109
- this.loadCountry(this.questionId, this.currentPage, this.size, '');
110
109
  }
111
110
  onInput(event) {
112
111
  this.validationService.clearInvalid(this.buildElementId());
@@ -268,4 +267,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
268
267
  }], disableEdit: [{
269
268
  type: Input
270
269
  }] } });
271
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mobile-fields.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/form-fields/mobile-fields/mobile-fields.component.ts","../../../../../projects/form-submission/src/form-fields/mobile-fields/mobile-fields.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;;;;;;;;AAgB/E,MAAM,OAAO,qBAAqB;IAkChC,YACU,cAA8B,EAC9B,iBAAoC,EACpC,OAA8B;QAF9B,mBAAc,GAAd,cAAc,CAAgB;QAC9B,sBAAiB,GAAjB,iBAAiB,CAAmB;QACpC,YAAO,GAAP,OAAO,CAAuB;QApC/B,aAAQ,GAAQ,EAAE,CAAC;QACnB,WAAM,GAAY,KAAK,CAAC;QACxB,WAAM,GAAY,KAAK,CAAC;QAEvB,iBAAY,GAAG,IAAI,YAAY,EAA8C,CAAC;QAExF,UAAK,GAAW,CAAC,CAAC;QAClB,aAAQ,GAAY,KAAK,CAAC;QAC1B,SAAI,GAAW,EAAE,CAAC;QAClB,gBAAW,GAAW,EAAE,CAAC;QACzB,uBAAkB,GAAY,IAAI,CAAC;QACnC,gBAAW,GAAY,IAAI,CAAC;QAC5B,gBAAW,GAAY,IAAI,CAAC;QAC5B,oBAAe,GAAY,IAAI,CAAC;QAChC,oBAAe,GAAY,IAAI,CAAC;QAChC,0BAAqB,GAAY,IAAI,CAAC;QACtC,mBAAc,GAAkB,EAAE,CAAC;QACnC,oBAAe,GAAkB,EAAE,CAAC;QACpC,qBAAgB,GAAY,KAAK,CAAC;QAClC,sBAAiB,GAAW,EAAE,CAAC;QAC/B,iBAAY,GAAW,EAAE,CAAC;QAC1B,eAAU,GAAW,EAAE,CAAC;QACxB,gBAAW,GAAW,CAAC,CAAC;QACxB,SAAI,GAAW,EAAE,CAAC;QAClB,eAAU,GAAW,CAAC,CAAC;QACvB,cAAS,GAAW,EAAE,CAAC;QACvB,aAAQ,GAAS,KAAK,CAAC;QACvB,gBAAW,GAAY,KAAK,CAAC;QAC7B,iBAAY,GAAW,EAAE,CAAC;QACjB,gBAAW,GAAY,KAAK,CAAC;QAE/B,cAAS,GAAS,EAAE,CAAC;IAMxB,CAAC;IAEL,QAAQ;QACN,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IAED,aAAa;QACX,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC;QACjC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC;QACvC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;QAC/B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,WAAW,CAAC;QACpE,IAAI,CAAC,kBAAkB;YACrB,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,kBAAkB,CAAC;QAC1D,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,WAAW,CAAC;QACpE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,WAAW,CAAC;QACpE,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,eAAe,CAAC;QAC5E,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,eAAe,CAAC;QAC5E,IAAI,CAAC,qBAAqB;YACxB,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,CAAC,qBAAqB,CAAC;QAC7D,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;QACnC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,QAAQ,EAAE,YAAY,CAAC;QAChD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,QAAQ,EAAE,WAAW,IAAI,KAAK,CAAC;QAC3E,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;IACjF,CAAC;IAGD,gBAAgB,CAAC,KAAc;QAC7B,IAAI,WAA+B,CAAC;QACpC,IAAI,YAAgC,CAAC;QAErC,MAAM,KAAK,GAAG,KAAK,KAAK,QAAQ,IAAI,IAAI,CAAC,QAAQ,EAAE,MAAM;YACvD,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM;YACtB,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,YAAY,CAAC;QAEhC,IAAI,IAAI,CAAC,kBAAkB,EAAE;YAC3B,oCAAoC;YACpC,CAAC,WAAW,EAAE,YAAY,CAAC,GAAG,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;SACxD;aAAM;YACL,6BAA6B;YAC7B,YAAY,GAAG,KAAK,IAAI,EAAE,CAAC;SAC5B;QAED,IAAI,CAAC,YAAY,GAAG,YAAY,IAAI,EAAE,CAAC;QAEvC,IAAI,IAAI,CAAC,kBAAkB,EAAE;YAC3B,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE;gBACzB,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;aAC3B;YAED,IAAI,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAC3C,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,KAAK,WAAW,CAC3C,CAAC;YAEF,IAAI,cAAc,EAAE;gBAClB,IAAI,CAAC,eAAe,GAAE,CAAC,cAAc,CAAC,CAAC;aACxC;iBAGI,IAAI,WAAW,EAAE;gBACpB,qCAAqC;gBACrC,IAAI,CAAC,cAAc,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,EAAE,CAAC,EAAE,WAAW,CAAC,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;oBAC5F,MAAM,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC,qBAAqB,CAC9D,IAAI,CAAC,MAAM,CAAC,OAAO,EACnB,IAAI,CAAC,WAAW,EAChB,IAAI,CAAC,WAAW,EAChB,IAAI,CAAC,eAAe,CACrB,CAAC;oBACF,cAAc,GAAG,cAAc,CAAC,IAAI,CAClC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,KAAK,WAAW,CAC3C,CAAC;oBACF,IAAI,cAAc,EAAE;wBAClB,kCAAkC;wBAClC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,cAAe,CAAC,KAAK,CAAC,EAAE;4BACvE,IAAI,CAAC,cAAc,GAAG,CAAC,cAAc,EAAE,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC;yBAChE;wBACD,eAAe;wBACf,IAAI,CAAC,eAAe,GAAG,CAAC,cAAc,CAAC,CAAC;qBACzC;gBACH,CAAC,CAAC,CAAC;aACJ;SACF;IACH,CAAC;IAGD,eAAe;QACb,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;QAC9B,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;QAC5B,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;IACrE,CAAC;IAED,OAAO,CAAC,KAAY;QAClB,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;QAC3D,MAAM,KAAK,GAAG,KAAK,CAAC,MAA0B,CAAC;QAE/C,4GAA4G;QAC5G,MAAM,KAAK,GAAG,gBAAgB,CAAC;QAE/B,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE;YAC5B,4BAA4B;YAC5B,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;YAEjD,oDAAoD;YACpD,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC,KAAK;iBACtB,KAAK,CAAC,GAAG,CAAC;iBACV,MAAM,CAAC,CAAC,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,CAAC,OAAO,IAAI,KAAK,KAAK,CAAC,IAAI,KAAK,KAAK,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;iBACvF,IAAI,CAAC,GAAG,CAAC,CAAC;SACd;QAED,mBAAmB;QACnB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,KAAK,CAAC;QAEhC,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IACD,oBAAoB;IACpB,CAAC;IAED,YAAY;QACV,IAAG,IAAI,CAAC,kBAAkB,EAAC;YACzB,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,YAAY,EAAE;gBACxD,MAAM,WAAW,GAAG,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;gBAClD,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,GAAG,WAAW,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;aAC9D;SACF;aAAK;YACJ,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC;SAC1C;QACD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAC,MAAM,EAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAC,gBAAgB,EAAC,CAAC,EAAC,CAAC,CAAC;IAC3E,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;QAC9B,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;QAE5B,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,CAAC,IAAI,CAAC,YAAY,IAAI,CAAC,IAAI,CAAC,kBAAkB,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,EAAE;YAC3G,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;YAC7B,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;YAC3D,IAAI,CAAC,iBAAiB,GAAG,6BAA6B,CAAC;SACxD;aAAM;YACL,IAAI,CAAC,YAAY,EAAE,CAAC;SACrB;IACH,CAAC;IAED,WAAW,CAAC,EAAU,EAAE,WAAmB,EAAE,IAAY,EAAE,SAAiB,EAAE,WAAoB,KAAK;QACrG,IAAI,CAAC,cAAc,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAU,EAAE,WAAW,EAAE,IAAI,EAAE,SAAS,CAAC,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;YACvG,IAAI,IAAI,CAAC,UAAU,KAAK,CAAC,EAAE;gBACzB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC;aAC1C;YACD,IAAI,CAAC,QAAQ,GAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;YAC/B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;YACrC,IAAI,YAAY,GAAC,IAAI,CAAC,cAAc,CAAC,qBAAqB,CACxD,IAAI,CAAC,MAAM,CAAC,OAAO,EACnB,IAAI,CAAC,WAAW,EAChB,IAAI,CAAC,WAAW,EAChB,IAAI,CAAC,eAAe,CACrB,CAAA;YAED,IAAI,IAAI,CAAC,WAAW,GAAG,CAAC,EAAE;gBACxB,IAAI,CAAC,cAAc,GAAG;oBACpB,GAAG,IAAI,CAAC,cAAc;oBACtB,GAAG,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,QAAa,EAAE,EAAE,CAAC,QAAQ,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,CAAC,CAAC;iBAC1G,CAAC;aACL;iBAAM;gBACL,IAAI,CAAC,cAAc,GAAG;oBACpB,GAAG,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,QAAa,EAAE,EAAE,CAAC,QAAQ,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,CAAC,CAAC;oBAC3G,GAAG,IAAI,CAAC,cAAc;iBACrB,CAAC;aACL;YACD,IAAG,IAAI,CAAC,YAAY,IAAI,CAAC,QAAQ,EAAC;gBAChC,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAA;aACjC;YACD,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,IAAI,CAAC,QAAQ,EAAE;gBACrC,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;aACjC;QACH,CAAC,CAAC,CAAC;IAEL,CAAC;IAED,iBAAiB,CAAC,KAAU;QAC1B,MAAM,OAAO,GAAG,KAAK,CAAC,MAAM,CAAC;QAC7B,IAAG,CAAC,IAAI,CAAC,QAAQ,EAAC;YAChB,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,YAAY,GAAG,OAAO,CAAC,SAAS,CAAC,IAAI,OAAO,CAAC,YAAY,EAAE;gBAChF,IAAI,CAAC,YAAY,EAAE,CAAC;aACrB;SACF;QACD,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,OAAO,CAAC,SAAS,IAAI,GAAG,EAAE;YACjD,IAAI,CAAC,gBAAgB,EAAE,CAAC;SACzB;IACH,CAAC;IAED,YAAY;QACV,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,WAAW,EAAE,CAAC;YACnB,IAAI,IAAI,CAAC,WAAW,IAAI,CAAC,EAAE;gBACzB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,EAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;aACnE;QACH,CAAC,EAAE,CAAC,CAAC,CAAC;IACR,CAAC;IAED,gBAAgB;QACd,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,WAAW,EAAE,CAAC;YACnB,IAAI,IAAI,CAAC,WAAW,IAAI,CAAC,EAAE;gBACzB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,EAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;aACnE;QACH,CAAC,EAAE,CAAC,CAAC,CAAC;IACR,CAAC;IAED,MAAM,CAAC,UAAe;QACpB,IAAI,UAAU,IAAI,EAAE,EAAE;YACpB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,EAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,IAAI,EAAE,EAAE,EAAC,IAAI,CAAC,CAAC;SACxE;aACI;YACH,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;YACzB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,EAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,IAAI,EAAE,UAAU,EAAC,IAAI,CAAC,CAAC;SAChF;IACH,CAAC;IAED,gBAAgB,CAAC,OAAgB,EAAE,UAAkB,wBAAwB;QAC3E,IAAI,OAAO,EAAE;YACX,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;SAC5D;aAAM;YACL,gEAAgE;SACjE;IACH,CAAC;IAEO,cAAc;QACpB,OAAO,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC;YACjC,CAAC,CAAC,GAAG,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE;YAC/C,CAAC,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;IAC5B,CAAC;IAED,IAAI,SAAS;QACX,OAAO,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;IACzE,CAAC;IAED,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;IACvE,CAAC;IAED,eAAe;QACb,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,EAAE;YAC9B,IAAI,CAAC,SAAS,GAAG,YAAY,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;SACzE;aAAM;YACL,IAAI,CAAC,SAAS,GAAG,YAAY,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;SACjD;QAED,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC/C,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;SAChD;IACH,CAAC;+GAnSU,qBAAqB;mGAArB,qBAAqB,0OChBlC,qtHAiGA;;4FDjFa,qBAAqB;kBALjC,SAAS;+BACE,mBAAmB;yKAKpB,QAAQ;sBAAhB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACI,YAAY;sBAArB,MAAM;gBAyBE,WAAW;sBAAnB,KAAK","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { CountryService } from '../../services/countryService';\nimport { ElementTrackerService } from '../../services/element-tracker.service';\nimport { ValidationService } from '../../services/validation.service';\n\ninterface CountryData {\n  value: string;\n  label: string;\n  image: string;\n}\n\n@Component({\n  selector: 'lib-mobile-fields',\n  templateUrl: './mobile-fields.component.html',\n  styleUrls: ['./mobile-fields.component.scss'],\n})\nexport class MobileFieldsComponent implements OnInit {\n  @Input() question: any = {};\n  @Input() inLine: boolean = false;\n  @Input() inCard: boolean = false;\n  @Input() submissionIndex!: number;\n  @Output() answerChange = new EventEmitter<{ answer: any; maxPossibleScore?: number }>();\n\n  count: number = 0;\n  required: boolean = false;\n  hint: string = '';\n  placeholder: string = '';\n  displayCountryCode: boolean = true;\n  displayFlag: boolean = true;\n  displayCode: boolean = true;\n  showCountryName: boolean = true;\n  beautifyNumbers: boolean = true;\n  countryWiseValidation: boolean = true;\n  countryDetails: CountryData[] = [];\n  selectedCountry: CountryData[] = [];\n  validationFailed: boolean = false;\n  validationMessage: string = '';\n  mobileNumber: string = '';\n  questionId: string = '';\n  currentPage: number = 0;\n  size: number = 30;\n  totalPages: number = 0;\n  searchKey: string = '';\n  lastPage:boolean=false;\n  isFirstPage: boolean = false;\n  defaultValue: string = '';\n  @Input() disableEdit: boolean = false;\n\n private elementId: string='';\n\n  constructor(\n    private countryService: CountryService,\n    private validationService: ValidationService,\n    private tracker: ElementTrackerService\n  ) { }\n\n  ngOnInit() {\n    this.valueAssigned();\n  }\n\n  valueAssigned() {\n    this.count = this.question.count;\n    this.required = this.question.required;\n    this.hint = this.question.hint;\n    this.placeholder = this.question.formElement.appearance.placeholder;\n    this.displayCountryCode =\n      this.question.formElement.appearance.displayCountryCode;\n    this.displayFlag = this.question.formElement.appearance.displayFlag;\n    this.displayCode = this.question.formElement.appearance.displayCode;\n    this.showCountryName = this.question.formElement.appearance.showCountryName;\n    this.beautifyNumbers = this.question.formElement.appearance.beautifyNumbers;\n    this.countryWiseValidation =\n      this.question.formElement.validation.countryWiseValidation;\n    this.questionId = this.question.id;\n    this.defaultValue = this.question?.defaultValue;\n    this.disableEdit = this.disableEdit ?? this.question?.disableEdit ?? false;\n    this.loadCountry(this.questionId, this.currentPage, this.size, this.searchKey);\n  }\n\n\n  initializeAnswer(param?: string): void {\n    let countryCode: string | undefined;\n    let mobileNumber: string | undefined;\n  \n    const value = param === 'answer' && this.question?.answer\n      ? this.question.answer\n      : this.question?.defaultValue;\n  \n    if (this.displayCountryCode) {\n      // Expect \"countryCode mobileNumber\"\n      [countryCode, mobileNumber] = (value || '').split(' ');\n    } else {\n      // Only mobile number present\n      mobileNumber = value || '';\n    }\n    \n    this.mobileNumber = mobileNumber || '';\n  \n    if (this.displayCountryCode) {\n      if (!this.selectedCountry) {\n        this.selectedCountry = [];\n      }\n  \n      let matchedCountry = this.countryDetails.find(\n        (country) => country.value === countryCode\n      );\n  \n      if (matchedCountry) {\n        this.selectedCountry= [matchedCountry];\n      }\n\n\n      else if (countryCode) {\n        // Not found? Fetch from API directly\n        this.countryService.loadCountryDetails(this.questionId, 0, 1, countryCode).subscribe((data) => {\n          const extraCountries = this.countryService.processCountryDetails(\n            data.result.content,\n            this.displayFlag,\n            this.displayCode,\n            this.showCountryName\n          );\n          matchedCountry = extraCountries.find(\n            (country) => country.value === countryCode\n          );\n          if (matchedCountry) {\n            // Add to dropdown list if missing\n            if (!this.countryDetails.some((c) => c.value === matchedCountry!.value)) {\n              this.countryDetails = [matchedCountry, ...this.countryDetails];\n            }\n            // Preselect it\n            this.selectedCountry = [matchedCountry];\n          }\n        });\n      } \n    }\n  }\n  \n\n  onCountryChange() {\n    this.validationFailed = false;\n    this.validationMessage = '';\n    this.updateAnswer();\n    this.loadCountry(this.questionId, this.currentPage, this.size, '');\n  }\n\n  onInput(event: Event) {\n    this.validationService.clearInvalid(this.buildElementId());\n    const input = event.target as HTMLInputElement;\n  \n    // Regular expression to allow only numbers and multiple hyphens, but ensure only one hyphen between numbers\n    const regex = /^(\\d+)(-\\d+)*$/;\n  \n    if (!regex.test(input.value)) {\n      // Remove invalid characters\n      input.value = input.value.replace(/[^\\d-]/g, '');\n  \n      // Ensure only one hyphen is present between numbers\n      input.value = input.value\n        .split('-')\n        .filter((segment, index, array) => segment || index === 0 || index === array.length - 1)\n        .join('-');\n    }\n  \n    // Update the model\n    this.mobileNumber = input.value;\n    \n    this.updateAnswer();\n  }\n  onMobileNumberChange() {\n  }\n\n  updateAnswer() {  \n    if(this.displayCountryCode){\n      if (this.selectedCountry.length > 0 && this.mobileNumber) {\n        const countryCode = this.selectedCountry[0].value;\n        this.question.answer = `${countryCode} ${this.mobileNumber}`;\n      }\n    }else {\n      this.question.answer = this.mobileNumber;\n    }\n    this.answerChange.emit({answer:this.question.answer,maxPossibleScore:0});\n  }\n\n  validateMobile() {\n    this.validationFailed = false;\n    this.validationMessage = '';\n  \n    if (this.required && (!this.mobileNumber || (this.displayCountryCode && this.selectedCountry.length === 0))) {\n      this.validationFailed = true;\n      this.validationService.clearInvalid(this.buildElementId());\n      this.validationMessage = 'This is a required question';\n    } else {\n      this.updateAnswer();\n    }\n  }\n\n  loadCountry(id: string, currentPage: number, size: number, searchKey: string, isSearch: boolean = false) {\n    this.countryService.loadCountryDetails(this.questionId, currentPage, size, searchKey).subscribe((data) => {\n      if (this.totalPages === 0) {\n        this.totalPages = data.result.totalPages;\n      }\n      this.lastPage=data.result.last;\n      this.isFirstPage = data.result.first;\n      let newCountries=this.countryService.processCountryDetails(\n        data.result.content,\n        this.displayFlag,\n        this.displayCode,\n        this.showCountryName\n      )      \n\n      if (this.currentPage > 0) {\n        this.countryDetails = [\n          ...this.countryDetails,\n          ...newCountries.filter(item => !this.countryDetails.some((existing: any) => existing.value === item.value))\n          ];\n      } else {\n        this.countryDetails = [\n          ...newCountries.filter(item => !this.countryDetails.some((existing: any) => existing.value === item.value)),\n          ...this.countryDetails\n          ];\n      }\n      if(this.defaultValue && !isSearch){\n        this.initializeAnswer('default')\n      }\n      if (this.question.answer && !isSearch) {\n        this.initializeAnswer('answer');\n      }\n    });\n\n  }\n\n  getNextSetOfItems(event: any) {\n    const element = event.target;\n    if(!this.lastPage){\n      if (Math.floor(element.scrollHeight - element.scrollTop) <= element.clientHeight) {\n        this.loadMoreData();\n      }\n    }\n    if (!this.isFirstPage && element.scrollTop <= 150) {\n      this.loadPreviousData();\n    }\n  }\n\n  loadMoreData() {\n    setTimeout(() => {\n      this.currentPage++;\n      if (this.currentPage >= 0) {\n        this.loadCountry(this.questionId,this.currentPage, this.size, \"\");\n      }\n    }, 0);\n  }\n\n  loadPreviousData() {\n    setTimeout(() => {\n      this.currentPage--;\n      if (this.currentPage >= 0) {\n        this.loadCountry(this.questionId,this.currentPage, this.size, \"\");\n      }\n    }, 0);\n  }\n\n  search(searchTerm: any) {\n    if (searchTerm == '') {\n      this.loadCountry(this.questionId,this.currentPage, this.size, \"\",true);\n    }\n    else {\n      this.countryDetails = []; \n      this.loadCountry(this.questionId,this.currentPage, this.size, searchTerm,true);\n    }\n  }\n\n  handleValidation(isValid: boolean, message: string = 'This field is required') {\n    if (isValid) {\n      this.validationService.clearInvalid(this.buildElementId());\n    } else {\n      // this.validationService.setInvalid(this.question.id, message);\n    }\n  }\n\n  private buildElementId(): string {\n    return (this.inLine || this.inCard)\n      ? `${this.submissionIndex}-${this.question.id}`\n      : `${this.question.id}`;\n  }\n\n  get isInvalid(): boolean {\n    return !!this.validationService.getErrorMessage(this.buildElementId());\n  }\n\n  get errorMessage(): string | null {\n    return this.validationService.getErrorMessage(this.buildElementId());\n  }\n\n  ngAfterViewInit() {\n    if (this.inLine || this.inCard) {\n      this.elementId = `question-${this.submissionIndex}-${this.question.id}`;\n    } else {\n      this.elementId = `question-${this.question.id}`;\n    }\n  \n    this.tracker.registerElement(this.elementId);\n  }\n\n  ngOnDestroy() {\n    if (this.elementId) {\n      this.tracker.unregisterElement(this.elementId);\n    }\n  }\n\n}\n\n","<div\n  [ngClass]=\"{ 'mb-4': !inLine }\"\n  class=\"px-3\"\n  [id]=\"(inLine || inCard) ? 'question-' + submissionIndex + '-' + question.id : 'question-' + question.id\"\n  [attr.name]=\"question.testElementName\"\n>\n  <div class=\"input-wrapper mb-2\" *ngIf=\"!inLine\">\n    <div *ngIf=\"question.questionNumber\" [innerHTML]=\"question.questionNumber\"></div>\n    <span *ngIf=\"question.questionNumber\" class=\"space\"></span> <label>{{ question.question }}</label\n    >&nbsp;\n    <span class=\"text-danger\" *ngIf=\"question?.required\">*</span>\n    <div\n      class=\"svg-wrapper mb-2 hintIcon\"\n      [attr.data-title]=\"hint\"\n      *ngIf=\"hint\"\n    >\n      <svg\n        class=\"hintSvg\"\n        viewBox=\"0 0 30 30\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n      >\n        <path\n          fill-rule=\"evenodd\"\n          clip-rule=\"evenodd\"\n          d=\"M15 26.25V26.25C8.78625 26.25 3.75 21.2138 3.75 15V15C3.75 8.78625 8.78625 3.75 15 3.75V3.75C21.2138 3.75 26.25 8.78625 26.25 15V15C26.25 21.2138 21.2138 26.25 15 26.25Z\"\n          stroke=\"#323232\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          d=\"M15 16.5623V16.2498C15 15.2285 15.6312 14.6748 16.2637 14.2498C16.8812 13.8335 17.5 13.291 17.5 12.291C17.5 10.9098 16.3813 9.79102 15 9.79102C13.6187 9.79102 12.5 10.9098 12.5 12.291\"\n          stroke=\"#323232\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          d=\"M14.9988 20C14.8263 20 14.6863 20.14 14.6875 20.3125C14.6875 20.485 14.8275 20.625 15 20.625C15.1725 20.625 15.3125 20.485 15.3125 20.3125C15.3125 20.14 15.1725 20 14.9988 20\"\n          stroke=\"#323232\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n      </svg>\n    </div>\n  </div>\n  <div class=\"input-group mb-2\">\n    <ng-container *ngIf=\"displayCountryCode; else fullWidthInput\">\n      <div class=\"col-xs-5 col-5 col-md-3 px-0 pe-2 ps-2\"\n      [ngClass]=\"{'disable':disableEdit}\">\n        <lib-dropdown\n          [items]=\"countryDetails\"\n          [multiple]=\"false\"\n          [(selectedItems)]=\"selectedCountry\"\n          (selectedItemsChange)=\"onCountryChange()\"\n          [disable]=\"disableEdit\"\n          (onDropdownScroll)=\"getNextSetOfItems($event)\"\n          (onSearch)=\"search($event)\"\n        ></lib-dropdown>\n      </div>\n      <input\n        type=\"text\"\n        class=\"form-control col-xs-7 col-7 col-md-9 height mobileField\"\n        [placeholder]=\"placeholder\"\n        aria-label=\"Mobile Number\"\n        (blur)=\"validateMobile()\"\n        [(ngModel)]=\"mobileNumber\"\n        (ngModelChange)=\"onMobileNumberChange()\"\n        (input)=\"onInput($event)\"\n        [disabled]=\"disableEdit\"\n      />\n    </ng-container>\n\n    <!-- Full-width input when displayCountryCode is false -->\n    <ng-template #fullWidthInput>\n      <input\n        type=\"text\"\n        class=\"form-control col-12 height mobileField\"\n        [placeholder]=\"placeholder\"\n        aria-label=\"Mobile Number\"\n        [class.invalid]=\"validationFailed\"\n        [class.invalid-question]=\"isInvalid\"\n        (blur)=\"validateMobile()\"\n        [(ngModel)]=\"mobileNumber\"\n        (ngModelChange)=\"onMobileNumberChange()\"\n        (input)=\"onInput($event)\"\n      />\n    </ng-template>\n  </div>\n  <div *ngIf=\"isInvalid && (!inLine || !mobileNumber)\" class=\"error-message\">\n    {{ errorMessage }}\n  </div>\n  <div *ngIf=\"validationFailed && !isInvalid\" class=\"text-danger error-message\">\n    {{ validationMessage }}\n  </div>\n</div>\n"]}
270
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mobile-fields.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/form-fields/mobile-fields/mobile-fields.component.ts","../../../../../projects/form-submission/src/form-fields/mobile-fields/mobile-fields.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { CountryService } from '../../services/countryService';\nimport { ElementTrackerService } from '../../services/element-tracker.service';\nimport { ValidationService } from '../../services/validation.service';\n\ninterface CountryData {\n  value: string;\n  label: string;\n  image: string;\n}\n\n@Component({\n  selector: 'lib-mobile-fields',\n  templateUrl: './mobile-fields.component.html',\n  styleUrls: ['./mobile-fields.component.scss'],\n})\nexport class MobileFieldsComponent implements OnInit {\n  @Input() question: any = {};\n  @Input() inLine: boolean = false;\n  @Input() inCard: boolean = false;\n  @Input() submissionIndex!: number;\n  @Output() answerChange = new EventEmitter<{ answer: any; maxPossibleScore?: number }>();\n\n  count: number = 0;\n  required: boolean = false;\n  hint: string = '';\n  placeholder: string = '';\n  displayCountryCode: boolean = true;\n  displayFlag: boolean = true;\n  displayCode: boolean = true;\n  showCountryName: boolean = true;\n  beautifyNumbers: boolean = true;\n  countryWiseValidation: boolean = true;\n  countryDetails: CountryData[] = [];\n  selectedCountry: CountryData[] = [];\n  validationFailed: boolean = false;\n  validationMessage: string = '';\n  mobileNumber: string = '';\n  questionId: string = '';\n  currentPage: number = 0;\n  size: number = 30;\n  totalPages: number = 0;\n  searchKey: string = '';\n  lastPage:boolean=false;\n  isFirstPage: boolean = false;\n  defaultValue: string = '';\n  @Input() disableEdit: boolean = false;\n\n private elementId: string='';\n\n  constructor(\n    private countryService: CountryService,\n    private validationService: ValidationService,\n    private tracker: ElementTrackerService\n  ) { }\n\n  ngOnInit() {\n    this.valueAssigned();\n  }\n\n  valueAssigned() {\n    this.count = this.question.count;\n    this.required = this.question.required;\n    this.hint = this.question.hint;\n    this.placeholder = this.question.formElement.appearance.placeholder;\n    this.displayCountryCode =\n      this.question.formElement.appearance.displayCountryCode;\n    this.displayFlag = this.question.formElement.appearance.displayFlag;\n    this.displayCode = this.question.formElement.appearance.displayCode;\n    this.showCountryName = this.question.formElement.appearance.showCountryName;\n    this.beautifyNumbers = this.question.formElement.appearance.beautifyNumbers;\n    this.countryWiseValidation =\n      this.question.formElement.validation.countryWiseValidation;\n    this.questionId = this.question.id;\n    this.defaultValue = this.question?.defaultValue;\n    this.disableEdit = this.disableEdit ?? this.question?.disableEdit ?? false;\n    this.loadCountry(this.questionId, this.currentPage, this.size, this.searchKey);\n  }\n\n\n  initializeAnswer(param?: string): void {\n    let countryCode: string | undefined;\n    let mobileNumber: string | undefined;\n  \n    const value = param === 'answer' && this.question?.answer\n      ? this.question.answer\n      : this.question?.defaultValue;\n  \n    if (this.displayCountryCode) {\n      // Expect \"countryCode mobileNumber\"\n      [countryCode, mobileNumber] = (value || '').split(' ');\n    } else {\n      // Only mobile number present\n      mobileNumber = value || '';\n    }\n    \n    this.mobileNumber = mobileNumber || '';\n  \n    if (this.displayCountryCode) {\n      if (!this.selectedCountry) {\n        this.selectedCountry = [];\n      }\n  \n      let matchedCountry = this.countryDetails.find(\n        (country) => country.value === countryCode\n      );\n  \n      if (matchedCountry) {\n        this.selectedCountry= [matchedCountry];\n      }\n\n\n      else if (countryCode) {\n        // Not found? Fetch from API directly\n        this.countryService.loadCountryDetails(this.questionId, 0, 1, countryCode).subscribe((data) => {\n          const extraCountries = this.countryService.processCountryDetails(\n            data.result.content,\n            this.displayFlag,\n            this.displayCode,\n            this.showCountryName\n          );\n          matchedCountry = extraCountries.find(\n            (country) => country.value === countryCode\n          );\n          if (matchedCountry) {\n            // Add to dropdown list if missing\n            if (!this.countryDetails.some((c) => c.value === matchedCountry!.value)) {\n              this.countryDetails = [matchedCountry, ...this.countryDetails];\n            }\n            // Preselect it\n            this.selectedCountry = [matchedCountry];\n          }\n        });\n      } \n    }\n  }\n  \n\n  onCountryChange() {\n    this.validationFailed = false;\n    this.validationMessage = '';\n    this.updateAnswer();\n  }\n\n  onInput(event: Event) {\n    this.validationService.clearInvalid(this.buildElementId());\n    const input = event.target as HTMLInputElement;\n  \n    // Regular expression to allow only numbers and multiple hyphens, but ensure only one hyphen between numbers\n    const regex = /^(\\d+)(-\\d+)*$/;\n  \n    if (!regex.test(input.value)) {\n      // Remove invalid characters\n      input.value = input.value.replace(/[^\\d-]/g, '');\n  \n      // Ensure only one hyphen is present between numbers\n      input.value = input.value\n        .split('-')\n        .filter((segment, index, array) => segment || index === 0 || index === array.length - 1)\n        .join('-');\n    }\n  \n    // Update the model\n    this.mobileNumber = input.value;\n    \n    this.updateAnswer();\n  }\n  onMobileNumberChange() {\n  }\n\n  updateAnswer() {  \n    if(this.displayCountryCode){\n      if (this.selectedCountry.length > 0 && this.mobileNumber) {\n        const countryCode = this.selectedCountry[0].value;\n        this.question.answer = `${countryCode} ${this.mobileNumber}`;\n      }\n    }else {\n      this.question.answer = this.mobileNumber;\n    }\n    this.answerChange.emit({answer:this.question.answer,maxPossibleScore:0});\n  }\n\n  validateMobile() {\n    this.validationFailed = false;\n    this.validationMessage = '';\n  \n    if (this.required && (!this.mobileNumber || (this.displayCountryCode && this.selectedCountry.length === 0))) {\n      this.validationFailed = true;\n      this.validationService.clearInvalid(this.buildElementId());\n      this.validationMessage = 'This is a required question';\n    } else {\n      this.updateAnswer();\n    }\n  }\n\n  loadCountry(id: string, currentPage: number, size: number, searchKey: string, isSearch: boolean = false) {\n    this.countryService.loadCountryDetails(this.questionId, currentPage, size, searchKey).subscribe((data) => {\n      if (this.totalPages === 0) {\n        this.totalPages = data.result.totalPages;\n      }\n      this.lastPage=data.result.last;\n      this.isFirstPage = data.result.first;\n      let newCountries=this.countryService.processCountryDetails(\n        data.result.content,\n        this.displayFlag,\n        this.displayCode,\n        this.showCountryName\n      )      \n\n      if (this.currentPage > 0) {\n        this.countryDetails = [\n          ...this.countryDetails,\n          ...newCountries.filter(item => !this.countryDetails.some((existing: any) => existing.value === item.value))\n          ];\n      } else {\n        this.countryDetails = [\n          ...newCountries.filter(item => !this.countryDetails.some((existing: any) => existing.value === item.value)),\n          ...this.countryDetails\n          ];\n      }\n      if(this.defaultValue && !isSearch){\n        this.initializeAnswer('default')\n      }\n      if (this.question.answer && !isSearch) {\n        this.initializeAnswer('answer');\n      }\n    });\n\n  }\n\n  getNextSetOfItems(event: any) {\n    const element = event.target;\n    if(!this.lastPage){\n      if (Math.floor(element.scrollHeight - element.scrollTop) <= element.clientHeight) {\n        this.loadMoreData();\n      }\n    }\n    if (!this.isFirstPage && element.scrollTop <= 150) {\n      this.loadPreviousData();\n    }\n  }\n\n  loadMoreData() {\n    setTimeout(() => {\n      this.currentPage++;\n      if (this.currentPage >= 0) {\n        this.loadCountry(this.questionId,this.currentPage, this.size, \"\");\n      }\n    }, 0);\n  }\n\n  loadPreviousData() {\n    setTimeout(() => {\n      this.currentPage--;\n      if (this.currentPage >= 0) {\n        this.loadCountry(this.questionId,this.currentPage, this.size, \"\");\n      }\n    }, 0);\n  }\n\n  search(searchTerm: any) {\n    if (searchTerm == '') {\n      this.loadCountry(this.questionId,this.currentPage, this.size, \"\",true);\n    }\n    else {\n      this.countryDetails = []; \n      this.loadCountry(this.questionId,this.currentPage, this.size, searchTerm,true);\n    }\n  }\n\n  handleValidation(isValid: boolean, message: string = 'This field is required') {\n    if (isValid) {\n      this.validationService.clearInvalid(this.buildElementId());\n    } else {\n      // this.validationService.setInvalid(this.question.id, message);\n    }\n  }\n\n  private buildElementId(): string {\n    return (this.inLine || this.inCard)\n      ? `${this.submissionIndex}-${this.question.id}`\n      : `${this.question.id}`;\n  }\n\n  get isInvalid(): boolean {\n    return !!this.validationService.getErrorMessage(this.buildElementId());\n  }\n\n  get errorMessage(): string | null {\n    return this.validationService.getErrorMessage(this.buildElementId());\n  }\n\n  ngAfterViewInit() {\n    if (this.inLine || this.inCard) {\n      this.elementId = `question-${this.submissionIndex}-${this.question.id}`;\n    } else {\n      this.elementId = `question-${this.question.id}`;\n    }\n  \n    this.tracker.registerElement(this.elementId);\n  }\n\n  ngOnDestroy() {\n    if (this.elementId) {\n      this.tracker.unregisterElement(this.elementId);\n    }\n  }\n\n}\n\n","<div\n  [ngClass]=\"{ 'mb-4': !inLine }\"\n  class=\"px-3\"\n  [id]=\"(inLine || inCard) ? 'question-' + submissionIndex + '-' + question.id : 'question-' + question.id\"\n  [attr.name]=\"question.testElementName\"\n>\n  <div class=\"input-wrapper mb-2\" *ngIf=\"!inLine\">\n    <div *ngIf=\"question.questionNumber\" [innerHTML]=\"question.questionNumber\"></div>\n    <span *ngIf=\"question.questionNumber\" class=\"space\"></span> <label>{{ question.question }}</label\n    >&nbsp;\n    <span class=\"text-danger\" *ngIf=\"question?.required\">*</span>\n    <div\n      class=\"svg-wrapper mb-2 hintIcon\"\n      [attr.data-title]=\"hint\"\n      *ngIf=\"hint\"\n    >\n      <svg\n        class=\"hintSvg\"\n        viewBox=\"0 0 30 30\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n      >\n        <path\n          fill-rule=\"evenodd\"\n          clip-rule=\"evenodd\"\n          d=\"M15 26.25V26.25C8.78625 26.25 3.75 21.2138 3.75 15V15C3.75 8.78625 8.78625 3.75 15 3.75V3.75C21.2138 3.75 26.25 8.78625 26.25 15V15C26.25 21.2138 21.2138 26.25 15 26.25Z\"\n          stroke=\"#323232\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          d=\"M15 16.5623V16.2498C15 15.2285 15.6312 14.6748 16.2637 14.2498C16.8812 13.8335 17.5 13.291 17.5 12.291C17.5 10.9098 16.3813 9.79102 15 9.79102C13.6187 9.79102 12.5 10.9098 12.5 12.291\"\n          stroke=\"#323232\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          d=\"M14.9988 20C14.8263 20 14.6863 20.14 14.6875 20.3125C14.6875 20.485 14.8275 20.625 15 20.625C15.1725 20.625 15.3125 20.485 15.3125 20.3125C15.3125 20.14 15.1725 20 14.9988 20\"\n          stroke=\"#323232\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n      </svg>\n    </div>\n  </div>\n  <div class=\"input-group mb-2\">\n    <ng-container *ngIf=\"displayCountryCode; else fullWidthInput\">\n      <div class=\"col-xs-5 col-5 col-md-3 px-0 pe-2 ps-2\"\n      [ngClass]=\"{'disable':disableEdit}\">\n        <lib-dropdown\n          [items]=\"countryDetails\"\n          [multiple]=\"false\"\n          [(selectedItems)]=\"selectedCountry\"\n          (selectedItemsChange)=\"onCountryChange()\"\n          [disable]=\"disableEdit\"\n          (onDropdownScroll)=\"getNextSetOfItems($event)\"\n          (onSearch)=\"search($event)\"\n        ></lib-dropdown>\n      </div>\n      <input\n        type=\"text\"\n        class=\"form-control col-xs-7 col-7 col-md-9 height mobileField\"\n        [placeholder]=\"placeholder\"\n        aria-label=\"Mobile Number\"\n        (blur)=\"validateMobile()\"\n        [(ngModel)]=\"mobileNumber\"\n        (ngModelChange)=\"onMobileNumberChange()\"\n        (input)=\"onInput($event)\"\n        [disabled]=\"disableEdit\"\n      />\n    </ng-container>\n\n    <!-- Full-width input when displayCountryCode is false -->\n    <ng-template #fullWidthInput>\n      <input\n        type=\"text\"\n        class=\"form-control col-12 height mobileField\"\n        [placeholder]=\"placeholder\"\n        aria-label=\"Mobile Number\"\n        [class.invalid]=\"validationFailed\"\n        [class.invalid-question]=\"isInvalid\"\n        (blur)=\"validateMobile()\"\n        [(ngModel)]=\"mobileNumber\"\n        (ngModelChange)=\"onMobileNumberChange()\"\n        (input)=\"onInput($event)\"\n      />\n    </ng-template>\n  </div>\n  <div *ngIf=\"isInvalid && (!inLine || !mobileNumber)\" class=\"error-message\">\n    {{ errorMessage }}\n  </div>\n  <div *ngIf=\"validationFailed && !isInvalid\" class=\"text-danger error-message\">\n    {{ validationMessage }}\n  </div>\n</div>\n"]}
@@ -29,6 +29,9 @@ export class NavigationTabsComponent {
29
29
  this.submissionInProgress = false;
30
30
  this.submissionInDraft = false;
31
31
  this.showCancelButton = false;
32
+ this.submissionProgress = 0;
33
+ this.currentStep = 'Submitting form';
34
+ this.animatedDots = '';
32
35
  this.loadedPages = {};
33
36
  this.showTooltip = false;
34
37
  this.showNavArrows = false;
@@ -111,11 +114,11 @@ export class NavigationTabsComponent {
111
114
  this.cancel.emit();
112
115
  }
113
116
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NavigationTabsComponent, deps: [{ token: i1.FormValidationService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
114
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NavigationTabsComponent, selector: "lib-navigation-tabs", inputs: { pages: "pages", currentPageIndex: "currentPageIndex", skipValidation: "skipValidation", edit: "edit", acceptedLanguage: "acceptedLanguage", eligibleForSubmission: "eligibleForSubmission", pageDetails: "pageDetails", markAllQuestionsAsRequired: "markAllQuestionsAsRequired", skipMargin: "skipMargin", primaryColor: "primaryColor", secondaryColor: "secondaryColor", isActionTriggered: "isActionTriggered", submissionInProgress: "submissionInProgress", submissionInDraft: "submissionInDraft", showCancelButton: "showCancelButton" }, outputs: { pageChanged: "pageChanged", submitEmit: "submitEmit", saveAsDraftEmit: "saveAsDraftEmit", subFormChange: "subFormChange", rowSetIndex: "rowSetIndex", cancel: "cancel" }, ngImport: i0, template: "<div class=\"tab-inner-container\" [ngClass]=\"{ 'skip-margin': skipMargin}\">\n <div class=\"d-flex gap-2\">\n <div class=\"tab-navigation\" *ngIf=\"!hideTabs\">\n <ul class=\"nav nav-tabs navTabs\" id=\"myTab\" role=\"tablist\">\n <li\n class=\"nav-item\"\n role=\"presentation\"\n *ngFor=\"let page of pageDetails; let i = index; trackBy: trackByIndex\"\n [ngClass]=\"{'nav-item-ara': acceptedLanguage === 'ara', 'nav-item-default': acceptedLanguage !== 'ara'}\"\n >\n <button\n class=\"nav-link\"\n [title]=\"page.name\"\n data-bs-toggle=\"tooltip\"\n data-bs-placement=\"top\"\n data-bs-custom-class=\"custom-tooltip\"\n [class.active]=\"i === currentPageIndex\"\n id=\"tab-{{ i }}\"\n type=\"button\"\n role=\"tab\"\n [attr.aria-controls]=\"'content-' + i\"\n [attr.aria-selected]=\"i === currentPageIndex\"\n (click)=\"setCurrentPage(i)\"\n >\n {{ page.name }}\n </button>\n </li>\n </ul>\n </div>\n <div class=\"d-flex align-items-center\" *ngIf=\"showNavArrows\">\n <button class=\"nav-arrow\">\n <img src=\"assets/icons/left_arrow.svg\" alt=\"left arrow\"\n (click)=\"scrollTabs(-1)\">\n <img src=\"assets/icons/right_arrow.svg\" alt=\"right arrow\"\n (click)=\"scrollTabs(1)\">\n </button>\n </div>\n </div>\n\n\n\n <div class=\"tab-content pt-5 pb-3 px-1\" [attr.name]=\"pages[currentPageIndex].testElementName\">\n <ng-container *ngIf=\"pages[currentPageIndex]\">\n <div\n class=\"tab-pane fade show active\"\n id=\"content-{{ currentPageIndex }}\"\n role=\"tabpanel\"\n [attr.aria-labelledby]=\"'tab-' + currentPageIndex\"\n >\n <div *ngIf=\"loadedPages[currentPageIndex]\">\n <div class=\"data-container\"\n infiniteScroll\n [infiniteScrollDistance]=\"2\"\n [infiniteScrollThrottle]=\"200\"\n (scrolled)=\"loadMoreData()\">\n <div *ngFor=\"let row of pages[currentPageIndex].rows\">\n <div class=\"margin d-flex\">\n <div *ngFor=\"let grid of row.grid\"\n [ngStyle]=\"{'width.%': (grid.element.count) * (100 / 12)}\">\n <lib-form-elements\n [grid]=\"grid\"\n [edit]=\"edit\"\n [acceptedLanguage]=\"acceptedLanguage\"\n [pages]=\"pages\"\n (subFormChange)=\"updateSubFormWithSubmissions($event)\"\n ></lib-form-elements>\n </div>\n </div>\n </div>\n </div>\n <div class=\"footerButton d-flex justify-content-between align-items-center me-4 ms-4 position-relative\">\n <!-- Hover detection container -->\n <div [ngStyle]=\"{ display: currentPageIndex === pageDetails.length - 1 ? 'block' : 'none' }\" id=\"captcha-container\"></div>\n <div\n class=\"button-container position-relative\"\n (mouseenter)=\"showTooltip = true\"\n (mouseleave)=\"showTooltip = false\"\n >\n\n <div *ngIf=\"currentPageIndex == pageDetails.length - 1\">\n <button *ngIf=\"showCancelButton\" class=\"btn submitButton rounded-pill bg-secondary text-white\"\n (click)=\"cancelled()\" type=\"button\"\n >Cancel</button>\n <button\n *ngIf=\"!isActionTriggered && skipValidation\"\n class=\"btn rounded-pill submitButton text-white\"\n [ngStyle]=\"{ 'background-color': secondaryColor ? secondaryColor : '#084fff' }\"\n type=\"button\"\n (click)=\"saveAsDraft()\"\n [disabled]=\"!eligibleForSubmission.status || submissionInDraft\"\n >\n <ng-container *ngIf=\"submissionInDraft; else showSubmitText\">\n <span class=\"spinner-border spinner-border-sm me-2\" role=\"status\" aria-hidden=\"true\"></span>\n Submitting...\n </ng-container>\n <ng-template #showSubmitText>\n Save Draft\n </ng-template>\n </button>\n \n\n <button\n *ngIf=\"!isActionTriggered\"\n class=\"btn rounded-pill submitButton text-white\"\n [ngStyle]=\"{ 'background-color': primaryColor ? primaryColor: '#084fff' }\"\n type=\"button\"\n (click)=\"submitForm()\"\n [disabled]=\"!eligibleForSubmission.status || submissionInProgress\"\n >\n <ng-container *ngIf=\"submissionInProgress; else showSubmitText\">\n <span class=\"spinner-border spinner-border-sm me-2\" role=\"status\" aria-hidden=\"true\"></span>\n Submitting...\n </ng-container>\n <ng-template #showSubmitText>\n Submit\n </ng-template>\n </button>\n <div *ngIf=\"showTooltip && !eligibleForSubmission.status\" class=\"custom-tooltip\">\n {{eligibleForSubmission.message}}\n </div>\n </div>\n </div>\n\n </div>\n\n\n </div>\n </div>\n </ng-container>\n </div>\n</div>\n", styles: [".tab-inner-container{width:100%;position:relative;padding:3rem}@media (max-width: 1024px){.tab-inner-container{padding-left:1rem;padding-right:1rem}}@media (max-width: 576px){.tab-inner-container{padding:2rem .5rem}}.skip-margin{padding:0}.custom-tooltip{visibility:hidden;position:absolute;top:-40px;right:0;background:#efefef;color:#7b7878;padding:8px 12px;border-radius:12px;box-shadow:0 4px 8px #00000026;font-size:14px;white-space:nowrap;z-index:10}.custom-tooltip.warning{background:linear-gradient(135deg,gold,#ffb400)}.fade-in{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.footerButton:hover .custom-tooltip{visibility:visible}.navTabs{overflow-x:auto;overflow-y:hidden;flex-wrap:unset;margin:0 0 -1px!important;padding-right:0}.nav-item{background-color:#fff;border-radius:5px}.nav-item.nav-item-default{margin-right:.5%}.nav-item.nav-item-ara{margin-left:.5%}.nav-link{position:relative;margin-bottom:-2px;padding-left:25px;padding-right:25px}.nav-link:after{content:\"\";position:absolute;left:0;bottom:0;width:101%;height:6px;background:#efefef}.nav-link.active:after{display:none}.tab-content{background-color:#fff}.custom-tooltip{--bs-tooltip-bg: var(--bd-violet-bg);--bs-tooltip-color: var(--bs-white)}.tab-navigation{position:relative;display:flex;align-items:center;width:95%}.navTabs{display:flex;overflow-x:auto;scroll-behavior:smooth;white-space:nowrap;width:100%;padding:0;margin:0;scrollbar-width:none;-ms-overflow-style:none}.navTabs::-webkit-scrollbar{display:none}.nav-arrow{position:absolute;background:#fff;border:none;cursor:pointer;font-size:20px;font-weight:700;padding:5px 10px;z-index:1000;box-shadow:0 2px 5px #0003;width:45px;height:27px;gap:13px;display:flex;justify-content:center;align-items:center;border-radius:6px}.nav-arrow img{width:8px;height:15px}.submitButton{margin-right:1rem}.spinner-border{display:inline-block;width:1rem;height:1rem;vertical-align:text-bottom;border:.15em solid currentColor;border-right-color:transparent;border-radius:50%;animation:spinner-border .75s linear infinite}@keyframes spinner-border{to{transform:rotate(360deg)}}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i3.FormElementsComponent, selector: "lib-form-elements", inputs: ["currentPageIndex", "edit", "acceptedLanguage", "answer", "grid", "state", "pages"], outputs: ["subFormChange"] }, { kind: "directive", type: i4.InfiniteScrollDirective, selector: "[infiniteScroll], [infinite-scroll], [data-infinite-scroll]", inputs: ["infiniteScrollDistance", "infiniteScrollUpDistance", "infiniteScrollThrottle", "infiniteScrollDisabled", "infiniteScrollContainer", "scrollWindow", "immediateCheck", "horizontal", "alwaysCallback", "fromRoot"], outputs: ["scrolled", "scrolledUp"] }] }); }
117
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NavigationTabsComponent, selector: "lib-navigation-tabs", inputs: { pages: "pages", currentPageIndex: "currentPageIndex", skipValidation: "skipValidation", edit: "edit", acceptedLanguage: "acceptedLanguage", eligibleForSubmission: "eligibleForSubmission", pageDetails: "pageDetails", markAllQuestionsAsRequired: "markAllQuestionsAsRequired", skipMargin: "skipMargin", primaryColor: "primaryColor", secondaryColor: "secondaryColor", isActionTriggered: "isActionTriggered", submissionInProgress: "submissionInProgress", submissionInDraft: "submissionInDraft", showCancelButton: "showCancelButton", submissionProgress: "submissionProgress", currentStep: "currentStep", animatedDots: "animatedDots" }, outputs: { pageChanged: "pageChanged", submitEmit: "submitEmit", saveAsDraftEmit: "saveAsDraftEmit", subFormChange: "subFormChange", rowSetIndex: "rowSetIndex", cancel: "cancel" }, ngImport: i0, template: "<div class=\"tab-inner-container\" [ngClass]=\"{ 'skip-margin': skipMargin}\">\n <div class=\"d-flex gap-2\">\n <div class=\"tab-navigation\" *ngIf=\"!hideTabs\">\n <ul class=\"nav nav-tabs navTabs\" id=\"myTab\" role=\"tablist\">\n <li\n class=\"nav-item\"\n role=\"presentation\"\n *ngFor=\"let page of pageDetails; let i = index; trackBy: trackByIndex\"\n [ngClass]=\"{'nav-item-ara': acceptedLanguage === 'ara', 'nav-item-default': acceptedLanguage !== 'ara'}\"\n >\n <button\n class=\"nav-link\"\n [title]=\"page.name\"\n data-bs-toggle=\"tooltip\"\n data-bs-placement=\"top\"\n data-bs-custom-class=\"custom-tooltip\"\n [class.active]=\"i === currentPageIndex\"\n id=\"tab-{{ i }}\"\n type=\"button\"\n role=\"tab\"\n [attr.aria-controls]=\"'content-' + i\"\n [attr.aria-selected]=\"i === currentPageIndex\"\n (click)=\"setCurrentPage(i)\"\n >\n {{ page.name }}\n </button>\n </li>\n </ul>\n </div>\n <div class=\"d-flex align-items-center\" *ngIf=\"showNavArrows\">\n <button class=\"nav-arrow\">\n <img src=\"assets/icons/left_arrow.svg\" alt=\"left arrow\"\n (click)=\"scrollTabs(-1)\">\n <img src=\"assets/icons/right_arrow.svg\" alt=\"right arrow\"\n (click)=\"scrollTabs(1)\">\n </button>\n </div>\n </div>\n\n\n\n <div class=\"tab-content pt-5 pb-3 px-1\" [attr.name]=\"pages[currentPageIndex].testElementName\">\n <ng-container *ngIf=\"pages[currentPageIndex]\">\n <div\n class=\"tab-pane fade show active\"\n id=\"content-{{ currentPageIndex }}\"\n role=\"tabpanel\"\n [attr.aria-labelledby]=\"'tab-' + currentPageIndex\"\n >\n <div *ngIf=\"loadedPages[currentPageIndex]\">\n <div class=\"data-container\"\n infiniteScroll\n [infiniteScrollDistance]=\"2\"\n [infiniteScrollThrottle]=\"200\"\n (scrolled)=\"loadMoreData()\">\n <div *ngFor=\"let row of pages[currentPageIndex].rows\">\n <div class=\"margin d-flex\">\n <div *ngFor=\"let grid of row.grid\"\n [ngStyle]=\"{'width.%': (grid.element.count) * (100 / 12)}\">\n <lib-form-elements\n [grid]=\"grid\"\n [edit]=\"edit\"\n [acceptedLanguage]=\"acceptedLanguage\"\n [pages]=\"pages\"\n (subFormChange)=\"updateSubFormWithSubmissions($event)\"\n ></lib-form-elements>\n </div>\n </div>\n </div>\n </div>\n <div class=\"footerButton d-flex justify-content-between align-items-center me-4 ms-4 position-relative\">\n <!-- Hover detection container -->\n <div [ngStyle]=\"{ display: currentPageIndex === pageDetails.length - 1 ? 'block' : 'none' }\" id=\"captcha-container\"></div>\n <div\n class=\"button-container position-relative\"\n (mouseenter)=\"showTooltip = true\"\n (mouseleave)=\"showTooltip = false\"\n >\n\n <div *ngIf=\"currentPageIndex == pageDetails.length - 1\">\n <button *ngIf=\"showCancelButton\" class=\"btn submitButton rounded-pill bg-secondary text-white\"\n (click)=\"cancelled()\" type=\"button\"\n >Cancel</button>\n <button\n *ngIf=\"!isActionTriggered && skipValidation\"\n class=\"btn rounded-pill submitButton text-white\"\n [ngStyle]=\"{ 'background-color': secondaryColor ? secondaryColor : '#084fff' }\"\n type=\"button\"\n (click)=\"saveAsDraft()\"\n [disabled]=\"!eligibleForSubmission.status || submissionInDraft\"\n >\n <ng-container *ngIf=\"submissionInDraft; else showSubmitText\">\n <span class=\"spinner-border spinner-border-sm me-2\" role=\"status\" aria-hidden=\"true\"></span>\n Submitting...\n </ng-container>\n <ng-template #showSubmitText>\n Save Draft\n </ng-template>\n </button>\n \n\n <button\n *ngIf=\"!isActionTriggered\"\n class=\"btn rounded-pill submitButton text-white\"\n [ngStyle]=\"{ 'background-color': primaryColor ? primaryColor: '#084fff' }\"\n type=\"button\"\n (click)=\"submitForm()\"\n [disabled]=\"!eligibleForSubmission.status || submissionInProgress\"\n >\n <ng-container *ngIf=\"submissionInProgress; else showSubmitText\">\n <span class=\"spinner-border spinner-border-sm me-2\" role=\"status\" aria-hidden=\"true\"></span>\n Submitting...\n </ng-container>\n <ng-template #showSubmitText>\n Submit\n </ng-template>\n </button>\n <div *ngIf=\"showTooltip && !eligibleForSubmission.status\" class=\"custom-tooltip\">\n {{eligibleForSubmission.message}}\n </div>\n </div>\n </div>\n\n </div>\n <div *ngIf=\"submissionInProgress\" class=\"text-loader\">\n {{ currentStep }}{{ animatedDots }}\n <span class=\"percentage\">{{ submissionProgress }}%</span>\n </div>\n\n </div>\n </div>\n </ng-container>\n </div>\n</div>\n", styles: [".tab-inner-container{width:100%;position:relative;padding:3rem}@media (max-width: 1024px){.tab-inner-container{padding-left:1rem;padding-right:1rem}}@media (max-width: 576px){.tab-inner-container{padding:2rem .5rem}}.skip-margin{padding:0}.custom-tooltip{visibility:hidden;position:absolute;top:-40px;right:0;background:#efefef;color:#7b7878;padding:8px 12px;border-radius:12px;box-shadow:0 4px 8px #00000026;font-size:14px;white-space:nowrap;z-index:10}.custom-tooltip.warning{background:linear-gradient(135deg,gold,#ffb400)}.fade-in{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.footerButton:hover .custom-tooltip{visibility:visible}.navTabs{overflow-x:auto;overflow-y:hidden;flex-wrap:unset;margin:0 0 -1px!important;padding-right:0}.nav-item{background-color:#fff;border-radius:5px}.nav-item.nav-item-default{margin-right:.5%}.nav-item.nav-item-ara{margin-left:.5%}.nav-link{position:relative;margin-bottom:-2px;padding-left:25px;padding-right:25px}.nav-link:after{content:\"\";position:absolute;left:0;bottom:0;width:101%;height:6px;background:#efefef}.nav-link.active:after{display:none}.tab-content{background-color:#fff}.custom-tooltip{--bs-tooltip-bg: var(--bd-violet-bg);--bs-tooltip-color: var(--bs-white)}.tab-navigation{position:relative;display:flex;align-items:center;width:95%}.navTabs{display:flex;overflow-x:auto;scroll-behavior:smooth;white-space:nowrap;width:100%;padding:0;margin:0;scrollbar-width:none;-ms-overflow-style:none}.navTabs::-webkit-scrollbar{display:none}.nav-arrow{position:absolute;background:#fff;border:none;cursor:pointer;font-size:20px;font-weight:700;padding:5px 10px;z-index:1000;box-shadow:0 2px 5px #0003;width:45px;height:27px;gap:13px;display:flex;justify-content:center;align-items:center;border-radius:6px}.nav-arrow img{width:8px;height:15px}.submitButton{margin-right:1rem}.spinner-border{display:inline-block;width:1rem;height:1rem;vertical-align:text-bottom;border:.15em solid currentColor;border-right-color:transparent;border-radius:50%;animation:spinner-border .75s linear infinite}@keyframes spinner-border{to{transform:rotate(360deg)}}.text-loader{font-size:14px;font-weight:500;padding:8px 12px;border-radius:6px;align-items:center;gap:8px;display:flex;justify-content:center}.percentage{font-weight:600;color:var(--primaryColor, #084fff)}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i3.FormElementsComponent, selector: "lib-form-elements", inputs: ["currentPageIndex", "edit", "acceptedLanguage", "answer", "grid", "state", "pages"], outputs: ["subFormChange"] }, { kind: "directive", type: i4.InfiniteScrollDirective, selector: "[infiniteScroll], [infinite-scroll], [data-infinite-scroll]", inputs: ["infiniteScrollDistance", "infiniteScrollUpDistance", "infiniteScrollThrottle", "infiniteScrollDisabled", "infiniteScrollContainer", "scrollWindow", "immediateCheck", "horizontal", "alwaysCallback", "fromRoot"], outputs: ["scrolled", "scrolledUp"] }] }); }
115
118
  }
116
119
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NavigationTabsComponent, decorators: [{
117
120
  type: Component,
118
- args: [{ selector: 'lib-navigation-tabs', template: "<div class=\"tab-inner-container\" [ngClass]=\"{ 'skip-margin': skipMargin}\">\n <div class=\"d-flex gap-2\">\n <div class=\"tab-navigation\" *ngIf=\"!hideTabs\">\n <ul class=\"nav nav-tabs navTabs\" id=\"myTab\" role=\"tablist\">\n <li\n class=\"nav-item\"\n role=\"presentation\"\n *ngFor=\"let page of pageDetails; let i = index; trackBy: trackByIndex\"\n [ngClass]=\"{'nav-item-ara': acceptedLanguage === 'ara', 'nav-item-default': acceptedLanguage !== 'ara'}\"\n >\n <button\n class=\"nav-link\"\n [title]=\"page.name\"\n data-bs-toggle=\"tooltip\"\n data-bs-placement=\"top\"\n data-bs-custom-class=\"custom-tooltip\"\n [class.active]=\"i === currentPageIndex\"\n id=\"tab-{{ i }}\"\n type=\"button\"\n role=\"tab\"\n [attr.aria-controls]=\"'content-' + i\"\n [attr.aria-selected]=\"i === currentPageIndex\"\n (click)=\"setCurrentPage(i)\"\n >\n {{ page.name }}\n </button>\n </li>\n </ul>\n </div>\n <div class=\"d-flex align-items-center\" *ngIf=\"showNavArrows\">\n <button class=\"nav-arrow\">\n <img src=\"assets/icons/left_arrow.svg\" alt=\"left arrow\"\n (click)=\"scrollTabs(-1)\">\n <img src=\"assets/icons/right_arrow.svg\" alt=\"right arrow\"\n (click)=\"scrollTabs(1)\">\n </button>\n </div>\n </div>\n\n\n\n <div class=\"tab-content pt-5 pb-3 px-1\" [attr.name]=\"pages[currentPageIndex].testElementName\">\n <ng-container *ngIf=\"pages[currentPageIndex]\">\n <div\n class=\"tab-pane fade show active\"\n id=\"content-{{ currentPageIndex }}\"\n role=\"tabpanel\"\n [attr.aria-labelledby]=\"'tab-' + currentPageIndex\"\n >\n <div *ngIf=\"loadedPages[currentPageIndex]\">\n <div class=\"data-container\"\n infiniteScroll\n [infiniteScrollDistance]=\"2\"\n [infiniteScrollThrottle]=\"200\"\n (scrolled)=\"loadMoreData()\">\n <div *ngFor=\"let row of pages[currentPageIndex].rows\">\n <div class=\"margin d-flex\">\n <div *ngFor=\"let grid of row.grid\"\n [ngStyle]=\"{'width.%': (grid.element.count) * (100 / 12)}\">\n <lib-form-elements\n [grid]=\"grid\"\n [edit]=\"edit\"\n [acceptedLanguage]=\"acceptedLanguage\"\n [pages]=\"pages\"\n (subFormChange)=\"updateSubFormWithSubmissions($event)\"\n ></lib-form-elements>\n </div>\n </div>\n </div>\n </div>\n <div class=\"footerButton d-flex justify-content-between align-items-center me-4 ms-4 position-relative\">\n <!-- Hover detection container -->\n <div [ngStyle]=\"{ display: currentPageIndex === pageDetails.length - 1 ? 'block' : 'none' }\" id=\"captcha-container\"></div>\n <div\n class=\"button-container position-relative\"\n (mouseenter)=\"showTooltip = true\"\n (mouseleave)=\"showTooltip = false\"\n >\n\n <div *ngIf=\"currentPageIndex == pageDetails.length - 1\">\n <button *ngIf=\"showCancelButton\" class=\"btn submitButton rounded-pill bg-secondary text-white\"\n (click)=\"cancelled()\" type=\"button\"\n >Cancel</button>\n <button\n *ngIf=\"!isActionTriggered && skipValidation\"\n class=\"btn rounded-pill submitButton text-white\"\n [ngStyle]=\"{ 'background-color': secondaryColor ? secondaryColor : '#084fff' }\"\n type=\"button\"\n (click)=\"saveAsDraft()\"\n [disabled]=\"!eligibleForSubmission.status || submissionInDraft\"\n >\n <ng-container *ngIf=\"submissionInDraft; else showSubmitText\">\n <span class=\"spinner-border spinner-border-sm me-2\" role=\"status\" aria-hidden=\"true\"></span>\n Submitting...\n </ng-container>\n <ng-template #showSubmitText>\n Save Draft\n </ng-template>\n </button>\n \n\n <button\n *ngIf=\"!isActionTriggered\"\n class=\"btn rounded-pill submitButton text-white\"\n [ngStyle]=\"{ 'background-color': primaryColor ? primaryColor: '#084fff' }\"\n type=\"button\"\n (click)=\"submitForm()\"\n [disabled]=\"!eligibleForSubmission.status || submissionInProgress\"\n >\n <ng-container *ngIf=\"submissionInProgress; else showSubmitText\">\n <span class=\"spinner-border spinner-border-sm me-2\" role=\"status\" aria-hidden=\"true\"></span>\n Submitting...\n </ng-container>\n <ng-template #showSubmitText>\n Submit\n </ng-template>\n </button>\n <div *ngIf=\"showTooltip && !eligibleForSubmission.status\" class=\"custom-tooltip\">\n {{eligibleForSubmission.message}}\n </div>\n </div>\n </div>\n\n </div>\n\n\n </div>\n </div>\n </ng-container>\n </div>\n</div>\n", styles: [".tab-inner-container{width:100%;position:relative;padding:3rem}@media (max-width: 1024px){.tab-inner-container{padding-left:1rem;padding-right:1rem}}@media (max-width: 576px){.tab-inner-container{padding:2rem .5rem}}.skip-margin{padding:0}.custom-tooltip{visibility:hidden;position:absolute;top:-40px;right:0;background:#efefef;color:#7b7878;padding:8px 12px;border-radius:12px;box-shadow:0 4px 8px #00000026;font-size:14px;white-space:nowrap;z-index:10}.custom-tooltip.warning{background:linear-gradient(135deg,gold,#ffb400)}.fade-in{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.footerButton:hover .custom-tooltip{visibility:visible}.navTabs{overflow-x:auto;overflow-y:hidden;flex-wrap:unset;margin:0 0 -1px!important;padding-right:0}.nav-item{background-color:#fff;border-radius:5px}.nav-item.nav-item-default{margin-right:.5%}.nav-item.nav-item-ara{margin-left:.5%}.nav-link{position:relative;margin-bottom:-2px;padding-left:25px;padding-right:25px}.nav-link:after{content:\"\";position:absolute;left:0;bottom:0;width:101%;height:6px;background:#efefef}.nav-link.active:after{display:none}.tab-content{background-color:#fff}.custom-tooltip{--bs-tooltip-bg: var(--bd-violet-bg);--bs-tooltip-color: var(--bs-white)}.tab-navigation{position:relative;display:flex;align-items:center;width:95%}.navTabs{display:flex;overflow-x:auto;scroll-behavior:smooth;white-space:nowrap;width:100%;padding:0;margin:0;scrollbar-width:none;-ms-overflow-style:none}.navTabs::-webkit-scrollbar{display:none}.nav-arrow{position:absolute;background:#fff;border:none;cursor:pointer;font-size:20px;font-weight:700;padding:5px 10px;z-index:1000;box-shadow:0 2px 5px #0003;width:45px;height:27px;gap:13px;display:flex;justify-content:center;align-items:center;border-radius:6px}.nav-arrow img{width:8px;height:15px}.submitButton{margin-right:1rem}.spinner-border{display:inline-block;width:1rem;height:1rem;vertical-align:text-bottom;border:.15em solid currentColor;border-right-color:transparent;border-radius:50%;animation:spinner-border .75s linear infinite}@keyframes spinner-border{to{transform:rotate(360deg)}}\n"] }]
121
+ args: [{ selector: 'lib-navigation-tabs', template: "<div class=\"tab-inner-container\" [ngClass]=\"{ 'skip-margin': skipMargin}\">\n <div class=\"d-flex gap-2\">\n <div class=\"tab-navigation\" *ngIf=\"!hideTabs\">\n <ul class=\"nav nav-tabs navTabs\" id=\"myTab\" role=\"tablist\">\n <li\n class=\"nav-item\"\n role=\"presentation\"\n *ngFor=\"let page of pageDetails; let i = index; trackBy: trackByIndex\"\n [ngClass]=\"{'nav-item-ara': acceptedLanguage === 'ara', 'nav-item-default': acceptedLanguage !== 'ara'}\"\n >\n <button\n class=\"nav-link\"\n [title]=\"page.name\"\n data-bs-toggle=\"tooltip\"\n data-bs-placement=\"top\"\n data-bs-custom-class=\"custom-tooltip\"\n [class.active]=\"i === currentPageIndex\"\n id=\"tab-{{ i }}\"\n type=\"button\"\n role=\"tab\"\n [attr.aria-controls]=\"'content-' + i\"\n [attr.aria-selected]=\"i === currentPageIndex\"\n (click)=\"setCurrentPage(i)\"\n >\n {{ page.name }}\n </button>\n </li>\n </ul>\n </div>\n <div class=\"d-flex align-items-center\" *ngIf=\"showNavArrows\">\n <button class=\"nav-arrow\">\n <img src=\"assets/icons/left_arrow.svg\" alt=\"left arrow\"\n (click)=\"scrollTabs(-1)\">\n <img src=\"assets/icons/right_arrow.svg\" alt=\"right arrow\"\n (click)=\"scrollTabs(1)\">\n </button>\n </div>\n </div>\n\n\n\n <div class=\"tab-content pt-5 pb-3 px-1\" [attr.name]=\"pages[currentPageIndex].testElementName\">\n <ng-container *ngIf=\"pages[currentPageIndex]\">\n <div\n class=\"tab-pane fade show active\"\n id=\"content-{{ currentPageIndex }}\"\n role=\"tabpanel\"\n [attr.aria-labelledby]=\"'tab-' + currentPageIndex\"\n >\n <div *ngIf=\"loadedPages[currentPageIndex]\">\n <div class=\"data-container\"\n infiniteScroll\n [infiniteScrollDistance]=\"2\"\n [infiniteScrollThrottle]=\"200\"\n (scrolled)=\"loadMoreData()\">\n <div *ngFor=\"let row of pages[currentPageIndex].rows\">\n <div class=\"margin d-flex\">\n <div *ngFor=\"let grid of row.grid\"\n [ngStyle]=\"{'width.%': (grid.element.count) * (100 / 12)}\">\n <lib-form-elements\n [grid]=\"grid\"\n [edit]=\"edit\"\n [acceptedLanguage]=\"acceptedLanguage\"\n [pages]=\"pages\"\n (subFormChange)=\"updateSubFormWithSubmissions($event)\"\n ></lib-form-elements>\n </div>\n </div>\n </div>\n </div>\n <div class=\"footerButton d-flex justify-content-between align-items-center me-4 ms-4 position-relative\">\n <!-- Hover detection container -->\n <div [ngStyle]=\"{ display: currentPageIndex === pageDetails.length - 1 ? 'block' : 'none' }\" id=\"captcha-container\"></div>\n <div\n class=\"button-container position-relative\"\n (mouseenter)=\"showTooltip = true\"\n (mouseleave)=\"showTooltip = false\"\n >\n\n <div *ngIf=\"currentPageIndex == pageDetails.length - 1\">\n <button *ngIf=\"showCancelButton\" class=\"btn submitButton rounded-pill bg-secondary text-white\"\n (click)=\"cancelled()\" type=\"button\"\n >Cancel</button>\n <button\n *ngIf=\"!isActionTriggered && skipValidation\"\n class=\"btn rounded-pill submitButton text-white\"\n [ngStyle]=\"{ 'background-color': secondaryColor ? secondaryColor : '#084fff' }\"\n type=\"button\"\n (click)=\"saveAsDraft()\"\n [disabled]=\"!eligibleForSubmission.status || submissionInDraft\"\n >\n <ng-container *ngIf=\"submissionInDraft; else showSubmitText\">\n <span class=\"spinner-border spinner-border-sm me-2\" role=\"status\" aria-hidden=\"true\"></span>\n Submitting...\n </ng-container>\n <ng-template #showSubmitText>\n Save Draft\n </ng-template>\n </button>\n \n\n <button\n *ngIf=\"!isActionTriggered\"\n class=\"btn rounded-pill submitButton text-white\"\n [ngStyle]=\"{ 'background-color': primaryColor ? primaryColor: '#084fff' }\"\n type=\"button\"\n (click)=\"submitForm()\"\n [disabled]=\"!eligibleForSubmission.status || submissionInProgress\"\n >\n <ng-container *ngIf=\"submissionInProgress; else showSubmitText\">\n <span class=\"spinner-border spinner-border-sm me-2\" role=\"status\" aria-hidden=\"true\"></span>\n Submitting...\n </ng-container>\n <ng-template #showSubmitText>\n Submit\n </ng-template>\n </button>\n <div *ngIf=\"showTooltip && !eligibleForSubmission.status\" class=\"custom-tooltip\">\n {{eligibleForSubmission.message}}\n </div>\n </div>\n </div>\n\n </div>\n <div *ngIf=\"submissionInProgress\" class=\"text-loader\">\n {{ currentStep }}{{ animatedDots }}\n <span class=\"percentage\">{{ submissionProgress }}%</span>\n </div>\n\n </div>\n </div>\n </ng-container>\n </div>\n</div>\n", styles: [".tab-inner-container{width:100%;position:relative;padding:3rem}@media (max-width: 1024px){.tab-inner-container{padding-left:1rem;padding-right:1rem}}@media (max-width: 576px){.tab-inner-container{padding:2rem .5rem}}.skip-margin{padding:0}.custom-tooltip{visibility:hidden;position:absolute;top:-40px;right:0;background:#efefef;color:#7b7878;padding:8px 12px;border-radius:12px;box-shadow:0 4px 8px #00000026;font-size:14px;white-space:nowrap;z-index:10}.custom-tooltip.warning{background:linear-gradient(135deg,gold,#ffb400)}.fade-in{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.footerButton:hover .custom-tooltip{visibility:visible}.navTabs{overflow-x:auto;overflow-y:hidden;flex-wrap:unset;margin:0 0 -1px!important;padding-right:0}.nav-item{background-color:#fff;border-radius:5px}.nav-item.nav-item-default{margin-right:.5%}.nav-item.nav-item-ara{margin-left:.5%}.nav-link{position:relative;margin-bottom:-2px;padding-left:25px;padding-right:25px}.nav-link:after{content:\"\";position:absolute;left:0;bottom:0;width:101%;height:6px;background:#efefef}.nav-link.active:after{display:none}.tab-content{background-color:#fff}.custom-tooltip{--bs-tooltip-bg: var(--bd-violet-bg);--bs-tooltip-color: var(--bs-white)}.tab-navigation{position:relative;display:flex;align-items:center;width:95%}.navTabs{display:flex;overflow-x:auto;scroll-behavior:smooth;white-space:nowrap;width:100%;padding:0;margin:0;scrollbar-width:none;-ms-overflow-style:none}.navTabs::-webkit-scrollbar{display:none}.nav-arrow{position:absolute;background:#fff;border:none;cursor:pointer;font-size:20px;font-weight:700;padding:5px 10px;z-index:1000;box-shadow:0 2px 5px #0003;width:45px;height:27px;gap:13px;display:flex;justify-content:center;align-items:center;border-radius:6px}.nav-arrow img{width:8px;height:15px}.submitButton{margin-right:1rem}.spinner-border{display:inline-block;width:1rem;height:1rem;vertical-align:text-bottom;border:.15em solid currentColor;border-right-color:transparent;border-radius:50%;animation:spinner-border .75s linear infinite}@keyframes spinner-border{to{transform:rotate(360deg)}}.text-loader{font-size:14px;font-weight:500;padding:8px 12px;border-radius:6px;align-items:center;gap:8px;display:flex;justify-content:center}.percentage{font-weight:600;color:var(--primaryColor, #084fff)}\n"] }]
119
122
  }], ctorParameters: function () { return [{ type: i1.FormValidationService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { pages: [{
120
123
  type: Input
121
124
  }], currentPageIndex: [{
@@ -158,5 +161,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
158
161
  type: Input
159
162
  }], showCancelButton: [{
160
163
  type: Input
164
+ }], submissionProgress: [{
165
+ type: Input
166
+ }], currentStep: [{
167
+ type: Input
168
+ }], animatedDots: [{
169
+ type: Input
161
170
  }] } });
162
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navigation-tabs.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/form-submission/navigation-tabs/navigation-tabs.component.ts","../../../../../projects/form-submission/src/form-submission/navigation-tabs/navigation-tabs.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, EventEmitter, Input, Output } from '@angular/core';\nimport { FormValidationService } from '../../services/form-validation.service';\n\n@Component({\n  selector: 'lib-navigation-tabs',\n  templateUrl: './navigation-tabs.component.html',\n  styleUrls: ['./navigation-tabs.component.scss'],\n})\nexport class NavigationTabsComponent {\n  @Input() pages: any[] = [];\n  @Input() currentPageIndex: number = 0;\n   @Input() skipValidation: boolean = false;\n  @Output() pageChanged = new EventEmitter<number>();\n  @Output() submitEmit: EventEmitter<any> = new EventEmitter<any>();\n   @Output() saveAsDraftEmit: EventEmitter<any> = new EventEmitter<any>();\n  @Input() edit : boolean = false;\n  @Input() acceptedLanguage: string ='';\n  @Input()  eligibleForSubmission:{ status: boolean; message: string } = { status: true, message: '' };\n  @Output() subFormChange = new EventEmitter<any>();\n  @Input() pageDetails: any[] = [];\n  @Input() markAllQuestionsAsRequired : boolean = false;\n  @Input() skipMargin: boolean = false;\n  @Output() rowSetIndex = new EventEmitter<number>();\n  @Output() cancel: EventEmitter<string> = new EventEmitter<string>();\n  @Input() primaryColor: string = '';\n  @Input() secondaryColor: string = '';\n  @Input() isActionTriggered: boolean = false;\n  @Input() submissionInProgress: boolean = false;\n  @Input() submissionInDraft: boolean = false;\n  @Input() showCancelButton: boolean = false;\n  loadedPages: { [key: number]: boolean } = {};\n  showTooltip: boolean = false;\n  showNavArrows: boolean = false;\n  hideTabs: boolean = false;\n\n  constructor(\n    private formValidationService: FormValidationService,\n    private cdr: ChangeDetectorRef\n  ) {\n    // Load the first page initially\n    this.loadedPages[this.currentPageIndex] = true;\n  }\n\n\n  ngOnInit() {\n    this.checkPageDetails()\n  }\n\n  ngAfterViewInit() {\n    setTimeout(() => this.checkOverflow());\n    this.cdr.detectChanges();\n  }\n\n  checkPageDetails(){\n    if(this.pageDetails && this.pageDetails?.length==1 && this.pageDetails[0]?.name==''){\n      this.hideTabs=true;\n    }\n  }\n\n  updateSubFormWithSubmissions(event:any){\n    this.subFormChange.emit(event);\n  }\n\n  triggerFunction(event: number) {\n    this.setCurrentPage(event);\n  }\n\n  setCurrentPage(index: number) {\n    if(this.markAllQuestionsAsRequired){\n      const currentPageData = this.pages[this.currentPageIndex];\n      let validationResponse=true;\n      if(!this.skipValidation) {\n            validationResponse = this.formValidationService.validateRequiredQuestions(currentPageData).isValid;\n       }\n      if (validationResponse) {\n        this.pageChanged.emit(index);\n        this.currentPageIndex = index;\n        // Mark this page as loaded to avoid reloading\n        if (!this.loadedPages[index]) {\n          this.loadedPages[index] = true;\n        }\n      }\n    }else{\n      this.pageChanged.emit(index);\n      this.currentPageIndex = index;\n      // Mark this page as loaded to avoid reloading\n      if (!this.loadedPages[index]) {\n        this.loadedPages[index] = true;\n      }\n    }\n  }\n\n  submitForm() {\n    this.submitEmit.emit();\n  }\n\n    saveAsDraft() {\n    this.saveAsDraftEmit.emit();\n  }\n\n  trackByIndex(index: number, item: any): number {\n    return index;\n  }\n\n  loadMoreData(): void {\n    this.rowSetIndex.emit(this.currentPageIndex);\n }\n\n toggleTooltip() {\n  this.showTooltip = !this.eligibleForSubmission.status;\n}\n\nscrollTabs(direction: number) {\n  const tabContainer = document.querySelector('.navTabs') as HTMLElement;\n  if (tabContainer) {\n    tabContainer.scrollBy({ left: direction * 100, behavior: 'smooth' });\n    setTimeout(() => this.checkOverflow(), 300);\n  }\n}\n\ncheckOverflow() {\n  const tabContainer = document.querySelector('.navTabs') as HTMLElement;\n  if (tabContainer) {\n    this.showNavArrows = (tabContainer.scrollWidth > tabContainer.clientWidth);\n  }\n}\n\ncancelled(){\n  this.cancel.emit();\n}\n}\n","<div class=\"tab-inner-container\" [ngClass]=\"{ 'skip-margin': skipMargin}\">\n  <div class=\"d-flex gap-2\">\n    <div class=\"tab-navigation\" *ngIf=\"!hideTabs\">\n      <ul class=\"nav nav-tabs navTabs\" id=\"myTab\" role=\"tablist\">\n        <li\n          class=\"nav-item\"\n          role=\"presentation\"\n          *ngFor=\"let page of pageDetails; let i = index; trackBy: trackByIndex\"\n          [ngClass]=\"{'nav-item-ara': acceptedLanguage === 'ara', 'nav-item-default': acceptedLanguage !== 'ara'}\"\n        >\n          <button\n            class=\"nav-link\"\n            [title]=\"page.name\"\n            data-bs-toggle=\"tooltip\"\n            data-bs-placement=\"top\"\n            data-bs-custom-class=\"custom-tooltip\"\n            [class.active]=\"i === currentPageIndex\"\n            id=\"tab-{{ i }}\"\n            type=\"button\"\n            role=\"tab\"\n            [attr.aria-controls]=\"'content-' + i\"\n            [attr.aria-selected]=\"i === currentPageIndex\"\n            (click)=\"setCurrentPage(i)\"\n          >\n            {{ page.name }}\n          </button>\n        </li>\n      </ul>\n    </div>\n    <div class=\"d-flex align-items-center\" *ngIf=\"showNavArrows\">\n      <button class=\"nav-arrow\">\n        <img src=\"assets/icons/left_arrow.svg\" alt=\"left arrow\"\n        (click)=\"scrollTabs(-1)\">\n        <img src=\"assets/icons/right_arrow.svg\" alt=\"right arrow\"\n        (click)=\"scrollTabs(1)\">\n      </button>\n    </div>\n  </div>\n\n\n\n  <div class=\"tab-content pt-5 pb-3 px-1\" [attr.name]=\"pages[currentPageIndex].testElementName\">\n    <ng-container *ngIf=\"pages[currentPageIndex]\">\n      <div\n        class=\"tab-pane fade show active\"\n        id=\"content-{{ currentPageIndex }}\"\n        role=\"tabpanel\"\n        [attr.aria-labelledby]=\"'tab-' + currentPageIndex\"\n      >\n        <div *ngIf=\"loadedPages[currentPageIndex]\">\n          <div class=\"data-container\"\n          infiniteScroll\n          [infiniteScrollDistance]=\"2\"\n          [infiniteScrollThrottle]=\"200\"\n          (scrolled)=\"loadMoreData()\">\n          <div *ngFor=\"let row of pages[currentPageIndex].rows\">\n            <div class=\"margin d-flex\">\n              <div *ngFor=\"let grid of row.grid\"\n                   [ngStyle]=\"{'width.%': (grid.element.count) * (100 / 12)}\">\n                <lib-form-elements\n                  [grid]=\"grid\"\n                  [edit]=\"edit\"\n                  [acceptedLanguage]=\"acceptedLanguage\"\n                  [pages]=\"pages\"\n                  (subFormChange)=\"updateSubFormWithSubmissions($event)\"\n                ></lib-form-elements>\n              </div>\n            </div>\n          </div>\n          </div>\n          <div class=\"footerButton d-flex justify-content-between align-items-center me-4 ms-4 position-relative\">\n          <!-- Hover detection container -->\n                    <div  [ngStyle]=\"{ display: currentPageIndex === pageDetails.length - 1 ? 'block' : 'none' }\" id=\"captcha-container\"></div>\n          <div\n            class=\"button-container position-relative\"\n            (mouseenter)=\"showTooltip = true\"\n            (mouseleave)=\"showTooltip = false\"\n          >\n\n          <div  *ngIf=\"currentPageIndex == pageDetails.length - 1\">\n            <button *ngIf=\"showCancelButton\" class=\"btn submitButton rounded-pill bg-secondary text-white\"\n            (click)=\"cancelled()\" type=\"button\"\n            >Cancel</button>\n               <button\n            *ngIf=\"!isActionTriggered && skipValidation\"\n              class=\"btn rounded-pill submitButton text-white\"\n              [ngStyle]=\"{ 'background-color': secondaryColor ? secondaryColor : '#084fff' }\"\n              type=\"button\"\n              (click)=\"saveAsDraft()\"\n              [disabled]=\"!eligibleForSubmission.status || submissionInDraft\"\n            >\n            <ng-container *ngIf=\"submissionInDraft; else showSubmitText\">\n              <span class=\"spinner-border spinner-border-sm me-2\" role=\"status\" aria-hidden=\"true\"></span>\n              Submitting...\n            </ng-container>\n            <ng-template #showSubmitText>\n             Save Draft\n            </ng-template>\n            </button>\n            \n\n            <button\n            *ngIf=\"!isActionTriggered\"\n              class=\"btn rounded-pill submitButton text-white\"\n              [ngStyle]=\"{ 'background-color': primaryColor ? primaryColor: '#084fff' }\"\n              type=\"button\"\n              (click)=\"submitForm()\"\n              [disabled]=\"!eligibleForSubmission.status || submissionInProgress\"\n            >\n            <ng-container *ngIf=\"submissionInProgress; else showSubmitText\">\n              <span class=\"spinner-border spinner-border-sm me-2\" role=\"status\" aria-hidden=\"true\"></span>\n              Submitting...\n            </ng-container>\n            <ng-template #showSubmitText>\n              Submit\n            </ng-template>\n            </button>\n            <div *ngIf=\"showTooltip && !eligibleForSubmission.status\" class=\"custom-tooltip\">\n              {{eligibleForSubmission.message}}\n            </div>\n              </div>\n          </div>\n\n        </div>\n\n\n        </div>\n      </div>\n    </ng-container>\n  </div>\n</div>\n"]}
171
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navigation-tabs.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/form-submission/navigation-tabs/navigation-tabs.component.ts","../../../../../projects/form-submission/src/form-submission/navigation-tabs/navigation-tabs.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, EventEmitter, Input, Output } from '@angular/core';\nimport { FormValidationService } from '../../services/form-validation.service';\n\n@Component({\n  selector: 'lib-navigation-tabs',\n  templateUrl: './navigation-tabs.component.html',\n  styleUrls: ['./navigation-tabs.component.scss'],\n})\nexport class NavigationTabsComponent {\n  @Input() pages: any[] = [];\n  @Input() currentPageIndex: number = 0;\n   @Input() skipValidation: boolean = false;\n  @Output() pageChanged = new EventEmitter<number>();\n  @Output() submitEmit: EventEmitter<any> = new EventEmitter<any>();\n   @Output() saveAsDraftEmit: EventEmitter<any> = new EventEmitter<any>();\n  @Input() edit : boolean = false;\n  @Input() acceptedLanguage: string ='';\n  @Input()  eligibleForSubmission:{ status: boolean; message: string } = { status: true, message: '' };\n  @Output() subFormChange = new EventEmitter<any>();\n  @Input() pageDetails: any[] = [];\n  @Input() markAllQuestionsAsRequired : boolean = false;\n  @Input() skipMargin: boolean = false;\n  @Output() rowSetIndex = new EventEmitter<number>();\n  @Output() cancel: EventEmitter<string> = new EventEmitter<string>();\n  @Input() primaryColor: string = '';\n  @Input() secondaryColor: string = '';\n  @Input() isActionTriggered: boolean = false;\n  @Input() submissionInProgress: boolean = false;\n  @Input() submissionInDraft: boolean = false;\n  @Input() showCancelButton: boolean = false;\n  @Input() submissionProgress = 0;\n  @Input() currentStep = 'Submitting form';\n  @Input() animatedDots = '';\n  loadedPages: { [key: number]: boolean } = {};\n  showTooltip: boolean = false;\n  showNavArrows: boolean = false;\n  hideTabs: boolean = false;\n\n  constructor(\n    private formValidationService: FormValidationService,\n    private cdr: ChangeDetectorRef\n  ) {\n    // Load the first page initially\n    this.loadedPages[this.currentPageIndex] = true;\n  }\n\n\n  ngOnInit() {\n    this.checkPageDetails()\n  }\n\n  ngAfterViewInit() {\n    setTimeout(() => this.checkOverflow());\n    this.cdr.detectChanges();\n  }\n\n  checkPageDetails(){\n    if(this.pageDetails && this.pageDetails?.length==1 && this.pageDetails[0]?.name==''){\n      this.hideTabs=true;\n    }\n  }\n\n  updateSubFormWithSubmissions(event:any){\n    this.subFormChange.emit(event);\n  }\n\n  triggerFunction(event: number) {\n    this.setCurrentPage(event);\n  }\n\n  setCurrentPage(index: number) {\n    if(this.markAllQuestionsAsRequired){\n      const currentPageData = this.pages[this.currentPageIndex];\n      let validationResponse=true;\n      if(!this.skipValidation) {\n            validationResponse = this.formValidationService.validateRequiredQuestions(currentPageData).isValid;\n       }\n      if (validationResponse) {\n        this.pageChanged.emit(index);\n        this.currentPageIndex = index;\n        // Mark this page as loaded to avoid reloading\n        if (!this.loadedPages[index]) {\n          this.loadedPages[index] = true;\n        }\n      }\n    }else{\n      this.pageChanged.emit(index);\n      this.currentPageIndex = index;\n      // Mark this page as loaded to avoid reloading\n      if (!this.loadedPages[index]) {\n        this.loadedPages[index] = true;\n      }\n    }\n  }\n\n  submitForm() {\n    this.submitEmit.emit();\n  }\n\n    saveAsDraft() {\n    this.saveAsDraftEmit.emit();\n  }\n\n  trackByIndex(index: number, item: any): number {\n    return index;\n  }\n\n  loadMoreData(): void {\n    this.rowSetIndex.emit(this.currentPageIndex);\n }\n\n toggleTooltip() {\n  this.showTooltip = !this.eligibleForSubmission.status;\n}\n\nscrollTabs(direction: number) {\n  const tabContainer = document.querySelector('.navTabs') as HTMLElement;\n  if (tabContainer) {\n    tabContainer.scrollBy({ left: direction * 100, behavior: 'smooth' });\n    setTimeout(() => this.checkOverflow(), 300);\n  }\n}\n\ncheckOverflow() {\n  const tabContainer = document.querySelector('.navTabs') as HTMLElement;\n  if (tabContainer) {\n    this.showNavArrows = (tabContainer.scrollWidth > tabContainer.clientWidth);\n  }\n}\n\ncancelled(){\n  this.cancel.emit();\n}\n}\n","<div class=\"tab-inner-container\" [ngClass]=\"{ 'skip-margin': skipMargin}\">\n  <div class=\"d-flex gap-2\">\n    <div class=\"tab-navigation\" *ngIf=\"!hideTabs\">\n      <ul class=\"nav nav-tabs navTabs\" id=\"myTab\" role=\"tablist\">\n        <li\n          class=\"nav-item\"\n          role=\"presentation\"\n          *ngFor=\"let page of pageDetails; let i = index; trackBy: trackByIndex\"\n          [ngClass]=\"{'nav-item-ara': acceptedLanguage === 'ara', 'nav-item-default': acceptedLanguage !== 'ara'}\"\n        >\n          <button\n            class=\"nav-link\"\n            [title]=\"page.name\"\n            data-bs-toggle=\"tooltip\"\n            data-bs-placement=\"top\"\n            data-bs-custom-class=\"custom-tooltip\"\n            [class.active]=\"i === currentPageIndex\"\n            id=\"tab-{{ i }}\"\n            type=\"button\"\n            role=\"tab\"\n            [attr.aria-controls]=\"'content-' + i\"\n            [attr.aria-selected]=\"i === currentPageIndex\"\n            (click)=\"setCurrentPage(i)\"\n          >\n            {{ page.name }}\n          </button>\n        </li>\n      </ul>\n    </div>\n    <div class=\"d-flex align-items-center\" *ngIf=\"showNavArrows\">\n      <button class=\"nav-arrow\">\n        <img src=\"assets/icons/left_arrow.svg\" alt=\"left arrow\"\n        (click)=\"scrollTabs(-1)\">\n        <img src=\"assets/icons/right_arrow.svg\" alt=\"right arrow\"\n        (click)=\"scrollTabs(1)\">\n      </button>\n    </div>\n  </div>\n\n\n\n  <div class=\"tab-content pt-5 pb-3 px-1\" [attr.name]=\"pages[currentPageIndex].testElementName\">\n    <ng-container *ngIf=\"pages[currentPageIndex]\">\n      <div\n        class=\"tab-pane fade show active\"\n        id=\"content-{{ currentPageIndex }}\"\n        role=\"tabpanel\"\n        [attr.aria-labelledby]=\"'tab-' + currentPageIndex\"\n      >\n        <div *ngIf=\"loadedPages[currentPageIndex]\">\n          <div class=\"data-container\"\n          infiniteScroll\n          [infiniteScrollDistance]=\"2\"\n          [infiniteScrollThrottle]=\"200\"\n          (scrolled)=\"loadMoreData()\">\n          <div *ngFor=\"let row of pages[currentPageIndex].rows\">\n            <div class=\"margin d-flex\">\n              <div *ngFor=\"let grid of row.grid\"\n                   [ngStyle]=\"{'width.%': (grid.element.count) * (100 / 12)}\">\n                <lib-form-elements\n                  [grid]=\"grid\"\n                  [edit]=\"edit\"\n                  [acceptedLanguage]=\"acceptedLanguage\"\n                  [pages]=\"pages\"\n                  (subFormChange)=\"updateSubFormWithSubmissions($event)\"\n                ></lib-form-elements>\n              </div>\n            </div>\n          </div>\n          </div>\n          <div class=\"footerButton d-flex justify-content-between align-items-center me-4 ms-4 position-relative\">\n          <!-- Hover detection container -->\n                    <div  [ngStyle]=\"{ display: currentPageIndex === pageDetails.length - 1 ? 'block' : 'none' }\" id=\"captcha-container\"></div>\n          <div\n            class=\"button-container position-relative\"\n            (mouseenter)=\"showTooltip = true\"\n            (mouseleave)=\"showTooltip = false\"\n          >\n\n          <div  *ngIf=\"currentPageIndex == pageDetails.length - 1\">\n            <button *ngIf=\"showCancelButton\" class=\"btn submitButton rounded-pill bg-secondary text-white\"\n            (click)=\"cancelled()\" type=\"button\"\n            >Cancel</button>\n               <button\n            *ngIf=\"!isActionTriggered && skipValidation\"\n              class=\"btn rounded-pill submitButton text-white\"\n              [ngStyle]=\"{ 'background-color': secondaryColor ? secondaryColor : '#084fff' }\"\n              type=\"button\"\n              (click)=\"saveAsDraft()\"\n              [disabled]=\"!eligibleForSubmission.status || submissionInDraft\"\n            >\n            <ng-container *ngIf=\"submissionInDraft; else showSubmitText\">\n              <span class=\"spinner-border spinner-border-sm me-2\" role=\"status\" aria-hidden=\"true\"></span>\n              Submitting...\n            </ng-container>\n            <ng-template #showSubmitText>\n             Save Draft\n            </ng-template>\n            </button>\n            \n\n            <button\n            *ngIf=\"!isActionTriggered\"\n              class=\"btn rounded-pill submitButton text-white\"\n              [ngStyle]=\"{ 'background-color': primaryColor ? primaryColor: '#084fff' }\"\n              type=\"button\"\n              (click)=\"submitForm()\"\n              [disabled]=\"!eligibleForSubmission.status || submissionInProgress\"\n            >\n            <ng-container *ngIf=\"submissionInProgress; else showSubmitText\">\n              <span class=\"spinner-border spinner-border-sm me-2\" role=\"status\" aria-hidden=\"true\"></span>\n              Submitting...\n            </ng-container>\n            <ng-template #showSubmitText>\n              Submit\n            </ng-template>\n            </button>\n            <div *ngIf=\"showTooltip && !eligibleForSubmission.status\" class=\"custom-tooltip\">\n              {{eligibleForSubmission.message}}\n            </div>\n              </div>\n          </div>\n\n        </div>\n        <div *ngIf=\"submissionInProgress\" class=\"text-loader\">\n          {{ currentStep }}{{ animatedDots }}\n          <span class=\"percentage\">{{ submissionProgress }}%</span>\n        </div>\n\n        </div>\n      </div>\n    </ng-container>\n  </div>\n</div>\n"]}