@wertzui/ngx-restworld-client 1.0.2 → 2.0.0

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.
Files changed (31) hide show
  1. package/bundles/wertzui-ngx-restworld-client.umd.js +1101 -301
  2. package/bundles/wertzui-ngx-restworld-client.umd.js.map +1 -1
  3. package/esm2015/lib/models/problem-details.js +2 -2
  4. package/esm2015/lib/pipes/as.pipe.js +25 -0
  5. package/esm2015/lib/pipes/safe-url.pipe.js +23 -0
  6. package/esm2015/lib/restworld-client.module.js +68 -8
  7. package/esm2015/lib/services/avatar-generator.js +2 -2
  8. package/esm2015/lib/services/form.service.js +69 -0
  9. package/esm2015/lib/services/restworld-client-collection.js +1 -1
  10. package/esm2015/lib/services/restworld-client.js +46 -8
  11. package/esm2015/lib/views/restworld-edit-form/restworld-edit-form.component.js +238 -0
  12. package/esm2015/lib/views/restworld-edit-view/restworld-edit-view.component.js +209 -143
  13. package/esm2015/lib/views/restworld-file-view/restworld-file-view.component.js +63 -0
  14. package/esm2015/lib/views/restworld-image-view/restworld-image-view.component.js +107 -0
  15. package/esm2015/lib/views/restworld-list-view/restworld-list-view.component.js +64 -37
  16. package/esm2015/public-api.js +7 -1
  17. package/fesm2015/wertzui-ngx-restworld-client.js +880 -220
  18. package/fesm2015/wertzui-ngx-restworld-client.js.map +1 -1
  19. package/lib/models/problem-details.d.ts +4 -8
  20. package/lib/pipes/as.pipe.d.ts +18 -0
  21. package/lib/pipes/safe-url.pipe.d.ts +10 -0
  22. package/lib/restworld-client.module.d.ts +35 -21
  23. package/lib/services/form.service.d.ts +14 -0
  24. package/lib/services/restworld-client.d.ts +4 -1
  25. package/lib/views/restworld-edit-form/restworld-edit-form.component.d.ts +69 -0
  26. package/lib/views/restworld-edit-view/restworld-edit-view.component.d.ts +53 -32
  27. package/lib/views/restworld-file-view/restworld-file-view.component.d.ts +21 -0
  28. package/lib/views/restworld-image-view/restworld-image-view.component.d.ts +38 -0
  29. package/lib/views/restworld-list-view/restworld-list-view.component.d.ts +20 -8
  30. package/package.json +29 -8
  31. package/public-api.d.ts +6 -0
@@ -17,6 +17,13 @@ import * as i10 from "primeng/tooltip";
17
17
  import * as i11 from "@angular/router";
18
18
  import * as i12 from "primeng/button";
19
19
  import * as i13 from "@angular/forms";
20
+ export var ColumnType;
21
+ (function (ColumnType) {
22
+ ColumnType["text"] = "text";
23
+ ColumnType["numeric"] = "numeric";
24
+ ColumnType["boolean"] = "boolean";
25
+ ColumnType["date"] = "date";
26
+ })(ColumnType || (ColumnType = {}));
20
27
  export class RESTworldListViewComponent {
21
28
  constructor(_clients, _confirmationService, _messageService, avatarGenerator) {
22
29
  this._clients = _clients;
@@ -93,12 +100,12 @@ export class RESTworldListViewComponent {
93
100
  return;
94
101
  this.isLoading = true;
95
102
  this._lastEvent = event;
96
- const parameters = RESTworldListViewComponent.createParametersFromEvent(event);
103
+ const parameters = this.createParametersFromEvent(event);
97
104
  const response = yield this.getClient().getList(this.rel, parameters);
98
105
  if (!response.ok || ProblemDetails.isProblemDetails(response.body) || !response.body) {
99
106
  this._messageService.add({ severity: 'error', summary: 'Error', detail: 'Error while loading the resources from the API.', data: response });
100
107
  }
101
- else {
108
+ else if (response.body) {
102
109
  this.resource = response.body;
103
110
  this.totalRecords = this.resource.totalPages && parameters.$top ? this.resource.totalPages * parameters.$top : undefined;
104
111
  this._columns = this.createColumns();
@@ -125,7 +132,7 @@ export class RESTworldListViewComponent {
125
132
  }
126
133
  createColumns() {
127
134
  if (this.value.length === 0)
128
- return [];
135
+ return this.columns;
129
136
  // Get all distinct properties from all rows
130
137
  // We look at all rows to eliminate possible undefined values
131
138
  const rowsWithProperties = this.value
@@ -134,9 +141,9 @@ export class RESTworldListViewComponent {
134
141
  p[0] !== '_embedded' &&
135
142
  p[0] !== 'id' &&
136
143
  p[0] !== 'timestamp'));
137
- let distinctProperties = rowsWithProperties[0];
138
- for (let propertiesOfRow of rowsWithProperties) {
139
- for (var property of propertiesOfRow) {
144
+ const distinctProperties = rowsWithProperties[0];
145
+ for (const propertiesOfRow of rowsWithProperties) {
146
+ for (const property of propertiesOfRow) {
140
147
  const propertyName = property[0];
141
148
  const propertyValue = property[1];
142
149
  const alreadyFoundPropertyWithSameName = distinctProperties.find(p => p[0] === propertyName);
@@ -174,16 +181,16 @@ export class RESTworldListViewComponent {
174
181
  }
175
182
  static getColumnType(value) {
176
183
  if (value === null || value === undefined)
177
- return 'text';
184
+ return ColumnType.text;
178
185
  if (_.isNumber(value))
179
- return 'numeric';
186
+ return ColumnType.numeric;
180
187
  if (_.isDate(value))
181
- return 'date';
188
+ return ColumnType.date;
182
189
  if (_.isString(value))
183
- return 'text';
190
+ return ColumnType.text;
184
191
  if (_.isBoolean(value))
185
- return 'boolean';
186
- return 'text';
192
+ return ColumnType.boolean;
193
+ return ColumnType.text;
187
194
  }
188
195
  static toTitleCase(anyCase) {
189
196
  return anyCase
@@ -195,9 +202,9 @@ export class RESTworldListViewComponent {
195
202
  .replace(/([a-z]+)([A-Z0-9]+)/g, "$1 $2") // insert space after numbers
196
203
  .replace(/^./, (match) => match.toUpperCase()); // change first letter to be upper case
197
204
  }
198
- static createParametersFromEvent(event) {
205
+ createParametersFromEvent(event) {
199
206
  const oDataParameters = {
200
- $filter: RESTworldListViewComponent.createFilterFromEvent(event),
207
+ $filter: this.createFilterFromEvent(event),
201
208
  $orderby: RESTworldListViewComponent.createOrderByFromEvent(event),
202
209
  $top: RESTworldListViewComponent.createTopFromEvent(event),
203
210
  $skip: RESTworldListViewComponent.createSkipFromEvent(event)
@@ -217,22 +224,33 @@ export class RESTworldListViewComponent {
217
224
  }
218
225
  return undefined;
219
226
  }
220
- static createFilterFromEvent(event) {
227
+ createFilterFromEvent(event) {
221
228
  if (!event.filters)
222
229
  return undefined;
223
230
  const filter = Object.entries(event.filters)
224
- .map(([property, filter]) => RESTworldListViewComponent.createFilterForProperty(property, filter))
225
- .filter(filter => !!filter)
231
+ // The type definition is wrong, event.filters has values of type FilterMetadata[] and not FilterMetadata.
232
+ .map(([property, filter]) => ({ property: property, filters: filter }))
233
+ .map(f => this.createFilterForPropertyArray(f.property, f.filters))
234
+ .filter(f => !!f)
226
235
  .join(' and ');
227
236
  if (filter === '')
228
237
  return undefined;
229
238
  return `(${filter})`;
230
239
  }
231
- static createFilterForProperty(property, filter) {
240
+ createFilterForPropertyArray(property, filters) {
241
+ const filter = filters
242
+ .map(f => this.createFilterForProperty(property, f))
243
+ .filter(f => !!f)
244
+ .join(` ${filters[0].operator} `);
245
+ if (filter === '')
246
+ return undefined;
247
+ return `(${filter})`;
248
+ }
249
+ createFilterForProperty(property, filter) {
232
250
  if (!filter.value)
233
251
  return undefined;
234
252
  const oDataOperator = RESTworldListViewComponent.createODataOperator(filter.matchMode);
235
- const comparisonValue = RESTworldListViewComponent.createComparisonValue(filter.value);
253
+ const comparisonValue = this.createComparisonValue(property, filter.value);
236
254
  switch (oDataOperator) {
237
255
  case 'contains':
238
256
  case 'not contains':
@@ -275,28 +293,37 @@ export class RESTworldListViewComponent {
275
293
  return 'lt';
276
294
  case FilterMatchMode.AFTER:
277
295
  return 'gt';
296
+ case FilterMatchMode.DATE_AFTER:
297
+ return 'ge';
298
+ case FilterMatchMode.DATE_BEFORE:
299
+ return 'lt';
300
+ case FilterMatchMode.DATE_IS:
301
+ return 'eq';
302
+ case FilterMatchMode.DATE_IS_NOT:
303
+ return 'ne';
278
304
  default:
279
305
  throw Error(`Unknown matchMode ${matchMode}`);
280
306
  }
281
307
  }
282
- static createComparisonValue(value) {
308
+ createComparisonValue(property, value) {
283
309
  if (value === null || value === undefined)
284
310
  return 'null';
285
- if (_.isNumber(value))
286
- return `${value}`;
287
- if (_.isDate(value))
288
- return `cast(${value.toISOString()}, Edm.DateTimeOffset)`;
289
- if (_.isString(value)) {
290
- const date = new Date(value);
291
- if (!isNaN(date.valueOf()))
292
- return `cast(${date.toISOString()}, Edm.DateTimeOffset)`;
293
- return `'${value}'`;
311
+ const columns = this.columns.filter(c => c.field === property);
312
+ if (columns.length !== 1)
313
+ throw new Error(`Cannot find the column for the property ${property} which is specified in the filter.`);
314
+ const type = columns[0].type;
315
+ switch (type) {
316
+ case ColumnType.boolean:
317
+ return `${value}`;
318
+ case ColumnType.date:
319
+ return `cast(${value.toISOString()}, Edm.DateTimeOffset)`;
320
+ case ColumnType.numeric:
321
+ return `${value}`;
322
+ case ColumnType.text:
323
+ return `'${value}'`;
324
+ default:
325
+ throw new Error(`Unknown column type '${type}'`);
294
326
  }
295
- if (_.isArray(value))
296
- return `(${value
297
- .map((v) => this.createComparisonValue(v))
298
- .join(',')})`;
299
- throw new Error(`Unknown type of value: ${value}.`);
300
327
  }
301
328
  }
302
329
  RESTworldListViewComponent._dateFormat = new Date(3333, 10, 22)
@@ -306,11 +333,11 @@ RESTworldListViewComponent._dateFormat = new Date(3333, 10, 22)
306
333
  .replace("3333", "y")
307
334
  .replace("33", "yy");
308
335
  RESTworldListViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.11", ngImport: i0, type: RESTworldListViewComponent, deps: [{ token: i1.RESTworldClientCollection }, { token: i2.ConfirmationService }, { token: i2.MessageService }, { token: i3.AvatarGenerator }], target: i0.ɵɵFactoryTarget.Component });
309
- RESTworldListViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.11", type: RESTworldListViewComponent, selector: "restworld-list-view", inputs: { editLink: "editLink", apiName: "apiName", rel: "rel", rowsPerPage: "rowsPerPage" }, ngImport: i0, template: "<p-table [value]=\"value\"\r\n [lazy]=\"true\"\r\n [lazyLoadOnInit]=\"false\"\r\n (onLazyLoad)=\"load($event)\"\r\n responsiveLayout=\"scroll\"\r\n [paginator]=\"true\"\r\n [rows]=\"rows\"\r\n [rowsPerPageOptions]=\"rowsPerPage\"\r\n [totalRecords]=\"totalRecords\"\r\n [loading]=\"isLoading\"\r\n [showInitialSortBadge]=\"true\"\r\n [columns]=\"columns\">\r\n\r\n <ng-template pTemplate=\"header\" let-columns>\r\n <tr>\r\n <th *ngFor=\"let col of columns\" [pSortableColumn]=\"col.field\">\r\n <div class=\"p-d-flex p-jc-between p-ai-center\">\r\n {{col.header}}\r\n <p-sortIcon [field]=\"col.field\"></p-sortIcon>\r\n <p-columnFilter [type]=\"col.type\" [field]=\"col.field\" display=\"menu\"></p-columnFilter>\r\n </div>\r\n </th>\r\n <th>\r\n <div class=\"flex justify-content-end\">\r\n <div class=\"mx-2\" pTooltip=\"Create new\" tooltipPosition=\"left\">\r\n <a class=\"p-button-success\" icon=\"fas fa-plus\" pButton [routerLink]=\"['/edit', apiName, newHref]\"></a>\r\n </div>\r\n </div>\r\n </th>\r\n </tr>\r\n </ng-template>\r\n\r\n <ng-template pTemplate=\"body\" let-entity let-columns=\"columns\">\r\n <tr>\r\n <td [ngSwitch]=\"col.type\" *ngFor=\"let col of columns\">\r\n <ng-container *ngSwitchCase=\"'text'\">\r\n <p-avatar *ngIf=\"col.field === 'createdBy' || col.field === 'lastChangedBy'\" [pTooltip]=\"entity[col.field]\" tooltipPosition=\"top\" [image]=\"avatarGenerator.getImage(entity[col.field])\" [label]=\"avatarGenerator.getLabel(entity[col.field])\" [style]=\"avatarGenerator.getStyle(entity[col.field])\" shape=\"circle\"></p-avatar>\r\n <span *ngIf=\"col.field !== 'createdBy' && col.field !== 'lastChangedBy'\">{{entity[col.field]}}</span>\r\n </ng-container>\r\n <span *ngSwitchCase=\"'numeric'\" class=\"flex justify-content-end\">{{entity[col.field]}}</span>\r\n <span *ngSwitchCase=\"'boolean'\" class=\"flex justify-content-center\"><p-triStateCheckbox [(ngModel)]=\"entity[col.field]\" [readonly]=\"true\"></p-triStateCheckbox></span>\r\n <span *ngSwitchCase=\"'date'\" [pTooltip]=\"entity[col.field]\">{{entity[col.field] | date:dateFormat}}</span>\r\n </td>\r\n <td>\r\n <div class=\"flex justify-content-end\">\r\n <a pButton pTooltip=\"View/Edit\" tooltipPosition=\"left\" [routerLink]=\"[editLink, apiName, entity._links?.self[0].href]\" icon=\"fas fa-edit\"></a>\r\n <button pTooltip=\"Delete\" tooltipPosition=\"left\" pButton *ngIf=\"entity._links.delete\" (click)=\"showDeleteConfirmatioModal(entity)\" icon=\"fas fa-trash-alt\" type=\"button\" class=\"mx-2 p-button-danger\"></button>\r\n </div>\r\n </td>\r\n </tr>\r\n </ng-template>\r\n\r\n <ng-template pTemplate=\"emptymessage\">\r\n <tr>\r\n <td colspan=\"8\">No entries found.</td>\r\n </tr>\r\n </ng-template>\r\n\r\n</p-table>\r\n\r\n<p-toast></p-toast>\r\n<p-confirmDialog></p-confirmDialog>\r\n", styles: [".p-tooltip{max-width:-webkit-fit-content;max-width:-moz-fit-content;max-width:fit-content}a.p-button{text-decoration:none}\n"], components: [{ type: i4.Table, selector: "p-table", inputs: ["frozenColumns", "frozenValue", "style", "styleClass", "tableStyle", "tableStyleClass", "paginator", "pageLinks", "rowsPerPageOptions", "alwaysShowPaginator", "paginatorPosition", "paginatorDropdownAppendTo", "paginatorDropdownScrollHeight", "currentPageReportTemplate", "showCurrentPageReport", "showJumpToPageDropdown", "showJumpToPageInput", "showFirstLastIcon", "showPageLinks", "defaultSortOrder", "sortMode", "resetPageOnSort", "selectionMode", "contextMenuSelection", "contextMenuSelectionMode", "dataKey", "metaKeySelection", "rowTrackBy", "lazy", "lazyLoadOnInit", "compareSelectionBy", "csvSeparator", "exportFilename", "filters", "globalFilterFields", "filterDelay", "filterLocale", "expandedRowKeys", "editingRowKeys", "rowExpandMode", "scrollable", "scrollDirection", "rowGroupMode", "scrollHeight", "virtualScroll", "virtualScrollDelay", "virtualRowHeight", "frozenWidth", "responsive", "contextMenu", "resizableColumns", "columnResizeMode", "reorderableColumns", "loading", "loadingIcon", "showLoader", "rowHover", "customSort", "showInitialSortBadge", "autoLayout", "exportFunction", "stateKey", "stateStorage", "editMode", "groupRowsBy", "groupRowsByOrder", "minBufferPx", "maxBufferPx", "responsiveLayout", "breakpoint", "value", "columns", "first", "rows", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection"], outputs: ["selectionChange", "contextMenuSelectionChange", "onRowSelect", "onRowUnselect", "onPage", "onSort", "onFilter", "onLazyLoad", "onRowExpand", "onRowCollapse", "onContextMenuSelect", "onColResize", "onColReorder", "onRowReorder", "onEditInit", "onEditComplete", "onEditCancel", "onHeaderCheckboxToggle", "sortFunction", "firstChange", "rowsChange", "onStateSave", "onStateRestore"] }, { type: i4.SortIcon, selector: "p-sortIcon", inputs: ["field"] }, { type: i4.ColumnFilter, selector: "p-columnFilter", inputs: ["field", "type", "display", "showMenu", "matchMode", "operator", "showOperator", "showClearButton", "showApplyButton", "showMatchModes", "showAddButton", "hideOnClear", "placeholder", "matchModeOptions", "maxConstraints", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "locale", "localeMatcher", "currency", "currencyDisplay", "useGrouping"] }, { type: i5.Avatar, selector: "p-avatar", inputs: ["label", "icon", "image", "size", "shape", "style", "styleClass"] }, { type: i6.TriStateCheckbox, selector: "p-triStateCheckbox", inputs: ["disabled", "name", "ariaLabelledBy", "tabindex", "inputId", "style", "styleClass", "label", "readonly", "checkboxTrueIcon", "checkboxFalseIcon"], outputs: ["onChange"] }, { type: i7.Toast, selector: "p-toast", inputs: ["key", "autoZIndex", "baseZIndex", "style", "styleClass", "position", "preventOpenDuplicates", "preventDuplicates", "showTransformOptions", "hideTransformOptions", "showTransitionOptions", "hideTransitionOptions", "breakpoints"], outputs: ["onClose"] }, { type: i8.ConfirmDialog, selector: "p-confirmDialog", inputs: ["header", "icon", "message", "style", "styleClass", "maskStyleClass", "acceptIcon", "acceptLabel", "acceptAriaLabel", "acceptVisible", "rejectIcon", "rejectLabel", "rejectAriaLabel", "rejectVisible", "acceptButtonStyleClass", "rejectButtonStyleClass", "closeOnEscape", "dismissableMask", "blockScroll", "rtl", "closable", "appendTo", "key", "autoZIndex", "baseZIndex", "transitionOptions", "focusTrap", "defaultFocus", "breakpoints", "visible", "position"], outputs: ["onHide"] }], directives: [{ type: i2.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { type: i9.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i4.SortableColumn, selector: "[pSortableColumn]", inputs: ["pSortableColumn", "pSortableColumnDisabled"] }, { type: i10.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { type: i11.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["routerLink", "target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo"] }, { type: i12.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { type: i9.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i9.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i13.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i13.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], pipes: { "date": i9.DatePipe } });
336
+ RESTworldListViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.11", type: RESTworldListViewComponent, selector: "rw-list", inputs: { editLink: "editLink", apiName: "apiName", rel: "rel", rowsPerPage: "rowsPerPage" }, ngImport: i0, template: "<p-table [value]=\"value\"\r\n [lazy]=\"true\"\r\n [lazyLoadOnInit]=\"false\"\r\n (onLazyLoad)=\"load($event)\"\r\n responsiveLayout=\"scroll\"\r\n [paginator]=\"true\"\r\n [rows]=\"rows\"\r\n [rowsPerPageOptions]=\"rowsPerPage\"\r\n [totalRecords]=\"totalRecords\"\r\n [loading]=\"isLoading\"\r\n [showInitialSortBadge]=\"true\"\r\n [columns]=\"columns\">\r\n\r\n <ng-template pTemplate=\"header\" let-columns>\r\n <tr>\r\n <th *ngFor=\"let col of columns\" [pSortableColumn]=\"col.field\">\r\n <div class=\"p-d-flex p-jc-between p-ai-center\">\r\n {{col.header}}\r\n <p-sortIcon [field]=\"col.field\"></p-sortIcon>\r\n <p-columnFilter [type]=\"col.type\" [field]=\"col.field\" display=\"menu\"></p-columnFilter>\r\n </div>\r\n </th>\r\n <th>\r\n <div class=\"flex justify-content-end\">\r\n <div class=\"mx-2\" pTooltip=\"Create new\" tooltipPosition=\"left\">\r\n <a class=\"p-button-success\" icon=\"fas fa-plus\" pButton [routerLink]=\"['/edit', apiName, newHref]\"></a>\r\n </div>\r\n </div>\r\n </th>\r\n </tr>\r\n </ng-template>\r\n\r\n <ng-template pTemplate=\"body\" let-entity let-columns=\"columns\">\r\n <tr>\r\n <td [ngSwitch]=\"col.type\" *ngFor=\"let col of columns\">\r\n <ng-container *ngSwitchCase=\"'text'\">\r\n <p-avatar *ngIf=\"col.field === 'createdBy' || col.field === 'lastChangedBy'\" [pTooltip]=\"entity[col.field]\" tooltipPosition=\"top\" [image]=\"avatarGenerator.getImage(entity[col.field])\" [label]=\"avatarGenerator.getLabel(entity[col.field])\" [style]=\"avatarGenerator.getStyle(entity[col.field])\" shape=\"circle\"></p-avatar>\r\n <span *ngIf=\"col.field !== 'createdBy' && col.field !== 'lastChangedBy'\">{{entity[col.field]}}</span>\r\n </ng-container>\r\n <span *ngSwitchCase=\"'numeric'\" class=\"flex justify-content-end\">{{entity[col.field]}}</span>\r\n <span *ngSwitchCase=\"'boolean'\" class=\"flex justify-content-center\"><p-triStateCheckbox [(ngModel)]=\"entity[col.field]\" [readonly]=\"true\"></p-triStateCheckbox></span>\r\n <span *ngSwitchCase=\"'date'\" [pTooltip]=\"entity[col.field]\">{{entity[col.field] | date:dateFormat}}</span>\r\n </td>\r\n <td>\r\n <div class=\"flex justify-content-end\">\r\n <a pButton pTooltip=\"View/Edit\" tooltipPosition=\"left\" [routerLink]=\"[editLink, apiName, entity._links?.self[0].href]\" icon=\"fas fa-edit\"></a>\r\n <button pTooltip=\"Delete\" tooltipPosition=\"left\" pButton *ngIf=\"entity._links.delete\" (click)=\"showDeleteConfirmatioModal(entity)\" icon=\"fas fa-trash-alt\" type=\"button\" class=\"mx-2 p-button-danger\"></button>\r\n </div>\r\n </td>\r\n </tr>\r\n </ng-template>\r\n\r\n <ng-template pTemplate=\"emptymessage\">\r\n <tr>\r\n <td colspan=\"8\">No entries found.</td>\r\n </tr>\r\n </ng-template>\r\n\r\n</p-table>\r\n\r\n<p-toast></p-toast>\r\n<p-confirmDialog></p-confirmDialog>\r\n", styles: [".p-tooltip{max-width:-webkit-fit-content;max-width:-moz-fit-content;max-width:fit-content}a.p-button{text-decoration:none}\n"], components: [{ type: i4.Table, selector: "p-table", inputs: ["frozenColumns", "frozenValue", "style", "styleClass", "tableStyle", "tableStyleClass", "paginator", "pageLinks", "rowsPerPageOptions", "alwaysShowPaginator", "paginatorPosition", "paginatorDropdownAppendTo", "paginatorDropdownScrollHeight", "currentPageReportTemplate", "showCurrentPageReport", "showJumpToPageDropdown", "showJumpToPageInput", "showFirstLastIcon", "showPageLinks", "defaultSortOrder", "sortMode", "resetPageOnSort", "selectionMode", "contextMenuSelection", "contextMenuSelectionMode", "dataKey", "metaKeySelection", "rowTrackBy", "lazy", "lazyLoadOnInit", "compareSelectionBy", "csvSeparator", "exportFilename", "filters", "globalFilterFields", "filterDelay", "filterLocale", "expandedRowKeys", "editingRowKeys", "rowExpandMode", "scrollable", "scrollDirection", "rowGroupMode", "scrollHeight", "virtualScroll", "virtualScrollDelay", "virtualRowHeight", "frozenWidth", "responsive", "contextMenu", "resizableColumns", "columnResizeMode", "reorderableColumns", "loading", "loadingIcon", "showLoader", "rowHover", "customSort", "showInitialSortBadge", "autoLayout", "exportFunction", "stateKey", "stateStorage", "editMode", "groupRowsBy", "groupRowsByOrder", "minBufferPx", "maxBufferPx", "responsiveLayout", "breakpoint", "value", "columns", "first", "rows", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection"], outputs: ["selectionChange", "contextMenuSelectionChange", "onRowSelect", "onRowUnselect", "onPage", "onSort", "onFilter", "onLazyLoad", "onRowExpand", "onRowCollapse", "onContextMenuSelect", "onColResize", "onColReorder", "onRowReorder", "onEditInit", "onEditComplete", "onEditCancel", "onHeaderCheckboxToggle", "sortFunction", "firstChange", "rowsChange", "onStateSave", "onStateRestore"] }, { type: i4.SortIcon, selector: "p-sortIcon", inputs: ["field"] }, { type: i4.ColumnFilter, selector: "p-columnFilter", inputs: ["field", "type", "display", "showMenu", "matchMode", "operator", "showOperator", "showClearButton", "showApplyButton", "showMatchModes", "showAddButton", "hideOnClear", "placeholder", "matchModeOptions", "maxConstraints", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "locale", "localeMatcher", "currency", "currencyDisplay", "useGrouping"] }, { type: i5.Avatar, selector: "p-avatar", inputs: ["label", "icon", "image", "size", "shape", "style", "styleClass"] }, { type: i6.TriStateCheckbox, selector: "p-triStateCheckbox", inputs: ["disabled", "name", "ariaLabelledBy", "tabindex", "inputId", "style", "styleClass", "label", "readonly", "checkboxTrueIcon", "checkboxFalseIcon"], outputs: ["onChange"] }, { type: i7.Toast, selector: "p-toast", inputs: ["key", "autoZIndex", "baseZIndex", "style", "styleClass", "position", "preventOpenDuplicates", "preventDuplicates", "showTransformOptions", "hideTransformOptions", "showTransitionOptions", "hideTransitionOptions", "breakpoints"], outputs: ["onClose"] }, { type: i8.ConfirmDialog, selector: "p-confirmDialog", inputs: ["header", "icon", "message", "style", "styleClass", "maskStyleClass", "acceptIcon", "acceptLabel", "acceptAriaLabel", "acceptVisible", "rejectIcon", "rejectLabel", "rejectAriaLabel", "rejectVisible", "acceptButtonStyleClass", "rejectButtonStyleClass", "closeOnEscape", "dismissableMask", "blockScroll", "rtl", "closable", "appendTo", "key", "autoZIndex", "baseZIndex", "transitionOptions", "focusTrap", "defaultFocus", "breakpoints", "visible", "position"], outputs: ["onHide"] }], directives: [{ type: i2.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { type: i9.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i4.SortableColumn, selector: "[pSortableColumn]", inputs: ["pSortableColumn", "pSortableColumnDisabled"] }, { type: i10.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { type: i11.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["routerLink", "target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo"] }, { type: i12.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { type: i9.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i9.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i13.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i13.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], pipes: { "date": i9.DatePipe } });
310
337
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.11", ngImport: i0, type: RESTworldListViewComponent, decorators: [{
311
338
  type: Component,
312
339
  args: [{
313
- selector: 'restworld-list-view',
340
+ selector: 'rw-list',
314
341
  templateUrl: './restworld-list-view.component.html',
315
342
  styleUrls: ['./restworld-list-view.component.css']
316
343
  }]
@@ -323,4 +350,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.11", ngImpo
323
350
  }], rowsPerPage: [{
324
351
  type: Input
325
352
  }] } });
326
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restworld-list-view.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-restworld-client/src/lib/views/restworld-list-view/restworld-list-view.component.ts","../../../../../../projects/ngx-restworld-client/src/lib/views/restworld-list-view/restworld-list-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\r\nimport { PagedListResource, Resource } from '@wertzui/ngx-hal-client';\r\nimport * as _ from 'lodash'\r\nimport { ConfirmationService, FilterMatchMode, FilterMetadata, LazyLoadEvent, MessageService } from 'primeng/api'\r\nimport { RESTworldClient } from '../../services/restworld-client';\r\nimport { RESTworldClientCollection } from '../../services/restworld-client-collection';\r\nimport { ProblemDetails } from '../../models/problem-details';\r\nimport { AvatarGenerator } from '../../services/avatar-generator';\r\n\r\n@Component({\r\n  selector: 'restworld-list-view',\r\n  templateUrl: './restworld-list-view.component.html',\r\n  styleUrls: ['./restworld-list-view.component.css']\r\n})\r\nexport class RESTworldListViewComponent {\r\n  public get columns(): any[] {\r\n    return this._columns;\r\n  }\r\n  private _columns: any[] = [];\r\n  @Input()\r\n  public set editLink(value: string) {\r\n    if (value)\r\n      this._editLink = value;\r\n  }\r\n  public get editLink() {\r\n    return this._editLink;\r\n  }\r\n  private _editLink: string = '/edit';\r\n  @Input()\r\n  public set apiName(value: string | undefined) {\r\n    this._apiName = value;\r\n    if (this.apiName && this.rel && this._lastEvent)\r\n      this.load(this._lastEvent);\r\n  }\r\n  public get apiName(): string | undefined {\r\n    return this._apiName;\r\n  }\r\n  private _apiName?: string;\r\n  @Input()\r\n  public set rel(value: string | undefined) {\r\n    this._rel = value;\r\n    if (this.apiName && this.rel && this._lastEvent)\r\n      this.load(this._lastEvent);\r\n  }\r\n  public get rel(): string | undefined {\r\n    return this._rel;\r\n  }\r\n  private _rel?: string;\r\n  @Input()\r\n  public rowsPerPage: number[];\r\n  public resource?: PagedListResource;\r\n  public isLoading = false;\r\n  private _totalRecords: number = 0;\r\n  private _lastEvent: LazyLoadEvent;\r\n  public get value(): Resource[] {\r\n    return this.resource?._embedded?.items || [];\r\n  }\r\n  public get rows(): number {\r\n    return this._lastEvent?.rows || 0;\r\n  }\r\n  public get totalRecords(): number {\r\n    return this._totalRecords;\r\n  }\r\n  private set totalRecords(value: number | undefined) {\r\n    this._totalRecords = value || 0;\r\n  }\r\n  public get sortOrder() {\r\n    return this._lastEvent.sortOrder || 0;\r\n  }\r\n\r\n  public get newHref(): string | undefined {\r\n    return this.resource?.findLink('new')?.href;\r\n  }\r\n\r\n  private static _dateFormat = new Date(3333, 10, 22)\r\n    .toLocaleDateString()\r\n    .replace(\"22\", \"dd\")\r\n    .replace(\"11\", \"MM\")\r\n    .replace(\"3333\", \"y\")\r\n    .replace(\"33\", \"yy\");\r\n\r\n  public get dateFormat(): string {\r\n    return RESTworldListViewComponent._dateFormat;\r\n  }\r\n\r\n  constructor(\r\n    private _clients: RESTworldClientCollection,\r\n    private _confirmationService: ConfirmationService,\r\n    private _messageService: MessageService,\r\n    public avatarGenerator: AvatarGenerator) {\r\n    this.rowsPerPage = [10, 25, 50];\r\n\r\n    this._lastEvent = {\r\n      rows: this.rowsPerPage[0]\r\n    }\r\n  }\r\n\r\n  private getClient(): RESTworldClient {\r\n    if (!this.apiName)\r\n      throw new Error('Cannot get a client, because the apiName is not set.');\r\n\r\n    return this._clients.getClient(this.apiName);\r\n  }\r\n\r\n  public async load(event: LazyLoadEvent): Promise<void> {\r\n    if (!this.apiName || !this.rel)\r\n      return;\r\n\r\n    this.isLoading = true;\r\n    this._lastEvent = event;\r\n\r\n    const parameters = RESTworldListViewComponent.createParametersFromEvent(event);\r\n    const response = await this.getClient().getList(this.rel, parameters);\r\n    if (!response.ok || ProblemDetails.isProblemDetails(response.body) || !response.body) {\r\n      this._messageService.add({ severity: 'error', summary: 'Error', detail: 'Error while loading the resources from the API.',  data: response})\r\n    }\r\n    else {\r\n      this.resource = response.body;\r\n      this.totalRecords = this.resource!.totalPages && parameters.$top ? this.resource!.totalPages * parameters.$top : undefined;\r\n      this._columns = this.createColumns();\r\n    }\r\n\r\n    this.isLoading = false;\r\n  }\r\n\r\n\r\n  public showDeleteConfirmatioModal(resource: Resource) {\r\n    this._confirmationService.confirm({\r\n      message: 'Do you really want to delete this resource?',\r\n      header: 'Confirm delete',\r\n      icon: 'far fa-trash-alt',\r\n      accept: () => this.delete(resource)\r\n    });\r\n  }\r\n\r\n  public async delete(resource: Resource): Promise<void> {\r\n    if (!this.apiName || !this.rel)\r\n      return;\r\n\r\n    await this.getClient().delete(resource);\r\n\r\n    this._messageService.add({ severity: 'success', summary: 'Deleted', detail: 'The resource has been deleted.' });\r\n\r\n    this.load(this._lastEvent)\r\n  }\r\n\r\n  private createColumns(): any[] {\r\n    if (this.value.length === 0)\r\n      return [];\r\n\r\n    // Get all distinct properties from all rows\r\n    // We look at all rows to eliminate possible undefined values\r\n    const rowsWithProperties = this.value\r\n      .map(resource =>\r\n        Object.entries(resource)\r\n          .filter(p =>\r\n            p[0] !== '_links' &&\r\n            p[0] !== '_embedded' &&\r\n            p[0] !== 'id' &&\r\n            p[0] !== 'timestamp'));\r\n\r\n    let distinctProperties = rowsWithProperties[0];\r\n    for (let propertiesOfRow of rowsWithProperties) {\r\n      for (var property of propertiesOfRow) {\r\n        const propertyName = property[0];\r\n        const propertyValue = property[1];\r\n        const alreadyFoundPropertyWithSameName = distinctProperties.find(p => p[0] === propertyName);\r\n        if (!alreadyFoundPropertyWithSameName) // Add new property\r\n          distinctProperties.push(property);\r\n        else if (!alreadyFoundPropertyWithSameName[1] && propertyValue) // Use defined value instead of existing undefined value\r\n          alreadyFoundPropertyWithSameName[1] = propertyValue\r\n      }\r\n    }\r\n\r\n    // Check if the rows are entities with change tracking\r\n    const withoutChangeTrackingProperties = distinctProperties.filter(p =>\r\n      p[0] !== 'createdAt' &&\r\n      p[0] !== 'createdBy' &&\r\n      p[0] !== 'lastChangedAt' &&\r\n      p[0] !== 'lastChangedBy');\r\n    const hasChangeTrackingProperties = withoutChangeTrackingProperties.length < distinctProperties.length;\r\n\r\n    // First the id, then all other properties\r\n    const sortedProperties: [string, any][] = [\r\n      ['id', 0],\r\n      ...withoutChangeTrackingProperties\r\n    ];\r\n\r\n    // And change tracking properties at the end\r\n    if (hasChangeTrackingProperties) {\r\n      sortedProperties.push(['createdAt', new Date()]);\r\n      sortedProperties.push(['createdBy', '']);\r\n      sortedProperties.push(['lastChangedAt', new Date()]);\r\n      sortedProperties.push(['lastChangedBy', '']);\r\n    }\r\n\r\n    const columns = sortedProperties\r\n      .map(p => ({\r\n        header: RESTworldListViewComponent.toTitleCase(p[0]),\r\n        field: p[0],\r\n        type: RESTworldListViewComponent.getColumnType(p[1]),\r\n      }));\r\n\r\n    return columns;\r\n  }\r\n\r\n  private static getColumnType(value: any) {\r\n    if (value === null || value === undefined)\r\n      return 'text';\r\n\r\n    if (_.isNumber(value))\r\n      return 'numeric';\r\n\r\n    if (_.isDate(value))\r\n      return 'date'\r\n\r\n    if (_.isString(value))\r\n      return 'text';\r\n\r\n    if (_.isBoolean(value))\r\n      return 'boolean';\r\n\r\n    return 'text'\r\n  }\r\n\r\n  private static toTitleCase(anyCase: string) {\r\n    return anyCase\r\n      .replace(/(_)+/g, ' ')                              // underscore to whitespace\r\n      .replace(/([a-z])([A-Z][a-z])/g, \"$1 $2\")           // insert space before each new word if there is none\r\n      .replace(/([A-Z][a-z])([A-Z])/g, \"$1 $2\")           // insert space after each word if there is none\r\n      .replace(/([a-z])([A-Z]+[a-z])/g, \"$1 $2\")          // insert space after single letter word if there is none\r\n      .replace(/([A-Z]+)([A-Z][a-z][a-z])/g, \"$1 $2\")     // insert space before single letter word if there is none\r\n      .replace(/([a-z]+)([A-Z0-9]+)/g, \"$1 $2\")           // insert space after numbers\r\n      .replace(/^./, (match) => match.toUpperCase());     // change first letter to be upper case\r\n  }\r\n\r\n  private static createParametersFromEvent(event: LazyLoadEvent) {\r\n    const oDataParameters = {\r\n      $filter: RESTworldListViewComponent.createFilterFromEvent(event),\r\n      $orderby: RESTworldListViewComponent.createOrderByFromEvent(event),\r\n      $top: RESTworldListViewComponent.createTopFromEvent(event),\r\n      $skip: RESTworldListViewComponent.createSkipFromEvent(event)\r\n    };\r\n\r\n    return oDataParameters;\r\n  }\r\n\r\n  static createSkipFromEvent(event: LazyLoadEvent): number | undefined {\r\n    return event.first;\r\n  }\r\n\r\n  static createTopFromEvent(event: LazyLoadEvent): number | undefined {\r\n    return event.rows;\r\n  }\r\n\r\n  static createOrderByFromEvent(event: LazyLoadEvent): string | undefined {\r\n    if (event.sortField) {\r\n      const order = !event.sortOrder || event.sortOrder > 0 ? 'asc' : 'desc';\r\n      return `${event.sortField} ${order}`;\r\n    }\r\n\r\n    return undefined;\r\n  }\r\n  static createFilterFromEvent(event: LazyLoadEvent): string | undefined {\r\n    if (!event.filters)\r\n      return undefined;\r\n\r\n    const filter = Object.entries(event.filters)\r\n      .map(([property, filter]) => RESTworldListViewComponent.createFilterForProperty(property, filter))\r\n      .filter(filter => !!filter)\r\n      .join(' and ');\r\n\r\n    if (filter === '')\r\n      return undefined;\r\n\r\n    return `(${filter})`\r\n  }\r\n\r\n  static createFilterForProperty(property: string, filter: FilterMetadata): string | undefined {\r\n    if (!filter.value)\r\n      return undefined;\r\n\r\n    const oDataOperator = RESTworldListViewComponent.createODataOperator(\r\n      filter.matchMode,\r\n    );\r\n    const comparisonValue = RESTworldListViewComponent.createComparisonValue(filter.value);\r\n\r\n    switch (oDataOperator) {\r\n      case 'contains':\r\n      case 'not contains':\r\n      case 'startswith':\r\n      case 'endswith':\r\n        return `${oDataOperator}(${property}, ${comparisonValue})`;\r\n      default:\r\n        return `${property} ${oDataOperator} ${comparisonValue}`;\r\n    }\r\n  }\r\n\r\n  static createODataOperator(matchMode?: string): string {\r\n    switch (matchMode) {\r\n      case FilterMatchMode.STARTS_WITH:\r\n        return 'startswith';\r\n      case FilterMatchMode.CONTAINS:\r\n        return 'contains';\r\n      case FilterMatchMode.NOT_CONTAINS:\r\n        return 'not contains';\r\n      case FilterMatchMode.ENDS_WITH:\r\n        return 'endswith';\r\n      case FilterMatchMode.EQUALS:\r\n        return 'eq';\r\n      case FilterMatchMode.NOT_EQUALS:\r\n        return 'ne';\r\n      case FilterMatchMode.IN:\r\n        return 'in';\r\n      case FilterMatchMode.LESS_THAN:\r\n        return 'lt';\r\n      case FilterMatchMode.LESS_THAN_OR_EQUAL_TO:\r\n        return 'le';\r\n      case FilterMatchMode.GREATER_THAN:\r\n        return 'gt';\r\n      case FilterMatchMode.GREATER_THAN_OR_EQUAL_TO:\r\n        return 'ge';\r\n      case FilterMatchMode.IS:\r\n        return 'eq';\r\n      case FilterMatchMode.IS_NOT:\r\n        return 'ne';\r\n      case FilterMatchMode.BEFORE:\r\n        return 'lt';\r\n      case FilterMatchMode.AFTER:\r\n        return 'gt';\r\n      default:\r\n        throw Error(`Unknown matchMode ${matchMode}`);\r\n    }\r\n  }\r\n\r\n  static createComparisonValue(value: unknown): string {\r\n    if (value === null || value === undefined)\r\n      return 'null';\r\n\r\n    if (_.isNumber(value))\r\n      return `${value}`;\r\n\r\n    if (_.isDate(value))\r\n      return `cast(${value.toISOString()}, Edm.DateTimeOffset)`;\r\n\r\n    if (_.isString(value)) {\r\n      const date = new Date(value);\r\n      if (!isNaN(date.valueOf()))\r\n        return `cast(${date.toISOString()}, Edm.DateTimeOffset)`;\r\n\r\n      return `'${value}'`;\r\n    }\r\n\r\n    if (_.isArray(value))\r\n      return `(${value\r\n        .map((v) => this.createComparisonValue(v))\r\n        .join(',')})`;\r\n\r\n    throw new Error(`Unknown type of value: ${value}.`);\r\n  }\r\n\r\n}\r\n","<p-table [value]=\"value\"\r\n         [lazy]=\"true\"\r\n         [lazyLoadOnInit]=\"false\"\r\n         (onLazyLoad)=\"load($event)\"\r\n         responsiveLayout=\"scroll\"\r\n         [paginator]=\"true\"\r\n         [rows]=\"rows\"\r\n         [rowsPerPageOptions]=\"rowsPerPage\"\r\n         [totalRecords]=\"totalRecords\"\r\n         [loading]=\"isLoading\"\r\n         [showInitialSortBadge]=\"true\"\r\n         [columns]=\"columns\">\r\n\r\n  <ng-template pTemplate=\"header\" let-columns>\r\n    <tr>\r\n      <th *ngFor=\"let col of columns\" [pSortableColumn]=\"col.field\">\r\n        <div class=\"p-d-flex p-jc-between p-ai-center\">\r\n          {{col.header}}\r\n          <p-sortIcon [field]=\"col.field\"></p-sortIcon>\r\n          <p-columnFilter [type]=\"col.type\" [field]=\"col.field\" display=\"menu\"></p-columnFilter>\r\n        </div>\r\n      </th>\r\n      <th>\r\n        <div class=\"flex justify-content-end\">\r\n          <div class=\"mx-2\" pTooltip=\"Create new\" tooltipPosition=\"left\">\r\n            <a class=\"p-button-success\" icon=\"fas fa-plus\" pButton [routerLink]=\"['/edit', apiName, newHref]\"></a>\r\n          </div>\r\n        </div>\r\n      </th>\r\n    </tr>\r\n  </ng-template>\r\n\r\n  <ng-template pTemplate=\"body\" let-entity let-columns=\"columns\">\r\n    <tr>\r\n      <td [ngSwitch]=\"col.type\" *ngFor=\"let col of columns\">\r\n        <ng-container *ngSwitchCase=\"'text'\">\r\n          <p-avatar *ngIf=\"col.field === 'createdBy' || col.field === 'lastChangedBy'\" [pTooltip]=\"entity[col.field]\" tooltipPosition=\"top\" [image]=\"avatarGenerator.getImage(entity[col.field])\" [label]=\"avatarGenerator.getLabel(entity[col.field])\" [style]=\"avatarGenerator.getStyle(entity[col.field])\" shape=\"circle\"></p-avatar>\r\n          <span *ngIf=\"col.field !== 'createdBy' && col.field !== 'lastChangedBy'\">{{entity[col.field]}}</span>\r\n        </ng-container>\r\n        <span *ngSwitchCase=\"'numeric'\" class=\"flex justify-content-end\">{{entity[col.field]}}</span>\r\n        <span *ngSwitchCase=\"'boolean'\" class=\"flex justify-content-center\"><p-triStateCheckbox [(ngModel)]=\"entity[col.field]\" [readonly]=\"true\"></p-triStateCheckbox></span>\r\n        <span *ngSwitchCase=\"'date'\" [pTooltip]=\"entity[col.field]\">{{entity[col.field] | date:dateFormat}}</span>\r\n      </td>\r\n      <td>\r\n        <div class=\"flex justify-content-end\">\r\n          <a pButton pTooltip=\"View/Edit\" tooltipPosition=\"left\" [routerLink]=\"[editLink, apiName, entity._links?.self[0].href]\" icon=\"fas fa-edit\"></a>\r\n          <button pTooltip=\"Delete\" tooltipPosition=\"left\" pButton *ngIf=\"entity._links.delete\" (click)=\"showDeleteConfirmatioModal(entity)\" icon=\"fas fa-trash-alt\" type=\"button\" class=\"mx-2 p-button-danger\"></button>\r\n        </div>\r\n      </td>\r\n    </tr>\r\n  </ng-template>\r\n\r\n  <ng-template pTemplate=\"emptymessage\">\r\n    <tr>\r\n      <td colspan=\"8\">No entries found.</td>\r\n    </tr>\r\n  </ng-template>\r\n\r\n</p-table>\r\n\r\n<p-toast></p-toast>\r\n<p-confirmDialog></p-confirmDialog>\r\n"]}
353
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restworld-list-view.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-restworld-client/src/lib/views/restworld-list-view/restworld-list-view.component.ts","../../../../../../projects/ngx-restworld-client/src/lib/views/restworld-list-view/restworld-list-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input } from '@angular/core';\r\nimport { PagedListResource, Resource } from '@wertzui/ngx-hal-client';\r\nimport * as _ from 'lodash';\r\nimport { ConfirmationService, FilterMatchMode, FilterMetadata, LazyLoadEvent, MessageService } from 'primeng/api';\r\nimport { RESTworldClient } from '../../services/restworld-client';\r\nimport { RESTworldClientCollection } from '../../services/restworld-client-collection';\r\nimport { ProblemDetails } from '../../models/problem-details';\r\nimport { AvatarGenerator } from '../../services/avatar-generator';\r\n\r\nexport enum ColumnType {\r\n  text = 'text',\r\n  numeric = 'numeric',\r\n  boolean = 'boolean',\r\n  date = 'date'\r\n}\r\n\r\nexport interface Column {\r\n  header: string;\r\n  field: string;\r\n  type: ColumnType;\r\n}\r\n\r\n@Component({\r\n  selector: 'rw-list',\r\n  templateUrl: './restworld-list-view.component.html',\r\n  styleUrls: ['./restworld-list-view.component.css']\r\n})\r\nexport class RESTworldListViewComponent {\r\n\r\n  public get columns(): Column[] {\r\n    return this._columns;\r\n  }\r\n  private _columns: Column[] = [];\r\n  @Input()\r\n  public set editLink(value: string) {\r\n    if (value)\r\n      this._editLink = value;\r\n  }\r\n  public get editLink() {\r\n    return this._editLink;\r\n  }\r\n  private _editLink = '/edit';\r\n  @Input()\r\n  public set apiName(value: string | undefined) {\r\n    this._apiName = value;\r\n    if (this.apiName && this.rel && this._lastEvent)\r\n      this.load(this._lastEvent);\r\n  }\r\n  public get apiName(): string | undefined {\r\n    return this._apiName;\r\n  }\r\n  private _apiName?: string;\r\n  @Input()\r\n  public set rel(value: string | undefined) {\r\n    this._rel = value;\r\n    if (this.apiName && this.rel && this._lastEvent)\r\n      this.load(this._lastEvent);\r\n  }\r\n  public get rel(): string | undefined {\r\n    return this._rel;\r\n  }\r\n  private _rel?: string;\r\n  @Input()\r\n  public rowsPerPage: number[];\r\n  public resource?: PagedListResource;\r\n  public isLoading = false;\r\n  private _totalRecords = 0;\r\n  private _lastEvent: LazyLoadEvent;\r\n  public get value(): Resource[] {\r\n    return this.resource?._embedded?.items || [];\r\n  }\r\n  public get rows(): number {\r\n    return this._lastEvent?.rows || 0;\r\n  }\r\n  public get totalRecords(): number {\r\n    return this._totalRecords;\r\n  }\r\n  private set totalRecords(value: number | undefined) {\r\n    this._totalRecords = value || 0;\r\n  }\r\n  public get sortOrder() {\r\n    return this._lastEvent.sortOrder || 0;\r\n  }\r\n\r\n  public get newHref(): string | undefined {\r\n    return this.resource?.findLink('new')?.href;\r\n  }\r\n\r\n  private static _dateFormat = new Date(3333, 10, 22)\r\n    .toLocaleDateString()\r\n    .replace(\"22\", \"dd\")\r\n    .replace(\"11\", \"MM\")\r\n    .replace(\"3333\", \"y\")\r\n    .replace(\"33\", \"yy\");\r\n\r\n  public get dateFormat(): string {\r\n    return RESTworldListViewComponent._dateFormat;\r\n  }\r\n\r\n  constructor(\r\n    private _clients: RESTworldClientCollection,\r\n    private _confirmationService: ConfirmationService,\r\n    private _messageService: MessageService,\r\n    public avatarGenerator: AvatarGenerator) {\r\n    this.rowsPerPage = [10, 25, 50];\r\n\r\n    this._lastEvent = {\r\n      rows: this.rowsPerPage[0]\r\n    };\r\n  }\r\n\r\n  private getClient(): RESTworldClient {\r\n    if (!this.apiName)\r\n      throw new Error('Cannot get a client, because the apiName is not set.');\r\n\r\n    return this._clients.getClient(this.apiName);\r\n  }\r\n\r\n  public async load(event: LazyLoadEvent): Promise<void> {\r\n    if (!this.apiName || !this.rel)\r\n      return;\r\n\r\n    this.isLoading = true;\r\n    this._lastEvent = event;\r\n\r\n    const parameters = this.createParametersFromEvent(event);\r\n    const response = await this.getClient().getList(this.rel, parameters);\r\n    if (!response.ok || ProblemDetails.isProblemDetails(response.body) || !response.body) {\r\n      this._messageService.add({ severity: 'error', summary: 'Error', detail: 'Error while loading the resources from the API.', data: response });\r\n    }\r\n    else if (response.body) {\r\n      this.resource = response.body;\r\n      this.totalRecords = this.resource.totalPages && parameters.$top ? this.resource.totalPages * parameters.$top : undefined;\r\n      this._columns = this.createColumns();\r\n    }\r\n\r\n    this.isLoading = false;\r\n  }\r\n\r\n\r\n  public showDeleteConfirmatioModal(resource: Resource) {\r\n    this._confirmationService.confirm({\r\n      message: 'Do you really want to delete this resource?',\r\n      header: 'Confirm delete',\r\n      icon: 'far fa-trash-alt',\r\n      accept: () => this.delete(resource)\r\n    });\r\n  }\r\n\r\n  public async delete(resource: Resource): Promise<void> {\r\n    if (!this.apiName || !this.rel)\r\n      return;\r\n\r\n    await this.getClient().delete(resource);\r\n\r\n    this._messageService.add({ severity: 'success', summary: 'Deleted', detail: 'The resource has been deleted.' });\r\n\r\n    this.load(this._lastEvent);\r\n  }\r\n\r\n  private createColumns(): Column[] {\r\n    if (this.value.length === 0)\r\n      return this.columns;\r\n\r\n    // Get all distinct properties from all rows\r\n    // We look at all rows to eliminate possible undefined values\r\n    const rowsWithProperties = this.value\r\n      .map(resource =>\r\n        Object.entries(resource)\r\n          .filter(p =>\r\n            p[0] !== '_links' &&\r\n            p[0] !== '_embedded' &&\r\n            p[0] !== 'id' &&\r\n            p[0] !== 'timestamp'));\r\n\r\n    const distinctProperties = rowsWithProperties[0];\r\n    for (const propertiesOfRow of rowsWithProperties) {\r\n      for (const property of propertiesOfRow) {\r\n        const propertyName = property[0];\r\n        const propertyValue = property[1];\r\n        const alreadyFoundPropertyWithSameName = distinctProperties.find(p => p[0] === propertyName);\r\n        if (!alreadyFoundPropertyWithSameName) // Add new property\r\n          distinctProperties.push(property);\r\n        else if (!alreadyFoundPropertyWithSameName[1] && propertyValue) // Use defined value instead of existing undefined value\r\n          alreadyFoundPropertyWithSameName[1] = propertyValue;\r\n      }\r\n    }\r\n\r\n    // Check if the rows are entities with change tracking\r\n    const withoutChangeTrackingProperties = distinctProperties.filter(p =>\r\n      p[0] !== 'createdAt' &&\r\n      p[0] !== 'createdBy' &&\r\n      p[0] !== 'lastChangedAt' &&\r\n      p[0] !== 'lastChangedBy');\r\n    const hasChangeTrackingProperties = withoutChangeTrackingProperties.length < distinctProperties.length;\r\n\r\n    // First the id, then all other properties\r\n    const sortedProperties: [string, unknown][] = [\r\n      ['id', 0],\r\n      ...withoutChangeTrackingProperties\r\n    ];\r\n\r\n    // And change tracking properties at the end\r\n    if (hasChangeTrackingProperties) {\r\n      sortedProperties.push(['createdAt', new Date()]);\r\n      sortedProperties.push(['createdBy', '']);\r\n      sortedProperties.push(['lastChangedAt', new Date()]);\r\n      sortedProperties.push(['lastChangedBy', '']);\r\n    }\r\n\r\n    const columns = sortedProperties\r\n      .map(p => ({\r\n        header: RESTworldListViewComponent.toTitleCase(p[0]),\r\n        field: p[0],\r\n        type: RESTworldListViewComponent.getColumnType(p[1]),\r\n      }));\r\n\r\n    return columns;\r\n  }\r\n\r\n  private static getColumnType(value: unknown): ColumnType {\r\n    if (value === null || value === undefined)\r\n      return ColumnType.text;\r\n\r\n    if (_.isNumber(value))\r\n      return ColumnType.numeric;\r\n\r\n    if (_.isDate(value))\r\n      return ColumnType.date;\r\n\r\n    if (_.isString(value))\r\n      return ColumnType.text;\r\n\r\n    if (_.isBoolean(value))\r\n      return ColumnType.boolean;\r\n\r\n    return ColumnType.text;\r\n  }\r\n\r\n  private static toTitleCase(anyCase: string) {\r\n    return anyCase\r\n      .replace(/(_)+/g, ' ')                              // underscore to whitespace\r\n      .replace(/([a-z])([A-Z][a-z])/g, \"$1 $2\")           // insert space before each new word if there is none\r\n      .replace(/([A-Z][a-z])([A-Z])/g, \"$1 $2\")           // insert space after each word if there is none\r\n      .replace(/([a-z])([A-Z]+[a-z])/g, \"$1 $2\")          // insert space after single letter word if there is none\r\n      .replace(/([A-Z]+)([A-Z][a-z][a-z])/g, \"$1 $2\")     // insert space before single letter word if there is none\r\n      .replace(/([a-z]+)([A-Z0-9]+)/g, \"$1 $2\")           // insert space after numbers\r\n      .replace(/^./, (match) => match.toUpperCase());     // change first letter to be upper case\r\n  }\r\n\r\n  private createParametersFromEvent(event: LazyLoadEvent) {\r\n    const oDataParameters = {\r\n      $filter: this.createFilterFromEvent(event),\r\n      $orderby: RESTworldListViewComponent.createOrderByFromEvent(event),\r\n      $top: RESTworldListViewComponent.createTopFromEvent(event),\r\n      $skip: RESTworldListViewComponent.createSkipFromEvent(event)\r\n    };\r\n\r\n    return oDataParameters;\r\n  }\r\n\r\n  static createSkipFromEvent(event: LazyLoadEvent): number | undefined {\r\n    return event.first;\r\n  }\r\n\r\n  static createTopFromEvent(event: LazyLoadEvent): number | undefined {\r\n    return event.rows;\r\n  }\r\n\r\n  static createOrderByFromEvent(event: LazyLoadEvent): string | undefined {\r\n    if (event.sortField) {\r\n      const order = !event.sortOrder || event.sortOrder > 0 ? 'asc' : 'desc';\r\n      return `${event.sortField} ${order}`;\r\n    }\r\n\r\n    return undefined;\r\n  }\r\n\r\n  private createFilterFromEvent(event: LazyLoadEvent): string | undefined {\r\n    if (!event.filters)\r\n      return undefined;\r\n\r\n    const filter = Object.entries(event.filters)\r\n      // The type definition is wrong, event.filters has values of type FilterMetadata[] and not FilterMetadata.\r\n      .map(([property, filter]) => ({ property: property, filters: filter as FilterMetadata[] }))\r\n      .map(f => this.createFilterForPropertyArray(f.property, f.filters))\r\n      .filter(f => !!f)\r\n      .join(' and ');\r\n\r\n    if (filter === '')\r\n      return undefined;\r\n\r\n    return `(${filter})`;\r\n  }\r\n\r\n  private createFilterForPropertyArray(property: string, filters: FilterMetadata[]): string | undefined {\r\n    const filter = filters\r\n      .map(f => this.createFilterForProperty(property, f))\r\n      .filter(f => !!f)\r\n      .join(` ${filters[0].operator} `);\r\n\r\n    if (filter === '')\r\n      return undefined;\r\n\r\n    return `(${filter})`;\r\n  }\r\n\r\n  private createFilterForProperty(property: string, filter: FilterMetadata): string | undefined {\r\n    if (!filter.value)\r\n      return undefined;\r\n\r\n    const oDataOperator = RESTworldListViewComponent.createODataOperator(\r\n      filter.matchMode,\r\n    );\r\n    const comparisonValue = this.createComparisonValue(property, filter.value);\r\n\r\n    switch (oDataOperator) {\r\n      case 'contains':\r\n      case 'not contains':\r\n      case 'startswith':\r\n      case 'endswith':\r\n        return `${oDataOperator}(${property}, ${comparisonValue})`;\r\n      default:\r\n        return `${property} ${oDataOperator} ${comparisonValue}`;\r\n    }\r\n  }\r\n\r\n  private static createODataOperator(matchMode?: string): string {\r\n    switch (matchMode) {\r\n      case FilterMatchMode.STARTS_WITH:\r\n        return 'startswith';\r\n      case FilterMatchMode.CONTAINS:\r\n        return 'contains';\r\n      case FilterMatchMode.NOT_CONTAINS:\r\n        return 'not contains';\r\n      case FilterMatchMode.ENDS_WITH:\r\n        return 'endswith';\r\n      case FilterMatchMode.EQUALS:\r\n        return 'eq';\r\n      case FilterMatchMode.NOT_EQUALS:\r\n        return 'ne';\r\n      case FilterMatchMode.IN:\r\n        return 'in';\r\n      case FilterMatchMode.LESS_THAN:\r\n        return 'lt';\r\n      case FilterMatchMode.LESS_THAN_OR_EQUAL_TO:\r\n        return 'le';\r\n      case FilterMatchMode.GREATER_THAN:\r\n        return 'gt';\r\n      case FilterMatchMode.GREATER_THAN_OR_EQUAL_TO:\r\n        return 'ge';\r\n      case FilterMatchMode.IS:\r\n        return 'eq';\r\n      case FilterMatchMode.IS_NOT:\r\n        return 'ne';\r\n      case FilterMatchMode.BEFORE:\r\n        return 'lt';\r\n      case FilterMatchMode.AFTER:\r\n        return 'gt';\r\n      case FilterMatchMode.DATE_AFTER:\r\n        return 'ge';\r\n      case FilterMatchMode.DATE_BEFORE:\r\n        return 'lt';\r\n      case FilterMatchMode.DATE_IS:\r\n        return 'eq';\r\n      case FilterMatchMode.DATE_IS_NOT:\r\n        return 'ne';\r\n      default:\r\n        throw Error(`Unknown matchMode ${matchMode}`);\r\n    }\r\n  }\r\n\r\n  private createComparisonValue(property: string, value: unknown): string {\r\n    if (value === null || value === undefined)\r\n      return 'null';\r\n\r\n    const columns = this.columns.filter(c => c.field === property);\r\n    if (columns.length !== 1)\r\n      throw new Error(`Cannot find the column for the property ${property} which is specified in the filter.`);\r\n\r\n    const type = columns[0].type;\r\n\r\n    switch (type) {\r\n      case ColumnType.boolean:\r\n        return `${value}`;\r\n      case ColumnType.date:\r\n        return `cast(${(value as Date).toISOString()}, Edm.DateTimeOffset)`;\r\n      case ColumnType.numeric:\r\n        return `${value}`;\r\n      case ColumnType.text:\r\n        return `'${value}'`;\r\n      default:\r\n        throw new Error(`Unknown column type '${type}'`);\r\n    }\r\n  }\r\n}\r\n","<p-table [value]=\"value\"\r\n         [lazy]=\"true\"\r\n         [lazyLoadOnInit]=\"false\"\r\n         (onLazyLoad)=\"load($event)\"\r\n         responsiveLayout=\"scroll\"\r\n         [paginator]=\"true\"\r\n         [rows]=\"rows\"\r\n         [rowsPerPageOptions]=\"rowsPerPage\"\r\n         [totalRecords]=\"totalRecords\"\r\n         [loading]=\"isLoading\"\r\n         [showInitialSortBadge]=\"true\"\r\n         [columns]=\"columns\">\r\n\r\n  <ng-template pTemplate=\"header\" let-columns>\r\n    <tr>\r\n      <th *ngFor=\"let col of columns\" [pSortableColumn]=\"col.field\">\r\n        <div class=\"p-d-flex p-jc-between p-ai-center\">\r\n          {{col.header}}\r\n          <p-sortIcon [field]=\"col.field\"></p-sortIcon>\r\n          <p-columnFilter [type]=\"col.type\" [field]=\"col.field\" display=\"menu\"></p-columnFilter>\r\n        </div>\r\n      </th>\r\n      <th>\r\n        <div class=\"flex justify-content-end\">\r\n          <div class=\"mx-2\" pTooltip=\"Create new\" tooltipPosition=\"left\">\r\n            <a class=\"p-button-success\" icon=\"fas fa-plus\" pButton [routerLink]=\"['/edit', apiName, newHref]\"></a>\r\n          </div>\r\n        </div>\r\n      </th>\r\n    </tr>\r\n  </ng-template>\r\n\r\n  <ng-template pTemplate=\"body\" let-entity let-columns=\"columns\">\r\n    <tr>\r\n      <td [ngSwitch]=\"col.type\" *ngFor=\"let col of columns\">\r\n        <ng-container *ngSwitchCase=\"'text'\">\r\n          <p-avatar *ngIf=\"col.field === 'createdBy' || col.field === 'lastChangedBy'\" [pTooltip]=\"entity[col.field]\" tooltipPosition=\"top\" [image]=\"avatarGenerator.getImage(entity[col.field])\" [label]=\"avatarGenerator.getLabel(entity[col.field])\" [style]=\"avatarGenerator.getStyle(entity[col.field])\" shape=\"circle\"></p-avatar>\r\n          <span *ngIf=\"col.field !== 'createdBy' && col.field !== 'lastChangedBy'\">{{entity[col.field]}}</span>\r\n        </ng-container>\r\n        <span *ngSwitchCase=\"'numeric'\" class=\"flex justify-content-end\">{{entity[col.field]}}</span>\r\n        <span *ngSwitchCase=\"'boolean'\" class=\"flex justify-content-center\"><p-triStateCheckbox [(ngModel)]=\"entity[col.field]\" [readonly]=\"true\"></p-triStateCheckbox></span>\r\n        <span *ngSwitchCase=\"'date'\" [pTooltip]=\"entity[col.field]\">{{entity[col.field] | date:dateFormat}}</span>\r\n      </td>\r\n      <td>\r\n        <div class=\"flex justify-content-end\">\r\n          <a pButton pTooltip=\"View/Edit\" tooltipPosition=\"left\" [routerLink]=\"[editLink, apiName, entity._links?.self[0].href]\" icon=\"fas fa-edit\"></a>\r\n          <button pTooltip=\"Delete\" tooltipPosition=\"left\" pButton *ngIf=\"entity._links.delete\" (click)=\"showDeleteConfirmatioModal(entity)\" icon=\"fas fa-trash-alt\" type=\"button\" class=\"mx-2 p-button-danger\"></button>\r\n        </div>\r\n      </td>\r\n    </tr>\r\n  </ng-template>\r\n\r\n  <ng-template pTemplate=\"emptymessage\">\r\n    <tr>\r\n      <td colspan=\"8\">No entries found.</td>\r\n    </tr>\r\n  </ng-template>\r\n\r\n</p-table>\r\n\r\n<p-toast></p-toast>\r\n<p-confirmDialog></p-confirmDialog>\r\n"]}
@@ -6,11 +6,17 @@ export * from './lib/models/api-url';
6
6
  export * from './lib/models/client-settings';
7
7
  export * from './lib/models/problem-details';
8
8
  export * from './lib/models/restworld-options';
9
+ export * from './lib/pipes/safe-url.pipe';
10
+ export * from './lib/pipes/as.pipe';
9
11
  export * from './lib/services/avatar-generator';
12
+ export * from './lib/services/form.service';
10
13
  export * from './lib/services/restworld-client';
11
14
  export * from './lib/services/restworld-client-collection';
12
15
  export * from './lib/services/settings.service';
16
+ export * from './lib/views/restworld-edit-form/restworld-edit-form.component';
13
17
  export * from './lib/views/restworld-edit-view/restworld-edit-view.component';
18
+ export * from './lib/views/restworld-file-view/restworld-file-view.component';
19
+ export * from './lib/views/restworld-image-view/restworld-image-view.component';
14
20
  export * from './lib/views/restworld-list-view/restworld-list-view.component';
15
21
  export * from './lib/restworld-client.module';
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25neC1yZXN0d29ybGQtY2xpZW50L3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyw0QkFBNEIsQ0FBQztBQUUzQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLGdDQUFnQyxDQUFDO0FBRS9DLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLDRDQUE0QyxDQUFDO0FBQzNELGNBQWMsaUNBQWlDLENBQUM7QUFFaEQsY0FBYywrREFBK0QsQ0FBQTtBQUM3RSxjQUFjLCtEQUErRCxDQUFBO0FBRTdFLGNBQWMsK0JBQStCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIG5neC1yZXN0d29ybGQtY2xpZW50XG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29uc3RhbnRzL2xpbmstbmFtZXMnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2RlbHMvYXBpLXVybCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2RlbHMvY2xpZW50LXNldHRpbmdzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9wcm9ibGVtLWRldGFpbHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kZWxzL3Jlc3R3b3JsZC1vcHRpb25zJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvYXZhdGFyLWdlbmVyYXRvcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZXJ2aWNlcy9yZXN0d29ybGQtY2xpZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NlcnZpY2VzL3Jlc3R3b3JsZC1jbGllbnQtY29sbGVjdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZXJ2aWNlcy9zZXR0aW5ncy5zZXJ2aWNlJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvdmlld3MvcmVzdHdvcmxkLWVkaXQtdmlldy9yZXN0d29ybGQtZWRpdC12aWV3LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3ZpZXdzL3Jlc3R3b3JsZC1saXN0LXZpZXcvcmVzdHdvcmxkLWxpc3Qtdmlldy5jb21wb25lbnQnXG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL3Jlc3R3b3JsZC1jbGllbnQubW9kdWxlJzsiXX0=
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25neC1yZXN0d29ybGQtY2xpZW50L3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyw0QkFBNEIsQ0FBQztBQUUzQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLGdDQUFnQyxDQUFDO0FBRS9DLGNBQWMsMkJBQTJCLENBQUE7QUFDekMsY0FBYyxxQkFBcUIsQ0FBQTtBQUVuQyxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLDRDQUE0QyxDQUFDO0FBQzNELGNBQWMsaUNBQWlDLENBQUM7QUFFaEQsY0FBYywrREFBK0QsQ0FBQztBQUM5RSxjQUFjLCtEQUErRCxDQUFDO0FBQzlFLGNBQWMsK0RBQStELENBQUE7QUFDN0UsY0FBYyxpRUFBaUUsQ0FBQTtBQUMvRSxjQUFjLCtEQUErRCxDQUFBO0FBRTdFLGNBQWMsK0JBQStCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIG5neC1yZXN0d29ybGQtY2xpZW50XG4gKi9cclxuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb25zdGFudHMvbGluay1uYW1lcyc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9hcGktdXJsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9jbGllbnQtc2V0dGluZ3MnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kZWxzL3Byb2JsZW0tZGV0YWlscyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2RlbHMvcmVzdHdvcmxkLW9wdGlvbnMnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9waXBlcy9zYWZlLXVybC5waXBlJ1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcGlwZXMvYXMucGlwZSdcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvYXZhdGFyLWdlbmVyYXRvcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZXJ2aWNlcy9mb3JtLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvcmVzdHdvcmxkLWNsaWVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZXJ2aWNlcy9yZXN0d29ybGQtY2xpZW50LWNvbGxlY3Rpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvc2V0dGluZ3Muc2VydmljZSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL3ZpZXdzL3Jlc3R3b3JsZC1lZGl0LWZvcm0vcmVzdHdvcmxkLWVkaXQtZm9ybS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdmlld3MvcmVzdHdvcmxkLWVkaXQtdmlldy9yZXN0d29ybGQtZWRpdC12aWV3LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi92aWV3cy9yZXN0d29ybGQtZmlsZS12aWV3L3Jlc3R3b3JsZC1maWxlLXZpZXcuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdmlld3MvcmVzdHdvcmxkLWltYWdlLXZpZXcvcmVzdHdvcmxkLWltYWdlLXZpZXcuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdmlld3MvcmVzdHdvcmxkLWxpc3Qtdmlldy9yZXN0d29ybGQtbGlzdC12aWV3LmNvbXBvbmVudCdcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvcmVzdHdvcmxkLWNsaWVudC5tb2R1bGUnOyJdfQ==