@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
|
@@ -0,0 +1,313 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { PropertyType } from '@wertzui/ngx-hal-client';
|
|
3
|
+
import { FormGroup } from '@angular/forms';
|
|
4
|
+
import { ProblemDetails } from '../../models/problem-details';
|
|
5
|
+
import { ContentChild } from '@angular/core';
|
|
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 "@angular/common";
|
|
10
|
+
import * as i4 from "@angular/router";
|
|
11
|
+
import * as i5 from "../../services/form.service";
|
|
12
|
+
import * as i6 from "ngx-valdemort";
|
|
13
|
+
import * as i7 from "primeng/tabview";
|
|
14
|
+
import * as i8 from "primeng/skeleton";
|
|
15
|
+
import * as i9 from "../restworld-edit-form/restworld-edit-form.component";
|
|
16
|
+
import * as i10 from "primeng/progressspinner";
|
|
17
|
+
import * as i11 from "primeng/toast";
|
|
18
|
+
import * as i12 from "primeng/confirmdialog";
|
|
19
|
+
import * as i13 from "@angular/forms";
|
|
20
|
+
import * as i14 from "primeng/button";
|
|
21
|
+
import * as i15 from "primeng/ripple";
|
|
22
|
+
export class RESTworldEditViewComponent {
|
|
23
|
+
constructor(_clients, _confirmationService, _messageService, _location, _router, _formService, valdemortConfig) {
|
|
24
|
+
this._clients = _clients;
|
|
25
|
+
this._confirmationService = _confirmationService;
|
|
26
|
+
this._messageService = _messageService;
|
|
27
|
+
this._location = _location;
|
|
28
|
+
this._router = _router;
|
|
29
|
+
this._formService = _formService;
|
|
30
|
+
this._templates = {};
|
|
31
|
+
this._formTabs = {};
|
|
32
|
+
this.isLoading = false;
|
|
33
|
+
valdemortConfig.errorClasses = 'p-error text-sm';
|
|
34
|
+
}
|
|
35
|
+
get PropertyType() {
|
|
36
|
+
return PropertyType;
|
|
37
|
+
}
|
|
38
|
+
get templates() {
|
|
39
|
+
return this._templates;
|
|
40
|
+
}
|
|
41
|
+
get isLoadingForTheFirstTime() {
|
|
42
|
+
return Object.keys(this.templates).length === 0 && this.isLoading;
|
|
43
|
+
}
|
|
44
|
+
get formTabs() {
|
|
45
|
+
return this._formTabs;
|
|
46
|
+
}
|
|
47
|
+
set apiName(value) {
|
|
48
|
+
this._apiName = value;
|
|
49
|
+
this.load();
|
|
50
|
+
}
|
|
51
|
+
get apiName() {
|
|
52
|
+
return this._apiName;
|
|
53
|
+
}
|
|
54
|
+
//@Input()
|
|
55
|
+
//public set rel(value: string | undefined) {
|
|
56
|
+
// this._rel = value;
|
|
57
|
+
//}
|
|
58
|
+
//public get rel(): string | undefined {
|
|
59
|
+
// return this._rel;
|
|
60
|
+
//}
|
|
61
|
+
//private _rel?: string;
|
|
62
|
+
set uri(value) {
|
|
63
|
+
this._uri = value;
|
|
64
|
+
this.load();
|
|
65
|
+
}
|
|
66
|
+
get uri() {
|
|
67
|
+
return this._uri;
|
|
68
|
+
}
|
|
69
|
+
get resource() {
|
|
70
|
+
return this._resource;
|
|
71
|
+
}
|
|
72
|
+
get canSave() {
|
|
73
|
+
const length = this.resource?._links["save"]?.length;
|
|
74
|
+
return length !== undefined && length > 0;
|
|
75
|
+
}
|
|
76
|
+
get canDelete() {
|
|
77
|
+
const length = this.resource?._links["delete"]?.length;
|
|
78
|
+
return length !== undefined && length > 0;
|
|
79
|
+
}
|
|
80
|
+
canSubmit(templateName) {
|
|
81
|
+
const form = this.formTabs[templateName];
|
|
82
|
+
return form && form.valid;
|
|
83
|
+
}
|
|
84
|
+
getTooltip(resource, keysToExclude) {
|
|
85
|
+
const tooltip = Object.entries(resource)
|
|
86
|
+
.filter(([key]) => !(key.startsWith('_') || ['createdAt', 'createdBy', 'lastChangedAt', 'lastChangedBy', 'timestamp'].includes(key) || keysToExclude?.includes(key)))
|
|
87
|
+
.reduce((prev, [key, value], index) => `${prev}${index === 0 ? '' : '\n'}${key}: ${RESTworldEditViewComponent.jsonStringifyWithElipsis(value)}`, '');
|
|
88
|
+
return tooltip;
|
|
89
|
+
}
|
|
90
|
+
static jsonStringifyWithElipsis(value) {
|
|
91
|
+
const maxLength = 200;
|
|
92
|
+
const end = 10;
|
|
93
|
+
const start = maxLength - end - 2;
|
|
94
|
+
const json = JSON.stringify(value);
|
|
95
|
+
const shortened = json.length > maxLength ? json.substring(0, start) + '…' + json.substring(json.length - end) : json;
|
|
96
|
+
return shortened;
|
|
97
|
+
}
|
|
98
|
+
getClient() {
|
|
99
|
+
if (!this.apiName)
|
|
100
|
+
throw new Error('Cannot get a client, because the apiName is not set.');
|
|
101
|
+
return this._clients.getClient(this.apiName);
|
|
102
|
+
}
|
|
103
|
+
async submit(templateName, template, formValue) {
|
|
104
|
+
this.isLoading = true;
|
|
105
|
+
try {
|
|
106
|
+
const targetBeforeSave = template.target;
|
|
107
|
+
const response = await this.getClient().submit(template, formValue);
|
|
108
|
+
if (!response.ok) {
|
|
109
|
+
let summary = 'Error';
|
|
110
|
+
let detail = 'Error while saving the resource.';
|
|
111
|
+
if (ProblemDetails.isProblemDetails(response.body)) {
|
|
112
|
+
const problemDetails = response.body;
|
|
113
|
+
summary = problemDetails.title || summary;
|
|
114
|
+
detail = problemDetails.detail || detail;
|
|
115
|
+
// display validation errors
|
|
116
|
+
if (problemDetails['errors']) {
|
|
117
|
+
const form = this.formTabs[templateName];
|
|
118
|
+
for (const [key, errorsForKey] of Object.entries(problemDetails['errors'])) {
|
|
119
|
+
const path = key.split(/\.|\[/).map(e => e.replace("]", ""));
|
|
120
|
+
const formControl = path.reduce((control, pathElement) => (control instanceof FormGroup ? control.controls[pathElement] : control) || control, form);
|
|
121
|
+
formControl.setErrors({ remote: errorsForKey });
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
this._messageService.add({ severity: 'error', summary: summary, detail: detail, data: response, life: 10000 });
|
|
126
|
+
}
|
|
127
|
+
else {
|
|
128
|
+
const responseResource = response.body;
|
|
129
|
+
const targetAfterSave = responseResource._templates[templateName].target;
|
|
130
|
+
setTimeout(() => this._messageService.add({ severity: 'success', summary: 'Saved', detail: 'The resource has been saved.' }), 100);
|
|
131
|
+
if (targetBeforeSave !== targetAfterSave) {
|
|
132
|
+
this._router.navigate(['/edit', this.apiName, responseResource._links.self[0].href]);
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
catch (e) {
|
|
137
|
+
this._messageService.add({ severity: 'error', summary: 'Error', detail: `An unknown error occurred. ${JSON.stringify(e)}`, life: 10000 });
|
|
138
|
+
console.log(e);
|
|
139
|
+
}
|
|
140
|
+
this.isLoading = false;
|
|
141
|
+
}
|
|
142
|
+
showDeleteConfirmatioModal() {
|
|
143
|
+
this._confirmationService.confirm({
|
|
144
|
+
message: 'Do you really want to delete this resource?',
|
|
145
|
+
header: 'Confirm delete',
|
|
146
|
+
icon: 'far fa-trash-alt',
|
|
147
|
+
accept: () => this.delete()
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
async delete() {
|
|
151
|
+
if (!this.apiName || !this.uri || !this.resource)
|
|
152
|
+
return;
|
|
153
|
+
Object.assign(this.resource, this.formTabs.value);
|
|
154
|
+
await this.getClient().delete(this.resource);
|
|
155
|
+
setTimeout(() => this._messageService.add({ severity: 'success', summary: 'Deleted', detail: 'The resource has been deleted.' }), 100);
|
|
156
|
+
this._location.back();
|
|
157
|
+
}
|
|
158
|
+
async load() {
|
|
159
|
+
if (!this.apiName || !this.uri)
|
|
160
|
+
return;
|
|
161
|
+
this.isLoading = true;
|
|
162
|
+
const response = await this.getClient().getSingle(this.uri);
|
|
163
|
+
if (!response.ok || ProblemDetails.isProblemDetails(response.body) || !response.body) {
|
|
164
|
+
this._messageService.add({ severity: 'error', summary: 'Error', detail: 'Error while loading the resource from the API.', data: response });
|
|
165
|
+
}
|
|
166
|
+
else {
|
|
167
|
+
this._resource = response.body;
|
|
168
|
+
this._templates = await this.getAllTemplates(this._resource);
|
|
169
|
+
this._formTabs = this._formService.createFormGroupsFromTemplates(this._templates);
|
|
170
|
+
}
|
|
171
|
+
this.isLoading = false;
|
|
172
|
+
}
|
|
173
|
+
async setInitialSelectedOptionsElementsForTemplates(templates) {
|
|
174
|
+
return Promise.all(Object.values(templates)
|
|
175
|
+
.map(template => this.setInitialSelectedOptionsElementsForTemplate(template)));
|
|
176
|
+
}
|
|
177
|
+
imageChanged(formControl, event) {
|
|
178
|
+
const file = event.files[0];
|
|
179
|
+
console.log(file);
|
|
180
|
+
const reader = new FileReader();
|
|
181
|
+
reader.onload = () => {
|
|
182
|
+
const uri = reader.result;
|
|
183
|
+
console.log(uri);
|
|
184
|
+
formControl.setValue(uri);
|
|
185
|
+
};
|
|
186
|
+
reader.readAsDataURL(file);
|
|
187
|
+
}
|
|
188
|
+
async setInitialSelectedOptionsElementsForTemplate(template) {
|
|
189
|
+
return Promise.all(template.properties
|
|
190
|
+
.filter(property => property?.options?.link?.href)
|
|
191
|
+
.map(property => this.setInitialSelectedOptionsElementForProperty(property)));
|
|
192
|
+
}
|
|
193
|
+
async setInitialSelectedOptionsElementForProperty(property) {
|
|
194
|
+
const options = property?.options;
|
|
195
|
+
if (!options?.link?.href)
|
|
196
|
+
return;
|
|
197
|
+
const templatedUri = options.link.href;
|
|
198
|
+
const filter = `${options.valueField} eq ${property.value}`;
|
|
199
|
+
const response = await this.getClient().getListByUri(templatedUri, { $filter: filter, $top: 10 });
|
|
200
|
+
if (!response.ok || ProblemDetails.isProblemDetails(response.body) || !response.body) {
|
|
201
|
+
const message = `An error occurred while getting the filtered items.`;
|
|
202
|
+
this._messageService.add({ severity: 'error', summary: 'Error', detail: message, data: response });
|
|
203
|
+
return;
|
|
204
|
+
}
|
|
205
|
+
const items = response.body._embedded.items;
|
|
206
|
+
options.inline = items;
|
|
207
|
+
}
|
|
208
|
+
async getAllTemplates(resource) {
|
|
209
|
+
const formResponses = await this.getClient().getAllForms(resource);
|
|
210
|
+
const failedResponses = formResponses.filter(response => !response.ok || ProblemDetails.isProblemDetails(response.body) || !response.body);
|
|
211
|
+
if (failedResponses.length !== 0) {
|
|
212
|
+
for (const response of failedResponses) {
|
|
213
|
+
this._messageService.add({ severity: 'error', summary: 'Error', detail: 'Error while loading the resource from the API.', data: response });
|
|
214
|
+
}
|
|
215
|
+
return Promise.resolve({});
|
|
216
|
+
}
|
|
217
|
+
const formTemplates = Object.assign({}, ...formResponses.map(response => response.body._templates));
|
|
218
|
+
await this.setInitialSelectedOptionsElementsForTemplates(formTemplates);
|
|
219
|
+
return formTemplates;
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
RESTworldEditViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: RESTworldEditViewComponent, deps: [{ token: i1.RESTworldClientCollection }, { token: i2.ConfirmationService }, { token: i2.MessageService }, { token: i3.Location }, { token: i4.Router }, { token: i5.FormService }, { token: i6.ValdemortConfig }], target: i0.ɵɵFactoryTarget.Component });
|
|
223
|
+
RESTworldEditViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.5", type: RESTworldEditViewComponent, selector: "rw-edit", inputs: { apiName: "apiName", uri: "uri" }, queries: [{ propertyName: "extraTabsRef", first: true, predicate: ["extraTabs"], descendants: true }, { propertyName: "buttonsRef", first: true, predicate: ["buttons"], descendants: true }, { propertyName: "inputOptionsSingleRef", first: true, predicate: ["inputOptionsSingle"], descendants: true }, { propertyName: "inputOptionsMultipleRef", first: true, predicate: ["inputOptionsMultiple"], descendants: true }, { propertyName: "inputOptionsRef", first: true, predicate: ["inputOptions"], descendants: true }, { propertyName: "inputHiddenRef", first: true, predicate: ["inputHidden"], descendants: true }, { propertyName: "inputTextRef", first: true, predicate: ["inputText"], descendants: true }, { propertyName: "inputTextareaRef", first: true, predicate: ["inputTextarea"], descendants: true }, { propertyName: "inputSearchRef", first: true, predicate: ["inputSearch"], descendants: true }, { propertyName: "inputTelRef", first: true, predicate: ["inputTel"], descendants: true }, { propertyName: "inputUrlRef", first: true, predicate: ["inputUrl"], descendants: true }, { propertyName: "inputEmailRef", first: true, predicate: ["inputEmail"], descendants: true }, { propertyName: "inputPasswordRef", first: true, predicate: ["inputPassword"], descendants: true }, { propertyName: "inputDateRef", first: true, predicate: ["inputDate"], descendants: true }, { propertyName: "inputMonthRef", first: true, predicate: ["inputMonth"], descendants: true }, { propertyName: "inputWeekRef", first: true, predicate: ["inputWeek"], descendants: true }, { propertyName: "inputTimeRef", first: true, predicate: ["inputTime"], descendants: true }, { propertyName: "inputDatetimeLocalRef", first: true, predicate: ["inputDatetimeLocal"], descendants: true }, { propertyName: "inputNumberRef", first: true, predicate: ["inputNumber"], descendants: true }, { propertyName: "inputRangeRef", first: true, predicate: ["inputRange"], descendants: true }, { propertyName: "inputColorRef", first: true, predicate: ["inputColor"], descendants: true }, { propertyName: "inputBoolRef", first: true, predicate: ["inputBool"], descendants: true }, { propertyName: "inputDatetimeOffsetRef", first: true, predicate: ["inputDatetimeOffset"], descendants: true }, { propertyName: "inputDurationRef", first: true, predicate: ["inputDuration"], descendants: true }, { propertyName: "inputImageRef", first: true, predicate: ["inputImage"], descendants: true }, { propertyName: "inputFileRef", first: true, predicate: ["inputFile"], descendants: true }, { propertyName: "inputDefaultRef", first: true, predicate: ["inputDefault"], descendants: true }], ngImport: i0, template: "<div class=\"grid\">\r\n <div class=\"col\">\r\n <h1>Edit resource</h1>\r\n </div>\r\n</div>\r\n\r\n<p-tabView>\r\n\r\n <p-tabPanel *ngIf=\"isLoadingForTheFirstTime\" header=\"Loading\">\r\n <div *ngFor=\"let i of [1, 2, 3, 4, 5]\" class=\"grid field\">\r\n <p-skeleton class=\"col-12 mb-2 md:col-2 md:mb-0\" height=\"39px\"></p-skeleton>\r\n <div class=\"col-12 md:col-10\">\r\n <p-skeleton class=\"w-full\" height=\"39px\"></p-skeleton>\r\n </div>\r\n </div>\r\n <div class=\"grid\">\r\n <div class=\"col\">\r\n <div class=\"flex justify-content-end w-full\">\r\n <p-skeleton width=\"120px\" height=\"39px\" class=\"mx-2\"></p-skeleton>\r\n <p-skeleton width=\"120px\" height=\"39px\" class=\"mx-2\"></p-skeleton>\r\n <p-skeleton width=\"120px\" height=\"39px\" class=\"mx-2\"></p-skeleton>\r\n </div>\r\n </div>\r\n </div>\r\n </p-tabPanel>\r\n\r\n <p-tabPanel *ngFor=\"let item of templates | keyvalue\" [header]=\"item.value.title || item.key\" [disabled]=\"isLoading\">\r\n <form [formGroup]=\"formTabs[item.key]\" (ngSubmit)=\"submit(item.key, item.value, formTabs[item.key].value)\">\r\n <div class=\"blockable-container\">\r\n <div class=\"blockable-element\">\r\n <rw-form [formGroup]=\"formTabs[item.key]\" [template]=\"item.value\" [apiName]=\"apiName\"></rw-form>\r\n </div>\r\n <div class=\"blockable-overlay\" *ngIf=\"isLoading\">\r\n <p-progressSpinner></p-progressSpinner>\r\n </div>\r\n </div>\r\n\r\n <div class=\"grid\">\r\n <div class=\"col\">\r\n <div class=\"flex justify-content-end w-full\">\r\n <ng-template #defaultButtons>\r\n <button pButton pRipple type=\"submit\" label=\"Save\" icon=\"far fa-save\" class=\"mx-2 p-button-success\" [disabled]=\"isLoading || !canSubmit(item.key)\"></button>\r\n <button pButton pRipple type=\"button\" label=\"Reload\" icon=\"fas fa-redo\" class=\"mx-2 p-button-info\" (click)=\"load()\" [disabled]=\"isLoading\"></button>\r\n <button pButton pRipple type=\"button\" label=\"Delete\" icon=\"far fa-trash-alt\" class=\"ml-2 p-button-danger\" (click)=\"showDeleteConfirmatioModal()\" [disabled]=\"!resource || isLoading || !canDelete\"></button>\r\n </ng-template>\r\n <ng-container *ngTemplateOutlet=\"buttonsRef || defaultButtons\"></ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n </form>\r\n </p-tabPanel>\r\n\r\n <ng-template #defaultExtraTabs>\r\n </ng-template>\r\n <ng-container *ngTemplateOutlet=\"extraTabsRef || defaultExtraTabs\"></ng-container>\r\n\r\n</p-tabView>\r\n\r\n<p-toast></p-toast>\r\n<p-confirmDialog></p-confirmDialog>\r\n", styles: ["::ng-deep .p-tooltip{max-width:-moz-fit-content!important;max-width:fit-content!important}.blockable-container{display:grid;place-items:center;grid-template-areas:\"inner\"}.blockable-element{grid-area:inner;width:100%}.blockable-overlay{grid-area:inner;height:100%;width:100%;background-color:#0006;display:flex;align-items:center;justify-content:center;z-index:1}.field.grid>label.hasChildren{border-right:1px solid rgba(0,0,0,.1)}\n"], components: [{ type: i7.TabView, selector: "p-tabView", inputs: ["orientation", "style", "styleClass", "controlClose", "scrollable", "activeIndex"], outputs: ["onChange", "onClose", "activeIndexChange"] }, { type: i7.TabPanel, selector: "p-tabPanel", inputs: ["closable", "headerStyle", "headerStyleClass", "cache", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "selected", "disabled", "header", "leftIcon", "rightIcon"] }, { type: i8.Skeleton, selector: "p-skeleton", inputs: ["styleClass", "style", "shape", "animation", "borderRadius", "size", "width", "height"] }, { type: i9.RestworldEditFormComponent, selector: "rw-form", inputs: ["formGroup", "template", "apiName"] }, { type: i10.ProgressSpinner, selector: "p-progressSpinner", inputs: ["style", "styleClass", "strokeWidth", "fill", "animationDuration"] }, { type: i11.Toast, selector: "p-toast", inputs: ["key", "autoZIndex", "baseZIndex", "style", "styleClass", "position", "preventOpenDuplicates", "preventDuplicates", "showTransformOptions", "hideTransformOptions", "showTransitionOptions", "hideTransitionOptions", "breakpoints"], outputs: ["onClose"] }, { type: i12.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: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i13.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i13.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i13.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i14.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { type: i15.Ripple, selector: "[pRipple]" }, { type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "keyvalue": i3.KeyValuePipe } });
|
|
224
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: RESTworldEditViewComponent, decorators: [{
|
|
225
|
+
type: Component,
|
|
226
|
+
args: [{ selector: 'rw-edit', template: "<div class=\"grid\">\r\n <div class=\"col\">\r\n <h1>Edit resource</h1>\r\n </div>\r\n</div>\r\n\r\n<p-tabView>\r\n\r\n <p-tabPanel *ngIf=\"isLoadingForTheFirstTime\" header=\"Loading\">\r\n <div *ngFor=\"let i of [1, 2, 3, 4, 5]\" class=\"grid field\">\r\n <p-skeleton class=\"col-12 mb-2 md:col-2 md:mb-0\" height=\"39px\"></p-skeleton>\r\n <div class=\"col-12 md:col-10\">\r\n <p-skeleton class=\"w-full\" height=\"39px\"></p-skeleton>\r\n </div>\r\n </div>\r\n <div class=\"grid\">\r\n <div class=\"col\">\r\n <div class=\"flex justify-content-end w-full\">\r\n <p-skeleton width=\"120px\" height=\"39px\" class=\"mx-2\"></p-skeleton>\r\n <p-skeleton width=\"120px\" height=\"39px\" class=\"mx-2\"></p-skeleton>\r\n <p-skeleton width=\"120px\" height=\"39px\" class=\"mx-2\"></p-skeleton>\r\n </div>\r\n </div>\r\n </div>\r\n </p-tabPanel>\r\n\r\n <p-tabPanel *ngFor=\"let item of templates | keyvalue\" [header]=\"item.value.title || item.key\" [disabled]=\"isLoading\">\r\n <form [formGroup]=\"formTabs[item.key]\" (ngSubmit)=\"submit(item.key, item.value, formTabs[item.key].value)\">\r\n <div class=\"blockable-container\">\r\n <div class=\"blockable-element\">\r\n <rw-form [formGroup]=\"formTabs[item.key]\" [template]=\"item.value\" [apiName]=\"apiName\"></rw-form>\r\n </div>\r\n <div class=\"blockable-overlay\" *ngIf=\"isLoading\">\r\n <p-progressSpinner></p-progressSpinner>\r\n </div>\r\n </div>\r\n\r\n <div class=\"grid\">\r\n <div class=\"col\">\r\n <div class=\"flex justify-content-end w-full\">\r\n <ng-template #defaultButtons>\r\n <button pButton pRipple type=\"submit\" label=\"Save\" icon=\"far fa-save\" class=\"mx-2 p-button-success\" [disabled]=\"isLoading || !canSubmit(item.key)\"></button>\r\n <button pButton pRipple type=\"button\" label=\"Reload\" icon=\"fas fa-redo\" class=\"mx-2 p-button-info\" (click)=\"load()\" [disabled]=\"isLoading\"></button>\r\n <button pButton pRipple type=\"button\" label=\"Delete\" icon=\"far fa-trash-alt\" class=\"ml-2 p-button-danger\" (click)=\"showDeleteConfirmatioModal()\" [disabled]=\"!resource || isLoading || !canDelete\"></button>\r\n </ng-template>\r\n <ng-container *ngTemplateOutlet=\"buttonsRef || defaultButtons\"></ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n </form>\r\n </p-tabPanel>\r\n\r\n <ng-template #defaultExtraTabs>\r\n </ng-template>\r\n <ng-container *ngTemplateOutlet=\"extraTabsRef || defaultExtraTabs\"></ng-container>\r\n\r\n</p-tabView>\r\n\r\n<p-toast></p-toast>\r\n<p-confirmDialog></p-confirmDialog>\r\n", styles: ["::ng-deep .p-tooltip{max-width:-moz-fit-content!important;max-width:fit-content!important}.blockable-container{display:grid;place-items:center;grid-template-areas:\"inner\"}.blockable-element{grid-area:inner;width:100%}.blockable-overlay{grid-area:inner;height:100%;width:100%;background-color:#0006;display:flex;align-items:center;justify-content:center;z-index:1}.field.grid>label.hasChildren{border-right:1px solid rgba(0,0,0,.1)}\n"] }]
|
|
227
|
+
}], ctorParameters: function () { return [{ type: i1.RESTworldClientCollection }, { type: i2.ConfirmationService }, { type: i2.MessageService }, { type: i3.Location }, { type: i4.Router }, { type: i5.FormService }, { type: i6.ValdemortConfig }]; }, propDecorators: { apiName: [{
|
|
228
|
+
type: Input
|
|
229
|
+
}], uri: [{
|
|
230
|
+
type: Input
|
|
231
|
+
}], extraTabsRef: [{
|
|
232
|
+
type: ContentChild,
|
|
233
|
+
args: ['extraTabs', { static: false }]
|
|
234
|
+
}], buttonsRef: [{
|
|
235
|
+
type: ContentChild,
|
|
236
|
+
args: ['buttons', { static: false }]
|
|
237
|
+
}], inputOptionsSingleRef: [{
|
|
238
|
+
type: ContentChild,
|
|
239
|
+
args: ['inputOptionsSingle', { static: false }]
|
|
240
|
+
}], inputOptionsMultipleRef: [{
|
|
241
|
+
type: ContentChild,
|
|
242
|
+
args: ['inputOptionsMultiple', { static: false }]
|
|
243
|
+
}], inputOptionsRef: [{
|
|
244
|
+
type: ContentChild,
|
|
245
|
+
args: ['inputOptions', { static: false }]
|
|
246
|
+
}], inputHiddenRef: [{
|
|
247
|
+
type: ContentChild,
|
|
248
|
+
args: ['inputHidden', { static: false }]
|
|
249
|
+
}], inputTextRef: [{
|
|
250
|
+
type: ContentChild,
|
|
251
|
+
args: ['inputText', { static: false }]
|
|
252
|
+
}], inputTextareaRef: [{
|
|
253
|
+
type: ContentChild,
|
|
254
|
+
args: ['inputTextarea', { static: false }]
|
|
255
|
+
}], inputSearchRef: [{
|
|
256
|
+
type: ContentChild,
|
|
257
|
+
args: ['inputSearch', { static: false }]
|
|
258
|
+
}], inputTelRef: [{
|
|
259
|
+
type: ContentChild,
|
|
260
|
+
args: ['inputTel', { static: false }]
|
|
261
|
+
}], inputUrlRef: [{
|
|
262
|
+
type: ContentChild,
|
|
263
|
+
args: ['inputUrl', { static: false }]
|
|
264
|
+
}], inputEmailRef: [{
|
|
265
|
+
type: ContentChild,
|
|
266
|
+
args: ['inputEmail', { static: false }]
|
|
267
|
+
}], inputPasswordRef: [{
|
|
268
|
+
type: ContentChild,
|
|
269
|
+
args: ['inputPassword', { static: false }]
|
|
270
|
+
}], inputDateRef: [{
|
|
271
|
+
type: ContentChild,
|
|
272
|
+
args: ['inputDate', { static: false }]
|
|
273
|
+
}], inputMonthRef: [{
|
|
274
|
+
type: ContentChild,
|
|
275
|
+
args: ['inputMonth', { static: false }]
|
|
276
|
+
}], inputWeekRef: [{
|
|
277
|
+
type: ContentChild,
|
|
278
|
+
args: ['inputWeek', { static: false }]
|
|
279
|
+
}], inputTimeRef: [{
|
|
280
|
+
type: ContentChild,
|
|
281
|
+
args: ['inputTime', { static: false }]
|
|
282
|
+
}], inputDatetimeLocalRef: [{
|
|
283
|
+
type: ContentChild,
|
|
284
|
+
args: ['inputDatetimeLocal', { static: false }]
|
|
285
|
+
}], inputNumberRef: [{
|
|
286
|
+
type: ContentChild,
|
|
287
|
+
args: ['inputNumber', { static: false }]
|
|
288
|
+
}], inputRangeRef: [{
|
|
289
|
+
type: ContentChild,
|
|
290
|
+
args: ['inputRange', { static: false }]
|
|
291
|
+
}], inputColorRef: [{
|
|
292
|
+
type: ContentChild,
|
|
293
|
+
args: ['inputColor', { static: false }]
|
|
294
|
+
}], inputBoolRef: [{
|
|
295
|
+
type: ContentChild,
|
|
296
|
+
args: ['inputBool', { static: false }]
|
|
297
|
+
}], inputDatetimeOffsetRef: [{
|
|
298
|
+
type: ContentChild,
|
|
299
|
+
args: ['inputDatetimeOffset', { static: false }]
|
|
300
|
+
}], inputDurationRef: [{
|
|
301
|
+
type: ContentChild,
|
|
302
|
+
args: ['inputDuration', { static: false }]
|
|
303
|
+
}], inputImageRef: [{
|
|
304
|
+
type: ContentChild,
|
|
305
|
+
args: ['inputImage', { static: false }]
|
|
306
|
+
}], inputFileRef: [{
|
|
307
|
+
type: ContentChild,
|
|
308
|
+
args: ['inputFile', { static: false }]
|
|
309
|
+
}], inputDefaultRef: [{
|
|
310
|
+
type: ContentChild,
|
|
311
|
+
args: ['inputDefault', { static: false }]
|
|
312
|
+
}] } });
|
|
313
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restworld-edit-view.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-restworld-client/src/lib/views/restworld-edit-view/restworld-edit-view.component.ts","../../../../../../projects/ngx-restworld-client/src/lib/views/restworld-edit-view/restworld-edit-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input } from '@angular/core';\r\nimport { PropertyType, Resource, Template, Templates, FormsResource, Property } from '@wertzui/ngx-hal-client';\r\nimport { RESTworldClient } from '../../services/restworld-client';\r\nimport { RESTworldClientCollection } from '../../services/restworld-client-collection';\r\nimport { AbstractControl, FormControl, FormGroup } from '@angular/forms';\r\nimport { ConfirmationService, MessageService } from 'primeng/api';\r\nimport { Location } from '@angular/common';\r\nimport { Router } from '@angular/router';\r\nimport { ProblemDetails } from '../../models/problem-details';\r\nimport { ContentChild } from '@angular/core';\r\nimport { TemplateRef } from '@angular/core';\r\nimport { ValdemortConfig } from 'ngx-valdemort';\r\nimport { FormService } from '../../services/form.service';\r\n\r\n@Component({\r\n  selector: 'rw-edit',\r\n  templateUrl: './restworld-edit-view.component.html',\r\n  styleUrls: ['./restworld-edit-view.component.css']\r\n})\r\nexport class RESTworldEditViewComponent {\r\n  public get PropertyType() {\r\n    return PropertyType;\r\n  }\r\n  public get templates() {\r\n    return this._templates;\r\n  }\r\n  private _templates: Templates = {};\r\n\r\n  public get isLoadingForTheFirstTime() {\r\n    return Object.keys(this.templates).length === 0 && this.isLoading;\r\n  }\r\n\r\n  public get formTabs() {\r\n    return this._formTabs;\r\n  }\r\n  private _formTabs: { [name: string]: FormGroup } = {};\r\n\r\n  @Input()\r\n  public set apiName(value: string | undefined) {\r\n    this._apiName = value;\r\n    this.load();\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  //}\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 set uri(value: string | undefined) {\r\n    this._uri = value;\r\n    this.load();\r\n  }\r\n  public get uri(): string | undefined {\r\n    return this._uri;\r\n  }\r\n  private _uri?: string;\r\n\r\n  public get resource() {\r\n    return this._resource;\r\n  }\r\n  private _resource?: Resource;\r\n  public isLoading = false;\r\n  public get canSave() {\r\n    const length = this.resource?._links[\"save\"]?.length;\r\n    return length !== undefined && length > 0;\r\n  }\r\n  public get canDelete() {\r\n    const length = this.resource?._links[\"delete\"]?.length;\r\n    return length !== undefined && length > 0;\r\n  }\r\n  public canSubmit(templateName: string) {\r\n    const form = this.formTabs[templateName];\r\n    return form && form.valid;\r\n  }\r\n\r\n  @ContentChild('extraTabs', { static: false })\r\n  extraTabsRef?: TemplateRef<unknown>;\r\n\r\n  @ContentChild('buttons', { static: false })\r\n  buttonsRef?: TemplateRef<unknown>;\r\n\r\n  @ContentChild('inputOptionsSingle', { static: false })\r\n  inputOptionsSingleRef?: TemplateRef<unknown>;\r\n\r\n  @ContentChild('inputOptionsMultiple', { static: false })\r\n  inputOptionsMultipleRef?: TemplateRef<unknown>;\r\n\r\n  @ContentChild('inputOptions', { static: false })\r\n  inputOptionsRef?: TemplateRef<unknown>;\r\n\r\n  @ContentChild('inputHidden', { static: false })\r\n  inputHiddenRef?: TemplateRef<unknown>;\r\n\r\n  @ContentChild('inputText', { static: false })\r\n  inputTextRef?: TemplateRef<unknown>;\r\n\r\n  @ContentChild('inputTextarea', { static: false })\r\n  inputTextareaRef?: TemplateRef<unknown>;\r\n\r\n  @ContentChild('inputSearch', { static: false })\r\n  inputSearchRef?: TemplateRef<unknown>;\r\n\r\n  @ContentChild('inputTel', { static: false })\r\n  inputTelRef?: TemplateRef<unknown>;\r\n\r\n  @ContentChild('inputUrl', { static: false })\r\n  inputUrlRef?: TemplateRef<unknown>;\r\n\r\n  @ContentChild('inputEmail', { static: false })\r\n  inputEmailRef?: TemplateRef<unknown>;\r\n\r\n  @ContentChild('inputPassword', { static: false })\r\n  inputPasswordRef?: TemplateRef<unknown>;\r\n\r\n  @ContentChild('inputDate', { static: false })\r\n  inputDateRef?: TemplateRef<unknown>;\r\n\r\n  @ContentChild('inputMonth', { static: false })\r\n  inputMonthRef?: TemplateRef<unknown>;\r\n\r\n  @ContentChild('inputWeek', { static: false })\r\n  inputWeekRef?: TemplateRef<unknown>;\r\n\r\n  @ContentChild('inputTime', { static: false })\r\n  inputTimeRef?: TemplateRef<unknown>;\r\n\r\n  @ContentChild('inputDatetimeLocal', { static: false })\r\n  inputDatetimeLocalRef?: TemplateRef<unknown>;\r\n\r\n  @ContentChild('inputNumber', { static: false })\r\n  inputNumberRef?: TemplateRef<unknown>;\r\n\r\n  @ContentChild('inputRange', { static: false })\r\n  inputRangeRef?: TemplateRef<unknown>;\r\n\r\n  @ContentChild('inputColor', { static: false })\r\n  inputColorRef?: TemplateRef<unknown>;\r\n\r\n  @ContentChild('inputBool', { static: false })\r\n  inputBoolRef?: TemplateRef<unknown>;\r\n\r\n  @ContentChild('inputDatetimeOffset', { static: false })\r\n  inputDatetimeOffsetRef?: TemplateRef<unknown>;\r\n\r\n  @ContentChild('inputDuration', { static: false })\r\n  inputDurationRef?: TemplateRef<unknown>;\r\n\r\n  @ContentChild('inputImage', { static: false })\r\n  inputImageRef?: TemplateRef<unknown>;\r\n\r\n  @ContentChild('inputFile', { static: false })\r\n  inputFileRef?: TemplateRef<unknown>;\r\n\r\n  @ContentChild('inputDefault', { static: false })\r\n  inputDefaultRef?: TemplateRef<unknown>;\r\n\r\n  constructor(\r\n    private _clients: RESTworldClientCollection,\r\n    private _confirmationService: ConfirmationService,\r\n    private _messageService: MessageService,\r\n    private _location: Location,\r\n    private _router: Router,\r\n    private _formService: FormService,\r\n    valdemortConfig: ValdemortConfig) {\r\n    valdemortConfig.errorClasses = 'p-error text-sm';\r\n  }\r\n\r\n  public getTooltip(resource: Resource, keysToExclude?: string[]): string {\r\n    const tooltip = Object.entries(resource)\r\n      .filter(([key]) => !(key.startsWith('_') || ['createdAt', 'createdBy', 'lastChangedAt', 'lastChangedBy', 'timestamp'].includes(key) || keysToExclude?.includes(key)))\r\n      .reduce((prev, [key, value], index) => `${prev}${index === 0 ? '' : '\\n'}${key}: ${RESTworldEditViewComponent.jsonStringifyWithElipsis(value)}`, '');\r\n\r\n    return tooltip;\r\n  }\r\n\r\n  private static jsonStringifyWithElipsis(value: unknown) {\r\n    const maxLength = 200;\r\n    const end = 10;\r\n    const start = maxLength - end - 2;\r\n    const json = JSON.stringify(value);\r\n    const shortened = json.length > maxLength ? json.substring(0, start) + '…' + json.substring(json.length - end) : json;\r\n\r\n    return shortened;\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 submit(templateName: string, template: Template, formValue: {}) {\r\n    this.isLoading = true;\r\n\r\n    try {\r\n      const targetBeforeSave = template.target;\r\n      const response = await this.getClient().submit(template, formValue);\r\n\r\n      if (!response.ok) {\r\n        let summary = 'Error';\r\n        let detail = 'Error while saving the resource.';\r\n        if (ProblemDetails.isProblemDetails(response.body)) {\r\n          const problemDetails = response.body as ProblemDetails;\r\n          summary = problemDetails.title || summary;\r\n          detail = problemDetails.detail || detail;\r\n          // display validation errors\r\n          if (problemDetails['errors'] as {}) {\r\n            const form = this.formTabs[templateName];\r\n            for (const [key, errorsForKey] of Object.entries(problemDetails['errors'] as {})) {\r\n              const path = key.split(/\\.|\\[/).map(e => e.replace(\"]\", \"\"));\r\n              const formControl = path.reduce<AbstractControl>((control, pathElement) => (control instanceof FormGroup ? control.controls[pathElement] : control) || control, form);\r\n              formControl.setErrors({ remote: errorsForKey });\r\n            }\r\n          }\r\n        }\r\n\r\n        this._messageService.add({ severity: 'error', summary: summary, detail: detail, data: response, life: 10000 });\r\n      }\r\n      else {\r\n        const responseResource = (response.body as FormsResource);\r\n        const targetAfterSave = responseResource._templates[templateName].target;\r\n\r\n        setTimeout(() =>\r\n          this._messageService.add({ severity: 'success', summary: 'Saved', detail: 'The resource has been saved.' }),\r\n          100);\r\n\r\n        if (targetBeforeSave !== targetAfterSave) {\r\n          this._router.navigate(['/edit', this.apiName, responseResource._links.self[0].href]);\r\n        }\r\n      }\r\n\r\n    }\r\n    catch (e: unknown) {\r\n      this._messageService.add({ severity: 'error', summary: 'Error', detail: `An unknown error occurred. ${JSON.stringify(e)}`, life: 10000 });\r\n      console.log(e);\r\n    }\r\n\r\n    this.isLoading = false;\r\n  }\r\n\r\n  public showDeleteConfirmatioModal() {\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()\r\n    });\r\n  }\r\n\r\n  public async delete(): Promise<void> {\r\n    if (!this.apiName || !this.uri || !this.resource)\r\n      return;\r\n\r\n    Object.assign(this.resource, this.formTabs.value);\r\n\r\n    await this.getClient().delete(this.resource);\r\n    setTimeout(() =>\r\n      this._messageService.add({ severity: 'success', summary: 'Deleted', detail: 'The resource has been deleted.' }),\r\n      100);\r\n\r\n    this._location.back();\r\n  }\r\n\r\n  public async load(): Promise<void> {\r\n    if (!this.apiName || !this.uri)\r\n      return;\r\n\r\n    this.isLoading = true;\r\n\r\n    const response = await this.getClient().getSingle(this.uri);\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 resource from the API.', data: response });\r\n    }\r\n    else {\r\n      this._resource = response.body;\r\n      this._templates = await this.getAllTemplates(this._resource);\r\n      this._formTabs = this._formService.createFormGroupsFromTemplates(this._templates);\r\n    }\r\n\r\n    this.isLoading = false;\r\n  }\r\n\r\n  private async setInitialSelectedOptionsElementsForTemplates(templates: Templates) {\r\n    return Promise.all(Object.values(templates)\r\n      .map(template => this.setInitialSelectedOptionsElementsForTemplate(template)));\r\n  }\r\n\r\n  public imageChanged(formControl: FormControl, event: { files: File[] }): void {\r\n    const file = event.files[0];\r\n    console.log(file);\r\n    const reader = new FileReader();\r\n    reader.onload = () => {\r\n      const uri = reader.result;\r\n      console.log(uri);\r\n      formControl.setValue(uri);\r\n    };\r\n    reader.readAsDataURL(file);\r\n  }\r\n\r\n  private async setInitialSelectedOptionsElementsForTemplate(template: Template) {\r\n    return Promise.all(template.properties\r\n      .filter(property => property?.options?.link?.href)\r\n      .map(property => this.setInitialSelectedOptionsElementForProperty(property)));\r\n  }\r\n\r\n  private async setInitialSelectedOptionsElementForProperty(property: Property) {\r\n    const options = property?.options;\r\n\r\n    if (!options?.link?.href)\r\n      return;\r\n\r\n    const templatedUri = options.link.href;\r\n    const filter = `${options.valueField} eq ${property.value}`;\r\n    const response = await this.getClient().getListByUri(templatedUri, { $filter: filter, $top: 10 });\r\n    if (!response.ok || ProblemDetails.isProblemDetails(response.body) || !response.body) {\r\n      const message = `An error occurred while getting the filtered items.`;\r\n      this._messageService.add({ severity: 'error', summary: 'Error', detail: message, data: response });\r\n      return;\r\n    }\r\n\r\n    const items = response.body._embedded.items;\r\n    options.inline = items;\r\n  }\r\n\r\n  private async getAllTemplates(resource: Resource): Promise<Templates> {\r\n    const formResponses = await this.getClient().getAllForms(resource);\r\n\r\n    const failedResponses = formResponses.filter(response => !response.ok || ProblemDetails.isProblemDetails(response.body) || !response.body);\r\n    if (failedResponses.length !== 0) {\r\n      for (const response of failedResponses) {\r\n        this._messageService.add({ severity: 'error', summary: 'Error', detail: 'Error while loading the resource from the API.', data: response });\r\n      }\r\n      return Promise.resolve({});\r\n    }\r\n\r\n    const formTemplates = Object.assign({}, ...formResponses.map(response => (response.body as FormsResource)._templates)) as Templates;\r\n\r\n    await this.setInitialSelectedOptionsElementsForTemplates(formTemplates);\r\n\r\n    return formTemplates;\r\n  }\r\n}\r\n","<div class=\"grid\">\r\n  <div class=\"col\">\r\n    <h1>Edit resource</h1>\r\n  </div>\r\n</div>\r\n\r\n<p-tabView>\r\n\r\n  <p-tabPanel *ngIf=\"isLoadingForTheFirstTime\" header=\"Loading\">\r\n    <div *ngFor=\"let i of [1, 2, 3, 4, 5]\" class=\"grid field\">\r\n      <p-skeleton class=\"col-12 mb-2 md:col-2 md:mb-0\" height=\"39px\"></p-skeleton>\r\n      <div class=\"col-12 md:col-10\">\r\n        <p-skeleton class=\"w-full\" height=\"39px\"></p-skeleton>\r\n      </div>\r\n    </div>\r\n    <div class=\"grid\">\r\n      <div class=\"col\">\r\n        <div class=\"flex justify-content-end w-full\">\r\n          <p-skeleton width=\"120px\" height=\"39px\" class=\"mx-2\"></p-skeleton>\r\n          <p-skeleton width=\"120px\" height=\"39px\" class=\"mx-2\"></p-skeleton>\r\n          <p-skeleton width=\"120px\" height=\"39px\" class=\"mx-2\"></p-skeleton>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </p-tabPanel>\r\n\r\n  <p-tabPanel *ngFor=\"let item of templates | keyvalue\" [header]=\"item.value.title || item.key\" [disabled]=\"isLoading\">\r\n    <form [formGroup]=\"formTabs[item.key]\" (ngSubmit)=\"submit(item.key, item.value, formTabs[item.key].value)\">\r\n      <div class=\"blockable-container\">\r\n        <div class=\"blockable-element\">\r\n          <rw-form [formGroup]=\"formTabs[item.key]\" [template]=\"item.value\" [apiName]=\"apiName\"></rw-form>\r\n        </div>\r\n        <div class=\"blockable-overlay\" *ngIf=\"isLoading\">\r\n          <p-progressSpinner></p-progressSpinner>\r\n        </div>\r\n      </div>\r\n\r\n      <div class=\"grid\">\r\n        <div class=\"col\">\r\n          <div class=\"flex justify-content-end w-full\">\r\n            <ng-template #defaultButtons>\r\n              <button pButton pRipple type=\"submit\" label=\"Save\" icon=\"far fa-save\" class=\"mx-2 p-button-success\" [disabled]=\"isLoading || !canSubmit(item.key)\"></button>\r\n              <button pButton pRipple type=\"button\" label=\"Reload\" icon=\"fas fa-redo\" class=\"mx-2 p-button-info\" (click)=\"load()\" [disabled]=\"isLoading\"></button>\r\n              <button pButton pRipple type=\"button\" label=\"Delete\" icon=\"far fa-trash-alt\" class=\"ml-2 p-button-danger\" (click)=\"showDeleteConfirmatioModal()\" [disabled]=\"!resource || isLoading || !canDelete\"></button>\r\n            </ng-template>\r\n            <ng-container *ngTemplateOutlet=\"buttonsRef || defaultButtons\"></ng-container>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </form>\r\n  </p-tabPanel>\r\n\r\n  <ng-template #defaultExtraTabs>\r\n  </ng-template>\r\n  <ng-container *ngTemplateOutlet=\"extraTabsRef || defaultExtraTabs\"></ng-container>\r\n\r\n</p-tabView>\r\n\r\n<p-toast></p-toast>\r\n<p-confirmDialog></p-confirmDialog>\r\n"]}
|
|
@@ -0,0 +1,57 @@
|
|
|
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 "@angular/common";
|
|
8
|
+
import * as i4 from "primeng/tooltip";
|
|
9
|
+
import * as i5 from "../../pipes/safe-url.pipe";
|
|
10
|
+
export class RESTWorldFileViewComponent {
|
|
11
|
+
constructor() {
|
|
12
|
+
this.disabled = false;
|
|
13
|
+
}
|
|
14
|
+
writeValue(obj) {
|
|
15
|
+
this.uri = obj;
|
|
16
|
+
}
|
|
17
|
+
registerOnChange(fn) {
|
|
18
|
+
this.onChange = fn;
|
|
19
|
+
}
|
|
20
|
+
registerOnTouched() {
|
|
21
|
+
// not needed for this component, but needed to implement the interface
|
|
22
|
+
}
|
|
23
|
+
setDisabledState(isDisabled) {
|
|
24
|
+
this.disabled = isDisabled;
|
|
25
|
+
}
|
|
26
|
+
fileChanged(event) {
|
|
27
|
+
const file = event.files[0];
|
|
28
|
+
const reader = new FileReader();
|
|
29
|
+
reader.onload = () => {
|
|
30
|
+
this.uri = reader.result;
|
|
31
|
+
this.onChange?.(this.uri);
|
|
32
|
+
};
|
|
33
|
+
reader.readAsDataURL(file);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
RESTWorldFileViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: RESTWorldFileViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
37
|
+
RESTWorldFileViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.5", type: RESTWorldFileViewComponent, selector: "rw-file", inputs: { accept: "accept", fileName: "fileName" }, providers: [{
|
|
38
|
+
provide: NG_VALUE_ACCESSOR,
|
|
39
|
+
useExisting: forwardRef(() => RESTWorldFileViewComponent),
|
|
40
|
+
multi: true
|
|
41
|
+
}], 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 file present\"></p-button>\r\n <a *ngIf=\"uri\" [href]=\"uri | safeUrl\" [download]=\"fileName || 'download'\" class=\"mr-1\" pButton pTooltip=\"Download file\" icon=\"pi pi-download\"></a>\r\n <p-fileUpload chooseIcon=\"pi-upload fas fa-upload\" pTooltip=\"Upload new file\" mode=\"basic\" [auto]=\"true\" [accept]=\"accept || 'false'\" [customUpload]=\"true\" (uploadHandler)=\"fileChanged($event)\"></p-fileUpload>\r\n</div>\r\n", styles: ["a{text-decoration:none;height:calc(1rem + 18px)}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", "ariaLabel"], 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"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.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"] }], pipes: { "safeUrl": i5.SafeUrlPipe } });
|
|
42
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: RESTWorldFileViewComponent, decorators: [{
|
|
43
|
+
type: Component,
|
|
44
|
+
args: [{ selector: 'rw-file', providers: [{
|
|
45
|
+
provide: NG_VALUE_ACCESSOR,
|
|
46
|
+
useExisting: forwardRef(() => RESTWorldFileViewComponent),
|
|
47
|
+
multi: true
|
|
48
|
+
}], template: "<div class=\"flex align-items-center\">\r\n <p-button *ngIf=\"!uri\" [disabled]=\"true\" icon=\"pi pi-download\" class=\"mr-1\" pTooltip=\"No file present\"></p-button>\r\n <a *ngIf=\"uri\" [href]=\"uri | safeUrl\" [download]=\"fileName || 'download'\" class=\"mr-1\" pButton pTooltip=\"Download file\" icon=\"pi pi-download\"></a>\r\n <p-fileUpload chooseIcon=\"pi-upload fas fa-upload\" pTooltip=\"Upload new file\" mode=\"basic\" [auto]=\"true\" [accept]=\"accept || 'false'\" [customUpload]=\"true\" (uploadHandler)=\"fileChanged($event)\"></p-fileUpload>\r\n</div>\r\n", styles: ["a{text-decoration:none;height:calc(1rem + 18px)}a.p-button-icon-only span.p-button-label{height:1rem!important}\n"] }]
|
|
49
|
+
}], propDecorators: { accept: [{
|
|
50
|
+
type: Input
|
|
51
|
+
}], fileName: [{
|
|
52
|
+
type: Input
|
|
53
|
+
}], fileUploads: [{
|
|
54
|
+
type: ViewChildren,
|
|
55
|
+
args: [FileUpload]
|
|
56
|
+
}] } });
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzdHdvcmxkLWZpbGUtdmlldy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtcmVzdHdvcmxkLWNsaWVudC9zcmMvbGliL3ZpZXdzL3Jlc3R3b3JsZC1maWxlLXZpZXcvcmVzdHdvcmxkLWZpbGUtdmlldy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtcmVzdHdvcmxkLWNsaWVudC9zcmMvbGliL3ZpZXdzL3Jlc3R3b3JsZC1maWxlLXZpZXcvcmVzdHdvcmxkLWZpbGUtdmlldy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxLQUFLLEVBQWEsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3RGLE9BQU8sRUFBd0IsaUJBQWlCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUN6RSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7Ozs7Ozs7QUFZaEQsTUFBTSxPQUFPLDBCQUEwQjtJQVZ2QztRQXFCUyxhQUFRLEdBQUcsS0FBSyxDQUFDO0tBMEJ6QjtJQXZCQyxVQUFVLENBQUMsR0FBWTtRQUNyQixJQUFJLENBQUMsR0FBRyxHQUFHLEdBQUcsQ0FBQztJQUNqQixDQUFDO0lBQ0QsZ0JBQWdCLENBQUMsRUFBYTtRQUM1QixJQUFJLENBQUMsUUFBUSxHQUFHLEVBQUUsQ0FBQztJQUNyQixDQUFDO0lBQ0QsaUJBQWlCO1FBQ2YsdUVBQXVFO0lBQ3pFLENBQUM7SUFDRCxnQkFBZ0IsQ0FBRSxVQUFtQjtRQUNuQyxJQUFJLENBQUMsUUFBUSxHQUFHLFVBQVUsQ0FBQztJQUM3QixDQUFDO0lBRU0sV0FBVyxDQUFDLEtBQXdCO1FBQ3pDLE1BQU0sSUFBSSxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDNUIsTUFBTSxNQUFNLEdBQUcsSUFBSSxVQUFVLEVBQUUsQ0FBQztRQUNoQyxNQUFNLENBQUMsTUFBTSxHQUFHLEdBQUcsRUFBRTtZQUNuQixJQUFJLENBQUMsR0FBRyxHQUFHLE1BQU0sQ0FBQyxNQUFnQixDQUFDO1lBQ25DLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDNUIsQ0FBQyxDQUFDO1FBRUYsTUFBTSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUM3QixDQUFDOzt1SEFwQ1UsMEJBQTBCOzJHQUExQiwwQkFBMEIsc0ZBTjFCLENBQUM7WUFDVixPQUFPLEVBQUUsaUJBQWlCO1lBQzFCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsMEJBQTBCLENBQUM7WUFDekQsS0FBSyxFQUFFLElBQUk7U0FDWixDQUFDLDBEQVVZLFVBQVUsZ0RDdEIxQixra0JBS0E7MkZEU2EsMEJBQTBCO2tCQVZ0QyxTQUFTOytCQUNFLFNBQVMsYUFHUixDQUFDOzRCQUNWLE9BQU8sRUFBRSxpQkFBaUI7NEJBQzFCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLDJCQUEyQixDQUFDOzRCQUN6RCxLQUFLLEVBQUUsSUFBSTt5QkFDWixDQUFDOzhCQUtLLE1BQU07c0JBRFosS0FBSztnQkFJQyxRQUFRO3NCQURkLEtBQUs7Z0JBSU4sV0FBVztzQkFEVixZQUFZO3VCQUFDLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIGZvcndhcmRSZWYsIElucHV0LCBRdWVyeUxpc3QsIFZpZXdDaGlsZHJlbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29udHJvbFZhbHVlQWNjZXNzb3IsIE5HX1ZBTFVFX0FDQ0VTU09SIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBGaWxlVXBsb2FkIH0gZnJvbSAncHJpbWVuZy9maWxldXBsb2FkJztcclxuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdydy1maWxlJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3Jlc3R3b3JsZC1maWxlLXZpZXcuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9yZXN0d29ybGQtZmlsZS12aWV3LmNvbXBvbmVudC5jc3MnXSxcbiAgcHJvdmlkZXJzOiBbe1xyXG4gICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXHJcbiAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBSRVNUV29ybGRGaWxlVmlld0NvbXBvbmVudCksXHJcbiAgICBtdWx0aTogdHJ1ZVxyXG4gIH1dXG59KVxuZXhwb3J0IGNsYXNzIFJFU1RXb3JsZEZpbGVWaWV3Q29tcG9uZW50IGltcGxlbWVudHMgQ29udHJvbFZhbHVlQWNjZXNzb3Ige1xuICBwcml2YXRlIG9uQ2hhbmdlPzogRnVuY3Rpb247XG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBhY2NlcHQ/OiBzdHJpbmc7XG5cbiAgQElucHV0KClcbiAgcHVibGljIGZpbGVOYW1lPzogc3RyaW5nO1xuXHJcbiAgQFZpZXdDaGlsZHJlbihGaWxlVXBsb2FkKVxyXG4gIGZpbGVVcGxvYWRzPzogUXVlcnlMaXN0PEZpbGVVcGxvYWQ+O1xuXG4gIHB1YmxpYyBkaXNhYmxlZCA9IGZhbHNlO1xuICBwdWJsaWMgdXJpPzogc3RyaW5nO1xyXG5cbiAgd3JpdGVWYWx1ZShvYmo/OiBzdHJpbmcpOiB2b2lkIHtcclxuICAgIHRoaXMudXJpID0gb2JqO1xyXG4gIH1cclxuICByZWdpc3Rlck9uQ2hhbmdlKGZuPzogRnVuY3Rpb24pOiB2b2lkIHtcclxuICAgIHRoaXMub25DaGFuZ2UgPSBmbjtcclxuICB9XHJcbiAgcmVnaXN0ZXJPblRvdWNoZWQoKTogdm9pZCB7XHJcbiAgICAvLyBub3QgbmVlZGVkIGZvciB0aGlzIGNvbXBvbmVudCwgYnV0IG5lZWRlZCB0byBpbXBsZW1lbnQgdGhlIGludGVyZmFjZVxyXG4gIH1cclxuICBzZXREaXNhYmxlZFN0YXRlPyhpc0Rpc2FibGVkOiBib29sZWFuKTogdm9pZCB7XHJcbiAgICB0aGlzLmRpc2FibGVkID0gaXNEaXNhYmxlZDtcclxuICB9XG5cbiAgcHVibGljIGZpbGVDaGFuZ2VkKGV2ZW50OiB7IGZpbGVzOiBGaWxlW10gfSk6IHZvaWQge1xyXG4gICAgY29uc3QgZmlsZSA9IGV2ZW50LmZpbGVzWzBdO1xyXG4gICAgY29uc3QgcmVhZGVyID0gbmV3IEZpbGVSZWFkZXIoKTtcclxuICAgIHJlYWRlci5vbmxvYWQgPSAoKSA9PiB7XHJcbiAgICAgIHRoaXMudXJpID0gcmVhZGVyLnJlc3VsdCBhcyBzdHJpbmc7XHJcbiAgICAgIHRoaXMub25DaGFuZ2U/Lih0aGlzLnVyaSk7XHJcbiAgICB9O1xyXG5cclxuICAgIHJlYWRlci5yZWFkQXNEYXRhVVJMKGZpbGUpO1xyXG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJmbGV4IGFsaWduLWl0ZW1zLWNlbnRlclwiPlxyXG4gIDxwLWJ1dHRvbiAqbmdJZj1cIiF1cmlcIiBbZGlzYWJsZWRdPVwidHJ1ZVwiIGljb249XCJwaSBwaS1kb3dubG9hZFwiIGNsYXNzPVwibXItMVwiIHBUb29sdGlwPVwiTm8gZmlsZSBwcmVzZW50XCI+PC9wLWJ1dHRvbj5cclxuICA8YSAqbmdJZj1cInVyaVwiIFtocmVmXT1cInVyaSB8IHNhZmVVcmxcIiBbZG93bmxvYWRdPVwiZmlsZU5hbWUgfHwgJ2Rvd25sb2FkJ1wiIGNsYXNzPVwibXItMVwiIHBCdXR0b24gcFRvb2x0aXA9XCJEb3dubG9hZCBmaWxlXCIgaWNvbj1cInBpIHBpLWRvd25sb2FkXCI+PC9hPlxyXG4gIDxwLWZpbGVVcGxvYWQgY2hvb3NlSWNvbj1cInBpLXVwbG9hZCBmYXMgZmEtdXBsb2FkXCIgcFRvb2x0aXA9XCJVcGxvYWQgbmV3IGZpbGVcIiBtb2RlPVwiYmFzaWNcIiBbYXV0b109XCJ0cnVlXCIgW2FjY2VwdF09XCJhY2NlcHQgfHwgJ2ZhbHNlJ1wiIFtjdXN0b21VcGxvYWRdPVwidHJ1ZVwiICh1cGxvYWRIYW5kbGVyKT1cImZpbGVDaGFuZ2VkKCRldmVudClcIj48L3AtZmlsZVVwbG9hZD5cclxuPC9kaXY+XHJcbiJdfQ==
|
|
@@ -0,0 +1,100 @@
|
|
|
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
|
+
this.uri = this.tempCroppedUri;
|
|
53
|
+
this.onChange?.(this.uri);
|
|
54
|
+
this.closeCropDialog();
|
|
55
|
+
}
|
|
56
|
+
closeCropDialog() {
|
|
57
|
+
this.fileUploads?.forEach(f => f.clear());
|
|
58
|
+
this.displayCropDialog = false;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
RESTWorldImageViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: RESTWorldImageViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
62
|
+
RESTWorldImageViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.5", 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: [{
|
|
63
|
+
provide: NG_VALUE_ACCESSOR,
|
|
64
|
+
useExisting: forwardRef(() => RESTWorldImageViewComponent),
|
|
65
|
+
multi: true
|
|
66
|
+
}], 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 + 18px);cursor:zoom-in;border-radius:3px}a{text-decoration:none;height:calc(1rem + 18px)}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", "ariaLabel"], 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: ["imageChangedEvent", "imageURL", "imageBase64", "imageFile", "format", "transform", "maintainAspectRatio", "aspectRatio", "resizeToWidth", "resizeToHeight", "cropperMinWidth", "cropperMinHeight", "cropperMaxHeight", "cropperMaxWidth", "cropperStaticWidth", "cropperStaticHeight", "canvasRotation", "initialStepSize", "roundCropper", "onlyScaleDown", "imageQuality", "autoCrop", "backgroundColor", "containWithinAspectRatio", "hideResizeSquares", "cropper", "alignImage", "disabled"], 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 } });
|
|
67
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: RESTWorldImageViewComponent, decorators: [{
|
|
68
|
+
type: Component,
|
|
69
|
+
args: [{ selector: 'rw-image', providers: [{
|
|
70
|
+
provide: NG_VALUE_ACCESSOR,
|
|
71
|
+
useExisting: forwardRef(() => RESTWorldImageViewComponent),
|
|
72
|
+
multi: true
|
|
73
|
+
}], 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 + 18px);cursor:zoom-in;border-radius:3px}a{text-decoration:none;height:calc(1rem + 18px)}a.p-button-icon-only span.p-button-label{height:1rem!important}\n"] }]
|
|
74
|
+
}], propDecorators: { alt: [{
|
|
75
|
+
type: Input
|
|
76
|
+
}], accept: [{
|
|
77
|
+
type: Input
|
|
78
|
+
}], fileName: [{
|
|
79
|
+
type: Input
|
|
80
|
+
}], maintainAspectRatio: [{
|
|
81
|
+
type: Input
|
|
82
|
+
}], aspectRatio: [{
|
|
83
|
+
type: Input
|
|
84
|
+
}], resizeToWidth: [{
|
|
85
|
+
type: Input
|
|
86
|
+
}], resizeToHeight: [{
|
|
87
|
+
type: Input
|
|
88
|
+
}], onlyScaleDown: [{
|
|
89
|
+
type: Input
|
|
90
|
+
}], containWithinAspectRatio: [{
|
|
91
|
+
type: Input
|
|
92
|
+
}], backgroundColor: [{
|
|
93
|
+
type: Input
|
|
94
|
+
}], format: [{
|
|
95
|
+
type: Input
|
|
96
|
+
}], fileUploads: [{
|
|
97
|
+
type: ViewChildren,
|
|
98
|
+
args: [FileUpload]
|
|
99
|
+
}] } });
|
|
100
|
+
//# 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":"AAAA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAa,YAAY,EAAE,MAAM,eAAe,CAAC;AACtF,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAEzE,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;;;;;;;;;;;;;AAYhD,MAAM,OAAO,2BAA2B;IAVxC;QAqBE,wBAAmB,GAAG,IAAI,CAAC;QAE3B,gBAAW,GAAG,CAAC,CAAC;QAEhB,kBAAa,GAAG,CAAC,CAAC;QAElB,mBAAc,GAAG,CAAC,CAAC;QAEnB,kBAAa,GAAG,KAAK,CAAC;QAEtB,6BAAwB,GAAG,KAAK,CAAC;QAEjC,oBAAe,GAAG,SAAS,CAAC;QAErB,WAAM,GAAiB,KAAK,CAAC;QAO7B,aAAQ,GAAG,KAAK,CAAC;QAGjB,sBAAiB,GAAG,KAAK,CAAC;KAwClC;IArCC,UAAU,CAAC,GAAmB;QAC5B,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;IACjB,CAAC;IACD,gBAAgB,CAAC,EAAa;QAC5B,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IACD,iBAAiB;QACf,uEAAuE;IACzE,CAAC;IAED,gBAAgB,CAAE,UAAmB;QACnC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;IAC7B,CAAC;IAEM,cAAc;QACnB,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;IAChC,CAAC;IAEM,YAAY,CAAC,KAAwB;QAC1C,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACpC,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEM,mBAAmB,CAAC,KAAwB;QACjD,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC,MAAM,CAAC;IACrC,CAAC;IAEM,kBAAkB;QACvB,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,cAAc,CAAC;QAC/B,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC1B,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAEM,eAAe;QACpB,IAAI,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC;QAC1C,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;IACjC,CAAC;;wHA1EU,2BAA2B;4GAA3B,2BAA2B,yXAN3B,CAAC;YACV,OAAO,EAAE,iBAAiB;YAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,2BAA2B,CAAC;YAC1D,KAAK,EAAE,IAAI;SACZ,CAAC,0DA8BY,UAAU,gDC3C1B,+/DA+BA;2FDhBa,2BAA2B;kBAVvC,SAAS;+BACE,UAAU,aAGT,CAAC;4BACV,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,4BAA4B,CAAC;4BAC1D,KAAK,EAAE,IAAI;yBACZ,CAAC;8BAOK,GAAG;sBADT,KAAK;gBAGC,MAAM;sBADZ,KAAK;gBAGC,QAAQ;sBADd,KAAK;gBAGN,mBAAmB;sBADlB,KAAK;gBAGN,WAAW;sBADV,KAAK;gBAGN,aAAa;sBADZ,KAAK;gBAGN,cAAc;sBADb,KAAK;gBAGN,aAAa;sBADZ,KAAK;gBAGN,wBAAwB;sBADvB,KAAK;gBAGN,eAAe;sBADd,KAAK;gBAGC,MAAM;sBADZ,KAAK;gBAKN,WAAW;sBADV,YAAY;uBAAC,UAAU","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"]}
|