nuxeo-development-framework 5.6.7 → 5.6.8

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.
@@ -257,17 +257,21 @@ export class DynamicFormSelectUsersComponent {
257
257
  ConstructedData = this.filterUsers(data, filterValue);
258
258
  // Due to not using bindValue, we need to hold the selected value as the full user object, not just the username
259
259
  if (this.writedValue) {
260
- let selected;
261
- if (this.multiple) {
262
- selected = ConstructedData.filter(user => this.writedValue.includes(user.properties.username));
263
- }
264
- else {
265
- selected = ConstructedData.filter(user => user.properties.username === this.writedValue)[0];
266
- }
267
- this.selection = selected !== null && selected !== void 0 ? selected : this.selection;
260
+ this.handleWrittedValue(ConstructedData);
268
261
  }
269
262
  return ConstructedData;
270
263
  }
264
+ handleWrittedValue(users) {
265
+ const userId = (value) => {
266
+ return (typeof (value) === 'string') ? value : value.id;
267
+ };
268
+ this.selection = (this.multiple) ? users.filter(user => this.writedValue.some(value => user.properties.username === userId(value)))
269
+ : users.filter(user => user.properties.username === userId(this.writedValue))[0];
270
+ if (this.selection) {
271
+ this.writedValue = null;
272
+ this.emitSelection(this.selection);
273
+ }
274
+ }
271
275
  insertFUllName(data) {
272
276
  return data.map((user) => {
273
277
  var _a, _b;
@@ -349,4 +353,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
349
353
  }], onSelectItems: [{
350
354
  type: Output
351
355
  }], getUsersSuggestions: [] } });
352
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form-select-users.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-select-users/dynamic-form-select-users.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-select-users/dynamic-form-select-users.component.html"],"names":[],"mappings":";AAAA,OAAO,EACL,SAAS,EACT,YAAY,EACZ,KAAK,EAGL,QAAQ,EACR,MAAM,EACN,IAAI,EAEJ,SAAS,EACT,iBAAiB,GAClB,MAAM,eAAe,CAAC;AASvB,OAAO,EAAkB,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/C,OAAO,EAEL,YAAY,EACZ,oBAAoB,EACpB,SAAS,EACT,GAAG,GACJ,MAAM,gBAAgB,CAAC;AAGxB,OAAO,KAAK,CAAC,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;;;;;;;;;;;;AACzC;;;;;;;;;;;;;;GAcG;AACH,MAAM,MAAM,GAAG,KAAK,CAAC;AAOrB,MAAM,OAAO,+BAA+B;IAuE1C,YACU,cAA4C,EAC7C,SAA2B,EAC1B,WAA+B,EACZ,OAAkB;QAHrC,mBAAc,GAAd,cAAc,CAA8B;QAC7C,cAAS,GAAT,SAAS,CAAkB;QAC1B,gBAAW,GAAX,WAAW,CAAoB;QACZ,YAAO,GAAP,OAAO,CAAW;QAvE/C,SAAI,GAAG,EAAE,CAAC;QAEV,mBAAc,GAAG,IAAI,OAAO,EAAU,CAAC;QAcvC,0BAA0B;QACjB,aAAQ,GAAG,KAAK,CAAC;QAC1B,6BAA6B;QACpB,eAAU,GAAG,KAAK,CAAC;QAC5B,+CAA+C;QACtC,kBAAa,GAAG,IAAI,CAAC;QAC9B,iCAAiC;QACxB,sBAAiB,GAAG,KAAK,CAAC;QAGnC,6CAA6C;QACpC,wBAAmB,GAAG,KAAK,CAAC;QACrC,kBAAkB;QACT,aAAQ,GAAG,KAAK,CAAC;QAC1B,gDAAgD;QACvC,WAAM,GAAa,EAAE,CAAC;QAE/B,wEAAwE;QAC/D,kBAAa,GAAG,KAAK,CAAC;QAE/B,0CAA0C;QAChC,kBAAa,GAAG,IAAI,YAAY,EAAE,CAAC;QAC7C,YAAO,GAAG,KAAK,CAAC;QAGhB,WAAM,GAAG,EAAE,CAAC;QACZ,eAAU,GAAG,IAAI,CAAC;QAClB,2CAAsC,GAAG,EAAE,CAAC;QAG5C,oBAAe,GAAQ,GAAG,EAAE,GAAG,CAAC,CAAC;QACjC,eAAU,GAAQ,GAAG,EAAE,GAAG,CAAC,CAAC;QAC5B,aAAQ,GAAG,KAAK,CAAC;QACV,cAAS,GAAQ,GAAG,EAAE;YAC3B,SAAS;QACX,CAAC,CAAC;QACF,cAAS,GAAW,CAAC,CAAC;QAqBpB,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,CAAC,OAAO,CAAC,aAAa,GAAG,IAAI,CAAC;SACnC;IACH,CAAC;IAtBD,IAAW,OAAO;QAChB,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC;IACrD,CAAC;IAED,IAAW,SAAS;QAClB,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YACjB,OAAO,KAAK,CAAC;SACd;QAED,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC;QAExC,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,IAAI,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC;IACjD,CAAC;IAYD,aAAa,CAAC,KAAK;QACjB,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,aAAa,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;SAChE;QACD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACrC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED,aAAa;QACX,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,EAAE,IAAI,CAAC,SAAS,CAAC;QACjB,IAAI,IAAI,CAAC,mBAAmB,IAAI,IAAI,CAAC,QAAQ,EAAE;YAC7C,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;SACrC;IACH,CAAC;IAEO,SAAS;QACf,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC;QAC/B,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC,CAAC;QACzD,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACrC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;IACD,WAAW,CAAC,OAAsB;;QAChC,IAAI,CAAC,OAAO,CAAC,SAAS,IAAI,CAAC,CAAA,MAAA,OAAO,CAAC,SAAS,0CAAE,WAAW,CAAA,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,IAAI,CAAC,CAAA,MAAA,OAAO,CAAC,SAAS,0CAAE,WAAW,CAAA,CAAC,EAAE;YACpH,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;YACf,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;YACjB,IAAI,CAAC,cAAc,EAAE,CAAC;SACvB;IACH,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,KAAK,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;QACxD,IAAI,CAAC,SAAS,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;QAClD,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,SAAS,EAAE,CAAC;SAClB;QACD,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,EAAE;YACzC,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;YACnB,EAAE;gBACA,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,mBAAmB,CAAC;gBACrC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,gBAAgB,CAAC,CAAC;YACrC,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,IAAI,CAAC,aAAa,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;aAChE;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,cAAc,CAAC,IAAI,GAAG,CAAC;QACrB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,cAAc,CAAC,yBAAyB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE;gBAC7E,IAAI,OAAO,GAAG,IAAI,CAAC,kBAAkB,CACnC,IAAI,CAAC,KAAK,EACV,qBAAqB,CACtB,CAAC;gBACF,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;gBACtC,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,mBAAmB,CAAC;gBACpD,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;gBAC1D,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;oBACvB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;gBAC1B,CAAC,CAAC,CAAC;gBACH,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACvB,CAAC,CAAC,CAAA;SACH;aAAM,IAAI,IAAI,CAAC,SAAS,EAAE;YACzB,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;oBACxC,IAAI,OAAO,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;oBAC1D,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;oBACtC,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,mBAAmB,CAAC;oBACpD,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;oBAC1D,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;wBACvB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;oBAC1B,CAAC,CAAC,CAAC;oBACH,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,CAAC,sBAAsB;gBAC9C,CAAC,CAAC,CAAC;aACJ;iBAAM;gBACL,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;oBAClD,IAAI,OAAO,GAAG,IAAI,CAAC,kBAAkB,CACnC,IAAI,CAAC,KAAK,EACV,qBAAqB,CACtB,CAAC;oBACF,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;oBACtC,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,mBAAmB,CAAC;oBACpD,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;oBAC1D,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;wBACvB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;oBAC1B,CAAC,CAAC,CAAC;oBACH,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;gBACvB,CAAC,CAAC,CAAC;aACJ;SACF;IACH,CAAC;IAED,WAAW,CAAC,IAAI,GAAG,CAAC;QAClB,OAAO,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC;YACrC,gBAAgB,EAAE,IAAI;YACtB,QAAQ,EAAE,GAAG;SACd,CAAC,CAAC;IACL,CAAC;IAEO,SAAS;QACf,IAAI,CAAC,cAAc;aAChB,IAAI,CACH,YAAY,CAAC,GAAG,CAAC,EACjB,oBAAoB,EAAE,EACtB,GAAG,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,CAAC,EAChC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;YACjB,IAAI,IAAI,IAAI,IAAI,CAAC,MAAM,EAAE;gBACvB,OAAO,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;aACvC;iBAAM;gBACL,OAAO,IAAI,CAAC,WAAW,EAAE,CAAC;aAC3B;QACH,CAAC,CAAC,CACH;aACA,SAAS,CACR,CAAC,IAAS,EAAE,EAAE;YACZ,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE;gBACvB,IAAI,OAAO,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;gBAC1D,IAAI,CAAC,MAAM,GAAG,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;gBACxD,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,mBAAmB,CAAC;gBACpD,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;aACtB;iBAAM;gBACL,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;gBACjB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;aACtB;QACH,CAAC,EACD,CAAC,GAAG,EAAE,EAAE;YACN,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;QACnB,CAAC,CACF,CAAC;IACN,CAAC;IAED,UAAU,CAAC,KAAK;QACd,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;YACzB,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,IAAI,CAAC,aAAa,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;aAClE;SACF;aAAM;YACL,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;YACxB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;YACtB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAA;SAC1B;IACH,CAAC;IAED,SAAS,CAAC,IAAI,EAAE,QAAQ;QACtB,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;QAC5B,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QAChC,OAAO,IAAI,CAAC,EAAE,KAAK,QAAQ,CAAC,EAAE,CAAC;IACjC,CAAC;IAED,gBAAgB,CAAC,EAAE;QACjB,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;IAC5B,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,QAAQ,CAAC,CAAc;QACrB,OAAO,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;IAC5B,CAAC;IACD,UAAU;QACR,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,SAAS,EAAE;YACpD,OAAO,KAAK,CAAC;SACd;QAED,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,EAAqB,CAAC,CAAC;QACxE,OAAO,SAAS,IAAI,SAAS,CAAC,QAAQ,CAAC;IACzC,CAAC;IACD,SAAS;QACP,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAED,eAAe;IACf,yBAAyB;IACzB,mBAAmB;IACnB,KAAK;IAEL,WAAW,CAAC,SAAS;QACnB,OAAO,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;IACpD,CAAC;IAMD,mBAAmB,CAAC,IAAI;QACtB,OAAO,IAAI,CAAC,cAAc,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;IACvD,CAAC;IAEO,kBAAkB,CAAC,IAAI,EAAE,WAAmB;QAClD,IAAI,eAAsB,CAAC;QAC3B,yDAAyD;QACzD,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;YACvB,eAAe,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;SAC7C;QACD,eAAe,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC;QACtD,gHAAgH;QAChH,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,IAAI,QAAQ,CAAC;YACb,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,QAAQ,GAAG,eAAe,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC;aAChG;iBAAM;gBACL,QAAQ,GAAG,eAAe,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,KAAK,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;aAC7F;YACD,IAAI,CAAC,SAAS,GAAG,QAAQ,aAAR,QAAQ,cAAR,QAAQ,GAAI,IAAI,CAAC,SAAS,CAAC;SAC7C;QACD,OAAO,eAAe,CAAC;IACzB,CAAC;IAEO,cAAc,CAAC,IAAI;QACzB,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;;YACvB,IAAI,CAAC,QAAQ,GAAG,GAAG,MAAA,IAAI,CAAC,UAAU,0CAAE,SAAS,IAAI,MAAA,IAAI,CAAC,UAAU,0CAAE,QAAQ,EAAE,CAAC;QAC/E,CAAC,CAAC,CAAC;IACL,CAAC;IACO,WAAW,CAAC,IAAI,EAAE,IAAY;QACpC,IAAI,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE;YACpC,MAAM,gBAAgB,GACpB,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;gBACvC,CAAC,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,eAAe,CAAC;YACxC,OAAO,CAAC,gBAAgB,CAAC;QAC3B,CAAC,CAAC,CAAC;QACH,OAAO,UAAU,CAAC;IACpB,CAAC;IAED,yBAAyB;IAEzB,CAAC;IACD,KAAK;QACH,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,EAAE,CAAC;IAC5C,CAAC;IACD,WAAW;QACT,IAAI,CAAC,cAAc,CAAC,WAAW,EAAE,CAAC;IACpC,CAAC;;6HA/TU,+BAA+B;iHAA/B,+BAA+B,+sBCvD5C,wsGAsFA;ADiPE;IAJC,SAAS,CAAC;QACT,aAAa,EAAE,IAAI;QACnB,MAAM,EAAE,CAAC,GAAG,MAAM;KACnB,CAAC;0EAGD;4FAlRU,+BAA+B;kBAN3C,SAAS;mBAAC;oBACT,QAAQ,EAAE,+BAA+B;oBACzC,WAAW,EAAE,4CAA4C;oBACzD,SAAS,EAAE,CAAC,4CAA4C,CAAC;oBACzD,aAAa,EAAE,iBAAiB,CAAC,IAAI;iBACtC;;0BA4EI,IAAI;;0BAAI,QAAQ;4CAzEa,iBAAiB;sBAAhD,SAAS;uBAAC,mBAAmB;gBAMrB,SAAS;sBAAjB,KAAK;gBAEG,SAAS;sBAAjB,KAAK;gBAEG,KAAK;sBAAb,KAAK;gBAEG,SAAS;sBAAjB,KAAK;gBAEG,SAAS;sBAAjB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBAEG,WAAW;sBAAnB,KAAK;gBAEG,QAAQ;sBAAhB,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBAEG,aAAa;sBAArB,KAAK;gBAEG,iBAAiB;sBAAzB,KAAK;gBAEG,iBAAiB;sBAAzB,KAAK;gBAEG,mBAAmB;sBAA3B,KAAK;gBAEG,QAAQ;sBAAhB,KAAK;gBAEG,MAAM;sBAAd,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBAGI,aAAa;sBAAtB,MAAM;gBAuOP,mBAAmB","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  Optional,\r\n  Output,\r\n  Self,\r\n  SimpleChanges,\r\n  ViewChild,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport {\r\n  AbstractControl,\r\n  ControlValueAccessor,\r\n  FormControl,\r\n  NgControl,\r\n} from '@angular/forms';\r\nimport { NgSelectComponent } from '@ng-select/ng-select';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { Observable, of, Subject } from 'rxjs';\r\nimport {\r\n  catchError,\r\n  debounceTime,\r\n  distinctUntilChanged,\r\n  switchMap,\r\n  tap,\r\n} from 'rxjs/operators';\r\nimport { TranslationService } from '../../../../core/services/translation/translation.service';\r\nimport { UsersInDepartmentsApiService } from './services/user-api.service';\r\nimport * as _ from 'lodash';\r\nimport { Cacheable } from 'ts-cacheable';\r\n/**\r\n * Users dropdown input integrated with users API,\r\n * that can be used inside reactive or template driven forms\r\n * @title\r\n * Users dropdown\r\n * @example\r\n * <cts-dynamic-form-select-users\r\n *     formControlName=\"controlName\"\r\n *     [bindValue]=\"bindToProperty\"\r\n *     [bindLabel]=\"'bindToLabel'\"\r\n *     [searchable]=\"true\"\r\n *     [label]=\"'PATH.TO.TRANSLATION'\"\r\n *     [deptTitle]=\"'all'\"\r\n *   ></cts-dynamic-form-select-users>\r\n */\r\nconst minute = 60000;\r\n@Component({\r\n  selector: 'cts-dynamic-form-select-users',\r\n  templateUrl: './dynamic-form-select-users.component.html',\r\n  styleUrls: ['./dynamic-form-select-users.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class DynamicFormSelectUsersComponent\r\n  implements OnChanges, OnDestroy, ControlValueAccessor {\r\n  @ViewChild('ngSelectComponent') ngSelectComponent: NgSelectComponent;\r\n  selectionstrg: string;\r\n  data = [];\r\n  allUsers: boolean;\r\n  userNameInput$ = new Subject<string>();\r\n  /** filter users by department (departmentName | all) */\r\n  @Input() deptTitle: string;\r\n  /** filter users by group name => this will replce dep title */\r\n  @Input() groupName: string;\r\n  /** Field Label */\r\n  @Input() label: string;\r\n  /** Bind value to object property */\r\n  @Input() bindValue;\r\n  /** Bind label to object property */\r\n  @Input() bindLabel;\r\n  @Input() arabicBindLabel;\r\n  /** Placeholder text */\r\n  @Input() placeholder;\r\n  /** Can select multiple */\r\n  @Input() multiple = false;\r\n  /** is dropdown searchable */\r\n  @Input() searchable = false;\r\n  /** should close dropdown on value selection */\r\n  @Input() closeOnSelect = true;\r\n  /** should hide selected items */\r\n  @Input() hideSelectedItems = false;\r\n  /** Pre Selected values */\r\n  @Input() preSelectedValues;\r\n  /** flage to use preselected values or not */\r\n  @Input() usePreSelectedValue = false;\r\n  /** is Disabled */\r\n  @Input() disabled = false;\r\n  /** List of usernames that should be exluded  */\r\n  @Input() filter: string[] = [];\r\n\r\n  /** flage to indicate if use full arabic name or not beside fullName  */\r\n  @Input() useArabicName = false;\r\n\r\n  /** event emitted when item is selected */\r\n  @Output() onSelectItems = new EventEmitter();\r\n  loading = false;\r\n  selection;\r\n  writedValue: any;\r\n  buffer = [];\r\n  bufferSize = 1000;\r\n  numberOfItemsFromEndBeforeFetchingMore = 10;\r\n  suffix;\r\n\r\n  propagateChange: any = () => { };\r\n  validateFn: any = () => { };\r\n  isArabic = false;\r\n  public onTouched: any = () => {\r\n    /*Empty*/\r\n  };\r\n  pageIndex: number = 0;\r\n  isNextPageAvailable: boolean;\r\n  public get invalid(): boolean {\r\n    return this.control ? this.control.invalid : false;\r\n  }\r\n\r\n  public get showError(): boolean {\r\n    if (!this.control) {\r\n      return false;\r\n    }\r\n\r\n    const { dirty, touched } = this.control;\r\n\r\n    return this.invalid ? dirty || touched : false;\r\n  }\r\n  constructor(\r\n    private userApiService: UsersInDepartmentsApiService,\r\n    public translate: TranslateService,\r\n    private translation: TranslationService,\r\n    @Self() @Optional() public control: NgControl\r\n  ) {\r\n    if (this.control) {\r\n      this.control.valueAccessor = this;\r\n    }\r\n  }\r\n\r\n  emitSelection(event) {\r\n    if (this.multiple) {\r\n      this.selectionstrg = `${this.selection.length} ${this.suffix}`;\r\n    }\r\n    this.propagateChange(this.selection);\r\n    this.onSelectItems.emit(event);\r\n  }\r\n\r\n  onScrollToEnd() {\r\n    this.fetchMore();\r\n    ++this.pageIndex;\r\n    if (this.isNextPageAvailable && this.allUsers) {\r\n      this.getDepartments(this.pageIndex);\r\n    }\r\n  }\r\n\r\n  private fetchMore() {\r\n    this.loading = true;\r\n    const len = this.buffer.length;\r\n    const more = this.data.slice(len, this.bufferSize + len);\r\n    this.buffer = this.data.concat(more);\r\n    this.loading = false;\r\n  }\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if ((changes.deptTitle && !changes.deptTitle?.firstChange) || (changes.groupName && !changes.groupName?.firstChange)) {\r\n      this.data = [];\r\n      this.buffer = [];\r\n      this.getDepartments();\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.allUsers = this.deptTitle === 'all' ? true : false;\r\n    this.selection = (this.multiple ? [] : undefined);\r\n    if (this.allUsers) {\r\n      this.loadUsers();\r\n    }\r\n    this.getDepartments();\r\n    this.translation.isArabic.subscribe((ar) => {\r\n      this.isArabic = ar;\r\n      ar\r\n        ? (this.suffix = 'مستخدم تم إختياره')\r\n        : (this.suffix = 'Users Selected');\r\n      if (this.multiple) {\r\n        this.selectionstrg = `${this.selection.length} ${this.suffix}`;\r\n      }\r\n    });\r\n  }\r\n\r\n  getDepartments(page = 0) {\r\n    this.loading = true;\r\n    if (this.groupName) {\r\n      this.userApiService.getUsersUnderCertainGroup(this.groupName).subscribe(data => {\r\n        let newData = this.constructUserArray(\r\n          data.users,\r\n          'properties.username'\r\n        );\r\n        this.data = this.data.concat(newData);\r\n        this.isNextPageAvailable = data.isNextPageAvailable;\r\n        this.buffer = (this.data || []).slice(0, this.bufferSize);\r\n        this.buffer.map((item) => {\r\n          item.isSelected = false;\r\n        });\r\n        this.loading = false;\r\n      })\r\n    } else if (this.deptTitle) {\r\n      if (this.allUsers) {\r\n        this.getAllUsers(page).subscribe((data) => {\r\n          let newData = this.constructUserArray(data.entries, 'id');\r\n          this.data = this.data.concat(newData);\r\n          this.isNextPageAvailable = data.isNextPageAvailable;\r\n          this.buffer = (this.data || []).slice(0, this.bufferSize);\r\n          this.buffer.map((item) => {\r\n            item.isSelected = false;\r\n          });\r\n          this.loading = false; // for loading spinner\r\n        });\r\n      } else {\r\n        this.getCtsUsers(this.deptTitle).subscribe((data) => {\r\n          let newData = this.constructUserArray(\r\n            data.users,\r\n            'properties.username'\r\n          );\r\n          this.data = this.data.concat(newData);\r\n          this.isNextPageAvailable = data.isNextPageAvailable;\r\n          this.buffer = (this.data || []).slice(0, this.bufferSize);\r\n          this.buffer.map((item) => {\r\n            item.isSelected = false;\r\n          });\r\n          this.loading = false;\r\n        });\r\n      }\r\n    }\r\n  }\r\n\r\n  getAllUsers(page = 0): Observable<any> {\r\n    return this.userApiService.getAllUsers({\r\n      currentPageIndex: page,\r\n      pageSize: 100,\r\n    });\r\n  }\r\n\r\n  private loadUsers() {\r\n    this.userNameInput$\r\n      .pipe(\r\n        debounceTime(200),\r\n        distinctUntilChanged(),\r\n        tap(() => (this.loading = true)),\r\n        switchMap((term) => {\r\n          if (term && term.length) {\r\n            return this.getUsersSuggestions(term);\r\n          } else {\r\n            return this.getAllUsers();\r\n          }\r\n        })\r\n      )\r\n      .subscribe(\r\n        (data: any) => {\r\n          if (data.entries.length) {\r\n            let newData = this.constructUserArray(data.entries, 'id');\r\n            this.buffer = (newData || []).slice(0, this.bufferSize);\r\n            this.isNextPageAvailable = data.isNextPageAvailable;\r\n            this.loading = false;\r\n          } else {\r\n            this.buffer = [];\r\n            this.loading = false;\r\n          }\r\n        },\r\n        (err) => {\r\n          this.loading = false;\r\n          this.buffer = [];\r\n        }\r\n      );\r\n  }\r\n\r\n  writeValue(value) {\r\n    if (value) {\r\n      this.writedValue = value;\r\n      if (this.multiple) {\r\n        this.selectionstrg = `${this.writedValue.length} ${this.suffix}`;\r\n      }\r\n    } else {\r\n      this.writedValue = null;\r\n      this.selection = null;\r\n      this.selectionstrg = null\r\n    }\r\n  }\r\n\r\n  compareFn(item, selected) {\r\n    console.log(\"item 1\", item);\r\n    console.log(\"Item 2\", selected);\r\n    return item.id === selected.id;\r\n  }\r\n\r\n  registerOnChange(fn) {\r\n    this.propagateChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any) {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  validate(c: FormControl) {\r\n    return this.validateFn(c);\r\n  }\r\n  isRequired() {\r\n    if (!this.control || !this.control.control.validator) {\r\n      return false;\r\n    }\r\n\r\n    const validator = this.control.control.validator({} as AbstractControl);\r\n    return validator && validator.required;\r\n  }\r\n  hasErrors(): boolean {\r\n    return this.showError;\r\n  }\r\n\r\n  // @Cacheable({\r\n  //   maxCacheCount: 1000,\r\n  //   maxAge: 20000,\r\n  // })\r\n\r\n  getCtsUsers(deptTitle): Observable<any> {\r\n    return this.userApiService.getCtsUsers(deptTitle);\r\n  }\r\n\r\n  @Cacheable({\r\n    maxCacheCount: 1000,\r\n    maxAge: 5 * minute,\r\n  })\r\n  getUsersSuggestions(term): Observable<any> {\r\n    return this.userApiService.getUsersSuggestions(term);\r\n  }\r\n\r\n  private constructUserArray(data, filterValue: string) {\r\n    let ConstructedData: any[];\r\n    // if not using arabic name then construct full name here\r\n    if (!this.useArabicName) {\r\n      ConstructedData = this.insertFUllName(data);\r\n    }\r\n    ConstructedData = this.filterUsers(data, filterValue);\r\n    // Due to not using bindValue, we need to hold the selected value as the full user object, not just the username\r\n    if (this.writedValue) {\r\n      let selected;\r\n      if (this.multiple) {\r\n        selected = ConstructedData.filter(user => this.writedValue.includes(user.properties.username));\r\n      } else {\r\n        selected = ConstructedData.filter(user => user.properties.username === this.writedValue)[0];\r\n      }\r\n      this.selection = selected ?? this.selection;\r\n    }\r\n    return ConstructedData;\r\n  }\r\n\r\n  private insertFUllName(data) {\r\n    return data.map((user) => {\r\n      user.fullName = `${user.properties?.firstName} ${user.properties?.lastName}`;\r\n    });\r\n  }\r\n  private filterUsers(data, path: string) {\r\n    let filterData = data.filter((user) => {\r\n      const includedInFilter =\r\n        this.filter.includes(_.get(user, path)) ||\r\n        _.get(user, path) === 'Administrator';\r\n      return !includedInFilter;\r\n    });\r\n    return filterData;\r\n  }\r\n\r\n  getUsersUnderCertainGroup() {\r\n\r\n  }\r\n  reset() {\r\n    this.ngSelectComponent.handleClearClick();\r\n  }\r\n  ngOnDestroy(): void {\r\n    this.userNameInput$.unsubscribe();\r\n  }\r\n}\r\n","<ng-container *ngIf=\"label\">\r\n\t<div>\r\n\t\t<label class=\"select-label\"\r\n\t\t\t>{{ label | translate }}<span *ngIf=\"isRequired()\" class=\"text-danger mx-1\">*</span></label\r\n\t\t>\r\n\t</div>\r\n</ng-container>\r\n<div class=\"user-select\" [ngClass]=\"{ 'multiple-wrapper': multiple }\" SetRtl>\r\n\t<ng-select\r\n\t\t#ngSelectComponent\r\n\t\t[items]=\"buffer\"\r\n\t\t[bindLabel]=\"useArabicName ? (isArabic ? arabicBindLabel : bindLabel) : bindLabel\"\r\n\t\t[placeholder]=\"multiple && selection && selection.length > 0 ? selectionstrg : placeholder\"\r\n\t\t[multiple]=\"multiple\"\r\n\t\t[searchable]=\"searchable\"\r\n\t\t[closeOnSelect]=\"closeOnSelect\"\r\n\t\t[hideSelected]=\"hideSelectedItems\"\r\n\t\t[loading]=\"loading\"\r\n\t\t(scrollToEnd)=\"onScrollToEnd()\"\r\n\t\t[disabled]=\"disabled\"\r\n\t\t[typeahead]=\"userNameInput$\"\r\n\t\t[compareWith]=\"compareFn\"\r\n\t\t[(ngModel)]=\"selection\"\r\n\t\t(change)=\"emitSelection($event)\"\r\n\t>\r\n\t\t<ng-template ng-label-tmp let-item=\"item\" let-clear=\"clear\" *ngIf=\"!loading\">\r\n\t\t\t<span style=\"display: flex; align-items: center; column-gap: 4px; font-size: 16px\">\r\n\t\t\t\t<div style=\"width: 30px; height: 30px\">\r\n\t\t\t\t\t<cts-avatar [user]=\"item\"></cts-avatar>\r\n\t\t\t\t</div>\r\n\t\t\t\t<div class=\"user-name\">\r\n\t\t\t\t\t{{\r\n\t\t\t\t\t\titem?.id === 'system'\r\n\t\t\t\t\t\t\t? ('SYSTEM_ADMIN' | translate)\r\n\t\t\t\t\t\t\t: useArabicName\r\n\t\t\t\t\t\t\t? isArabic\r\n\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t: item?.properties?.firstName + ' ' + item?.properties?.lastName\r\n\t\t\t\t\t}}\r\n\t\t\t\t</div>\r\n\t\t\t\t<div>\r\n\t\t\t\t\t<span class=\"ng-value-icon right\" (click)=\"clear(item)\" aria-hidden=\"true\">×</span>\r\n\t\t\t\t</div>\r\n\t\t\t</span>\r\n\t\t</ng-template>\r\n\r\n\t\t<ng-template ng-option-tmp let-item=\"item\" let-item$=\"item$\" let-index=\"index\">\r\n\t\t\t<span style=\"display: flex; align-items: center; column-gap: 4px; font-size: 16px\">\r\n\t\t\t\t<mat-checkbox\r\n\t\t\t\t\t*ngIf=\"multiple\"\r\n\t\t\t\t\tid=\"item-{{ index }}\"\r\n\t\t\t\t\t[ngModel]=\"item$.selected\"\r\n\t\t\t\t\t(click)=\"(false)\"\r\n\t\t\t\t></mat-checkbox>\r\n\t\t\t\t<div style=\"width: 30px; height: 30px\">\r\n\t\t\t\t\t<cts-avatar [user]=\"item\"></cts-avatar>\r\n\t\t\t\t</div>\r\n\t\t\t\t<div>\r\n\t\t\t\t\t{{\r\n\t\t\t\t\t\titem?.id === 'system'\r\n\t\t\t\t\t\t\t? ('SYSTEM_ADMIN' | translate)\r\n\t\t\t\t\t\t\t: useArabicName\r\n\t\t\t\t\t\t\t? isArabic\r\n\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t: item?.properties?.firstName + ' ' + item?.properties?.lastName\r\n\t\t\t\t\t}}\r\n\t\t\t\t</div>\r\n\r\n\t\t\t\t<div></div>\r\n\t\t\t</span>\r\n\t\t</ng-template>\r\n\t</ng-select>\r\n</div>\r\n<mat-error [attr.data-automation-id]=\"'card-textitem-error-'\" class=\"app-textitem-editable-error\" *ngIf=\"hasErrors()\">\r\n\t<ul>\r\n\t\t<li *ngIf=\"control.errors.required\">\r\n\t\t\t{{ 'VALIDATORS.REQUIRED' | translate }}\r\n\t\t</li>\r\n\t</ul>\r\n</mat-error>\r\n"]}
356
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form-select-users.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-select-users/dynamic-form-select-users.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/dynamic-form/components/dynamic-form-select-users/dynamic-form-select-users.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  Optional,\r\n  Output,\r\n  Self,\r\n  SimpleChanges,\r\n  ViewChild,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport {\r\n  AbstractControl,\r\n  ControlValueAccessor,\r\n  FormControl,\r\n  NgControl,\r\n} from '@angular/forms';\r\nimport { NgSelectComponent } from '@ng-select/ng-select';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { Observable, of, Subject } from 'rxjs';\r\nimport {\r\n  catchError,\r\n  debounceTime,\r\n  distinctUntilChanged,\r\n  switchMap,\r\n  tap,\r\n} from 'rxjs/operators';\r\nimport { TranslationService } from '../../../../core/services/translation/translation.service';\r\nimport { UsersInDepartmentsApiService } from './services/user-api.service';\r\nimport * as _ from 'lodash';\r\nimport { Cacheable } from 'ts-cacheable';\r\n/**\r\n * Users dropdown input integrated with users API,\r\n * that can be used inside reactive or template driven forms\r\n * @title\r\n * Users dropdown\r\n * @example\r\n * <cts-dynamic-form-select-users\r\n *     formControlName=\"controlName\"\r\n *     [bindValue]=\"bindToProperty\"\r\n *     [bindLabel]=\"'bindToLabel'\"\r\n *     [searchable]=\"true\"\r\n *     [label]=\"'PATH.TO.TRANSLATION'\"\r\n *     [deptTitle]=\"'all'\"\r\n *   ></cts-dynamic-form-select-users>\r\n */\r\nconst minute = 60000;\r\n@Component({\r\n  selector: 'cts-dynamic-form-select-users',\r\n  templateUrl: './dynamic-form-select-users.component.html',\r\n  styleUrls: ['./dynamic-form-select-users.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class DynamicFormSelectUsersComponent\r\n  implements OnChanges, OnDestroy, ControlValueAccessor {\r\n  @ViewChild('ngSelectComponent') ngSelectComponent: NgSelectComponent;\r\n  selectionstrg: string;\r\n  data = [];\r\n  allUsers: boolean;\r\n  userNameInput$ = new Subject<string>();\r\n  /** filter users by department (departmentName | all) */\r\n  @Input() deptTitle: string;\r\n  /** filter users by group name => this will replce dep title */\r\n  @Input() groupName: string;\r\n  /** Field Label */\r\n  @Input() label: string;\r\n  /** Bind value to object property */\r\n  @Input() bindValue;\r\n  /** Bind label to object property */\r\n  @Input() bindLabel;\r\n  @Input() arabicBindLabel;\r\n  /** Placeholder text */\r\n  @Input() placeholder;\r\n  /** Can select multiple */\r\n  @Input() multiple = false;\r\n  /** is dropdown searchable */\r\n  @Input() searchable = false;\r\n  /** should close dropdown on value selection */\r\n  @Input() closeOnSelect = true;\r\n  /** should hide selected items */\r\n  @Input() hideSelectedItems = false;\r\n  /** Pre Selected values */\r\n  @Input() preSelectedValues;\r\n  /** flage to use preselected values or not */\r\n  @Input() usePreSelectedValue = false;\r\n  /** is Disabled */\r\n  @Input() disabled = false;\r\n  /** List of usernames that should be exluded  */\r\n  @Input() filter: string[] = [];\r\n\r\n  /** flage to indicate if use full arabic name or not beside fullName  */\r\n  @Input() useArabicName = false;\r\n\r\n  /** event emitted when item is selected */\r\n  @Output() onSelectItems = new EventEmitter();\r\n  loading = false;\r\n  selection;\r\n  writedValue: any;\r\n  buffer = [];\r\n  bufferSize = 1000;\r\n  numberOfItemsFromEndBeforeFetchingMore = 10;\r\n  suffix;\r\n\r\n  propagateChange: any = () => { };\r\n  validateFn: any = () => { };\r\n  isArabic = false;\r\n  public onTouched: any = () => {\r\n    /*Empty*/\r\n  };\r\n  pageIndex: number = 0;\r\n  isNextPageAvailable: boolean;\r\n  public get invalid(): boolean {\r\n    return this.control ? this.control.invalid : false;\r\n  }\r\n\r\n  public get showError(): boolean {\r\n    if (!this.control) {\r\n      return false;\r\n    }\r\n\r\n    const { dirty, touched } = this.control;\r\n\r\n    return this.invalid ? dirty || touched : false;\r\n  }\r\n  constructor(\r\n    private userApiService: UsersInDepartmentsApiService,\r\n    public translate: TranslateService,\r\n    private translation: TranslationService,\r\n    @Self() @Optional() public control: NgControl\r\n  ) {\r\n    if (this.control) {\r\n      this.control.valueAccessor = this;\r\n    }\r\n  }\r\n\r\n  emitSelection(event) {\r\n    if (this.multiple) {\r\n      this.selectionstrg = `${this.selection.length} ${this.suffix}`;\r\n    }\r\n    this.propagateChange(this.selection);\r\n    this.onSelectItems.emit(event);\r\n  }\r\n\r\n  onScrollToEnd() {\r\n    this.fetchMore();\r\n    ++this.pageIndex;\r\n    if (this.isNextPageAvailable && this.allUsers) {\r\n      this.getDepartments(this.pageIndex);\r\n    }\r\n  }\r\n\r\n  private fetchMore() {\r\n    this.loading = true;\r\n    const len = this.buffer.length;\r\n    const more = this.data.slice(len, this.bufferSize + len);\r\n    this.buffer = this.data.concat(more);\r\n    this.loading = false;\r\n  }\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if ((changes.deptTitle && !changes.deptTitle?.firstChange) || (changes.groupName && !changes.groupName?.firstChange)) {\r\n      this.data = [];\r\n      this.buffer = [];\r\n      this.getDepartments();\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.allUsers = this.deptTitle === 'all' ? true : false;\r\n    this.selection = (this.multiple ? [] : undefined);\r\n    if (this.allUsers) {\r\n      this.loadUsers();\r\n    }\r\n    this.getDepartments();\r\n    this.translation.isArabic.subscribe((ar) => {\r\n      this.isArabic = ar;\r\n      ar\r\n        ? (this.suffix = 'مستخدم تم إختياره')\r\n        : (this.suffix = 'Users Selected');\r\n      if (this.multiple) {\r\n        this.selectionstrg = `${this.selection.length} ${this.suffix}`;\r\n      }\r\n    });\r\n  }\r\n\r\n  getDepartments(page = 0) {\r\n    this.loading = true;\r\n    if (this.groupName) {\r\n      this.userApiService.getUsersUnderCertainGroup(this.groupName).subscribe(data => {\r\n        let newData = this.constructUserArray(\r\n          data.users,\r\n          'properties.username'\r\n        );\r\n        this.data = this.data.concat(newData);\r\n        this.isNextPageAvailable = data.isNextPageAvailable;\r\n        this.buffer = (this.data || []).slice(0, this.bufferSize);\r\n        this.buffer.map((item) => {\r\n          item.isSelected = false;\r\n        });\r\n        this.loading = false;\r\n      })\r\n    } else if (this.deptTitle) {\r\n      if (this.allUsers) {\r\n        this.getAllUsers(page).subscribe((data) => {\r\n          let newData = this.constructUserArray(data.entries, 'id');\r\n          this.data = this.data.concat(newData);\r\n          this.isNextPageAvailable = data.isNextPageAvailable;\r\n          this.buffer = (this.data || []).slice(0, this.bufferSize);\r\n          this.buffer.map((item) => {\r\n            item.isSelected = false;\r\n          });\r\n          this.loading = false; // for loading spinner\r\n        });\r\n      } else {\r\n        this.getCtsUsers(this.deptTitle).subscribe((data) => {\r\n          let newData = this.constructUserArray(\r\n            data.users,\r\n            'properties.username'\r\n          );\r\n          this.data = this.data.concat(newData);\r\n          this.isNextPageAvailable = data.isNextPageAvailable;\r\n          this.buffer = (this.data || []).slice(0, this.bufferSize);\r\n          this.buffer.map((item) => {\r\n            item.isSelected = false;\r\n          });\r\n          this.loading = false;\r\n        });\r\n      }\r\n    }\r\n  }\r\n\r\n  getAllUsers(page = 0): Observable<any> {\r\n    return this.userApiService.getAllUsers({\r\n      currentPageIndex: page,\r\n      pageSize: 100,\r\n    });\r\n  }\r\n\r\n  private loadUsers() {\r\n    this.userNameInput$\r\n      .pipe(\r\n        debounceTime(200),\r\n        distinctUntilChanged(),\r\n        tap(() => (this.loading = true)),\r\n        switchMap((term) => {\r\n          if (term && term.length) {\r\n            return this.getUsersSuggestions(term);\r\n          } else {\r\n            return this.getAllUsers();\r\n          }\r\n        })\r\n      )\r\n      .subscribe(\r\n        (data: any) => {\r\n          if (data.entries.length) {\r\n            let newData = this.constructUserArray(data.entries, 'id');\r\n            this.buffer = (newData || []).slice(0, this.bufferSize);\r\n            this.isNextPageAvailable = data.isNextPageAvailable;\r\n            this.loading = false;\r\n          } else {\r\n            this.buffer = [];\r\n            this.loading = false;\r\n          }\r\n        },\r\n        (err) => {\r\n          this.loading = false;\r\n          this.buffer = [];\r\n        }\r\n      );\r\n  }\r\n\r\n  writeValue(value) {\r\n    if (value) {\r\n      this.writedValue = value;\r\n      if (this.multiple) {\r\n        this.selectionstrg = `${this.writedValue.length} ${this.suffix}`;\r\n      }\r\n    } else {\r\n      this.writedValue = null;\r\n      this.selection = null;\r\n      this.selectionstrg = null\r\n    }\r\n  }\r\n\r\n  compareFn(item, selected) {\r\n    console.log(\"item 1\", item);\r\n    console.log(\"Item 2\", selected);\r\n    return item.id === selected.id;\r\n  }\r\n\r\n  registerOnChange(fn) {\r\n    this.propagateChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any) {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  validate(c: FormControl) {\r\n    return this.validateFn(c);\r\n  }\r\n  isRequired() {\r\n    if (!this.control || !this.control.control.validator) {\r\n      return false;\r\n    }\r\n\r\n    const validator = this.control.control.validator({} as AbstractControl);\r\n    return validator && validator.required;\r\n  }\r\n  hasErrors(): boolean {\r\n    return this.showError;\r\n  }\r\n\r\n  // @Cacheable({\r\n  //   maxCacheCount: 1000,\r\n  //   maxAge: 20000,\r\n  // })\r\n\r\n  getCtsUsers(deptTitle): Observable<any> {\r\n    return this.userApiService.getCtsUsers(deptTitle);\r\n  }\r\n\r\n  @Cacheable({\r\n    maxCacheCount: 1000,\r\n    maxAge: 5 * minute,\r\n  })\r\n  getUsersSuggestions(term): Observable<any> {\r\n    return this.userApiService.getUsersSuggestions(term);\r\n  }\r\n\r\n  private constructUserArray(data, filterValue: string) {\r\n    let ConstructedData: any[];\r\n    // if not using arabic name then construct full name here\r\n    if (!this.useArabicName) {\r\n      ConstructedData = this.insertFUllName(data);\r\n    }\r\n    ConstructedData = this.filterUsers(data, filterValue);\r\n    // Due to not using bindValue, we need to hold the selected value as the full user object, not just the username\r\n    if (this.writedValue) {\r\n      this.handleWrittedValue(ConstructedData);\r\n    }\r\n    return ConstructedData;\r\n  }\r\n\r\n  handleWrittedValue(users: Record<string, any>[]) {\r\n    const userId = (value) => {\r\n      return (typeof (value) === 'string') ? value : value.id;\r\n    }\r\n    this.selection = (this.multiple) ? users.filter(user => this.writedValue.some(value => user.properties.username === userId(value)))\r\n      : users.filter(user => user.properties.username === userId(this.writedValue))[0];\r\n    if (this.selection) {\r\n      this.writedValue = null;\r\n      this.emitSelection(this.selection);\r\n    }\r\n  }\r\n  private insertFUllName(data) {\r\n    return data.map((user) => {\r\n      user.fullName = `${user.properties?.firstName} ${user.properties?.lastName}`;\r\n    });\r\n  }\r\n  private filterUsers(data, path: string) {\r\n    let filterData = data.filter((user) => {\r\n      const includedInFilter =\r\n        this.filter.includes(_.get(user, path)) ||\r\n        _.get(user, path) === 'Administrator';\r\n      return !includedInFilter;\r\n    });\r\n    return filterData;\r\n  }\r\n\r\n  getUsersUnderCertainGroup() {\r\n\r\n  }\r\n  reset() {\r\n    this.ngSelectComponent.handleClearClick();\r\n  }\r\n  ngOnDestroy(): void {\r\n    this.userNameInput$.unsubscribe();\r\n  }\r\n}\r\n","<ng-container *ngIf=\"label\">\r\n\t<div>\r\n\t\t<label class=\"select-label\"\r\n\t\t\t>{{ label | translate }}<span *ngIf=\"isRequired()\" class=\"text-danger mx-1\">*</span></label\r\n\t\t>\r\n\t</div>\r\n</ng-container>\r\n<div class=\"user-select\" [ngClass]=\"{ 'multiple-wrapper': multiple }\" SetRtl>\r\n\t<ng-select\r\n\t\t#ngSelectComponent\r\n\t\t[items]=\"buffer\"\r\n\t\t[bindLabel]=\"useArabicName ? (isArabic ? arabicBindLabel : bindLabel) : bindLabel\"\r\n\t\t[placeholder]=\"multiple && selection && selection.length > 0 ? selectionstrg : placeholder\"\r\n\t\t[multiple]=\"multiple\"\r\n\t\t[searchable]=\"searchable\"\r\n\t\t[closeOnSelect]=\"closeOnSelect\"\r\n\t\t[hideSelected]=\"hideSelectedItems\"\r\n\t\t[loading]=\"loading\"\r\n\t\t(scrollToEnd)=\"onScrollToEnd()\"\r\n\t\t[disabled]=\"disabled\"\r\n\t\t[typeahead]=\"userNameInput$\"\r\n\t\t[compareWith]=\"compareFn\"\r\n\t\t[(ngModel)]=\"selection\"\r\n\t\t(change)=\"emitSelection($event)\"\r\n\t>\r\n\t\t<ng-template ng-label-tmp let-item=\"item\" let-clear=\"clear\" *ngIf=\"!loading\">\r\n\t\t\t<span style=\"display: flex; align-items: center; column-gap: 4px; font-size: 16px\">\r\n\t\t\t\t<div style=\"width: 30px; height: 30px\">\r\n\t\t\t\t\t<cts-avatar [user]=\"item\"></cts-avatar>\r\n\t\t\t\t</div>\r\n\t\t\t\t<div class=\"user-name\">\r\n\t\t\t\t\t{{\r\n\t\t\t\t\t\titem?.id === 'system'\r\n\t\t\t\t\t\t\t? ('SYSTEM_ADMIN' | translate)\r\n\t\t\t\t\t\t\t: useArabicName\r\n\t\t\t\t\t\t\t? isArabic\r\n\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t: item?.properties?.firstName + ' ' + item?.properties?.lastName\r\n\t\t\t\t\t}}\r\n\t\t\t\t</div>\r\n\t\t\t\t<div>\r\n\t\t\t\t\t<span class=\"ng-value-icon right\" (click)=\"clear(item)\" aria-hidden=\"true\">×</span>\r\n\t\t\t\t</div>\r\n\t\t\t</span>\r\n\t\t</ng-template>\r\n\r\n\t\t<ng-template ng-option-tmp let-item=\"item\" let-item$=\"item$\" let-index=\"index\">\r\n\t\t\t<span style=\"display: flex; align-items: center; column-gap: 4px; font-size: 16px\">\r\n\t\t\t\t<mat-checkbox\r\n\t\t\t\t\t*ngIf=\"multiple\"\r\n\t\t\t\t\tid=\"item-{{ index }}\"\r\n\t\t\t\t\t[ngModel]=\"item$.selected\"\r\n\t\t\t\t\t(click)=\"(false)\"\r\n\t\t\t\t></mat-checkbox>\r\n\t\t\t\t<div style=\"width: 30px; height: 30px\">\r\n\t\t\t\t\t<cts-avatar [user]=\"item\"></cts-avatar>\r\n\t\t\t\t</div>\r\n\t\t\t\t<div>\r\n\t\t\t\t\t{{\r\n\t\t\t\t\t\titem?.id === 'system'\r\n\t\t\t\t\t\t\t? ('SYSTEM_ADMIN' | translate)\r\n\t\t\t\t\t\t\t: useArabicName\r\n\t\t\t\t\t\t\t? isArabic\r\n\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t? item?.fullNameAr\r\n\t\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t\t: item?.fullName\r\n\t\t\t\t\t\t\t: item?.properties?.firstName + ' ' + item?.properties?.lastName\r\n\t\t\t\t\t}}\r\n\t\t\t\t</div>\r\n\r\n\t\t\t\t<div></div>\r\n\t\t\t</span>\r\n\t\t</ng-template>\r\n\t</ng-select>\r\n</div>\r\n<mat-error [attr.data-automation-id]=\"'card-textitem-error-'\" class=\"app-textitem-editable-error\" *ngIf=\"hasErrors()\">\r\n\t<ul>\r\n\t\t<li *ngIf=\"control.errors.required\">\r\n\t\t\t{{ 'VALIDATORS.REQUIRED' | translate }}\r\n\t\t</li>\r\n\t</ul>\r\n</mat-error>\r\n"]}
@@ -105,10 +105,15 @@ export class NdfConfigEditorComponent extends DestroySubject {
105
105
  const themeValue = (_a = changes.theme) === null || _a === void 0 ? void 0 : _a.currentValue;
106
106
  const optionsValue = (_b = changes.options) === null || _b === void 0 ? void 0 : _b.currentValue;
107
107
  const isThemeFirstChange = (_c = changes === null || changes === void 0 ? void 0 : changes.theme) === null || _c === void 0 ? void 0 : _c.firstChange;
108
+ const activeTheme = this._optionsSubject.getValue().theme;
108
109
  let mergedOptions = _.merge(this._defaultEditorOptions, optionsValue || {}, { language: 'json' });
109
110
  if (themeValue && isThemeFirstChange) {
110
111
  mergedOptions.theme = themeValue;
111
112
  }
113
+ if (!optionsValue && activeTheme && themeValue && activeTheme !== themeValue) {
114
+ const activeOptions = this._optionsSubject.getValue();
115
+ this._optionsSubject.next(_.merge(activeOptions, { theme: themeValue }));
116
+ }
112
117
  if (optionsValue || (themeValue && isThemeFirstChange)) {
113
118
  this._optionsSubject.next(_.cloneDeep(mergedOptions));
114
119
  }
@@ -137,4 +142,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
137
142
  }], options: [{
138
143
  type: Input
139
144
  }] } });
140
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ndf-config-editor.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/ndf-config-editor/containers/ndf-config-editor/ndf-config-editor.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/ndf-config-editor/containers/ndf-config-editor/ndf-config-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, Input, OnChanges, OnInit, SimpleChanges } from '@angular/core';\r\nimport { DataStoreService } from '../../services';\r\nimport { CONFIG_EDITOR_MODE } from '../../constants';\r\nimport {\r\n\tEditorOptions,\r\n\tEditorTheme,\r\n\tInfoDialogData,\r\n\tMonacoEditor, NdfConfigDocumentationType,\r\n\tNdfConfigMetadata,\r\n\tNdfConfigModel\r\n} from '../../models';\r\nimport { BehaviorSubject, ReplaySubject } from 'rxjs';\r\nimport _ from 'lodash';\r\nimport { AppConfigService } from '../../../../configuration/app-config.service';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { InfoDialogComponent } from '../../components';\r\nimport { Location } from '@angular/common';\r\nimport { switchMap, takeUntil } from 'rxjs/operators';\r\nimport { DestroySubject } from '../../../../shared';\r\nimport * as monaco from 'monaco-editor';\r\nimport { CustomToastrService } from '../../../custom-toastr/services/custom-toastr.service';\r\n\r\n@Component({\r\n\tselector: 'app-ndf-config-editor',\r\n\ttemplateUrl: './ndf-config-editor.component.html',\r\n\tstyleUrls: ['./ndf-config-editor.component.scss'],\r\n\tproviders: [DataStoreService]\r\n})\r\nexport class NdfConfigEditorComponent extends DestroySubject implements OnInit, OnChanges {\r\n\tisEditorHasErrors = false;\r\n\r\n\tprivate readonly _defaultEditorOptions: EditorOptions = {\r\n\t\tvalue: ``,\r\n\t\tlanguage: 'json',\r\n\t\ttheme: 'vs', //'vs' (default), 'vs-dark', 'hc-black', 'hc-light.\r\n\t\tautomaticLayout: true\r\n\t};\r\n\r\n\tprivate readonly _optionsSubject = new BehaviorSubject<EditorOptions>(this._defaultEditorOptions);\r\n\treadonly options$ = this._optionsSubject.asObservable();\r\n\r\n\tprivate readonly _themeSubject = new ReplaySubject<EditorTheme>();\r\n\treadonly theme$ = this._themeSubject.asObservable();\r\n\tprivate readonly _dataKeySubject = new ReplaySubject<string>();\r\n\r\n\t@Input() metadata: NdfConfigMetadata;\r\n\t@Input() theme: EditorTheme;\r\n\t@Input() options: EditorOptions;\r\n\r\n\tprivate _monaco: typeof monaco;\r\n\r\n\tconfig: NdfConfigModel;\r\n\r\n\tpreviewData$ = this.dataStore.previewData$;\r\n\teditorData$ = this.dataStore.editorData$;\r\n\treadonly modes = CONFIG_EDITOR_MODE;\r\n\r\n\tisFeatureEnabled = false;\r\n\r\n\tconstructor(\r\n\t\t@Inject('environment') private readonly environment: Record<string, any>,\r\n\t\tpublic readonly dataStore: DataStoreService,\r\n\t\tprivate readonly configService: AppConfigService,\r\n\t\tprivate readonly matDialog: MatDialog,\r\n\t\tprivate readonly location: Location,\r\n\t\tprivate readonly toastrService: CustomToastrService\r\n\t) {\r\n\t\tsuper();\r\n\t\tthis.config = this.configService.myConfiguration?.configEditor;\r\n\t\tthis.isFeatureEnabled = environment.configEditor === 'YES';\r\n\t}\r\n\r\n\tngOnChanges(changes: SimpleChanges): void {\r\n\t\tthis._handleMetadataChanges(changes);\r\n\t\tthis._handleOptionsAndThemeChanges(changes);\r\n\t}\r\n\r\n\tngOnInit(): void {\r\n\t\tthis._dataKeySubject\r\n\t\t\t.pipe(\r\n\t\t\t\tswitchMap((key) => this.dataStore.getData(key, this.metadata.type)),\r\n\t\t\t\ttakeUntil(this.destroy$)\r\n\t\t\t)\r\n\t\t\t.subscribe();\r\n\t}\r\n\r\n\tonDataChanged(data: string) {\r\n\t\tthis.dataStore.storeData(data);\r\n\t}\r\n\r\n\tonEditorErrors(hasErrors: boolean): void {\r\n\t\tthis.isEditorHasErrors = hasErrors;\r\n\t}\r\n\r\n\tsaveData() {\r\n\t\tthis.dataStore\r\n\t\t\t.saveData(this.metadata.key, this.metadata.type)\r\n\t\t\t.pipe(takeUntil(this.destroy$))\r\n\t\t\t.subscribe((res) => {\r\n\t\t\t\tthis.toastrService.show('success', 'TOASTER.SUCCESS', 'JSON_EDITOR.MESSAGES.dataSaved');\r\n\t\t\t});\r\n\t}\r\n\r\n\tnavigateBack() {\r\n\t\tthis.location.back();\r\n\t}\r\n\r\n\tonEditorReady(data: MonacoEditor) {\r\n\t\tthis._monaco = data.monaco;\r\n\t}\r\n\r\n\topenInfoDialog(documentations: NdfConfigDocumentationType): void {\r\n\t\tthis.matDialog.open<InfoDialogComponent, InfoDialogData>(InfoDialogComponent, {\r\n\t\t\tpanelClass: 'ndf-dialog',\r\n\t\t\twidth: 'min(1200px,90%)',\r\n\t\t\theight: '90vh',\r\n\t\t\tdata: {\r\n\t\t\t\ttitle: 'JSON_EDITOR.info',\r\n\t\t\t\ttype: this.metadata.type,\r\n\t\t\t\tdocumentations: documentations\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\tprivate _handleMetadataChanges(changes: SimpleChanges) {\r\n\t\tif (changes?.metadata?.currentValue) {\r\n\t\t\tconst metadata = changes.metadata.currentValue;\r\n\t\t\tthis._dataKeySubject.next(metadata.key);\r\n\t\t\tthis.dataStore.changeEditorType(metadata.type);\r\n\t\t}\r\n\t}\r\n\r\n\tprivate _handleOptionsAndThemeChanges(changes: SimpleChanges) {\r\n\t\tconst themeValue = changes.theme?.currentValue;\r\n\t\tconst optionsValue = changes.options?.currentValue;\r\n\t\tconst isThemeFirstChange = changes?.theme?.firstChange;\r\n\r\n\t\tlet mergedOptions = _.merge(this._defaultEditorOptions, optionsValue || {}, { language: 'json' });\r\n\r\n\t\tif (themeValue && isThemeFirstChange) {\r\n\t\t\tmergedOptions.theme = themeValue;\r\n\t\t}\r\n\r\n\t\tif (optionsValue || (themeValue && isThemeFirstChange)) {\r\n\t\t\tthis._optionsSubject.next(_.cloneDeep(mergedOptions));\r\n\t\t}\r\n\r\n\t\tif (themeValue && !isThemeFirstChange) {\r\n\t\t\tthis._themeSubject.next(themeValue);\r\n\t\t}\r\n\t}\r\n}\r\n","<ng-container *ngIf=\"config?.enabled && isFeatureEnabled; else emptyTpl\">\r\n\t<div class=\"ndf-config-editor\" ndfFluidHeight *permission=\"{ name: config?.types[metadata?.type]?.permission }\">\r\n\t\t<div class=\"ndf-config-editor__sidebar\">\r\n\t\t\t<app-editor-settings class=\"ndf-config-editor__setting\"></app-editor-settings>\r\n\t\t\t<app-config-editor-actions\r\n\t\t\t\tappItemHeight\r\n\t\t\t\tcssVar=\"--ndf-editor-actions-height\"\r\n\t\t\t\t[saveDisabled]=\"isEditorHasErrors || !(dataStore.editorData | isValidJson)\"\r\n\t\t\t\t[config]=\"config?.types[metadata?.type]\"\r\n\t\t\t\t(onInfo)=\"openInfoDialog($event)\"\r\n\t\t\t\t(onBack)=\"navigateBack()\"\r\n\t\t\t\t(onSave)=\"saveData()\"\r\n\t\t\t>\r\n\t\t\t</app-config-editor-actions>\r\n\t\t</div>\r\n\t\t<div class=\"ndf-config-editor__content\">\r\n\t\t\t<div class=\"ndf-config-editor__topbar\">\r\n\t\t\t\t<app-editor-mode-switch\r\n\t\t\t\t\t[mode]=\"dataStore.editorMode\"\r\n\t\t\t\t\t(changeMode)=\"dataStore.changeMode($event)\"\r\n\t\t\t\t></app-editor-mode-switch>\r\n\t\t\t</div>\r\n\t\t\t<app-config-preview\r\n\t\t\t\t*ngIf=\"dataStore.editorMode === modes.PREVIEW\"\r\n        [type]=\"dataStore.editorType$ | async\"\r\n\t\t\t\t[data]=\"previewData$ | async\"\r\n\t\t\t></app-config-preview>\r\n\t\t\t<ndf-monaco-editor\r\n\t\t\t\t*ngIf=\"dataStore.editorMode === modes.EDIT\"\r\n\t\t\t\t[value]=\"editorData$ | async\"\r\n\t\t\t\t[options]=\"options$ | async\"\r\n\t\t\t\t[theme]=\"theme$ | async\"\r\n\t\t\t\t(valueChange)=\"onDataChanged($event)\"\r\n\t\t\t\t(hasError)=\"onEditorErrors($event)\"\r\n\t\t\t\t(onInit)=\"onEditorReady($event)\"\r\n\t\t\t></ndf-monaco-editor>\r\n\t\t</div>\r\n\t</div>\r\n</ng-container>\r\n\r\n<ng-template #emptyTpl>\r\n\t<div class=\"ndf-empty-config\">\r\n\t\t<app-no-data-found message=\"JSON_EDITOR.MESSAGES.notAllowed\"></app-no-data-found>\r\n\t</div>\r\n</ng-template>\r\n"]}
145
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ndf-config-editor.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/ndf-config-editor/containers/ndf-config-editor/ndf-config-editor.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/ndf-config-editor/containers/ndf-config-editor/ndf-config-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, Input, OnChanges, OnInit, SimpleChanges } from '@angular/core';\r\nimport { DataStoreService } from '../../services';\r\nimport { CONFIG_EDITOR_MODE } from '../../constants';\r\nimport {\r\n\tEditorOptions,\r\n\tEditorTheme,\r\n\tInfoDialogData,\r\n\tMonacoEditor,\r\n\tNdfConfigDocumentationType,\r\n\tNdfConfigMetadata,\r\n\tNdfConfigModel\r\n} from '../../models';\r\nimport { BehaviorSubject, ReplaySubject } from 'rxjs';\r\nimport _ from 'lodash';\r\nimport { AppConfigService } from '../../../../configuration/app-config.service';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { InfoDialogComponent } from '../../components';\r\nimport { Location } from '@angular/common';\r\nimport { switchMap, takeUntil } from 'rxjs/operators';\r\nimport { DestroySubject } from '../../../../shared';\r\nimport * as monaco from 'monaco-editor';\r\nimport { CustomToastrService } from '../../../custom-toastr/services/custom-toastr.service';\r\n\r\n@Component({\r\n\tselector: 'app-ndf-config-editor',\r\n\ttemplateUrl: './ndf-config-editor.component.html',\r\n\tstyleUrls: ['./ndf-config-editor.component.scss'],\r\n\tproviders: [DataStoreService]\r\n})\r\nexport class NdfConfigEditorComponent extends DestroySubject implements OnInit, OnChanges {\r\n\tisEditorHasErrors = false;\r\n\r\n\tprivate readonly _defaultEditorOptions: EditorOptions = {\r\n\t\tvalue: ``,\r\n\t\tlanguage: 'json',\r\n\t\ttheme: 'vs', //'vs' (default), 'vs-dark', 'hc-black', 'hc-light.\r\n\t\tautomaticLayout: true\r\n\t};\r\n\r\n\tprivate readonly _optionsSubject = new BehaviorSubject<EditorOptions>(this._defaultEditorOptions);\r\n\treadonly options$ = this._optionsSubject.asObservable();\r\n\r\n\tprivate readonly _themeSubject = new ReplaySubject<EditorTheme>();\r\n\treadonly theme$ = this._themeSubject.asObservable();\r\n\tprivate readonly _dataKeySubject = new ReplaySubject<string>();\r\n\r\n\t@Input() metadata: NdfConfigMetadata;\r\n\t@Input() theme: EditorTheme;\r\n\t@Input() options: EditorOptions;\r\n\r\n\tprivate _monaco: typeof monaco;\r\n\r\n\tconfig: NdfConfigModel;\r\n\r\n\tpreviewData$ = this.dataStore.previewData$;\r\n\teditorData$ = this.dataStore.editorData$;\r\n\treadonly modes = CONFIG_EDITOR_MODE;\r\n\r\n\tisFeatureEnabled = false;\r\n\r\n\tconstructor(\r\n\t\t@Inject('environment') private readonly environment: Record<string, any>,\r\n\t\tpublic readonly dataStore: DataStoreService,\r\n\t\tprivate readonly configService: AppConfigService,\r\n\t\tprivate readonly matDialog: MatDialog,\r\n\t\tprivate readonly location: Location,\r\n\t\tprivate readonly toastrService: CustomToastrService\r\n\t) {\r\n\t\tsuper();\r\n\t\tthis.config = this.configService.myConfiguration?.configEditor;\r\n\t\tthis.isFeatureEnabled = environment.configEditor === 'YES';\r\n\t}\r\n\r\n\tngOnChanges(changes: SimpleChanges): void {\r\n\t\tthis._handleMetadataChanges(changes);\r\n\t\tthis._handleOptionsAndThemeChanges(changes);\r\n\t}\r\n\r\n\tngOnInit(): void {\r\n\t\tthis._dataKeySubject\r\n\t\t\t.pipe(\r\n\t\t\t\tswitchMap((key) => this.dataStore.getData(key, this.metadata.type)),\r\n\t\t\t\ttakeUntil(this.destroy$)\r\n\t\t\t)\r\n\t\t\t.subscribe();\r\n\t}\r\n\r\n\tonDataChanged(data: string) {\r\n\t\tthis.dataStore.storeData(data);\r\n\t}\r\n\r\n\tonEditorErrors(hasErrors: boolean): void {\r\n\t\tthis.isEditorHasErrors = hasErrors;\r\n\t}\r\n\r\n\tsaveData() {\r\n\t\tthis.dataStore\r\n\t\t\t.saveData(this.metadata.key, this.metadata.type)\r\n\t\t\t.pipe(takeUntil(this.destroy$))\r\n\t\t\t.subscribe((res) => {\r\n\t\t\t\tthis.toastrService.show('success', 'TOASTER.SUCCESS', 'JSON_EDITOR.MESSAGES.dataSaved');\r\n\t\t\t});\r\n\t}\r\n\r\n\tnavigateBack() {\r\n\t\tthis.location.back();\r\n\t}\r\n\r\n\tonEditorReady(data: MonacoEditor) {\r\n\t\tthis._monaco = data.monaco;\r\n\t}\r\n\r\n\topenInfoDialog(documentations: NdfConfigDocumentationType): void {\r\n\t\tthis.matDialog.open<InfoDialogComponent, InfoDialogData>(InfoDialogComponent, {\r\n\t\t\tpanelClass: 'ndf-dialog',\r\n\t\t\twidth: 'min(1200px,90%)',\r\n\t\t\theight: '90vh',\r\n\t\t\tdata: {\r\n\t\t\t\ttitle: 'JSON_EDITOR.info',\r\n\t\t\t\ttype: this.metadata.type,\r\n\t\t\t\tdocumentations: documentations\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\tprivate _handleMetadataChanges(changes: SimpleChanges) {\r\n\t\tif (changes?.metadata?.currentValue) {\r\n\t\t\tconst metadata = changes.metadata.currentValue;\r\n\t\t\tthis._dataKeySubject.next(metadata.key);\r\n\t\t\tthis.dataStore.changeEditorType(metadata.type);\r\n\t\t}\r\n\t}\r\n\r\n\tprivate _handleOptionsAndThemeChanges(changes: SimpleChanges) {\r\n\t\tconst themeValue = changes.theme?.currentValue;\r\n\t\tconst optionsValue = changes.options?.currentValue;\r\n\t\tconst isThemeFirstChange = changes?.theme?.firstChange;\r\n\t\tconst activeTheme = this._optionsSubject.getValue().theme;\r\n\r\n\t\tlet mergedOptions = _.merge(this._defaultEditorOptions, optionsValue || {}, { language: 'json' });\r\n\r\n\t\tif (themeValue && isThemeFirstChange) {\r\n\t\t\tmergedOptions.theme = themeValue;\r\n\t\t}\r\n\r\n\t\tif (!optionsValue && activeTheme && themeValue && activeTheme !== themeValue) {\r\n\t\t\tconst activeOptions = this._optionsSubject.getValue();\r\n\t\t\tthis._optionsSubject.next(_.merge(activeOptions, { theme: themeValue }));\r\n\t\t}\r\n\r\n\t\tif (optionsValue || (themeValue && isThemeFirstChange)) {\r\n\t\t\tthis._optionsSubject.next(_.cloneDeep(mergedOptions));\r\n\t\t}\r\n\r\n\t\tif (themeValue && !isThemeFirstChange) {\r\n\t\t\tthis._themeSubject.next(themeValue);\r\n\t\t}\r\n\t}\r\n}\r\n","<ng-container *ngIf=\"config?.enabled && isFeatureEnabled; else emptyTpl\">\r\n\t<div class=\"ndf-config-editor\" ndfFluidHeight *permission=\"{ name: config?.types[metadata?.type]?.permission }\">\r\n\t\t<div class=\"ndf-config-editor__sidebar\">\r\n\t\t\t<app-editor-settings class=\"ndf-config-editor__setting\"></app-editor-settings>\r\n\t\t\t<app-config-editor-actions\r\n\t\t\t\tappItemHeight\r\n\t\t\t\tcssVar=\"--ndf-editor-actions-height\"\r\n\t\t\t\t[saveDisabled]=\"isEditorHasErrors || !(dataStore.editorData | isValidJson)\"\r\n\t\t\t\t[config]=\"config?.types[metadata?.type]\"\r\n\t\t\t\t(onInfo)=\"openInfoDialog($event)\"\r\n\t\t\t\t(onBack)=\"navigateBack()\"\r\n\t\t\t\t(onSave)=\"saveData()\"\r\n\t\t\t>\r\n\t\t\t</app-config-editor-actions>\r\n\t\t</div>\r\n\t\t<div class=\"ndf-config-editor__content\">\r\n\t\t\t<div class=\"ndf-config-editor__topbar\">\r\n\t\t\t\t<app-editor-mode-switch\r\n\t\t\t\t\t[mode]=\"dataStore.editorMode\"\r\n\t\t\t\t\t(changeMode)=\"dataStore.changeMode($event)\"\r\n\t\t\t\t></app-editor-mode-switch>\r\n\t\t\t</div>\r\n\t\t\t<app-config-preview\r\n\t\t\t\t*ngIf=\"dataStore.editorMode === modes.PREVIEW\"\r\n        [type]=\"dataStore.editorType$ | async\"\r\n\t\t\t\t[data]=\"previewData$ | async\"\r\n\t\t\t></app-config-preview>\r\n\t\t\t<ndf-monaco-editor\r\n\t\t\t\t*ngIf=\"dataStore.editorMode === modes.EDIT\"\r\n\t\t\t\t[value]=\"editorData$ | async\"\r\n\t\t\t\t[options]=\"options$ | async\"\r\n\t\t\t\t[theme]=\"theme$ | async\"\r\n\t\t\t\t(valueChange)=\"onDataChanged($event)\"\r\n\t\t\t\t(hasError)=\"onEditorErrors($event)\"\r\n\t\t\t\t(onInit)=\"onEditorReady($event)\"\r\n\t\t\t></ndf-monaco-editor>\r\n\t\t</div>\r\n\t</div>\r\n</ng-container>\r\n\r\n<ng-template #emptyTpl>\r\n\t<div class=\"ndf-empty-config\">\r\n\t\t<app-no-data-found message=\"JSON_EDITOR.MESSAGES.notAllowed\"></app-no-data-found>\r\n\t</div>\r\n</ng-template>\r\n"]}
@@ -34,4 +34,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
34
34
  ]
35
35
  }]
36
36
  }] });
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3BlbGwtY2hlY2tlci1maWVsZC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9udXhlby1kZXZlbG9wbWVudC1mcmFtZXdvcmsvc3JjL2xpYi9jb21wb25lbnRzL3NwZWxsLWNoZWNrZXItZmllbGQvc3BlbGwtY2hlY2tlci1maWVsZC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUV0RCxPQUFPLEVBQUUsOEJBQThCLEVBQUUsTUFBTSwrREFBK0QsQ0FBQzs7QUFrQi9HLE1BQU0sT0FBTyx1QkFBdUI7O3FIQUF2Qix1QkFBdUI7c0hBQXZCLHVCQUF1QixpQkFaaEMsOEJBQThCLGFBRzlCLFlBQVk7UUFDWixXQUFXO1FBQ1gsZUFBZTtRQUNmLG1CQUFtQixhQUduQiw4QkFBOEI7c0hBR3JCLHVCQUF1QixZQVZ6QjtZQUNQLFlBQVk7WUFDWixXQUFXO1lBQ1gsZUFBZTtZQUNmLG1CQUFtQjtTQUNwQjs0RkFLVSx1QkFBdUI7a0JBZG5DLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLDhCQUE4QjtxQkFDL0I7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osV0FBVzt3QkFDWCxlQUFlO3dCQUNmLG1CQUFtQjtxQkFDcEI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLDhCQUE4QjtxQkFDL0I7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgVHJhbnNsYXRlTW9kdWxlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XHJcblxyXG5pbXBvcnQgeyBTcGVsbENoZWNrZXJUZXh0RmllbGRDb21wb25lbnQgfSBmcm9tICcuL3NwZWxsLWNoZWNrZXItdGV4dC1maWVsZC9zcGVsbC1jaGVja2VyLXRleHQtZmllbGQuY29tcG9uZW50JztcclxuXHJcblxyXG5cclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFtcclxuICAgIFNwZWxsQ2hlY2tlclRleHRGaWVsZENvbXBvbmVudFxyXG4gIF0sXHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgRm9ybXNNb2R1bGUsXHJcbiAgICBUcmFuc2xhdGVNb2R1bGUsXHJcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlXHJcbiAgXSxcclxuICBleHBvcnRzOiBbXHJcbiAgICBTcGVsbENoZWNrZXJUZXh0RmllbGRDb21wb25lbnRcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTcGVsbENoZWNrZXJGaWVsZE1vZHVsZSB7IH1cclxuIl19
37
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3BlbGwtY2hlY2tlci1maWVsZC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9udXhlby1kZXZlbG9wbWVudC1mcmFtZXdvcmsvc3JjL2xpYi9jb21wb25lbnRzL3NwZWxsLWNoZWNrZXItZmllbGQvc3BlbGwtY2hlY2tlci1maWVsZC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUV0RCxPQUFPLEVBQUUsOEJBQThCLEVBQUUsTUFBTSwrREFBK0QsQ0FBQzs7QUFrQi9HLE1BQU0sT0FBTyx1QkFBdUI7O3FIQUF2Qix1QkFBdUI7c0hBQXZCLHVCQUF1QixpQkFaaEMsOEJBQThCLGFBRzlCLFlBQVk7UUFDWixXQUFXO1FBQ1gsZUFBZTtRQUNmLG1CQUFtQixhQUduQiw4QkFBOEI7c0hBR3JCLHVCQUF1QixZQVZ6QjtZQUNQLFlBQVk7WUFDWixXQUFXO1lBQ1gsZUFBZTtZQUNmLG1CQUFtQjtTQUNwQjs0RkFLVSx1QkFBdUI7a0JBZG5DLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLDhCQUE4QjtxQkFDL0I7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osV0FBVzt3QkFDWCxlQUFlO3dCQUNmLG1CQUFtQjtxQkFDcEI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLDhCQUE4QjtxQkFDL0I7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgVHJhbnNsYXRlTW9kdWxlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XG5cbmltcG9ydCB7IFNwZWxsQ2hlY2tlclRleHRGaWVsZENvbXBvbmVudCB9IGZyb20gJy4vc3BlbGwtY2hlY2tlci10ZXh0LWZpZWxkL3NwZWxsLWNoZWNrZXItdGV4dC1maWVsZC5jb21wb25lbnQnO1xuXG5cblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgU3BlbGxDaGVja2VyVGV4dEZpZWxkQ29tcG9uZW50XG4gIF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgRm9ybXNNb2R1bGUsXG4gICAgVHJhbnNsYXRlTW9kdWxlLFxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGVcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIFNwZWxsQ2hlY2tlclRleHRGaWVsZENvbXBvbmVudFxuICBdXG59KVxuZXhwb3J0IGNsYXNzIFNwZWxsQ2hlY2tlckZpZWxkTW9kdWxlIHsgfVxuIl19
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLW9wdGlvbi5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL251eGVvLWRldmVsb3BtZW50LWZyYW1ld29yay9zcmMvbGliL3NoYXJlZC9jb21wb25lbnRzL251eGVvLWRpYWxvZy9tb2RlbHMvZGlhbG9nLW9wdGlvbi5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGVtcGxhdGVSZWYsIFR5cGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xyXG5leHBvcnQgdHlwZSBEaWFsb2dBY3Rpb25UeXBlID0gKC4uLmFyZ3M6IGFueVtdKSA9PiBPYnNlcnZhYmxlPGFueT47XHJcbmV4cG9ydCBpbnRlcmZhY2UgRGlhbG9nT3B0aW9ucyB7XHJcblx0Y29tcG9uZW50OiBUeXBlPGFueT4gfCBUZW1wbGF0ZVJlZjxhbnk+O1xyXG5cdHdpZHRoPzogc3RyaW5nO1xyXG5cdGhlaWdodD86IHN0cmluZztcclxuXHRwYW5lbENsYXNzPzogc3RyaW5nIHwgQXJyYXk8c3RyaW5nPjtcclxuXHRjb25maWc/OiB7XHJcblx0XHR0aXRsZT86IHN0cmluZztcclxuXHRcdHN1YlRpdGxlPzogc3RyaW5nO1xyXG5cdFx0Y29udGVudFRlbXBsYXRlPzogVGVtcGxhdGVSZWY8YW55PjtcclxuXHRcdGFjdGlvbnNUZW1wbGF0ZT86IFRlbXBsYXRlUmVmPGFueT47XHJcblx0fTtcclxuXHRkYXRhPzogUmVjb3JkPHN0cmluZywgYW55PjtcclxufVxyXG4iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLW9wdGlvbi5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL251eGVvLWRldmVsb3BtZW50LWZyYW1ld29yay9zcmMvbGliL3NoYXJlZC9jb21wb25lbnRzL251eGVvLWRpYWxvZy9tb2RlbHMvZGlhbG9nLW9wdGlvbi5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGVtcGxhdGVSZWYsIFR5cGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xyXG5leHBvcnQgdHlwZSBEaWFsb2dBY3Rpb25UeXBlID0gKC4uLmFyZ3M6IGFueVtdKSA9PiBPYnNlcnZhYmxlPGFueT47XHJcbmV4cG9ydCBpbnRlcmZhY2UgRGlhbG9nT3B0aW9ucyB7XHJcblx0Y29tcG9uZW50OiBUeXBlPGFueT4gfCBUZW1wbGF0ZVJlZjxhbnk+O1xyXG5cdHdpZHRoPzogc3RyaW5nO1xyXG5cdGhlaWdodD86IHN0cmluZztcclxuXHRtYXhXaWR0aD86IHN0cmluZyxcclxuXHRwYW5lbENsYXNzPzogc3RyaW5nIHwgQXJyYXk8c3RyaW5nPjtcclxuXHRjb25maWc/OiB7XHJcblx0XHR0aXRsZT86IHN0cmluZztcclxuXHRcdHN1YlRpdGxlPzogc3RyaW5nO1xyXG5cdFx0Y29udGVudFRlbXBsYXRlPzogVGVtcGxhdGVSZWY8YW55PjtcclxuXHRcdGFjdGlvbnNUZW1wbGF0ZT86IFRlbXBsYXRlUmVmPGFueT47XHJcblx0fTtcclxuXHRkYXRhPzogUmVjb3JkPHN0cmluZywgYW55PjtcclxufVxyXG4iXX0=
@@ -16,7 +16,8 @@ export class NuxeoDialogService {
16
16
  return this.dialog.open(options.component, {
17
17
  width: (options === null || options === void 0 ? void 0 : options.width) || 'auto',
18
18
  height: (options === null || options === void 0 ? void 0 : options.height) || 'auto',
19
- minWidth: '35%',
19
+ minWidth: (options === null || options === void 0 ? void 0 : options.height) || '35%',
20
+ maxWidth: (options === null || options === void 0 ? void 0 : options.maxWidth) || '80vw',
20
21
  panelClass: ['ndf-dialog', ...__classPrivateFieldGet(this, _NuxeoDialogService_instances, "m", _NuxeoDialogService_getPanelClass).call(this, options === null || options === void 0 ? void 0 : options.panelClass)],
21
22
  disableClose: true,
22
23
  data: Object.assign({ dialogConfig: {
@@ -53,4 +54,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
53
54
  providedIn: 'root'
54
55
  }]
55
56
  }], ctorParameters: function () { return [{ type: i1.MatDialog }]; } });
56
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnV4ZW8tZGlhbG9nLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9udXhlby1kZXZlbG9wbWVudC1mcmFtZXdvcmsvc3JjL2xpYi9zaGFyZWQvY29tcG9uZW50cy9udXhlby1kaWFsb2cvc2VydmljZXMvbnV4ZW8tZGlhbG9nLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBSTNDLE9BQU8sRUFFTixvQkFBb0IsRUFDcEIsTUFBTSxpQ0FBaUMsQ0FBQztBQUN6QyxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBQ2xDLE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLG1EQUFtRCxDQUFDOzs7QUFLbkcsTUFBTSxPQUFPLGtCQUFrQjtJQUM5QixZQUFvQixNQUFpQjtRQUFqQixXQUFNLEdBQU4sTUFBTSxDQUFXOztJQUFHLENBQUM7SUFFekMsSUFBSSxDQUFDLE9BQXNCOztRQUMxQixPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxTQUFTLEVBQUU7WUFDMUMsS0FBSyxFQUFFLENBQUEsT0FBTyxhQUFQLE9BQU8sdUJBQVAsT0FBTyxDQUFFLEtBQUssS0FBSSxNQUFNO1lBQy9CLE1BQU0sRUFBRSxDQUFBLE9BQU8sYUFBUCxPQUFPLHVCQUFQLE9BQU8sQ0FBRSxNQUFNLEtBQUksTUFBTTtZQUNqQyxRQUFRLEVBQUUsS0FBSztZQUNmLFVBQVUsRUFBRSxDQUFDLFlBQVksRUFBRSxHQUFHLHVCQUFBLElBQUksd0VBQWUsTUFBbkIsSUFBSSxFQUFnQixPQUFPLGFBQVAsT0FBTyx1QkFBUCxPQUFPLENBQUUsVUFBVSxDQUFDLENBQUM7WUFDdkUsWUFBWSxFQUFFLElBQUk7WUFDbEIsSUFBSSxrQkFDSCxZQUFZLEVBQUU7b0JBQ2IsS0FBSyxFQUFFLE1BQUEsT0FBTyxDQUFDLE1BQU0sMENBQUUsS0FBSztvQkFDNUIsUUFBUSxFQUFFLE1BQUEsT0FBTyxDQUFDLE1BQU0sMENBQUUsUUFBUTtvQkFDbEMsZUFBZSxFQUFFLE1BQUEsT0FBTyxDQUFDLE1BQU0sMENBQUUsZUFBZTtvQkFDaEQsZUFBZSxFQUFFLE1BQUEsT0FBTyxDQUFDLE1BQU0sMENBQUUsZUFBZTtpQkFDaEQsSUFDRSxDQUFDLE9BQU8sQ0FBQyxJQUFJLElBQUksRUFBRSxDQUFDLENBQ3ZCO1NBQ0QsQ0FBQyxDQUFDO0lBQ0osQ0FBQztJQVVELFdBQVcsQ0FBQyxNQUFnQztRQUMzQyxnREFBZ0Q7UUFDaEQsTUFBTSxhQUFhLEdBQUcsS0FBSyxDQUFDLEVBQUUsRUFBRSxvQkFBb0IsRUFBRSxNQUFNLENBQUMsQ0FBQztRQUM5RCxNQUFNLE9BQU8sR0FBa0I7WUFDOUIsU0FBUyxFQUFFLDhCQUE4QjtZQUN6QyxJQUFJLG9CQUFPLGFBQWEsQ0FBRTtZQUMxQixVQUFVLEVBQUUsK0JBQStCO1NBQzNDLENBQUM7UUFDRixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDM0IsQ0FBQzs7OEhBakJjLFVBQWtDO0lBQ2hELElBQUksT0FBTyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUM7SUFDbkIsSUFBSSxVQUFVLEVBQUU7UUFDZixPQUFPLEdBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDO0tBQ2hFO0lBQ0QsT0FBTyxPQUFPLENBQUM7QUFDaEIsQ0FBQztnSEE1Qlcsa0JBQWtCO29IQUFsQixrQkFBa0IsY0FGbEIsTUFBTTs0RkFFTixrQkFBa0I7a0JBSDlCLFVBQVU7bUJBQUM7b0JBQ1gsVUFBVSxFQUFFLE1BQU07aUJBQ2xCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBNYXREaWFsb2cgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xyXG5cclxuaW1wb3J0IHsgRGlhbG9nT3B0aW9ucyB9IGZyb20gJy4uL21vZGVscy9kaWFsb2ctb3B0aW9uLm1vZGVsJztcclxuaW1wb3J0IHtcclxuXHRDb25maXJtYXRpb25EaWFsb2dDb25maWcsXHJcblx0ZGVmYXVsdENvbmZpcm1Db25maWdcclxufSBmcm9tICcuLi9tb2RlbHMvY29uZmlybS1vcHRpb25zLm1vZGVsJztcclxuaW1wb3J0IHsgbWVyZ2UgfSBmcm9tICdsb2Rhc2gtZXMnO1xyXG5pbXBvcnQgeyBOZGZDb25maXJtYXRpb25EaWFsb2dDb21wb25lbnQgfSBmcm9tICcuLi9jb25maXJtYXRpb24vbmRmLWNvbmZpcm1hdGlvbi1kaWFsb2cuY29tcG9uZW50JztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuXHRwcm92aWRlZEluOiAncm9vdCdcclxufSlcclxuZXhwb3J0IGNsYXNzIE51eGVvRGlhbG9nU2VydmljZSB7XHJcblx0Y29uc3RydWN0b3IocHJpdmF0ZSBkaWFsb2c6IE1hdERpYWxvZykge31cclxuXHJcblx0b3BlbihvcHRpb25zOiBEaWFsb2dPcHRpb25zKSB7XHJcblx0XHRyZXR1cm4gdGhpcy5kaWFsb2cub3BlbihvcHRpb25zLmNvbXBvbmVudCwge1xyXG5cdFx0XHR3aWR0aDogb3B0aW9ucz8ud2lkdGggfHwgJ2F1dG8nLFxyXG5cdFx0XHRoZWlnaHQ6IG9wdGlvbnM/LmhlaWdodCB8fCAnYXV0bycsXHJcblx0XHRcdG1pbldpZHRoOiAnMzUlJyxcclxuXHRcdFx0cGFuZWxDbGFzczogWyduZGYtZGlhbG9nJywgLi4udGhpcy4jZ2V0UGFuZWxDbGFzcyhvcHRpb25zPy5wYW5lbENsYXNzKV0sXHJcblx0XHRcdGRpc2FibGVDbG9zZTogdHJ1ZSxcclxuXHRcdFx0ZGF0YToge1xyXG5cdFx0XHRcdGRpYWxvZ0NvbmZpZzoge1xyXG5cdFx0XHRcdFx0dGl0bGU6IG9wdGlvbnMuY29uZmlnPy50aXRsZSxcclxuXHRcdFx0XHRcdHN1YlRpdGxlOiBvcHRpb25zLmNvbmZpZz8uc3ViVGl0bGUsXHJcblx0XHRcdFx0XHRjb250ZW50VGVtcGxhdGU6IG9wdGlvbnMuY29uZmlnPy5jb250ZW50VGVtcGxhdGUsXHJcblx0XHRcdFx0XHRhY3Rpb25zVGVtcGxhdGU6IG9wdGlvbnMuY29uZmlnPy5hY3Rpb25zVGVtcGxhdGVcclxuXHRcdFx0XHR9LFxyXG5cdFx0XHRcdC4uLihvcHRpb25zLmRhdGEgfHwge30pXHJcblx0XHRcdH1cclxuXHRcdH0pO1xyXG5cdH1cclxuXHJcblx0I2dldFBhbmVsQ2xhc3MocGFuZWxDbGFzczogc3RyaW5nIHwgQXJyYXk8c3RyaW5nPik6IEFycmF5PHN0cmluZz4ge1xyXG5cdFx0bGV0IGNsYXNzZXMgPSBbJyddO1xyXG5cdFx0aWYgKHBhbmVsQ2xhc3MpIHtcclxuXHRcdFx0Y2xhc3NlcyA9IEFycmF5LmlzQXJyYXkocGFuZWxDbGFzcykgPyBwYW5lbENsYXNzIDogW3BhbmVsQ2xhc3NdO1xyXG5cdFx0fVxyXG5cdFx0cmV0dXJuIGNsYXNzZXM7XHJcblx0fVxyXG5cclxuXHRzaG93Q29uZmlybShjb25maWc6IENvbmZpcm1hdGlvbkRpYWxvZ0NvbmZpZykge1xyXG5cdFx0Ly8gTWVyZ2UgdGhlIHVzZXIgY29uZmlnIHdpdGggdGhlIGRlZmF1bHQgY29uZmlnXHJcblx0XHRjb25zdCBjb25maXJtQ29uZmlnID0gbWVyZ2Uoe30sIGRlZmF1bHRDb25maXJtQ29uZmlnLCBjb25maWcpO1xyXG5cdFx0Y29uc3Qgb3B0aW9uczogRGlhbG9nT3B0aW9ucyA9IHtcclxuXHRcdFx0Y29tcG9uZW50OiBOZGZDb25maXJtYXRpb25EaWFsb2dDb21wb25lbnQsXHJcblx0XHRcdGRhdGE6IHsgLi4uY29uZmlybUNvbmZpZyB9LFxyXG5cdFx0XHRwYW5lbENsYXNzOiAnbmRmLWNvbmZpcm1hdGlvbi1kaWFsb2ctcGFuZWwnXHJcblx0XHR9O1xyXG5cdFx0cmV0dXJuIHRoaXMub3BlbihvcHRpb25zKTtcclxuXHR9XHJcbn1cclxuIl19
57
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnV4ZW8tZGlhbG9nLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9udXhlby1kZXZlbG9wbWVudC1mcmFtZXdvcmsvc3JjL2xpYi9zaGFyZWQvY29tcG9uZW50cy9udXhlby1kaWFsb2cvc2VydmljZXMvbnV4ZW8tZGlhbG9nLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBSTNDLE9BQU8sRUFFTixvQkFBb0IsRUFDcEIsTUFBTSxpQ0FBaUMsQ0FBQztBQUN6QyxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBQ2xDLE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLG1EQUFtRCxDQUFDOzs7QUFLbkcsTUFBTSxPQUFPLGtCQUFrQjtJQUM5QixZQUFvQixNQUFpQjtRQUFqQixXQUFNLEdBQU4sTUFBTSxDQUFXOztJQUFJLENBQUM7SUFFMUMsSUFBSSxDQUFDLE9BQXNCOztRQUMxQixPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxTQUFTLEVBQUU7WUFDMUMsS0FBSyxFQUFFLENBQUEsT0FBTyxhQUFQLE9BQU8sdUJBQVAsT0FBTyxDQUFFLEtBQUssS0FBSSxNQUFNO1lBQy9CLE1BQU0sRUFBRSxDQUFBLE9BQU8sYUFBUCxPQUFPLHVCQUFQLE9BQU8sQ0FBRSxNQUFNLEtBQUksTUFBTTtZQUNqQyxRQUFRLEVBQUUsQ0FBQSxPQUFPLGFBQVAsT0FBTyx1QkFBUCxPQUFPLENBQUUsTUFBTSxLQUFJLEtBQUs7WUFDbEMsUUFBUSxFQUFFLENBQUEsT0FBTyxhQUFQLE9BQU8sdUJBQVAsT0FBTyxDQUFFLFFBQVEsS0FBSSxNQUFNO1lBQ3JDLFVBQVUsRUFBRSxDQUFDLFlBQVksRUFBRSxHQUFHLHVCQUFBLElBQUksd0VBQWUsTUFBbkIsSUFBSSxFQUFnQixPQUFPLGFBQVAsT0FBTyx1QkFBUCxPQUFPLENBQUUsVUFBVSxDQUFDLENBQUM7WUFDdkUsWUFBWSxFQUFFLElBQUk7WUFDbEIsSUFBSSxrQkFDSCxZQUFZLEVBQUU7b0JBQ2IsS0FBSyxFQUFFLE1BQUEsT0FBTyxDQUFDLE1BQU0sMENBQUUsS0FBSztvQkFDNUIsUUFBUSxFQUFFLE1BQUEsT0FBTyxDQUFDLE1BQU0sMENBQUUsUUFBUTtvQkFDbEMsZUFBZSxFQUFFLE1BQUEsT0FBTyxDQUFDLE1BQU0sMENBQUUsZUFBZTtvQkFDaEQsZUFBZSxFQUFFLE1BQUEsT0FBTyxDQUFDLE1BQU0sMENBQUUsZUFBZTtpQkFDaEQsSUFDRSxDQUFDLE9BQU8sQ0FBQyxJQUFJLElBQUksRUFBRSxDQUFDLENBQ3ZCO1NBQ0QsQ0FBQyxDQUFDO0lBQ0osQ0FBQztJQVVELFdBQVcsQ0FBQyxNQUFnQztRQUMzQyxnREFBZ0Q7UUFDaEQsTUFBTSxhQUFhLEdBQUcsS0FBSyxDQUFDLEVBQUUsRUFBRSxvQkFBb0IsRUFBRSxNQUFNLENBQUMsQ0FBQztRQUM5RCxNQUFNLE9BQU8sR0FBa0I7WUFDOUIsU0FBUyxFQUFFLDhCQUE4QjtZQUN6QyxJQUFJLG9CQUFPLGFBQWEsQ0FBRTtZQUMxQixVQUFVLEVBQUUsK0JBQStCO1NBQzNDLENBQUM7UUFDRixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDM0IsQ0FBQzs7OEhBakJjLFVBQWtDO0lBQ2hELElBQUksT0FBTyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUM7SUFDbkIsSUFBSSxVQUFVLEVBQUU7UUFDZixPQUFPLEdBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDO0tBQ2hFO0lBQ0QsT0FBTyxPQUFPLENBQUM7QUFDaEIsQ0FBQztnSEE3Qlcsa0JBQWtCO29IQUFsQixrQkFBa0IsY0FGbEIsTUFBTTs0RkFFTixrQkFBa0I7a0JBSDlCLFVBQVU7bUJBQUM7b0JBQ1gsVUFBVSxFQUFFLE1BQU07aUJBQ2xCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBNYXREaWFsb2cgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xyXG5cclxuaW1wb3J0IHsgRGlhbG9nT3B0aW9ucyB9IGZyb20gJy4uL21vZGVscy9kaWFsb2ctb3B0aW9uLm1vZGVsJztcclxuaW1wb3J0IHtcclxuXHRDb25maXJtYXRpb25EaWFsb2dDb25maWcsXHJcblx0ZGVmYXVsdENvbmZpcm1Db25maWdcclxufSBmcm9tICcuLi9tb2RlbHMvY29uZmlybS1vcHRpb25zLm1vZGVsJztcclxuaW1wb3J0IHsgbWVyZ2UgfSBmcm9tICdsb2Rhc2gtZXMnO1xyXG5pbXBvcnQgeyBOZGZDb25maXJtYXRpb25EaWFsb2dDb21wb25lbnQgfSBmcm9tICcuLi9jb25maXJtYXRpb24vbmRmLWNvbmZpcm1hdGlvbi1kaWFsb2cuY29tcG9uZW50JztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuXHRwcm92aWRlZEluOiAncm9vdCdcclxufSlcclxuZXhwb3J0IGNsYXNzIE51eGVvRGlhbG9nU2VydmljZSB7XHJcblx0Y29uc3RydWN0b3IocHJpdmF0ZSBkaWFsb2c6IE1hdERpYWxvZykgeyB9XHJcblxyXG5cdG9wZW4ob3B0aW9uczogRGlhbG9nT3B0aW9ucykge1xyXG5cdFx0cmV0dXJuIHRoaXMuZGlhbG9nLm9wZW4ob3B0aW9ucy5jb21wb25lbnQsIHtcclxuXHRcdFx0d2lkdGg6IG9wdGlvbnM/LndpZHRoIHx8ICdhdXRvJyxcclxuXHRcdFx0aGVpZ2h0OiBvcHRpb25zPy5oZWlnaHQgfHwgJ2F1dG8nLFxyXG5cdFx0XHRtaW5XaWR0aDogb3B0aW9ucz8uaGVpZ2h0IHx8ICczNSUnLFxyXG5cdFx0XHRtYXhXaWR0aDogb3B0aW9ucz8ubWF4V2lkdGggfHwgJzgwdncnLFxyXG5cdFx0XHRwYW5lbENsYXNzOiBbJ25kZi1kaWFsb2cnLCAuLi50aGlzLiNnZXRQYW5lbENsYXNzKG9wdGlvbnM/LnBhbmVsQ2xhc3MpXSxcclxuXHRcdFx0ZGlzYWJsZUNsb3NlOiB0cnVlLFxyXG5cdFx0XHRkYXRhOiB7XHJcblx0XHRcdFx0ZGlhbG9nQ29uZmlnOiB7XHJcblx0XHRcdFx0XHR0aXRsZTogb3B0aW9ucy5jb25maWc/LnRpdGxlLFxyXG5cdFx0XHRcdFx0c3ViVGl0bGU6IG9wdGlvbnMuY29uZmlnPy5zdWJUaXRsZSxcclxuXHRcdFx0XHRcdGNvbnRlbnRUZW1wbGF0ZTogb3B0aW9ucy5jb25maWc/LmNvbnRlbnRUZW1wbGF0ZSxcclxuXHRcdFx0XHRcdGFjdGlvbnNUZW1wbGF0ZTogb3B0aW9ucy5jb25maWc/LmFjdGlvbnNUZW1wbGF0ZVxyXG5cdFx0XHRcdH0sXHJcblx0XHRcdFx0Li4uKG9wdGlvbnMuZGF0YSB8fCB7fSlcclxuXHRcdFx0fVxyXG5cdFx0fSk7XHJcblx0fVxyXG5cclxuXHQjZ2V0UGFuZWxDbGFzcyhwYW5lbENsYXNzOiBzdHJpbmcgfCBBcnJheTxzdHJpbmc+KTogQXJyYXk8c3RyaW5nPiB7XHJcblx0XHRsZXQgY2xhc3NlcyA9IFsnJ107XHJcblx0XHRpZiAocGFuZWxDbGFzcykge1xyXG5cdFx0XHRjbGFzc2VzID0gQXJyYXkuaXNBcnJheShwYW5lbENsYXNzKSA/IHBhbmVsQ2xhc3MgOiBbcGFuZWxDbGFzc107XHJcblx0XHR9XHJcblx0XHRyZXR1cm4gY2xhc3NlcztcclxuXHR9XHJcblxyXG5cdHNob3dDb25maXJtKGNvbmZpZzogQ29uZmlybWF0aW9uRGlhbG9nQ29uZmlnKSB7XHJcblx0XHQvLyBNZXJnZSB0aGUgdXNlciBjb25maWcgd2l0aCB0aGUgZGVmYXVsdCBjb25maWdcclxuXHRcdGNvbnN0IGNvbmZpcm1Db25maWcgPSBtZXJnZSh7fSwgZGVmYXVsdENvbmZpcm1Db25maWcsIGNvbmZpZyk7XHJcblx0XHRjb25zdCBvcHRpb25zOiBEaWFsb2dPcHRpb25zID0ge1xyXG5cdFx0XHRjb21wb25lbnQ6IE5kZkNvbmZpcm1hdGlvbkRpYWxvZ0NvbXBvbmVudCxcclxuXHRcdFx0ZGF0YTogeyAuLi5jb25maXJtQ29uZmlnIH0sXHJcblx0XHRcdHBhbmVsQ2xhc3M6ICduZGYtY29uZmlybWF0aW9uLWRpYWxvZy1wYW5lbCdcclxuXHRcdH07XHJcblx0XHRyZXR1cm4gdGhpcy5vcGVuKG9wdGlvbnMpO1xyXG5cdH1cclxufVxyXG4iXX0=
@@ -2395,7 +2395,8 @@ class NuxeoDialogService {
2395
2395
  return this.dialog.open(options.component, {
2396
2396
  width: (options === null || options === void 0 ? void 0 : options.width) || 'auto',
2397
2397
  height: (options === null || options === void 0 ? void 0 : options.height) || 'auto',
2398
- minWidth: '35%',
2398
+ minWidth: (options === null || options === void 0 ? void 0 : options.height) || '35%',
2399
+ maxWidth: (options === null || options === void 0 ? void 0 : options.maxWidth) || '80vw',
2399
2400
  panelClass: ['ndf-dialog', ...__classPrivateFieldGet(this, _NuxeoDialogService_instances, "m", _NuxeoDialogService_getPanelClass).call(this, options === null || options === void 0 ? void 0 : options.panelClass)],
2400
2401
  disableClose: true,
2401
2402
  data: Object.assign({ dialogConfig: {
@@ -11195,17 +11196,21 @@ class DynamicFormSelectUsersComponent {
11195
11196
  ConstructedData = this.filterUsers(data, filterValue);
11196
11197
  // Due to not using bindValue, we need to hold the selected value as the full user object, not just the username
11197
11198
  if (this.writedValue) {
11198
- let selected;
11199
- if (this.multiple) {
11200
- selected = ConstructedData.filter(user => this.writedValue.includes(user.properties.username));
11201
- }
11202
- else {
11203
- selected = ConstructedData.filter(user => user.properties.username === this.writedValue)[0];
11204
- }
11205
- this.selection = selected !== null && selected !== void 0 ? selected : this.selection;
11199
+ this.handleWrittedValue(ConstructedData);
11206
11200
  }
11207
11201
  return ConstructedData;
11208
11202
  }
11203
+ handleWrittedValue(users) {
11204
+ const userId = (value) => {
11205
+ return (typeof (value) === 'string') ? value : value.id;
11206
+ };
11207
+ this.selection = (this.multiple) ? users.filter(user => this.writedValue.some(value => user.properties.username === userId(value)))
11208
+ : users.filter(user => user.properties.username === userId(this.writedValue))[0];
11209
+ if (this.selection) {
11210
+ this.writedValue = null;
11211
+ this.emitSelection(this.selection);
11212
+ }
11213
+ }
11209
11214
  insertFUllName(data) {
11210
11215
  return data.map((user) => {
11211
11216
  var _a, _b;
@@ -45245,10 +45250,15 @@ class NdfConfigEditorComponent extends DestroySubject {
45245
45250
  const themeValue = (_a = changes.theme) === null || _a === void 0 ? void 0 : _a.currentValue;
45246
45251
  const optionsValue = (_b = changes.options) === null || _b === void 0 ? void 0 : _b.currentValue;
45247
45252
  const isThemeFirstChange = (_c = changes === null || changes === void 0 ? void 0 : changes.theme) === null || _c === void 0 ? void 0 : _c.firstChange;
45253
+ const activeTheme = this._optionsSubject.getValue().theme;
45248
45254
  let mergedOptions = ___default.merge(this._defaultEditorOptions, optionsValue || {}, { language: 'json' });
45249
45255
  if (themeValue && isThemeFirstChange) {
45250
45256
  mergedOptions.theme = themeValue;
45251
45257
  }
45258
+ if (!optionsValue && activeTheme && themeValue && activeTheme !== themeValue) {
45259
+ const activeOptions = this._optionsSubject.getValue();
45260
+ this._optionsSubject.next(___default.merge(activeOptions, { theme: themeValue }));
45261
+ }
45252
45262
  if (optionsValue || (themeValue && isThemeFirstChange)) {
45253
45263
  this._optionsSubject.next(___default.cloneDeep(mergedOptions));
45254
45264
  }