@wertzui/ngx-restworld-client 2.0.0 → 3.1.1
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.
- package/{esm2015/lib/constants/link-names.js → esm2020/lib/constants/link-names.mjs} +0 -0
- package/{esm2015/lib/models/api-url.js → esm2020/lib/models/api-url.mjs} +0 -0
- package/{esm2015/lib/models/client-settings.js → esm2020/lib/models/client-settings.mjs} +1 -1
- package/{esm2015/lib/models/problem-details.js → esm2020/lib/models/problem-details.mjs} +0 -0
- package/{esm2015/lib/models/restworld-options.js → esm2020/lib/models/restworld-options.mjs} +0 -0
- package/{esm2015/lib/pipes/as.pipe.js → esm2020/lib/pipes/as.pipe.mjs} +4 -4
- package/{esm2015/lib/pipes/safe-url.pipe.js → esm2020/lib/pipes/safe-url.pipe.mjs} +4 -4
- package/esm2020/lib/restworld-client.module.mjs +200 -0
- package/{esm2015/lib/services/avatar-generator.js → esm2020/lib/services/avatar-generator.mjs} +4 -4
- package/{esm2015/lib/services/form.service.js → esm2020/lib/services/form.service.mjs} +4 -4
- package/esm2020/lib/services/restworld-client-collection.mjs +39 -0
- package/esm2020/lib/services/restworld-client.mjs +165 -0
- package/esm2020/lib/services/settings.service.mjs +39 -0
- package/esm2020/lib/views/restworld-edit-form/restworld-edit-form.component.mjs +230 -0
- package/esm2020/lib/views/restworld-edit-view/restworld-edit-view.component.mjs +313 -0
- package/esm2020/lib/views/restworld-file-view/restworld-file-view.component.mjs +57 -0
- package/esm2020/lib/views/restworld-image-view/restworld-image-view.component.mjs +100 -0
- package/esm2020/lib/views/restworld-list-view/restworld-list-view.component.mjs +341 -0
- package/{esm2015/public-api.js → esm2020/public-api.mjs} +0 -0
- package/{esm2015/wertzui-ngx-restworld-client.js → esm2020/wertzui-ngx-restworld-client.mjs} +0 -0
- package/fesm2015/wertzui-ngx-restworld-client.mjs +1709 -0
- package/fesm2015/wertzui-ngx-restworld-client.mjs.map +1 -0
- package/fesm2020/wertzui-ngx-restworld-client.mjs +1649 -0
- package/fesm2020/wertzui-ngx-restworld-client.mjs.map +1 -0
- package/lib/models/client-settings.d.ts +4 -1
- package/package.json +42 -31
- package/bundles/wertzui-ngx-restworld-client.umd.js +0 -2477
- package/bundles/wertzui-ngx-restworld-client.umd.js.map +0 -1
- package/esm2015/lib/restworld-client.module.js +0 -201
- package/esm2015/lib/services/restworld-client-collection.js +0 -42
- package/esm2015/lib/services/restworld-client.js +0 -183
- package/esm2015/lib/services/settings.service.js +0 -47
- package/esm2015/lib/views/restworld-edit-form/restworld-edit-form.component.js +0 -238
- package/esm2015/lib/views/restworld-edit-view/restworld-edit-view.component.js +0 -335
- package/esm2015/lib/views/restworld-file-view/restworld-file-view.component.js +0 -63
- package/esm2015/lib/views/restworld-image-view/restworld-image-view.component.js +0 -107
- package/esm2015/lib/views/restworld-list-view/restworld-list-view.component.js +0 -353
- package/fesm2015/wertzui-ngx-restworld-client.js +0 -1728
- package/fesm2015/wertzui-ngx-restworld-client.js.map +0 -1
|
@@ -1,107 +0,0 @@
|
|
|
1
|
-
import { Component, forwardRef, Input, ViewChildren } from '@angular/core';
|
|
2
|
-
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
-
import { FileUpload } from 'primeng/fileupload';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "primeng/button";
|
|
6
|
-
import * as i2 from "primeng/fileupload";
|
|
7
|
-
import * as i3 from "primeng/dialog";
|
|
8
|
-
import * as i4 from "ngx-image-cropper";
|
|
9
|
-
import * as i5 from "primeng/colorpicker";
|
|
10
|
-
import * as i6 from "@angular/common";
|
|
11
|
-
import * as i7 from "primeng/tooltip";
|
|
12
|
-
import * as i8 from "@angular/forms";
|
|
13
|
-
import * as i9 from "primeng/inputtext";
|
|
14
|
-
import * as i10 from "primeng/ripple";
|
|
15
|
-
import * as i11 from "../../pipes/safe-url.pipe";
|
|
16
|
-
export class RESTWorldImageViewComponent {
|
|
17
|
-
constructor() {
|
|
18
|
-
this.maintainAspectRatio = true;
|
|
19
|
-
this.aspectRatio = 1;
|
|
20
|
-
this.resizeToWidth = 0;
|
|
21
|
-
this.resizeToHeight = 0;
|
|
22
|
-
this.onlyScaleDown = false;
|
|
23
|
-
this.containWithinAspectRatio = false;
|
|
24
|
-
this.backgroundColor = "#ffffff";
|
|
25
|
-
this.format = 'png';
|
|
26
|
-
this.disabled = false;
|
|
27
|
-
this.displayCropDialog = false;
|
|
28
|
-
}
|
|
29
|
-
writeValue(obj) {
|
|
30
|
-
this.uri = obj;
|
|
31
|
-
}
|
|
32
|
-
registerOnChange(fn) {
|
|
33
|
-
this.onChange = fn;
|
|
34
|
-
}
|
|
35
|
-
registerOnTouched() {
|
|
36
|
-
// not needed for this component, but needed to implement the interface
|
|
37
|
-
}
|
|
38
|
-
setDisabledState(isDisabled) {
|
|
39
|
-
this.disabled = isDisabled;
|
|
40
|
-
}
|
|
41
|
-
showCropDialog() {
|
|
42
|
-
this.displayCropDialog = true;
|
|
43
|
-
}
|
|
44
|
-
imageChanged(event) {
|
|
45
|
-
this.tempImageFile = event.files[0];
|
|
46
|
-
this.showCropDialog();
|
|
47
|
-
}
|
|
48
|
-
croppedImageChanged(event) {
|
|
49
|
-
this.tempCroppedUri = event.base64;
|
|
50
|
-
}
|
|
51
|
-
acceptCroppedImage() {
|
|
52
|
-
var _a;
|
|
53
|
-
this.uri = this.tempCroppedUri;
|
|
54
|
-
(_a = this.onChange) === null || _a === void 0 ? void 0 : _a.call(this, this.uri);
|
|
55
|
-
this.closeCropDialog();
|
|
56
|
-
}
|
|
57
|
-
closeCropDialog() {
|
|
58
|
-
var _a;
|
|
59
|
-
(_a = this.fileUploads) === null || _a === void 0 ? void 0 : _a.forEach(f => f.clear());
|
|
60
|
-
this.displayCropDialog = false;
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
RESTWorldImageViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.11", ngImport: i0, type: RESTWorldImageViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
64
|
-
RESTWorldImageViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.11", type: RESTWorldImageViewComponent, selector: "rw-image", inputs: { alt: "alt", accept: "accept", fileName: "fileName", maintainAspectRatio: "maintainAspectRatio", aspectRatio: "aspectRatio", resizeToWidth: "resizeToWidth", resizeToHeight: "resizeToHeight", onlyScaleDown: "onlyScaleDown", containWithinAspectRatio: "containWithinAspectRatio", backgroundColor: "backgroundColor", format: "format" }, providers: [{
|
|
65
|
-
provide: NG_VALUE_ACCESSOR,
|
|
66
|
-
useExisting: forwardRef(() => RESTWorldImageViewComponent),
|
|
67
|
-
multi: true
|
|
68
|
-
}], viewQueries: [{ propertyName: "fileUploads", predicate: FileUpload, descendants: true }], ngImport: i0, template: "<div class=\"flex align-items-center\">\r\n <p-button *ngIf=\"!uri\" [disabled]=\"true\" icon=\"pi pi-download\" class=\"mr-1\" pTooltip=\"No image present\"></p-button>\r\n <a *ngIf=\"uri\" [href]=\"uri | safeUrl\" [download]=\"fileName || 'download'\" class=\"mr-1\" pButton pTooltip=\"Download image\" icon=\"pi pi-download\"></a>\r\n <p-fileUpload class=\"mr-1\" chooseIcon=\"pi-upload fas fa-upload\" mode=\"basic\" [auto]=\"true\" [accept]=\"accept || 'false'\" [customUpload]=\"true\" (uploadHandler)=\"imageChanged($event)\" pTooltip=\"Upload new image\"></p-fileUpload>\r\n <img *ngIf=\"uri\" [src]=\"uri\" [alt]=\"alt\" (click)=\"showCropDialog()\" pTooltip=\"Zoom and crop\" />\r\n</div>\r\n\r\n<p-dialog header=\"alt\" [(visible)]=\"displayCropDialog\">\r\n <image-cropper #cropper\r\n [imageFile]=\"tempImageFile!\"\r\n [imageURL]=\"uri!\"\r\n [maintainAspectRatio]=\"maintainAspectRatio\"\r\n [aspectRatio]=\"aspectRatio\"\r\n [resizeToWidth]=\"resizeToWidth\"\r\n [resizeToHeight]=\"resizeToHeight\"\r\n [onlyScaleDown]=\"onlyScaleDown\"\r\n [autoCrop]=\"true\"\r\n [containWithinAspectRatio]=\"containWithinAspectRatio\"\r\n [backgroundColor]=\"backgroundColor\"\r\n [format]=\"format\"\r\n (imageCropped)=\"croppedImageChanged($event)\"></image-cropper>\r\n <div class=\"flex justify-content-end\">\r\n <div class=\"flex-auto align-items-center\">\r\n <span>Background color: </span>\r\n <p-colorPicker [(ngModel)]=\"cropper.backgroundColor\" appendTo=\"body\" class=\"ml-1 mr-1\"></p-colorPicker>\r\n <input pInputText [(ngModel)]=\"cropper.backgroundColor\" />\r\n </div>\r\n <button type=\"button\" pButton pRipple (click)=\"acceptCroppedImage()\" class=\"mr-2\">Ok</button>\r\n <button type=\"button\" pButton pRipple (click)=\"closeCropDialog()\">Cancel</button>\r\n </div>\r\n</p-dialog>\r\n", styles: ["img{height:calc(1rem + 2*8px + 2*1px);cursor:zoom-in;border-radius:3px}a{text-decoration:none;height:calc(1rem + 2*8px + 2px)}a.p-button-icon-only span.p-button-label{height:1rem!important}\n"], components: [{ type: i1.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "style", "styleClass", "badgeClass"], outputs: ["onClick", "onFocus", "onBlur"] }, { type: i2.FileUpload, selector: "p-fileUpload", inputs: ["name", "url", "method", "multiple", "accept", "disabled", "auto", "withCredentials", "maxFileSize", "invalidFileSizeMessageSummary", "invalidFileSizeMessageDetail", "invalidFileTypeMessageSummary", "invalidFileTypeMessageDetail", "invalidFileLimitMessageDetail", "invalidFileLimitMessageSummary", "style", "styleClass", "previewWidth", "chooseLabel", "uploadLabel", "cancelLabel", "chooseIcon", "uploadIcon", "cancelIcon", "showUploadButton", "showCancelButton", "mode", "headers", "customUpload", "fileLimit", "files"], outputs: ["onBeforeUpload", "onSend", "onUpload", "onError", "onClear", "onRemove", "onSelect", "onProgress", "uploadHandler"] }, { type: i3.Dialog, selector: "p-dialog", inputs: ["header", "draggable", "resizable", "positionLeft", "positionTop", "contentStyle", "contentStyleClass", "modal", "closeOnEscape", "dismissableMask", "rtl", "closable", "responsive", "appendTo", "breakpoints", "styleClass", "maskStyleClass", "showHeader", "breakpoint", "blockScroll", "autoZIndex", "baseZIndex", "minX", "minY", "focusOnShow", "maximizable", "keepInViewport", "focusTrap", "transitionOptions", "closeIcon", "closeAriaLabel", "closeTabindex", "minimizeIcon", "maximizeIcon", "visible", "style", "position"], outputs: ["onShow", "onHide", "visibleChange", "onResizeInit", "onResizeEnd", "onDragEnd", "onMaximize"] }, { type: i4.ImageCropperComponent, selector: "image-cropper", inputs: ["format", "transform", "maintainAspectRatio", "aspectRatio", "resizeToWidth", "resizeToHeight", "cropperMinWidth", "cropperMinHeight", "cropperMaxHeight", "cropperMaxWidth", "cropperStaticWidth", "cropperStaticHeight", "canvasRotation", "initialStepSize", "roundCropper", "onlyScaleDown", "imageQuality", "autoCrop", "backgroundColor", "containWithinAspectRatio", "hideResizeSquares", "cropper", "alignImage", "disabled", "imageChangedEvent", "imageURL", "imageBase64", "imageFile"], outputs: ["imageCropped", "startCropImage", "imageLoaded", "cropperReady", "loadImageFailed"] }, { type: i5.ColorPicker, selector: "p-colorPicker", inputs: ["style", "styleClass", "inline", "format", "appendTo", "disabled", "tabindex", "inputId", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onChange", "onShow", "onHide"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { type: i1.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i8.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i8.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i9.InputText, selector: "[pInputText]" }, { type: i10.Ripple, selector: "[pRipple]" }], pipes: { "safeUrl": i11.SafeUrlPipe } });
|
|
69
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.11", ngImport: i0, type: RESTWorldImageViewComponent, decorators: [{
|
|
70
|
-
type: Component,
|
|
71
|
-
args: [{
|
|
72
|
-
selector: 'rw-image',
|
|
73
|
-
templateUrl: './restworld-image-view.component.html',
|
|
74
|
-
styleUrls: ['./restworld-image-view.component.css'],
|
|
75
|
-
providers: [{
|
|
76
|
-
provide: NG_VALUE_ACCESSOR,
|
|
77
|
-
useExisting: forwardRef(() => RESTWorldImageViewComponent),
|
|
78
|
-
multi: true
|
|
79
|
-
}]
|
|
80
|
-
}]
|
|
81
|
-
}], propDecorators: { alt: [{
|
|
82
|
-
type: Input
|
|
83
|
-
}], accept: [{
|
|
84
|
-
type: Input
|
|
85
|
-
}], fileName: [{
|
|
86
|
-
type: Input
|
|
87
|
-
}], maintainAspectRatio: [{
|
|
88
|
-
type: Input
|
|
89
|
-
}], aspectRatio: [{
|
|
90
|
-
type: Input
|
|
91
|
-
}], resizeToWidth: [{
|
|
92
|
-
type: Input
|
|
93
|
-
}], resizeToHeight: [{
|
|
94
|
-
type: Input
|
|
95
|
-
}], onlyScaleDown: [{
|
|
96
|
-
type: Input
|
|
97
|
-
}], containWithinAspectRatio: [{
|
|
98
|
-
type: Input
|
|
99
|
-
}], backgroundColor: [{
|
|
100
|
-
type: Input
|
|
101
|
-
}], format: [{
|
|
102
|
-
type: Input
|
|
103
|
-
}], fileUploads: [{
|
|
104
|
-
type: ViewChildren,
|
|
105
|
-
args: [FileUpload]
|
|
106
|
-
}] } });
|
|
107
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restworld-image-view.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-restworld-client/src/lib/views/restworld-image-view/restworld-image-view.component.ts","../../../../../../projects/ngx-restworld-client/src/lib/views/restworld-image-view/restworld-image-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, Input, QueryList, ViewChildren } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { ImageCroppedEvent, OutputFormat } from 'ngx-image-cropper';\r\nimport { FileUpload } from 'primeng/fileupload';\r\n\n@Component({\n  selector: 'rw-image',\n  templateUrl: './restworld-image-view.component.html',\n  styleUrls: ['./restworld-image-view.component.css'],\n  providers: [{\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => RESTWorldImageViewComponent),\r\n    multi: true\r\n  }]\n})\nexport class RESTWorldImageViewComponent implements ControlValueAccessor {\n\r\n  private onChange?: Function;\n\n  @Input()\n  public alt?: string;\n  @Input()\n  public accept?: string;\n  @Input()\n  public fileName?: string;\n  @Input()\n  maintainAspectRatio = true;\n  @Input()\n  aspectRatio = 1;\n  @Input()\n  resizeToWidth = 0;\n  @Input()\n  resizeToHeight = 0;\n  @Input()\n  onlyScaleDown = false;\n  @Input()\n  containWithinAspectRatio = false;\n  @Input()\n  backgroundColor = \"#ffffff\";\n  @Input()\n  public format: OutputFormat = 'png';\n\n\r\n  @ViewChildren(FileUpload)\r\n  fileUploads?: QueryList<FileUpload>;\n\n\n  public disabled = false;\n  public uri?: string | null;\r\n  public tempImageFile?: File;\r\n  public displayCropDialog = false;\n  public tempCroppedUri?: string | null;\n\n  writeValue(obj?: string | null): void {\r\n    this.uri = obj;\r\n  }\r\n  registerOnChange(fn?: Function): void {\r\n    this.onChange = fn;\r\n  }\r\n  registerOnTouched(): void {\r\n    // not needed for this component, but needed to implement the interface\r\n  }\r\n\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n  }\r\n\r\n  public showCropDialog(): void {\r\n    this.displayCropDialog = true;\r\n  }\r\n\n  public imageChanged(event: { files: File[] }): void {\r\n    this.tempImageFile = event.files[0];\r\n    this.showCropDialog();\r\n  }\n\n  public croppedImageChanged(event: ImageCroppedEvent): void {\r\n    this.tempCroppedUri = event.base64;\r\n  }\n\r\n  public acceptCroppedImage(): void {\r\n    this.uri = this.tempCroppedUri;\r\n    this.onChange?.(this.uri);\r\n    this.closeCropDialog();\r\n  }\r\n\r\n  public closeCropDialog(): void {\r\n    this.fileUploads?.forEach(f => f.clear());\r\n    this.displayCropDialog = false;\r\n  }\n}\n","<div class=\"flex align-items-center\">\r\n  <p-button *ngIf=\"!uri\" [disabled]=\"true\" icon=\"pi pi-download\" class=\"mr-1\" pTooltip=\"No image present\"></p-button>\r\n  <a *ngIf=\"uri\" [href]=\"uri | safeUrl\" [download]=\"fileName || 'download'\" class=\"mr-1\" pButton pTooltip=\"Download image\" icon=\"pi pi-download\"></a>\r\n  <p-fileUpload class=\"mr-1\" chooseIcon=\"pi-upload fas fa-upload\" mode=\"basic\" [auto]=\"true\" [accept]=\"accept || 'false'\" [customUpload]=\"true\" (uploadHandler)=\"imageChanged($event)\" pTooltip=\"Upload new image\"></p-fileUpload>\r\n  <img *ngIf=\"uri\" [src]=\"uri\" [alt]=\"alt\" (click)=\"showCropDialog()\" pTooltip=\"Zoom and crop\" />\r\n</div>\r\n\r\n<p-dialog header=\"alt\" [(visible)]=\"displayCropDialog\">\r\n  <image-cropper #cropper\r\n                 [imageFile]=\"tempImageFile!\"\r\n                 [imageURL]=\"uri!\"\r\n                 [maintainAspectRatio]=\"maintainAspectRatio\"\r\n                 [aspectRatio]=\"aspectRatio\"\r\n                 [resizeToWidth]=\"resizeToWidth\"\r\n                 [resizeToHeight]=\"resizeToHeight\"\r\n                 [onlyScaleDown]=\"onlyScaleDown\"\r\n                 [autoCrop]=\"true\"\r\n                 [containWithinAspectRatio]=\"containWithinAspectRatio\"\r\n                 [backgroundColor]=\"backgroundColor\"\r\n                 [format]=\"format\"\r\n                 (imageCropped)=\"croppedImageChanged($event)\"></image-cropper>\r\n  <div class=\"flex justify-content-end\">\r\n    <div class=\"flex-auto align-items-center\">\r\n      <span>Background color:&nbsp;</span>\r\n      <p-colorPicker [(ngModel)]=\"cropper.backgroundColor\" appendTo=\"body\" class=\"ml-1 mr-1\"></p-colorPicker>\r\n      <input pInputText [(ngModel)]=\"cropper.backgroundColor\" />\r\n    </div>\r\n    <button type=\"button\" pButton pRipple (click)=\"acceptCroppedImage()\" class=\"mr-2\">Ok</button>\r\n    <button type=\"button\" pButton pRipple (click)=\"closeCropDialog()\">Cancel</button>\r\n  </div>\r\n</p-dialog>\r\n"]}
|
|
@@ -1,353 +0,0 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
|
-
import { Component, Input } from '@angular/core';
|
|
3
|
-
import * as _ from 'lodash';
|
|
4
|
-
import { FilterMatchMode } from 'primeng/api';
|
|
5
|
-
import { ProblemDetails } from '../../models/problem-details';
|
|
6
|
-
import * as i0 from "@angular/core";
|
|
7
|
-
import * as i1 from "../../services/restworld-client-collection";
|
|
8
|
-
import * as i2 from "primeng/api";
|
|
9
|
-
import * as i3 from "../../services/avatar-generator";
|
|
10
|
-
import * as i4 from "primeng/table";
|
|
11
|
-
import * as i5 from "primeng/avatar";
|
|
12
|
-
import * as i6 from "primeng/tristatecheckbox";
|
|
13
|
-
import * as i7 from "primeng/toast";
|
|
14
|
-
import * as i8 from "primeng/confirmdialog";
|
|
15
|
-
import * as i9 from "@angular/common";
|
|
16
|
-
import * as i10 from "primeng/tooltip";
|
|
17
|
-
import * as i11 from "@angular/router";
|
|
18
|
-
import * as i12 from "primeng/button";
|
|
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 = {}));
|
|
27
|
-
export class RESTworldListViewComponent {
|
|
28
|
-
constructor(_clients, _confirmationService, _messageService, avatarGenerator) {
|
|
29
|
-
this._clients = _clients;
|
|
30
|
-
this._confirmationService = _confirmationService;
|
|
31
|
-
this._messageService = _messageService;
|
|
32
|
-
this.avatarGenerator = avatarGenerator;
|
|
33
|
-
this._columns = [];
|
|
34
|
-
this._editLink = '/edit';
|
|
35
|
-
this.isLoading = false;
|
|
36
|
-
this._totalRecords = 0;
|
|
37
|
-
this.rowsPerPage = [10, 25, 50];
|
|
38
|
-
this._lastEvent = {
|
|
39
|
-
rows: this.rowsPerPage[0]
|
|
40
|
-
};
|
|
41
|
-
}
|
|
42
|
-
get columns() {
|
|
43
|
-
return this._columns;
|
|
44
|
-
}
|
|
45
|
-
set editLink(value) {
|
|
46
|
-
if (value)
|
|
47
|
-
this._editLink = value;
|
|
48
|
-
}
|
|
49
|
-
get editLink() {
|
|
50
|
-
return this._editLink;
|
|
51
|
-
}
|
|
52
|
-
set apiName(value) {
|
|
53
|
-
this._apiName = value;
|
|
54
|
-
if (this.apiName && this.rel && this._lastEvent)
|
|
55
|
-
this.load(this._lastEvent);
|
|
56
|
-
}
|
|
57
|
-
get apiName() {
|
|
58
|
-
return this._apiName;
|
|
59
|
-
}
|
|
60
|
-
set rel(value) {
|
|
61
|
-
this._rel = value;
|
|
62
|
-
if (this.apiName && this.rel && this._lastEvent)
|
|
63
|
-
this.load(this._lastEvent);
|
|
64
|
-
}
|
|
65
|
-
get rel() {
|
|
66
|
-
return this._rel;
|
|
67
|
-
}
|
|
68
|
-
get value() {
|
|
69
|
-
var _a, _b;
|
|
70
|
-
return ((_b = (_a = this.resource) === null || _a === void 0 ? void 0 : _a._embedded) === null || _b === void 0 ? void 0 : _b.items) || [];
|
|
71
|
-
}
|
|
72
|
-
get rows() {
|
|
73
|
-
var _a;
|
|
74
|
-
return ((_a = this._lastEvent) === null || _a === void 0 ? void 0 : _a.rows) || 0;
|
|
75
|
-
}
|
|
76
|
-
get totalRecords() {
|
|
77
|
-
return this._totalRecords;
|
|
78
|
-
}
|
|
79
|
-
set totalRecords(value) {
|
|
80
|
-
this._totalRecords = value || 0;
|
|
81
|
-
}
|
|
82
|
-
get sortOrder() {
|
|
83
|
-
return this._lastEvent.sortOrder || 0;
|
|
84
|
-
}
|
|
85
|
-
get newHref() {
|
|
86
|
-
var _a, _b;
|
|
87
|
-
return (_b = (_a = this.resource) === null || _a === void 0 ? void 0 : _a.findLink('new')) === null || _b === void 0 ? void 0 : _b.href;
|
|
88
|
-
}
|
|
89
|
-
get dateFormat() {
|
|
90
|
-
return RESTworldListViewComponent._dateFormat;
|
|
91
|
-
}
|
|
92
|
-
getClient() {
|
|
93
|
-
if (!this.apiName)
|
|
94
|
-
throw new Error('Cannot get a client, because the apiName is not set.');
|
|
95
|
-
return this._clients.getClient(this.apiName);
|
|
96
|
-
}
|
|
97
|
-
load(event) {
|
|
98
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
99
|
-
if (!this.apiName || !this.rel)
|
|
100
|
-
return;
|
|
101
|
-
this.isLoading = true;
|
|
102
|
-
this._lastEvent = event;
|
|
103
|
-
const parameters = this.createParametersFromEvent(event);
|
|
104
|
-
const response = yield this.getClient().getList(this.rel, parameters);
|
|
105
|
-
if (!response.ok || ProblemDetails.isProblemDetails(response.body) || !response.body) {
|
|
106
|
-
this._messageService.add({ severity: 'error', summary: 'Error', detail: 'Error while loading the resources from the API.', data: response });
|
|
107
|
-
}
|
|
108
|
-
else if (response.body) {
|
|
109
|
-
this.resource = response.body;
|
|
110
|
-
this.totalRecords = this.resource.totalPages && parameters.$top ? this.resource.totalPages * parameters.$top : undefined;
|
|
111
|
-
this._columns = this.createColumns();
|
|
112
|
-
}
|
|
113
|
-
this.isLoading = false;
|
|
114
|
-
});
|
|
115
|
-
}
|
|
116
|
-
showDeleteConfirmatioModal(resource) {
|
|
117
|
-
this._confirmationService.confirm({
|
|
118
|
-
message: 'Do you really want to delete this resource?',
|
|
119
|
-
header: 'Confirm delete',
|
|
120
|
-
icon: 'far fa-trash-alt',
|
|
121
|
-
accept: () => this.delete(resource)
|
|
122
|
-
});
|
|
123
|
-
}
|
|
124
|
-
delete(resource) {
|
|
125
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
126
|
-
if (!this.apiName || !this.rel)
|
|
127
|
-
return;
|
|
128
|
-
yield this.getClient().delete(resource);
|
|
129
|
-
this._messageService.add({ severity: 'success', summary: 'Deleted', detail: 'The resource has been deleted.' });
|
|
130
|
-
this.load(this._lastEvent);
|
|
131
|
-
});
|
|
132
|
-
}
|
|
133
|
-
createColumns() {
|
|
134
|
-
if (this.value.length === 0)
|
|
135
|
-
return this.columns;
|
|
136
|
-
// Get all distinct properties from all rows
|
|
137
|
-
// We look at all rows to eliminate possible undefined values
|
|
138
|
-
const rowsWithProperties = this.value
|
|
139
|
-
.map(resource => Object.entries(resource)
|
|
140
|
-
.filter(p => p[0] !== '_links' &&
|
|
141
|
-
p[0] !== '_embedded' &&
|
|
142
|
-
p[0] !== 'id' &&
|
|
143
|
-
p[0] !== 'timestamp'));
|
|
144
|
-
const distinctProperties = rowsWithProperties[0];
|
|
145
|
-
for (const propertiesOfRow of rowsWithProperties) {
|
|
146
|
-
for (const property of propertiesOfRow) {
|
|
147
|
-
const propertyName = property[0];
|
|
148
|
-
const propertyValue = property[1];
|
|
149
|
-
const alreadyFoundPropertyWithSameName = distinctProperties.find(p => p[0] === propertyName);
|
|
150
|
-
if (!alreadyFoundPropertyWithSameName) // Add new property
|
|
151
|
-
distinctProperties.push(property);
|
|
152
|
-
else if (!alreadyFoundPropertyWithSameName[1] && propertyValue) // Use defined value instead of existing undefined value
|
|
153
|
-
alreadyFoundPropertyWithSameName[1] = propertyValue;
|
|
154
|
-
}
|
|
155
|
-
}
|
|
156
|
-
// Check if the rows are entities with change tracking
|
|
157
|
-
const withoutChangeTrackingProperties = distinctProperties.filter(p => p[0] !== 'createdAt' &&
|
|
158
|
-
p[0] !== 'createdBy' &&
|
|
159
|
-
p[0] !== 'lastChangedAt' &&
|
|
160
|
-
p[0] !== 'lastChangedBy');
|
|
161
|
-
const hasChangeTrackingProperties = withoutChangeTrackingProperties.length < distinctProperties.length;
|
|
162
|
-
// First the id, then all other properties
|
|
163
|
-
const sortedProperties = [
|
|
164
|
-
['id', 0],
|
|
165
|
-
...withoutChangeTrackingProperties
|
|
166
|
-
];
|
|
167
|
-
// And change tracking properties at the end
|
|
168
|
-
if (hasChangeTrackingProperties) {
|
|
169
|
-
sortedProperties.push(['createdAt', new Date()]);
|
|
170
|
-
sortedProperties.push(['createdBy', '']);
|
|
171
|
-
sortedProperties.push(['lastChangedAt', new Date()]);
|
|
172
|
-
sortedProperties.push(['lastChangedBy', '']);
|
|
173
|
-
}
|
|
174
|
-
const columns = sortedProperties
|
|
175
|
-
.map(p => ({
|
|
176
|
-
header: RESTworldListViewComponent.toTitleCase(p[0]),
|
|
177
|
-
field: p[0],
|
|
178
|
-
type: RESTworldListViewComponent.getColumnType(p[1]),
|
|
179
|
-
}));
|
|
180
|
-
return columns;
|
|
181
|
-
}
|
|
182
|
-
static getColumnType(value) {
|
|
183
|
-
if (value === null || value === undefined)
|
|
184
|
-
return ColumnType.text;
|
|
185
|
-
if (_.isNumber(value))
|
|
186
|
-
return ColumnType.numeric;
|
|
187
|
-
if (_.isDate(value))
|
|
188
|
-
return ColumnType.date;
|
|
189
|
-
if (_.isString(value))
|
|
190
|
-
return ColumnType.text;
|
|
191
|
-
if (_.isBoolean(value))
|
|
192
|
-
return ColumnType.boolean;
|
|
193
|
-
return ColumnType.text;
|
|
194
|
-
}
|
|
195
|
-
static toTitleCase(anyCase) {
|
|
196
|
-
return anyCase
|
|
197
|
-
.replace(/(_)+/g, ' ') // underscore to whitespace
|
|
198
|
-
.replace(/([a-z])([A-Z][a-z])/g, "$1 $2") // insert space before each new word if there is none
|
|
199
|
-
.replace(/([A-Z][a-z])([A-Z])/g, "$1 $2") // insert space after each word if there is none
|
|
200
|
-
.replace(/([a-z])([A-Z]+[a-z])/g, "$1 $2") // insert space after single letter word if there is none
|
|
201
|
-
.replace(/([A-Z]+)([A-Z][a-z][a-z])/g, "$1 $2") // insert space before single letter word if there is none
|
|
202
|
-
.replace(/([a-z]+)([A-Z0-9]+)/g, "$1 $2") // insert space after numbers
|
|
203
|
-
.replace(/^./, (match) => match.toUpperCase()); // change first letter to be upper case
|
|
204
|
-
}
|
|
205
|
-
createParametersFromEvent(event) {
|
|
206
|
-
const oDataParameters = {
|
|
207
|
-
$filter: this.createFilterFromEvent(event),
|
|
208
|
-
$orderby: RESTworldListViewComponent.createOrderByFromEvent(event),
|
|
209
|
-
$top: RESTworldListViewComponent.createTopFromEvent(event),
|
|
210
|
-
$skip: RESTworldListViewComponent.createSkipFromEvent(event)
|
|
211
|
-
};
|
|
212
|
-
return oDataParameters;
|
|
213
|
-
}
|
|
214
|
-
static createSkipFromEvent(event) {
|
|
215
|
-
return event.first;
|
|
216
|
-
}
|
|
217
|
-
static createTopFromEvent(event) {
|
|
218
|
-
return event.rows;
|
|
219
|
-
}
|
|
220
|
-
static createOrderByFromEvent(event) {
|
|
221
|
-
if (event.sortField) {
|
|
222
|
-
const order = !event.sortOrder || event.sortOrder > 0 ? 'asc' : 'desc';
|
|
223
|
-
return `${event.sortField} ${order}`;
|
|
224
|
-
}
|
|
225
|
-
return undefined;
|
|
226
|
-
}
|
|
227
|
-
createFilterFromEvent(event) {
|
|
228
|
-
if (!event.filters)
|
|
229
|
-
return undefined;
|
|
230
|
-
const filter = Object.entries(event.filters)
|
|
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)
|
|
235
|
-
.join(' and ');
|
|
236
|
-
if (filter === '')
|
|
237
|
-
return undefined;
|
|
238
|
-
return `(${filter})`;
|
|
239
|
-
}
|
|
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) {
|
|
250
|
-
if (!filter.value)
|
|
251
|
-
return undefined;
|
|
252
|
-
const oDataOperator = RESTworldListViewComponent.createODataOperator(filter.matchMode);
|
|
253
|
-
const comparisonValue = this.createComparisonValue(property, filter.value);
|
|
254
|
-
switch (oDataOperator) {
|
|
255
|
-
case 'contains':
|
|
256
|
-
case 'not contains':
|
|
257
|
-
case 'startswith':
|
|
258
|
-
case 'endswith':
|
|
259
|
-
return `${oDataOperator}(${property}, ${comparisonValue})`;
|
|
260
|
-
default:
|
|
261
|
-
return `${property} ${oDataOperator} ${comparisonValue}`;
|
|
262
|
-
}
|
|
263
|
-
}
|
|
264
|
-
static createODataOperator(matchMode) {
|
|
265
|
-
switch (matchMode) {
|
|
266
|
-
case FilterMatchMode.STARTS_WITH:
|
|
267
|
-
return 'startswith';
|
|
268
|
-
case FilterMatchMode.CONTAINS:
|
|
269
|
-
return 'contains';
|
|
270
|
-
case FilterMatchMode.NOT_CONTAINS:
|
|
271
|
-
return 'not contains';
|
|
272
|
-
case FilterMatchMode.ENDS_WITH:
|
|
273
|
-
return 'endswith';
|
|
274
|
-
case FilterMatchMode.EQUALS:
|
|
275
|
-
return 'eq';
|
|
276
|
-
case FilterMatchMode.NOT_EQUALS:
|
|
277
|
-
return 'ne';
|
|
278
|
-
case FilterMatchMode.IN:
|
|
279
|
-
return 'in';
|
|
280
|
-
case FilterMatchMode.LESS_THAN:
|
|
281
|
-
return 'lt';
|
|
282
|
-
case FilterMatchMode.LESS_THAN_OR_EQUAL_TO:
|
|
283
|
-
return 'le';
|
|
284
|
-
case FilterMatchMode.GREATER_THAN:
|
|
285
|
-
return 'gt';
|
|
286
|
-
case FilterMatchMode.GREATER_THAN_OR_EQUAL_TO:
|
|
287
|
-
return 'ge';
|
|
288
|
-
case FilterMatchMode.IS:
|
|
289
|
-
return 'eq';
|
|
290
|
-
case FilterMatchMode.IS_NOT:
|
|
291
|
-
return 'ne';
|
|
292
|
-
case FilterMatchMode.BEFORE:
|
|
293
|
-
return 'lt';
|
|
294
|
-
case FilterMatchMode.AFTER:
|
|
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';
|
|
304
|
-
default:
|
|
305
|
-
throw Error(`Unknown matchMode ${matchMode}`);
|
|
306
|
-
}
|
|
307
|
-
}
|
|
308
|
-
createComparisonValue(property, value) {
|
|
309
|
-
if (value === null || value === undefined)
|
|
310
|
-
return 'null';
|
|
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}'`);
|
|
326
|
-
}
|
|
327
|
-
}
|
|
328
|
-
}
|
|
329
|
-
RESTworldListViewComponent._dateFormat = new Date(3333, 10, 22)
|
|
330
|
-
.toLocaleDateString()
|
|
331
|
-
.replace("22", "dd")
|
|
332
|
-
.replace("11", "MM")
|
|
333
|
-
.replace("3333", "y")
|
|
334
|
-
.replace("33", "yy");
|
|
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 });
|
|
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 } });
|
|
337
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.11", ngImport: i0, type: RESTworldListViewComponent, decorators: [{
|
|
338
|
-
type: Component,
|
|
339
|
-
args: [{
|
|
340
|
-
selector: 'rw-list',
|
|
341
|
-
templateUrl: './restworld-list-view.component.html',
|
|
342
|
-
styleUrls: ['./restworld-list-view.component.css']
|
|
343
|
-
}]
|
|
344
|
-
}], ctorParameters: function () { return [{ type: i1.RESTworldClientCollection }, { type: i2.ConfirmationService }, { type: i2.MessageService }, { type: i3.AvatarGenerator }]; }, propDecorators: { editLink: [{
|
|
345
|
-
type: Input
|
|
346
|
-
}], apiName: [{
|
|
347
|
-
type: Input
|
|
348
|
-
}], rel: [{
|
|
349
|
-
type: Input
|
|
350
|
-
}], rowsPerPage: [{
|
|
351
|
-
type: Input
|
|
352
|
-
}] } });
|
|
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"]}
|