@wertzui/ngx-restworld-client 7.1.1 → 7.2.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.
- package/esm2020/lib/components/restworld-avatar/restworld-avatar.component.mjs +33 -0
- package/esm2020/lib/restworld-client.module.mjs +14 -4
- package/esm2020/lib/services/avatar-generator.mjs +14 -16
- package/esm2020/lib/views/restworld-list-view/restworld-list-view.component.mjs +5 -5
- package/esm2020/public-api.mjs +2 -1
- package/fesm2015/wertzui-ngx-restworld-client.mjs +161 -119
- package/fesm2015/wertzui-ngx-restworld-client.mjs.map +1 -1
- package/fesm2020/wertzui-ngx-restworld-client.mjs +135 -101
- package/fesm2020/wertzui-ngx-restworld-client.mjs.map +1 -1
- package/lib/components/restworld-avatar/restworld-avatar.component.d.ts +21 -0
- package/lib/restworld-client.module.d.ts +34 -33
- package/lib/services/avatar-generator.d.ts +6 -5
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "../../services/avatar-generator";
|
|
4
|
+
import * as i2 from "primeng/tooltip";
|
|
5
|
+
import * as i3 from "primeng/avatar";
|
|
6
|
+
export class RestWorldAvatarComponent {
|
|
7
|
+
constructor(_generator) {
|
|
8
|
+
this._generator = _generator;
|
|
9
|
+
this._image = '';
|
|
10
|
+
this._label = '';
|
|
11
|
+
this._style = '';
|
|
12
|
+
}
|
|
13
|
+
get image() { return this._image; }
|
|
14
|
+
get label() { return this._label; }
|
|
15
|
+
get style() { return this._style; }
|
|
16
|
+
get tooltip() { return this.user ?? ''; }
|
|
17
|
+
async ngOnInit() {
|
|
18
|
+
if (this.user === undefined || this.user === null)
|
|
19
|
+
return;
|
|
20
|
+
this._image = await this._generator.getImageAsync(this.user);
|
|
21
|
+
this._label = await this._generator.getLabelAsync(this.user);
|
|
22
|
+
this._style = await this._generator.getStyleAsync(this.user);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
RestWorldAvatarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: RestWorldAvatarComponent, deps: [{ token: i1.AvatarGenerator }], target: i0.ɵɵFactoryTarget.Component });
|
|
26
|
+
RestWorldAvatarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: RestWorldAvatarComponent, selector: "rw-avatar", inputs: { user: "user" }, ngImport: i0, template: "<p-avatar [pTooltip]=\"tooltip\" tooltipPosition=\"top\" [image]=\"image\" [label]=\"label\" [style]=\"style\" shape=\"circle\"></p-avatar>\n", styles: [""], dependencies: [{ kind: "directive", type: i2.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "fitContent", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "component", type: i3.Avatar, selector: "p-avatar", inputs: ["label", "icon", "image", "size", "shape", "style", "styleClass"], outputs: ["onImageError"] }] });
|
|
27
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: RestWorldAvatarComponent, decorators: [{
|
|
28
|
+
type: Component,
|
|
29
|
+
args: [{ selector: 'rw-avatar', template: "<p-avatar [pTooltip]=\"tooltip\" tooltipPosition=\"top\" [image]=\"image\" [label]=\"label\" [style]=\"style\" shape=\"circle\"></p-avatar>\n" }]
|
|
30
|
+
}], ctorParameters: function () { return [{ type: i1.AvatarGenerator }]; }, propDecorators: { user: [{
|
|
31
|
+
type: Input
|
|
32
|
+
}] } });
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzdHdvcmxkLWF2YXRhci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtcmVzdHdvcmxkLWNsaWVudC9zcmMvbGliL2NvbXBvbmVudHMvcmVzdHdvcmxkLWF2YXRhci9yZXN0d29ybGQtYXZhdGFyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1yZXN0d29ybGQtY2xpZW50L3NyYy9saWIvY29tcG9uZW50cy9yZXN0d29ybGQtYXZhdGFyL3Jlc3R3b3JsZC1hdmF0YXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQVUsTUFBTSxlQUFlLENBQUM7Ozs7O0FBU3pELE1BQU0sT0FBTyx3QkFBd0I7SUFZbkMsWUFDbUIsVUFBMkI7UUFBM0IsZUFBVSxHQUFWLFVBQVUsQ0FBaUI7UUFUdEMsV0FBTSxHQUFZLEVBQUUsQ0FBQztRQUVyQixXQUFNLEdBQVcsRUFBRSxDQUFDO1FBRXBCLFdBQU0sR0FBdUQsRUFBRSxDQUFDO0lBUXhFLENBQUM7SUFYRCxJQUFXLEtBQUssS0FBYSxPQUFPLElBQUksQ0FBQyxNQUFnQixDQUFDLENBQUMsQ0FBQztJQUU1RCxJQUFXLEtBQUssS0FBYSxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO0lBRWxELElBQVcsS0FBSyxLQUEwRCxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO0lBQy9GLElBQVcsT0FBTyxLQUFhLE9BQU8sSUFBSSxDQUFDLElBQUksSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBUXhELEtBQUssQ0FBQyxRQUFRO1FBQ1osSUFBRyxJQUFJLENBQUMsSUFBSSxLQUFLLFNBQVMsSUFBSSxJQUFJLENBQUMsSUFBSSxLQUFLLElBQUk7WUFDOUMsT0FBTztRQUVULElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDN0QsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUM3RCxJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQy9ELENBQUM7O3FIQXpCVSx3QkFBd0I7eUdBQXhCLHdCQUF3QiwyRUNUckMsK0lBQ0E7MkZEUWEsd0JBQXdCO2tCQUxwQyxTQUFTOytCQUNFLFdBQVc7c0dBTXJCLElBQUk7c0JBREgsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU2FmZVVybCB9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xuaW1wb3J0IHsgQXZhdGFyR2VuZXJhdG9yIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvYXZhdGFyLWdlbmVyYXRvcic7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3J3LWF2YXRhcicsXG4gIHRlbXBsYXRlVXJsOiAnLi9yZXN0d29ybGQtYXZhdGFyLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vcmVzdHdvcmxkLWF2YXRhci5jb21wb25lbnQuY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgUmVzdFdvcmxkQXZhdGFyQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0e1xuICBASW5wdXQoKVxuICB1c2VyPzogc3RyaW5nO1xuXG4gIHByaXZhdGUgX2ltYWdlOiBTYWZlVXJsID0gJyc7XG4gIHB1YmxpYyBnZXQgaW1hZ2UoKTogc3RyaW5nIHsgcmV0dXJuIHRoaXMuX2ltYWdlIGFzIHN0cmluZzsgfVxuICBwcml2YXRlIF9sYWJlbDogc3RyaW5nID0gJyc7XG4gIHB1YmxpYyBnZXQgbGFiZWwoKTogc3RyaW5nIHsgcmV0dXJuIHRoaXMuX2xhYmVsOyB9XG4gIHByaXZhdGUgX3N0eWxlOiAnJyB8IHsgJ2JhY2tncm91bmQtY29sb3InOiBzdHJpbmc7IGNvbG9yOiBzdHJpbmcgfSA9ICcnO1xuICBwdWJsaWMgZ2V0IHN0eWxlKCk6ICcnIHwgeyAnYmFja2dyb3VuZC1jb2xvcic6IHN0cmluZzsgY29sb3I6IHN0cmluZzsgfSB7IHJldHVybiB0aGlzLl9zdHlsZTsgfVxuICBwdWJsaWMgZ2V0IHRvb2x0aXAoKTogc3RyaW5nIHsgcmV0dXJuIHRoaXMudXNlciA/PyAnJzsgfVxuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgcmVhZG9ubHkgX2dlbmVyYXRvcjogQXZhdGFyR2VuZXJhdG9yXG4gICkge1xuXG4gIH1cblxuICBhc3luYyBuZ09uSW5pdCgpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBpZih0aGlzLnVzZXIgPT09IHVuZGVmaW5lZCB8fCB0aGlzLnVzZXIgPT09IG51bGwpXG4gICAgICByZXR1cm47XG5cbiAgICB0aGlzLl9pbWFnZSA9IGF3YWl0IHRoaXMuX2dlbmVyYXRvci5nZXRJbWFnZUFzeW5jKHRoaXMudXNlcik7XG4gICAgdGhpcy5fbGFiZWwgPSBhd2FpdCB0aGlzLl9nZW5lcmF0b3IuZ2V0TGFiZWxBc3luYyh0aGlzLnVzZXIpO1xuICAgIHRoaXMuX3N0eWxlID0gYXdhaXQgdGhpcy5fZ2VuZXJhdG9yLmdldFN0eWxlQXN5bmModGhpcy51c2VyKTtcbiAgfVxufVxuIiwiPHAtYXZhdGFyIFtwVG9vbHRpcF09XCJ0b29sdGlwXCIgdG9vbHRpcFBvc2l0aW9uPVwidG9wXCIgW2ltYWdlXT1cImltYWdlXCIgW2xhYmVsXT1cImxhYmVsXCIgW3N0eWxlXT1cInN0eWxlXCIgc2hhcGU9XCJjaXJjbGVcIj48L3AtYXZhdGFyPlxuIl19
|
|
@@ -41,6 +41,7 @@ import { RestworldEditFormComponent } from './views/restworld-edit-form/restworl
|
|
|
41
41
|
import { FormService } from './services/form.service';
|
|
42
42
|
import { AsPipe } from './pipes/as.pipe';
|
|
43
43
|
import { SplitButtonModule } from 'primeng/splitbutton';
|
|
44
|
+
import { RestWorldAvatarComponent } from './components/restworld-avatar/restworld-avatar.component';
|
|
44
45
|
import * as i0 from "@angular/core";
|
|
45
46
|
export function initializeSettings(settingsService) {
|
|
46
47
|
return async () => await settingsService.ensureInitialized();
|
|
@@ -53,8 +54,10 @@ RestworldClientModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", v
|
|
|
53
54
|
RESTWorldImageViewComponent,
|
|
54
55
|
RESTWorldFileViewComponent,
|
|
55
56
|
RestworldEditFormComponent,
|
|
57
|
+
RestWorldAvatarComponent,
|
|
56
58
|
SafeUrlPipe,
|
|
57
|
-
AsPipe
|
|
59
|
+
AsPipe,
|
|
60
|
+
RestWorldAvatarComponent], imports: [CommonModule,
|
|
58
61
|
RouterModule,
|
|
59
62
|
FormsModule,
|
|
60
63
|
ReactiveFormsModule,
|
|
@@ -84,11 +87,13 @@ RestworldClientModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", v
|
|
|
84
87
|
ButtonModule,
|
|
85
88
|
ColorPickerModule,
|
|
86
89
|
DragDropModule,
|
|
87
|
-
SplitButtonModule
|
|
90
|
+
SplitButtonModule,
|
|
91
|
+
AvatarModule], exports: [RESTworldListViewComponent,
|
|
88
92
|
RESTworldEditViewComponent,
|
|
89
93
|
RESTWorldImageViewComponent,
|
|
90
94
|
RESTWorldFileViewComponent,
|
|
91
95
|
RestworldEditFormComponent,
|
|
96
|
+
RestWorldAvatarComponent,
|
|
92
97
|
SafeUrlPipe,
|
|
93
98
|
AsPipe] });
|
|
94
99
|
RestworldClientModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: RestworldClientModule, providers: [
|
|
@@ -133,7 +138,8 @@ RestworldClientModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", v
|
|
|
133
138
|
ButtonModule,
|
|
134
139
|
ColorPickerModule,
|
|
135
140
|
DragDropModule,
|
|
136
|
-
SplitButtonModule
|
|
141
|
+
SplitButtonModule,
|
|
142
|
+
AvatarModule] });
|
|
137
143
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: RestworldClientModule, decorators: [{
|
|
138
144
|
type: NgModule,
|
|
139
145
|
args: [{
|
|
@@ -143,8 +149,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
|
|
|
143
149
|
RESTWorldImageViewComponent,
|
|
144
150
|
RESTWorldFileViewComponent,
|
|
145
151
|
RestworldEditFormComponent,
|
|
152
|
+
RestWorldAvatarComponent,
|
|
146
153
|
SafeUrlPipe,
|
|
147
154
|
AsPipe,
|
|
155
|
+
RestWorldAvatarComponent,
|
|
148
156
|
],
|
|
149
157
|
imports: [
|
|
150
158
|
CommonModule,
|
|
@@ -178,6 +186,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
|
|
|
178
186
|
ColorPickerModule,
|
|
179
187
|
DragDropModule,
|
|
180
188
|
SplitButtonModule,
|
|
189
|
+
AvatarModule
|
|
181
190
|
],
|
|
182
191
|
exports: [
|
|
183
192
|
RESTworldListViewComponent,
|
|
@@ -185,6 +194,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
|
|
|
185
194
|
RESTWorldImageViewComponent,
|
|
186
195
|
RESTWorldFileViewComponent,
|
|
187
196
|
RestworldEditFormComponent,
|
|
197
|
+
RestWorldAvatarComponent,
|
|
188
198
|
SafeUrlPipe,
|
|
189
199
|
AsPipe
|
|
190
200
|
],
|
|
@@ -203,4 +213,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
|
|
|
203
213
|
]
|
|
204
214
|
}]
|
|
205
215
|
}] });
|
|
206
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restworld-client.module.js","sourceRoot":"","sources":["../../../../projects/ngx-restworld-client/src/lib/restworld-client.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { APP_INITIALIZER, NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { ScrollingModule } from '@angular/cdk/scrolling';\r\nimport { DragDropModule } from '@angular/cdk/drag-drop';\r\nimport { RouterModule } from '@angular/router';\r\n\r\nimport { TableModule } from 'primeng/table';\r\nimport { TooltipModule } from 'primeng/tooltip'\r\nimport { ReactiveFormsModule, FormsModule } from '@angular/forms';\r\nimport { InputTextModule } from 'primeng/inputtext';\r\nimport { InputNumberModule } from 'primeng/inputnumber';\r\nimport { CalendarModule } from 'primeng/calendar';\r\nimport { CheckboxModule } from 'primeng/checkbox';\r\nimport { ConfirmDialogModule } from 'primeng/confirmdialog';\r\nimport { ConfirmationService, MessageService } from 'primeng/api';\r\nimport { ToastModule } from 'primeng/toast';\r\nimport { MessagesModule } from 'primeng/messages';\r\nimport { PanelModule } from 'primeng/panel';\r\nimport { TabViewModule } from 'primeng/tabview';\r\nimport { SkeletonModule } from 'primeng/skeleton';\r\nimport { ProgressSpinnerModule } from 'primeng/progressspinner';\r\nimport { RippleModule } from 'primeng/ripple';\r\nimport { TriStateCheckboxModule } from 'primeng/tristatecheckbox';\r\nimport { AvatarModule } from 'primeng/avatar';\r\nimport { DropdownModule } from 'primeng/dropdown';\r\nimport { MultiSelectModule } from 'primeng/multiselect';\r\nimport { FileUploadModule } from 'primeng/fileupload';\r\nimport { ValdemortModule } from 'ngx-valdemort';\r\nimport { ImageCropperModule } from 'ngx-image-cropper';\r\nimport { DialogModule } from 'primeng/dialog';\r\nimport { ColorPickerModule } from 'primeng/colorpicker';\r\n\r\nimport { RESTworldListViewComponent } from './views/restworld-list-view/restworld-list-view.component';\r\nimport { RESTworldEditViewComponent } from './views/restworld-edit-view/restworld-edit-view.component';\r\nimport { RESTworldClientCollection } from './services/restworld-client-collection';\r\nimport { AvatarGenerator } from './services/avatar-generator';\r\nimport { SettingsService } from './services/settings.service';\nimport { RESTWorldImageViewComponent } from './views/restworld-image-view/restworld-image-view.component';\r\nimport { ButtonModule } from 'primeng/button';\nimport { RESTWorldFileViewComponent } from './views/restworld-file-view/restworld-file-view.component';\r\nimport { SafeUrlPipe } from './pipes/safe-url.pipe';\nimport { RestworldEditFormComponent } from './views/restworld-edit-form/restworld-edit-form.component'\r\nimport { FormService } from './services/form.service';\r\nimport { AsPipe } from './pipes/as.pipe';\r\nimport { SplitButtonModule } from 'primeng/splitbutton';\r\n\r\nexport function initializeSettings(settingsService: SettingsService): () => Promise<void> {\r\n  return async () => await settingsService.ensureInitialized();\r\n}\r\n\r\n@NgModule({\r\n  declarations: [\r\n    RESTworldListViewComponent,\r\n    RESTworldEditViewComponent,\r\n    RESTWorldImageViewComponent,\r\n    RESTWorldFileViewComponent,\r\n    RestworldEditFormComponent,\r\n    SafeUrlPipe,\r\n    AsPipe,\r\n  ],\r\n  imports: [\r\n    CommonModule,\r\n    RouterModule,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    TableModule,\r\n    TooltipModule,\r\n    ScrollingModule,\r\n    InputTextModule,\r\n    InputNumberModule,\r\n    CalendarModule,\r\n    CheckboxModule,\r\n    ConfirmDialogModule,\r\n    ToastModule,\r\n    MessagesModule,\r\n    PanelModule,\r\n    TabViewModule,\r\n    SkeletonModule,\r\n    ProgressSpinnerModule,\r\n    RippleModule,\r\n    TriStateCheckboxModule,\r\n    AvatarModule,\r\n    DropdownModule,\r\n    MultiSelectModule,\r\n    FileUploadModule,\r\n    ValdemortModule,\r\n    ImageCropperModule,\r\n    DialogModule,\r\n    ButtonModule,\r\n    ColorPickerModule,\r\n    DragDropModule,\r\n    SplitButtonModule,\r\n  ],\r\n  exports: [\r\n    RESTworldListViewComponent,\r\n    RESTworldEditViewComponent,\r\n    RESTWorldImageViewComponent,\r\n    RESTWorldFileViewComponent,\r\n    RestworldEditFormComponent,\r\n    SafeUrlPipe,\r\n    AsPipe\r\n  ],\r\n  providers: [\r\n    RESTworldClientCollection,\r\n    AvatarGenerator,\r\n    ConfirmationService,\r\n    FormService,\r\n    MessageService,\r\n    {\r\n      provide: APP_INITIALIZER,\r\n      useFactory: initializeSettings,\r\n      deps: [SettingsService],\r\n      multi: true,\r\n    }\r\n  ]\r\n})\r\nexport class RestworldClientModule { }\r\n"]}
|
|
216
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restworld-client.module.js","sourceRoot":"","sources":["../../../../projects/ngx-restworld-client/src/lib/restworld-client.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { APP_INITIALIZER, NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { ScrollingModule } from '@angular/cdk/scrolling';\r\nimport { DragDropModule } from '@angular/cdk/drag-drop';\r\nimport { RouterModule } from '@angular/router';\r\n\r\nimport { TableModule } from 'primeng/table';\r\nimport { TooltipModule } from 'primeng/tooltip'\r\nimport { ReactiveFormsModule, FormsModule } from '@angular/forms';\r\nimport { InputTextModule } from 'primeng/inputtext';\r\nimport { InputNumberModule } from 'primeng/inputnumber';\r\nimport { CalendarModule } from 'primeng/calendar';\r\nimport { CheckboxModule } from 'primeng/checkbox';\r\nimport { ConfirmDialogModule } from 'primeng/confirmdialog';\r\nimport { ConfirmationService, MessageService } from 'primeng/api';\r\nimport { ToastModule } from 'primeng/toast';\r\nimport { MessagesModule } from 'primeng/messages';\r\nimport { PanelModule } from 'primeng/panel';\r\nimport { TabViewModule } from 'primeng/tabview';\r\nimport { SkeletonModule } from 'primeng/skeleton';\r\nimport { ProgressSpinnerModule } from 'primeng/progressspinner';\r\nimport { RippleModule } from 'primeng/ripple';\r\nimport { TriStateCheckboxModule } from 'primeng/tristatecheckbox';\r\nimport { AvatarModule } from 'primeng/avatar';\r\nimport { DropdownModule } from 'primeng/dropdown';\r\nimport { MultiSelectModule } from 'primeng/multiselect';\r\nimport { FileUploadModule } from 'primeng/fileupload';\r\nimport { ValdemortModule } from 'ngx-valdemort';\r\nimport { ImageCropperModule } from 'ngx-image-cropper';\r\nimport { DialogModule } from 'primeng/dialog';\r\nimport { ColorPickerModule } from 'primeng/colorpicker';\r\n\r\nimport { RESTworldListViewComponent } from './views/restworld-list-view/restworld-list-view.component';\r\nimport { RESTworldEditViewComponent } from './views/restworld-edit-view/restworld-edit-view.component';\r\nimport { RESTworldClientCollection } from './services/restworld-client-collection';\r\nimport { AvatarGenerator } from './services/avatar-generator';\r\nimport { SettingsService } from './services/settings.service';\r\nimport { RESTWorldImageViewComponent } from './views/restworld-image-view/restworld-image-view.component';\r\nimport { ButtonModule } from 'primeng/button';\r\nimport { RESTWorldFileViewComponent } from './views/restworld-file-view/restworld-file-view.component';\r\nimport { SafeUrlPipe } from './pipes/safe-url.pipe';\r\nimport { RestworldEditFormComponent } from './views/restworld-edit-form/restworld-edit-form.component'\r\nimport { FormService } from './services/form.service';\r\nimport { AsPipe } from './pipes/as.pipe';\r\nimport { SplitButtonModule } from 'primeng/splitbutton';\r\nimport { RestWorldAvatarComponent } from './components/restworld-avatar/restworld-avatar.component';\r\n\r\nexport function initializeSettings(settingsService: SettingsService): () => Promise<void> {\r\n  return async () => await settingsService.ensureInitialized();\r\n}\r\n\r\n@NgModule({\r\n  declarations: [\r\n    RESTworldListViewComponent,\r\n    RESTworldEditViewComponent,\r\n    RESTWorldImageViewComponent,\r\n    RESTWorldFileViewComponent,\r\n    RestworldEditFormComponent,\r\n    RestWorldAvatarComponent,\r\n    SafeUrlPipe,\r\n    AsPipe,\r\n    RestWorldAvatarComponent,\r\n  ],\r\n  imports: [\r\n    CommonModule,\r\n    RouterModule,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    TableModule,\r\n    TooltipModule,\r\n    ScrollingModule,\r\n    InputTextModule,\r\n    InputNumberModule,\r\n    CalendarModule,\r\n    CheckboxModule,\r\n    ConfirmDialogModule,\r\n    ToastModule,\r\n    MessagesModule,\r\n    PanelModule,\r\n    TabViewModule,\r\n    SkeletonModule,\r\n    ProgressSpinnerModule,\r\n    RippleModule,\r\n    TriStateCheckboxModule,\r\n    AvatarModule,\r\n    DropdownModule,\r\n    MultiSelectModule,\r\n    FileUploadModule,\r\n    ValdemortModule,\r\n    ImageCropperModule,\r\n    DialogModule,\r\n    ButtonModule,\r\n    ColorPickerModule,\r\n    DragDropModule,\r\n    SplitButtonModule,\r\n    AvatarModule\r\n  ],\r\n  exports: [\r\n    RESTworldListViewComponent,\r\n    RESTworldEditViewComponent,\r\n    RESTWorldImageViewComponent,\r\n    RESTWorldFileViewComponent,\r\n    RestworldEditFormComponent,\r\n    RestWorldAvatarComponent,\r\n    SafeUrlPipe,\r\n    AsPipe\r\n  ],\r\n  providers: [\r\n    RESTworldClientCollection,\r\n    AvatarGenerator,\r\n    ConfirmationService,\r\n    FormService,\r\n    MessageService,\r\n    {\r\n      provide: APP_INITIALIZER,\r\n      useFactory: initializeSettings,\r\n      deps: [SettingsService],\r\n      multi: true,\r\n    }\r\n  ]\r\n})\r\nexport class RestworldClientModule { }\r\n"]}
|
|
@@ -1,28 +1,28 @@
|
|
|
1
|
-
import { Injectable
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export class AvatarGenerator {
|
|
4
4
|
constructor() {
|
|
5
|
-
this.
|
|
5
|
+
this.getImageAsyncOverride = () => Promise.resolve('');
|
|
6
6
|
}
|
|
7
|
-
|
|
8
|
-
let
|
|
9
|
-
if (
|
|
10
|
-
|
|
11
|
-
AvatarGenerator._imageCache.set(nameOrEmail,
|
|
7
|
+
async getImageAsync(nameOrEmail) {
|
|
8
|
+
let promise = AvatarGenerator._imageCache.get(nameOrEmail);
|
|
9
|
+
if (promise === undefined) {
|
|
10
|
+
promise = this.getImageAsyncOverride(nameOrEmail);
|
|
11
|
+
AvatarGenerator._imageCache.set(nameOrEmail, promise);
|
|
12
12
|
}
|
|
13
|
-
return
|
|
13
|
+
return promise;
|
|
14
14
|
}
|
|
15
|
-
|
|
15
|
+
async getLabelAsync(nameOrEmail) {
|
|
16
16
|
if (!nameOrEmail)
|
|
17
17
|
return '';
|
|
18
|
-
if (this.
|
|
18
|
+
if (await this.getImageAsync(nameOrEmail))
|
|
19
19
|
return '';
|
|
20
20
|
const name = AvatarGenerator.getLocalPartOfEmailAddress(nameOrEmail);
|
|
21
21
|
const initials = AvatarGenerator.getTwoUppercaseLettersFromName(name);
|
|
22
22
|
return initials;
|
|
23
23
|
}
|
|
24
|
-
|
|
25
|
-
if (this.
|
|
24
|
+
async getStyleAsync(nameOrEmail) {
|
|
25
|
+
if (await this.getImageAsync(nameOrEmail))
|
|
26
26
|
return '';
|
|
27
27
|
const foregroundColor = '#ffffff';
|
|
28
28
|
const backgroundColor = AvatarGenerator.getBackgroundColor(nameOrEmail);
|
|
@@ -91,7 +91,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
|
|
|
91
91
|
args: [{
|
|
92
92
|
providedIn: 'root',
|
|
93
93
|
}]
|
|
94
|
-
}]
|
|
95
|
-
|
|
96
|
-
}] } });
|
|
97
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"avatar-generator.js","sourceRoot":"","sources":["../../../../../projects/ngx-restworld-client/src/lib/services/avatar-generator.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Input } from '@angular/core';\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class AvatarGenerator {\r\n  private static _nonWordRegex = new RegExp('\\\\W');\r\n  private static _imageCache: Map<string, string> = new Map<string, string>();\r\n\r\n  @Input()\r\n  public getImageOverride: (nameOrEmail: string) => string = () => '';\r\n\r\n  public getImage(nameOrEmail: string): string {\r\n    let uri = AvatarGenerator._imageCache.get(nameOrEmail);\r\n\r\n    if (!uri) {\r\n      uri = this.getImageOverride(nameOrEmail);\r\n      AvatarGenerator._imageCache.set(nameOrEmail, uri);\r\n    }\r\n\r\n    return uri;\r\n  }\r\n\r\n  public getLabel(nameOrEmail: string): string {\r\n    if (!nameOrEmail)\r\n      return '';\r\n\r\n    if (this.getImage(nameOrEmail))\r\n      return '';\r\n\r\n    const name = AvatarGenerator.getLocalPartOfEmailAddress(nameOrEmail);\r\n    const initials = AvatarGenerator.getTwoUppercaseLettersFromName(name);\r\n\r\n    return initials;\r\n  }\r\n\r\n  public getStyle(nameOrEmail: string,): '' | { 'background-color': string; color: string } {\r\n    if (this.getImage(nameOrEmail))\r\n      return '';\r\n\r\n    const foregroundColor = '#ffffff';\r\n    const backgroundColor = AvatarGenerator.getBackgroundColor(nameOrEmail);\r\n\r\n    const style = {\r\n      'background-color': backgroundColor,\r\n      color: foregroundColor,\r\n    };\r\n\r\n    return style;\r\n  }\r\n\r\n  private static getLocalPartOfEmailAddress(email: string): string {\r\n    const indexOfAt = email.indexOf('@');\r\n    if (indexOfAt < 2) {\r\n      if (indexOfAt >= 0) {\r\n        if (indexOfAt === email.length - 1)\r\n          return email.substring(0, indexOfAt);\r\n        return email.substring(indexOfAt + 1);\r\n      }\r\n    } else {\r\n      return email.substring(0, indexOfAt);\r\n    }\r\n\r\n    return email;\r\n  }\r\n\r\n  private static getTwoUppercaseLettersFromName(name: string): string {\r\n    // Too short to do anything besides just returning the name\r\n    if (name.length <= 2) {\r\n      return name.toUpperCase();\r\n    }\r\n\r\n    // Try to split by non word characters\r\n    const splittedByNonWord = name.split(AvatarGenerator._nonWordRegex);\r\n    if (splittedByNonWord.length > 1) {\r\n      return (splittedByNonWord[0][0] + splittedByNonWord[1][0]).toUpperCase();\r\n    }\r\n\r\n    // Try to split by upper case letters\r\n    const upperCaseLetters = [...name]\r\n      .filter((c) => c.toUpperCase() === c && !AvatarGenerator._nonWordRegex.test(c))\r\n      .join();\r\n    if (upperCaseLetters.length > 1) {\r\n      return upperCaseLetters.substring(0, 2);\r\n    }\r\n\r\n    // Just return the first 2 letters\r\n    return name.substring(0, 2).toUpperCase();\r\n  }\r\n\r\n  // from https://stackoverflow.com/a/66494926/1378307\r\n  private static getBackgroundColor(\r\n    text: string,\r\n    minLightness = 40,\r\n    maxLightness = 80,\r\n    minSaturation = 30,\r\n    maxSaturation = 100,\r\n  ): string {\r\n    if (!text) return '#aaa';\r\n\r\n    const hash = [...text].reduce((acc, char) => {\r\n      return char.charCodeAt(0) + ((acc << 5) - acc);\r\n    }, 0);\r\n\r\n    return (\r\n      'hsl(' +\r\n      (hash % 360) +\r\n      ', ' +\r\n      ((hash % (maxSaturation - minSaturation)) + minSaturation) +\r\n      '%, ' +\r\n      ((hash % (maxLightness - minLightness)) + minLightness) +\r\n      '%)'\r\n    );\r\n  }\r\n}\r\n"]}
|
|
94
|
+
}] });
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"avatar-generator.js","sourceRoot":"","sources":["../../../../../projects/ngx-restworld-client/src/lib/services/avatar-generator.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Input } from '@angular/core';\r\nimport { SafeUrl } from '@angular/platform-browser';\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class AvatarGenerator {\r\n  private static _nonWordRegex = new RegExp('\\\\W');\r\n  private static _imageCache: Map<string, SafeUrl> = new Map<string, SafeUrl>();\r\n\r\n  public getImageAsyncOverride: (nameOrEmail: string) => Promise<SafeUrl> = () => Promise.resolve('');\r\n\r\n  public async getImageAsync(nameOrEmail: string): Promise<SafeUrl> {\r\n    let promise = AvatarGenerator._imageCache.get(nameOrEmail);\r\n\r\n    if (promise === undefined) {\r\n      promise = this.getImageAsyncOverride(nameOrEmail);\r\n      AvatarGenerator._imageCache.set(nameOrEmail, promise);\r\n    }\r\n\r\n    return promise;\r\n  }\r\n\r\n  public async getLabelAsync(nameOrEmail: string): Promise<string> {\r\n    if (!nameOrEmail)\r\n      return '';\r\n\r\n    if (await this.getImageAsync(nameOrEmail))\r\n      return '';\r\n\r\n    const name = AvatarGenerator.getLocalPartOfEmailAddress(nameOrEmail);\r\n    const initials = AvatarGenerator.getTwoUppercaseLettersFromName(name);\r\n\r\n    return initials;\r\n  }\r\n\r\n  public async getStyleAsync(nameOrEmail: string,): Promise<'' | { 'background-color': string; color: string }> {\r\n    if (await this.getImageAsync(nameOrEmail))\r\n      return '';\r\n\r\n    const foregroundColor = '#ffffff';\r\n    const backgroundColor = AvatarGenerator.getBackgroundColor(nameOrEmail);\r\n\r\n    const style = {\r\n      'background-color': backgroundColor,\r\n      color: foregroundColor,\r\n    };\r\n\r\n    return style;\r\n  }\r\n\r\n  private static getLocalPartOfEmailAddress(email: string): string {\r\n    const indexOfAt = email.indexOf('@');\r\n    if (indexOfAt < 2) {\r\n      if (indexOfAt >= 0) {\r\n        if (indexOfAt === email.length - 1)\r\n          return email.substring(0, indexOfAt);\r\n        return email.substring(indexOfAt + 1);\r\n      }\r\n    } else {\r\n      return email.substring(0, indexOfAt);\r\n    }\r\n\r\n    return email;\r\n  }\r\n\r\n  private static getTwoUppercaseLettersFromName(name: string): string {\r\n    // Too short to do anything besides just returning the name\r\n    if (name.length <= 2) {\r\n      return name.toUpperCase();\r\n    }\r\n\r\n    // Try to split by non word characters\r\n    const splittedByNonWord = name.split(AvatarGenerator._nonWordRegex);\r\n    if (splittedByNonWord.length > 1) {\r\n      return (splittedByNonWord[0][0] + splittedByNonWord[1][0]).toUpperCase();\r\n    }\r\n\r\n    // Try to split by upper case letters\r\n    const upperCaseLetters = [...name]\r\n      .filter((c) => c.toUpperCase() === c && !AvatarGenerator._nonWordRegex.test(c))\r\n      .join();\r\n    if (upperCaseLetters.length > 1) {\r\n      return upperCaseLetters.substring(0, 2);\r\n    }\r\n\r\n    // Just return the first 2 letters\r\n    return name.substring(0, 2).toUpperCase();\r\n  }\r\n\r\n  // from https://stackoverflow.com/a/66494926/1378307\r\n  private static getBackgroundColor(\r\n    text: string,\r\n    minLightness = 40,\r\n    maxLightness = 80,\r\n    minSaturation = 30,\r\n    maxSaturation = 100,\r\n  ): string {\r\n    if (!text) return '#aaa';\r\n\r\n    const hash = [...text].reduce((acc, char) => {\r\n      return char.charCodeAt(0) + ((acc << 5) - acc);\r\n    }, 0);\r\n\r\n    return (\r\n      'hsl(' +\r\n      (hash % 360) +\r\n      ', ' +\r\n      ((hash % (maxSaturation - minSaturation)) + minSaturation) +\r\n      '%, ' +\r\n      ((hash % (maxLightness - minLightness)) + minLightness) +\r\n      '%)'\r\n    );\r\n  }\r\n}\r\n"]}
|
|
@@ -16,8 +16,8 @@ import * as i9 from "primeng/button";
|
|
|
16
16
|
import * as i10 from "primeng/confirmdialog";
|
|
17
17
|
import * as i11 from "primeng/toast";
|
|
18
18
|
import * as i12 from "primeng/tristatecheckbox";
|
|
19
|
-
import * as i13 from "primeng/
|
|
20
|
-
import * as i14 from "
|
|
19
|
+
import * as i13 from "primeng/splitbutton";
|
|
20
|
+
import * as i14 from "../../components/restworld-avatar/restworld-avatar.component";
|
|
21
21
|
export var ColumnFilterType;
|
|
22
22
|
(function (ColumnFilterType) {
|
|
23
23
|
ColumnFilterType["text"] = "text";
|
|
@@ -177,10 +177,10 @@ RESTworldListViewComponent._dateFormat = new Date(3333, 10, 22)
|
|
|
177
177
|
.replace("3333", "y")
|
|
178
178
|
.replace("33", "yy");
|
|
179
179
|
RESTworldListViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: RESTworldListViewComponent, deps: [{ token: i1.RESTworldClientCollection }, { token: i2.ConfirmationService }, { token: i2.MessageService }, { token: i3.AvatarGenerator }, { token: i4.Router }], target: i0.ɵɵFactoryTarget.Component });
|
|
180
|
-
RESTworldListViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: RESTworldListViewComponent, selector: "rw-list", inputs: { createButtonMenu: "createButtonMenu", rowsPerPage: "rowsPerPage", apiName: "apiName", editLink: "editLink", rel: "rel", sortField: "sortField", sortOrder: "sortOrder" }, 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 [sortField]=\"sortField\"\r\n [sortOrder]=\"sortOrder\">\r\n\r\n <ng-template pTemplate=\"header\" let-columns>\r\n <tr>\r\n <th *ngFor=\"let col of columns\" [pSortableColumn]=\"col.name\">\r\n <div class=\"p-d-flex p-jc-between p-ai-center\">\r\n {{col.prompt}}\r\n <p-sortIcon [field]=\"col.name\"></p-sortIcon>\r\n <p-columnFilter [type]=\"toColumnFilterType(col.type)\" [field]=\"col.name\" 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\">\r\n <a *ngIf=\"!createButtonMenu\" class=\"p-button-success\" icon=\"fas fa-plus\" pButton [routerLink]=\"[editLink, apiName, rel, newHref]\" pTooltip=\"Create new\" tooltipPosition=\"left\"></a>\r\n <p-splitButton *ngIf=\"createButtonMenu\" styleClass=\"p-button-success\" icon=\"fas fa-plus\" pTooltip=\"Create new\" tooltipPosition=\"left\" (onClick)=\"createNew()\" [model]=\"createButtonMenu\" appendTo=\"body\"></p-splitButton>\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=\"PropertyType.Text\">\r\n <p-avatar *ngIf=\"col.name === 'createdBy' || col.name === 'lastChangedBy'\" [pTooltip]=\"entity[col.name]\" tooltipPosition=\"top\" [image]=\"avatarGenerator.getImage(entity[col.name])\" [label]=\"avatarGenerator.getLabel(entity[col.name])\" [style]=\"avatarGenerator.getStyle(entity[col.name])\" shape=\"circle\"></p-avatar>\r\n <span *ngIf=\"col.name !== 'createdBy' && col.name !== 'lastChangedBy'\">{{entity[col.name]}}</span>\r\n </ng-container>\r\n <span *ngSwitchCase=\"PropertyType.Number\" class=\"flex justify-content-end\">{{entity[col.name]}}</span>\r\n <span *ngSwitchCase=\"PropertyType.Bool\" class=\"flex justify-content-center\"><p-triStateCheckbox [(ngModel)]=\"entity[col.name]\" [readonly]=\"true\"></p-triStateCheckbox></span>\r\n <span *ngSwitchCase=\"PropertyType.Date\" [pTooltip]=\"entity[col.name]\">{{entity[col.name] | date:dateFormat}}</span>\r\n <span *ngSwitchCase=\"PropertyType.DatetimeLocal\" [pTooltip]=\"entity[col.name]\">{{entity[col.name] | date:dateFormat}}</span>\r\n <span *ngSwitchCase=\"PropertyType.DatetimeOffset\" [pTooltip]=\"entity[col.name]\">{{entity[col.name] | date:dateFormat}}</span>\r\n <span *ngSwitchCase=\"PropertyType.Collection\" class=\"flex justify-content-end\"><p *ngFor=\"let arrayElement of entity[col.name]\">{{arrayElement | json}}</p></span>\r\n <span *ngSwitchCase=\"PropertyType.Object\" class=\"flex justify-content-end\">{{entity[col.name] | json}}</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, rel, 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:-moz-fit-content;max-width:fit-content}a.p-button{text-decoration:none}\n"], dependencies: [{ kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i5.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i4.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i7.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", "selectionPageOnly", "contextMenuSelection", "contextMenuSelectionMode", "dataKey", "metaKeySelection", "rowSelectable", "rowTrackBy", "lazy", "lazyLoadOnInit", "compareSelectionBy", "csvSeparator", "exportFilename", "filters", "globalFilterFields", "filterDelay", "filterLocale", "expandedRowKeys", "editingRowKeys", "rowExpandMode", "scrollable", "scrollDirection", "rowGroupMode", "scrollHeight", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "virtualScrollDelay", "frozenWidth", "responsive", "contextMenu", "resizableColumns", "columnResizeMode", "reorderableColumns", "loading", "loadingIcon", "showLoader", "rowHover", "customSort", "showInitialSortBadge", "autoLayout", "exportFunction", "exportHeader", "stateKey", "stateStorage", "editMode", "groupRowsBy", "groupRowsByOrder", "responsiveLayout", "breakpoint", "virtualRowHeight", "value", "columns", "first", "rows", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection", "selectAll"], outputs: ["selectAllChange", "selectionChange", "contextMenuSelectionChange", "onRowSelect", "onRowUnselect", "onPage", "onSort", "onFilter", "onLazyLoad", "onRowExpand", "onRowCollapse", "onContextMenuSelect", "onColResize", "onColReorder", "onRowReorder", "onEditInit", "onEditComplete", "onEditCancel", "onHeaderCheckboxToggle", "sortFunction", "firstChange", "rowsChange", "onStateSave", "onStateRestore"] }, { kind: "directive", type: i2.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "directive", type: i7.SortableColumn, selector: "[pSortableColumn]", inputs: ["pSortableColumn", "pSortableColumnDisabled"] }, { kind: "component", type: i7.SortIcon, selector: "p-sortIcon", inputs: ["field"] }, { kind: "component", type: i7.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", "showButtons"] }, { kind: "directive", type: i8.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "fitContent", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "directive", type: i9.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "component", type: i10.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"] }, { kind: "component", type: i11.Toast, selector: "p-toast", inputs: ["key", "autoZIndex", "baseZIndex", "style", "styleClass", "position", "preventOpenDuplicates", "preventDuplicates", "showTransformOptions", "hideTransformOptions", "showTransitionOptions", "hideTransitionOptions", "breakpoints"], outputs: ["onClose"] }, { kind: "component", type: i12.TriStateCheckbox, selector: "p-triStateCheckbox", inputs: ["disabled", "name", "ariaLabelledBy", "tabindex", "inputId", "style", "styleClass", "label", "readonly", "checkboxTrueIcon", "checkboxFalseIcon"], outputs: ["onChange"] }, { kind: "component", type: i13.Avatar, selector: "p-avatar", inputs: ["label", "icon", "image", "size", "shape", "style", "styleClass"], outputs: ["onImageError"] }, { kind: "component", type: i14.SplitButton, selector: "p-splitButton", inputs: ["model", "icon", "iconPos", "label", "style", "styleClass", "menuStyle", "menuStyleClass", "disabled", "tabindex", "appendTo", "dir", "expandAriaLabel", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onClick", "onDropdownClick"] }, { kind: "pipe", type: i5.JsonPipe, name: "json" }, { kind: "pipe", type: i5.DatePipe, name: "date" }] });
|
|
180
|
+
RESTworldListViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: RESTworldListViewComponent, selector: "rw-list", inputs: { createButtonMenu: "createButtonMenu", rowsPerPage: "rowsPerPage", apiName: "apiName", editLink: "editLink", rel: "rel", sortField: "sortField", sortOrder: "sortOrder" }, 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 [sortField]=\"sortField\"\r\n [sortOrder]=\"sortOrder\">\r\n\r\n <ng-template pTemplate=\"header\" let-columns>\r\n <tr>\r\n <th *ngFor=\"let col of columns\" [pSortableColumn]=\"col.name\">\r\n <div class=\"p-d-flex p-jc-between p-ai-center\">\r\n {{col.prompt}}\r\n <p-sortIcon [field]=\"col.name\"></p-sortIcon>\r\n <p-columnFilter [type]=\"toColumnFilterType(col.type)\" [field]=\"col.name\" 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\">\r\n <a *ngIf=\"!createButtonMenu\" class=\"p-button-success\" icon=\"fas fa-plus\" pButton [routerLink]=\"[editLink, apiName, rel, newHref]\" pTooltip=\"Create new\" tooltipPosition=\"left\"></a>\r\n <p-splitButton *ngIf=\"createButtonMenu\" styleClass=\"p-button-success\" icon=\"fas fa-plus\" pTooltip=\"Create new\" tooltipPosition=\"left\" (onClick)=\"createNew()\" [model]=\"createButtonMenu\" appendTo=\"body\"></p-splitButton>\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=\"PropertyType.Text\">\r\n <rw-avatar *ngIf=\"col.name === 'createdBy' || col.name === 'lastChangedBy'\" [user]=\"entity[col.name]\"></rw-avatar>\r\n <span *ngIf=\"col.name !== 'createdBy' && col.name !== 'lastChangedBy'\">{{entity[col.name]}}</span>\r\n </ng-container>\r\n <span *ngSwitchCase=\"PropertyType.Number\" class=\"flex justify-content-end\">{{entity[col.name]}}</span>\r\n <span *ngSwitchCase=\"PropertyType.Bool\" class=\"flex justify-content-center\"><p-triStateCheckbox [(ngModel)]=\"entity[col.name]\" [readonly]=\"true\"></p-triStateCheckbox></span>\r\n <span *ngSwitchCase=\"PropertyType.Date\" [pTooltip]=\"entity[col.name]\">{{entity[col.name] | date:dateFormat}}</span>\r\n <span *ngSwitchCase=\"PropertyType.DatetimeLocal\" [pTooltip]=\"entity[col.name]\">{{entity[col.name] | date:dateFormat}}</span>\r\n <span *ngSwitchCase=\"PropertyType.DatetimeOffset\" [pTooltip]=\"entity[col.name]\">{{entity[col.name] | date:dateFormat}}</span>\r\n <span *ngSwitchCase=\"PropertyType.Collection\" class=\"flex justify-content-end\"><p *ngFor=\"let arrayElement of entity[col.name]\">{{arrayElement | json}}</p></span>\r\n <span *ngSwitchCase=\"PropertyType.Object\" class=\"flex justify-content-end\">{{entity[col.name] | json}}</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, rel, 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:-moz-fit-content;max-width:fit-content}a.p-button{text-decoration:none}\n"], dependencies: [{ kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i5.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i4.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i7.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", "selectionPageOnly", "contextMenuSelection", "contextMenuSelectionMode", "dataKey", "metaKeySelection", "rowSelectable", "rowTrackBy", "lazy", "lazyLoadOnInit", "compareSelectionBy", "csvSeparator", "exportFilename", "filters", "globalFilterFields", "filterDelay", "filterLocale", "expandedRowKeys", "editingRowKeys", "rowExpandMode", "scrollable", "scrollDirection", "rowGroupMode", "scrollHeight", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "virtualScrollDelay", "frozenWidth", "responsive", "contextMenu", "resizableColumns", "columnResizeMode", "reorderableColumns", "loading", "loadingIcon", "showLoader", "rowHover", "customSort", "showInitialSortBadge", "autoLayout", "exportFunction", "exportHeader", "stateKey", "stateStorage", "editMode", "groupRowsBy", "groupRowsByOrder", "responsiveLayout", "breakpoint", "virtualRowHeight", "value", "columns", "first", "rows", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection", "selectAll"], outputs: ["selectAllChange", "selectionChange", "contextMenuSelectionChange", "onRowSelect", "onRowUnselect", "onPage", "onSort", "onFilter", "onLazyLoad", "onRowExpand", "onRowCollapse", "onContextMenuSelect", "onColResize", "onColReorder", "onRowReorder", "onEditInit", "onEditComplete", "onEditCancel", "onHeaderCheckboxToggle", "sortFunction", "firstChange", "rowsChange", "onStateSave", "onStateRestore"] }, { kind: "directive", type: i2.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "directive", type: i7.SortableColumn, selector: "[pSortableColumn]", inputs: ["pSortableColumn", "pSortableColumnDisabled"] }, { kind: "component", type: i7.SortIcon, selector: "p-sortIcon", inputs: ["field"] }, { kind: "component", type: i7.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", "showButtons"] }, { kind: "directive", type: i8.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "fitContent", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "directive", type: i9.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "component", type: i10.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"] }, { kind: "component", type: i11.Toast, selector: "p-toast", inputs: ["key", "autoZIndex", "baseZIndex", "style", "styleClass", "position", "preventOpenDuplicates", "preventDuplicates", "showTransformOptions", "hideTransformOptions", "showTransitionOptions", "hideTransitionOptions", "breakpoints"], outputs: ["onClose"] }, { kind: "component", type: i12.TriStateCheckbox, selector: "p-triStateCheckbox", inputs: ["disabled", "name", "ariaLabelledBy", "tabindex", "inputId", "style", "styleClass", "label", "readonly", "checkboxTrueIcon", "checkboxFalseIcon"], outputs: ["onChange"] }, { kind: "component", type: i13.SplitButton, selector: "p-splitButton", inputs: ["model", "icon", "iconPos", "label", "style", "styleClass", "menuStyle", "menuStyleClass", "disabled", "tabindex", "appendTo", "dir", "expandAriaLabel", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onClick", "onDropdownClick"] }, { kind: "component", type: i14.RestWorldAvatarComponent, selector: "rw-avatar", inputs: ["user"] }, { kind: "pipe", type: i5.JsonPipe, name: "json" }, { kind: "pipe", type: i5.DatePipe, name: "date" }] });
|
|
181
181
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: RESTworldListViewComponent, decorators: [{
|
|
182
182
|
type: Component,
|
|
183
|
-
args: [{ selector: 'rw-list', 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 [sortField]=\"sortField\"\r\n [sortOrder]=\"sortOrder\">\r\n\r\n <ng-template pTemplate=\"header\" let-columns>\r\n <tr>\r\n <th *ngFor=\"let col of columns\" [pSortableColumn]=\"col.name\">\r\n <div class=\"p-d-flex p-jc-between p-ai-center\">\r\n {{col.prompt}}\r\n <p-sortIcon [field]=\"col.name\"></p-sortIcon>\r\n <p-columnFilter [type]=\"toColumnFilterType(col.type)\" [field]=\"col.name\" 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\">\r\n <a *ngIf=\"!createButtonMenu\" class=\"p-button-success\" icon=\"fas fa-plus\" pButton [routerLink]=\"[editLink, apiName, rel, newHref]\" pTooltip=\"Create new\" tooltipPosition=\"left\"></a>\r\n <p-splitButton *ngIf=\"createButtonMenu\" styleClass=\"p-button-success\" icon=\"fas fa-plus\" pTooltip=\"Create new\" tooltipPosition=\"left\" (onClick)=\"createNew()\" [model]=\"createButtonMenu\" appendTo=\"body\"></p-splitButton>\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=\"PropertyType.Text\">\r\n <
|
|
183
|
+
args: [{ selector: 'rw-list', 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 [sortField]=\"sortField\"\r\n [sortOrder]=\"sortOrder\">\r\n\r\n <ng-template pTemplate=\"header\" let-columns>\r\n <tr>\r\n <th *ngFor=\"let col of columns\" [pSortableColumn]=\"col.name\">\r\n <div class=\"p-d-flex p-jc-between p-ai-center\">\r\n {{col.prompt}}\r\n <p-sortIcon [field]=\"col.name\"></p-sortIcon>\r\n <p-columnFilter [type]=\"toColumnFilterType(col.type)\" [field]=\"col.name\" 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\">\r\n <a *ngIf=\"!createButtonMenu\" class=\"p-button-success\" icon=\"fas fa-plus\" pButton [routerLink]=\"[editLink, apiName, rel, newHref]\" pTooltip=\"Create new\" tooltipPosition=\"left\"></a>\r\n <p-splitButton *ngIf=\"createButtonMenu\" styleClass=\"p-button-success\" icon=\"fas fa-plus\" pTooltip=\"Create new\" tooltipPosition=\"left\" (onClick)=\"createNew()\" [model]=\"createButtonMenu\" appendTo=\"body\"></p-splitButton>\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=\"PropertyType.Text\">\r\n <rw-avatar *ngIf=\"col.name === 'createdBy' || col.name === 'lastChangedBy'\" [user]=\"entity[col.name]\"></rw-avatar>\r\n <span *ngIf=\"col.name !== 'createdBy' && col.name !== 'lastChangedBy'\">{{entity[col.name]}}</span>\r\n </ng-container>\r\n <span *ngSwitchCase=\"PropertyType.Number\" class=\"flex justify-content-end\">{{entity[col.name]}}</span>\r\n <span *ngSwitchCase=\"PropertyType.Bool\" class=\"flex justify-content-center\"><p-triStateCheckbox [(ngModel)]=\"entity[col.name]\" [readonly]=\"true\"></p-triStateCheckbox></span>\r\n <span *ngSwitchCase=\"PropertyType.Date\" [pTooltip]=\"entity[col.name]\">{{entity[col.name] | date:dateFormat}}</span>\r\n <span *ngSwitchCase=\"PropertyType.DatetimeLocal\" [pTooltip]=\"entity[col.name]\">{{entity[col.name] | date:dateFormat}}</span>\r\n <span *ngSwitchCase=\"PropertyType.DatetimeOffset\" [pTooltip]=\"entity[col.name]\">{{entity[col.name] | date:dateFormat}}</span>\r\n <span *ngSwitchCase=\"PropertyType.Collection\" class=\"flex justify-content-end\"><p *ngFor=\"let arrayElement of entity[col.name]\">{{arrayElement | json}}</p></span>\r\n <span *ngSwitchCase=\"PropertyType.Object\" class=\"flex justify-content-end\">{{entity[col.name] | json}}</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, rel, 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:-moz-fit-content;max-width:fit-content}a.p-button{text-decoration:none}\n"] }]
|
|
184
184
|
}], ctorParameters: function () { return [{ type: i1.RESTworldClientCollection }, { type: i2.ConfirmationService }, { type: i2.MessageService }, { type: i3.AvatarGenerator }, { type: i4.Router }]; }, propDecorators: { createButtonMenu: [{
|
|
185
185
|
type: Input
|
|
186
186
|
}], rowsPerPage: [{
|
|
@@ -196,4 +196,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
|
|
|
196
196
|
}], sortOrder: [{
|
|
197
197
|
type: Input
|
|
198
198
|
}] } });
|
|
199
|
-
//# 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, Property, PropertyType, Resource, ResourceDto, Template } from '@wertzui/ngx-hal-client';\r\nimport * as _ from 'lodash';\r\nimport { ConfirmationService, FilterMatchMode, FilterMetadata, LazyLoadEvent, MenuItem, 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\nimport { Router } from '@angular/router';\r\nimport { ODataService } from '../../services/o-data.service'\r\n\r\nexport enum ColumnFilterType {\r\n  text = 'text',\r\n  numeric = 'numeric',\r\n  boolean = 'boolean',\r\n  date = 'date'\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<TListDto extends ResourceDto> {\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  @Input()\r\n  public createButtonMenu?: MenuItem[];\r\n  public isLoading = false;\r\n  public load = _.debounce(this.load2, 100);\r\n  public resource?: PagedListResource<TListDto>;\r\n  @Input()\r\n  public rowsPerPage: number[];\r\n\r\n  private _apiName?: string;\r\n  private _editLink = '/edit';\r\n  private _lastEvent: LazyLoadEvent;\r\n  private _rel?: string;\r\n  private _sortField = '';\r\n  private _sortOrder = 1;\r\n  private _template?: Template;\r\n  private _totalRecords = 0;\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    private readonly _router: Router) {\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  public get PropertyType(): typeof PropertyType {\r\n    return PropertyType;\r\n  }\r\n\r\n  public get apiName(): string | undefined {\r\n    return this._apiName;\r\n  }\r\n\r\n  @Input()\r\n  public set apiName(value: string | undefined) {\r\n    this._apiName = value;\r\n    this.load(this._lastEvent);\r\n  }\r\n\r\n  public get columns(): Property[] {\r\n    return this.template?.properties.filter(p => p.type !== PropertyType.Hidden) ?? [];\r\n  }\r\n\r\n  public get dateFormat(): string {\r\n    return RESTworldListViewComponent._dateFormat;\r\n  }\r\n\r\n  public get editLink() {\r\n    return this._editLink;\r\n  }\r\n\r\n  @Input()\r\n  public set editLink(value: string) {\r\n    if (value)\r\n      this._editLink = value;\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  public get rel(): string | undefined {\r\n    return this._rel;\r\n  }\r\n\r\n  @Input()\r\n  public set rel(value: string | undefined) {\r\n    this._rel = value;\r\n    this.load(this._lastEvent);\r\n  }\r\n\r\n  public get rows(): number {\r\n    return this._lastEvent?.rows || 0;\r\n  }\r\n\r\n  public get sortField(): string {\r\n    return this._sortField;\r\n  }\r\n\r\n  @Input()\r\n  public set sortField(value: string | undefined) {\r\n    this._sortField = value ?? '';\r\n    this._lastEvent.sortField = value;\r\n    this.load(this._lastEvent);\r\n  }\r\n\r\n  public get sortOrder(): number {\r\n    return this._sortOrder;\r\n  }\r\n\r\n  @Input()\r\n  public set sortOrder(value: number | undefined) {\r\n    this._sortOrder = value ?? 1;\r\n    this._lastEvent.sortOrder = value;\r\n    this.load(this._lastEvent);\r\n  }\r\n\r\n  public get template(): Template | undefined {\r\n    return this._template;\r\n  }\r\n\r\n  public get totalRecords(): number {\r\n    return this._totalRecords;\r\n  }\r\n\r\n  public get value(): Resource[] {\r\n    return this.resource?._embedded?.items || [];\r\n  }\r\n\r\n  private set totalRecords(value: number | undefined) {\r\n    this._totalRecords = value || 0;\r\n  }\r\n\r\n  public createNew(): Promise<boolean> {\r\n    return this._router.navigate([this.editLink, this.apiName, this.rel, this.newHref]);\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  public async load2(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 = ODataService.createParametersFromTableLoadEvent(event, this.template);\r\n    const response = await this.getClient().getList<TListDto>(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      try {\r\n        const templates = await this.getClient().getAllTemplates(response.body);\r\n        this._template = templates[\"Search\"];\r\n        if (this._template === undefined)\r\n          throw new Error(\"No search template found in the API response.\");\r\n      }\r\n      catch (e: unknown) {\r\n        this._messageService.add({ severity: 'error', summary: 'Error', detail: 'Error while loading the resources from the API. ' + e, data: e });\r\n      }\r\n\r\n      this.resource = response.body;\r\n      this.totalRecords = this.resource.totalPages && parameters.$top ? this.resource.totalPages * parameters.$top : undefined;\r\n    }\r\n\r\n    this.isLoading = false;\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 toColumnFilterType(propertyType: PropertyType) : ColumnFilterType{\r\n    switch(propertyType) {\r\n      case PropertyType.Number:\r\n        return ColumnFilterType.numeric;\r\n      case PropertyType.Bool:\r\n        return ColumnFilterType.boolean;\r\n      case PropertyType.Date:\r\n      case PropertyType.DatetimeLocal:\r\n      case PropertyType.DatetimeOffset:\r\n        return ColumnFilterType.date;\r\n      default:\r\n        return ColumnFilterType.text;\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","<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         [sortField]=\"sortField\"\r\n         [sortOrder]=\"sortOrder\">\r\n\r\n    <ng-template pTemplate=\"header\" let-columns>\r\n        <tr>\r\n            <th *ngFor=\"let col of columns\" [pSortableColumn]=\"col.name\">\r\n                <div class=\"p-d-flex p-jc-between p-ai-center\">\r\n                    {{col.prompt}}\r\n                    <p-sortIcon [field]=\"col.name\"></p-sortIcon>\r\n                    <p-columnFilter [type]=\"toColumnFilterType(col.type)\" [field]=\"col.name\" 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\">\r\n                        <a *ngIf=\"!createButtonMenu\" class=\"p-button-success\" icon=\"fas fa-plus\" pButton [routerLink]=\"[editLink, apiName, rel, newHref]\" pTooltip=\"Create new\" tooltipPosition=\"left\"></a>\r\n                        <p-splitButton *ngIf=\"createButtonMenu\" styleClass=\"p-button-success\" icon=\"fas fa-plus\" pTooltip=\"Create new\" tooltipPosition=\"left\" (onClick)=\"createNew()\" [model]=\"createButtonMenu\" appendTo=\"body\"></p-splitButton>\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=\"PropertyType.Text\">\r\n                    <p-avatar *ngIf=\"col.name === 'createdBy' || col.name === 'lastChangedBy'\" [pTooltip]=\"entity[col.name]\" tooltipPosition=\"top\" [image]=\"avatarGenerator.getImage(entity[col.name])\" [label]=\"avatarGenerator.getLabel(entity[col.name])\" [style]=\"avatarGenerator.getStyle(entity[col.name])\" shape=\"circle\"></p-avatar>\r\n                    <span *ngIf=\"col.name !== 'createdBy' && col.name !== 'lastChangedBy'\">{{entity[col.name]}}</span>\r\n                </ng-container>\r\n                <span *ngSwitchCase=\"PropertyType.Number\" class=\"flex justify-content-end\">{{entity[col.name]}}</span>\r\n                <span *ngSwitchCase=\"PropertyType.Bool\" class=\"flex justify-content-center\"><p-triStateCheckbox [(ngModel)]=\"entity[col.name]\" [readonly]=\"true\"></p-triStateCheckbox></span>\r\n                <span *ngSwitchCase=\"PropertyType.Date\" [pTooltip]=\"entity[col.name]\">{{entity[col.name] | date:dateFormat}}</span>\r\n                <span *ngSwitchCase=\"PropertyType.DatetimeLocal\" [pTooltip]=\"entity[col.name]\">{{entity[col.name] | date:dateFormat}}</span>\r\n                <span *ngSwitchCase=\"PropertyType.DatetimeOffset\" [pTooltip]=\"entity[col.name]\">{{entity[col.name] | date:dateFormat}}</span>\r\n                <span *ngSwitchCase=\"PropertyType.Collection\" class=\"flex justify-content-end\"><p *ngFor=\"let arrayElement of entity[col.name]\">{{arrayElement | json}}</p></span>\r\n                <span *ngSwitchCase=\"PropertyType.Object\" class=\"flex justify-content-end\">{{entity[col.name] | json}}</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, rel, 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"]}
|
|
199
|
+
//# 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, Property, PropertyType, Resource, ResourceDto, Template } from '@wertzui/ngx-hal-client';\r\nimport * as _ from 'lodash';\r\nimport { ConfirmationService, FilterMatchMode, FilterMetadata, LazyLoadEvent, MenuItem, 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\nimport { Router } from '@angular/router';\r\nimport { ODataService } from '../../services/o-data.service'\r\n\r\nexport enum ColumnFilterType {\r\n  text = 'text',\r\n  numeric = 'numeric',\r\n  boolean = 'boolean',\r\n  date = 'date'\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<TListDto extends ResourceDto> {\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  @Input()\r\n  public createButtonMenu?: MenuItem[];\r\n  public isLoading = false;\r\n  public load = _.debounce(this.load2, 100);\r\n  public resource?: PagedListResource<TListDto>;\r\n  @Input()\r\n  public rowsPerPage: number[];\r\n\r\n  private _apiName?: string;\r\n  private _editLink = '/edit';\r\n  private _lastEvent: LazyLoadEvent;\r\n  private _rel?: string;\r\n  private _sortField = '';\r\n  private _sortOrder = 1;\r\n  private _template?: Template;\r\n  private _totalRecords = 0;\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    private readonly _router: Router) {\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  public get PropertyType(): typeof PropertyType {\r\n    return PropertyType;\r\n  }\r\n\r\n  public get apiName(): string | undefined {\r\n    return this._apiName;\r\n  }\r\n\r\n  @Input()\r\n  public set apiName(value: string | undefined) {\r\n    this._apiName = value;\r\n    this.load(this._lastEvent);\r\n  }\r\n\r\n  public get columns(): Property[] {\r\n    return this.template?.properties.filter(p => p.type !== PropertyType.Hidden) ?? [];\r\n  }\r\n\r\n  public get dateFormat(): string {\r\n    return RESTworldListViewComponent._dateFormat;\r\n  }\r\n\r\n  public get editLink() {\r\n    return this._editLink;\r\n  }\r\n\r\n  @Input()\r\n  public set editLink(value: string) {\r\n    if (value)\r\n      this._editLink = value;\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  public get rel(): string | undefined {\r\n    return this._rel;\r\n  }\r\n\r\n  @Input()\r\n  public set rel(value: string | undefined) {\r\n    this._rel = value;\r\n    this.load(this._lastEvent);\r\n  }\r\n\r\n  public get rows(): number {\r\n    return this._lastEvent?.rows || 0;\r\n  }\r\n\r\n  public get sortField(): string {\r\n    return this._sortField;\r\n  }\r\n\r\n  @Input()\r\n  public set sortField(value: string | undefined) {\r\n    this._sortField = value ?? '';\r\n    this._lastEvent.sortField = value;\r\n    this.load(this._lastEvent);\r\n  }\r\n\r\n  public get sortOrder(): number {\r\n    return this._sortOrder;\r\n  }\r\n\r\n  @Input()\r\n  public set sortOrder(value: number | undefined) {\r\n    this._sortOrder = value ?? 1;\r\n    this._lastEvent.sortOrder = value;\r\n    this.load(this._lastEvent);\r\n  }\r\n\r\n  public get template(): Template | undefined {\r\n    return this._template;\r\n  }\r\n\r\n  public get totalRecords(): number {\r\n    return this._totalRecords;\r\n  }\r\n\r\n  public get value(): Resource[] {\r\n    return this.resource?._embedded?.items || [];\r\n  }\r\n\r\n  private set totalRecords(value: number | undefined) {\r\n    this._totalRecords = value || 0;\r\n  }\r\n\r\n  public createNew(): Promise<boolean> {\r\n    return this._router.navigate([this.editLink, this.apiName, this.rel, this.newHref]);\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  public async load2(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 = ODataService.createParametersFromTableLoadEvent(event, this.template);\r\n    const response = await this.getClient().getList<TListDto>(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      try {\r\n        const templates = await this.getClient().getAllTemplates(response.body);\r\n        this._template = templates[\"Search\"];\r\n        if (this._template === undefined)\r\n          throw new Error(\"No search template found in the API response.\");\r\n      }\r\n      catch (e: unknown) {\r\n        this._messageService.add({ severity: 'error', summary: 'Error', detail: 'Error while loading the resources from the API. ' + e, data: e });\r\n      }\r\n\r\n      this.resource = response.body;\r\n      this.totalRecords = this.resource.totalPages && parameters.$top ? this.resource.totalPages * parameters.$top : undefined;\r\n    }\r\n\r\n    this.isLoading = false;\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 toColumnFilterType(propertyType: PropertyType) : ColumnFilterType{\r\n    switch(propertyType) {\r\n      case PropertyType.Number:\r\n        return ColumnFilterType.numeric;\r\n      case PropertyType.Bool:\r\n        return ColumnFilterType.boolean;\r\n      case PropertyType.Date:\r\n      case PropertyType.DatetimeLocal:\r\n      case PropertyType.DatetimeOffset:\r\n        return ColumnFilterType.date;\r\n      default:\r\n        return ColumnFilterType.text;\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","<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         [sortField]=\"sortField\"\r\n         [sortOrder]=\"sortOrder\">\r\n\r\n    <ng-template pTemplate=\"header\" let-columns>\r\n        <tr>\r\n            <th *ngFor=\"let col of columns\" [pSortableColumn]=\"col.name\">\r\n                <div class=\"p-d-flex p-jc-between p-ai-center\">\r\n                    {{col.prompt}}\r\n                    <p-sortIcon [field]=\"col.name\"></p-sortIcon>\r\n                    <p-columnFilter [type]=\"toColumnFilterType(col.type)\" [field]=\"col.name\" 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\">\r\n                        <a *ngIf=\"!createButtonMenu\" class=\"p-button-success\" icon=\"fas fa-plus\" pButton [routerLink]=\"[editLink, apiName, rel, newHref]\" pTooltip=\"Create new\" tooltipPosition=\"left\"></a>\r\n                        <p-splitButton *ngIf=\"createButtonMenu\" styleClass=\"p-button-success\" icon=\"fas fa-plus\" pTooltip=\"Create new\" tooltipPosition=\"left\" (onClick)=\"createNew()\" [model]=\"createButtonMenu\" appendTo=\"body\"></p-splitButton>\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=\"PropertyType.Text\">\r\n                    <rw-avatar *ngIf=\"col.name === 'createdBy' || col.name === 'lastChangedBy'\" [user]=\"entity[col.name]\"></rw-avatar>\r\n                    <span *ngIf=\"col.name !== 'createdBy' && col.name !== 'lastChangedBy'\">{{entity[col.name]}}</span>\r\n                </ng-container>\r\n                <span *ngSwitchCase=\"PropertyType.Number\" class=\"flex justify-content-end\">{{entity[col.name]}}</span>\r\n                <span *ngSwitchCase=\"PropertyType.Bool\" class=\"flex justify-content-center\"><p-triStateCheckbox [(ngModel)]=\"entity[col.name]\" [readonly]=\"true\"></p-triStateCheckbox></span>\r\n                <span *ngSwitchCase=\"PropertyType.Date\" [pTooltip]=\"entity[col.name]\">{{entity[col.name] | date:dateFormat}}</span>\r\n                <span *ngSwitchCase=\"PropertyType.DatetimeLocal\" [pTooltip]=\"entity[col.name]\">{{entity[col.name] | date:dateFormat}}</span>\r\n                <span *ngSwitchCase=\"PropertyType.DatetimeOffset\" [pTooltip]=\"entity[col.name]\">{{entity[col.name] | date:dateFormat}}</span>\r\n                <span *ngSwitchCase=\"PropertyType.Collection\" class=\"flex justify-content-end\"><p *ngFor=\"let arrayElement of entity[col.name]\">{{arrayElement | json}}</p></span>\r\n                <span *ngSwitchCase=\"PropertyType.Object\" class=\"flex justify-content-end\">{{entity[col.name] | json}}</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, rel, 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"]}
|
package/esm2020/public-api.mjs
CHANGED
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
* Public API Surface of ngx-restworld-client
|
|
3
3
|
*/
|
|
4
4
|
export * from './lib/constants/link-names';
|
|
5
|
+
export * from './lib/components/restworld-avatar/restworld-avatar.component';
|
|
5
6
|
export * from './lib/models/api-url';
|
|
6
7
|
export * from './lib/models/client-settings';
|
|
7
8
|
export * from './lib/models/problem-details';
|
|
@@ -20,4 +21,4 @@ export * from './lib/views/restworld-file-view/restworld-file-view.component';
|
|
|
20
21
|
export * from './lib/views/restworld-image-view/restworld-image-view.component';
|
|
21
22
|
export * from './lib/views/restworld-list-view/restworld-list-view.component';
|
|
22
23
|
export * from './lib/restworld-client.module';
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25neC1yZXN0d29ybGQtY2xpZW50L3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyw0QkFBNEIsQ0FBQztBQUUzQyxjQUFjLDhEQUE4RCxDQUFBO0FBRTVFLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsZ0NBQWdDLENBQUM7QUFFL0MsY0FBYywyQkFBMkIsQ0FBQTtBQUN6QyxjQUFjLHFCQUFxQixDQUFBO0FBRW5DLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLGlDQUFpQyxDQUFDO0FBRWhELGNBQWMsK0RBQStELENBQUM7QUFDOUUsY0FBYywrREFBK0QsQ0FBQztBQUM5RSxjQUFjLCtEQUErRCxDQUFBO0FBQzdFLGNBQWMsaUVBQWlFLENBQUE7QUFDL0UsY0FBYywrREFBK0QsQ0FBQTtBQUU3RSxjQUFjLCtCQUErQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBuZ3gtcmVzdHdvcmxkLWNsaWVudFxuICovXHJcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29uc3RhbnRzL2xpbmstbmFtZXMnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL3Jlc3R3b3JsZC1hdmF0YXIvcmVzdHdvcmxkLWF2YXRhci5jb21wb25lbnQnXG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9hcGktdXJsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9jbGllbnQtc2V0dGluZ3MnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kZWxzL3Byb2JsZW0tZGV0YWlscyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2RlbHMvcmVzdHdvcmxkLW9wdGlvbnMnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9waXBlcy9zYWZlLXVybC5waXBlJ1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcGlwZXMvYXMucGlwZSdcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvYXZhdGFyLWdlbmVyYXRvcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZXJ2aWNlcy9mb3JtLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvby1kYXRhLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvcmVzdHdvcmxkLWNsaWVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZXJ2aWNlcy9yZXN0d29ybGQtY2xpZW50LWNvbGxlY3Rpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvc2V0dGluZ3Muc2VydmljZSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL3ZpZXdzL3Jlc3R3b3JsZC1lZGl0LWZvcm0vcmVzdHdvcmxkLWVkaXQtZm9ybS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdmlld3MvcmVzdHdvcmxkLWVkaXQtdmlldy9yZXN0d29ybGQtZWRpdC12aWV3LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi92aWV3cy9yZXN0d29ybGQtZmlsZS12aWV3L3Jlc3R3b3JsZC1maWxlLXZpZXcuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdmlld3MvcmVzdHdvcmxkLWltYWdlLXZpZXcvcmVzdHdvcmxkLWltYWdlLXZpZXcuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdmlld3MvcmVzdHdvcmxkLWxpc3Qtdmlldy9yZXN0d29ybGQtbGlzdC12aWV3LmNvbXBvbmVudCdcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvcmVzdHdvcmxkLWNsaWVudC5tb2R1bGUnOyJdfQ==
|