tin-spa 2.1.39 → 2.1.40

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.
@@ -265,8 +265,9 @@ export class TableInternalComponent {
265
265
  }
266
266
  //Actions
267
267
  loadData(action, data) {
268
- console.log("loading");
268
+ console.log("loading table data");
269
269
  if (action) {
270
+ console.log(action.url);
270
271
  this.dataService.CallApi(action, data).subscribe((apiResponse) => {
271
272
  if (this.config.logResponse) {
272
273
  console.log(apiResponse);
@@ -548,4 +549,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
548
549
  }], inputChange: [{
549
550
  type: Output
550
551
  }] } });
551
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-internal.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/table-internal/table-internal.component.ts","../../../../../../projects/tin-spa/src/lib/components/table-internal/table-internal.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC1F,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAE7D,OAAO,EAAsD,UAAU,EAAqB,MAAM,uBAAuB,CAAC;AAI1H,OAAO,EAAE,qBAAqB,EAAE,MAAM,oCAAoC,CAAC;AAI3E,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;;;;;;;;;;;;;;;;;;;AAO/B,MAAM,OAAO,sBAAsB;IAEjC,YAAoB,WAA2B,EAAU,cAA8B,EAAU,kBAAsC,EAAS,MAAiB;QAA7I,gBAAW,GAAX,WAAW,CAAgB;QAAU,mBAAc,GAAd,cAAc,CAAgB;QAAU,uBAAkB,GAAlB,kBAAkB,CAAoB;QAAS,WAAM,GAAN,MAAM,CAAW;QAgEjK,cAAS,GAAG,kBAAkB,CAAC;QAC/B,iBAAY,GAAG,MAAM,CAAC;QAEtB,qBAAgB,GAAG,IAAI,CAAC;QACxB,eAAU,GAAsB,IAAI,OAAO,EAAE,CAAC;QAmBrC,SAAI,GAAO,EAAE,CAAC;QAGb,aAAQ,GAAG,IAAI,YAAY,EAAE,CAAC;QAC9B,iBAAY,GAAG,IAAI,YAAY,EAAE,CAAC;QAClC,gBAAW,GAAG,IAAI,YAAY,EAAE,CAAC;QACjC,gBAAW,GAAG,IAAI,YAAY,EAAE,CAAC;QACjC,gBAAW,GAAG,IAAI,YAAY,EAAE,CAAC;QACjC,gBAAW,GAAG,IAAI,YAAY,EAAE,CAAC;QAO3C,gBAAW,GAAG,KAAK,CAAA;QAQnB,0BAA0B;QAC1B,qBAAgB,GAAG,EAAE,CAAA;QACrB,6BAA6B;QAC7B,+BAA+B;QAC/B,qBAAgB,GAAG,EAAE,CAAA;QAhHnB,6BAA6B;QAC7B,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAE,oBAAoB,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,MAAuB,EAAE,EAAE;YAE7F,IAAI,MAAM,CAAC,OAAO,EAAE;gBAClB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAA;gBACvB,IAAI,CAAC,UAAU,EAAE,CAAA;aAClB;iBAAM;gBACL,IAAI,CAAC,WAAW,GAAG,KAAK,CAAA;gBACxB,IAAI,CAAC,UAAU,EAAE,CAAA;aAClB;QAEH,CAAC,CAAC,CAAC;IACL,CAAC;IAGD,QAAQ;QAEN,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,EAAC;YACxB,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,IAAI,MAAM,EAAC;gBAClC,IAAI,CAAC,SAAS,GAAG,EAAE,CAAA;aACpB;iBACI,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,IAAI,KAAK,EAAE;gBACvC,IAAI,CAAC,SAAS,GAAG,kBAAkB,CAAA;aACpC;iBACI,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,IAAI,QAAQ,EAAE;gBAC1C,IAAI,CAAC,SAAS,GAAG,kBAAkB,CAAA;aACpC;iBACI,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,IAAI,MAAM,EAAE;gBACxC,IAAI,CAAC,SAAS,GAAG,kBAAkB,CAAA;aACpC;SACF;QAED,IAAI,CAAC,UAAU,EAAE,CAAA;QAEjB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAA;QAI5C,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,EAAC;YACzB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;SAC3C;QAED,IAAI,CAAC,YAAY,EAAE,CAAC;QAEpB,IAAI,IAAI,CAAC,MAAM,CAAC,YAAY,EAAC;YAC3B,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;SAC/B;QAED,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,EAAC;YACtB,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;gBAExB,IAAI,CAAC,IAAI,IAAI,EAAE;oBACb,IAAI,IAAI,CAAC,MAAM,EAAE,UAAU,EAAE;wBAC3B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,UAAU,EAAE,EAAE,CAAC,CAAC;qBAC5C;iBACF;YAEH,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAUD,WAAW;QAET,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,EAAC;YAC1B,oCAAoC;YACpC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC;YAE5B,IAAI,CAAC,eAAe,GAAG,IAAI,kBAAkB,CAAM,IAAI,CAAC,UAAU,CAAC,CAAC;YACpE,UAAU,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;SAC/E;IAEH,CAAC;IAgBD,YAAY,CAAC,KAAK;QAChB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,CAAC,CAAA;QACjE,kDAAkD;IACpD,CAAC;IAgBD,YAAY;QAEV,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE;YAC3B,IAAI,MAAM,GAAG,IAAI,UAAU,CAAA;YAE3B,MAAM,CAAC,MAAM,GAAG,EAAE,CAAA;YAElB,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;gBAEnC,IAAI,KAAK,GAAG,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,CAAA;gBACpD,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;YAE3B,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,MAAM,CAAC,UAAU,GAAG,MAAM,CAAC;SACjC;IACH,CAAC;IAED,UAAU;QAER,SAAS;QACT,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,OAAO,EAAE;YACzB,OAAM;SACP;QAED,IAAI,IAAI,CAAC,WAAW,EAAE;YAEpB,IAAI,IAAI,GAAG,EAAE,CAAC;YAEd,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,EAAC;gBACzB,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CACzC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,GAAG,CAAC,CAC9C,CAAA;aACF;YAGD,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAC;gBAClB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;aAC9B;iBAAI;gBACH,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAA;aACpE;SAEF;aAAM;YACL,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAA;SACpE;QAGD,SAAS;QACT,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,OAAO,EAAE;YACzB,OAAM;SACP;QAED,IAAI,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,QAAQ,CAAC,CAAC,MAAM,IAAI,CAAC,CAAA;QAClF,IAAI,YAAY,GAAG,CAAC,EAAE;YAEpB,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,QAAQ,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE;gBAC1E,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;aACrC;YAID,IAAI,IAAI,CAAC,WAAW,EAAE;gBAEpB,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,EAAC;oBACzB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAA;iBACjG;qBAAI;oBACH,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,QAAQ,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;iBACzF;aACF;iBAAM;gBACL,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,QAAQ,CAAC,CAAC;aAC7E;YAED,IAAI,CAAC,YAAY,GAAG,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,GAAG,EAAE,GAAE,EAAE,IAAI,CAAA;SAGjE;IAEH,CAAC;IAED,UAAU;QAER,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO;YAAE,OAAM;QAEhC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAC;YACpB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;SAE7C;aAAI;YACH,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;SAE7C;IAEH,CAAC;IAGD,SAAS,CAAC,IAAY;QACpB,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE;YACxB,OAAO,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAA;YAC/B,OAAO,IAAI,CAAA;SACZ;QACD,OAAO,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,IAAI,CAAC,CAAA;IACtD,CAAC;IAED,OAAO,CAAC,UAAkB;QAExB,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QACnC,IAAI,CAAC,CAAC,IAAI,EAAC;YACT,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAA;SACnB;QAED,IAAI,CAAC,GAAG,aAAa,CAAA;QAErB,QAAQ,UAAU,EAAE;YAElB,KAAK,MAAM;gBAET,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,UAAU,CAAC;gBAEzD,MAAM;YACR,KAAK,MAAM;gBACT,CAAC,GAAG,MAAM,CAAA;gBACV,MAAM;YACR,KAAK,QAAQ;gBACX,CAAC,GAAG,QAAQ,CAAA;gBACZ,MAAM;YAER;gBACE,MAAM;SACT;QAED,OAAO,CAAC,CAAC;IACX,CAAC;IAED,cAAc,CAAC,MAAc,EAAE,GAAG;QAEhC,IAAI,MAAM,CAAC,QAAQ,EAAC;YAClB,IAAI,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAC;gBACvB,OAAO,WAAW,CAAA;aACnB;SACF;QAED,IAAI,MAAM,CAAC,KAAK,EAAC;YACf,OAAO,MAAM,CAAC,KAAK,CAAC;SACrB;QAED,IAAI,MAAM,CAAC,IAAI,IAAI,QAAQ,EAAC;YAC1B,OAAO,SAAS,CAAA;SACjB;QAED,OAAM,UAAU,CAAA;IAClB,CAAC;IAGD,UAAU,CAAC,MAAM;QACf,IAAI,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC;QAC7D,OAAQ,CAAC,CAAA;IACX,CAAC;IAED,QAAQ,CAAC,CAAC,EAAE,OAAO;QAEjB,IAAI,YAAY,GAAG,WAAW,CAAA;QAE9B,IAAI,CAAC,OAAO;YAAE,OAAO,YAAY,CAAA;QAEjC,IAAI,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,CAAA;QAEvC,IAAI,CAAC,EAAE;YACL,OAAO,CAAC,CAAC,KAAK,CAAA;SACf;aAAM;YACL,OAAO,YAAY,CAAA;SACpB;IAGH,CAAC;IAGD,iBAAiB,CAAC,KAAU,EAAE,IAAW;QAEvC,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;SAE9B;aAAI;YACH,OAAO,IAAI,CAAC;SACb;IACH,CAAC;IAED,kBAAkB,CAAC,KAAU,EAAE,KAAY;QAEzC,IAAI,CAAC,KAAK;YAAE,OAAO,KAAK,CAAC;QAEzB,IAAI,KAAK,CAAC,SAAS,EAAE;YACnB,OAAO,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;SAE/B;aAAM;YACL,OAAO,IAAI,CAAC;SACb;IACH,CAAC;IAED,UAAU,CAAC,OAAO;QAEhB,IAAI,CAAC,OAAO;YAAE,OAAO;QACrB,IAAI,OAAO,IAAI,EAAE;YAAE,OAAO;QAC1B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACpC,CAAC;IAED,YAAY,CAAC,GAAG,EAAE,UAAkB;QAElC,IAAI,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAA;QAEvC,IAAI,MAAM,CAAC,QAAQ,EAAC;YAElB,OAAO,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;SAC7B;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAGD,WAAW,CAAC,GAAG,EAAE,UAAkB;QAEjC,IAAI,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAA;QAEvC,IAAI,MAAM,CAAC,OAAO,EAAE;YAElB,OAAO,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;SAC5B;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAGD,SAAS;IAIT,QAAQ,CAAC,MAAc,EAAE,IAAS;QAChC,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,CAAA;QAEtB,IAAI,MAAM,EAAE;YAEV,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,SAAS,CAAC,CAAC,WAAwB,EAAE,EAAE;gBAE5E,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,EAAC;oBAC1B,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,CAAA;iBACzB;gBAED,IAAI,CAAC,UAAU,GAAG,WAAW,CAAC,IAAI,CAAA;gBAElC,IAAI,CAAC,eAAe,GAAG,IAAI,kBAAkB,CAAM,WAAW,CAAC,IAAI,CAAC,CAAC;gBACrE,IAAI,CAAC,eAAe,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC;gBAErD,IAAI,WAAW,CAAC,OAAO,EAAE;oBACvB,IAAI,CAAC,eAAe,GAAG,IAAI,kBAAkB,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;oBAChE,IAAI,CAAC,eAAe,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC;oBAErD,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;iBAGnC;qBAAM;oBACL,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,SAAS,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC;iBAC5D;YAEH,CAAC,CAAC,CAAC;SACJ;IAEH,CAAC;IAGD,QAAQ;IACR,aAAa,CAAC,CAAC;QACb,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAA;QACrB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAEzB,iBAAiB;QAEjB,IAAI,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,YAAY,EAAC;YACxC,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,YAAY,CAAC,MAAM,IAAI,MAAM,CAAA;YACtD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;SACzD;IACH,CAAC;IAED,cAAc;QACZ,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,CAAA;QACtB,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QAGzB,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE;YAC1B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,EAAC,EAAE,CAAC,CAAC;SAC1C;aAAI;YACH,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;SACtB;IACH,CAAC;IAED,UAAU,CAAC,CAAC;QAEV,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QAErB,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC,CAAA;QAEzB,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,UAAU,EAAE;YACtC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SAC5B;IACH,CAAC;IAID,aAAa,CAAC,IAAI,EAAE,GAAG;QAErB,IAAI,IAAI,IAAI,MAAM,EAAE;YAClB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAA;SACpB;aACI,IAAI,IAAI,IAAI,MAAM,EAAE;YACvB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;SACrB;aACI,IAAI,IAAI,IAAI,QAAQ,EAAE;YACzB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;SACvB;aAAI;YACH,IAAI,CAAC,WAAW,CAAC,IAAI,EAAC,GAAG,CAAC,CAAC;SAC5B;IAEH,CAAC;IAGD,aAAa,CAAC,MAAe,EAAE,GAAG;QAEhC,IAAI,MAAM,CAAC,aAAa,EAAC;YAEvB,MAAM,CAAC,aAAa,CAAC,OAAO,GAAG,GAAG,CAAC;YAEnC,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,qBAAqB,EAAE;gBACxD,KAAK,EAAE,OAAO;gBACd,IAAI,EAAE,MAAM,CAAC,aAAa;aAC3B,CAAC,CAAC;YAEH,SAAS,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;gBAE3C,IAAI,MAAM,CAAC,OAAO,IAAI,SAAS,EAAE;oBAC/B,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,IAAI,EAAE,GAAG,CAAC,CAAA;oBACxC,IAAI,CAAC,cAAc,EAAE,CAAC;iBACvB;YAEH,CAAC,CAAC,CAAC;SACJ;aACG;YACF,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,IAAI,EAAE,GAAG,CAAC,CAAA;SACzC;IACH,CAAC;IAED,WAAW,CAAC,IAAI,EAAE,GAAG;QAEnB,IAAI,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAClC,IAAI,MAAM,EAAE;YAEV,IAAI,CAAC,MAAM,CAAC,MAAM,EAAC;gBACjB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,EAAE,GAAG,CAAC,CAAA;gBAC/B,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;aACnC;iBACG;gBAEF,IAAI,MAAM,CAAC,aAAa,EAAE;oBAExB,MAAM,CAAC,aAAa,CAAC,OAAO,GAAG,GAAG,CAAC;oBAEnC,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,qBAAqB,EAAE;wBACxD,KAAK,EAAE,OAAO;wBACd,IAAI,EAAE,MAAM,CAAC,aAAa;qBAC3B,CAAC,CAAC;oBAEH,SAAS,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;wBAE3C,IAAI,MAAM,CAAC,OAAO,IAAI,SAAS,EAAE;4BAC/B,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,IAAI,EAAE,GAAG,CAAC,CAAA;4BACxC,IAAI,CAAC,cAAc,EAAE,CAAC;yBACvB;oBAEH,CAAC,CAAC,CAAC;iBACJ;qBACI;oBACH,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,IAAI,EAAE,GAAG,CAAC,CAAA;iBACzC;aACF;SAEF;aAAI;YACH,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;SACnC;IAIH,CAAC;IAGD,iBAAiB,CAAC,IAAI,EAAE,GAAG;QACzB,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAA;QAC7B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAC,IAAI,EAAC,IAAI,EAAC,IAAI,EAAG,GAAG,EAAC,CAAC,CAAC;IAChD,CAAC;IAKD,SAAS,CAAC,GAAG;QAEX,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,CAAA;QAE3B,IAAI,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QAEpC,IAAI,CAAC,MAAM;YAAE,OAAO;QAEpB,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE;YAClB,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;YACzC,OAAO;SACR;QAED,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE;YAC3B,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,uBAAuB,CAAC,CAAA;YAClD,OAAO;SACR;QAED,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,GAAG,MAAM,CAAC;QACrC,IAAI,IAAI,GAAwB;YAC9B,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,UAAU;YAC9B,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,OAAO;YAC5B,OAAO,EAAE,GAAG;SACb,CAAA;QAED,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,qBAAqB,EAAE;YACxD,KAAK,EAAE,OAAO;YACd,IAAI,EAAE,IAAI;SACX,CAAC,CAAC;QAEH,SAAS,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YAC3C,IAAI,MAAM,CAAC,OAAO,EAAE;gBAClB,IAAI,CAAC,cAAc,EAAE,CAAC;aACvB;QACH,CAAC,CAAC,CAAC;IAIL,CAAC;IAED,QAAQ;QAEN,IAAI,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QACtC,IAAI,CAAC,MAAM;YAAE,OAAO;QAEpB,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE;YAClB,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YAC1C,OAAO;SACR;QAED,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE;YAC3B,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,uBAAuB,CAAC,CAAA;YAClD,OAAO;SACR;QAED,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,GAAG,QAAQ,CAAC;QACvC,IAAI,IAAI,GAAyB;YAC/B,MAAM,EAAG,IAAI,CAAC,MAAM,CAAC,UAAU;YAC/B,OAAO,EAAG,IAAI,CAAC,MAAM,CAAC,OAAO;SAC9B,CAAA;QAED,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,qBAAqB,EAAE;YACxD,KAAK,EAAE,OAAO;YACd,IAAI,EAAE,IAAI;SACX,CAAC,CAAC;QAEH,SAAS,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YAC3C,IAAI,MAAM,CAAC,OAAO,IAAI,SAAS,EAAE;gBAC/B,IAAI,CAAC,iBAAiB,CAAC,QAAQ,EAAC,MAAM,CAAC,IAAI,CAAC,CAAC;gBAC7C,IAAI,CAAC,cAAc,EAAE,CAAC;aACvB;iBAAM,IAAI,MAAM,CAAC,OAAO,IAAI,MAAM,EAAE;gBACnC,IAAI,CAAC,iBAAiB,CAAC,QAAQ,EAAC,MAAM,CAAC,IAAI,CAAC,CAAC;aAC9C;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAID,SAAS,CAAC,GAAG;QAEX,IAAI,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QACpC,IAAI,CAAC,MAAM;YAAE,OAAO;QAEpB,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE;YAClB,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;YACzC,OAAO;SACR;QAED,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE;YAC3B,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,uBAAuB,CAAC,CAAA;YAClD,OAAO;SACR;QAED,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,GAAG,MAAM,CAAC;QACrC,IAAI,IAAI,GAAwB;YAC9B,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,UAAU;YAC9B,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,OAAO;YAC5B,OAAO,EAAG,GAAG;SACd,CAAA;QAED,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,qBAAqB,EAAE;YACxD,KAAK,EAAE,OAAO;YACd,IAAI,EAAE,IAAI;SACX,CAAC,CAAC;QAGH,SAAS,CAAC,iBAAiB,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YACtD,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAA;QACtB,CAAC,CAAC,CAAC;QAGH,SAAS,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YAC3C,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;YACnB,IAAI,MAAM,CAAC,OAAO,IAAI,SAAS,EAAE;gBAC/B,IAAI,CAAC,iBAAiB,CAAC,MAAM,EAAC,MAAM,CAAC,IAAI,CAAC,CAAC;gBAC3C,IAAI,CAAC,cAAc,EAAE,CAAC;aACvB;iBAAM,IAAI,MAAM,CAAC,OAAO,IAAI,MAAM,EAAE;gBACnC,IAAI,CAAC,iBAAiB,CAAC,MAAM,EAAC,MAAM,CAAC,IAAI,CAAC,CAAC;aAC5C;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,WAAW,CAAC,GAAG;QAEb,IAAI,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QACtC,IAAI,CAAC,MAAM;YAAE,OAAO;QAGpB,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YAC3D,IAAI,MAAM,IAAI,KAAK,EAAE;gBACnB,IAAI,CAAC,iBAAiB,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAA;gBACrC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,EAAC,GAAG,CAAC,CAAC;aAChC;QACH,CAAC,CAAC,CAAC;IAEL,CAAC;IAGD,QAAQ,CAAC,UAAkB,EAAE,GAAG;QAE9B,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAA;QAElC,IAAI,CAAC,CAAC;YAAE,OAAO;QAEf,IAAI,CAAC,CAAC,CAAC,MAAM;YAAE,OAAO;QAEtB,IAAI,CAAC,CAAC,OAAO,EAAC;YACZ,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;gBACvE,IAAI,MAAM,IAAI,KAAK,EAAE;oBACnB,IAAI,CAAC,UAAU,CAAC,CAAC,EAAC,GAAG,CAAC,CAAA;iBACvB;YACH,CAAC,CAAC,CAAC;SACJ;aAAI;YACH,IAAI,CAAC,UAAU,CAAC,CAAC,EAAE,GAAG,CAAC,CAAA;SACxB;IAEH,CAAC;IAGD,UAAU,CAAC,CAAS,EAAE,GAAG;QACvB,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,EAAE;YAEhE,IAAI,WAAW,CAAC,OAAO,EAAE;gBACvB,IAAI,CAAC,CAAC,MAAM,CAAC,cAAc,EAAE;oBAC3B,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;iBACpD;qBAAM;oBAEL,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;iBACtC;gBAED,IAAI,CAAC,cAAc,EAAE,CAAC;aACvB;iBAAM;gBACL,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,SAAS,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC;aAC5D;QACH,CAAC,EACC,CAAC,KAAK,EAAE,EAAE;YACR,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,SAAS,GAAG,KAAK,CAAC,CAAC;QAC/C,CAAC,CACF,CAAC;IACJ,CAAC;;mHAvrBU,sBAAsB;uGAAtB,sBAAsB,gbClBnC,+yWA0LA;2FDxKa,sBAAsB;kBALlC,SAAS;+BACE,oBAAoB;2LA0FD,cAAc;sBAA1C,SAAS;uBAAC,gBAAgB;gBAGlB,IAAI;sBAAZ,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACI,QAAQ;sBAAjB,MAAM;gBACG,YAAY;sBAArB,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACG,WAAW;sBAApB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { MatTableDataSource } from '@angular/material/table';\r\nimport { DatePipe, CurrencyPipe } from '@angular/common';\r\nimport { Action, Button, Color, Column, DetailsDialogConfig, FormConfig, Icon, TableConfig } from '../../classes/Classes';\r\nimport { MatPaginator } from '@angular/material/paginator';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { DetailsDialogInternal } from './detailsDialog-internal.component';\r\nimport { BreakpointObserver, BreakpointState } from '@angular/cdk/layout';\r\nimport { DataServiceLib } from '../../services/data.service';\r\nimport { ApiResponse } from '../../classes/TinCore';\r\nimport { Subject } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'spa-table-internal',\r\n  templateUrl: './table-internal.component.html',\r\n  styleUrls: ['./table-internal.component.css']\r\n})\r\nexport class TableInternalComponent implements OnInit {\r\n\r\n  constructor(private dataService: DataServiceLib, private messageService: MessageService, private breakpointObserver: BreakpointObserver, public dialog: MatDialog)\r\n  {\r\n    // detect screen size changes\r\n    this.breakpointObserver.observe([ \"(max-width: 600px)\"]).subscribe((result: BreakpointState) => {\r\n\r\n      if (result.matches) {\r\n        this.smallScreen = true\r\n        this.setColumns()\r\n      } else {\r\n        this.smallScreen = false\r\n        this.setColumns()\r\n      }\r\n\r\n    });\r\n  }\r\n\r\n\r\n  ngOnInit() {\r\n\r\n    if (this.config.elevation){\r\n      if (this.config.elevation == \"none\"){\r\n        this.elevation = \"\"\r\n      }\r\n      else if (this.config.elevation == \"low\") {\r\n        this.elevation = \"mat-elevation-z1\"\r\n      }\r\n      else if (this.config.elevation == \"medium\") {\r\n        this.elevation = \"mat-elevation-z5\"\r\n      }\r\n      else if (this.config.elevation == \"high\") {\r\n        this.elevation = \"mat-elevation-z9\"\r\n      }\r\n    }\r\n\r\n    this.setColumns()\r\n\r\n    this.createButton = this.getButton('create')\r\n\r\n\r\n\r\n    if (this.config.loadAction){\r\n      this.loadData(this.config.loadAction, \"\");\r\n    }\r\n\r\n    this.formDefaults();\r\n\r\n    if (this.config.searchConfig){\r\n      this.showFilterButton = false;\r\n    }\r\n\r\n    if (this.reload != null){\r\n      this.reload.subscribe(v => {\r\n\r\n        if (v == true) {\r\n          if (this.config?.loadAction) {\r\n            this.loadData(this.config?.loadAction, \"\");\r\n          }\r\n        }\r\n\r\n      });\r\n    }\r\n  }\r\n\r\n\r\n  elevation = \"mat-elevation-z5\";\r\n  actionsWidth = \"50px\";\r\n\r\n  showFilterButton = true;\r\n  tileReload : Subject<boolean> = new Subject();\r\n\r\n\r\n  ngOnChanges() {\r\n\r\n    if (!this.config.loadAction){\r\n      // console.log(\"Table data Changed\")\r\n      this.dataSource = this.data;\r\n\r\n      this.tableDataSource = new MatTableDataSource<any>(this.dataSource);\r\n      setTimeout(() => { this.tableDataSource.paginator = this.tablePaginator; }, 5)\r\n    }\r\n\r\n  }\r\n\r\n\r\n  @ViewChild('tablePaginator') tablePaginator: MatPaginator;\r\n\r\n\r\n  @Input() data: any =[];\r\n  @Input() config: TableConfig;\r\n  @Input() reload: Subject<boolean>;\r\n  @Output() dataLoad = new EventEmitter();\r\n  @Output() refreshClick = new EventEmitter();\r\n  @Output() searchClick = new EventEmitter();\r\n  @Output() createClick = new EventEmitter();\r\n  @Output() actionClick = new EventEmitter();\r\n  @Output() inputChange = new EventEmitter();\r\n\r\n  inputChanged(event) {\r\n    this.inputChange.emit({ field: event.field, value: event.value })\r\n    // console.log(\"Changed \" + JSON.stringify(event))\r\n  }\r\n\r\n  smallScreen = false\r\n\r\n  createButton: Button;\r\n\r\n\r\n  //Table\r\n  tableDataSource;\r\n  dataSource: any[];\r\n  // columns: Column[] = [];\r\n  displayedColumns = []\r\n  // @Input() optionValue = \"\";\r\n  // @Input() optionDisplay = \"\";\r\n  displayedButtons = []\r\n\r\n  formDefaults() {\r\n\r\n    if (!this.config.formConfig) {\r\n      let config = new FormConfig\r\n\r\n      config.fields = []\r\n\r\n      this.config.columns.forEach(column => {\r\n\r\n        let field = { name: column.name, type: column.type }\r\n        config.fields.push(field)\r\n\r\n      });\r\n\r\n      this.config.formConfig = config;\r\n    }\r\n  }\r\n\r\n  setColumns() {\r\n\r\n    //columns\r\n    if (!this.config?.columns) {\r\n      return\r\n    }\r\n\r\n    if (this.smallScreen) {\r\n\r\n      let cols = [];\r\n\r\n      if (this.config.minColumns){\r\n        cols = this.config.minColumns.filter(col =>\r\n          this.config.columns.some(x => x.name === col)\r\n        )\r\n      }\r\n\r\n\r\n      if (cols.length > 0){\r\n        this.displayedColumns = cols;\r\n      }else{\r\n        this.displayedColumns = this.config.columns.map(({ name }) => name)\r\n      }\r\n\r\n    } else {\r\n      this.displayedColumns = this.config.columns.map(({ name }) => name)\r\n    }\r\n\r\n\r\n    //buttons\r\n    if (!this.config?.buttons) {\r\n      return\r\n    }\r\n\r\n    let buttonsCount = this.config.buttons.filter(x => x.name != 'create').length ?? 0\r\n    if (buttonsCount > 0) {\r\n\r\n      if (!this.displayedColumns.find(x => x == 'action') && this.config.buttons) {\r\n        this.displayedColumns.push(\"action\")\r\n      }\r\n\r\n\r\n\r\n      if (this.smallScreen) {\r\n\r\n        if (this.config.minButtons){\r\n          this.displayedButtons = this.config.buttons.filter(x => this.config.minButtons.includes(x.name))\r\n        }else{\r\n          this.displayedButtons = this.config.buttons.filter(x => x.name != 'create').slice(0, 1);\r\n        }\r\n      } else {\r\n        this.displayedButtons = this.config.buttons.filter(x => x.name != 'create');\r\n      }\r\n\r\n      this.actionsWidth = `${this.displayedButtons.length * 40 +20}px`\r\n\r\n\r\n    }\r\n\r\n  }\r\n\r\n  setButtons(){\r\n\r\n    if (!this.config.buttons) return\r\n\r\n    if (!this.smallScreen){\r\n      this.displayedButtons = this.config.buttons;\r\n\r\n    }else{\r\n      this.displayedButtons = this.config.buttons;\r\n\r\n    }\r\n\r\n  }\r\n\r\n\r\n  getButton(name: string) {\r\n    if (!this.config.buttons) {\r\n      console.log(\"No buttons found\")\r\n      return null\r\n    }\r\n    return this.config.buttons.find(x => x.name == name)\r\n  }\r\n\r\n  getIcon(buttonName: string){\r\n\r\n    let b = this.getButton(buttonName);\r\n    if (b.icon){\r\n      return b.icon.name\r\n    }\r\n\r\n    let i = 'open_in_new'\r\n\r\n    switch (buttonName) {\r\n\r\n      case 'view':\r\n\r\n        i = this.config.flatButtons ? 'open_in_new' : 'pageview';\r\n\r\n        break;\r\n      case 'edit':\r\n        i = 'edit'\r\n        break;\r\n      case 'delete':\r\n        i = 'delete'\r\n        break;\r\n\r\n      default:\r\n        break;\r\n    }\r\n\r\n    return i;\r\n  }\r\n\r\n  getButtonColor(button: Button, row) {\r\n\r\n    if (button.disabled){\r\n      if (button.disabled(row)){\r\n        return 'lightgray'\r\n      }\r\n    }\r\n\r\n    if (button.color){\r\n      return button.color;\r\n    }\r\n\r\n    if (button.name == 'delete'){\r\n      return '#F44336'\r\n    }\r\n\r\n    return' #4050B5'\r\n  }\r\n\r\n\r\n  getOptions(column){\r\n    let x = this.config.columns.find(opt => opt.name === column);\r\n    return  x\r\n  }\r\n\r\n  getColor(v, options) {\r\n\r\n    let defaultColor = 'lightgrey'\r\n\r\n    if (!options) return defaultColor\r\n\r\n    let c = options.find(x => x.value == v)\r\n\r\n    if (c) {\r\n      return c.color\r\n    } else {\r\n      return defaultColor\r\n    }\r\n\r\n\r\n  }\r\n\r\n\r\n  testIconCondition(value: any, icon : Icon): boolean {\r\n\r\n    if (icon.condition) {\r\n      return icon.condition(value);\r\n\r\n    }else{\r\n      return true;\r\n    }\r\n  }\r\n\r\n  testColorCondition(value: any, color: Color): boolean {\r\n\r\n    if (!color) return false;\r\n\r\n    if (color.condition) {\r\n      return color.condition(value);\r\n\r\n    } else {\r\n      return true;\r\n    }\r\n  }\r\n\r\n  showBanner(message){\r\n\r\n    if (!message) return;\r\n    if (message == '') return;\r\n    this.messageService.info(message);\r\n  }\r\n\r\n  testDisabled(row, buttonName: string): boolean{\r\n\r\n    let button = this.getButton(buttonName)\r\n\r\n    if (button.disabled){\r\n\r\n      return button.disabled(row);\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n\r\n  testVisible(row, buttonName: string): boolean {\r\n\r\n    let button = this.getButton(buttonName)\r\n\r\n    if (button.visible) {\r\n\r\n      return button.visible(row);\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n\r\n  //Actions\r\n\r\n\r\n\r\n  loadData(action: Action, data: any) {\r\n    console.log(\"loading\")\r\n\r\n    if (action) {\r\n\r\n      this.dataService.CallApi(action, data).subscribe((apiResponse: ApiResponse) => {\r\n\r\n        if (this.config.logResponse){\r\n          console.log(apiResponse)\r\n        }\r\n\r\n        this.dataSource = apiResponse.data\r\n\r\n        this.tableDataSource = new MatTableDataSource<any>(apiResponse.data);\r\n        this.tableDataSource.paginator = this.tablePaginator;\r\n\r\n        if (apiResponse.success) {\r\n          this.tableDataSource = new MatTableDataSource(apiResponse.data);\r\n          this.tableDataSource.paginator = this.tablePaginator;\r\n\r\n          this.dataLoaded(apiResponse.data);\r\n\r\n\r\n        } else {\r\n          this.messageService.toast(\"Error: \" + apiResponse.message);\r\n        }\r\n\r\n      });\r\n    }\r\n\r\n  }\r\n\r\n\r\n  //Events\r\n  searchClicked(x){\r\n    console.log(\"Search\")\r\n    this.searchClick.emit(x);\r\n\r\n    // console.log(x)\r\n\r\n    if (this.config.searchConfig.searchAction){\r\n      this.config.searchConfig.searchAction.method == 'post'\r\n      this.loadData(this.config.searchConfig.searchAction, x);\r\n    }\r\n  }\r\n\r\n  refreshClicked() {\r\n    console.log(\"Refresh\")\r\n    this.refreshClick.emit();\r\n\r\n\r\n    if (this.config.loadAction) {\r\n      this.loadData(this.config.loadAction,\"\");\r\n    }else{\r\n      this.dataLoad.emit();\r\n    }\r\n  }\r\n\r\n  dataLoaded(x) {\r\n\r\n    this.dataLoad.emit(x)\r\n\r\n    console.log(\"dataloaded\")\r\n\r\n    if (this.config.tileConfig?.loadAction) {\r\n      this.tileReload.next(true);\r\n    }\r\n  }\r\n\r\n\r\n\r\n  actionClicked(name, row) {\r\n\r\n    if (name == 'view') {\r\n      this.viewModel(row)\r\n    }\r\n    else if (name == 'edit') {\r\n      this.editModel(row);\r\n    }\r\n    else if (name == 'delete') {\r\n      this.deleteModel(row);\r\n    }else{\r\n      this.customModel(name,row);\r\n    }\r\n\r\n  }\r\n\r\n\r\n  columnClicked(column : Column, row){\r\n\r\n    if (column.detailsConfig){\r\n\r\n      column.detailsConfig.details = row;\r\n\r\n      const dialogRef = this.dialog.open(DetailsDialogInternal, {\r\n        width: \"900px\",\r\n        data: column.detailsConfig\r\n      });\r\n\r\n      dialogRef.afterClosed().subscribe((result) => {\r\n\r\n        if (result.message == \"success\") {\r\n          this.actionClickedEmit(column.name, row)\r\n          this.refreshClicked();\r\n        }\r\n\r\n      });\r\n    }\r\n    else{\r\n      this.actionClickedEmit(column.name, row)\r\n    }\r\n  }\r\n\r\n  customModel(name, row) {\r\n\r\n    let button = this.getButton(name);\r\n    if (button) {\r\n\r\n      if (!button.dialog){\r\n        this.doAction(button.name, row)\r\n        this.actionClickedEmit(name, row);\r\n      }\r\n      else{\r\n\r\n        if (button.detailsConfig) {\r\n\r\n          button.detailsConfig.details = row;\r\n\r\n          const dialogRef = this.dialog.open(DetailsDialogInternal, {\r\n            width: \"900px\",\r\n            data: button.detailsConfig\r\n          });\r\n\r\n          dialogRef.afterClosed().subscribe((result) => {\r\n\r\n            if (result.message == \"success\") {\r\n              this.actionClickedEmit(button.name, row)\r\n              this.refreshClicked();\r\n            }\r\n\r\n          });\r\n        }\r\n        else {\r\n          this.actionClickedEmit(button.name, row)\r\n        }\r\n      }\r\n\r\n    }else{\r\n      this.actionClickedEmit(name, row);\r\n    }\r\n\r\n\r\n\r\n  }\r\n\r\n\r\n  actionClickedEmit(name, row) {\r\n    console.log(\"Action clicked\")\r\n    this.actionClick.emit({name:name,data : row});\r\n  }\r\n\r\n\r\n\r\n\r\n  viewModel(row) {\r\n\r\n    console.log(\"view Clicked\")\r\n\r\n    let button = this.getButton('view');\r\n\r\n    if (!button) return;\r\n\r\n    if (!button.dialog) {\r\n      this.actionClickedEmit(button.name, row);\r\n      return;\r\n    }\r\n\r\n    if (!this.config.formConfig) {\r\n      this.messageService.toast(\"Please configure form\")\r\n      return;\r\n    }\r\n\r\n    this.config.formConfig.mode = \"view\";\r\n    let conf: DetailsDialogConfig = {\r\n      config: this.config.formConfig,\r\n      buttons: this.config.buttons,\r\n      details: row,\r\n    }\r\n\r\n    const dialogRef = this.dialog.open(DetailsDialogInternal, {\r\n      width: \"900px\",\r\n      data: conf\r\n    });\r\n\r\n    dialogRef.afterClosed().subscribe((result) => {\r\n      if (result.message) {\r\n        this.refreshClicked();\r\n      }\r\n    });\r\n\r\n\r\n\r\n  }\r\n\r\n  newModel() {\r\n\r\n    let button = this.getButton('create');\r\n    if (!button) return;\r\n\r\n    if (!button.dialog) {\r\n      this.actionClickedEmit(button.name, null);\r\n      return;\r\n    }\r\n\r\n    if (!this.config.formConfig) {\r\n      this.messageService.toast(\"Please configure form\")\r\n      return;\r\n    }\r\n\r\n    this.config.formConfig.mode = \"create\";\r\n    let conf : DetailsDialogConfig = {\r\n      config : this.config.formConfig,\r\n      buttons : this.config.buttons,\r\n    }\r\n\r\n    const dialogRef = this.dialog.open(DetailsDialogInternal, {\r\n      width: \"900px\",\r\n      data: conf,\r\n    });\r\n\r\n    dialogRef.afterClosed().subscribe((result) => {\r\n      if (result.message == \"success\") {\r\n        this.actionClickedEmit('create',result.data);\r\n        this.refreshClicked();\r\n      } else if (result.message == \"emit\") {\r\n        this.actionClickedEmit('create',result.data);\r\n      }\r\n    });\r\n  }\r\n\r\n\r\n\r\n  editModel(row) {\r\n\r\n    let button = this.getButton('edit');\r\n    if (!button) return;\r\n\r\n    if (!button.dialog) {\r\n      this.actionClickedEmit(button.name, row);\r\n      return;\r\n    }\r\n\r\n    if (!this.config.formConfig) {\r\n      this.messageService.toast(\"Please configure form\")\r\n      return;\r\n    }\r\n\r\n    this.config.formConfig.mode = \"edit\";\r\n    let conf: DetailsDialogConfig = {\r\n      config: this.config.formConfig,\r\n      buttons: this.config.buttons,\r\n      details : row,\r\n    }\r\n\r\n    const dialogRef = this.dialog.open(DetailsDialogInternal, {\r\n      width: \"900px\",\r\n      data: conf\r\n    });\r\n\r\n\r\n    dialogRef.componentInstance.inputChange.subscribe((x) => {\r\n      this.inputChanged(x)\r\n    });\r\n\r\n\r\n    dialogRef.afterClosed().subscribe((result) => {\r\n      console.log(result)\r\n      if (result.message == \"success\") {\r\n        this.actionClickedEmit('edit',result.data);\r\n        this.refreshClicked();\r\n      } else if (result.message == \"emit\") {\r\n        this.actionClickedEmit('edit',result.data);\r\n      }\r\n    });\r\n  }\r\n\r\n  deleteModel(row) {\r\n\r\n    let button = this.getButton('delete');\r\n    if (!button) return;\r\n\r\n\r\n    this.messageService.confirm(`DELETE ?`).subscribe((result) => {\r\n      if (result == \"yes\") {\r\n        this.actionClickedEmit('delete', row)\r\n        this.doAction(button.name,row);\r\n      }\r\n    });\r\n\r\n  }\r\n\r\n\r\n  doAction(buttonName: string, row) {\r\n\r\n    let b = this.getButton(buttonName)\r\n\r\n    if (!b) return;\r\n\r\n    if (!b.action) return;\r\n\r\n    if (b.confirm){\r\n      this.messageService.confirm(`${b.confirm.message}`).subscribe((result) => {\r\n        if (result == \"yes\") {\r\n          this.execAction(b,row)\r\n        }\r\n      });\r\n    }else{\r\n      this.execAction(b, row)\r\n    }\r\n\r\n  }\r\n\r\n\r\n  execAction(b: Button, row){\r\n    this.dataService.CallApi(b.action, row).subscribe((apiResponse) => {\r\n\r\n      if (apiResponse.success) {\r\n        if (b.action.successMessage) {\r\n          this.messageService.toast(b.action.successMessage);\r\n        } else {\r\n\r\n          this.messageService.toast(\"Updated\");\r\n        }\r\n\r\n        this.refreshClicked();\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse.message);\r\n      }\r\n    },\r\n      (error) => {\r\n        this.messageService.toast(\"Error: \" + error);\r\n      }\r\n    );\r\n  }\r\n\r\n\r\n}\r\n","\n<spa-search *ngIf=\"config.searchConfig\" [config]=\"config.searchConfig\" style=\"margin-bottom: 20px;\" (searchClick)=\"searchClicked($event)\"></spa-search>\n\n<div class=\"top\">\n\n  <div class=\"tin-row\" >\n    <button *ngIf=\"createButton\" id=\"btnNew\" mat-raised-button color=\"primary\" style=\"margin-right: 10px;\" (click)=\"newModel()\">{{createButton.display}}</button>\n    <!-- <spa-tiles *ngIf=\"config.tileConfig\" [reload]=\"tileReload\" [config]=\"config.tileConfig\"></spa-tiles> -->\n  </div>\n\n  <div *ngIf=\"config.tileConfig && !smallScreen\" style=\"min-width: 75%;\">\n    <spa-tiles  [reload]=\"tileReload\" [config]=\"config.tileConfig\"></spa-tiles>\n  </div>\n\n  <div *ngIf=\"config.showFilter\" class=\"d-flex justify-content-end\">\n    <spa-filter [showButton]=\"showFilterButton\" [data]=\"tableDataSource\" (refreshClick)=\"refreshClicked()\"></spa-filter>\n  </div>\n\n</div>\n\n<div *ngIf=\"config.tileConfig && smallScreen\" style=\"width: 100%;\">\n  <spa-tiles [reload]=\"tileReload\" [config]=\"config.tileConfig\"></spa-tiles>\n</div>\n\n<div *ngIf=\"config.title\" class=\"title\">\n  <label style=\"font-size: larger;\">{{config.title | camelToWords}}</label>\n</div>\n\n<div>\n\n  <p *ngIf=\"!config\"><em>Configure Table</em></p>\n  <p *ngIf=\"!dataSource\"><em>Loading...</em></p>\n\n\n\n  <div *ngIf=\"dataSource\">\n\n\n    <table mat-table [dataSource]=\"tableDataSource\"  [ngClass]=\"elevation\">\n      <ng-container *ngFor=\"let column of config.columns\" [matColumnDef]=\"column.name\">\n        <th mat-header-cell *matHeaderCellDef >{{ column.alias ?? column.name | camelToWords }}</th>\n        <td mat-cell *matCellDef=\"let row;\" class=\"right-padding\" >\n\n          <ng-container [ngSwitch]=\"column.type\">\n\n            <ng-container *ngSwitchCase=\"'checkbox'\">\n              <spa-check [value]=\"row[column.name]\" [readonly]=\"true\"></spa-check>\n              <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n              <ng-container *ngFor=\"let icon of column.icons\">\n                <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n              </ng-container>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'select'\">\n              <spa-select [options]=\"column.options\" [optionDisplay]=\"column.optionDisplay\" [optionValue]=\"column.optionValue\" [(value)]=\"row[column.name]\" width=\"90%\" ></spa-select>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'chip'\">\n              <mat-chip-list>\n                <mat-chip (click)=\"columnClicked(column, row)\" [ngStyle]=\"{'background-color': testColorCondition(row, column.color) ? column.color.name : getColor(row[column.name], column?.options)}\" style=\"font-size: 12px;\"> {{row[column.name]}} </mat-chip>\n                  <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n                  <ng-container *ngFor=\"let icon of column.icons\">\n                    <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n                  </ng-container>\n              </mat-chip-list>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'icon'\">\n              <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n              <ng-container *ngFor=\"let icon of column.icons\">\n                <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n              </ng-container>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'date'\">\n              {{row[column.name] | date : 'dd/MM/yyyy'}}\n              <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n              <ng-container *ngFor=\"let icon of column.icons\">\n                <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n              </ng-container>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'datetime'\">\n              {{row[column.name] | date : 'dd/MM/yyyy HH:mm'}}\n              <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n              <ng-container *ngFor=\"let icon of column.icons\">\n                <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n              </ng-container>\n            </ng-container>\n\n            <!-- <ng-container *ngSwitchCase=\"'spinner'\">\n                <mat-spinner [diameter]=\"20\">\n\n                </mat-spinner>\n            </ng-container> -->\n\n            <ng-container *ngSwitchCase=\"'money'\">\n\n              <label [ngStyle]=\"{'color': testColorCondition(row, column.color) ? column.color.name : ''}\">{{row[column.name] | currency:'':''}}</label>\n\n              <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n              <ng-container *ngFor=\"let icon of column.icons\">\n                <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n              </ng-container>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'button'\">\n\n              <button mat-button [ngStyle]=\"{'color': testColorCondition(row, column.color) ? column.color.name : ''}\" (click)=\"actionClicked(column.name, row)\">{{row[column.name]}}</button>\n\n              <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n              <ng-container *ngFor=\"let icon of column.icons\">\n                <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n              </ng-container>\n            </ng-container>\n\n            <ng-container *ngSwitchDefault>\n              <label [ngStyle]=\"{'color': testColorCondition(row, column.color) ? column.color.name : ''}\">{{row[column.name]}}</label>\n              <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n              <ng-container *ngFor=\"let icon of column.icons\">\n                <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n              </ng-container>\n\n            </ng-container>\n\n          </ng-container>\n\n\n        </td>\n      </ng-container>\n\n      <ng-container matColumnDef=\"action\">\n        <th mat-header-cell *matHeaderCellDef> Action </th>\n        <td mat-cell *matCellDef=\"let row\" [ngStyle]=\"{width:false ? '50px' : actionsWidth}\">\n\n\n          <ng-container *ngFor=\"let button of displayedButtons\">\n\n            <ng-container *ngIf=\"button.name != 'create' && testVisible(row,button.name)\">\n\n              <button *ngIf=\"!config.flatButtons\" mat-mini-fab  [matTooltip]=\"button.tip ?? button.name \" matTooltipPosition=\"above\" style=\"margin-right:5px\"\n              [ngStyle]=\"{'background-color':getButtonColor(button, row)}\"\n              [disabled]=\"testDisabled(row,button.name)\"  (click)=\"actionClicked(button.name, row)\">\n                <mat-icon>{{getIcon(button.name)}}</mat-icon>\n              </button>\n\n              <button *ngIf=\"config.flatButtons\"  mat-icon-button  [matTooltip]=\"button.tip ?? button.name \" matTooltipPosition=\"above\" style=\"margin-right:5px\"\n\n              [disabled]=\"testDisabled(row,button.name)\"  (click)=\"actionClicked(button.name, row)\">\n                <mat-icon [ngStyle]=\"{'color':getButtonColor(button, row)}\">{{getIcon(button.name)}}</mat-icon>\n              </button>\n\n            </ng-container>\n\n            <ng-container *ngIf=\"button.name != 'create' && !testVisible(row,button.name)\">\n              <label style=\"margin-right: 35px;\"></label>\n            </ng-container>\n\n          </ng-container>\n\n\n        </td>\n      </ng-container>\n\n\n      <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n      <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\" [ngClass]=\"{'make-gray': config.greyOut && config.greyOut(row)}\"></tr>\n    </table>\n\n  </div>\n\n  <mat-paginator #tablePaginator [pageSizeOptions]=\"[10, 20, 50]\" showFirstLastButtons></mat-paginator>\n\n</div>\n\n<p *ngIf=\"dataSource?.length == 0\"><em>No Data</em></p>\n\n\n"]}
552
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-internal.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/table-internal/table-internal.component.ts","../../../../../../projects/tin-spa/src/lib/components/table-internal/table-internal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { MatTableDataSource } from '@angular/material/table';\r\nimport { DatePipe, CurrencyPipe } from '@angular/common';\r\nimport { Action, Button, Color, Column, DetailsDialogConfig, FormConfig, Icon, TableConfig } from '../../classes/Classes';\r\nimport { MatPaginator } from '@angular/material/paginator';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { DetailsDialogInternal } from './detailsDialog-internal.component';\r\nimport { BreakpointObserver, BreakpointState } from '@angular/cdk/layout';\r\nimport { DataServiceLib } from '../../services/data.service';\r\nimport { ApiResponse } from '../../classes/TinCore';\r\nimport { Subject } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'spa-table-internal',\r\n  templateUrl: './table-internal.component.html',\r\n  styleUrls: ['./table-internal.component.css']\r\n})\r\nexport class TableInternalComponent implements OnInit {\r\n\r\n  constructor(private dataService: DataServiceLib, private messageService: MessageService, private breakpointObserver: BreakpointObserver, public dialog: MatDialog)\r\n  {\r\n    // detect screen size changes\r\n    this.breakpointObserver.observe([ \"(max-width: 600px)\"]).subscribe((result: BreakpointState) => {\r\n\r\n      if (result.matches) {\r\n        this.smallScreen = true\r\n        this.setColumns()\r\n      } else {\r\n        this.smallScreen = false\r\n        this.setColumns()\r\n      }\r\n\r\n    });\r\n  }\r\n\r\n\r\n  ngOnInit() {\r\n\r\n    if (this.config.elevation){\r\n      if (this.config.elevation == \"none\"){\r\n        this.elevation = \"\"\r\n      }\r\n      else if (this.config.elevation == \"low\") {\r\n        this.elevation = \"mat-elevation-z1\"\r\n      }\r\n      else if (this.config.elevation == \"medium\") {\r\n        this.elevation = \"mat-elevation-z5\"\r\n      }\r\n      else if (this.config.elevation == \"high\") {\r\n        this.elevation = \"mat-elevation-z9\"\r\n      }\r\n    }\r\n\r\n    this.setColumns()\r\n\r\n    this.createButton = this.getButton('create')\r\n\r\n\r\n\r\n    if (this.config.loadAction){\r\n      this.loadData(this.config.loadAction, \"\");\r\n    }\r\n\r\n    this.formDefaults();\r\n\r\n    if (this.config.searchConfig){\r\n      this.showFilterButton = false;\r\n    }\r\n\r\n    if (this.reload != null){\r\n      this.reload.subscribe(v => {\r\n\r\n        if (v == true) {\r\n          if (this.config?.loadAction) {\r\n            this.loadData(this.config?.loadAction, \"\");\r\n          }\r\n        }\r\n\r\n      });\r\n    }\r\n  }\r\n\r\n\r\n  elevation = \"mat-elevation-z5\";\r\n  actionsWidth = \"50px\";\r\n\r\n  showFilterButton = true;\r\n  tileReload : Subject<boolean> = new Subject();\r\n\r\n\r\n  ngOnChanges() {\r\n\r\n    if (!this.config.loadAction){\r\n      // console.log(\"Table data Changed\")\r\n      this.dataSource = this.data;\r\n\r\n      this.tableDataSource = new MatTableDataSource<any>(this.dataSource);\r\n      setTimeout(() => { this.tableDataSource.paginator = this.tablePaginator; }, 5)\r\n    }\r\n\r\n  }\r\n\r\n\r\n  @ViewChild('tablePaginator') tablePaginator: MatPaginator;\r\n\r\n\r\n  @Input() data: any =[];\r\n  @Input() config: TableConfig;\r\n  @Input() reload: Subject<boolean>;\r\n  @Output() dataLoad = new EventEmitter();\r\n  @Output() refreshClick = new EventEmitter();\r\n  @Output() searchClick = new EventEmitter();\r\n  @Output() createClick = new EventEmitter();\r\n  @Output() actionClick = new EventEmitter();\r\n  @Output() inputChange = new EventEmitter();\r\n\r\n  inputChanged(event) {\r\n    this.inputChange.emit({ field: event.field, value: event.value })\r\n    // console.log(\"Changed \" + JSON.stringify(event))\r\n  }\r\n\r\n  smallScreen = false\r\n\r\n  createButton: Button;\r\n\r\n\r\n  //Table\r\n  tableDataSource;\r\n  dataSource: any[];\r\n  // columns: Column[] = [];\r\n  displayedColumns = []\r\n  // @Input() optionValue = \"\";\r\n  // @Input() optionDisplay = \"\";\r\n  displayedButtons = []\r\n\r\n  formDefaults() {\r\n\r\n    if (!this.config.formConfig) {\r\n      let config = new FormConfig\r\n\r\n      config.fields = []\r\n\r\n      this.config.columns.forEach(column => {\r\n\r\n        let field = { name: column.name, type: column.type }\r\n        config.fields.push(field)\r\n\r\n      });\r\n\r\n      this.config.formConfig = config;\r\n    }\r\n  }\r\n\r\n  setColumns() {\r\n\r\n    //columns\r\n    if (!this.config?.columns) {\r\n      return\r\n    }\r\n\r\n    if (this.smallScreen) {\r\n\r\n      let cols = [];\r\n\r\n      if (this.config.minColumns){\r\n        cols = this.config.minColumns.filter(col =>\r\n          this.config.columns.some(x => x.name === col)\r\n        )\r\n      }\r\n\r\n\r\n      if (cols.length > 0){\r\n        this.displayedColumns = cols;\r\n      }else{\r\n        this.displayedColumns = this.config.columns.map(({ name }) => name)\r\n      }\r\n\r\n    } else {\r\n      this.displayedColumns = this.config.columns.map(({ name }) => name)\r\n    }\r\n\r\n\r\n    //buttons\r\n    if (!this.config?.buttons) {\r\n      return\r\n    }\r\n\r\n    let buttonsCount = this.config.buttons.filter(x => x.name != 'create').length ?? 0\r\n    if (buttonsCount > 0) {\r\n\r\n      if (!this.displayedColumns.find(x => x == 'action') && this.config.buttons) {\r\n        this.displayedColumns.push(\"action\")\r\n      }\r\n\r\n\r\n\r\n      if (this.smallScreen) {\r\n\r\n        if (this.config.minButtons){\r\n          this.displayedButtons = this.config.buttons.filter(x => this.config.minButtons.includes(x.name))\r\n        }else{\r\n          this.displayedButtons = this.config.buttons.filter(x => x.name != 'create').slice(0, 1);\r\n        }\r\n      } else {\r\n        this.displayedButtons = this.config.buttons.filter(x => x.name != 'create');\r\n      }\r\n\r\n      this.actionsWidth = `${this.displayedButtons.length * 40 +20}px`\r\n\r\n\r\n    }\r\n\r\n  }\r\n\r\n  setButtons(){\r\n\r\n    if (!this.config.buttons) return\r\n\r\n    if (!this.smallScreen){\r\n      this.displayedButtons = this.config.buttons;\r\n\r\n    }else{\r\n      this.displayedButtons = this.config.buttons;\r\n\r\n    }\r\n\r\n  }\r\n\r\n\r\n  getButton(name: string) {\r\n    if (!this.config.buttons) {\r\n      console.log(\"No buttons found\")\r\n      return null\r\n    }\r\n    return this.config.buttons.find(x => x.name == name)\r\n  }\r\n\r\n  getIcon(buttonName: string){\r\n\r\n    let b = this.getButton(buttonName);\r\n    if (b.icon){\r\n      return b.icon.name\r\n    }\r\n\r\n    let i = 'open_in_new'\r\n\r\n    switch (buttonName) {\r\n\r\n      case 'view':\r\n\r\n        i = this.config.flatButtons ? 'open_in_new' : 'pageview';\r\n\r\n        break;\r\n      case 'edit':\r\n        i = 'edit'\r\n        break;\r\n      case 'delete':\r\n        i = 'delete'\r\n        break;\r\n\r\n      default:\r\n        break;\r\n    }\r\n\r\n    return i;\r\n  }\r\n\r\n  getButtonColor(button: Button, row) {\r\n\r\n    if (button.disabled){\r\n      if (button.disabled(row)){\r\n        return 'lightgray'\r\n      }\r\n    }\r\n\r\n    if (button.color){\r\n      return button.color;\r\n    }\r\n\r\n    if (button.name == 'delete'){\r\n      return '#F44336'\r\n    }\r\n\r\n    return' #4050B5'\r\n  }\r\n\r\n\r\n  getOptions(column){\r\n    let x = this.config.columns.find(opt => opt.name === column);\r\n    return  x\r\n  }\r\n\r\n  getColor(v, options) {\r\n\r\n    let defaultColor = 'lightgrey'\r\n\r\n    if (!options) return defaultColor\r\n\r\n    let c = options.find(x => x.value == v)\r\n\r\n    if (c) {\r\n      return c.color\r\n    } else {\r\n      return defaultColor\r\n    }\r\n\r\n\r\n  }\r\n\r\n\r\n  testIconCondition(value: any, icon : Icon): boolean {\r\n\r\n    if (icon.condition) {\r\n      return icon.condition(value);\r\n\r\n    }else{\r\n      return true;\r\n    }\r\n  }\r\n\r\n  testColorCondition(value: any, color: Color): boolean {\r\n\r\n    if (!color) return false;\r\n\r\n    if (color.condition) {\r\n      return color.condition(value);\r\n\r\n    } else {\r\n      return true;\r\n    }\r\n  }\r\n\r\n  showBanner(message){\r\n\r\n    if (!message) return;\r\n    if (message == '') return;\r\n    this.messageService.info(message);\r\n  }\r\n\r\n  testDisabled(row, buttonName: string): boolean{\r\n\r\n    let button = this.getButton(buttonName)\r\n\r\n    if (button.disabled){\r\n\r\n      return button.disabled(row);\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n\r\n  testVisible(row, buttonName: string): boolean {\r\n\r\n    let button = this.getButton(buttonName)\r\n\r\n    if (button.visible) {\r\n\r\n      return button.visible(row);\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n\r\n  //Actions\r\n\r\n\r\n\r\n  loadData(action: Action, data: any) {\r\n    console.log(\"loading table data\")\r\n\r\n    if (action) {\r\n\r\n      console.log(action.url)\r\n\r\n      this.dataService.CallApi(action, data).subscribe((apiResponse: ApiResponse) => {\r\n\r\n        if (this.config.logResponse){\r\n          console.log(apiResponse)\r\n        }\r\n\r\n        this.dataSource = apiResponse.data\r\n\r\n        this.tableDataSource = new MatTableDataSource<any>(apiResponse.data);\r\n        this.tableDataSource.paginator = this.tablePaginator;\r\n\r\n        if (apiResponse.success) {\r\n          this.tableDataSource = new MatTableDataSource(apiResponse.data);\r\n          this.tableDataSource.paginator = this.tablePaginator;\r\n\r\n          this.dataLoaded(apiResponse.data);\r\n\r\n\r\n        } else {\r\n          this.messageService.toast(\"Error: \" + apiResponse.message);\r\n        }\r\n\r\n      });\r\n    }\r\n\r\n  }\r\n\r\n\r\n  //Events\r\n  searchClicked(x){\r\n    console.log(\"Search\")\r\n    this.searchClick.emit(x);\r\n\r\n    // console.log(x)\r\n\r\n    if (this.config.searchConfig.searchAction){\r\n      this.config.searchConfig.searchAction.method == 'post'\r\n      this.loadData(this.config.searchConfig.searchAction, x);\r\n    }\r\n  }\r\n\r\n  refreshClicked() {\r\n    console.log(\"Refresh\")\r\n    this.refreshClick.emit();\r\n\r\n\r\n    if (this.config.loadAction) {\r\n      this.loadData(this.config.loadAction,\"\");\r\n    }else{\r\n      this.dataLoad.emit();\r\n    }\r\n  }\r\n\r\n  dataLoaded(x) {\r\n\r\n    this.dataLoad.emit(x)\r\n\r\n    console.log(\"dataloaded\")\r\n\r\n    if (this.config.tileConfig?.loadAction) {\r\n      this.tileReload.next(true);\r\n    }\r\n  }\r\n\r\n\r\n\r\n  actionClicked(name, row) {\r\n\r\n    if (name == 'view') {\r\n      this.viewModel(row)\r\n    }\r\n    else if (name == 'edit') {\r\n      this.editModel(row);\r\n    }\r\n    else if (name == 'delete') {\r\n      this.deleteModel(row);\r\n    }else{\r\n      this.customModel(name,row);\r\n    }\r\n\r\n  }\r\n\r\n\r\n  columnClicked(column : Column, row){\r\n\r\n    if (column.detailsConfig){\r\n\r\n      column.detailsConfig.details = row;\r\n\r\n      const dialogRef = this.dialog.open(DetailsDialogInternal, {\r\n        width: \"900px\",\r\n        data: column.detailsConfig\r\n      });\r\n\r\n      dialogRef.afterClosed().subscribe((result) => {\r\n\r\n        if (result.message == \"success\") {\r\n          this.actionClickedEmit(column.name, row)\r\n          this.refreshClicked();\r\n        }\r\n\r\n      });\r\n    }\r\n    else{\r\n      this.actionClickedEmit(column.name, row)\r\n    }\r\n  }\r\n\r\n  customModel(name, row) {\r\n\r\n    let button = this.getButton(name);\r\n    if (button) {\r\n\r\n      if (!button.dialog){\r\n        this.doAction(button.name, row)\r\n        this.actionClickedEmit(name, row);\r\n      }\r\n      else{\r\n\r\n        if (button.detailsConfig) {\r\n\r\n          button.detailsConfig.details = row;\r\n\r\n          const dialogRef = this.dialog.open(DetailsDialogInternal, {\r\n            width: \"900px\",\r\n            data: button.detailsConfig\r\n          });\r\n\r\n          dialogRef.afterClosed().subscribe((result) => {\r\n\r\n            if (result.message == \"success\") {\r\n              this.actionClickedEmit(button.name, row)\r\n              this.refreshClicked();\r\n            }\r\n\r\n          });\r\n        }\r\n        else {\r\n          this.actionClickedEmit(button.name, row)\r\n        }\r\n      }\r\n\r\n    }else{\r\n      this.actionClickedEmit(name, row);\r\n    }\r\n\r\n\r\n\r\n  }\r\n\r\n\r\n  actionClickedEmit(name, row) {\r\n    console.log(\"Action clicked\")\r\n    this.actionClick.emit({name:name,data : row});\r\n  }\r\n\r\n\r\n\r\n\r\n  viewModel(row) {\r\n\r\n    console.log(\"view Clicked\")\r\n\r\n    let button = this.getButton('view');\r\n\r\n    if (!button) return;\r\n\r\n    if (!button.dialog) {\r\n      this.actionClickedEmit(button.name, row);\r\n      return;\r\n    }\r\n\r\n    if (!this.config.formConfig) {\r\n      this.messageService.toast(\"Please configure form\")\r\n      return;\r\n    }\r\n\r\n    this.config.formConfig.mode = \"view\";\r\n    let conf: DetailsDialogConfig = {\r\n      config: this.config.formConfig,\r\n      buttons: this.config.buttons,\r\n      details: row,\r\n    }\r\n\r\n    const dialogRef = this.dialog.open(DetailsDialogInternal, {\r\n      width: \"900px\",\r\n      data: conf\r\n    });\r\n\r\n    dialogRef.afterClosed().subscribe((result) => {\r\n      if (result.message) {\r\n        this.refreshClicked();\r\n      }\r\n    });\r\n\r\n\r\n\r\n  }\r\n\r\n  newModel() {\r\n\r\n    let button = this.getButton('create');\r\n    if (!button) return;\r\n\r\n    if (!button.dialog) {\r\n      this.actionClickedEmit(button.name, null);\r\n      return;\r\n    }\r\n\r\n    if (!this.config.formConfig) {\r\n      this.messageService.toast(\"Please configure form\")\r\n      return;\r\n    }\r\n\r\n    this.config.formConfig.mode = \"create\";\r\n    let conf : DetailsDialogConfig = {\r\n      config : this.config.formConfig,\r\n      buttons : this.config.buttons,\r\n    }\r\n\r\n    const dialogRef = this.dialog.open(DetailsDialogInternal, {\r\n      width: \"900px\",\r\n      data: conf,\r\n    });\r\n\r\n    dialogRef.afterClosed().subscribe((result) => {\r\n      if (result.message == \"success\") {\r\n        this.actionClickedEmit('create',result.data);\r\n        this.refreshClicked();\r\n      } else if (result.message == \"emit\") {\r\n        this.actionClickedEmit('create',result.data);\r\n      }\r\n    });\r\n  }\r\n\r\n\r\n\r\n  editModel(row) {\r\n\r\n    let button = this.getButton('edit');\r\n    if (!button) return;\r\n\r\n    if (!button.dialog) {\r\n      this.actionClickedEmit(button.name, row);\r\n      return;\r\n    }\r\n\r\n    if (!this.config.formConfig) {\r\n      this.messageService.toast(\"Please configure form\")\r\n      return;\r\n    }\r\n\r\n    this.config.formConfig.mode = \"edit\";\r\n    let conf: DetailsDialogConfig = {\r\n      config: this.config.formConfig,\r\n      buttons: this.config.buttons,\r\n      details : row,\r\n    }\r\n\r\n    const dialogRef = this.dialog.open(DetailsDialogInternal, {\r\n      width: \"900px\",\r\n      data: conf\r\n    });\r\n\r\n\r\n    dialogRef.componentInstance.inputChange.subscribe((x) => {\r\n      this.inputChanged(x)\r\n    });\r\n\r\n\r\n    dialogRef.afterClosed().subscribe((result) => {\r\n      console.log(result)\r\n      if (result.message == \"success\") {\r\n        this.actionClickedEmit('edit',result.data);\r\n        this.refreshClicked();\r\n      } else if (result.message == \"emit\") {\r\n        this.actionClickedEmit('edit',result.data);\r\n      }\r\n    });\r\n  }\r\n\r\n  deleteModel(row) {\r\n\r\n    let button = this.getButton('delete');\r\n    if (!button) return;\r\n\r\n\r\n    this.messageService.confirm(`DELETE ?`).subscribe((result) => {\r\n      if (result == \"yes\") {\r\n        this.actionClickedEmit('delete', row)\r\n        this.doAction(button.name,row);\r\n      }\r\n    });\r\n\r\n  }\r\n\r\n\r\n  doAction(buttonName: string, row) {\r\n\r\n    let b = this.getButton(buttonName)\r\n\r\n    if (!b) return;\r\n\r\n    if (!b.action) return;\r\n\r\n    if (b.confirm){\r\n      this.messageService.confirm(`${b.confirm.message}`).subscribe((result) => {\r\n        if (result == \"yes\") {\r\n          this.execAction(b,row)\r\n        }\r\n      });\r\n    }else{\r\n      this.execAction(b, row)\r\n    }\r\n\r\n  }\r\n\r\n\r\n  execAction(b: Button, row){\r\n    this.dataService.CallApi(b.action, row).subscribe((apiResponse) => {\r\n\r\n      if (apiResponse.success) {\r\n        if (b.action.successMessage) {\r\n          this.messageService.toast(b.action.successMessage);\r\n        } else {\r\n\r\n          this.messageService.toast(\"Updated\");\r\n        }\r\n\r\n        this.refreshClicked();\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse.message);\r\n      }\r\n    },\r\n      (error) => {\r\n        this.messageService.toast(\"Error: \" + error);\r\n      }\r\n    );\r\n  }\r\n\r\n\r\n}\r\n","\n<spa-search *ngIf=\"config.searchConfig\" [config]=\"config.searchConfig\" style=\"margin-bottom: 20px;\" (searchClick)=\"searchClicked($event)\"></spa-search>\n\n<div class=\"top\">\n\n  <div class=\"tin-row\" >\n    <button *ngIf=\"createButton\" id=\"btnNew\" mat-raised-button color=\"primary\" style=\"margin-right: 10px;\" (click)=\"newModel()\">{{createButton.display}}</button>\n    <!-- <spa-tiles *ngIf=\"config.tileConfig\" [reload]=\"tileReload\" [config]=\"config.tileConfig\"></spa-tiles> -->\n  </div>\n\n  <div *ngIf=\"config.tileConfig && !smallScreen\" style=\"min-width: 75%;\">\n    <spa-tiles  [reload]=\"tileReload\" [config]=\"config.tileConfig\"></spa-tiles>\n  </div>\n\n  <div *ngIf=\"config.showFilter\" class=\"d-flex justify-content-end\">\n    <spa-filter [showButton]=\"showFilterButton\" [data]=\"tableDataSource\" (refreshClick)=\"refreshClicked()\"></spa-filter>\n  </div>\n\n</div>\n\n<div *ngIf=\"config.tileConfig && smallScreen\" style=\"width: 100%;\">\n  <spa-tiles [reload]=\"tileReload\" [config]=\"config.tileConfig\"></spa-tiles>\n</div>\n\n<div *ngIf=\"config.title\" class=\"title\">\n  <label style=\"font-size: larger;\">{{config.title | camelToWords}}</label>\n</div>\n\n<div>\n\n  <p *ngIf=\"!config\"><em>Configure Table</em></p>\n  <p *ngIf=\"!dataSource\"><em>Loading...</em></p>\n\n\n\n  <div *ngIf=\"dataSource\">\n\n\n    <table mat-table [dataSource]=\"tableDataSource\"  [ngClass]=\"elevation\">\n      <ng-container *ngFor=\"let column of config.columns\" [matColumnDef]=\"column.name\">\n        <th mat-header-cell *matHeaderCellDef >{{ column.alias ?? column.name | camelToWords }}</th>\n        <td mat-cell *matCellDef=\"let row;\" class=\"right-padding\" >\n\n          <ng-container [ngSwitch]=\"column.type\">\n\n            <ng-container *ngSwitchCase=\"'checkbox'\">\n              <spa-check [value]=\"row[column.name]\" [readonly]=\"true\"></spa-check>\n              <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n              <ng-container *ngFor=\"let icon of column.icons\">\n                <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n              </ng-container>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'select'\">\n              <spa-select [options]=\"column.options\" [optionDisplay]=\"column.optionDisplay\" [optionValue]=\"column.optionValue\" [(value)]=\"row[column.name]\" width=\"90%\" ></spa-select>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'chip'\">\n              <mat-chip-list>\n                <mat-chip (click)=\"columnClicked(column, row)\" [ngStyle]=\"{'background-color': testColorCondition(row, column.color) ? column.color.name : getColor(row[column.name], column?.options)}\" style=\"font-size: 12px;\"> {{row[column.name]}} </mat-chip>\n                  <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n                  <ng-container *ngFor=\"let icon of column.icons\">\n                    <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n                  </ng-container>\n              </mat-chip-list>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'icon'\">\n              <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n              <ng-container *ngFor=\"let icon of column.icons\">\n                <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n              </ng-container>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'date'\">\n              {{row[column.name] | date : 'dd/MM/yyyy'}}\n              <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n              <ng-container *ngFor=\"let icon of column.icons\">\n                <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n              </ng-container>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'datetime'\">\n              {{row[column.name] | date : 'dd/MM/yyyy HH:mm'}}\n              <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n              <ng-container *ngFor=\"let icon of column.icons\">\n                <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n              </ng-container>\n            </ng-container>\n\n            <!-- <ng-container *ngSwitchCase=\"'spinner'\">\n                <mat-spinner [diameter]=\"20\">\n\n                </mat-spinner>\n            </ng-container> -->\n\n            <ng-container *ngSwitchCase=\"'money'\">\n\n              <label [ngStyle]=\"{'color': testColorCondition(row, column.color) ? column.color.name : ''}\">{{row[column.name] | currency:'':''}}</label>\n\n              <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n              <ng-container *ngFor=\"let icon of column.icons\">\n                <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n              </ng-container>\n            </ng-container>\n\n            <ng-container *ngSwitchCase=\"'button'\">\n\n              <button mat-button [ngStyle]=\"{'color': testColorCondition(row, column.color) ? column.color.name : ''}\" (click)=\"actionClicked(column.name, row)\">{{row[column.name]}}</button>\n\n              <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n              <ng-container *ngFor=\"let icon of column.icons\">\n                <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n              </ng-container>\n            </ng-container>\n\n            <ng-container *ngSwitchDefault>\n              <label [ngStyle]=\"{'color': testColorCondition(row, column.color) ? column.color.name : ''}\">{{row[column.name]}}</label>\n              <mat-icon class=\"col-icon\" *ngIf=\"column.icon && testIconCondition(row, column.icon)\" [matTooltip]=\"row[column.icon.tipField] ?? column.icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[column.icon.tipField])\" (click)=\"showBanner(row[column.icon.tipField])\" [ngStyle]=\"{'color':column.icon?.color}\">{{column.icon.name }}</mat-icon>\n\n              <ng-container *ngFor=\"let icon of column.icons\">\n                <mat-icon class=\"col-icon\" *ngIf=\"testIconCondition(row, icon)\" [matTooltip]=\"row[icon.tipField] ?? icon?.tip\" matTooltipPosition=\"above\" (click)=\"showBanner(row[icon.tipField])\" [ngStyle]=\"{'color':icon?.color}\">{{icon.name }}</mat-icon>\n              </ng-container>\n\n            </ng-container>\n\n          </ng-container>\n\n\n        </td>\n      </ng-container>\n\n      <ng-container matColumnDef=\"action\">\n        <th mat-header-cell *matHeaderCellDef> Action </th>\n        <td mat-cell *matCellDef=\"let row\" [ngStyle]=\"{width:false ? '50px' : actionsWidth}\">\n\n\n          <ng-container *ngFor=\"let button of displayedButtons\">\n\n            <ng-container *ngIf=\"button.name != 'create' && testVisible(row,button.name)\">\n\n              <button *ngIf=\"!config.flatButtons\" mat-mini-fab  [matTooltip]=\"button.tip ?? button.name \" matTooltipPosition=\"above\" style=\"margin-right:5px\"\n              [ngStyle]=\"{'background-color':getButtonColor(button, row)}\"\n              [disabled]=\"testDisabled(row,button.name)\"  (click)=\"actionClicked(button.name, row)\">\n                <mat-icon>{{getIcon(button.name)}}</mat-icon>\n              </button>\n\n              <button *ngIf=\"config.flatButtons\"  mat-icon-button  [matTooltip]=\"button.tip ?? button.name \" matTooltipPosition=\"above\" style=\"margin-right:5px\"\n\n              [disabled]=\"testDisabled(row,button.name)\"  (click)=\"actionClicked(button.name, row)\">\n                <mat-icon [ngStyle]=\"{'color':getButtonColor(button, row)}\">{{getIcon(button.name)}}</mat-icon>\n              </button>\n\n            </ng-container>\n\n            <ng-container *ngIf=\"button.name != 'create' && !testVisible(row,button.name)\">\n              <label style=\"margin-right: 35px;\"></label>\n            </ng-container>\n\n          </ng-container>\n\n\n        </td>\n      </ng-container>\n\n\n      <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n      <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\" [ngClass]=\"{'make-gray': config.greyOut && config.greyOut(row)}\"></tr>\n    </table>\n\n  </div>\n\n  <mat-paginator #tablePaginator [pageSizeOptions]=\"[10, 20, 50]\" showFirstLastButtons></mat-paginator>\n\n</div>\n\n<p *ngIf=\"dataSource?.length == 0\"><em>No Data</em></p>\n\n\n"]}
@@ -3528,8 +3528,9 @@ class TableInternalComponent {
3528
3528
  }
3529
3529
  //Actions
3530
3530
  loadData(action, data) {
3531
- console.log("loading");
3531
+ console.log("loading table data");
3532
3532
  if (action) {
3533
+ console.log(action.url);
3533
3534
  this.dataService.CallApi(action, data).subscribe((apiResponse) => {
3534
3535
  if (this.config.logResponse) {
3535
3536
  console.log(apiResponse);
@@ -3877,7 +3878,7 @@ class DetailsDialog {
3877
3878
  }
3878
3879
  }
3879
3880
  loadData(action) {
3880
- console.log("loading");
3881
+ console.log("loading details");
3881
3882
  if (action) {
3882
3883
  this.dataService.CallApi(action).subscribe((apiResponse) => {
3883
3884
  if (apiResponse.success) {
@@ -4362,6 +4363,13 @@ class TableComponent {
4362
4363
  columnClicked(column, row) {
4363
4364
  if (column.detailsConfig) {
4364
4365
  column.detailsConfig.details = row;
4366
+ if (column.detailsConfig.tableConfig && column.detailsConfig.tableConfig.loadAction && column.detailsConfig.tableConfig.loadCriteria && column.detailsConfig.tableConfig.loadIDField) {
4367
+ column.detailsConfig.tableConfig.loadAction.url = column.detailsConfig.tableConfig.loadAction.url.split('/')[0] + "/" + column.detailsConfig.tableConfig.loadCriteria + "/" + column.detailsConfig.details[column.detailsConfig.tableConfig.loadIDField]; // fix data to proper source
4368
+ console.log("Transformed");
4369
+ }
4370
+ else {
4371
+ console.log("NOT Transformed");
4372
+ }
4365
4373
  const dialogRef = this.dialog.open(DetailsDialog, {
4366
4374
  width: "900px",
4367
4375
  data: column.detailsConfig